diff nodejs/coord.cc @ 745:4ccb0553e804

Refactor code of free C objects into xnjsmb_coord_free_subtree
author Thinker K.F. Li <thinker@codemud.net>
date Wed, 25 Aug 2010 14:43:48 +0800
parents 6a988e23ad2a
children 1dbc74a14199
line wrap: on
line diff
--- a/nodejs/coord.cc	Wed Aug 25 14:23:06 2010 +0800
+++ b/nodejs/coord.cc	Wed Aug 25 14:43:48 2010 +0800
@@ -68,26 +68,44 @@
  * \sa \ref jsgc
  */
 static void
-xnjsmb_coord_invalidate_subtree(Handle<Object> self) {
+xnjsmb_coord_invalidate_subtree(coord_t *coord) {
     Persistent<Object> *child_hdl;
     Persistent<Object> *mem_hdl;
-    coord_t *coord, *child, *last_child;
-    Handle<Object> js_rt;
-    redraw_man_t *rdman;
-    shape_t *mem, *last_mem;
+    coord_t *child;
+    shape_t *mem;
     Handle<Value> _false = Boolean::New(0);
-    int r;
 
-    if(!GET(self, "valid")->ToBoolean()->Value()) /* Invalidated object */
-	return;
+    /* Invalidate all coords in the subtree */
+    FOR_COORDS_PREORDER(coord, child) {
+	child_hdl = (Persistent<Object> *)mb_prop_get(&child->obj.props,
+						      PROP_JSOBJ);
+	SET(*child_hdl, "valid", _false);
+	WRAP(*child_hdl, NULL);
+	
+	/* Invalidate members of a coord */
+	FOR_COORD_SHAPES(child, mem) {
+	    mem_hdl = (Persistent<Object> *)mb_prop_get(&mem->obj.props,
+							PROP_JSOBJ);
+	    SET(*mem_hdl, "valid", _false);
+	    WRAP(*mem_hdl, NULL);
+	}
+    }
+}
+
+/*! \brief Free C objects for coords and shapes in a subtree.
+ *
+ * \param self is the object of the root of subtree.
+ *
+ * \sa \ref jsgc
+ */
+static void
+xnjsmb_coord_free_subtree(redraw_man_t *rdman, coord_t *coord) {
+    coord_t *child, *last_child;
+    shape_t *mem, *last_mem;
+    int r;
     
-    js_rt = GET(self, "mbrt")->ToObject();
-    rdman = xnjsmb_rt_rdman(js_rt);
-    
-    coord = (coord_t *)UNWRAP(self);
     rdman_coord_changed(rdman, coord);
     
-    /* Invalidate all coords in the subtree */
     last_child = NULL;
     FOR_COORDS_POSTORDER(coord, child) {
 	if(last_child != NULL) {
@@ -95,13 +113,8 @@
 	    if(r != OK)
 		THROW_noret("Unknown error");
 	}
-
-	child_hdl = (Persistent<Object> *)mb_prop_get(&child->obj.props,
-						      PROP_JSOBJ);
-	SET(*child_hdl, "valid", _false);
-	WRAP(*child_hdl, NULL);
 	
-	/* Invalidate members of a coord */
+	/* Free members of a coord */
 	last_mem = NULL;
 	FOR_COORD_SHAPES(child, mem) {
 	    if(last_mem != NULL) {
@@ -110,11 +123,6 @@
 		    THROW_noret("Unknown error");
 	    }
 
-	    mem_hdl = (Persistent<Object> *)mb_prop_get(&mem->obj.props,
-							PROP_JSOBJ);
-	    SET(*mem_hdl, "valid", _false);
-	    WRAP(*mem_hdl, NULL);
-	    
 	    last_mem = mem;
 	}
 	if(last_mem != NULL) {
@@ -197,8 +205,18 @@
 }
 
 static void
-xnjsmb_coord_remove(coord_t *coord, Handle<Object> self, const char **err) {
-    xnjsmb_coord_invalidate_subtree(self);
+xnjsmb_coord_remove(coord_t *coord, Handle<Object> self) {
+    Handle<Object> js_rt;
+    redraw_man_t *rdman;
+    
+    if(!GET(self, "valid")->ToBoolean()->Value()) /* Invalidated object */
+	THROW_noret("Invalid object");
+    
+    js_rt = GET(self, "mbrt")->ToObject();
+    rdman = xnjsmb_rt_rdman(js_rt);
+
+    xnjsmb_coord_invalidate_subtree(coord);
+    xnjsmb_coord_free_subtree(rdman, coord);
 }
 
 #include "coord-inc.h"