diff options
-rw-r--r-- | input.c | 320 | ||||
-rw-r--r-- | startmode.c | 2 | ||||
-rw-r--r-- | test/testcases/smode_cases.txt | 24 |
3 files changed, 206 insertions, 140 deletions
@@ -6,27 +6,22 @@ #include "7ed.h" #include <stdint.h> +#define _SINGLE 1 +#define _MULTIPLE 2 +#define _FAIL '?' // final return value from smode_input to indicate an invalid +#define _VALID 0 // this may only be used to mark as valid or invalid from the validate functions +#define _INVALID -1 // this may only be used to mark as valid or invalid from the validate functions + // _FAIL and _INVALID are sorta tied to eachother + // This will be the new input system for combining commands with line numbers // Work in progress and far from finished. This is not included when compiling normally. #define SMODE_MAX_SIZE 33 #define SMODE_MAX_INPUT_SIZE 32 -int smode_input_and_validator(char *single, char **multiple, uint64_t focus) { // This function checks for valid input +int validate_L(char *smode_buf) { - // char *single is for p, e, c, q, a - // char **multiple is for L, n, x and d. Although it can be expanded to be used in p and e. - - char smode_buf[SMODE_MAX_SIZE]; // Smode buffer - fprintf(stdout, "(%lu): ", focus); // UI - fgets(smode_buf, SMODE_MAX_SIZE, stdin); // Read user input - - switch (smode_buf[0]) { - // from L to D there will be the 'Multiple' options. In their respective cases i will check if the input is valid or not. - // I will not make the program clean the input because that could lead to assumptions. - case 'l': - case 'L': - /* + /* Check for + (or -) path 1: If there is a + then check if there is anything else after it. If not then return L+. (DONEish) 1.1: If there is a anything that is not a number from 0-9 then return '?' (safety check) @@ -41,187 +36,246 @@ int smode_input_and_validator(char *single, char **multiple, uint64_t focus) { / path 3: If there is nothing else after the L (in this case just an L) then just return an L (DONE) */ - // its already a clusterf##k of a function - char nums[] = "123456789"; - int L_num_flag = 2; - int plus_num_flag = -1; //If true the if statement will validate if input is valid after the + - int num_flag = -1; // If true the if statement will validate if input is valid after L - - if (smode_buf[1] == '+') { - printf("Its a plus!\n"); - plus_num_flag = 1; - // Check if its a plus - if (smode_buf[2] == '0') { - L_num_flag = -1; // if 0 then its just invalid immediately - } - if (smode_buf[2] != '\n') { // If there is no return we set these flags to false. - plus_num_flag = -1; // If there is a return then no flags are changed and thus we know that the input is only an L+ - L_num_flag = -1; - } - - for (int i = 0 ; i < 9 ; i++) { // Check if theres a number after + - if (smode_buf[2] == nums[i]) { - printf("Its a number after + \n"); - plus_num_flag = 0; - break; - } - } + char nums[] = "123456789"; + int L_num_flag = 2; + int plus_num_flag = -1; //If true the if statement will validate if input is valid after the + + int num_flag = -1; // If true the if statement will validate if input is valid after L + + if (smode_buf[1] == '+' || smode_buf[1] == '-') { + //printf("Its a plus!\n"); + plus_num_flag = 1; + // Check if its a plus + if (smode_buf[2] == '0') { + L_num_flag = -1; // if 0 then its just invalid immediately + } + if (smode_buf[2] != '\n') { // If there is no return we set these flags to false. + plus_num_flag = -1; // If there is a return then no flags are changed and thus we know that the input is only an L+ + L_num_flag = -1; + } + + for (int i = 0 ; i < 9 ; i++) { // Check if theres a number after + + if (smode_buf[2] == nums[i]) { + //printf("Its a number after + \n"); + plus_num_flag = 0; + break; } + } + } - if (plus_num_flag == 0) { - int plus_valid_flag = -1; - L_num_flag = -1; // False - char nums_with_zero[] = "0123456789"; - // Check the rest with a loop. Start at 2 - for (int i = 1 ; i < SMODE_MAX_INPUT_SIZE ; i++) { - // Nested loop to check every element in nums_with_zero on the current smode element (i)(outer loop) - for (int j = 0 ; j < 10 ; j++) { - - if(smode_buf[i] == nums_with_zero[j]) {//check if its not a number. It could be the null terminator so we check if it is - if (smode_buf[i+1] == '\n' || smode_buf[i+1] == '\0') { - - // 0 1 2 3 - // L 2 5 8 - L_num_flag = 0; - plus_valid_flag = 0; - printf(" +++ String is valid!\n"); - // success! return the "valid" string. (example: L44) - // Do something to indicate that its successful and break out somehow not sure yet - break; - } - break; - } - - } //inner nested loop - if (plus_valid_flag == 0) { - printf(" +++ Validflag!\n"); + if (plus_num_flag == 0) { + int plus_valid_flag = -1; + L_num_flag = -1; // False + char nums_with_zero[] = "0123456789"; + // Check the rest with a loop. Start at 2 + for (int i = 1 ; i < SMODE_MAX_INPUT_SIZE ; i++) { + // Nested loop to check every element in nums_with_zero on the current smode element (i)(outer loop) + for (int j = 0 ; j < 10 ; j++) { + + if(smode_buf[i] == nums_with_zero[j]) {//check if its not a number. It could be the null terminator so we check if it is + if (smode_buf[i+1] == '\n' || smode_buf[i+1] == '\0') { + L_num_flag = 0; + plus_valid_flag = 0; + //printf(" +++ String is valid!\n"); + // success! return the "valid" string. (example: L44) + // Do something to indicate that its successful and break out somehow not sure yet break; } - - - }//outer nested loop - } - - if (smode_buf[1] == '0') { // [1] because there is no + at 1. Number starts immediately after L - L_num_flag = -1; // if 0 then its just invalid immediately - } - - for (int i = 0 ; i < 9 ; i++) { // Check if it starts with a number - if (smode_buf[1] == nums[i]) { - printf("Its a number!\n"); - num_flag = 0; break; } + + } //inner nested loop + if (plus_valid_flag == 0) { + //printf(" +++ Validflag!\n"); + break; } - if (num_flag == 0) { // Start validating if there are numbers after L - int valid_flag = -1; - L_num_flag = -1; // False - char nums_with_zero[] = "0123456789"; - // Check the rest with a loop. Start at 2 - for (int i = 1 ; i < SMODE_MAX_INPUT_SIZE ; i++) { - // Nested loop to check every element in nums_with_zero on the current smode element (i)(outer loop) - for (int j = 0 ; j < 10 ; j++) { - - if(smode_buf[i] == nums_with_zero[j]) {//check if its not a number. It could be the null terminator so we check if it is - if (smode_buf[i+1] == '\n' || smode_buf[i+1] == '\0') { - - // 0 1 2 3 - // L 2 5 8 - L_num_flag = 0; - valid_flag = 0; - printf("Success! String is valid!\n"); - // success! return the "valid" string. (example: L44) - // Do something to indicate that its successful and break out somehow not sure yet - break; - } - break; - } - - } //inner nested loop - if (valid_flag == 0) { - printf("Validflag!\n"); + + }//outer nested loop + } + + if (smode_buf[1] == '0') { // [1] because there is no + at 1. Number starts immediately after L + L_num_flag = -1; // if 0 then its just invalid immediately + if(smode_buf[2] == '\n') { + //valid + L_num_flag = 0; + } + } + + for (int i = 0 ; i < 9 ; i++) { // Check if it starts with a number + if (smode_buf[1] == nums[i]) { + //printf("Its a number!\n"); + num_flag = 0; + break; + } + } + + if (num_flag == 0) { // Start validating if there are numbers after L + int valid_flag = -1; + L_num_flag = -1; // False + char nums_with_zero[] = "0123456789"; + // Check the rest with a loop. Start at 2 + for (int i = 1 ; i < SMODE_MAX_INPUT_SIZE ; i++) { + // Nested loop to check every element in nums_with_zero on the current smode element (i)(outer loop) + for (int j = 0 ; j < 10 ; j++) { + + if(smode_buf[i] == nums_with_zero[j]) {//check if its not a number. It could be the null terminator so we check if it is + if (smode_buf[i+1] == '\n' || smode_buf[i+1] == '\0') { + + // 0 1 2 3 + // L 2 5 8 + L_num_flag = 0; + valid_flag = 0; + //printf("Success! String is valid!\n"); + // success! return the "valid" string. (example: L44) + // Do something to indicate that its successful and break out somehow not sure yet break; } - + break; + } - }//outer nested loop - }// num_flag if-statement - if (L_num_flag == 0) { - printf("Because the string was valid we return it here!\n"); - // actually return the valid string here - break; - } - if (L_num_flag == -1) { - printf("Because the string was invalid we return '?' here!\n"); - // invalid! return '?' + } //inner nested loop + if (valid_flag == 0) { + //printf("Validflag!\n"); break; } + - if (plus_num_flag == 1) { - printf("L+ only!"); - break; - } + }//outer nested loop + }// num_flag if-statement + if (L_num_flag == 0) { + //printf("Because the string was valid we return it here!\n"); + // actually return the valid string here + return _VALID; + } + if (L_num_flag == -1) { + //printf("Because the string was invalid we return '?' here!\n"); + // invalid! return '?' + return _INVALID; + } - if (smode_buf[1] == '\n') { - printf("L only!\n"); - // just return L - break; - } + if (plus_num_flag == 1) { + //printf("L+ only!"); + return _VALID; + } - printf("Because the string was invalid we return '?' here!\n"); // Last catch, it it makes it to here then just invalid - // if it gets to here then i guess we just return '?' + if (smode_buf[1] == '\n') { + //printf("L only!\n"); + // just return L + return _VALID; + } + + //printf("Because the string was invalid we return '?' here!\n"); // Last catch, if it makes it to here then just invalid + return _INVALID; + +} + +int smode_input(char *single, char **multiple, uint64_t focus) { // This function is for input then calls the appropriate validator + + // char *single is for p, e, c, q, a + // char **multiple is for L, n, x and d. Although it can be expanded to be used in p and e. + + char smode_buf[SMODE_MAX_SIZE]; // Smode buffer + fprintf(stdout, "(%lu): ", focus); // UI + fgets(smode_buf, SMODE_MAX_SIZE, stdin); // Read user input + + switch (smode_buf[0]) { + // from L to D there will be the 'Multiple' options. In their respective cases i will check if the input is valid or not. + // I will not make the program clean the input because that could lead to assumptions. + case 'l': + case 'L': + int chk = validate_L(smode_buf); + if (chk == _INVALID) { + return _FAIL; + } + *multiple = (char *)malloc(strlen(smode_buf) + 1); // just a test + strcpy(*multiple, smode_buf); + return _MULTIPLE; break; case 'n': case 'N': - + return _MULTIPLE; break; case 'x': case 'X': - + return _MULTIPLE; break; case 'd': case 'D': *multiple = (char *)malloc(strlen(smode_buf) + 1); // just a test strcpy(*multiple, smode_buf); + return _MULTIPLE; break; // singles below this point case 'p': case 'P': *single = smode_buf[0]; + return _SINGLE; break; case 'e': case 'E': *single = smode_buf[0]; + return _SINGLE; break; case 'c': case 'C': *single = smode_buf[0]; + return _SINGLE; break; case 'q': case 'Q': *single = smode_buf[0]; + return _SINGLE; break; case 'a': case 'A': *single = smode_buf[0]; + return _SINGLE; break; } - //printf("%s\n", smode_buf); - return 0; + // invalid inputs + return _FAIL; } int main () { + + // running smode_input will do a few things: + /* + scenario 1: If you input a valid multiple then the function return multiple + and it also returns the valid string to the char pointer you provide to the function + + scenario 2: If you input an invalid string, then it will return _FAIL which is basically just '?' + nothing will be returned to multiple nor single + + scenario 3: if you input a valid single then it will return _SINGLE + and it will also return the valid single character to the char you provide to the function + + scenario 4: if you input an invalid single then it will return _FAIL which is basically just '?' + nothing will be returned to multiple nor single + this scenario is the same as scenario 3. + */ + char *multiple; char single; uint64_t focus = 1; - smode_input_and_validator(&single, &multiple, focus); + int si_ret = smode_input(&single, &multiple, focus); + if (si_ret == _SINGLE) { + fprintf(stdout, "single\n"); + fprintf(stdout, "%c", single); + } + if (si_ret == _MULTIPLE) { + fprintf(stdout, "multiple\n"); + fprintf(stdout, "%s", multiple); + free(multiple); + } + if (si_ret == _FAIL) { + fprintf(stdout, "?\n"); + } //fprintf(stdout, "%s\n", multiple); //free(multiple); diff --git a/startmode.c b/startmode.c index 8f75069..0ad7155 100644 --- a/startmode.c +++ b/startmode.c @@ -35,6 +35,7 @@ int startmode(char filename[]) { fprintf(stdout,"%s %lu lines\n", filename, Flines); uint64_t focus = 1; // The focus variable. Which is the actual line number we have "selected" + while(1) { // The main loop to get the "UI" started firstwhile: @@ -48,6 +49,7 @@ int startmode(char filename[]) { if (command == '\n') { continue; } + while ('\n' != getchar()); switch (command) { diff --git a/test/testcases/smode_cases.txt b/test/testcases/smode_cases.txt index 435fb48..3c2ec8a 100644 --- a/test/testcases/smode_cases.txt +++ b/test/testcases/smode_cases.txt @@ -1,16 +1,26 @@ Positive: -L expected result: L only -L+ expected result: L+ only -L+4 expected result: +++ Valid -L+34 expected result: +++ Valid -L+4467 expected result: +++ Valid +L expected result: Valid +L+ expected result: Valid +L+4 expected result: Valid +L+34 expected result: Valid +L+4467 expected result: Valid L24 expected result: Valid L34553 expected result: Valid +L0 expected result: Valid +L- expected result: Valid +L-2 expected result: Valid +L-34 expected result: Valid Negative: LL expected result: Invalid -L0 expected result: Invalid +L-0 expected result: Invalid L+0 expected result: Invalid L+l expected result: Invalid -L+35l expected result: Invalid +L-l expected result: Invalid +L-43L expected result: Invalid +L+35L expected result: Invalid +L+021 expected result: Invalid +L+023L expected result: Invalid L23l expected result: Invalid +L-012 expected result: Invalid +L-0L expected result: Invalid |