summaryrefslogtreecommitdiff
path: root/scripting
diff options
context:
space:
mode:
Diffstat (limited to 'scripting')
-rw-r--r--scripting/source/pyprov/pythonscript.py143
1 files changed, 72 insertions, 71 deletions
diff --git a/scripting/source/pyprov/pythonscript.py b/scripting/source/pyprov/pythonscript.py
index 03f0cdeae7c8..c62c22872f9c 100644
--- a/scripting/source/pyprov/pythonscript.py
+++ b/scripting/source/pyprov/pythonscript.py
@@ -23,6 +23,7 @@ import os
import imp
import time
import ast
+import platform
try:
unicode
@@ -82,18 +83,18 @@ def getLogTarget():
except:
print("Exception during creation of pythonscript logfile: "+ lastException2String() + "\n, delagating log to stdout\n")
return ret
-
+
class Logger(LogLevel):
def __init__(self , target ):
self.target = target
def isDebugLevel( self ):
return self.use >= self.DEBUG
-
+
def debug( self, msg ):
if self.isDebugLevel():
self.log( self.DEBUG, msg )
-
+
def isErrorLevel( self ):
return self.use >= self.ERROR
@@ -159,12 +160,12 @@ def readTextFromStream( inputStream ):
if read < BLOCK_SIZE:
break
return code.value
-
+
def toIniName( str ):
- # TODO: what is the official way to get to know whether i am on the windows platform ?
- if( hasattr(sys , "dllhandle") ):
+ if platform.system() == "Windows":
return str + ".ini"
- return str + "rc"
+ else:
+ return str + "rc"
""" definition: storageURI is the system dependent, absolute file url, where the script is stored on disk
@@ -177,7 +178,7 @@ class MyUriHelper:
{ "share" : "vnd.sun.star.expand:$BRAND_BASE_DIR/$BRAND_SHARE_SUBDIR/Scripts/python" , \
"share:uno_packages" : "vnd.sun.star.expand:$UNO_SHARED_PACKAGES_CACHE/uno_packages", \
"user" : "vnd.sun.star.expand:${$BRAND_INI_DIR/" + toIniName( "bootstrap") + "::UserInstallation}/user/Scripts/python" , \
- "user:uno_packages" : "vnd.sun.star.expand:$UNO_USER_PACKAGES_CACHE/uno_packages" }
+ "user:uno_packages" : "vnd.sun.star.expand:$UNO_USER_PACKAGES_CACHE/uno_packages" }
self.m_uriRefFac = ctx.ServiceManager.createInstanceWithContext("com.sun.star.uri.UriReferenceFactory",ctx)
if location.startswith( "vnd.sun.star.tdoc" ):
self.m_baseUri = location + "/Scripts/python"
@@ -186,10 +187,10 @@ class MyUriHelper:
self.m_baseUri = expandUri( self.s_UriMap[location] )
self.m_scriptUriLocation = location
log.debug( "initialized urihelper with baseUri="+self.m_baseUri + ",m_scriptUriLocation="+self.m_scriptUriLocation )
-
+
def getRootStorageURI( self ):
return self.m_baseUri
-
+
def getStorageURI( self, scriptURI ):
return self.scriptURI2StorageUri(scriptURI)
@@ -207,7 +208,7 @@ class MyUriHelper:
"?language=" + LANGUAGENAME + "&location=" + self.m_scriptUriLocation
log.debug( "converting storageURI="+storageURI + " to scriptURI=" + ret )
return ret
-
+
def scriptURI2StorageUri( self, scriptURI ):
try:
myUri = self.m_uriRefFac.parse(scriptURI)
@@ -220,7 +221,7 @@ class MyUriHelper:
except Exception as e:
log.error( "error during converting scriptURI="+scriptURI + ": " + str(e))
raise RuntimeException( "pythonscript:scriptURI2StorageUri: " + str(e), None )
-
+
class ModuleEntry:
def __init__( self, lastRead, module ):
@@ -256,14 +257,14 @@ def checkForPythonPathBesideScript( url ):
if 1 == os.access( encfile(path), os.F_OK) and not path in sys.path:
log.log( LogLevel.DEBUG, "adding " + path + " to sys.path" )
sys.path.append( path )
-
-
+
+
class ScriptContext(unohelper.Base):
def __init__( self, ctx, doc, inv ):
self.ctx = ctx
self.doc = doc
self.inv = inv
-
+
# XScriptContext
def getDocument(self):
if self.doc:
@@ -296,12 +297,12 @@ class ScriptContext(unohelper.Base):
# log.debug("file " + url + " has changed, reloading")
# else:
# load = False
-#
+#
# if load:
# log.debug( "opening >" + url + "<" )
#
# code = readTextFromStream( sfa.openFileRead( url ) )
-
+
# execute the module
# entry = ModuleEntry( lastRead, imp.new_module("ooo_script_framework") )
# entry.module.__dict__[GLOBAL_SCRIPTCONTEXT_NAME] = g_scriptContext
@@ -324,13 +325,13 @@ class ProviderContext:
def getTransientPartFromUrl( self, url ):
rest = url.replace( self.rootUrl , "",1 ).replace( "/","",1)
return rest[0:rest.find("/")]
-
+
def getPackageNameFromUrl( self, url ):
rest = url.replace( self.rootUrl , "",1 ).replace( "/","",1)
start = rest.find("/") +1
return rest[start:rest.find("/",start)]
-
-
+
+
def removePackageByUrl( self, url ):
items = self.mapPackageName2Path.items()
for i in items:
@@ -348,20 +349,20 @@ class ProviderContext:
else:
package = Package( (url,), transientPart)
self.mapPackageName2Path[ packageName ] = package
-
+
def isUrlInPackage( self, url ):
values = self.mapPackageName2Path.values()
for i in values:
-# print ("checking " + url + " in " + str(i.paths))
+# print ("checking " + url + " in " + str(i.paths))
if url in i.paths:
return True
# print ("false")
return False
-
+
def setPackageAttributes( self, mapPackageName2Path, rootUrl ):
self.mapPackageName2Path = mapPackageName2Path
self.rootUrl = rootUrl
-
+
def getPersistentUrlFromStorageUrl( self, url ):
# package name is the second directory
ret = url
@@ -431,14 +432,14 @@ class ProviderContext:
log.debug( "file " + url + " has changed, reloading" )
else:
load = False
-
+
if load:
log.debug( "opening >" + url + "<" )
-
+
src = readTextFromStream( self.sfa.openFileRead( url ) )
checkForPythonPathBesideScript( url[0:url.rfind('/')] )
- src = ensureSourceState( src )
-
+ src = ensureSourceState( src )
+
# execute the module
entry = ModuleEntry( lastRead, imp.new_module("ooo_script_framework") )
entry.module.__dict__[GLOBAL_SCRIPTCONTEXT_NAME] = self.scriptContext
@@ -453,14 +454,14 @@ class ProviderContext:
self.modules[ url ] = entry
log.debug( "mapped " + url + " to " + str( entry.module ) )
return entry.module
-
+
#--------------------------------------------------
def isScript( candidate ):
ret = False
if isinstance( candidate, type(isScript) ):
ret = True
return ret
-
+
#-------------------------------------------------------
class ScriptBrowseNode( unohelper.Base, XBrowseNode , XPropertySet, XInvocation, XActionListener ):
def __init__( self, provCtx, uri, fileName, funcName ):
@@ -468,7 +469,7 @@ class ScriptBrowseNode( unohelper.Base, XBrowseNode , XPropertySet, XInvocation,
self.funcName = funcName
self.provCtx = provCtx
self.uri = uri
-
+
def getName( self ):
return self.funcName
@@ -477,7 +478,7 @@ class ScriptBrowseNode( unohelper.Base, XBrowseNode , XPropertySet, XInvocation,
def hasChildNodes(self):
return False
-
+
def getType( self):
return SCRIPT
@@ -489,19 +490,19 @@ class ScriptBrowseNode( unohelper.Base, XBrowseNode , XPropertySet, XInvocation,
self.provCtx.getPersistentUrlFromStorageUrl( self.uri + "$" + self.funcName ) )
elif name == "Editable" and ENABLE_EDIT_DIALOG:
ret = not self.provCtx.sfa.isReadOnly( self.uri )
-
+
log.debug( "ScriptBrowseNode.getPropertyValue called for " + name + ", returning " + str(ret) )
except:
log.error( "ScriptBrowseNode.getPropertyValue error " + lastException2String())
raise
-
+
return ret
def setPropertyValue( self, name, value ):
log.debug( "ScriptBrowseNode.setPropertyValue called " + name + "=" +str(value ) )
def getPropertySetInfo( self ):
log.debug( "ScriptBrowseNode.getPropertySetInfo called " )
return None
-
+
def getIntrospection( self ):
return None
@@ -540,12 +541,12 @@ class ScriptBrowseNode( unohelper.Base, XBrowseNode , XPropertySet, XInvocation,
values = mod.__dict__.get( CALLABLE_CONTAINER_NAME , None )
if not values:
values = mod.__dict__.values()
-
+
for i in values:
if isScript( i ):
i()
break
-
+
elif event.ActionCommand == "Save":
toWrite = uno.ByteSequence(
str(
@@ -561,9 +562,9 @@ class ScriptBrowseNode( unohelper.Base, XBrowseNode , XPropertySet, XInvocation,
# text = self.editor.getControl("EditorTextField").getText()
# log.debug("Would save: " + text)
except:
- # TODO: add an error box here !
+ # TODO: add an error box here!
log.error( lastException2String() )
-
+
def setValue( self, name, value ):
return None
@@ -577,7 +578,7 @@ class ScriptBrowseNode( unohelper.Base, XBrowseNode , XPropertySet, XInvocation,
def hasProperty( self, name ):
return False
-
+
#-------------------------------------------------------
class FileBrowseNode( unohelper.Base, XBrowseNode ):
def __init__( self, provCtx, uri , name ):
@@ -585,15 +586,15 @@ class FileBrowseNode( unohelper.Base, XBrowseNode ):
self.uri = uri
self.name = name
self.funcnames = None
-
+
def getName( self ):
return self.name
-
+
def getChildNodes(self):
ret = ()
try:
self.funcnames = self.provCtx.getFuncsByUrl( self.uri )
-
+
scriptNodeList = []
for i in self.funcnames:
scriptNodeList.append(
@@ -612,11 +613,11 @@ class FileBrowseNode( unohelper.Base, XBrowseNode ):
return len(self.getChildNodes()) > 0
except:
return False
-
+
def getType( self):
return CONTAINER
-
+
class DirBrowseNode( unohelper.Base, XBrowseNode ):
def __init__( self, provCtx, name, rootUrl ):
@@ -661,13 +662,13 @@ class DirBrowseNode( unohelper.Base, XBrowseNode ):
class ManifestHandler( XDocumentHandler, unohelper.Base ):
def __init__( self, rootUrl ):
self.rootUrl = rootUrl
-
+
def startDocument( self ):
self.urlList = []
-
+
def endDocument( self ):
pass
-
+
def startElement( self , name, attlist):
if name == "manifest:file-entry":
if attlist.getValueByName( "manifest:media-type" ) == "application/vnd.sun.star.framework-script":
@@ -699,11 +700,11 @@ def isPyFileInPath( sfa, path ):
break
return ret
-# extracts META-INF directory from
+# extracts META-INF directory from
def getPathsFromPackage( rootUrl, sfa ):
ret = ()
try:
- fileUrl = rootUrl + "/META-INF/manifest.xml"
+ fileUrl = rootUrl + "/META-INF/manifest.xml"
inputStream = sfa.openFileRead( fileUrl )
parser = uno.getComponentContext().ServiceManager.createInstance( "com.sun.star.xml.sax.Parser" )
handler = ManifestHandler( rootUrl )
@@ -718,7 +719,7 @@ def getPathsFromPackage( rootUrl, sfa ):
log.debug( "getPathsFromPackage " + fileUrl + " Exception: " +text )
pass
return ret
-
+
class Package:
def __init__( self, paths, transientPathElement ):
@@ -734,8 +735,8 @@ class DummyInteractionHandler( unohelper.Base, XInteractionHandler ):
class DummyProgressHandler( unohelper.Base, XProgressHandler ):
def __init__( self ):
pass
-
- def push( self,status ):
+
+ def push( self,status ):
log.debug( "pythonscript: DummyProgressHandler.push " + str( status ) )
def update( self,status ):
log.debug( "pythonscript: DummyProgressHandler.update " + str( status ) )
@@ -771,12 +772,12 @@ def getModelFromDocUrl(ctx, url):
p = Property()
p.Name = "DocumentModel"
p.Handle = -1
-
+
c = Command()
c.Handle = -1
c.Name = "getPropertyValues"
c.Argument = uno.Any("[]com.sun.star.beans.Property", (p,))
-
+
env = CommandEnvironment()
try:
ret = content.execute(c, 0, env)
@@ -899,7 +900,7 @@ def expandUri( uri ):
if uri.startswith( "file:" ):
uri = uno.absolutize("",uri) # necessary to get rid of .. in uri
return uri
-
+
#--------------------------------------------------------------
class PythonScriptProvider( unohelper.Base, XBrowseNode, XScriptProvider, XNameContainer):
def __init__( self, ctx, *args ):
@@ -938,7 +939,7 @@ class PythonScriptProvider( unohelper.Base, XBrowseNode, XScriptProvider, XNameC
# "com.sun.star.script.provider.ScriptURIHelper", (LANGUAGENAME, storageType), ctx)
urlHelper = MyUriHelper( ctx, storageType )
log.debug( "got urlHelper " + str( urlHelper ) )
-
+
rootUrl = expandUri( urlHelper.getRootStorageURI() )
log.debug( storageType + " transformed to " + rootUrl )
@@ -956,7 +957,7 @@ class PythonScriptProvider( unohelper.Base, XBrowseNode, XScriptProvider, XNameC
self.dirBrowseNode = PackageBrowseNode( self.provCtx, LANGUAGENAME, rootUrl )
else:
self.dirBrowseNode = DirBrowseNode( self.provCtx, LANGUAGENAME, rootUrl )
-
+
except Exception as e:
text = lastException2String()
log.debug( "PythonScriptProvider could not be instantiated because of : " + text )
@@ -966,7 +967,7 @@ class PythonScriptProvider( unohelper.Base, XBrowseNode, XScriptProvider, XNameC
return self.dirBrowseNode.getName()
def getChildNodes( self ):
- return self.dirBrowseNode.getChildNodes()
+ return self.dirBrowseNode.getChildNodes()
def hasChildNodes( self ):
return self.dirBrowseNode.hasChildNodes()
@@ -976,22 +977,22 @@ class PythonScriptProvider( unohelper.Base, XBrowseNode, XScriptProvider, XNameC
def getScript( self, uri ):
log.debug( "DirBrowseNode getScript " + uri + " invoked" )
-
+
raise IllegalArgumentException( "DirBrowseNode couldn't instantiate script " + uri , self , 0 )
def getScript( self, scriptUri ):
try:
log.debug( "getScript " + scriptUri + " invoked")
-
+
storageUri = self.provCtx.getStorageUrlFromPersistentUrl(
self.provCtx.uriHelper.getStorageURI(scriptUri) );
log.debug( "getScript: storageUri = " + storageUri)
fileUri = storageUri[0:storageUri.find( "$" )]
- funcName = storageUri[storageUri.find( "$" )+1:len(storageUri)]
-
+ funcName = storageUri[storageUri.find( "$" )+1:len(storageUri)]
+
mod = self.provCtx.getModuleByUrl( fileUri )
log.debug( " got mod " + str(mod) )
-
+
func = mod.__dict__[ funcName ]
log.debug( "got func " + str( func ) )
@@ -1000,7 +1001,7 @@ class PythonScriptProvider( unohelper.Base, XBrowseNode, XScriptProvider, XNameC
text = lastException2String()
log.error( text )
raise ScriptFrameworkErrorException( text, self, scriptUri, LANGUAGENAME, 0 )
-
+
# XServiceInfo
def getSupportedServices( self ):
@@ -1016,11 +1017,11 @@ class PythonScriptProvider( unohelper.Base, XBrowseNode, XScriptProvider, XNameC
log.debug( "getByName called" + str( name ))
return None
-
+
def getElementNames( self ):
log.debug( "getElementNames called")
return ()
-
+
def hasByName( self, name ):
try:
log.debug( "hasByName called " + str( name ))
@@ -1042,7 +1043,7 @@ class PythonScriptProvider( unohelper.Base, XBrowseNode, XScriptProvider, XNameC
log.debug( "removeByName unknown uri " + str( name ) + ", ignoring" )
raise NoSuchElementException( uri + "is not in package" , self )
log.debug( "removeByName called" + str( uri ) + " successful" )
-
+
def insertByName( self, name, value ):
log.debug( "insertByName called " + str( name ) + " " + str( value ))
uri = expandUri( name )
@@ -1064,13 +1065,13 @@ class PythonScriptProvider( unohelper.Base, XBrowseNode, XScriptProvider, XNameC
def getElementType( self ):
log.debug( "getElementType called" )
return uno.getTypeByName( "void" )
-
+
def hasElements( self ):
log.debug( "hasElements got called")
return False
-
+
g_ImplementationHelper.addImplementation( \
- PythonScriptProvider,g_implName, \
+ PythonScriptProvider,g_implName, \
("com.sun.star.script.provider.LanguageScriptProvider",
"com.sun.star.script.provider.ScriptProviderFor"+ LANGUAGENAME,),)