William Prothero wrote:

> Reading this kinda makes my head spin. Now I’m thinking it is going
> to be a heck of a lot more robust for my situation, as a single
> developer, to not use behaviors at all, but to have a single
> (possibly script only) substack that holds all of the handlers that I
> would normally use as behaviors, and just put a call to that handler
> in each button. I can use “the target”  or “me” as a passed variable
> to make the action specific to a particular control.
>
> This approach seems a lot less prone to idiosyncrasies and more
> easily transportable to other apps, to me. It also means that all of
> my “behavior type scripts” would sit in a single script-only stack,
> which would make it a lot more convenient to access and edit than a
> bunch of small script only stacks sitting in my project browser.
>
> Am I wrong. misguided, foolish, or brilliant?

Behaviors are very powerful for all sorts of things, whether you work alone or in a team of twenty.

The biggest benefit for teamwork comes from the very separate question of whether to use script-only stacks to define behaviors. Script-only stacks are an ideal solution for Github-based workflows, but have minimal value (some, but not as much) for anyone not dependent on a version control system designed for other languages.

Ditch script-only stacks for now and continue to explore behaviors. You'll thank me. You'll want to buy me lunch next time I'm in Santa Barbara. I'll accept. Behaviors will change everything, very powerfully, the more you explore and use them.

Once we step away from the very separate issue of script-only stacks, we have really only two guidelines for using behaviors effectively:

- A behavior definition can be any button or stack.

- When using behaviors, the object containing the behavior script
  must be in memory when anything relying on it is brought into
  memory.

That's it.

When exploring a new feature I like to make a simple stack I can use as a playground to poke around and experiment without mucking up anything important I'm working on.

Here's a quick tutorial that may get you hooked on the power of behaviors:

1. Make a new stack titled "Behavior Playground"

2. Add a button named "MyClass"

3. Set the script of that button to:

    on mouseUp
       answer the name of me
    end mouseUp

There - you've just created a behavior, defining an action for what will be an entire class of custom button objects:

4. Make a new button named "A"

5. In the Message Box run:

   set the behavior of btn "A" to the long id of btn "MyClass"

6. Make two copies of btn "A", naming them "B" and "C" respectively.

7. Click any of them.

What you'll see is that each of them uses the script of button "MyClass" as if it's their own, bringing up an answer dialog showing the unique name of each.

At this point your mind is already thinking of a dozen times in recent projects where you have several objects you wanted to work the same without affecting any other scripts. We could leave it here and you'd be off writing behaviors very productively right now.

But we're going to take this one step further - we'll create a superclass:

8. Make a new button named "MySuperClass"

9. Set this script of that button to:

   on mouseDown
      grab me
   end mouseDown

10. In the Message Box run:

  set the behavior of btn "MyClass" to the long id of btn "MySuperClass"

11. Drag any of the "A", "B", or "C" buttons.

In just 11 steps, each taking only a few seconds, you've just created a rich hierarchy of custom messaging:

      "A" "B" "C"
        \  |  /
         \ | /
        MyClass
           |
           |
     MySuperClass


If you wanted the drag behavior used for an entirely different set of objects that do something else on mouseUp, you could make another button named "MyOtherClass" and extend your scope of custom controls even further:

 "A" "B" "C" "D" "E" "F"
   \  |  /     \  |  /
    \ | /       \ | /
   MyClass   MyOtherClass
       \         /
        \       /
       MySuperClass

Behaviors can be chained as deeply as you like, allowing for very rich class hierarchies.

This will get you started.  And it only takes a few minutes to explore.


------ EXTRA CREDIT -------

After you feel comfortable with this, an extra credit exercise might be explore overriding and overloading.

Overriding is blocking an action defined in a parent by using a handler of the same name in a child.

For example, if you decided button "C" was different from the others and should reports its long ID rather than its name, you could write a script in it with:

  on mouseUp
    answer the long id of me
  end mouseUp

...and it'll do that, without affecting any other behaviors provided by the parent script, or affecting any other objects that use the parent script.

Overloading is augmenting a behavior without replacing it.

So if you wanted your custom controls (buttons "A", "B", etc.) to be able to have their own mouseUp messages independent of any handling provided in their parent behavior script, you could write the behavior with either of two special forms of message handlers: before or after.

The script of button "MyClass" could be revised as:

  after mouseUp
    answer the name of me
  end mouseUp

...and then the mouseUp message can be handled however you like in any of the class instances ("A", "B", etc.), yet the behavior script will also fire immediately after.

The "before <message>" works similarly, but as you can guess those fire before the child gets the message.

Before and after handlers are limited to behavior scripts, as they were added specifically to allow behaviors to augment actions without limiting the scope of normal messages a subscribed object can act on.

This may be a lot to take in all at once.

Play with steps 1 to 11 to get going, explore ways to apply that to your work. Later on you can add "before" and "after" handlers if you need them. You may not (I rarely use them), but if you do need them they're good to know about.

Don your pith helmet and begin your adventure!

--
 Richard Gaskin
 Fourth World Systems
 Software Design and Development for the Desktop, Mobile, and the Web
 ____________________________________________________________________
 ambassa...@fourthworld.com                http://www.FourthWorld.com


_______________________________________________
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