From 428aa889649c3688240a14a4f291b8a2be1e2ae8 Mon Sep 17 00:00:00 2001 From: Matthias Andreas Benkard Date: Tue, 12 Aug 2008 19:18:52 +0200 Subject: MLKLexicalContext: Add management of user-defined function and variable properties. --- MLKLexicalContext-MLKLLVMCompilation.mm | 75 +++++++++++++++++++++++++++++++++ 1 file changed, 75 insertions(+) create mode 100644 MLKLexicalContext-MLKLLVMCompilation.mm (limited to 'MLKLexicalContext-MLKLLVMCompilation.mm') diff --git a/MLKLexicalContext-MLKLLVMCompilation.mm b/MLKLexicalContext-MLKLLVMCompilation.mm new file mode 100644 index 0000000..7e81ccb --- /dev/null +++ b/MLKLexicalContext-MLKLLVMCompilation.mm @@ -0,0 +1,75 @@ +/* -*- mode: objc; coding: utf-8 -*- */ +/* Toilet Lisp, a Common Lisp subset for the Étoilé runtime. + * Copyright (C) 2008 Matthias Andreas Benkard. + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or (at + * your option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +#import "MLKLexicalContext-MLKLLVMCompilation.h" + +#import +#import + +#include +#include +#include +using namespace llvm; +using namespace std; + + +@implementation MLKLexicalContext (MLKLLVMCompilation) +-(void) setVariableHeapAllocation:(BOOL)heapp + forSymbol:(id)name +{ + [self setDeepProperty:[NSNumber numberWithBool:heapp] + forVariable:name + key:@"LLVM.heap-flag"]; +} + +-(BOOL) variableHeapAllocationForSymbol:(id)name; +{ + id flag = [self deepPropertyForVariable:name + key:@"LLVM.heap-flag"]; + + return (flag && [flag boolValue]); +} + +-(Value *) functionCellForSymbol:(id)name +{ + return (Value *) [[self deepPropertyForFunction:name + key:@"LLVM.function-cell"] + pointerValue]; +} + +-(Value *) closureDataPointerForSymbol:(id)name +{ + return (Value *) [[self deepPropertyForFunction:name + key:@"LLVM.closure-data-pointer"] + pointerValue]; +} + +-(Value *) bindingForSymbol:(id)name +{ + return (Value *) [[self deepPropertyForVariable:name + key:@"LLVM.variable-binding"] + pointerValue]; +} + +-(Value *) valueForSymbol:(id)name +{ + return (Value *) [[self deepPropertyForVariable:name + key:@"LLVM.variable-value"] + pointerValue]; +} +@end -- cgit v1.2.3