Mercurial > hg > Gears > GearsAgda
changeset 338:0d720487291f
remove stub from RedBlackTree.cbc
author | mir3636 |
---|---|
date | Tue, 09 May 2017 12:08:29 +0900 |
parents | 5bca0ff563e6 |
children | 720e272299ad |
files | src/parallel_execution/RedBlackTree.cbc src/parallel_execution/generate_context.pl |
diffstat | 2 files changed, 39 insertions(+), 57 deletions(-) [+] |
line wrap: on
line diff
--- a/src/parallel_execution/RedBlackTree.cbc Tue May 02 21:27:39 2017 +0900 +++ b/src/parallel_execution/RedBlackTree.cbc Tue May 09 12:08:29 2017 +0900 @@ -93,7 +93,7 @@ tree->current = newNode; nodeStack->stack = (union Data*)tree->nodeStack; nodeStack->next = C_insertCase1; - goto meta(context, traverse->nodeStack->get2); + goto meta(context, tree->nodeStack->get2); } __code insertCase1(struct RedBlackTree* tree, struct Node *parent, struct Node *grandparent) { @@ -148,7 +148,7 @@ tree->current = tree->current->left; tree->parent = tree->grandparent; - rotateTree->tree = tree; + rotateTree->traverse = tree; rotateTree->next = C_insertCase5; nodeStack->stack = (union Data*)tree->nodeStack; @@ -158,7 +158,7 @@ tree->parent = tree->grandparent; tree->current = tree->current->right; - rotateTree->tree = tree; + rotateTree->traverse = tree; rotateTree->next = C_insertCase5; nodeStack->stack = (union Data*)tree->nodeStack; @@ -169,26 +169,23 @@ goto meta(context, C_insertCase5); } -__code insertCase5(struct RedBlackTree* traverse,struct Stack *nodeStack) { - nodeStack->stack = (union Data*)traverse->nodeStack; +__code insertCase5(struct RedBlackTree* tree, struct Stack* nodeStack) { + nodeStack->stack = (union Data*)tree->nodeStack; nodeStack->next = C_insertCase51; - goto meta(context, traverse->nodeStack->pop2); + goto meta(context, tree->nodeStack->pop2); } -__code insertCase5_stub(struct Context* context) { - goto insertCase5(context, &Gearef(context, Tree)->tree->Tree.tree->RedBlackTree, Gearef(context, Stack)); -} - -__code insertCase51(struct RedBlackTree* traverse, struct RotateTree *rotateTree, struct Node* current, struct Node* parent, struct Node* grandparent) { - traverse->parent = parent; - traverse->grandparent = grandparent; +__code insertCase51(struct RedBlackTree* tree, struct RotateTree* rotateTree, struct Node* parent, struct Node* grandparent) { + struct Node* current = tree->current; + tree->parent = parent; + tree->grandparent = grandparent; parent->color = Black; grandparent->color = Red; - traverse->current = grandparent; + tree->current = grandparent; - rotateTree->traverse = traverse; + rotateTree->traverse = tree; rotateTree->next = C_stackClear; if ((current == parent->left) && (parent == grandparent->left)) @@ -203,23 +200,22 @@ goto insertCase51(context, &Gearef(context, Tree)->tree->Tree.tree->RedBlackTree, Gearef(context, RotateTree), - Gearef(context, Tree)->tree->Tree.tree->RedBlackTree.current, parent, grandparent); } -__code rotateLeft(struct RedBlackTree* traverse,struct Stack* nodeStack) { - nodeStack->stack = (union Data*)traverse->nodeStack; +__code rotateLeft(struct RedBlackTree* tree, struct Stack* nodeStack) { + nodeStack->stack = (union Data*)tree->nodeStack; nodeStack->next = C_rotateLeft1; - goto meta(context, traverse->nodeStack->get); + goto meta(context, tree->nodeStack->get); } __code rotateLeft_stub(struct Context* context) { struct RedBlackTree* traverse = context->data[D_RotateTree]->RotateTree.traverse; goto rotateLeft(context, traverse, Gearef(context, Stack)); } - -__code rotateLeft1(struct Node* node, struct RedBlackTree* traverse, struct Node *parent,struct RotateTree *rotateTree) { + +__code rotateLeft1(struct Node* node, struct RedBlackTree* tree, struct Node* parent, struct RotateTree* rotateTree) { struct Node* tmp = node->right; if (parent) { @@ -228,16 +224,16 @@ else parent->right = tmp; } else { - traverse->root = tmp; + tree->root = tmp; } node->right = tmp->left; tmp->left = node; - traverse->current = tmp; + tree->current = tmp; goto meta(context, rotateTree->next); } - + __code rotateLeft1_stub(struct Context* context) { struct RedBlackTree* traverse = context->data[D_RotateTree]->RotateTree.traverse; struct Node* parent = &context->data[D_Stack]->Stack.data->Node; @@ -248,10 +244,10 @@ Gearef(context, RotateTree)); } -__code rotateRight(struct RedBlackTree* traverse,struct Stack *nodeStack) { - nodeStack->stack = (union Data*)traverse->nodeStack; +__code rotateRight(struct RedBlackTree* tree, struct Stack* nodeStack) { + nodeStack->stack = (union Data*)tree->nodeStack; nodeStack->next = C_rotateRight1; - goto meta(context, traverse->nodeStack->get); + goto meta(context, tree->nodeStack->get); } __code rotateRight_stub(struct Context* context) { @@ -288,22 +284,16 @@ Gearef(context, RotateTree)); } -__code stackClear(struct RedBlackTree* traverse,struct Stack *nodeStack, __code next(...)) { - traverse->current = 0; - nodeStack->stack = (union Data*)traverse->nodeStack; +__code stackClear(struct RedBlackTree* tree, struct Stack* nodeStack, __code next(...)) { + tree->current = 0; + nodeStack->stack = (union Data*)tree->nodeStack; nodeStack->next = next; - goto meta(context, traverse->nodeStack->clear); + goto meta(context, tree->nodeStack->clear); } -__code stackClear_stub(struct Context* context) { - goto stackClear(context, &Gearef(context, Tree)->tree->Tree.tree->RedBlackTree, Gearef(context, Stack), - Gearef(context, Tree)->next); -} - - -__code getRedBlackTree(struct RedBlackTree* traverse, __code next(...)) { - if (traverse->root) { - traverse->current = traverse->root; +__code getRedBlackTree(struct RedBlackTree* tree, __code next(...)) { + if (tree->root) { + tree->current = tree->root; goto meta(context, C_search); } @@ -311,33 +301,25 @@ goto next(...); } -__code getRedBlackTree_stub(struct Context* context) { - goto getRedBlackTree(context, &Gearef(context, Tree)->tree->Tree.tree->RedBlackTree, Gearef(context, Tree)->next); -} - -__code search(struct RedBlackTree* traverse, struct Node* node, __code next(...)) { +__code search(struct RedBlackTree* tree, struct Node* node, __code next(...)) { // compare(context, traverse, traverse->current->key, node->key); - traverse->result = compare(traverse->current, node); - if (traverse->result == EQ) { - *node = *traverse->current; + tree->result = compare(tree->current, node); + if (tree->result == EQ) { + *node = *tree->current; goto meta(context, next); - } else if (traverse->result == GT) { - traverse->current = traverse->current->right; + } else if (tree->result == GT) { + tree->current = tree->current->right; } else { - traverse->current = traverse->current->left; + tree->current = tree->current->left; } - if (traverse->current) + if (tree->current) goto meta(context, C_search); goto next(...); } -__code search_stub(struct Context* context) { - goto search(context, &Gearef(context, Tree)->tree->Tree.tree->RedBlackTree, Gearef(context, Node), Gearef(context, Tree)->next); -} - /* /\* __code delete(struct Context* context, struct Tree* tree) { *\/ */ /* /\* if (tree->root) { *\/ */ /* /\* stack_push(context->code_stack, &context->next); *\/ */
--- a/src/parallel_execution/generate_context.pl Tue May 02 21:27:39 2017 +0900 +++ b/src/parallel_execution/generate_context.pl Tue May 09 12:08:29 2017 +0900 @@ -74,7 +74,7 @@ my (%mCodeGear) = (%codeGear); # anyway we gather all Gears Information -while (<*.c test/*.c>) { +while (<*.c test/*.c $ddir/*.c $ddir/test/*.c>) { next if (/context.c/); &getStubInfo($_); }