Mercurial > fife-parpg
view engine/extensions/pychan/tools.py @ 253:6ab09eb765a1
* Added patch by MadMonk that exposes the guichan focus functions to pychan
* Thanks for contributing
author | nihathrael@33b003aa-7bff-0310-803a-e67f0ece8222 |
---|---|
date | Fri, 08 May 2009 08:45:27 +0000 |
parents | 54bfd1015b35 |
children | 33dd55160a9d |
line wrap: on
line source
# coding: utf-8 """ Functional utilities designed for pychan use cases. """ import exceptions ### Functools ### def applyOnlySuitable(func,*args,**kwargs): """ This nifty little function takes another function and applies it to a dictionary of keyword arguments. If the supplied function does not expect one or more of the keyword arguments, these are silently discarded. The result of the application is returned. This is useful to pass information to callbacks without enforcing a particular signature. """ if hasattr(func,'im_func'): code = func.im_func.func_code varnames = code.co_varnames[1:code.co_argcount]#ditch bound instance else: code = func.func_code varnames = code.co_varnames[0:code.co_argcount] #http://docs.python.org/lib/inspect-types.html if code.co_flags & 8: return func(*args,**kwargs) for name,value in kwargs.items(): if name not in varnames: del kwargs[name] return func(*args,**kwargs) def callbackWithArguments(callback,*args,**kwargs): """ Curries a function with extra arguments to create a suitable callback. If you don't know what this means, don't worry. It is designed for the case where you need different buttons to execute basically the same code with different argumnets. Usage:: # The target callback def printStuff(text): print text # Mapping the events gui.mapEvents({ 'buttonHello' : callbackWithArguments(printStuff,"Hello"), 'buttonBye' : callbackWithArguments(printStuff,"Adieu") }) """ def real_callback(): callback(*args,**kwargs) return real_callback def attrSetCallback(**kwargs): """ Generates an event callback that sets attributes on the widget it is called on. This is especially useful for mouseEntered/Exited events - to create hover effects. It takes a set of keyword arguments. The keys are treated as attribute names, which are then set to the corresponding value when the callback is called. Some key names are treated special - see below. Usage - Example adapted from demo application:: eventMap = { 'creditsLink' : showCreditsCallback, 'creditsLink/mouseEntered' : attrSetCallback( text = "Show credits!", background_color = (255,255,0,255), do__adaptLayout=True), 'creditsLink/mouseExited' : attrSetCallback(text = "Credits"), gui.mapEvents(eventMap) Now when the mouse enters the creditsLink (a Label in our case), the following code will be executed:: #widget is the creditsLink - given to the event callback. widget.text = "Show credits!" widget.background_color = (255,255,0,255) widget.adaptLayout() The C{do__adaptLayout} argument causes the method C{adaptLayout} to be called. In fact any key starting with C{do__} results in such a method call. The order of execution of such calls is undefined. Keys starting with an underscore raise a L{execptions.PrivateFunctionalityError}. """ do_calls = [] for name in kwargs.keys(): if name.startswith("_"): raise exceptions.PrivateFunctionalityError(name) if name.startswith("do__"): do_calls.append(name[4:]) del kwargs[name] def attrSet_callback(widget=None): for name,value in kwargs.items(): setattr(widget,name,value) for method_name in do_calls: method = getattr(widget,method_name) method() return attrSet_callback def chainCallbacks(*args): """ Chains callbacks to be called one after the other. Example Usage:: def print_event(event=0): print event def print_widget(widget=0): print widget callback = tools.chainCallbacks(doSomethingUseful, print_event, print_widget) guiElement.capture(callback) """ callbacks = args def chain_callback(event=0,widget=0): for callback in callbacks: applyOnlySuitable(callback, event=event, widget=widget) return chain_callback def this_is_deprecated(func,message=None): if message is None: message = repr(func) def wrapped_func(*args,**kwargs): print "PyChan: You are using the DEPRECATED functionality: %s" % message return func(*args,**kwargs) return wrapped_func