taskrambler
v0.1.8
Web server and task management solution.
Main Page
Related Pages
Data Structures
Files
File List
Globals
rotateLeft.c
Go to the documentation of this file.
1
/**
2
* \file
3
*
4
* \author Georg Hopp
5
*
6
* \copyright
7
* Copyright © 2012 Georg Hopp
8
*
9
* This program is free software: you can redistribute it and/or modify
10
* it under the terms of the GNU General Public License as published by
11
* the Free Software Foundation, either version 3 of the License, or
12
* (at your option) any later version.
13
*
14
* This program is distributed in the hope that it will be useful,
15
* but WITHOUT ANY WARRANTY; without even the implied warranty of
16
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17
* GNU General Public License for more details.
18
*
19
* You should have received a copy of the GNU General Public License
20
* along with this program. If not, see <http://www.gnu.org/licenses/>.
21
*/
22
23
#include "
tree.h
"
24
25
void
26
treeRotateLeft
(Tree *
this
, Tree node)
27
{
28
Tree rightChild =
TREE_RIGHT
(node);
29
Tree rcLeftSub =
TREE_RIGHT_LEFT
(node);
30
31
rightChild->left = node;
32
rightChild->parent =
TREE_PARENT
(node);
33
node->right = rcLeftSub;
34
if
(NULL != rcLeftSub) {
35
rcLeftSub->parent = node;
36
}
37
38
if
(NULL !=
TREE_PARENT
(node)) {
39
if
(
TREE_PARENT
(node)->left == node) {
40
TREE_PARENT
(node)->left = rightChild;
41
}
else
{
42
TREE_PARENT
(node)->right = rightChild;
43
}
44
}
else
{
45
*
this
= rightChild;
46
}
47
48
node->parent = rightChild;
49
}
50
51
// vim: set ts=4 sw=4:
TREE_RIGHT
#define TREE_RIGHT(node)
Definition:
tree.h:28
treeRotateLeft
void treeRotateLeft(Tree *this, Tree node)
Definition:
rotateLeft.c:26
TREE_PARENT
#define TREE_PARENT(node)
Definition:
tree.h:30
tree.h
TREE_RIGHT_LEFT
#define TREE_RIGHT_LEFT(node)
Definition:
tree.h:35
src
tree
rotateLeft.c
Generated on Wed Apr 13 2016 12:25:16 for taskrambler by
1.8.10