summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2012-03-05 21:48:45 -0600
committerJohn Wiegley <johnw@newartisans.com>2012-03-05 21:48:45 -0600
commit59a16e59ee2e684f1d5292fe78ef94464a935d73 (patch)
treed12112cf3a6c739a411366f44dd8da71d26a03c8 /src
parent97dbf379d5e44c80c748483a688502b1cec8f075 (diff)
downloadfork-ledger-59a16e59ee2e684f1d5292fe78ef94464a935d73.tar.gz
fork-ledger-59a16e59ee2e684f1d5292fe78ef94464a935d73.tar.bz2
fork-ledger-59a16e59ee2e684f1d5292fe78ef94464a935d73.zip
Simplified Python import in a journal file
Diffstat (limited to 'src')
-rw-r--r--src/textual.cc35
1 files changed, 28 insertions, 7 deletions
diff --git a/src/textual.cc b/src/textual.cc
index 7bf67347..b1df1fb8 100644
--- a/src/textual.cc
+++ b/src/textual.cc
@@ -164,9 +164,8 @@ namespace {
void assert_directive(char * line);
void check_directive(char * line);
-#if defined(HAVE_BOOST_PYTHON)
+ void import_directive(char * line);
void python_directive(char * line);
-#endif
post_t * parse_post(char * line,
std::streamsize len,
@@ -1114,6 +1113,14 @@ void instance_t::comment_directive(char * line)
}
#if defined(HAVE_BOOST_PYTHON)
+
+void instance_t::import_directive(char * line)
+{
+ string module_name(line);
+ trim(module_name);
+ python_session->import_option(module_name);
+}
+
void instance_t::python_directive(char * line)
{
std::ostringstream script;
@@ -1153,6 +1160,21 @@ void instance_t::python_directive(char * line)
("journal", python::object(python::ptr(context.journal)));
python_session->eval(script.str(), python_interpreter_t::PY_EVAL_MULTI);
}
+
+#else
+
+void instance_t::import_directive(char *)
+{
+ throw_(parse_error,
+ _("'python' directive seen, but Python support is missing"));
+}
+
+void instance_t::python_directive(char *)
+{
+ throw_(parse_error,
+ _("'import' directive seen, but Python support is missing"));
+}
+
#endif // HAVE_BOOST_PYTHON
bool instance_t::general_directive(char * line)
@@ -1232,6 +1254,10 @@ bool instance_t::general_directive(char * line)
include_directive(arg);
return true;
}
+ else if (std::strcmp(p, "import") == 0) {
+ import_directive(arg);
+ return true;
+ }
break;
case 'p':
@@ -1240,12 +1266,7 @@ bool instance_t::general_directive(char * line)
return true;
}
else if (std::strcmp(p, "python") == 0) {
-#if defined(HAVE_BOOST_PYTHON)
python_directive(arg);
-#else
- throw_(parse_error,
- _("'python' directive seen, but Python support is missing"));
-#endif
return true;
}
break;