We have a fairly large USSD application that uses Erlang's gen_fsm module to manage the menu options.
The current version has a single menus_fsm.erl
file that contains 5000+ lines gen_fsm related code. Our next version gives us an opportunity to split menus_fsm.erl
into separate files to make it more maintainable in the future.
In the old version, to display the help menu we do the following (help_menu/1
gets called from code not shown that displays the main menu):
-module(menus_fsm).
% Snipped some irrelvant code
help_menu(StateData) ->
% Display the first menu
send_menu(StateData, "Please Select:\n1. Option 1\n2. Option 2"),
{next_state, waitHelpMenuChoice, StateData, ?MENU_TOUT};
waitHelpMenuChoice(Params, StateData) ->
io:format("Got Help menu response: ~p", [Params]),
doTerminate(ok,"Help Menu", StateData).
I've left out a lot of code that shows the entry point into the FSM and so on.
In the new version, we'd want to move help_menu/1
and waitHelpMenuChoice/2
to a new module help_menu
, which gets called from menus_fsm
, like so:
-module( help_menu ).
% Snipped some irrelevant code
help_menu(StateData) ->
menus_fsm:send_menu(StateData, "Please Select:\n1. Option 1\n2. Option 2"),
{next_state, waitHelpMenuChoice, StateData, ?MENU_TOUT};
waitHelpMenuChoice(Params, StateData) ->
io:format("Got Help menu response: ~p", [Params]),
menus_fsm:doTerminate(ok,"Help Menu", StateData).
The problem is with the line {next_state, waitHelpMenuChoice, StateData, ?MENU_TOUT};
: gen_fsm
expects the waitHelpMenuChoice
to be in the module menus_fsm
which takes me back to where we started.
I've tried to replace the problematic line with
{next_state, fun help_menu:waitHelpMenuChoice/2, StateData, ?MENU_TOUT};
but that just leas to an error like the following:
{badarg,[{erlang,apply,[conv_fsm,#Fun<help_menu.waitHelpMenuChoice.2>,[]]}
Does anyone have any suggestions of how to get around this?