28{
33 typedef typename compositor_t::function function_t;
34
35 symbol_table_t symbol_table;
36
37 compositor_t compositor(symbol_table);
38
39
40 compositor.add(
41 function_t("sum_of_primes")
42 .var("z")
43 .expression(
44 " var i := 2; "
45 " var total := 0; "
46 " while (z > 1) "
47 " { "
48 " if (0 == (z % i)) "
49 " { "
50 " total += i; "
51 " z /= i; "
52 " } "
53 " else "
54 " i += 1; "
55 " }; "
56 " total; "));
57
59
60 symbol_table.add_function("println",println);
61
62 const std::string sum_of_prime_factors_program =
63 " for (var i := 1; i <= 100; i += 1) "
64 " { "
65 " println(i, sum_of_primes(i)); "
66 " } ";
67
68 expression_t expression;
69 expression.register_symbol_table(symbol_table);
70
71 parser_t parser;
72 parser.compile(sum_of_prime_factors_program,expression);
73
74 expression.value();
75}