mirror of
https://gitlab.com/scemama/irpf90.git
synced 2025-01-03 10:05:40 +01:00
Merge
This commit is contained in:
commit
f4fd841833
@ -24,6 +24,11 @@
|
|||||||
# 31062 Toulouse Cedex 4
|
# 31062 Toulouse Cedex 4
|
||||||
# scemama@irsamc.ups-tlse.fr
|
# scemama@irsamc.ups-tlse.fr
|
||||||
|
|
||||||
|
try:
|
||||||
|
import irpy
|
||||||
|
except:
|
||||||
|
import lib_irpy as irpy
|
||||||
|
|
||||||
|
|
||||||
import getopt, sys
|
import getopt, sys
|
||||||
from version import version
|
from version import version
|
||||||
@ -52,6 +57,7 @@ options['t'] = [ 'touch' , 'Display which entities are touched when touch
|
|||||||
options['v'] = [ 'version' , 'Prints version of irpf90', 0 ]
|
options['v'] = [ 'version' , 'Prints version of irpf90', 0 ]
|
||||||
options['w'] = [ 'warnings' , 'Activate Warnings', 0 ]
|
options['w'] = [ 'warnings' , 'Activate Warnings', 0 ]
|
||||||
options['z'] = [ 'openmp' , 'Activate for OpenMP code', 0 ]
|
options['z'] = [ 'openmp' , 'Activate for OpenMP code', 0 ]
|
||||||
|
options['G'] = [ 'graph' , 'Print the dependecy-graph of the entities (dots format)', 0 ]
|
||||||
|
|
||||||
class CommandLine(object):
|
class CommandLine(object):
|
||||||
|
|
||||||
@ -61,17 +67,16 @@ class CommandLine(object):
|
|||||||
self.argv = list(sys.argv)
|
self.argv = list(sys.argv)
|
||||||
self.executable_name = self.argv[0]
|
self.executable_name = self.argv[0]
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def defined(self):
|
def defined(self):
|
||||||
if '_defined' not in self.__dict__:
|
return [ a for o,a in self.opts if o in [ "-D", '--'+options['D'][0] ] ]
|
||||||
self._defined = []
|
|
||||||
for o,a in self.opts:
|
|
||||||
if o in [ "-D", '--'+options['D'][0] ]:
|
|
||||||
self._defined.append(a)
|
|
||||||
return self._defined
|
|
||||||
defined = property(fget=defined)
|
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
|
def graph(self):
|
||||||
|
return next((a.split() for o,a in self.opts if o in ["-G", '--'+options['G'][0] ]),[])
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def include_dir(self):
|
def include_dir(self):
|
||||||
if '_include_dir' not in self.__dict__:
|
|
||||||
self._include_dir = []
|
self._include_dir = []
|
||||||
for o,a in self.opts:
|
for o,a in self.opts:
|
||||||
if o in [ "-I", '--'+options['I'][0] ]:
|
if o in [ "-I", '--'+options['I'][0] ]:
|
||||||
@ -81,20 +86,13 @@ class CommandLine(object):
|
|||||||
a = a+'/'
|
a = a+'/'
|
||||||
self._include_dir.append(a)
|
self._include_dir.append(a)
|
||||||
return self._include_dir
|
return self._include_dir
|
||||||
include_dir = property(fget=include_dir)
|
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def inline(self):
|
def inline(self):
|
||||||
if '_inline' not in self.__dict__:
|
return next( (a for o,a in self.opts if o in [ "-n", '--'+options['n'][0] ]),'')
|
||||||
self._inline = ""
|
|
||||||
for o,a in self.opts:
|
|
||||||
if o in [ "-n", '--'+options['n'][0] ]:
|
|
||||||
self._inline = a
|
|
||||||
break
|
|
||||||
return self._inline
|
|
||||||
inline = property(fget=inline)
|
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def substituted(self):
|
def substituted(self):
|
||||||
if '_substituted' not in self.__dict__:
|
|
||||||
self._substituted = {}
|
self._substituted = {}
|
||||||
for o,a in self.opts:
|
for o,a in self.opts:
|
||||||
if o in [ "-s", '--'+options['s'][0] ]:
|
if o in [ "-s", '--'+options['s'][0] ]:
|
||||||
@ -102,19 +100,17 @@ class CommandLine(object):
|
|||||||
v_re = re.compile(r"(\W)(%s)(\W.*$|$)"%k.strip())
|
v_re = re.compile(r"(\W)(%s)(\W.*$|$)"%k.strip())
|
||||||
self._substituted[k] = [v, v_re]
|
self._substituted[k] = [v, v_re]
|
||||||
return self._substituted
|
return self._substituted
|
||||||
substituted = property(fget=substituted)
|
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def codelet(self):
|
def codelet(self):
|
||||||
if '_codelet' not in self.__dict__:
|
|
||||||
self._codelet = []
|
|
||||||
for o,a in self.opts:
|
for o,a in self.opts:
|
||||||
if o in [ "-c", '--'+options['c'][0] ]:
|
if o in [ "-c", '--'+options['c'][0] ]:
|
||||||
buffer = a.split(':')
|
buffer = a.split(':')
|
||||||
filename = 'codelet_'+buffer[0]+'.irp.f'
|
filename = 'codelet_'+buffer[0]+'.irp.f'
|
||||||
if len(buffer) == 2:
|
if len(buffer) == 2:
|
||||||
self._codelet = [buffer[0], int(buffer[1]), None, filename]
|
return [buffer[0], int(buffer[1]), None, filename]
|
||||||
elif len(buffer) == 3:
|
elif len(buffer) == 3:
|
||||||
self._codelet = [buffer[0], int(buffer[2]), buffer[1], filename]
|
return [buffer[0], int(buffer[2]), buffer[1], filename]
|
||||||
else:
|
else:
|
||||||
print """
|
print """
|
||||||
Error in codelet definition. Use:
|
Error in codelet definition. Use:
|
||||||
@ -123,80 +119,38 @@ or
|
|||||||
--codelet=provider:precondition:NMAX
|
--codelet=provider:precondition:NMAX
|
||||||
"""
|
"""
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
return self._codelet
|
|
||||||
codelet = property(fget=codelet)
|
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def preprocessed(self):
|
def preprocessed(self):
|
||||||
if '_preprocessed' not in self.__dict__:
|
return [a for o,a in self.ops if o in [ "-p", '--'+options['p'][0] ] ]
|
||||||
self._preprocessed = []
|
|
||||||
for o,a in self.opts:
|
|
||||||
if o in [ "-p", '--'+options['p'][0] ]:
|
|
||||||
self._preprocessed.append(a)
|
|
||||||
return self._preprocessed
|
|
||||||
preprocessed = property(fget=preprocessed)
|
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def touched(self):
|
def touched(self):
|
||||||
if '_touched' not in self.__dict__:
|
return [a for o,a in self.ops if o in [ "-t", '--'+options['t'][0] ] ]
|
||||||
self._touched = []
|
|
||||||
for o,a in self.opts:
|
|
||||||
if o in [ "-t", '--'+options['t'][0] ]:
|
|
||||||
self._touched.append(a.lower())
|
|
||||||
return self._touched
|
|
||||||
touched = property(fget=touched)
|
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def align(self):
|
def align(self):
|
||||||
if '_align' not in self.__dict__:
|
return next( (a for o,a in self.opts if o in [ "-l", '--'+options['l'][0] ]),'1')
|
||||||
self._align = '1'
|
|
||||||
for o,a in self.opts:
|
|
||||||
if o in [ "-l", '--'+options['l'][0] ]:
|
|
||||||
self._align = a
|
|
||||||
return self._align
|
|
||||||
align = property(fget=align)
|
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def coarray(self):
|
def coarray(self):
|
||||||
if '_coarray' not in self.__dict__:
|
return any(o for o,a in self.opts if o in [ "-C", '--'+options['C'][0] ])
|
||||||
self._coarray = False
|
|
||||||
for o,a in self.opts:
|
|
||||||
if o in [ "-C", '--'+options['C'][0] ]:
|
|
||||||
self._coarray = True
|
|
||||||
return self._coarray
|
|
||||||
coarray = property(fget=coarray)
|
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def warnings(self):
|
def warnings(self):
|
||||||
if '_warnings' not in self.__dict__:
|
return any(o for o,a in self.opts if o in [ "-W", '--'+options['W'][0] ])
|
||||||
self._warnings= False
|
|
||||||
for o,a in self.opts:
|
|
||||||
if o in [ "-w", '--'+options['w'][0] ]:
|
|
||||||
self._warnings= True
|
|
||||||
return self._warnings
|
|
||||||
do_warnings = property(fget=warnings)
|
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def openmp(self):
|
def openmp(self):
|
||||||
if '_openmp' not in self.__dict__:
|
return any(o for o,a in self.opts if o in [ "-z", '--'+options['z'][0] ])
|
||||||
self._openmp = False
|
|
||||||
for o,a in self.opts:
|
|
||||||
if o in [ "-z", '--'+options['z'][0] ]:
|
|
||||||
self._openmp = True
|
|
||||||
return self._openmp
|
|
||||||
do_openmp = property(fget=openmp)
|
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def ninja(self):
|
def ninja(self):
|
||||||
if '_ninja' not in self.__dict__:
|
return any(o for o,a in self.opts if o in [ "-j", '--'+options['j'][0] ])
|
||||||
self._ninja = False
|
|
||||||
for o,a in self.opts:
|
|
||||||
if o in [ "-j", '--'+options['j'][0] ]:
|
|
||||||
self._ninja = True
|
|
||||||
return self._ninja
|
|
||||||
do_ninja = property(fget=ninja)
|
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def directives(self):
|
def directives(self):
|
||||||
if '_directives' not in self.__dict__:
|
return not(any(o for o,a in self.opts if o in [ "-r", '--'+options['r'][0] ]))
|
||||||
self._directives = True
|
|
||||||
for o,a in self.opts:
|
|
||||||
if o in [ "-r", '--'+options['r'][0] ]:
|
|
||||||
self._directives = False
|
|
||||||
return self._directives
|
|
||||||
directives = property(fget=directives)
|
|
||||||
|
|
||||||
def usage(self):
|
def usage(self):
|
||||||
t = """
|
t = """
|
||||||
@ -252,16 +206,9 @@ do_$LONG = property(fget=do_$LONG)
|
|||||||
long = options[short][0]
|
long = options[short][0]
|
||||||
exec t.replace("$LONG",long).replace("$SHORT",short) #in locals()
|
exec t.replace("$LONG",long).replace("$SHORT",short) #in locals()
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
def do_run(self):
|
def do_run(self):
|
||||||
if '_do_run' not in self.__dict__:
|
return not(any( (self.do_version, self.do_help, self.do_preprocess, self.do_touch, self.do_init)))
|
||||||
self._do_run = not ( \
|
|
||||||
self.do_version or \
|
|
||||||
self.do_help or \
|
|
||||||
self.do_preprocess or \
|
|
||||||
self.do_touch or \
|
|
||||||
self.do_init )
|
|
||||||
return self._do_run
|
|
||||||
do_run = property(fget=do_run)
|
|
||||||
|
|
||||||
|
|
||||||
command_line = CommandLine()
|
command_line = CommandLine()
|
||||||
|
@ -54,6 +54,17 @@ def main():
|
|||||||
|
|
||||||
comm_world = Irpy_comm_world()
|
comm_world = Irpy_comm_world()
|
||||||
|
|
||||||
|
if command_line.do_graph:
|
||||||
|
comm_world.t_filename_parsed_text # Initialize entity need. Dirty I know.
|
||||||
|
|
||||||
|
print 'graph { '
|
||||||
|
for name,entity in comm_world.d_entity.items():
|
||||||
|
if entity.needs:
|
||||||
|
print ' {0} -> {1}'.format(name, ' '.join(entity.needs))
|
||||||
|
print '}'
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
if command_line.do_preprocess:
|
if command_line.do_preprocess:
|
||||||
for filename, text in comm_world.preprocessed_text:
|
for filename, text in comm_world.preprocessed_text:
|
||||||
if filename in command_line.preprocessed:
|
if filename in command_line.preprocessed:
|
||||||
@ -86,7 +97,6 @@ def main():
|
|||||||
comm_world.create_touches()
|
comm_world.create_touches()
|
||||||
comm_world.create_man()
|
comm_world.create_man()
|
||||||
|
|
||||||
print 'Done'
|
|
||||||
if command_line.do_profile:
|
if command_line.do_profile:
|
||||||
import profile
|
import profile
|
||||||
profile.run()
|
profile.run()
|
||||||
|
Loading…
Reference in New Issue
Block a user