Module gen_statem
An implementation of the Erlang/OTP gen_statem interface.
This module defines the gen_statem behaviour.
 Required callback functions: init/1, callback_mode/0.
Description
This module implements a strict subset of the Erlang/OTP gen_statem interface, supporting operations for local creation and management of gen_statem instances.
This module is designed to be API-compatible with gen_statem, with exceptions noted below.
Caveats:
- No support for start_link 
- Support only for locally named gen_statem instances 
- Support only for state function event handlers 
- No support for keep_state or repeat_state return values from Module:StateName/3 callbacks 
- No support for postpone or hibernate state transition actions 
- No support for state enter calls 
- No support for multi_call 
Data Types
options()
options() = [{atom(), term()}]
server_ref()
server_ref() = atom() | pid()
Function Index
| call/2 | Send a request to a gen_statem instance, and wait for a reply. | 
| call/3 | Send a request to a gen_statem instance, and wait for a reply.. | 
| cast/2 | Send a request to a gen_statem instance. | 
| reply/2 | Send a reply to a calling client. | 
| start/3 | Start an un-named gen_statem. | 
| start/4 | Start a named gen_statem. | 
| start_link/3 | Start an un-named gen_statem. | 
| start_link/4 | Start a named gen_statem. | 
| stop/1 | Stop a previously started gen_statem. | 
| stop/3 | Stop a previously started gen_statem instance. | 
Function Details
call/2
call(ServerRef::server_ref(), Request::term()) -> Reply::term() | {error, Reason::term()}
Equivalent to call(ServerRef, Request, infinity).
Send a request to a gen_statem instance, and wait for a reply.
call/3
call(ServerRef::server_ref(), Request::term(), Timeout::timeout()) -> Reply::term() | {error, Reason::term()}
ServerRef: a reference to the gen_statem acquired via startRequest: the request to send to the gen_statemTimeout: the amount of time in milliseconds to wait for a reply
returns: the reply sent back from the gen_statem; {error, Reason}, otherwise.
Send a request to a gen_statem instance, and wait for a reply..
This function will send the specified request to the specified gen_statem instance, and wait at least Timeout milliseconds for a reply from the gen_statem.
cast/2
cast(ServerRef::server_ref(), Request::term()) -> ok | {error, Reason::term()}
ServerRef: a reference to the gen_statem acquired via startRequest: the request to send to the gen_statem
returns: ok | {error, Reason}
Send a request to a gen_statem instance.
This function will send the specified request to the specified gen_statem instance, but will not wait for a reply.
start/3
start(Module::module(), Args::term(), Options::options()) -> {ok, pid()} | {error, Reason::term()}
Module: the module in which the gen_statem callbacks are definedArgs: the arguments to pass to the module’s init callbackOptions: the options used to create the gen_statem
returns: the gen_statem pid, if successful; {error, Reason}, otherwise.
Start an un-named gen_statem.
This function will start a gen_statem instance.
Note. The Options argument is currently ignored.
start/4
start(ServerName::{local, Name::atom()}, Module::module(), Args::term(), Options::options()) -> {ok, pid()} | {error, Reason::term()}
ServerName: the name with which to register the gen_statemModule: the module in which the gen_statem callbacks are definedArgs: the arguments to pass to the module’s init callbackOptions: the options used to create the gen_statem
returns: the gen_statem pid, if successful; {error, Reason}, otherwise.
Start a named gen_statem.
This function will start a gen_statem instance and register the newly created process with the process registry. Subsequent calls may use the gen_statem name, in lieu of the process id.
Note. The Options argument is currently ignored.
start_link/3
start_link(Module::module(), Args::term(), Options::options()) -> {ok, pid()} | {error, Reason::term()}
Module: the module in which the gen_statem callbacks are definedArgs: the arguments to pass to the module’s init callbackOptions: the options used to create the gen_statem
returns: the gen_statem pid, if successful; {error, Reason}, otherwise.
Start an un-named gen_statem.
This function will start a gen_statem instance.
This version of the start function will link the started gen_statem process to the calling process.
Note. The Options argument is currently ignored.
start_link/4
start_link(ServerName::{local, Name::atom()}, Module::module(), Args::term(), Options::options()) -> {ok, pid()} | {error, Reason::term()}
ServerName: the name with which to register the gen_statemModule: the module in which the gen_statem callbacks are definedArgs: the arguments to pass to the module’s init callbackOptions: the options used to create the gen_statem
returns: the gen_statem pid, if successful; {error, Reason}, otherwise.
Start a named gen_statem.
This function will start a gen_statem instance and register the newly created process with the process registry. Subsequent calls may use the gen_statem name, in lieu of the process id.
This version of the start function will link the started gen_statem process to the calling process.
Note. The Options argument is currently ignored.
stop/1
stop(ServerRef::server_ref()) -> ok | {error, Reason::term()}
Equivalent to stop(ServerRef, normal, infinity).
Stop a previously started gen_statem.
stop/3
stop(ServerRef::server_ref(), Reason::term(), Timeout::non_neg_integer() | infinity) -> ok | {error, Reason::term()}
ServerRef: a reference to the gen_statem acquired via startReason: the reason to supply for stoppingTimeout: maximum time to wait for shutdown
returns: ok, if the gen_statem stopped; {error, Reason}, otherwise.
Stop a previously started gen_statem instance.
This function will stop a gen_statem instance, providing the supplied Reason to the . If the gen_statem is a named gen_statem, then the gen_statem name may be used to stop the gen_statem.