Skip to content

Commit

Permalink
#655 feat: adds indentation instead of curly braces for and if blocks (
Browse files Browse the repository at this point in the history
…#746)

* #655 feat: adds indentation instead of curly braces for and if blocks

* feat: provides backward compatibility for single line if statements
  • Loading branch information
siowyisheng authored Mar 6, 2020
1 parent aa12682 commit b169547
Showing 1 changed file with 30 additions and 7 deletions.
37 changes: 30 additions & 7 deletions src/tagui_parse.php
Original file line number Diff line number Diff line change
Expand Up @@ -117,9 +117,12 @@
$input_file = fopen($script . '.raw','r') or die("ERROR - cannot open " . $script . '.raw' . "\n");}

// section to do required pre-processing on expanded .raw flow file
$indentation_spaces = 0;
$previous_indentation_length = 0;
$current_indentation_length = 0;
$padded_raw_flow = ""; $previous_line_is_condition = false; $reference_indentation = "";
while(!feof($input_file)) {$padded_raw_flow_line = fgets($input_file);
$indentation_tracker = str_replace(ltrim($padded_raw_flow_line),'',$padded_raw_flow_line);
$indentation_tracker = str_replace(ltrim($padded_raw_flow_line, " \t"),'',$padded_raw_flow_line);
$indentation_tracker = substr($indentation_tracker,strlen($reference_indentation));
// above line handles py and vision blocks that begin indented (eg in if or loops)
$padded_raw_flow_line = ltrim($padded_raw_flow_line);
Expand Down Expand Up @@ -147,25 +150,46 @@
$inside_dom_block + $inside_run_block + $inside_vision_block) > 0)
{$padded_raw_flow .= $indentation_tracker . $padded_raw_flow_line; continue;}

$current_indentation_length = strlen($indentation_tracker);
if ($indentation_spaces == 0 and $current_indentation_length > 0) {
$indentation_spaces = $current_indentation_length;
}
if ($current_indentation_length > $previous_indentation_length) {
$padded_raw_flow .= "{\n";
}
if ($current_indentation_length < $previous_indentation_length) {
$indentation_drop = $previous_indentation_length - $current_indentation_length;
if ($indentation_drop % $indentation_spaces != 0) {
die("ERROR - use a consistent number of spaces for indentation\n");
}
$indentation_levels = $indentation_drop / $indentation_spaces;
$padded_raw_flow .= str_repeat("}\n" , $indentation_levels);
}
$previous_indentation_length = $current_indentation_length;

// rewrite JS function definitions to work in scope within CasperJS blocks
if ((substr($padded_raw_flow_line,0,9)=="function ") or (substr($padded_raw_flow_line,0,12)=="js function "))
if (strpos($padded_raw_flow_line,"(")!==false) {$js_function_name_startpos = strpos($padded_raw_flow_line,"function ")+9;
$js_function_name_endpos = strpos($padded_raw_flow_line,"(",$js_function_name_startpos);
$padded_raw_flow_line = trim(substr($padded_raw_flow_line,$js_function_name_startpos,$js_function_name_endpos -
$js_function_name_startpos)) . ' = function ' . trim(substr($padded_raw_flow_line,$js_function_name_endpos))."\n";}
else die("ERROR - missing brackets () for ".$padded_raw_flow_line);

// pad { and } blocks for conditions, to keep JavaScript syntax correct
if ((substr($padded_raw_flow_line,0,3)=="if ") or (substr($padded_raw_flow_line,0,8)=="else if ")
or (substr($padded_raw_flow_line,0,4)=="for ") or (substr($padded_raw_flow_line,0,6)=="while ") or
(substr($padded_raw_flow_line,0,6)=="popup ") or (substr($padded_raw_flow_line,0,6)=="frame ") or
(trim($padded_raw_flow_line)=="else")) $current_line_is_condition = true; else $current_line_is_condition = false;

if (($previous_line_is_condition == true) and ($current_line_is_condition == true))
die("ERROR - for nested conditions, loops, popup, frame, set { and } explicitly\n".
"ERROR - add { before this line and add } accordingly - ".$padded_raw_flow_line);
if (($previous_line_is_condition == true) and (substr($padded_raw_flow_line,0,1)!="{"))
die("ERROR - for nested conditions, loops, popup, frame, set { and } explicitly\n".
"ERROR - add { before this line and add } accordingly - ".$padded_raw_flow_line);
if (($previous_line_is_condition == true) and (substr($padded_raw_flow_line,0,1)!="{"))
$padded_raw_flow .= "{\n".trim($padded_raw_flow_line)."\n}\n"; else $padded_raw_flow .= $padded_raw_flow_line;

$previous_line_is_condition = $current_line_is_condition; // prepare for next line
} fclose($input_file); file_put_contents($script . '.raw', $padded_raw_flow);
}
fclose($input_file); file_put_contents($script . '.raw', $padded_raw_flow);
// generate temp output file with padded { and } (if any) before reopening as input
$input_file = fopen($script . '.raw','r') or die("ERROR - cannot open " . $script . '.raw' . "\n");
// re-initialize trackers for begin-finish blocks of integrations
Expand Down Expand Up @@ -1012,6 +1036,7 @@ function parse_condition($logic) { // natural language handling for conditions
// take only lines starting with { or } as code blocks for processing, otherwise will break many valid javascript code
if (substr($logic,0,1) == "{") $GLOBALS['inside_code_block']++; // assume nothing on rest of the line except comment
if (substr($logic,0,1) == "}") $GLOBALS['inside_code_block']--; // assume nothing on rest of the line except comment

$code_block_header = ""; $code_block_footer = "";
$last_delimiter_pos = strrpos($GLOBALS['code_block_tracker'],"|");
$code_block_intent = substr($GLOBALS['code_block_tracker'],$last_delimiter_pos+1);
Expand Down Expand Up @@ -1146,5 +1171,3 @@ function parse_condition($logic) { // natural language handling for conditions

// return code after all the parsing and special handling
return $logic;}

?>

0 comments on commit b169547

Please sign in to comment.