From 1f39d4148e588a5476e96550591131ae65ad0fe2 Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Sat, 21 Feb 2009 18:49:43 -0400 Subject: Create a new interactive_t helper class The purpose of this class is much like Emacs' (interactive) form: it allows a value expression function to declare exactly how many arguments, and of what type, it intends to receive. It then offers type-safe access to theese arguments in a consistent manner. An example value expression function definition in C++: value_t fn_foo(call_scope_t& scope) { // We expect a string, an integer, and an optional date interactive_t args(scope, "sl&d"); std::cout << "String = " << args.get(0) << "Integer = " << args.get(1) << std::endl; if (args.has(2)) // was a date provided? std::cout << "Date = " << args.get(2) << std::endl; return NULL_VALUE; } There is also an in_context_t template, which finds the context type T in the current scope hierarchy. The in_context_t then also acts as a smart pointer to reference this context object, in addition to serving the same duty as interactive_t. This combination of intent is solely for the sake of brevity. value_t fn_bar(call_scope_t& scope) { in_context_t env(scope, "sl&d"); std::cout << "Account name = " << env->fullname() << "String arg = " << env.get(0) << std::endl; return NULL_VALUE; } As you can see here, 'env' acts as a smart pointer to the required context, and an object to extract the typed arguments. --- src/precmd.h | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) (limited to 'src/precmd.h') diff --git a/src/precmd.h b/src/precmd.h index d489b1af..b36d33e1 100644 --- a/src/precmd.h +++ b/src/precmd.h @@ -46,10 +46,12 @@ #ifndef _PRECMD_H #define _PRECMD_H -#include "scope.h" +#include "value.h" namespace ledger { +class call_scope_t; + value_t parse_command(call_scope_t& args); value_t eval_command(call_scope_t& args); value_t format_command(call_scope_t& args); -- cgit v1.2.3