mirror of
https://github.com/nim-lang/Nim.git
synced 2026-05-01 03:24:41 +00:00
Renamed new* to init*.
Added example code for documentation. Fixed a small documentation issue. Rewrote newEventEmitter... Updated test.
This commit is contained in:
@@ -11,11 +11,28 @@
|
||||
##
|
||||
## This module implements an event system that is not dependant on external
|
||||
## graphical toolkits. It was originally called ``NimEE`` because
|
||||
## it was inspired by Ptyhon's PyEE module.
|
||||
|
||||
## it was inspired by Python's PyEE module. There are two ways you can use events: one is a python-inspired way; the other is more of a C-style way.
|
||||
## .. code-block:: Nimrod
|
||||
## var ee = initEventEmitter()
|
||||
## var genericargs : TEventArgs
|
||||
## proc handleevent(e : TEventArgs) =
|
||||
## echo("Handled!")
|
||||
##
|
||||
## # Python way
|
||||
## ee.on("EventName", handleevent)
|
||||
## ee.emit("EventName", genericargs)
|
||||
##
|
||||
## # C/Java way
|
||||
## # Declare a type
|
||||
## type
|
||||
## TSomeObject = object of TObject
|
||||
## SomeEvent : TEventHandler
|
||||
## var myobj : TSomeObject
|
||||
## myobj.SomeEvent = initEventHandler("SomeEvent")
|
||||
## myobj.SomeEvent.addHandler(handleevent)
|
||||
## ee.emit(myobj.SomeEvent, genericargs)
|
||||
type
|
||||
TEventArgs* = object of TObject ## Base object for event arguments
|
||||
## that are passed to callback functions.
|
||||
TEventArgs* = object of TObject ## Base object for event arguments that are passed to callback functions.
|
||||
TEventHandler* = tuple[name: string, handlers: seq[proc(e:TEventArgs)]] ## An eventhandler for an event.
|
||||
|
||||
type
|
||||
@@ -23,7 +40,7 @@ type
|
||||
s: seq[TEventHandler]
|
||||
EInvalidEvent* = object of EInvalidValue
|
||||
|
||||
proc newEventHandler*(name: string): TEventHandler =
|
||||
proc initEventHandler*(name: string): TEventHandler =
|
||||
## Initializes an EventHandler with the specified name and returns it.
|
||||
#new(result)
|
||||
result.handlers = @[]
|
||||
@@ -73,9 +90,7 @@ proc emit*(emitter: var TEventEmitter, event: string, args: TEventArgs) =
|
||||
else:
|
||||
raise newException(EInvalidEvent, "invalid event: " & event)
|
||||
|
||||
proc newEventEmitter*(): TEventEmitter =
|
||||
proc initEventEmitter*(): TEventEmitter =
|
||||
## Creates and returns a new EventEmitter.
|
||||
#new(result)
|
||||
var result : TEventEmitter
|
||||
result.s = @[]
|
||||
return result
|
||||
result.s = @[]
|
||||
Reference in New Issue
Block a user