-
Notifications
You must be signed in to change notification settings - Fork 94
/
callable.cc
75 lines (61 loc) · 1.12 KB
/
callable.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/*****
* callable.cc
* Tom Prince 2005/06/19
*
* Runtime representation of functions.
*****/
#include "stack.h"
#include "callable.h"
namespace vm {
callable::~callable()
{}
void func::call(stack *s)
{
s->run(this);
}
void nullfunc::print(ostream& out) {
out << "nullfunc";
}
bool func::compare(callable* F)
{
if (func* f=dynamic_cast<func*>(F))
return (body == f->body) && (closure == f->closure);
else return false;
}
void func::print(ostream& out) {
out << "func with lambda";
#ifdef DEBUG_FRAME
out << " " << body->name;
#endif
}
bool bfunc::compare(callable* F)
{
if (bfunc* f=dynamic_cast<bfunc*>(F))
return (func == f->func);
else return false;
}
void bfunc::print(ostream& out) {
out << "bltin";
#ifdef DEBUG_BLTIN
out << " " << lookupBltin(func);
#endif
}
void thunk::call(stack *s)
{
s->push(arg);
func->call(s);
}
void thunk::print(ostream& out) {
out << "thunk on " << arg << " with ";
func->print(out);
}
nullfunc nullfunc::func;
void nullfunc::call(stack *)
{
error("dereference of null function");
}
bool nullfunc::compare(callable* f)
{
return f == &func;
}
} // namespace vm