Merge 0.10->trunk
authorMatthew Wild <mwild1@gmail.com>
Sat, 2 Jan 2016 20:42:53 +0000 (20:42 +0000)
committerMatthew Wild <mwild1@gmail.com>
Sat, 2 Jan 2016 20:42:53 +0000 (20:42 +0000)
net/server_event.lua
net/server_select.lua
util/events.lua

index 9b1ffb2584288968b49a6b0a41db256ba008ada9..677586645fd233b010ce82f66a169082d0a0ac86 100644 (file)
@@ -614,6 +614,7 @@ local function handleserver( server, addr, port, pattern, listener, sslctx )  --
        local interface = {
                _connections = 0;
 
+               type = "server";
                conn = server;
                onconnect = listener.onconnect;  -- will be called when new client connected
                eventread = false;  -- read event handler
index 35dcb5a75cc336de133cc043d772e400ae3c1a61..ced73074d56f981357eb6b3513df3949825b8942 100644 (file)
@@ -934,6 +934,7 @@ loop = function(once) -- this is the main loop of the program
                end
        until quitting;
        if once and quitting == "once" then quitting = nil; return; end
+       closeall();
        return "quitting"
 end
 
index 825ffb19b110f7e4d7e517d52fd34fbe6aaeb001..073d2a60fd84b9f317dbf8ace3863eb7cd1556dc 100644 (file)
@@ -17,10 +17,15 @@ local next = next;
 local _ENV = nil;
 
 local function new()
+       -- Map event name to ordered list of handlers (lazily built): handlers[event_name] = array_of_handler_functions
        local handlers = {};
+       -- Array of wrapper functions that wrap all events (nil if empty)
        local global_wrappers;
+       -- Per-event wrappers: wrappers[event_name] = wrapper_function
        local wrappers = {};
+       -- Event map: event_map[handler_function] = priority_number
        local event_map = {};
+       -- Called on-demand to build handlers entries
        local function _rebuild_index(handlers, event)
                local _handlers = event_map[event];
                if not _handlers or next(_handlers) == nil then return; end