Commit b4f27cf3 authored by Evan Simpson's avatar Evan Simpson

Script (Python) objects now have a _filepath attribute, also used as the...

Script (Python) objects now have a _filepath attribute, also used as the '__file__' global at runtime.  This prevents an import problem caused by the fix to #1074.
parent a859da52
...@@ -103,6 +103,10 @@ Zope Changes ...@@ -103,6 +103,10 @@ Zope Changes
Bugs fixed Bugs fixed
- Script (Python) objects now have a _filepath attribute, also
used as the '__file__' global at runtime. This prevents an
import problem caused by the fix to #1074.
- Minor usability tweaks: - Minor usability tweaks:
* Increased FindSupport meta type selection widgets * Increased FindSupport meta type selection widgets
......
...@@ -17,11 +17,12 @@ This product provides support for Script objects containing restricted ...@@ -17,11 +17,12 @@ This product provides support for Script objects containing restricted
Python code. Python code.
""" """
__version__='$Revision: 1.54 $'[11:-2] __version__='$Revision: 1.55 $'[11:-2]
import sys, os, traceback, re, marshal, new import sys, os, traceback, re, marshal, new
from Globals import DTMLFile, MessageDialog, package_home from Globals import DTMLFile, MessageDialog, package_home
import AccessControl, OFS, RestrictedPython import AccessControl, OFS, RestrictedPython
from Acquisition import aq_parent
from OFS.SimpleItem import SimpleItem from OFS.SimpleItem import SimpleItem
from DateTime.DateTime import DateTime from DateTime.DateTime import DateTime
from urllib import quote from urllib import quote
...@@ -193,7 +194,7 @@ class PythonScript(Script, Historical, Cacheable): ...@@ -193,7 +194,7 @@ class PythonScript(Script, Historical, Cacheable):
name = name.strip() name = name.strip()
if name and name[0] != '*' and re.match('\w',name): if name and name[0] != '*' and re.match('\w',name):
param_names.append(name.split('=', 1)[0]) param_names.append(name.split('=', 1)[0].strip())
return param_names return param_names
def manage_historyCompare(self, rev1, rev2, REQUEST, def manage_historyCompare(self, rev1, rev2, REQUEST,
...@@ -270,6 +271,9 @@ class PythonScript(Script, Historical, Cacheable): ...@@ -270,6 +271,9 @@ class PythonScript(Script, Historical, Cacheable):
def _makeFunction(self, dummy=0): # CMFCore.FSPythonScript uses dummy arg. def _makeFunction(self, dummy=0): # CMFCore.FSPythonScript uses dummy arg.
self.ZCacheable_invalidate() self.ZCacheable_invalidate()
self._compile() self._compile()
if not (aq_parent(self) is None or hasattr(self, '_filepath')):
# It needs a _filepath, and has an acquisition wrapper.
self._filepath = self.get_filepath()
def _editedBindings(self): def _editedBindings(self):
if getattr(self, '_v_ft', None) is not None: if getattr(self, '_v_ft', None) is not None:
...@@ -288,7 +292,7 @@ class PythonScript(Script, Historical, Cacheable): ...@@ -288,7 +292,7 @@ class PythonScript(Script, Historical, Cacheable):
asgns = self.getBindingAssignments() asgns = self.getBindingAssignments()
name_context = asgns.getAssignedName('name_context', None) name_context = asgns.getAssignedName('name_context', None)
if name_context: if name_context:
keyset[name_context] = self.aq_parent.getPhysicalPath() keyset[name_context] = aq_parent(self).getPhysicalPath()
name_subpath = asgns.getAssignedName('name_subpath', None) name_subpath = asgns.getAssignedName('name_subpath', None)
if name_subpath: if name_subpath:
keyset[name_subpath] = self._getTraverseSubpath() keyset[name_subpath] = self._getTraverseSubpath()
...@@ -313,6 +317,7 @@ class PythonScript(Script, Historical, Cacheable): ...@@ -313,6 +317,7 @@ class PythonScript(Script, Historical, Cacheable):
g.update(bound_names) g.update(bound_names)
g['__traceback_supplement__'] = ( g['__traceback_supplement__'] = (
PythonScriptTracebackSupplement, self, -1) PythonScriptTracebackSupplement, self, -1)
g['__file__'] = getattr(self, '_filepath', None) or self.get_filepath()
f = new.function(fcode, g, None, fadefs) f = new.function(fcode, g, None, fadefs)
result = f(*args, **kw) result = f(*args, **kw)
...@@ -321,6 +326,14 @@ class PythonScript(Script, Historical, Cacheable): ...@@ -321,6 +326,14 @@ class PythonScript(Script, Historical, Cacheable):
self.ZCacheable_set(result, keywords=keyset) self.ZCacheable_set(result, keywords=keyset)
return result return result
def manage_afterAdd(self, item, container):
if item is self:
self._filepath = self.get_filepath()
get_filepath=None # Public
def get_filepath(self):
return self.meta_type + ':' + '/'.join(self.getPhysicalPath())
def manage_haveProxy(self,r): return r in self._proxy_roles def manage_haveProxy(self,r): return r in self._proxy_roles
def _validateProxy(self, roles=None): def _validateProxy(self, roles=None):
......
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
# FOR A PARTICULAR PURPOSE # FOR A PARTICULAR PURPOSE
# #
############################################################################## ##############################################################################
import os, unittest import os, unittest, warnings
from Products.PythonScripts.PythonScript import PythonScript from Products.PythonScripts.PythonScript import PythonScript
from AccessControl.SecurityManagement import newSecurityManager from AccessControl.SecurityManagement import newSecurityManager
...@@ -55,19 +55,16 @@ class PythonScriptTestBase(unittest.TestCase): ...@@ -55,19 +55,16 @@ class PythonScriptTestBase(unittest.TestCase):
return ps return ps
def _filePS(self, fname, bind=None): def _filePS(self, fname, bind=None):
ps = PythonScript(fname) ps = VerifiedPythonScript(fname)
ps.ZBindings_edit(bind or {}) ps.ZBindings_edit(bind or {})
ps.write(readf(fname)) ps.write(readf(fname))
ps._makeFunction() ps._makeFunction()
if ps.errors:
raise SyntaxError, ps.errors[0]
return ps return ps
class TestPythonScriptNoAq(PythonScriptTestBase): class TestPythonScriptNoAq(PythonScriptTestBase):
def fail(self):
'Fail if called'
assert 0, 'Fail called'
def testEmpty(self): def testEmpty(self):
empty = self._newPS('')() empty = self._newPS('')()
self.failUnless(empty is None) self.failUnless(empty is None)
...@@ -238,10 +235,13 @@ class TestPythonScriptGlobals(PythonScriptTestBase): ...@@ -238,10 +235,13 @@ class TestPythonScriptGlobals(PythonScriptTestBase):
self.assertEqual(results, 8) self.assertEqual(results, 8)
def test__name__(self): def test__name__(self):
fname = 'class.__name__' f = self._filePS('class.__name__')
f = self._filePS(fname)
self.assertEqual(f(), ('?.foo', "'string'")) self.assertEqual(f(), ('?.foo', "'string'"))
def test_filepath(self):
f = self._filePS('filepath')
self.assertEqual(f(), [0])
def test_suite(): def test_suite():
suite = unittest.TestSuite() suite = unittest.TestSuite()
suite.addTest(unittest.makeSuite(TestPythonScriptNoAq)) suite.addTest(unittest.makeSuite(TestPythonScriptNoAq))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment