mapply.py
上传用户:gyjinxi
上传日期:2007-01-04
资源大小:159k
文件大小:6k
源码类别:

WEB邮件程序

开发平台:

Python

  1. ##############################################################################
  2. # Zope Public License (ZPL) Version 1.0
  3. # -------------------------------------
  4. # Copyright (c) Digital Creations.  All rights reserved.
  5. # This license has been certified as Open Source(tm).
  6. # Redistribution and use in source and binary forms, with or without
  7. # modification, are permitted provided that the following conditions are
  8. # met:
  9. # 1. Redistributions in source code must retain the above copyright
  10. #    notice, this list of conditions, and the following disclaimer.
  11. # 2. Redistributions in binary form must reproduce the above copyright
  12. #    notice, this list of conditions, and the following disclaimer in
  13. #    the documentation and/or other materials provided with the
  14. #    distribution.
  15. # 3. Digital Creations requests that attribution be given to Zope
  16. #    in any manner possible. Zope includes a "Powered by Zope"
  17. #    button that is installed by default. While it is not a license
  18. #    violation to remove this button, it is requested that the
  19. #    attribution remain. A significant investment has been put
  20. #    into Zope, and this effort will continue if the Zope community
  21. #    continues to grow. This is one way to assure that growth.
  22. # 4. All advertising materials and documentation mentioning
  23. #    features derived from or use of this software must display
  24. #    the following acknowledgement:
  25. #      "This product includes software developed by Digital Creations
  26. #      for use in the Z Object Publishing Environment
  27. #      (http://www.zope.org/)."
  28. #    In the event that the product being advertised includes an
  29. #    intact Zope distribution (with copyright and license included)
  30. #    then this clause is waived.
  31. # 5. Names associated with Zope or Digital Creations must not be used to
  32. #    endorse or promote products derived from this software without
  33. #    prior written permission from Digital Creations.
  34. # 6. Modified redistributions of any form whatsoever must retain
  35. #    the following acknowledgment:
  36. #      "This product includes software developed by Digital Creations
  37. #      for use in the Z Object Publishing Environment
  38. #      (http://www.zope.org/)."
  39. #    Intact (re-)distributions of any official Zope release do not
  40. #    require an external acknowledgement.
  41. # 7. Modifications are encouraged but must be packaged separately as
  42. #    patches to official Zope releases.  Distributions that do not
  43. #    clearly separate the patches from the original work must be clearly
  44. #    labeled as unofficial distributions.  Modifications which do not
  45. #    carry the name Zope may be packaged in any form, as long as they
  46. #    conform to all of the clauses above.
  47. # Disclaimer
  48. #   THIS SOFTWARE IS PROVIDED BY DIGITAL CREATIONS ``AS IS'' AND ANY
  49. #   EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  50. #   IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  51. #   PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL DIGITAL CREATIONS OR ITS
  52. #   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  53. #   SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  54. #   LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  55. #   USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  56. #   ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  57. #   OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  58. #   OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  59. #   SUCH DAMAGE.
  60. # This software consists of contributions made by Digital Creations and
  61. # many individuals on behalf of Digital Creations.  Specific
  62. # attributions are listed in the accompanying credits file.
  63. ##############################################################################
  64. """Provide an apply-like facility that works with any mapping object
  65. """
  66. def default_call_object(object, args, context):
  67.     result=apply(object,args) # Type s<cr> to step into published object.
  68.     return result
  69. def default_missing_name(name, context):
  70.     raise TypeError, 'argument %s was ommitted' % name
  71. def default_handle_class(klass, context):
  72.     if hasattr(klass,'__init__'): 
  73.         f=klass.__init__.im_func
  74.         c=f.func_code
  75.         names=c.co_varnames[1:c.co_argcount]
  76.         return klass, names, f.func_defaults
  77.     else:
  78.         return klass, (), ()
  79. def mapply(object, positional=(), keyword={},
  80.            debug=None, maybe=None,
  81.            missing_name=default_missing_name,
  82.            handle_class=default_handle_class,
  83.            context=None, bind=0,
  84.            ):
  85.     if hasattr(object,'__bases__'):
  86.         f, names, defaults = handle_class(object, context)
  87.     else:
  88.         f=object
  89.         im=0
  90.         if hasattr(f, 'im_func'):
  91.             im=1
  92.         elif not hasattr(f,'func_defaults'):
  93.             if hasattr(f, '__call__'):
  94.                 f=f.__call__
  95.                 if hasattr(f, 'im_func'):
  96.                     im=1
  97.                 elif not hasattr(f,'func_defaults') and maybe: return object
  98.             elif maybe: return object
  99.     
  100.         if im:
  101.             f=f.im_func
  102.             c=f.func_code
  103.             defaults=f.func_defaults
  104.             names=c.co_varnames[1:c.co_argcount]
  105.         else:
  106.             defaults=f.func_defaults
  107.             c=f.func_code
  108.             names=c.co_varnames[:c.co_argcount]
  109.     nargs=len(names)
  110.     if positional:
  111.         positional=list(positional)
  112.         if bind and nargs and names[0]=='self':
  113.             positional.insert(0, missing_name('self', context))
  114.         if len(positional) > nargs: raise TypeError, 'too many arguments'
  115.         args=positional
  116.     else:
  117.         if bind and nargs and names[0]=='self':
  118.             args=[missing_name('self', context)]
  119.         else:
  120.             args=[]
  121.     get=keyword.get
  122.     nrequired=len(names) - (len(defaults or ()))
  123.     for index in range(len(args), len(names)):
  124.         name=names[index]
  125.         v=get(name, args)
  126.         if v is args:
  127.             if index < nrequired: v=missing_name(name, context)
  128.             else: v=defaults[index-nrequired]
  129.         args.append(v)
  130.     args=tuple(args)
  131.     if debug is not None: return debug(object,args,context)
  132.     else: return apply(object,args)