mirror of
				https://github.com/zigzap/zap.git
				synced 2025-10-20 15:14:08 +00:00 
			
		
		
		
	Merge branch 'master' into XXX
This commit is contained in:
		
						commit
						75c0cfdf02
					
				
					 2 changed files with 36 additions and 1 deletions
				
			
		|  | @ -96,7 +96,7 @@ void free_ws_buffer(ws_s *owner, struct buffer_s buff) { | |||
| Create/Destroy the websocket object (prototypes) | ||||
| */ | ||||
| 
 | ||||
| static ws_s *new_websocket(); | ||||
| static ws_s *new_websocket(intptr_t uuid); | ||||
| static void destroy_ws(ws_s *ws); | ||||
| 
 | ||||
| /*******************************************************************************
 | ||||
|  |  | |||
|  | @ -75,6 +75,41 @@ pub fn handle_func_unbound(self: *Router, path: []const u8, h: zap.HttpRequestFn | |||
| pub fn handle_func(self: *Router, path: []const u8, instance: *anyopaque, handler: anytype) !void { | ||||
|     // TODO: assert type of instance has handler | ||||
| 
 | ||||
|     // Introspection checks on handler type | ||||
|     comptime { | ||||
|         const hand_info = @typeInfo(@TypeOf(handler)); | ||||
| 
 | ||||
|         // Need to check: | ||||
|         // 1) handler is function pointer | ||||
|         const f = blk: { | ||||
|             if (hand_info == .Pointer) { | ||||
|                 const inner = @typeInfo(hand_info.Pointer.child); | ||||
|                 if (inner == .Fn) { | ||||
|                     break :blk inner.Fn; | ||||
|                 } | ||||
|             } | ||||
|             @compileError("Expected handler to be a function pointer. Found " ++ | ||||
|                 @typeName(@TypeOf(handler))); | ||||
|         }; | ||||
| 
 | ||||
|         // 2) snd arg is zap.Request | ||||
|         if (f.params.len != 2) { | ||||
|             @compileError("Expected handler to have two paramters"); | ||||
|         } | ||||
|         const arg_type = f.params[1].type.?; | ||||
|         if (arg_type != zap.Request) { | ||||
|             @compileError("Expected handler's second argument to be of type zap.Request. Found " ++ | ||||
|                 @typeName(arg_type)); | ||||
|         } | ||||
| 
 | ||||
|         // 3) handler returns void | ||||
|         const ret_info = @typeInfo(f.return_type.?); | ||||
|         if (ret_info != .Void) { | ||||
|             @compileError("Expected handler's return type to be void. Found " ++ | ||||
|                 @typeName(f.return_type.?)); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     if (path.len == 0) { | ||||
|         return RouterError.EmptyPath; | ||||
|     } | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Rene Schallner
						Rene Schallner