Fixed bug with LOOP function

This commit is contained in:
Spacehuhn 2023-06-28 00:01:25 +02:00
parent 8db0a6e881
commit 92c4089d6d
3 changed files with 40 additions and 32 deletions

View File

@ -41,25 +41,26 @@ namespace attack {
uint32_t cur_pos = 0;
int repeats = 0;
// For LOOP_START and LOOP_END
// For LOOP_BEGIN and LOOP_END
uint32_t start_pos = 0;
int loops = 0;
while (true) {
debug("Reading line...");
debugF("Reading line...");
if (!msc::getInLine()) cur_pos = msc::getPosition();
len = msc::readLine(buffer, READ_BUFFER);
debugln(len);
//debugln(std::string(buffer, len-1).c_str());
// Reached end of file
if (len == 0) {
debugln("Reached end of file");
debuglnF("Reached end of file");
if (msc::openNextFile()) continue;
else break;
}
debug("Parsing...");
debugln(len);
debugln(std::string(buffer, len-1).c_str());
debugF("Parsing...");
duckparser::parse(buffer, len);
// For REPEAT/REPLAY
@ -76,7 +77,7 @@ namespace attack {
if (!msc::getInLine()) prev_pos = cur_pos;
// For LOOP_START/LOOP_STOP
// For LOOP_BEGIN/LOOP_END
if (duckparser::loopBegin()) {
start_pos = msc::getPosition();
loops = duckparser::getLoops();
@ -91,10 +92,9 @@ namespace attack {
msc::open(path.c_str());
}
debugln("OK");
debuglnF("OK");
}
debugln("Attack finished");
debuglnF("Attack finished");
}
void start() {

View File

@ -161,6 +161,9 @@ namespace duckparser {
if (offset > time) return;
else time -= offset;
if (time < 50) {
delay(time);
} else {
sleep_start_time = millis();
unsigned long sleep_end_time = sleep_start_time + time;
@ -169,6 +172,7 @@ namespace duckparser {
tasks::update();
}
}
}
// ====== PUBLIC ===== //
@ -190,20 +194,21 @@ namespace duckparser {
bool ignore_delay;
while (n) {
ignore_delay = false;
loop_begin = false;
loop_end = false;
word_list* wl = n->words;
word_node* cmd = wl->first;
// String of the entire line excluding the command keyword (i.e. "STRING ")
const char* line_str = cmd->str + cmd->len + 1;
size_t line_str_len = n->len - cmd->len - 1;
bool has_line_str = cmd->next;
const char* line_str = has_line_str ? (cmd->str + cmd->len + 1) : nullptr;
size_t line_str_len = has_line_str ? (n->len - cmd->len - 1) : 0;
char last_char = n->str[n->len];
bool line_end = last_char == '\r' || last_char == '\n';
ignore_delay = false;
loop_begin = false;
loop_end = false;
// Check if we're in a multi line comment
if (in_ml_comment) {
// Check for the end of the comment block

View File

@ -295,19 +295,22 @@ namespace duckparser {
// in_quotes = (curr == '"' && !escaped) ? !in_quotes : in_quotes;
// delimiter = !in_quotes && !escaped && curr == ';' && next == ';';
linebreak = !in_quotes && (curr == '\r' || curr == '\n');
linebreak = /*!in_quotes && */ (curr == '\r' || curr == '\n');
endofline = stri == len || curr == '\0';
// skip \n after \r (windows linebreak)
if (/*!in_quotes && */ (curr == '\r') && (next == '\n')) ++stri;
endofline = (stri == len) || (curr == '\0');
if (linebreak || endofline || delimiter) {
size_t llen = stri - ls; // length of line
// for every line, parse_words and add to list
//if (llen > 0) {
if (llen > 0) {
n = line_node_create(&str[ls], llen);
n->words = parse_words(&str[ls], llen);
line_list_push(l, n);
//}
}
if (delimiter) ++stri;