push broken path split code
This commit is contained in:
parent
5c0d3da6f2
commit
04be31476c
|
@ -10,8 +10,6 @@
|
||||||
|
|
||||||
#define setbit(x, y) x[y >> 3] |= 1 << (y & 7)
|
#define setbit(x, y) x[y >> 3] |= 1 << (y & 7)
|
||||||
|
|
||||||
#define NUM_MULTICALL 1
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
char* name;
|
char* name;
|
||||||
int (*fn)(int, char**);
|
int (*fn)(int, char**);
|
||||||
|
@ -37,25 +35,44 @@ char** psplit(char* path, int* i) {
|
||||||
|
|
||||||
if(path[strlen(path) - 1] == '/') dir = 1;
|
if(path[strlen(path) - 1] == '/') dir = 1;
|
||||||
|
|
||||||
while(1) {
|
while(x) {
|
||||||
while(*path == '/') path++;
|
while(*path == '/') path++;
|
||||||
|
if(!*path) break;
|
||||||
l = pstrlen(path, &x);
|
l = pstrlen(path, &x);
|
||||||
if(l < 3 && *path == '.') {
|
if(*path == '.' && l < 3) {
|
||||||
if(path[1] == '.' && *i != 0) free(rpth[*i--]);
|
// nop - will not handle case l == 0 or l == 1
|
||||||
} else {
|
if(l == 2) {
|
||||||
rpth[*i] = memcpy(malloc(l + 1), path, l);
|
if(path[1] == '.') {
|
||||||
rpth[(*i)++][l] = 0;
|
if(*i != !!strcmp(rpth[0], "/")) {
|
||||||
path += l + x; // prevent buffer overrun
|
printf("..: free rpth[%i]\n", *i);
|
||||||
|
free(memcpy(rpth[--(*i)], "\0", 1)); // will not overwrite first element if it is "/" or index oob
|
||||||
|
} else if(strcmp(rpth[0], "/")) {
|
||||||
|
int acc = 0;
|
||||||
|
for(int z = 0; z < *i; z++) {
|
||||||
|
acc += !!strcmp(rpth[z], "..");
|
||||||
|
printf("check rpth[%i]:\t%s\n", z, rpth[z]);
|
||||||
}
|
}
|
||||||
if(!x) break;
|
printf("acc = %i\n", acc);
|
||||||
|
if(!acc) goto addent;
|
||||||
|
}
|
||||||
|
} else goto addent;
|
||||||
|
}
|
||||||
|
} else { // insert string
|
||||||
|
addent: rpth[*i] = memcpy(malloc(l + 1), path, l);
|
||||||
|
rpth[(*i)++][l] = 0;
|
||||||
|
}
|
||||||
|
path += l + x; // prevent buffer overrun
|
||||||
if(*i >= a) rpth = realloc(rpth, sizeof(char*)*(a += 4));
|
if(*i >= a) rpth = realloc(rpth, sizeof(char*)*(a += 4));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
printf("end psplit\n\n");
|
||||||
|
|
||||||
if(dir) {
|
if(dir) {
|
||||||
if(*i + 1 >= a) rpth = realloc(rpth, sizeof(char*)*(a += 4));
|
if(*i + 1 >= a) rpth = realloc(rpth, sizeof(char*)*(a += 4));
|
||||||
rpth[(*i)++] = memcpy(malloc(2), "/", 2);
|
rpth[(*i)++] = memcpy(malloc(2), "/", 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO free a-*i elements from end to avoid leak
|
||||||
return rpth;
|
return rpth;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -214,18 +231,22 @@ int mfs_insert(int argc, char** argv) {
|
||||||
if(argc < 3) return !!printf("need arguments: [mothfs file] [file to insert]\n");
|
if(argc < 3) return !!printf("need arguments: [mothfs file] [file to insert]\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define NUM_MULTICALL 2
|
||||||
multicall mc[NUM_MULTICALL] = {
|
multicall mc[NUM_MULTICALL] = {
|
||||||
{"new", mfs_new},
|
{"new", mfs_new},
|
||||||
// {"insert", mfs_insert},
|
{"insert", mfs_insert},
|
||||||
};
|
};
|
||||||
|
|
||||||
int main(int argc, char** argv) {
|
int main(int argc, char** argv) {
|
||||||
|
|
||||||
int y;
|
int y;
|
||||||
char** x = psplit("//doc/toc////foc//", &y);
|
//char** x = psplit("/pl/../././../p2/p3/..//", &y);
|
||||||
|
//char** x = psplit("/p2/", &y);
|
||||||
|
//char** x = psplit("../../p2///", &y);
|
||||||
|
char** x = psplit("pl/../../././../p2/p3/..//", &y);
|
||||||
|
|
||||||
printf("%i\n", y);
|
printf("%i\n", y);
|
||||||
for(int i = 0; i < y; i++) printf("%s\n", x[i]);
|
for(int i = 0; i < y; i++) printf("%i:\t%s\n", i, x[i]);
|
||||||
|
|
||||||
if(argc < 2) err: {
|
if(argc < 2) err: {
|
||||||
printf("valid functions:");
|
printf("valid functions:");
|
||||||
|
|
Loading…
Reference in New Issue