diff options
Diffstat (limited to 'src/html/html_text_area_element.c')
-rw-r--r-- | src/html/html_text_area_element.c | 44 |
1 files changed, 41 insertions, 3 deletions
diff --git a/src/html/html_text_area_element.c b/src/html/html_text_area_element.c index bbc9789..6117e83 100644 --- a/src/html/html_text_area_element.c +++ b/src/html/html_text_area_element.c @@ -301,10 +301,48 @@ void _dom_virtual_html_text_area_element_destroy(dom_node_internal *node) } /* The virtual copy function, see src/core/node.c for detail */ -dom_exception _dom_html_text_area_element_copy(dom_node_internal *old, - dom_node_internal **copy) +dom_exception _dom_html_text_area_element_copy( + dom_node_internal *old, dom_node_internal **copy) { - return _dom_html_element_copy(old, copy); + dom_html_text_area_element *new_node; + dom_exception err; + + new_node = malloc(sizeof(dom_html_text_area_element)); + if (new_node == NULL) + return DOM_NO_MEM_ERR; + + err = dom_html_text_area_element_copy_internal(old, new_node); + if (err != DOM_NO_ERR) { + free(new_node); + return err; + } + + *copy = (dom_node_internal *) new_node; + + return DOM_NO_ERR; +} + +dom_exception _dom_html_text_area_element_copy_internal( + dom_html_text_area_element *old, + dom_html_text_area_element *new) +{ + dom_exception err; + + err = dom_html_element_copy_internal(old, new); + if (err != DOM_NO_ERR) { + return err; + } + + /* TODO: We don't seem to keep a ref to form element, so just + * copy the pointer for now. */ + new->form = old->form; + + new->default_value = dom_string_ref(old->default_value); + new->default_value_set = old->default_value_set; + new->value = dom_string_ref(old->value); + new->value_set = old->value_set; + + return DOM_NO_ERR; } /*-----------------------------------------------------------------------*/ |