diff options
author | Oskar <> | 2024-03-21 22:38:46 +0100 |
---|---|---|
committer | Oskar <> | 2024-03-21 22:38:46 +0100 |
commit | 44beae5d68575807c65498c3f992f4a29569fb0f (patch) | |
tree | c7a844a2f3b4588a6821afddec45b5c3abed61e8 | |
parent | 18a47e78f08ef9a845a5e2f15ef9d87c0c912c58 (diff) |
i think validate_plus_continue is working now, it took way too long to figure this out
-rw-r--r-- | i_validation.c | 32 | ||||
-rw-r--r-- | i_validation.h | 2 | ||||
-rw-r--r-- | test/validate_plus_continue_tests.c | 26 |
3 files changed, 44 insertions, 16 deletions
diff --git a/i_validation.c b/i_validation.c index eb64048..bc52f9c 100644 --- a/i_validation.c +++ b/i_validation.c @@ -4,6 +4,7 @@ #include <string.h> #include <errno.h> #include "7ed.h" +#include "i_validation.h" #include "input.h" #include <stdint.h> @@ -17,6 +18,7 @@ _PLUS_ONLY (L+ only. Immediately valid. Return) _PLUS_CONTINUE (L+ And more numbers after it. Will make validate_plus_continue run) _NA (None of these cases) */ + char nums[] = "123456789"; if (smode_buf[1] == '+' || smode_buf[1] == '-') { if (smode_buf[2] == '0') { return _INVALID; // Only L0 (invalid) @@ -54,7 +56,7 @@ _IMM_NUMBER (number immediately after L or N or whatever) for (int j = 0 ; j < 9 ; j++) { // Check if its just a number after if (smode_buf[1] == nums[j]) { - return _IMM_NUMBER // + return _IMM_NUMBER; } } @@ -65,30 +67,31 @@ _IMM_NUMBER (number immediately after L or N or whatever) int validate_plus_continue(char *smode_buf) { // if vcpm returns _PLUS_CONTINUE then run this to further validate char nums_with_zero[] = "0123456789"; + int kflag = _INVALID; //Start at 2 for (int i = 2 ; 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 k = 0 ; k < 10 ; k++) { - if(smode_buf[i] != nums_with_zero[k] || smode_buf[i] != '\n') { - return _INVALID; - } - } - + for (int j = 0 ; j < 10 ; j++) { - if(smode_buf[i] == '\n') { + + if (smode_buf[i] == '\n') { return _VALID; } - if(smode_buf[i] == nums_with_zero[j]) {// check if its a number + kflag = _INVALID; + if (smode_buf[i] == nums_with_zero[j]) { + kflag = _VALID; break; } - } //inner nested loop + if (kflag == _INVALID) { + return _INVALID; + } }//outer nested loop } -int validate_imm_numbers() { +int validate_imm_numbers(char *smode_buf) { int Kflag; char nums_with_zero[] = "0123456789"; @@ -98,8 +101,7 @@ int validate_imm_numbers() { for (int j = 0 ; j < 10 ; j++) { if(smode_buf[i] == nums_with_zero[j]) {//check if there is a number, if there is then next check if (smode_buf[i+1] == '\n' || smode_buf[i+1] == '\0') { // if there was a number then check if theres a newline - L_num_flag = _VALID; // if we had a newline then check the flags as valid and break out. - valid_flag = _VALID; // it will break out here and then an if statement check will also check it again so that it can break out of the outer loop + // it will break out here and then an if statement check will also check it again so that it can break out of the outer loop break; } @@ -118,9 +120,7 @@ int validate_imm_numbers() { } } //inner nested loop - if (valid_flag == _VALID) { - break; - } + }//outer nested loop diff --git a/i_validation.h b/i_validation.h index 73087ac..3c01563 100644 --- a/i_validation.h +++ b/i_validation.h @@ -14,6 +14,8 @@ #define _CONTINUE 6 #define _NA 7 +int validate_plus_continue(char *smode_buf); + int validate_L(char *smode_buf); int validate_N(char *smode_buf);
\ No newline at end of file diff --git a/test/validate_plus_continue_tests.c b/test/validate_plus_continue_tests.c new file mode 100644 index 0000000..433dcac --- /dev/null +++ b/test/validate_plus_continue_tests.c @@ -0,0 +1,26 @@ +#include <stdlib.h> +#include <stdio.h> +#include <unistd.h> +#include <string.h> +#include <errno.h> +#include "7ed.h" +#include "i_validation.h" +#include "input.h" +#include <stdint.h> + +int main () { + uint64_t focus = 1; + char smode_buf[SMODE_MAX_SIZE]; // Smode buffer + fprintf(stdout, "(%lu): ", focus); // UI + fgets(smode_buf, SMODE_MAX_SIZE, stdin); // Read user input + + int ret = validate_plus_continue(smode_buf); + + if(ret == _INVALID) { + printf("?\n"); + } + if(ret == _VALID) { + printf("valid\n"); + } + +}
\ No newline at end of file |