mirror of
https://gitlab.com/klmp200/fish.git
synced 2024-11-14 04:43:20 +00:00
Merge branch 'sli' into 'master'
Perfect logic is perfect and beyond perfection since there is no memory leak See merge request !8
This commit is contained in:
commit
99b847d43a
@ -33,9 +33,11 @@ builtinCommand **getBuiltinCommands(){
|
||||
int fishCd(WordArray *args) {
|
||||
if (args->size < 2){
|
||||
fprintf(stderr, "fish: Où sont les arguments de ta commande \"cd\" connard ?!\n");
|
||||
return EXIT_FAILURE;
|
||||
} else {
|
||||
if (chdir(args->words[1]) != 0){
|
||||
perror("fish");
|
||||
return EXIT_FAILURE;
|
||||
}
|
||||
}
|
||||
freeWordArray(args);
|
||||
|
@ -156,33 +156,38 @@ int fishExecute(WordList *list) {
|
||||
int signal = 1;
|
||||
|
||||
splited = parseWordList(list, &op);
|
||||
array = wordListToWordArray(list);
|
||||
|
||||
signal = loadRightCommand(array);
|
||||
if (signal == EXIT_SIGNAL){
|
||||
if (splited != NULL) freeWordList(splited);
|
||||
if (array != NULL) freeWordArray(array);
|
||||
return signal;
|
||||
}
|
||||
switch (op) {
|
||||
case AND:
|
||||
signal = fishExecute(list);
|
||||
if (!signal) signal = fishExecute(splited);
|
||||
else {
|
||||
if (splited != NULL) freeWordList(splited);
|
||||
splited = NULL;
|
||||
}
|
||||
break;
|
||||
case REVERSE_AND:
|
||||
if (signal) signal = fishExecute(splited);
|
||||
signal = fishExecute(list);
|
||||
if (signal && signal != EXIT_SIGNAL) signal = fishExecute(splited);
|
||||
else {
|
||||
if (splited != NULL) freeWordList(splited);
|
||||
splited = NULL;
|
||||
}
|
||||
break;
|
||||
case OR:
|
||||
signal = fishExecute(splited);
|
||||
signal = fishExecute(list);
|
||||
if (signal != EXIT_SIGNAL) signal = fishExecute(splited);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
array = wordListToWordArray(list);
|
||||
signal = loadRightCommand(array);
|
||||
splited = NULL;
|
||||
}
|
||||
|
||||
if (signal == EXIT_SIGNAL){
|
||||
if (splited != NULL) freeWordList(splited);
|
||||
if (array != NULL) freeWordArray(array);
|
||||
}
|
||||
|
||||
return signal;
|
||||
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user