-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcvxLexer.py
92 lines (74 loc) · 2.84 KB
/
cvxLexer.py
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#add more keywords and functions
#support different types of numbers: exp notation
import ply.lex as lex
class cvxLexer(object):
def __init__(self):
print 'initing cvxLexer'
# List of token names.
tokens = [
'INT',
'FLOAT',
#arithmetic operators
'PLUS', 'MINUS', 'TIMES', 'DIVIDE',
#punctuators
'LPAREN', 'RPAREN',
'COMMA', 'SEMICOLON', 'COLON', 'DOT', 'TRANSPOSE',
'EQUAL',
'COMMENT',
'NL',
'ID',
#logical
'LOGICALEQUAL', 'LESSTHAN', 'GREATERTHAN', 'LESSTHANEQUAL', 'GREATERTHANEQUAL',
]
#edit this to add new keywords. Maybe keep it in a separate file so that later adding to it is more modular
reserved = {
#basic keywords
'cvx_begin' : 'CVX_BEGIN', 'cvx_end' : 'CVX_END', 'variable' : 'VARIABLE', 'variables' : 'VARIABLES', 'dual' : 'DUAL', 'minimize' : 'SENSE', 'maximize' : 'SENSE', 'subject' : 'SUBJECT', 'to' : 'TO',
#non linear functions
'abs' : 'ABS', 'exp': 'EXP', 'log' : 'LOG', 'max' : 'MAX', 'min' : 'MIN', 'norm' : 'NORM', 'polyval' : 'POLYVAL', 'power' : 'POWER', 'std' : 'STD', 'sqrt' : 'SQRT', 'var' : 'VAR',
#fill more
#http://cvxr.com/cvx/doc/funcref.html
}
tokens = tokens + reserved.values()
# Regular expression rules for simple tokens
t_PLUS = r'\+'; t_MINUS = r'-'; t_TIMES = r'\*'; t_DIVIDE = r'\/'
t_LPAREN = r'\('; t_RPAREN = r'\)';
t_SEMICOLON = r'\;'; t_COLON = r'\:'; t_DOT = r'\.'; t_TRANSPOSE = r'\''
t_COMMA = r'\,'
t_EQUAL = r'\='
#t_COMMENT = r'\$'
#logical operators
t_LOGICALEQUAL = r'\=='; t_LESSTHAN = r'\<'; t_GREATERTHAN = r'\>'; t_LESSTHANEQUAL = r'\<='; t_GREATERTHANEQUAL = r'\>='
def t_COMMENT(self, t): #ignore anything after this, till newline #http://blog.ostermiller.org/find-comment
r'\%.*'
return t
#keep defination of FLOAT above that of INT (precedence)
def t_FLOAT(self, t):
r'(\d*)?[.]\d+'
t.value = float(t.value)
return t
def t_INT(self, t):
r'\d+'
t.value = int(t.value)
return t
def t_NL(self, t):
r'\n+'
t.lexer.lineno += len(t.value)
#t.value = len(t.value) - 1 - t.value.rfind('\n')
return t
#Define a rule to get ID and keywords
def t_ID(self, t):
r'[a-zA-Z_][a-zA-Z_0-9]*'
t.type = reserved.get(t.value,'ID') # Check for reserved words
return t
# A string containing ignored characters (spaces and tabs)
t_ignore = ' \t'
# Error handling rule
def t_error(self, t):
print "Illegal character '%s'" % t.value[0]
t.lexer.skip(1)
t.type = 'ERROR'
return t
def buildLex(self):
# Build the lexer
self.lexer = lex.lex(module = self)