Wiki
Download
Manual
Eggs
API
Tests
Bugs
show
edit
history
You can edit this page using
wiki syntax
for markup.
Article contents:
== Outdated egg! This is an egg for CHICKEN 4, the unsupported old release. You're almost certainly looking for [[/eggref/5/wodehaus|the CHICKEN 5 version of this egg]], if it exists. If it does not exist, there may be equivalent functionality provided by another egg; have a look at the [[https://wiki.call-cc.org/chicken-projects/egg-index-5.html|egg index]]. Otherwise, please consider porting this egg to the current version of CHICKEN. [[tags: egg]] == wodehaus [[toc:]] == Description Wodehaus is a lightweight forking job server. It dispatches workers created by a user-provided "producer" procedure to independent processes, then sends the results to a "consumer" procedure for finalization. The source for this extension is available [[https://git.foldling.org/chicken-wodehaus.git|here]]. == API [type] job any A {{job}} may be any object for which read/write invariance holds. [type] result any A {{result}}, like a job, may be any read/write-invariant object. [type] worker (job -> result) A worker may be any procedure that accepts a {{job}} and returns {{result}}. [type] producer (-> worker job) A {{producer}} is called repeatedly by a job server to produce pairs of workers and jobs to be dispatched. [type] consumer (job result -> any) A {{consumer}} is provided with the results of each job. [type] logger (symbol string #!rest any -> void) A {{logger}} is used to print information at various points during a job server's operation. It receives a symbolic log level (one of {{error}} or {{info}}) and a printf-style format string and arguments. <procedure>(process-name)</procedure> Returns a value that's unique to the worker process from which it's called. Currently, this is simply the worker's process ID. When called from within the server process, some descriptive object is returned. Exactly what type of object is unspecified. This value can be changed with {{set!}}. <procedure>(start producer #!optional consumer logger fixnum)</procedure> Starts a job server. When started, the server loops indefinitely, calling {{producer}} to generate workers and jobs to be dispatched. If there are no jobs to run, it is the {{producer}}'s responsibility to block until one becomes available. To stop the server, {{producer}} should raise the {{#:stop}} keyword. The final argument to {{start}} sets the maximum number of concurrent workers the job server will use. The default value is {{4}}. Each worker is executed in a dedicated OS-level process. A worker receives as a single argument the job with which it was produced, and its result is passed back to the {{consumer}} in the server process. Worker arguments and results must be fully read/write-invariant. The {{consumer}} procedure is invoked with each completed job and its result. Its own result is discarded. Each job server uses its thread's "specific" data slot for bookkeeping and installs a {{SIGINT}} handler that will cause the server to shut down cleanly on interrupt. It's recommended that each job server be run in a dedicated thread. == Author [[/users/evan-hanson|Evan Hanson]] == License Copyright (c) 2016, 3-Clause BSD.
Description of your changes:
I would like to authenticate
Authentication
Username:
Password:
Spam control
What do you get when you add 5 to 7?