summaryrefslogtreecommitdiff
path: root/starts/meaning-vm/level-2-wip-stmtexprs/funcs.cpp
blob: d746f13863baf63ee6e39f8812c585802607a88e (plain)
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
#include "funcs.hpp"

using namespace intellect;
using namespace level2;
using namespace concepts;

static ref refassigned(ref expr)
{
	ref lhs = ref.get(left-operand);
	ref rhs = ref.get(right-operand);
	if (lhs.isa(link) && lhs.get(link-target) == unknown) {
		// completes the target of a link, for a[b] = c
		lhs.unlink(link-target, unknown);
		lhs.set(link-target, rhs);
		ref.unlink(right-operand, rhs);
		ref src = lhs.get(link-source);
		if (lhs.get(link-type) != unknown && src != unknown) {
			src.set(lhs.get(link-type), rhs);
			return src;
		} else {
			throw std::logic_error("not sure what to do with incomplete link assignment");
		}
	} else if (isanonymous(rhs) && !isanonymous(lhs)) {
		// assignment of anonymous content to empty named concept
		ref.unlink(left-operand, lhs);
		return level1::movetoname(rhs, lhs);
	} else {
		throw std::logic_error("unexpected bare assignment");
	}
}
// maybe later we can have ref class itself do operators completely based on its own
// ref content.

statementref assignop(ref self, ref other)
{
	return statementref::makebinary(
		self, concepts::assign, other,
		refassigned, refassigned
	);
}
statementref commaop(ref self, ref other)
{
	if (self.isa(comma-expression)) {
		if (other.isa(comma-expression)) {
			for (auto & l : other.links()) { self.insert(l.first, l.second); }
			dealloc(other);
		} else {
			self.link(topic, other);
		}
		return self;
	} else if (other.isa(comma-expression)) {
		other.link(topic, self);
		return other;
	} else {
		return statementcallref::makebinary(
			self, comma, other,
			[](ref)->ref { return ref; },
			// um when we pass the comma-expression to
			// the [] operator that takes a ref
			// the destructor of statementref will deallocate it.
			[](ref) { throw std::logic_error("bare comma-expression"); }
			// something is wrong here.  some approach is wrong.
			// would it be better to have ref itself do it all?
		);
	}
}
ref subop(ref self, ref other)
{
}