From d7d82a1ee27c843992ab534271990f79c0c9ac43 Mon Sep 17 00:00:00 2001 From: Oskar <> Date: Thu, 21 Mar 2024 21:03:45 +0100 Subject: Moved around even more. Probably some things i am missing or removed somehow but overall it already feels a bit better to have moved everything to smaller more manageable functions --- i_validation.c | 109 +++++++++++++++++++++------------------------------------ i_validation.h | 4 +-- 2 files changed, 42 insertions(+), 71 deletions(-) diff --git a/i_validation.c b/i_validation.c index 9e90bd1..69afd38 100644 --- a/i_validation.c +++ b/i_validation.c @@ -39,6 +39,7 @@ _NA (None of these cases) int validate_check_imm(char *smode_buf) { // check immediately for \n, 0 or numbers /* _INVALID (immediately stop validating and return invalid to everything) +_IMM_NOTHING == _VALID(valid) _NA (None of these cases) _IMM_NUMBER (number immediately after L or N or whatever) */ @@ -92,6 +93,44 @@ int validate_plus_continue(char *smode_buf) { // if vcpm returns _PLUS_CONTINUE } +int validate_imm_numbers() { + + int Kflag; + 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 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 + + break; + } + Kflag = _INVALID; + for (int k = 0 ; k < 10 ; k++) { + if (smode_buf[i+1] == nums_with_zero[k]) { // We checked for newline earlier but since we didnt fine one + Kflag = _VALID; // We check if theres a number. If theres a number then keep going + break; // If there is anything but a number then Return _INVALID + } + } + if (Kflag == _INVALID) { + return _INVALID; + } + + break; + } + } //inner nested loop + + if (valid_flag == _VALID) { + break; + } + + + }//outer nested loop +} + int validate_L(char *smode_buf) { /* @@ -113,76 +152,8 @@ int validate_L(char *smode_buf) { validate_decision = validate_check_p_m(smode_buf); - if (vcpm == _PLUS_CONTINUE) { - - } - - if (smode_buf[1] == '0') { // [1] because there is no + at 1. Number starts immediately after L - L_num_flag = _INVALID; // 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]) { - num_flag = _VALID; - break; - } - } - - if (num_flag == 0) { // Start validating if there are numbers after L - int valid_flag = _INVALID; - L_num_flag = _INVALID; // False - int Kflag; - 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 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 - - break; - } - Kflag = _INVALID; - for (int k = 0 ; k < 10 ; k++) { - if (smode_buf[i+1] == nums_with_zero[k]) { // We checked for newline earlier but since we didnt fine one - Kflag = _VALID; // We check if theres a number. If theres a number then keep going - break; // If there is anything but a number then Return _INVALID - } - } - if (Kflag == _INVALID) { - return _INVALID; - } - - break; - } - } //inner nested loop - - if (valid_flag == _VALID) { - break; - } - - - }//outer nested loop - }// num_flag if-statement - if (L_num_flag == _VALID) { - return _VALID; - } - if (L_num_flag == _INVALID) { - return _INVALID; - } - - if (plus_num_flag == _ONE) { - return _VALID; - } - - if (smode_buf[1] == '\n') { - return _VALID; - } - - return _INVALID; + // this below will become validate_imm_numbers or something } diff --git a/i_validation.h b/i_validation.h index e2981ad..73087ac 100644 --- a/i_validation.h +++ b/i_validation.h @@ -6,9 +6,9 @@ #include "7ed.h" #include -#define _PLUS_ONLY 1 +#define _PLUS_ONLY _VALID #define _PLUS_CONTINUE 2 -#define _PLUS_NOTHING 3 +#define _PLUS_NOTHING _VALID #define _IMM_NUMBER 4 #define _IMM_NOTHING 5 #define _CONTINUE 6 -- cgit v1.2.3