diff --git a/source/smbd/server.c b/source/smbd/server.c index d6f2afdaea4..d30bcd66481 100644 --- a/source/smbd/server.c +++ b/source/smbd/server.c @@ -124,6 +124,19 @@ static void setup_signals(void) } +/* + handle io on stdin +*/ +static void server_stdin_handler(struct event_context *event_ctx, struct fd_event *fde, + uint16_t flags, void *private) +{ + uint8_t c; + if (read(0, &c, 1) == 0) { + DEBUG(0,("EOF on stdin - terminating\n")); + exit(0); + } +} + /* main server. */ @@ -200,6 +213,9 @@ static int binary_smbd_main(int argc, const char *argv[]) should hang off that */ event_ctx = event_context_init(NULL); + /* catch EOF on stdin */ + event_add_fd(event_ctx, event_ctx, 0, EVENT_FD_READ, server_stdin_handler, NULL); + DEBUG(0,("Using %s process model\n", model)); status = server_service_startup(event_ctx, model, lp_server_services()); if (!NT_STATUS_IS_OK(status)) {