mirror of
https://github.com/kekingcn/kkFileView.git
synced 2026-04-19 13:48:37 +00:00
集成OpenOffice替换为LibreOffice
This commit is contained in:
@@ -1,27 +1,25 @@
|
||||
#**************************************************************
|
||||
#
|
||||
# Licensed to the Apache Software Foundation (ASF) under one
|
||||
# or more contributor license agreements. See the NOTICE file
|
||||
# distributed with this work for additional information
|
||||
# regarding copyright ownership. The ASF licenses this file
|
||||
# to you under the Apache License, Version 2.0 (the
|
||||
# "License"); you may not use this file except in compliance
|
||||
# with the License. You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing,
|
||||
# software distributed under the License is distributed on an
|
||||
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
# KIND, either express or implied. See the License for the
|
||||
# specific language governing permissions and limitations
|
||||
# under the License.
|
||||
#
|
||||
#**************************************************************
|
||||
# -*- tab-width: 4; indent-tabs-mode: nil; py-indent-offset: 4 -*-
|
||||
#
|
||||
# This file is part of the LibreOffice project.
|
||||
#
|
||||
# This Source Code Form is subject to the terms of the Mozilla Public
|
||||
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||
#
|
||||
# This file incorporates work covered by the following license notice:
|
||||
#
|
||||
# Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
# contributor license agreements. See the NOTICE file distributed
|
||||
# with this work for additional information regarding copyright
|
||||
# ownership. The ASF licenses this file to you under the Apache
|
||||
# License, Version 2.0 (the "License"); you may not use this file
|
||||
# except in compliance with the License. You may obtain a copy of
|
||||
# the License at http://www.apache.org/licenses/LICENSE-2.0 .
|
||||
#
|
||||
import uno
|
||||
import unohelper
|
||||
import sys
|
||||
import imp
|
||||
import types
|
||||
import os
|
||||
from com.sun.star.uno import Exception,RuntimeException
|
||||
from com.sun.star.loader import XImplementationLoader
|
||||
@@ -43,16 +41,16 @@ g_loadedComponents = {}
|
||||
def checkForPythonPathBesideComponent( url ):
|
||||
path = unohelper.fileUrlToSystemPath( url+"/pythonpath.zip" );
|
||||
if DEBUG == 1:
|
||||
print("checking for existence of " + encfile( path ))
|
||||
print(b"checking for existence of " + encfile( path ))
|
||||
if 1 == os.access( encfile( path ), os.F_OK) and not path in sys.path:
|
||||
if DEBUG == 1:
|
||||
print("adding " + encfile( path ) + " to sys.path")
|
||||
print(b"adding " + encfile( path ) + b" to sys.path")
|
||||
sys.path.append( path )
|
||||
|
||||
path = unohelper.fileUrlToSystemPath( url+"/pythonpath" );
|
||||
if 1 == os.access( encfile( path ), os.F_OK) and not path in sys.path:
|
||||
if DEBUG == 1:
|
||||
print("adding " + encfile( path ) + " to sys.path")
|
||||
print(b"adding " + encfile( path ) + b" to sys.path")
|
||||
sys.path.append( path )
|
||||
|
||||
def encfile(uni):
|
||||
@@ -66,7 +64,7 @@ class Loader( XImplementationLoader, XServiceInfo, unohelper.Base ):
|
||||
|
||||
def getModuleFromUrl( self, url ):
|
||||
if DEBUG:
|
||||
print("pythonloader: interpreting url " +url)
|
||||
print("pythonloader: interpreting url " + url)
|
||||
protocol, dependent = splitUrl( url )
|
||||
if "vnd.sun.star.expand" == protocol:
|
||||
exp = self.ctx.getValueByName( "/singletons/com.sun.star.util.theMacroExpander" )
|
||||
@@ -74,7 +72,7 @@ class Loader( XImplementationLoader, XServiceInfo, unohelper.Base ):
|
||||
protocol,dependent = splitUrl( url )
|
||||
|
||||
if DEBUG:
|
||||
print("pythonloader: after expansion " +protocol +":" + dependent)
|
||||
print("pythonloader: after expansion " + protocol + ":" + dependent)
|
||||
|
||||
try:
|
||||
if "file" == protocol:
|
||||
@@ -84,31 +82,48 @@ class Loader( XImplementationLoader, XServiceInfo, unohelper.Base ):
|
||||
# did we load the module already ?
|
||||
mod = g_loadedComponents.get( url )
|
||||
if not mod:
|
||||
mod = imp.new_module("uno_component")
|
||||
mod = types.ModuleType("uno_component")
|
||||
|
||||
# check for pythonpath.zip beside .py files
|
||||
checkForPythonPathBesideComponent( url[0:url.rfind('/')] )
|
||||
|
||||
# read the file
|
||||
filename = unohelper.fileUrlToSystemPath( url )
|
||||
fileHandle = file( filename )
|
||||
|
||||
fileHandle = open( filename, encoding='utf_8' )
|
||||
src = fileHandle.read().replace("\r","")
|
||||
if not src.endswith( "\n" ):
|
||||
src = src + "\n"
|
||||
|
||||
# compile and execute the module
|
||||
codeobject = compile( src, encfile(filename), "exec" )
|
||||
mod.__file__ = filename
|
||||
exec(codeobject, mod.__dict__)
|
||||
mod.__file__ = encfile(filename)
|
||||
g_loadedComponents[url] = mod
|
||||
return mod
|
||||
elif "vnd.openoffice.pymodule" == protocol:
|
||||
return __import__( dependent )
|
||||
nSlash = dependent.rfind('/')
|
||||
if -1 != nSlash:
|
||||
path = unohelper.fileUrlToSystemPath( dependent[0:nSlash] )
|
||||
dependent = dependent[nSlash+1:len(dependent)]
|
||||
if not path in sys.path:
|
||||
sys.path.append( path )
|
||||
mod = __import__( dependent )
|
||||
path_component, dot, rest = dependent.partition('.')
|
||||
while dot == '.':
|
||||
path_component, dot, rest = rest.partition('.')
|
||||
mod = getattr(mod, path_component)
|
||||
return mod
|
||||
else:
|
||||
if DEBUG:
|
||||
print("Unknown protocol '" + protocol + "'");
|
||||
raise RuntimeException( "PythonLoader: Unknown protocol " +
|
||||
protocol + " in url " +url, self )
|
||||
except ImportError as e:
|
||||
raise RuntimeException( "Couldn't load "+url+ " for reason "+str(e), None)
|
||||
protocol + " in url " +url, self )
|
||||
except Exception as e:
|
||||
if DEBUG:
|
||||
print ("Python import exception " + str(type(e)) +
|
||||
" message " + str(e) + " args " + str(e.args));
|
||||
raise RuntimeException( "Couldn't load " + url + " for reason " + str(e), None )
|
||||
return None
|
||||
|
||||
def activate( self, implementationName, dummy, locationUrl, regKey ):
|
||||
@@ -117,18 +132,20 @@ class Loader( XImplementationLoader, XServiceInfo, unohelper.Base ):
|
||||
|
||||
mod = self.getModuleFromUrl( locationUrl )
|
||||
implHelper = mod.__dict__.get( "g_ImplementationHelper" , None )
|
||||
if implHelper == None:
|
||||
if DEBUG:
|
||||
print ("Fetched ImplHelper as " + str(implHelper))
|
||||
if implHelper is None:
|
||||
return mod.getComponentFactory( implementationName, self.ctx.ServiceManager, regKey )
|
||||
else:
|
||||
return implHelper.getComponentFactory( implementationName,regKey,self.ctx.ServiceManager)
|
||||
|
||||
def writeRegistryInfo( self, regKey, dummy, locationUrl ):
|
||||
if DEBUG:
|
||||
print("pythonloader.Loader.writeRegistryInfo")
|
||||
print( "pythonloader.Loader.writeRegistryInfo" )
|
||||
|
||||
mod = self.getModuleFromUrl( locationUrl )
|
||||
implHelper = mod.__dict__.get( "g_ImplementationHelper" , None )
|
||||
if implHelper == None:
|
||||
if implHelper is None:
|
||||
return mod.writeRegistryInfo( self.ctx.ServiceManager, regKey )
|
||||
else:
|
||||
return implHelper.writeRegistryInfo( regKey, self.ctx.ServiceManager )
|
||||
@@ -137,7 +154,9 @@ class Loader( XImplementationLoader, XServiceInfo, unohelper.Base ):
|
||||
return g_implementationName
|
||||
|
||||
def supportsService( self, ServiceName ):
|
||||
return ServiceName in self.serviceNames
|
||||
return ServiceName in self.getSupportedServiceNames()
|
||||
|
||||
def getSupportedServiceNames( self ):
|
||||
return g_supportedServices
|
||||
|
||||
# vim: set shiftwidth=4 softtabstop=4 expandtab:
|
||||
|
||||
Reference in New Issue
Block a user