File: pyscript.py

package info (click to toggle)
solfege 2.0.4-4
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 3,200 kB
  • ctags: 1,844
  • sloc: python: 12,160; xml: 5,458; ansic: 1,486; makefile: 562; sh: 233
file content (48 lines) | stat: -rw-r--r-- 1,947 bytes parent folder | download
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
# GNU Solfege - eartraining for GNOME
# Copyright (C) 2000, 2001, 2002, 2003  Tom Cato Amundsen
#
# 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 2 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, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

import string, re
import cfg

class PyScript:
    def __init__(self):
        self.cmt_re = re.compile("(\<solfege-cmt\>).*?(\</solfege-cmt\>)", re.DOTALL)
        self.script_re = re.compile("(\<script\s+type=\"text/solfegescript\"\>)(?P<scr>.*?)\</script\>", re.DOTALL)
        self.script2_re = re.compile("(\<ss\>)(?P<scr>.*?)\</ss\>", re.DOTALL)
    def evaluate(self, txt):
        txt = self.remove_comments(txt)
        txt = self.exec_scripts(txt)
        return txt
        #return self.remove_comments(self.exec_scripts(txt))
    def remove_comments(self, s):
        m = self.cmt_re.search(s)
        while m:
            s = s[:m.start()] + s[m.end():]
            m = self.cmt_re.search(s)
        return s
    def exec_scripts(self, s):
        G = {'get_string': lambda s: cfg.get_string(s)}
        m = self.script_re.search(s)
        while m:
            ret = eval(m.group("scr"), G)
            if ret:
                ret = string.replace(ret, '<', '&lt;')
                ret = string.replace(ret, '>', '&gt;')
            s = s[:m.start()] + str(ret) + s[m.end():]
            m = self.script_re.search(s)
        return s