diff options
author | Kartik K. Agaram <vc@akkartik.com> | 2015-11-08 22:42:21 -0800 |
---|---|---|
committer | Kartik K. Agaram <vc@akkartik.com> | 2015-11-08 22:42:21 -0800 |
commit | d379d683577e66ea927c212f579f7f45853623f3 (patch) | |
tree | 51316f1bc7c67c6ef6f2b6727d610b09a87aff07 /010vm.cc | |
parent | b766f5f8747166b688413d15375880be510d8af6 (diff) | |
download | mu-d379d683577e66ea927c212f579f7f45853623f3.tar.gz |
2405
Diffstat (limited to '010vm.cc')
-rw-r--r-- | 010vm.cc | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/010vm.cc b/010vm.cc index cfd12fce..6b7d58ff 100644 --- a/010vm.cc +++ b/010vm.cc @@ -99,6 +99,8 @@ struct string_tree { string_tree(string v, string_tree* r) :value(v), left(NULL), right(r) {} // advanced: tree containing strings string_tree(string_tree* l, string_tree* r) :left(l), right(r) {} + // print as s-expression + string to_string() const; }; :(before "End Globals") @@ -507,6 +509,28 @@ string recipe::to_string() const { return out.str(); } +string string_tree::to_string() const { + ostringstream out; + dump(this, out); + return out.str(); +} + +void dump(const string_tree* x, ostream& out) { + if (!x->left && !x->right) { + out << x->value; + return; + } + out << '('; + for (const string_tree* curr = x; curr; curr = curr->right) { + if (curr != x) out << ' '; + if (curr->left) + dump(curr->left, out); + else + out << curr->value; + } + out << ')'; +} + void skip_whitespace(istream& in) { while (!in.eof() && isspace(in.peek()) && in.peek() != '\n') { in.get(); |