Sha256: 63a6d5bab41de6c955b76fdf6426f75a82627046635137dcfd441002e2364765

Contents?: true

Size: 905 Bytes

Versions: 222

Compression:

Stored size: 905 Bytes

Contents

Implement an evaluator for a very simple subset of Forth.

[Forth](https://en.wikipedia.org/wiki/Forth_%28programming_language%29)
is a stack-based programming language. Implement a very basic evaluator
for a small subset of Forth.

Your evaluator has to support the following words:

- `+`, `-`, `*`, `/` (integer arithmetic)
- `DUP`, `DROP`, `SWAP`, `OVER` (stack manipulation)

Your evaluator also has to support defining new words using the
customary syntax: `: word-name definition ;`.

To keep things simple the only data type you need to support is signed
integers of at least 16 bits size.

You should use the following rules for the syntax: a number is a
sequence of one or more (ASCII) digits, a word is a sequence of one or
more letters, digits, symbols or punctuation that is not a number.
(Forth probably uses slightly different rules, but this is close
enough.)

Words are case-insensitive.

Version data entries

222 entries across 222 versions & 1 rubygems

Version Path
trackler-2.2.1.78 problem-specifications/exercises/forth/description.md
trackler-2.2.1.77 problem-specifications/exercises/forth/description.md
trackler-2.2.1.76 problem-specifications/exercises/forth/description.md
trackler-2.2.1.75 problem-specifications/exercises/forth/description.md
trackler-2.2.1.74 problem-specifications/exercises/forth/description.md
trackler-2.2.1.73 problem-specifications/exercises/forth/description.md
trackler-2.2.1.72 problem-specifications/exercises/forth/description.md
trackler-2.2.1.71 problem-specifications/exercises/forth/description.md
trackler-2.2.1.70 problem-specifications/exercises/forth/description.md
trackler-2.2.1.69 problem-specifications/exercises/forth/description.md
trackler-2.2.1.68 problem-specifications/exercises/forth/description.md
trackler-2.2.1.67 problem-specifications/exercises/forth/description.md
trackler-2.2.1.66 problem-specifications/exercises/forth/description.md
trackler-2.2.1.65 problem-specifications/exercises/forth/description.md
trackler-2.2.1.64 problem-specifications/exercises/forth/description.md
trackler-2.2.1.63 problem-specifications/exercises/forth/description.md
trackler-2.2.1.62 problem-specifications/exercises/forth/description.md
trackler-2.2.1.61 problem-specifications/exercises/forth/description.md
trackler-2.2.1.60 problem-specifications/exercises/forth/description.md
trackler-2.2.1.59 problem-specifications/exercises/forth/description.md