diff options
Diffstat (limited to 'numpy/f2py/use_rules.py')
-rw-r--r-- | numpy/f2py/use_rules.py | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/numpy/f2py/use_rules.py b/numpy/f2py/use_rules.py new file mode 100644 index 000000000..8affcbe41 --- /dev/null +++ b/numpy/f2py/use_rules.py @@ -0,0 +1,115 @@ +#!/usr/bin/env python +""" + +Build 'use others module data' mechanism for f2py2e. + +Unfinished. + +Copyright 2000 Pearu Peterson all rights reserved, +Pearu Peterson <pearu@ioc.ee> +Permission to use, modify, and distribute this software is given under the +terms of the LGPL. See http://www.fsf.org + +NO WARRANTY IS EXPRESSED OR IMPLIED. USE AT YOUR OWN RISK. +$Date: 2000/09/10 12:35:43 $ +Pearu Peterson +""" + +__version__ = "$Revision: 1.3 $"[10:-1] + +f2py_version='See `f2py -v`' + +import pprint +import sys,string,time,types,copy +errmess=sys.stderr.write +outmess=sys.stdout.write +show=pprint.pprint + +from auxfuncs import * +import capi_maps +import cfuncs +############## + +usemodule_rules={ + 'body':""" +#begintitle# +static char doc_#apiname#[] = \"\\\nVariable wrapper signature:\\n\\ +\t #name# = get_#name#()\\n\\ +Arguments:\\n\\ +#docstr#\"; +extern F_MODFUNC(#usemodulename#,#USEMODULENAME#,#realname#,#REALNAME#); +static PyObject *#apiname#(PyObject *capi_self, PyObject *capi_args) { +/*#decl#*/ +\tif (!PyArg_ParseTuple(capi_args, \"\")) goto capi_fail; +printf(\"c: %d\\n\",F_MODFUNC(#usemodulename#,#USEMODULENAME#,#realname#,#REALNAME#)); +\treturn Py_BuildValue(\"\"); +capi_fail: +\treturn NULL; +} +""", + 'method':'\t{\"get_#name#\",#apiname#,METH_VARARGS|METH_KEYWORDS,doc_#apiname#},', + 'need':['F_MODFUNC'] + } + +################ + +def buildusevars(m,r): + ret={} + outmess('\t\tBuilding use variable hooks for module "%s" (feature only for F90/F95)...\n'%(m['name'])) + varsmap={} + revmap={} + if r.has_key('map'): + for k in r['map'].keys(): + if revmap.has_key(r['map'][k]): + outmess('\t\t\tVariable "%s<=%s" is already mapped by "%s". Skipping.\n'%(r['map'][k],k,revmap[r['map'][k]])) + else: + revmap[r['map'][k]]=k + if r.has_key('only') and r['only']: + for v in r['map'].keys(): + if m['vars'].has_key(r['map'][v]): + + if revmap[r['map'][v]]==v: + varsmap[v]=r['map'][v] + else: + outmess('\t\t\tIgnoring map "%s=>%s". See above.\n'%(v,r['map'][v])) + else: + outmess('\t\t\tNo definition for variable "%s=>%s". Skipping.\n'%(v,r['map'][v])) + else: + for v in m['vars'].keys(): + if revmap.has_key(v): + varsmap[v]=revmap[v] + else: + varsmap[v]=v + for v in varsmap.keys(): + ret=dictappend(ret,buildusevar(v,varsmap[v],m['vars'],m['name'])) + return ret +def buildusevar(name,realname,vars,usemodulename): + outmess('\t\t\tConstructing wrapper function for variable "%s=>%s"...\n'%(name,realname)) + ret={} + vrd={'name':name, + 'realname':realname, + 'REALNAME':string.upper(realname), + 'usemodulename':usemodulename, + 'USEMODULENAME':string.upper(usemodulename), + 'texname':string.replace(name,'_','\\_'), + 'begintitle':gentitle('%s=>%s'%(name,realname)), + 'endtitle':gentitle('end of %s=>%s'%(name,realname)), + 'apiname':'#modulename#_use_%s_from_%s'%(realname,usemodulename) + } + nummap={0:'Ro',1:'Ri',2:'Rii',3:'Riii',4:'Riv',5:'Rv',6:'Rvi',7:'Rvii',8:'Rviii',9:'Rix'} + vrd['texnamename']=name + for i in nummap.keys(): + vrd['texnamename']=string.replace(vrd['texnamename'],`i`,nummap[i]) + if hasnote(vars[realname]): vrd['note']=vars[realname]['note'] + rd=dictappend({},vrd) + var=vars[realname] + + print name,realname,vars[realname] + ret=applyrules(usemodule_rules,rd) + return ret + + + + + + |