source: sasview/sansmodels/src/sans/models/c_models/lineparser.py @ fe10df5

ESS_GUIESS_GUI_DocsESS_GUI_batch_fittingESS_GUI_bumps_abstractionESS_GUI_iss1116ESS_GUI_iss879ESS_GUI_iss959ESS_GUI_openclESS_GUI_orderingESS_GUI_sync_sascalccostrafo411magnetic_scattrelease-4.1.1release-4.1.2release-4.2.2release_4.0.1ticket-1009ticket-1094-headlessticket-1242-2d-resolutionticket-1243ticket-1249ticket885unittest-saveload
Last change on this file since fe10df5 was 27a0771, checked in by Gervaise Alina <gervyh@…>, 16 years ago

add more models

  • Property mode set to 100644
File size: 8.1 KB
RevLine 
[25a608f5]1#!/usr/bin/env python
2""" WrapperGenerator class to generate model code automatically.
3"""
4
5import os, sys,re
6def split_list(separator, mylist, n=0):
7    """
8        @return a list of string without white space of separator
9        @param separator: the string to remove
10    """
11    list=[]
12    for item in mylist:
13        if re.search( separator,item)!=None:
14            if n >0:
15                word =re.split(separator,item,int(n))
16            else:
17                word =re.split( separator,item)
18            for new_item in word: 
19                if new_item.lstrip().rstrip() !='':
20                    list.append(new_item.lstrip().rstrip())
21    return list
22def split_text(separator, string1, n=0):
23    """
24        @return a list of string without white space of separator
25        @param separator: the string to remove
26    """
27    list=[]
28    if re.search( separator,string1)!=None:
29        if n >0:
30            word =re.split(separator,string1,int(n))
31        else:
32            word =re.split(separator,string1)
33        for item in word: 
34            if item.lstrip().rstrip() !='':
35                list.append(item.lstrip().rstrip())
36    return list
37def look_for_tag( string1,begin, end=None ):
38    """
39        @note: this method  remove the begin and end tags given by the user
40        from the string .
41        @param begin: the initial tag
42        @param end: the final tag
43        @param string: the string to check
44        @return: begin_flag==True if begin was found,
45         end_flag==if end was found else return false, false
46         
47    """
48    begin_flag= False
49    end_flag= False
50    if  re.search( begin,string1)!=None:
51        begin_flag= True
52    if end !=None:
53        if  re.search(end,string1)!=None:
54            end_flag= True
55    return begin_flag, end_flag
56
57
58 
59def readhelper(lines,key, key2,key3 , file):
60 
61    temp=""
62    # flag to found key
63    find_fixed= False
64    find_key2=False
65    find_key3=False
66    listtofill=[]
67    for line in lines:
68        if line.count(key.lstrip().rstrip())>0 :#[FIXED]= .....
69            try:
70                #print "found key", key
71                find_fixed= True
72                index = line.index(key)
73                toks  = line[index:].split("=",1 )
74                temp  = toks[1].lstrip().rstrip()
75                find_key2, find_key3=look_for_tag( string1=temp,begin=key2, end=key3 )
76                #print "looking for endpoints",find_key2, find_key3
77                ##[key]=<text>param </text>
78                if find_key2 and find_key3:
79                   
80                    temp1=[]
81                    temp2=[]
82                    temp3=[]
83                    temp4=[]
84                    temp1=split_text(separator=key2, string1=temp)
85                    temp2=split_list(separator=key3, mylist=temp1)
86                    temp3=split_list(separator=';', mylist=temp2)
87                    temp4=split_list(separator=',', mylist=temp3)
88                    listtofill= temp3 + temp4
89                    #print "endpoints found",listtofill
90                    return listtofill
91                   
92                   
93                elif find_key2 and not find_key3:
94                    ## [key]= key2(<text>)
95                    ##        ....
96                    ##        key3(<text>)
97                    temp1=[]
98                    temp2=[]
99                    temp3=[]
100                    temp4=[]
101                    ## remove key2= <text>
102                    temp1=split_text(separator=key2, string1=temp)
103                   
104                    ## split ";" first
105                    temp3=split_list(separator=';', mylist=temp1)
106                    temp4=split_list(separator=',', mylist=temp3)
107           
108                    if len(temp3+ temp4)==0:
109                        # [FIXED]=  only one param
110                        listtofill+= temp1
111                    listtofill += temp3+temp4
112               
113                elif not find_key2 and not find_key3 :
114                    ## [key]= param done looking
115                    temp3=[]
116                    temp4=[]
117                    if look_for_tag( string1=temp,begin=";")[0]:
118                        ## split ";" first
119                        temp3=split_text(separator=';',string1=temp)
120                        temp4=split_list(separator=',', mylist=temp3)
121                    else:
122                        ## slip "," first
123                        temp3=split_text(separator=',',string1=temp)
124                        temp4=split_list(separator=';', mylist=temp3)
125                    if len(temp3+ temp4)==0:
126                        ## [FIXED]=  only one param
[27a0771]127                        if temp.lstrip().rstrip()!="":
128                            listtofill= [temp.lstrip().rstrip()]
[25a608f5]129                       
130                    listtofill += temp3+temp4
131                    return listtofill
132            except:
133                raise ValueError, "Could not parse file %s" % file
134       
135        elif find_fixed :
136            if not find_key2:
137                raise ValueError, "Could not parse file %s" % file
138            #print "find_key3",find_key3,line,key3
139            if find_key3:
140                #print "At the ned of the file----->"
141                temp1=[]
142                temp2=[]
143                temp3=[]
144                temp4=[]
145                temp5=[]
146               
147                temp1=split_text(separator=key3, string1=line)
148                temp2=split_list(separator='//',mylist=temp1)
149                temp5=split_list(separator="\*",mylist=temp1)
150               
151                if len(temp5)>0:
152                    temp3=split_list(separator=';',mylist=temp5)
153                    temp4=split_list(separator=',', mylist=temp5)
154                elif len(temp2)>0:
155                    temp3=split_list(separator=';',mylist=temp2)
156                    temp4=split_list(separator=',', mylist=temp2)
157                else:
158                    temp3=split_list(separator=';',mylist=temp1)
159                    temp4=split_list(separator=',', mylist=temp1)
160               
161                if len(temp3+ temp4)==0:# [FIXED]=  only one param
162                    listtofill+= temp1
163                listtofill+=temp3+temp4 #   
164                break
165           
166            else:
167                temp2=split_text(separator='//',string1=line)
168                temp5=split_text(separator="\*",string1=line)
169                if len(temp5)>0:
170                    temp3=split_list(separator=';',mylist=temp5)
171                    temp4=split_list(separator=',', mylist=temp5)
172                elif len(temp2)>0:
173                    temp3=split_list(separator=';',mylist=temp2)
174                    temp4=split_list(separator=',', mylist=temp2)
175                else:
176                    if look_for_tag( string1=line,begin=";")[0]:# split ";" first
177                        temp3=split_text(separator=';',string1=line)
178                        temp4=split_list(separator=',', mylist=temp3)
179                    else:
180                        temp3=split_text(separator=',',string1=line)# slip "," first
181                        temp4=split_list(separator=';', mylist=temp3)
182                if len(temp3+ temp4)==0:# [FIXED]=  only one param
[27a0771]183                    if line.lstrip().rstrip()!="":
184                        listtofill= [line.lstrip().rstrip()]
[25a608f5]185                listtofill+=temp3+temp4 #
186                break
187    return listtofill
188   
189# main
190if __name__ == '__main__':
191   
192    # Read file
193    name= "sphere.h"
194    f = open("..\c_extensions\core_shell.h",'r')
195    buf = f.read()
196 
197    lines = buf.split('\n')
198 
199    ## Catch Fixed parameters
200    key = "[FIXED]"
201    #open item in this case Fixed
202    text='text'
203    key2="<%s>"%text.lower()
204    # close an item in this case fixed
205    text='TexT'
206    key3="</%s>"%text.lower()
207    listto=[]
208   
209    listto= readhelper(lines, key, key2,key3, file=name)
210    print "fixed parameters\n ",listto
211    print 
212   
213   
214    key0="[ORIENTATION_PARAMS]"
215   
216    listto=[]
217    listto= readhelper(lines,key0, key2,key3, file=name)
218    print "orientation parameters\n ",listto
219    print 
220    f.close()
221# End of file       
Note: See TracBrowser for help on using the repository browser.