# HG changeset patch # User mir3636 # Date 1478594103 -32400 # Node ID 909d0548284fd337a5b02b550a21151704d1ba2f # Parent a747dc9d4da6d61afd85fc02d973020510a44705 fix stackClear diff -r a747dc9d4da6 -r 909d0548284f src/parallel_execution/CMakeLists.txt --- a/src/parallel_execution/CMakeLists.txt Tue Nov 08 15:01:08 2016 +0900 +++ b/src/parallel_execution/CMakeLists.txt Tue Nov 08 17:35:03 2016 +0900 @@ -1,7 +1,8 @@ cmake_minimum_required(VERSION 2.8) # -DUSE_CUDA -add_definitions("-Wall -g -O") +# add_definitions("-Wall -g -O") +add_definitions("-Wall -g") set(CMAKE_C_COMPILER $ENV{CBC_COMPILER}) diff -r a747dc9d4da6 -r 909d0548284f src/parallel_execution/rb_tree.c --- a/src/parallel_execution/rb_tree.c Tue Nov 08 15:01:08 2016 +0900 +++ b/src/parallel_execution/rb_tree.c Tue Nov 08 17:35:03 2016 +0900 @@ -113,8 +113,8 @@ context->data[Traverse]->traverse.newNode); } -__code insertCase1(struct Context* context, struct Tree* tree, struct Stack* nodeStack) { - if (nodeStack != NULL) { +__code insertCase1(struct Context* context, struct Tree* tree, struct SingleLinkedStack* nodeStack) { + if (nodeStack->top != NULL) { goto meta(context, InsertCase2); } tree->root->color = Black; @@ -124,7 +124,7 @@ __code insert1_stub(struct Context* context) { goto insertCase1(context, &context->data[Tree]->tree, - context->data[Traverse]->traverse.nodeStack); + &context->data[Traverse]->traverse.nodeStack->stack->singleLinkedStack); } __code insertCase2(struct Context* context, struct Stack* nodeStack, struct Node* parent) { @@ -136,7 +136,8 @@ } __code insert2_stub(struct Context* context) { - goto insertCase2(context, context->data[Traverse]->traverse.nodeStack, (struct Node*)context->data[Traverse]->traverse.nodeStack->data); + struct SingleLinkedStack *nodeStack = (struct SingleLinkedStack*)context->data[Traverse]->traverse.nodeStack->stack; + goto insertCase2(context, context->data[Traverse]->traverse.nodeStack, &nodeStack->top->data->node); } __code insertCase3(struct Context* context, struct Traverse* traverse, struct Node* parent, struct Node* grandparent) { @@ -304,7 +305,8 @@ __code stackClear(struct Context* context, struct Traverse* traverse) { traverse->current = 0; - traverse->nodeStack = NULL; + struct SingleLinkedStack* nodeStack = &context->data[Traverse]->traverse.nodeStack->stack->singleLinkedStack; + nodeStack->top = NULL; goto meta(context, context->next); }