Exemplo n.º 1
0
Arquivo: eglan.py Projeto: Ran4/egLan
 def stripAndSplitSeq(self, seq, splitChar):
     return [x.strip() for x in parsing.split(seq, splitChar) if x.strip()]
Exemplo n.º 2
0
        def parse(self,s,secure):
            layer = self.layer.get(self.nest,None)
            self.result = None
# report any uncaught errors...
# WLD: this is problematic if parse is called inside an exception...removed.
#            if sys.exc_info()!=(None,None,None):
#                traceback.print_exc()
#                sys.exc_clear()
            if layer.embed_sentinel!=None:
                if string.strip(s) == layer.embed_sentinel:
                    etn = layer.embed_type
                    if etn == 0: # embedded data
                        print " Embed: read %d lines."%(len(layer.embed_list))
                        layer.embed_sentinel=None
                    elif etn == 1: # python block
                        print "PyMOL>"+string.rstrip(s)                    
                        py_block = string.join(layer.embed_list,'')
                        del layer.embed_list
                        layer.embed_sentinel=None
                        try:
                            exec(py_block,self.pymol_names,self.pymol_names)
                        except:
                            traceback.print_exc()
                    elif etn == 2: # skip block
                        print " Skip: skipped %d lines."%(layer.embed_line)
                        layer.embed_sentinel=None
                else:
                    etn = layer.embed_type
                    if etn == 0: # normal embedded data
                        layer.embed_list.append(string.rstrip(s)+"\n")
                    elif etn == 1: # python block
                        el = layer.embed_line + 1
                        print "%5d:%s"%(el,string.rstrip(s))
                        layer.embed_line = el
                        layer.embed_list.append(string.rstrip(s)+"\n")
                    elif etn == 2:
                        layer.embed_line = layer.embed_line + 1
                return 1
            p_result = 1
            layer.com0 = s
            try:
                layer.com1 = string.rstrip(layer.com0) # strips trailing whitespace
                if len(layer.com1) > 0:
                    if str(layer.com1[-1]) == "\\":
                        # prepend leftovers
                        if layer.cont != '':
                            layer.cont = layer.cont + "\n" + layer.com1[:-1]
                        else:
                            layer.cont = layer.com1[:-1]
                    else:
                        # prepend leftovers
                        if layer.cont != '':
                            layer.com1 = layer.cont + "\n" + layer.com1
                            layer.cont = ''
        # this routine splits up the line first based on semicolon 
                        
                        layer.next = parsing.split(layer.com1,';',1) + layer.next[1:]
                        
        # layer.com2 now a full non-compound command            
                        layer.com2 = layer.next[0]
                        layer.input = string.split(layer.com2,' ',1)
                        lin = len(layer.input)
                        if lin:
                            layer.input[0] = string.strip(layer.input[0])
                            com = layer.input[0]
                            if (com[0:1]=='/'):
                                # explicit literal python 
                                layer.com2 = string.strip(layer.com2[1:])
                                if len(layer.com2)>0:
                                    if not secure:
                                        exec(layer.com2+"\n",self.pymol_names,self.pymol_names)
                                    else:
                                        print 'Error: Python expressions disallowed in this file.'
                                        return None
                            elif lin>1 and py_delims.has_key(string.split(layer.input[-1:][0],' ',1)[0]):
                                if not secure:
                                    exec(layer.com2+"\n",self.pymol_names,self.pymol_names)
                                else:
                                    print 'Error: Python expressions disallowed in this file.'
                                    return None
                            else:
                                # try to find a keyword which matches
                                if self.cmd.kwhash.has_key(com):
                                    amb = self.cmd.kwhash.interpret(com)
                                    if amb == None:
                                        com = self.cmd.kwhash[com]
                                    elif type(amb)!=types.StringType:
                                        print 'Error: ambiguous command: '
                                        amb.sort()
                                        amb = parsing.list_to_str_list(amb)
                                        for a in amb:
                                            print a
                                        raise QuietException
                                    com = amb
                                if self.cmd.keyword.has_key(com):
                                    # here is the command and argument handling section
                                    layer.kw = self.cmd.keyword[com]
                                    if layer.kw[4]>=parsing.NO_CHECK:
                                        # stricter, Python-based argument parsing
                                        # remove line breaks (only important for Python expressions)
                                        layer.com2=string.replace(layer.com2,'\n','')

                                        if layer.kw[4]>=parsing.LITERAL: # treat literally
                                            layer.next = []
                                            if not secure:
                                                layer.com2=layer.com1
                                            else:
                                                print 'Error: Python expressions disallowed in this file.  '
                                                return 0
                                        if secure and (layer.kw[4]==parsing.SECURE):
                                            layer.next = []
                                            print 'Error: Command disallowed in this file.'
                                            return None
                                        else:
                                           (layer.args, layer.kw_args) = \
                                            parsing.prepare_call(
                                             layer.kw[0],
                                             parsing.parse_arg(layer.com2,mode=layer.kw[4],_self=self.cmd),
                                             layer.kw[4], _self=self.cmd) # will raise exception on failure
                                        self.result=apply(layer.kw[0],layer.args,layer.kw_args)
                                    elif layer.kw[4]==parsing.PYTHON:
                                            # handle python keyword
                                            layer.com2 = string.strip(layer.com2)
                                            if len(layer.com2)>0:
                                                if not secure:
                                                    exec(layer.com2+"\n",self.pymol_names,self.pymol_names)
                                                else:
                                                    layer.next = []                                    
                                                    print 'Error: Python expressions disallowed in this file.'
                                                    return None
                                    else:
                                        # remove line breaks (only important for Python expressions)
                                        layer.com2=string.replace(layer.com2,'\n','')
                                        # old parsing style, being phased out
                                        if layer.kw[4]==parsing.ABORT:
                                            return None # SCRIPT ABORT EXIT POINT
                                        if layer.kw[4]==parsing.MOVIE: # copy literal single line, no breaks
                                            layer.next = []
                                            if not secure:
                                                layer.input = string.split(layer.com1,' ',1)
                                            else:
                                                print 'Error: Movie commands disallowed in this file. '
                                                return None
                                        if len(layer.input)>1:
                                            layer.args = parsing.split(layer.input[1],layer.kw[3])
                                            while 1:
                                                nArg = len(layer.args) - 1
                                                c = 0
                                                while c < nArg:
                                                    if (string.count(layer.args[c],'(')!=
                                                         string.count(layer.args[c],')')):
                                                        tmp=layer.args[c+1]
                                                        layer.args.remove(tmp)
                                                        layer.args[c]=string.strip(layer.args[c])+\
                                                                          ','+string.strip(tmp)
                                                        nArg = nArg-1
                                                        break;
                                                    c = c + 1
                                                if c == nArg:
                                                    break;
                                            if len(layer.args)==1 and len(layer.args[0])==0:
                                                layer.args = []
                                        else:
                                            layer.args = []
                                        if layer.kw[1]<= len(layer.args) <= layer.kw[2]:
                                            layer.args = map(string.strip,layer.args)
                                            if layer.kw[4]<parsing.RUN:
                                                #                           
                                                # this is where old-style commands are invoked
                                                #
                                                self.result=apply(layer.kw[0],layer.args)
                                                #                           
                                            elif layer.kw[4]==parsing.SPAWN:
                                                if not secure:
                                                    path = exp_path(layer.args[0])                                                    
                                                    if re.search("\.pml$",path) != None:
                                                        if self.cmd._feedback(fb_module.parser,fb_mask.warnings):
                                                            print "Warning: use '@' instead of 'spawn' with PyMOL command scripts?"
                                                    # spawn command
                                                    if len(layer.args)==1: # default: module
                                                        parsing.run_file_as_module(path,spawn=1)
                                                    elif layer.args[1]=='main':
                                                        parsing.spawn_file(path,__main__.__dict__,__main__.__dict__)
                                                    elif layer.args[1]=='private':
                                                        parsing.spawn_file(path,__main__.__dict__,{})
                                                    elif layer.args[1]=='local':
                                                        parsing.spawn_file(path,self.pymol_names,{})
                                                    elif layer.args[1]=='global':
                                                        parsing.spawn_file(path,self.pymol_names,self.pymol_names)
                                                    elif layer.args[1]=='module':
                                                        parsing.run_file_as_module(path,spawn=1)
                                                else:
                                                    layer.next = []                                    
                                                    print 'Error: spawn disallowed in this file.'
                                                    return None
                                            elif layer.kw[4]==parsing.RUN: # synchronous
                                                if not secure:
                                                    path = exp_path(layer.args[0])
                                                    if re.search("\.pml$",path) != None:
                                                        if self.cmd._feedback(fb_module.parser,fb_mask.warnings):
                                                            print "Warning: use '@' instead of 'run' with PyMOL command scripts?"
                                                    # run command
                                                    if len(layer.args)==1: # default: global
                                                        parsing.run_file(path,self.pymol_names,self.pymol_names)
                                                    elif layer.args[1]=='main':
                                                        parsing.run_file(path,__main__.__dict__,__main__.__dict__)
                                                    elif layer.args[1]=='private':
                                                        parsing.run_file(path,__main__.__dict__,{})
                                                    elif layer.args[1]=='local':
                                                        parsing.run_file(path,self.pymol_names,{})
                                                    elif layer.args[1]=='global':
                                                        parsing.run_file(path,self.pymol_names,self.pymol_names)
                                                    elif layer.args[1]=='module':
                                                        parsing.run_file_as_module(path,spawn=0)
                                                    self.cmd._pymol.__script__ = layer.sc_path
                                                else:
                                                    layer.next = []                                    
                                                    print 'Error: run disallowed in this file.'
                                                    return None                                    
                                            elif (layer.kw[4]==parsing.EMBED):
                                                layer.next = []
                                                if secure or self.nest==0: # only legal on top level and p1m files
                                                    l = len(layer.args)
                                                    if l>0:
                                                        key = layer.args[0]
                                                    else:
                                                        key = os.path.splitext(os.path.basename(layer.sc_path))[0]
                                                    if l>1:
                                                        format = layer.args[1]
                                                    else:
                                                        format = 'pdb'
                                                    if l>2:
                                                        layer.embed_sentinel = layer.args[2]
                                                    else:
                                                        layer.embed_sentinel = "embed end"
                                                    list = []
                                                    layer.embed_dict[key] = ( format, list )
                                                    layer.embed_list = list
                                                    layer.embed_type = 0 # not a python block
                                                else:
                                                    print 'Error: embed only legal in special files (e.g. p1m)'
                                                    raise None
                                            elif (layer.kw[4]==parsing.SKIP):
                                                layer.next = []
                                                arg = parsing.apply_arg(
                                                    parsing.parse_arg(layer.com2,_self=self.cmd),
                                                    ('sentinel',),
                                                    {'sentinel':'skip end'})
                                                print arg # ???
                                                if len(layer.args):
                                                    if layer.args[0]=='end': # probable 'skip end' to ignore
                                                        arg = []
                                                if len(arg):
                                                    layer.embed_sentinel = arg[0]
                                                    layer.embed_type = 2 # skip block
                                                    layer.embed_line = 0
                                            elif (layer.kw[4]==parsing.PYTHON_BLOCK):
                                                layer.next = []
                                                if not secure:
                                                    arg = parsing.apply_arg(
                                                        parsing.parse_arg(layer.com2,_self=self.cmd),
                                                        ('sentinel','skip'),
                                                        {'sentinel':'python end','skip':0})
                                                    layer.embed_sentinel = arg[0]
                                                    list = []
                                                    layer.embed_list = list
                                                    if arg[1]:
                                                        layer.embed_type = 2 # skip block
                                                    else:
                                                        layer.embed_type = 1 # python block
                                                    layer.embed_line = 0
                                                else:
                                                    print 'Error: Python blocks disallowed in this file.'
                                                    raise None
                                            else:
                                                print 'Error: unknown keyword mode: '+str(layer.kw[4])
                                                raise QuietException
                                        else:
                                            print 'Error: invalid arguments for %s command.' % com
        #
        # non-keyword command handling
        #
                                elif len(layer.input[0]):
                                    if layer.input[0][0]=='@':
                                        path = exp_path(string.strip(layer.com2[1:]))
                                        if string.lower(path[-3:])=='p1m':
                                            nest_securely = 1
                                        else:
                                            nest_securely = secure
                                        if re.search("\.py$|\.pym$",path) != None:
                                            if self.cmd._feedback(fb_module.parser,fb_mask.warnings):
                                                print "Warning: use 'run' instead of '@' with Python files?"
                                        layer.script = open(path,'r')
                                        self.cmd._pymol.__script__ = path
                                        self.nest=self.nest+1
                                        self.layer[self.nest] = NestLayer()
                                        layer = self.layer[self.nest]
                                        layer.cont=''
                                        layer.sc_path=path
                                        layer.embed_sentinel=None
                                        while 1:
                                            layer.com0  = self.layer[self.nest-1].script.readline()
                                            if not layer.com0: break
                                            inp_cmd = layer.com0
                                            tmp_cmd = string.strip(inp_cmd)
                                            if len(tmp_cmd):
                                                if tmp_cmd[0] not in ['#','_','/']: # suppress comments, internals, python
                                                    if layer.embed_sentinel==None:
                                                        print "PyMOL>"+tmp_cmd
                                                elif tmp_cmd[0]=='_' and \
                                                      tmp_cmd[1:2] in [' ','']: # "_ " remove echo suppression signal
                                                    inp_cmd=inp_cmd[2:]
                                            pp_result = self.parse(inp_cmd,nest_securely)
                                            if pp_result==None: # RECURSION
                                                break # abort command gets us out
                                            elif pp_result==0: # QuietException
                                                if self.cmd.get_setting_legacy("stop_on_exceptions"):
                                                    p_result = 0 # signal an error occurred
                                                    print"PyMOL: stopped on exception."
                                                    break;
                                        self.nest=self.nest-1
                                        layer=self.layer[self.nest]
                                        
                                        layer.script.close()
                                        self.cmd.__script__ = layer.sc_path
                                    else: # nothing found, try literal python
                                        layer.com2 = string.strip(layer.com2)
                                        if len(layer.com2)>0:
                                            if not secure:
                                                exec(layer.com2+"\n",self.pymol_names,self.pymol_names)
                                            elif layer.input[0][0:1]!='#':
                                                print 'Error: unrecognized keyword: '+layer.input[0]
                        if (len(layer.next)>1) and p_result:
                            # continue parsing if no error or break has occurred
                            self.nest=self.nest+1
                            self.layer[self.nest] = NestLayer()
                            layer=self.layer[self.nest]
                            layer.com0 = self.layer[self.nest-1].next[1]
                            self.layer[self.nest-1].next=[]
                            layer.cont=''
                            layer.embed_sentinel=None
                            p_result = self.parse(layer.com0,secure) # RECURSION
                            self.nest=self.nest-1
                            layer=self.layer[self.nest]
            except QuietException:
                if self.cmd._feedback(fb_module.parser,fb_mask.blather):
                    print "Parser: QuietException caught"
                p_result = 0 # notify caller that an error was encountered
            except CmdException as e:
                if e.args:
                    print " Error:", e.args
                if self.cmd._feedback(fb_module.parser,fb_mask.blather):         
                    print "Parser: CmdException caught."
                p_result = 0
            except:
                traceback.print_exc()
                if self.cmd._feedback(fb_module.parser,fb_mask.blather):
                    print "PyMOL: Caught an unknown exception."
                p_result = 0 # notify caller that an error was encountered
            if not p_result and self.cmd._pymol.invocation.options.exit_on_error:
                self.cmd.quit(1)
            return p_result  # 0 = Exception, None = abort, 1 = ok
Exemplo n.º 3
0
        def parse(self, s, secure):
            layer = self.layer.get(self.nest, None)
            self.result = None
            # report any uncaught errors...
            # WLD: this is problematic if parse is called inside an exception...removed.
            #            if sys.exc_info()!=(None,None,None):
            #                traceback.print_exc()
            #                sys.exc_clear()
            if layer.embed_sentinel != None:
                if string.strip(s) == layer.embed_sentinel:
                    etn = layer.embed_type
                    if etn == 0:  # embedded data
                        print " Embed: read %d lines." % (len(
                            layer.embed_list))
                        layer.embed_sentinel = None
                    elif etn == 1:  # python block
                        print "PyMOL>" + string.rstrip(s)
                        py_block = string.join(layer.embed_list, '')
                        del layer.embed_list
                        layer.embed_sentinel = None
                        try:
                            exec(py_block, self.pymol_names, self.pymol_names)
                        except:
                            traceback.print_exc()
                    elif etn == 2:  # skip block
                        print " Skip: skipped %d lines." % (layer.embed_line)
                        layer.embed_sentinel = None
                else:
                    etn = layer.embed_type
                    if etn == 0:  # normal embedded data
                        layer.embed_list.append(string.rstrip(s) + "\n")
                    elif etn == 1:  # python block
                        el = layer.embed_line + 1
                        print "%5d:%s" % (el, string.rstrip(s))
                        layer.embed_line = el
                        layer.embed_list.append(string.rstrip(s) + "\n")
                    elif etn == 2:
                        layer.embed_line = layer.embed_line + 1
                return 1
            p_result = 1
            layer.com0 = s
            try:
                layer.com1 = string.rstrip(
                    layer.com0)  # strips trailing whitespace
                if len(layer.com1) > 0:
                    if str(layer.com1[-1]) == "\\":
                        # prepend leftovers
                        if layer.cont != '':
                            layer.cont = layer.cont + "\n" + layer.com1[:-1]
                        else:
                            layer.cont = layer.com1[:-1]
                    else:
                        # prepend leftovers
                        if layer.cont != '':
                            layer.com1 = layer.cont + "\n" + layer.com1
                            layer.cont = ''
        # this routine splits up the line first based on semicolon

                        layer.next = parsing.split(layer.com1, ';',
                                                   1) + layer.next[1:]

                        # layer.com2 now a full non-compound command
                        layer.com2 = layer.next[0]
                        layer.input = string.split(layer.com2, ' ', 1)
                        lin = len(layer.input)
                        if lin:
                            layer.input[0] = string.strip(layer.input[0])
                            com = layer.input[0]
                            if (com[0:1] == '/'):
                                # explicit literal python
                                layer.com2 = string.strip(layer.com2[1:])
                                if len(layer.com2) > 0:
                                    if not secure:
                                        exec(layer.com2 + "\n",
                                             self.pymol_names,
                                             self.pymol_names)
                                    else:
                                        print 'Error: Python expressions disallowed in this file.'
                                        return None
                            elif lin > 1 and py_delims.has_key(
                                    string.split(layer.input[-1:][0], ' ',
                                                 1)[0]):
                                if not secure:
                                    exec(layer.com2 + "\n", self.pymol_names,
                                         self.pymol_names)
                                else:
                                    print 'Error: Python expressions disallowed in this file.'
                                    return None
                            else:
                                # try to find a keyword which matches
                                if self.cmd.kwhash.has_key(com):
                                    amb = self.cmd.kwhash.interpret(com)
                                    if amb == None:
                                        com = self.cmd.kwhash[com]
                                    elif type(amb) != types.StringType:
                                        print 'Error: ambiguous command: '
                                        amb.sort()
                                        amb = parsing.list_to_str_list(amb)
                                        for a in amb:
                                            print a
                                        raise QuietException
                                    com = amb
                                if self.cmd.keyword.has_key(com):
                                    # here is the command and argument handling section
                                    layer.kw = self.cmd.keyword[com]
                                    if layer.kw[4] >= parsing.NO_CHECK:
                                        # stricter, Python-based argument parsing
                                        # remove line breaks (only important for Python expressions)
                                        layer.com2 = string.replace(
                                            layer.com2, '\n', '')

                                        if layer.kw[
                                                4] >= parsing.LITERAL:  # treat literally
                                            layer.next = []
                                            if not secure:
                                                layer.com2 = layer.com1
                                            else:
                                                print 'Error: Python expressions disallowed in this file.  '
                                                return 0
                                        if secure and (layer.kw[4]
                                                       == parsing.SECURE):
                                            layer.next = []
                                            print 'Error: Command disallowed in this file.'
                                            return None
                                        else:
                                            (layer.args, layer.kw_args) = \
                                             parsing.prepare_call(
                                              layer.kw[0],
                                              parsing.parse_arg(layer.com2,mode=layer.kw[4],_self=self.cmd),
                                              layer.kw[4], _self=self.cmd) # will raise exception on failure
                                        self.result = apply(
                                            layer.kw[0], layer.args,
                                            layer.kw_args)
                                    elif layer.kw[4] == parsing.PYTHON:
                                        # handle python keyword
                                        layer.com2 = string.strip(layer.com2)
                                        if len(layer.com2) > 0:
                                            if not secure:
                                                exec(layer.com2 + "\n",
                                                     self.pymol_names,
                                                     self.pymol_names)
                                            else:
                                                layer.next = []
                                                print 'Error: Python expressions disallowed in this file.'
                                                return None
                                    else:
                                        # remove line breaks (only important for Python expressions)
                                        layer.com2 = string.replace(
                                            layer.com2, '\n', '')
                                        # old parsing style, being phased out
                                        if layer.kw[4] == parsing.ABORT:
                                            return None  # SCRIPT ABORT EXIT POINT
                                        if layer.kw[
                                                4] == parsing.MOVIE:  # copy literal single line, no breaks
                                            layer.next = []
                                            if not secure:
                                                layer.input = string.split(
                                                    layer.com1, ' ', 1)
                                            else:
                                                print 'Error: Movie commands disallowed in this file. '
                                                return None
                                        if len(layer.input) > 1:
                                            layer.args = parsing.split(
                                                layer.input[1], layer.kw[3])
                                            while 1:
                                                nArg = len(layer.args) - 1
                                                c = 0
                                                while c < nArg:
                                                    if (string.count(
                                                            layer.args[c], '(')
                                                            != string.count(
                                                                layer.args[c],
                                                                ')')):
                                                        tmp = layer.args[c + 1]
                                                        layer.args.remove(tmp)
                                                        layer.args[c]=string.strip(layer.args[c])+\
                                                                          ','+string.strip(tmp)
                                                        nArg = nArg - 1
                                                        break
                                                    c = c + 1
                                                if c == nArg:
                                                    break
                                            if len(layer.args) == 1 and len(
                                                    layer.args[0]) == 0:
                                                layer.args = []
                                        else:
                                            layer.args = []
                                        if layer.kw[1] <= len(
                                                layer.args) <= layer.kw[2]:
                                            layer.args = map(
                                                string.strip, layer.args)
                                            if layer.kw[4] < parsing.RUN:
                                                #
                                                # this is where old-style commands are invoked
                                                #
                                                self.result = apply(
                                                    layer.kw[0], layer.args)
                                                #
                                            elif layer.kw[4] == parsing.SPAWN:
                                                if not secure:
                                                    path = exp_path(
                                                        layer.args[0])
                                                    if re.search(
                                                            "\.pml$",
                                                            path) != None:
                                                        if self.cmd._feedback(
                                                                fb_module.
                                                                parser,
                                                                fb_mask.
                                                                warnings):
                                                            print "Warning: use '@' instead of 'spawn' with PyMOL command scripts?"
                                                    # spawn command
                                                    if len(
                                                            layer.args
                                                    ) == 1:  # default: module
                                                        parsing.run_file_as_module(
                                                            path, spawn=1)
                                                    elif layer.args[
                                                            1] == 'main':
                                                        parsing.spawn_file(
                                                            path,
                                                            __main__.__dict__,
                                                            __main__.__dict__)
                                                    elif layer.args[
                                                            1] == 'private':
                                                        parsing.spawn_file(
                                                            path,
                                                            __main__.__dict__,
                                                            {})
                                                    elif layer.args[
                                                            1] == 'local':
                                                        parsing.spawn_file(
                                                            path,
                                                            self.pymol_names,
                                                            {})
                                                    elif layer.args[
                                                            1] == 'global':
                                                        parsing.spawn_file(
                                                            path,
                                                            self.pymol_names,
                                                            self.pymol_names)
                                                    elif layer.args[
                                                            1] == 'module':
                                                        parsing.run_file_as_module(
                                                            path, spawn=1)
                                                else:
                                                    layer.next = []
                                                    print 'Error: spawn disallowed in this file.'
                                                    return None
                                            elif layer.kw[
                                                    4] == parsing.RUN:  # synchronous
                                                if not secure:
                                                    path = exp_path(
                                                        layer.args[0])
                                                    if re.search(
                                                            "\.pml$",
                                                            path) != None:
                                                        if self.cmd._feedback(
                                                                fb_module.
                                                                parser,
                                                                fb_mask.
                                                                warnings):
                                                            print "Warning: use '@' instead of 'run' with PyMOL command scripts?"
                                                    # run command
                                                    if len(
                                                            layer.args
                                                    ) == 1:  # default: global
                                                        parsing.run_file(
                                                            path,
                                                            self.pymol_names,
                                                            self.pymol_names)
                                                    elif layer.args[
                                                            1] == 'main':
                                                        parsing.run_file(
                                                            path,
                                                            __main__.__dict__,
                                                            __main__.__dict__)
                                                    elif layer.args[
                                                            1] == 'private':
                                                        parsing.run_file(
                                                            path,
                                                            __main__.__dict__,
                                                            {})
                                                    elif layer.args[
                                                            1] == 'local':
                                                        parsing.run_file(
                                                            path,
                                                            self.pymol_names,
                                                            {})
                                                    elif layer.args[
                                                            1] == 'global':
                                                        parsing.run_file(
                                                            path,
                                                            self.pymol_names,
                                                            self.pymol_names)
                                                    elif layer.args[
                                                            1] == 'module':
                                                        parsing.run_file_as_module(
                                                            path, spawn=0)
                                                    self.cmd._pymol.__script__ = layer.sc_path
                                                else:
                                                    layer.next = []
                                                    print 'Error: run disallowed in this file.'
                                                    return None
                                            elif (layer.kw[4] == parsing.EMBED
                                                  ):
                                                layer.next = []
                                                if secure or self.nest == 0:  # only legal on top level and p1m files
                                                    l = len(layer.args)
                                                    if l > 0:
                                                        key = layer.args[0]
                                                    else:
                                                        key = os.path.splitext(
                                                            os.path.basename(
                                                                layer.sc_path)
                                                        )[0]
                                                    if l > 1:
                                                        format = layer.args[1]
                                                    else:
                                                        format = 'pdb'
                                                    if l > 2:
                                                        layer.embed_sentinel = layer.args[
                                                            2]
                                                    else:
                                                        layer.embed_sentinel = "embed end"
                                                    list = []
                                                    layer.embed_dict[key] = (
                                                        format, list)
                                                    layer.embed_list = list
                                                    layer.embed_type = 0  # not a python block
                                                else:
                                                    print 'Error: embed only legal in special files (e.g. p1m)'
                                                    raise None
                                            elif (layer.kw[4] == parsing.SKIP):
                                                layer.next = []
                                                arg = parsing.apply_arg(
                                                    parsing.parse_arg(
                                                        layer.com2,
                                                        _self=self.cmd),
                                                    ('sentinel', ),
                                                    {'sentinel': 'skip end'})
                                                print arg  # ???
                                                if len(layer.args):
                                                    if layer.args[
                                                            0] == 'end':  # probable 'skip end' to ignore
                                                        arg = []
                                                if len(arg):
                                                    layer.embed_sentinel = arg[
                                                        0]
                                                    layer.embed_type = 2  # skip block
                                                    layer.embed_line = 0
                                            elif (layer.kw[4] ==
                                                  parsing.PYTHON_BLOCK):
                                                layer.next = []
                                                if not secure:
                                                    arg = parsing.apply_arg(
                                                        parsing.parse_arg(
                                                            layer.com2,
                                                            _self=self.cmd),
                                                        ('sentinel', 'skip'), {
                                                            'sentinel':
                                                            'python end',
                                                            'skip': 0
                                                        })
                                                    layer.embed_sentinel = arg[
                                                        0]
                                                    list = []
                                                    layer.embed_list = list
                                                    if arg[1]:
                                                        layer.embed_type = 2  # skip block
                                                    else:
                                                        layer.embed_type = 1  # python block
                                                    layer.embed_line = 0
                                                else:
                                                    print 'Error: Python blocks disallowed in this file.'
                                                    raise None
                                            else:
                                                print 'Error: unknown keyword mode: ' + str(
                                                    layer.kw[4])
                                                raise QuietException
                                        else:
                                            print 'Error: invalid arguments for %s command.' % com

        #
        # non-keyword command handling
        #
                                elif len(layer.input[0]):
                                    if layer.input[0][0] == '@':
                                        path = exp_path(
                                            string.strip(layer.com2[1:]))
                                        if string.lower(path[-3:]) == 'p1m':
                                            nest_securely = 1
                                        else:
                                            nest_securely = secure
                                        if re.search("\.py$|\.pym$",
                                                     path) != None:
                                            if self.cmd._feedback(
                                                    fb_module.parser,
                                                    fb_mask.warnings):
                                                print "Warning: use 'run' instead of '@' with Python files?"
                                        layer.script = open(path, 'r')
                                        self.cmd._pymol.__script__ = path
                                        self.nest = self.nest + 1
                                        self.layer[self.nest] = NestLayer()
                                        layer = self.layer[self.nest]
                                        layer.cont = ''
                                        layer.sc_path = path
                                        layer.embed_sentinel = None
                                        while 1:
                                            layer.com0 = self.layer[
                                                self.nest -
                                                1].script.readline()
                                            if not layer.com0: break
                                            inp_cmd = layer.com0
                                            tmp_cmd = string.strip(inp_cmd)
                                            if len(tmp_cmd):
                                                if tmp_cmd[0] not in [
                                                        '#', '_', '/'
                                                ]:  # suppress comments, internals, python
                                                    if layer.embed_sentinel == None:
                                                        print "PyMOL>" + tmp_cmd
                                                elif tmp_cmd[0]=='_' and \
                                                      tmp_cmd[1:2] in [' ','']: # "_ " remove echo suppression signal
                                                    inp_cmd = inp_cmd[2:]
                                            pp_result = self.parse(
                                                inp_cmd, nest_securely)
                                            if pp_result == None:  # RECURSION
                                                break  # abort command gets us out
                                            elif pp_result == 0:  # QuietException
                                                if self.cmd.get_setting_legacy(
                                                        "stop_on_exceptions"):
                                                    p_result = 0  # signal an error occurred
                                                    print "PyMOL: stopped on exception."
                                                    break
                                        self.nest = self.nest - 1
                                        layer = self.layer[self.nest]

                                        layer.script.close()
                                        self.cmd.__script__ = layer.sc_path
                                    else:  # nothing found, try literal python
                                        layer.com2 = string.strip(layer.com2)
                                        if len(layer.com2) > 0:
                                            if not secure:
                                                exec(layer.com2 + "\n",
                                                     self.pymol_names,
                                                     self.pymol_names)
                                            elif layer.input[0][0:1] != '#':
                                                print 'Error: unrecognized keyword: ' + layer.input[
                                                    0]
                        if (len(layer.next) > 1) and p_result:
                            # continue parsing if no error or break has occurred
                            self.nest = self.nest + 1
                            self.layer[self.nest] = NestLayer()
                            layer = self.layer[self.nest]
                            layer.com0 = self.layer[self.nest - 1].next[1]
                            self.layer[self.nest - 1].next = []
                            layer.cont = ''
                            layer.embed_sentinel = None
                            p_result = self.parse(layer.com0,
                                                  secure)  # RECURSION
                            self.nest = self.nest - 1
                            layer = self.layer[self.nest]
            except QuietException:
                if self.cmd._feedback(fb_module.parser, fb_mask.blather):
                    print "Parser: QuietException caught"
                p_result = 0  # notify caller that an error was encountered
            except CmdException as e:
                if e.args:
                    print e
                if self.cmd._feedback(fb_module.parser, fb_mask.blather):
                    print "Parser: CmdException caught."
                p_result = 0
            except:
                traceback.print_exc()
                if self.cmd._feedback(fb_module.parser, fb_mask.blather):
                    print "PyMOL: Caught an unknown exception."
                p_result = 0  # notify caller that an error was encountered
            if not p_result and self.cmd._pymol.invocation.options.exit_on_error:
                self.cmd.quit(1)
            return p_result  # 0 = Exception, None = abort, 1 = ok
Exemplo n.º 4
0
def main():
    filePath = "sample_input/example1.s"
    dataCount = 0
    textCount = 0
    data = False
    text = False
    PC = 0

    #Data offset starts at 0x10000000
    dataPC = int("10000000", base=16)
    out = ""

    #In this first while loop we go through and keep track of labels, data values, number of instructions and number of data values.
    with open(filePath) as fp:
        line = fp.readline()
        cnt = 1
        while line:
            instArray = parsing.split(line.strip())

            #These two if statements above just keep track of where in the file we are.
            if (instArray[0] == ".data"):
                data = True
                text = False

            elif (instArray[0] == ".text"):
                data = False
                text = True

            if (data):
                #Here we add to our datavalues list, depending on whether the data type is acceptable.
                if (len(instArray) == 3):
                    if (instArray[1] in dataTypes):
                        dataCount += 1
                        dataValues.append("{},{},{}".format(
                            instArray[0][:-1], hex(dataPC), instArray[2]))
                        dataPC += 4
                        #print(hex(dataPC))
            if (text):
                #Check whether or not the line is a label.
                if (not ":" in instArray[0] and not "." in instArray[0]):
                    textCount += 1
                    #print("Counted this as text instruction")
                    if (instArray[0] in instruction_list):
                        PC += 4
                        if (instArray[0] == "la"):
                            ori = False
                            ori = parsing.checkLA(instArray, dataValues)
                            if (ori):
                                #print("Need ori instruction")
                                PC += 4
                                textCount += 1
                elif (":" in instArray[0] and not instArray[0] == "main:"):
                    labelsOffset.append("{},{}".format(instArray[0][:-1], PC))

            line = fp.readline()
            cnt += 1

    #for x in labelsOffset:
    #print(x)

    out += format(textCount * 4, '032b')
    out += format(dataCount * 4, '032b')

    PC = int("0", base=16)

    #In this second while loop is where we start using the above variables and we translate each instruction into its binary form.
    with open(filePath) as fp:
        line = fp.readline()
        cnt = 1
        while line:
            instArray = parsing.split(line.strip())
            #print(instArray)

            if (instArray[0] in instruction_list):
                #print(hex(PC))
                out += parsing.translateInstruction(instArray, dataValues, PC,
                                                    labelsOffset)
                #As a special case, la will be checked for and only if its lower 16 values are greater than 0 we will add another instruciton to our program.
                if (instArray[0] == "la"):
                    ori = parsing.checkLA(instArray, dataValues)
                    if (ori):
                        PC += 4
                PC += 4

            line = fp.readline()
            cnt += 1

    #Here we just printout every data value we currently have in our list.
    for data in dataValues:
        if ("0x" in data.split(",")[2]):
            number = int(data.split(",")[2], 16)
            number = format(number, '032b')
            out += number
            #print(number)
        else:
            number = int(data.split(",")[2])
            number = format(number, '032b')
            out += number
            #print(number)

    print(out)
    #print("text {}".format(textCount))
    return 0