summaryrefslogtreecommitdiff
path: root/src/expr.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2012-04-26 16:39:25 -0500
committerJohn Wiegley <johnw@newartisans.com>2012-04-26 16:39:25 -0500
commit64a9b42381c26baf24e58b40f50f0b253e551811 (patch)
tree5447a29dff64c3a8b7be8100a01bcb4a2d73b0bb /src/expr.cc
parent7cc550fc22357e2ded194d3e65287c6b3317f5ae (diff)
parentb4407c10c0071365322b2963747bf42a57fd7304 (diff)
downloadfork-ledger-64a9b42381c26baf24e58b40f50f0b253e551811.tar.gz
fork-ledger-64a9b42381c26baf24e58b40f50f0b253e551811.tar.bz2
fork-ledger-64a9b42381c26baf24e58b40f50f0b253e551811.zip
Merge branch 'release/v3.0.0-20120426'
Diffstat (limited to 'src/expr.cc')
-rw-r--r--src/expr.cc114
1 files changed, 113 insertions, 1 deletions
diff --git a/src/expr.cc b/src/expr.cc
index b3d4abcd..25967207 100644
--- a/src/expr.cc
+++ b/src/expr.cc
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2003-2010, John Wiegley. All rights reserved.
+ * Copyright (c) 2003-2012, John Wiegley. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
@@ -37,6 +37,59 @@
namespace ledger {
+expr_t::expr_t() : base_type()
+{
+ TRACE_CTOR(expr_t, "");
+}
+
+expr_t::expr_t(const expr_t& other) : base_type(other), ptr(other.ptr)
+{
+ TRACE_CTOR(expr_t, "copy");
+}
+expr_t::expr_t(ptr_op_t _ptr, scope_t * _context)
+ : base_type(_context), ptr(_ptr)
+{
+ TRACE_CTOR(expr_t, "const ptr_op_t&, scope_t *");
+}
+
+expr_t::expr_t(const string& _str, const parse_flags_t& flags)
+ : base_type()
+{
+ if (! _str.empty())
+ parse(_str, flags);
+ TRACE_CTOR(expr_t, "string, parse_flags_t");
+}
+
+expr_t::expr_t(std::istream& in, const parse_flags_t& flags)
+ : base_type()
+{
+ parse(in, flags);
+ TRACE_CTOR(expr_t, "std::istream&, parse_flags_t");
+}
+
+expr_t::~expr_t() {
+ TRACE_DTOR(expr_t);
+}
+
+expr_t& expr_t::operator=(const expr_t& _expr)
+{
+ if (this != &_expr) {
+ base_type::operator=(_expr);
+ ptr = _expr.ptr;
+ }
+ return *this;
+}
+
+expr_t::operator bool() const throw()
+{
+ return ptr.get() != NULL;
+}
+
+expr_t::ptr_op_t expr_t::get_op() throw()
+{
+ return ptr;
+}
+
void expr_t::parse(std::istream& in, const parse_flags_t& flags,
const optional<string>& original_string)
{
@@ -163,6 +216,65 @@ void expr_t::dump(std::ostream& out) const
if (ptr) ptr->dump(out, 0);
}
+bool merged_expr_t::check_for_single_identifier(const string& expr)
+{
+ bool single_identifier = true;
+ for (const char * p = expr.c_str(); *p; ++p)
+ if (! std::isalnum(*p) || *p == '_') {
+ single_identifier = false;
+ break;
+ }
+
+ if (single_identifier) {
+ set_base_expr(expr);
+ exprs.clear();
+ return true;
+ } else {
+ return false;
+ }
+}
+
+void merged_expr_t::compile(scope_t& scope)
+{
+ if (exprs.empty()) {
+ parse(base_expr);
+ } else {
+ std::ostringstream buf;
+
+ buf << "__tmp_" << term << "=(" << term << "=(" << base_expr << ")";
+ foreach (const string& expr, exprs) {
+ if (merge_operator == ";")
+ buf << merge_operator << term << "=" << expr;
+ else
+ buf << merge_operator << "(" << expr << ")";
+ }
+ buf << ";" << term << ");__tmp_" << term;
+
+ DEBUG("expr.merged.compile", "Compiled expr: " << buf.str());
+ parse(buf.str());
+ }
+
+ expr_t::compile(scope);
+}
+
+expr_t::ptr_op_t as_expr(const value_t& val)
+{
+ VERIFY(val.is_any());
+ return val.as_any<expr_t::ptr_op_t>();
+}
+
+void set_expr(value_t& val, expr_t::ptr_op_t op)
+{
+ val.set_any(op);
+}
+
+value_t expr_value(expr_t::ptr_op_t op)
+{
+ value_t temp;
+ temp.set_any(op);
+ return temp;
+}
+
value_t source_command(call_scope_t& args)
{
std::istream * in = NULL;