On 2/15/2015 7:14 AM, Graham Samuel wrote:
> This is probably very dumb, but I've got into a muddle thinking about " 'Go 
> To' Considered Harmful", if anyone is old enough to remember that Dutch 
> utterance... anyway:
>
> In LC, really everything is dealt with in handlers which begin, execute and 
> end and can be nested within one another. So how do you construct a control 
> structure like the following:
>
> 1. The program starts up with a 'startup' handler (could use 'preOpenStack' 
> but it's not so good). The script there does setting-up things, and then it 
> notices that it needs extensive user input (for example, maybe the program 
> isn't registered and we need some details - even maybe payment) before we can 
> go on.
>
> 2. To get the user input, the script does a 'go to' (which is really an 
> 'open') to a special stack for this input. Eventually, the data is input and 
> checked, and the user clicks say an "OK" button to get back to the startup 
> process.
>
> 3. What happens now? The script can't easily resume the original startup 
> handler, can it? After all, the special stack which deals with user input is 
> not a handler nested within the startup handler. The "OK" button is driven by 
> a 'mouseUp' handler, but when that handler closes, there is no automatic way 
> of going back to the calling handler of the whole process (the startup 
> handler) due to the lack of nesting. What the script **can** do is to invoke 
> a further handler in the original card where the startup is, called perhaps 
> 'continueStartup', so that at the end of the 'mouseUp' script, we simply call 
> this new handler.
>
> This kind of works, but we are left with loose ends: the original 'startup' 
> handler never reaches its termination point ('end startUp') as far as I can 
> see, and the 'resume' script doesn't exactly terminate either, does it? If it 
> did, we'd end up in the 'mouseUp' script in a stack (window), which is 
> probably closed by now, having done its job. So viewed as a set of control 
> structures, it looks a mess.
>
> OK, there is a way of doing it, kind of, but what is the most logical way to 
> approach this problem of non-nested control structures?
>
>

If you code looked like this:

on startup
  <part 1 code>
  if <some condition> then
    open stack <user input stack>
    exit startUp
  end if
  <part 2 code>
end startup

and your <user input stack>  exits in a mouseUp handler such as

on mouseUp
  close this stack
end mouseUp

you would need to restructure you code like this:

on startUp
  doPart1
  if <some condition> then
   open stack <user input stack>
   exit startup
  end if
  doPart2
end startup

on doPart1
  <part 1 code>
end doPart1

on doPart2
  <part 2 code>
end doPart2

and the <user input stack> mouseUp handler would be modified as
on mouseUp
  close this stack
  send "doPart2" to <main stack> in 1 tick
end mouseUp

This places the <part 1 code> and <part 2 code> blocks in separate
handlers in the main stack so that the <part 2 code> handler can be
invoked from the mouseUp on the input stack.

_______________________________________________
use-livecode mailing list
use-livecode@lists.runrev.com
Please visit this url to subscribe, unsubscribe and manage your subscription 
preferences:
http://lists.runrev.com/mailman/listinfo/use-livecode

Reply via email to