a ^W$@s@ddlmZGdddeZGdddeZddZdd Zd S) )_gic@sjeZdZdZGdddeZdddZddejdddddfdd Z dd d Z d d Z dddZ ddZ dS)SignalaObject which gives a nice API for creating and binding signals. :param name: Name of signal or callable closure when used as a decorator. :type name: str or callable :param callable func: Callable closure method. :param GObject.SignalFlags flags: Flags specifying when to run closure. :param type return_type: Return type of the Signal. :param list arg_types: List of argument types specifying the signals function signature :param str doc: Documentation of signal object. :param callable accumulator: Accumulator method with the signature: func(ihint, return_accu, handler_return, accu_data) -> boolean :param object accu_data: User data passed to the accumulator. :Example: .. code-block:: python class Spam(GObject.Object): velocity = 0 @GObject.Signal def pushed(self): self.velocity += 1 @GObject.Signal(flags=GObject.SignalFlags.RUN_LAST) def pulled(self): self.velocity -= 1 stomped = GObject.Signal('stomped', arg_types=(int,)) @GObject.Signal def annotated_signal(self, a:int, b:str): "Python3 annotation support for parameter types. def on_pushed(obj): print(obj) spam = Spam() spam.pushed.connect(on_pushed) spam.pushed.emit() c@sPeZdZdZddZddZddZdd Zd d Zd d Z ddZ ddZ dS)zSignal.BoundSignalz Temporary binding object which can be used for connecting signals without specifying the signal name string to connect. cOs t||SN)str__new__clsnameargskargsr 6/usr/lib64/python3.9/site-packages/gi/_signalhelper.pyrNszSignal.BoundSignal.__new__cCst|||_||_dSr)r__init__signalgobj)selfrrr r r rQs zSignal.BoundSignal.__init__cCsd|S)NzBoundSignal("%s")r rr r r __repr__VszSignal.BoundSignal.__repr__cOs|jj|jg|Ri|S)zCall the signals closure.)rfuncrrr r r r r __call__YszSignal.BoundSignal.__call__cOs|jj||g|Ri|S)z^Same as GObject.Object.connect except there is no need to specify the signal name.rconnect)rcallbackr r r r r r]szSignal.BoundSignal.connectcOs$|jj|d||g|Ri|S)a Same as GObject.Object.connect except there is no need to specify the signal name. In addition concats "::" to the signal name when connecting; for use with notifications like "notify" when a property changes. z::r)rrZdetailr r r r r connect_detailedbsz#Signal.BoundSignal.connect_detailedcCs|j|dS)z"Same as GObject.Object.disconnect.N)r disconnect)rZ handler_idr r r rjszSignal.BoundSignal.disconnectcOs|jjt|g|Ri|S)z[Same as GObject.Object.emit except there is no need to specify the signal name.)remitrrr r r rnszSignal.BoundSignal.emitN) __name__ __module__ __qualname____doc__rrrrrrrrr r r r BoundSignalIsr!cOst|r|j}t||Sr)callablerrrrr r r rsszSignal.__new__Nc Cs|durt|r|}|r"|s"|j}t||rD|sD|sDt|\}}|durRt}||_||_||_||_ ||_||_ ||_ dSr) r#r rrget_signal_annotationstuplerflags return_type arg_types accumulator accu_data) rr rr&r'r(docr)r*r r r rxs    zSignal.__init__cCs|dur |S|||S)z:Returns a BoundSignal when accessed on an object instance.N)r!)rinstanceownerr r r __get__szSignal.__get__c Osjt|tjr&|j|g|Ri|n@t|r8t|}n|j}t||||j|j|j |j |j |j dSdS)zmAllows for instantiated Signals to be used as a decorator or calling of the underlying signal method.r rr&r'r(r+r)r*N) isinstancerZGObjectrrrtyper&r'r(r r)r*)robjr r r r r r rs   zSignal.__call__c Cs*t|||j|j|j|j|j|j|jdS)z%Returns a renamed copy of the Signal.r/)r1rr&r'r(r r)r*)rZnewNamer r r copys z Signal.copycCs|j|j|j|j|jfS)zKReturns a tuple of: (flags, return_type, arg_types, accumulator, accu_data))r&r'r(r)r*rr r r get_signal_argsszSignal.get_signal_args)r")N)N)rrrr rr!rrZSIGNAL_RUN_FIRSTrr.rr3r4r r r r rs1*    rc@seZdZdZddZdS)SignalOverridea&Specialized sub-class of Signal which can be used as a decorator for overriding existing signals on GObjects. :Example: .. code-block:: python class MyWidget(Gtk.Widget): @GObject.SignalOverride def configure_event(self): pass cCsdS)zReturns the string 'override'.overrider rr r r r4szSignalOverride.get_signal_argsN)rrrr r4r r r r r5s r5csZt}d}t|drRddl}||tfddjD}djvrRjd}||fS)aAttempt pulling python 3 function annotations off of 'func' for use as a signals type information. Returns an ordered nested tuple of (return_type, (arg_type1, arg_type2, ...)). If the given function does not have annotations then (None, tuple()) is returned. N__annotations__c3s"|]}|jvrj|VqdSr) annotations).0argspecr r s z)get_signal_annotations..return)r%hasattrinspectZgetfullargspecr r9)rr(r'rAr r<r r$s    r$cCs|jdi}i}|jD]`\}}t|trt|}|sT|}||}t|||||vrhtd||||<| ||<q||_ |D]:\}}|j durd| dd}t ||st|||j qdS)zAdds Signal instances on a GObject derived class into the '__gsignals__' dictionary to be picked up and registered as real GObject signals. __gsignals__z(Signal "%s" has already been registered.NZdo_-_)__dict__getitemsr0rrr3setattr ValueErrorr4rBrreplacer@)rZgsignalsZ newsignalsr rZ signalNameZfuncNamer r r install_signalss&      rKN)r"rrrr5r$rKr r r r s