summaryrefslogtreecommitdiffstats
path: root/debian/uncrustify-trinity/uncrustify-trinity-0.78.1/tests/input/pawn/rpn_calc.pawn
diff options
context:
space:
mode:
authorMichele Calgaro <michele.calgaro@yahoo.it>2023-12-01 12:38:43 +0900
committerMichele Calgaro <michele.calgaro@yahoo.it>2023-12-01 12:38:43 +0900
commitb67b7f2b784c7105e88a5e639d9d84736ae2cbc1 (patch)
tree0fd16d439c681c07d57d7f0d544c7582e04c3a31 /debian/uncrustify-trinity/uncrustify-trinity-0.78.1/tests/input/pawn/rpn_calc.pawn
parentc0a6f1b84c84749908961579b84513fd9f9d9eac (diff)
downloadextra-dependencies-b67b7f2b784c7105e88a5e639d9d84736ae2cbc1.tar.gz
extra-dependencies-b67b7f2b784c7105e88a5e639d9d84736ae2cbc1.zip
uncrustify-trinity: updated based on upstream version 0.78.1
Signed-off-by: Michele Calgaro <michele.calgaro@yahoo.it>
Diffstat (limited to 'debian/uncrustify-trinity/uncrustify-trinity-0.78.1/tests/input/pawn/rpn_calc.pawn')
-rw-r--r--debian/uncrustify-trinity/uncrustify-trinity-0.78.1/tests/input/pawn/rpn_calc.pawn71
1 files changed, 71 insertions, 0 deletions
diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.78.1/tests/input/pawn/rpn_calc.pawn b/debian/uncrustify-trinity/uncrustify-trinity-0.78.1/tests/input/pawn/rpn_calc.pawn
new file mode 100644
index 00000000..2965d9c7
--- /dev/null
+++ b/debian/uncrustify-trinity/uncrustify-trinity-0.78.1/tests/input/pawn/rpn_calc.pawn
@@ -0,0 +1,71 @@
+/* main rpn parser and lexical analysis, part of the RPN calculator */
+#include <rational>
+#include <string>
+enum token
+ {
+ t_type, /* operator or token type */
+ Rational: t_value, /* value, if t_type is "Number" */
+ t_word[20], /* raw string */
+ }
+
+const Number = '0'
+const EndOfExpr = '#'
+
+rpncalc(const string[])
+ {
+ new index
+ new field[token]
+ for ( ;; )
+ {
+ field = gettoken(string, index)
+ switch (field[t_type])
+ {
+ case Number:
+ push field[t_value]
+ case '+':
+ push pop() + pop()
+ case '-':
+ push - pop() + pop()
+ case '*':
+ push pop() * pop()
+ case '/', ':':
+ push 1.0 / pop() * pop()
+ case EndOfExpr:
+ break /* exit "for" loop */
+ default:
+ printf "Unknown operator '%s'\n", field[t_word]
+ }
+ }
+
+ printf "Result = %r\n", pop()
+
+ if (clearstack())
+ print "Stack not empty\n", red
+ }
+
+gettoken(const string[], &index)
+ {
+ /* first get the next "word" from the string */
+ new word[20]
+ word = strtok(string, index)
+ /* then parse it */
+ new field[token]
+ field[t_word] = word
+ if (strlen(word) == 0)
+ {
+ field[t_type] = EndOfExpr /* special "stop" symbol */
+ field[t_value] = 0
+ }
+ else if ('0' <= word[0] <= '9')
+ {
+ field[t_type] = Number
+ field[t_value] = rationalstr(word)
+ }
+ else
+ {
+ field[t_type] = word[0]
+ field[t_value] = 0
+ }
+ return field
+ }
+