finish tree view
This commit is contained in:
parent
1408cca6b7
commit
fd25215671
82
src/main.c
82
src/main.c
|
@ -2,32 +2,68 @@
|
|||
|
||||
#include "node.h"
|
||||
|
||||
int main(int argc, char** argv){
|
||||
NOD_Node* node = NOD_CreateNode("Main Node");
|
||||
NOD_Node* child1 = NOD_CreateNode("First child");
|
||||
NOD_Node* child1child1 = NOD_CreateNode("Child of first child");
|
||||
NOD_Node* child2 = NOD_CreateNode("Second child");
|
||||
NOD_Node* child3 = NOD_CreateNode("Third child");
|
||||
NOD_Node* child3child1 = NOD_CreateNode("First child of third child");
|
||||
NOD_Node* child3child2 = NOD_CreateNode("Second child of third child");
|
||||
int main(int argc, char* *argv){
|
||||
NOD_Node *distros = NOD_CreateNode("Distros");
|
||||
NOD_Node *linoox = NOD_CreateNode("GNU/Linux");
|
||||
NOD_Node *debian = NOD_CreateNode("Debian");
|
||||
NOD_Node *ubuntu = NOD_CreateNode("Ubuntu");
|
||||
NOD_Node *mint = NOD_CreateNode("Linux Mint");
|
||||
NOD_Node *devuan = NOD_CreateNode("Devuan");
|
||||
NOD_Node *kali = NOD_CreateNode("Kali Linux");
|
||||
NOD_Node *voidlinux = NOD_CreateNode("Void Linux");
|
||||
NOD_Node *arch = NOD_CreateNode("Arch");
|
||||
NOD_Node *manjaro = NOD_CreateNode("Manjaro");
|
||||
NOD_Node *parabola = NOD_CreateNode("Parabola");
|
||||
NOD_Node *endeavouros = NOD_CreateNode("EndeavourOS");
|
||||
NOD_Node *bsd = NOD_CreateNode("BSD");
|
||||
NOD_Node *freebsd = NOD_CreateNode("FreeBSD");
|
||||
NOD_Node *openbsd = NOD_CreateNode("OpenBSD");
|
||||
NOD_Node *debianbsd = NOD_CreateNode("Debian GNU/kFreeBSD");
|
||||
|
||||
NOD_NodeAddChild(node, child1);
|
||||
NOD_NodeAddChild(child1, child1child1);
|
||||
NOD_NodeAddChild(node, child2);
|
||||
NOD_NodeAddChild(node, child3);
|
||||
NOD_NodeAddChild(child3, child3child1);
|
||||
NOD_NodeAddChild(child3, child3child2);
|
||||
NOD_NodeAddChild(distros, linoox);
|
||||
NOD_NodeAddChild(distros, bsd);
|
||||
|
||||
NOD_NodeUnparent(child2);
|
||||
NOD_NodeAddChild(linoox, debian);
|
||||
NOD_NodeAddChild(linoox, voidlinux);
|
||||
NOD_NodeAddChild(linoox, arch);
|
||||
|
||||
NOD_PrintNodeTree(node);
|
||||
NOD_NodeAddChild(debian, ubuntu);
|
||||
NOD_NodeAddChild(debian, devuan);
|
||||
NOD_NodeAddChild(debian, kali);
|
||||
|
||||
NOD_DestroyNode(node);
|
||||
NOD_DestroyNode(child1);
|
||||
NOD_DestroyNode(child1child1);
|
||||
NOD_DestroyNode(child2);
|
||||
NOD_DestroyNode(child3);
|
||||
NOD_DestroyNode(child3child1);
|
||||
NOD_DestroyNode(child3child2);
|
||||
NOD_NodeAddChild(ubuntu, mint);
|
||||
|
||||
NOD_NodeAddChild(arch, manjaro);
|
||||
NOD_NodeAddChild(arch, parabola);
|
||||
NOD_NodeAddChild(arch, endeavouros);
|
||||
|
||||
NOD_NodeAddChild(bsd, freebsd);
|
||||
NOD_NodeAddChild(bsd, openbsd);
|
||||
NOD_NodeAddChild(bsd, debianbsd);
|
||||
|
||||
//NOD_NodeUnparent(child2);
|
||||
|
||||
NOD_PrintNodeTree(distros);
|
||||
NOD_PrintNodeTree(arch);
|
||||
NOD_PrintNodeTree(linoox);
|
||||
NOD_PrintNodeTree(debian);
|
||||
NOD_PrintNodeTree(freebsd);
|
||||
|
||||
NOD_DestroyNode(distros);
|
||||
NOD_DestroyNode(linoox);
|
||||
NOD_DestroyNode(debian);
|
||||
NOD_DestroyNode(ubuntu);
|
||||
NOD_DestroyNode(mint);
|
||||
NOD_DestroyNode(devuan);
|
||||
NOD_DestroyNode(kali);
|
||||
NOD_DestroyNode(voidlinux);
|
||||
NOD_DestroyNode(arch);
|
||||
NOD_DestroyNode(manjaro);
|
||||
NOD_DestroyNode(parabola);
|
||||
NOD_DestroyNode(endeavouros);
|
||||
NOD_DestroyNode(bsd);
|
||||
NOD_DestroyNode(freebsd);
|
||||
NOD_DestroyNode(openbsd);
|
||||
NOD_DestroyNode(debianbsd);
|
||||
return 0;
|
||||
}
|
||||
|
|
82
src/node.c
82
src/node.c
|
@ -2,9 +2,10 @@
|
|||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
|
||||
NOD_Node* NOD_CreateNode(char* name){
|
||||
NOD_Node* node = malloc(sizeof(NOD_Node));
|
||||
NOD_Node *NOD_CreateNode(char *name){
|
||||
NOD_Node *node = malloc(sizeof(NOD_Node));
|
||||
|
||||
if(node != NULL){
|
||||
node->name = name;
|
||||
|
@ -17,20 +18,20 @@ NOD_Node* NOD_CreateNode(char* name){
|
|||
return node;
|
||||
}
|
||||
|
||||
void NOD_DestroyNode(NOD_Node* node){
|
||||
void NOD_DestroyNode(NOD_Node *node){
|
||||
if(node != NULL){
|
||||
free(node);
|
||||
}
|
||||
}
|
||||
|
||||
void NOD_NodeAddChild(NOD_Node* parent, NOD_Node* child){
|
||||
void NOD_NodeAddChild(NOD_Node *parent, NOD_Node *child){
|
||||
if(parent != NULL && child != NULL){
|
||||
/** Prevent recursion */
|
||||
if(parent == child){
|
||||
fprintf(stderr, "NOD_Warning: A node cannot be added to itself.\n");
|
||||
return;
|
||||
}
|
||||
NOD_Node* tmp_parent = parent->parent;
|
||||
NOD_Node *tmp_parent = parent->parent;
|
||||
while(tmp_parent != NULL){
|
||||
if(tmp_parent == child){
|
||||
fprintf(stderr, "NOD_Warning: Can't add a parent of a node as its child.\n");
|
||||
|
@ -69,7 +70,7 @@ void NOD_NodeAddChild(NOD_Node* parent, NOD_Node* child){
|
|||
has already been tested */
|
||||
else if(parent->childc > 0){
|
||||
parent->childv = realloc(parent->childv,
|
||||
sizeof(child) * (parent->childc+1));
|
||||
sizeof(child) *(parent->childc+1));
|
||||
|
||||
if(parent->childv != NULL){
|
||||
parent->childv[parent->childc] = child;
|
||||
|
@ -87,9 +88,9 @@ void NOD_NodeAddChild(NOD_Node* parent, NOD_Node* child){
|
|||
}
|
||||
}
|
||||
|
||||
void NOD_NodeUnparent(NOD_Node* node){
|
||||
void NOD_NodeUnparent(NOD_Node *node){
|
||||
if(node != NULL && node->parent != NULL){
|
||||
NOD_Node* parent = node->parent;
|
||||
NOD_Node *parent = node->parent;
|
||||
|
||||
for(int i = 0; i < parent->childc; i ++){
|
||||
if(parent->childv[i] == node){
|
||||
|
@ -99,7 +100,7 @@ void NOD_NodeUnparent(NOD_Node* node){
|
|||
if(i + 1 == parent->childc){
|
||||
//fprintf(stderr,
|
||||
//"NOD_Debug: Freeing last child of vector...\n");
|
||||
parent->childv = realloc(parent->childv, sizeof(node) * parent->childc);
|
||||
parent->childv = realloc(parent->childv, sizeof(node) *parent->childc);
|
||||
parent->childc--;
|
||||
}
|
||||
}
|
||||
|
@ -109,32 +110,65 @@ void NOD_NodeUnparent(NOD_Node* node){
|
|||
}
|
||||
}
|
||||
|
||||
void nodetree_print_branch(NOD_Node* node, int level, int pos){
|
||||
int get_child_pos(NOD_Node *node){
|
||||
int count = 0;
|
||||
if(node != NULL && node->parent != NULL){
|
||||
for(int i = 0; i < node->parent->childc; i++){
|
||||
if(node->parent->childv[i] == node) return count;
|
||||
count++;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
void nodetree_print_branch(NOD_Node *node, char* level){
|
||||
if(node != NULL){
|
||||
|
||||
if(pos+1 != node->parent->childc) printf("├── ");
|
||||
else printf("└── ");
|
||||
printf("\"%s\"\n", node->name);
|
||||
for(int i = 0; i < node->childc; i++){
|
||||
if(pos+1 != node->parent->childc) printf("│ ");
|
||||
for(int i = 0; level[i] != '\0'; i++){
|
||||
if(level[i] == 'y') printf("│ ");
|
||||
else printf(" ");
|
||||
nodetree_print_branch(node->childv[i], level+1, i);
|
||||
}
|
||||
|
||||
if(node->parent != NULL){
|
||||
if(get_child_pos(node)+1 != node->parent->childc){
|
||||
printf("├─ ");
|
||||
strcat(level, "y");
|
||||
}
|
||||
else{
|
||||
printf("└─ ");
|
||||
strcat(level, "n");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void NOD_PrintNodeTree(NOD_Node* node){
|
||||
if(node != NULL){
|
||||
printf("\"%s\"\n", node->name);
|
||||
printf("%s\n", node->name);
|
||||
|
||||
/** Recurse */
|
||||
for(int i = 0; i < node->childc; i++){
|
||||
nodetree_print_branch(node->childv[i], 0, i);
|
||||
nodetree_print_branch(node->childv[i], level);
|
||||
}
|
||||
|
||||
if(node->parent != NULL){
|
||||
level = (char *)realloc(level, strlen(level) * sizeof(char));
|
||||
level[strlen(level)-1] = '\0';
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
int NOD_NodeChildCount(NOD_Node* node){
|
||||
unsigned int count = 0;
|
||||
void NOD_PrintNodeTree(NOD_Node *node){
|
||||
if(node != NULL){
|
||||
char* level = strdup("");
|
||||
|
||||
printf("%s\n", node->name);
|
||||
for(int i = 0; i < node->childc; i++){
|
||||
nodetree_print_branch(node->childv[i], level);
|
||||
}
|
||||
|
||||
free(level);
|
||||
}
|
||||
}
|
||||
|
||||
int NOD_NodeChildCount(NOD_Node *node){
|
||||
int count = 0;
|
||||
for(int i = 0; i < node->childc; i++){
|
||||
if(node->childv[i] != NULL) count++;
|
||||
}
|
||||
|
|
18
src/node.h
18
src/node.h
|
@ -2,24 +2,24 @@
|
|||
#define __NODE_H_
|
||||
|
||||
typedef struct node{
|
||||
char* name;
|
||||
char *name;
|
||||
|
||||
/** childc keeps track of allocated space,
|
||||
not amount of children. For that use
|
||||
NOD_NodeChildCount */
|
||||
int childc;
|
||||
struct node** childv;
|
||||
struct node* parent;
|
||||
struct node* *childv;
|
||||
struct node *parent;
|
||||
|
||||
} NOD_Node;
|
||||
|
||||
NOD_Node* NOD_CreateNode(char* name);
|
||||
void NOD_DestroyNode(NOD_Node* node);
|
||||
NOD_Node *NOD_CreateNode(char *name);
|
||||
void NOD_DestroyNode(NOD_Node *node);
|
||||
|
||||
void NOD_NodeAddChild(NOD_Node* parent, NOD_Node* child);
|
||||
void NOD_NodeUnparent(NOD_Node* child);
|
||||
void NOD_NodeAddChild(NOD_Node *parent, NOD_Node *child);
|
||||
void NOD_NodeUnparent(NOD_Node *child);
|
||||
|
||||
void NOD_PrintNodeTree(NOD_Node* node);
|
||||
int NOD_NodeChildCount(NOD_Node* node);
|
||||
void NOD_PrintNodeTree(NOD_Node *node);
|
||||
int NOD_NodeChildCount(NOD_Node *node);
|
||||
|
||||
#endif // __NODE_H_
|
||||
|
|
Loading…
Reference in New Issue