On 2016-01-20 16:53, Bob Sneidar wrote:
On Jan 12, 2016, at 11:26 , Mark Waddingham
<m...@livecode.com<mailto:m...@livecode.com>> wrote:

Simple things like not putting code in a mouseUp, but instead just get
it to call an action function in the core part of the application
(independent of UI) help immensely.

This makes me a little sad, because one of the great things about LC
in my opinion is the modularity of the code. Going to an object's
script and seeing exactly what the object does, as opposed to having a
single large (and unweildy I might add) script is very attractive to
me.

My comment there was perhaps a little 'glib' and perhaps not quite representative of what I was suggesting.

In general there is always a line (which sometimes can be very difficult to find!) between code which drives a UI, and code which drives the application logic. So a sensible way to write an application which has to have multiple distinct UIs is to find that line and make sure the UI calls actions which perform the application's actual function. (Think command-line application being driven by a frontend UI - something which MetaCard was used widely for in the UNIX world from its original inception).

For example, many document-centric apps will have a 'Save' function. On Mac this is typically 'just' in the File menu. However, on Windows it is usual to have it both in the File menu *and* as a button on a document's toolbar. If the code for the 'save' action is not factored out you end up with duplicated code - so it is quite natural to move this code 'down' into core logic. If you do that for anything which can be taken out of a UI context you quickly end up with a architecture where the UI of your app is separated from the action thus making (in theory at least) adding variants of the UI easy.

Of course, good UIs are not easy to write - personally I generally find it much easier to define the core application model than I do to write the UI sitting on top of it. However, this is where LiveCode (and similar things) excel due to their visual and 'immediate' nature - you can iterate UIs rapidly, particularly if you don't have to worry about 'breaking' the core application logic, something which splitting things up into UI + Logic helps with.

So, I perhaps should have been more specific - code that deals with the UI should probably be 'closest to use' for all the places it should be used, whereas code which deals with core application logic is probably best 'pushed down' into a core library or set of libraries.

Of course, in the end, it all does largely depend on the application, how well the programmer understands the problem he/she are trying to solve in the first instance and how much time you have to solve it!

I also understand the advantage of a centralized library of functions
and I am not argueing against that, but I like the LC (and originally
HC) model. In fact the computing world thought this was such a neat
concept that OOP was born.

Well, I think OOP predates HyperCard by a significant margin. Simula was perhaps the first 'object oriented' language (although it did inheritence in reverse to current languages) - a superset of Algol, it appeared in 1965.

SmallTalk, one of the first 'purely object oriented' languages appeared in 1972.

HyperCard didn't appear until 1986.

So it seems that one objective might favor one approach, and another
objective a different one. This is exactly why designing for multiple
OSes, while certain techniques can get you a long way there, might
eventually be unattainable.

It would be possible to do a reasonably good job of abstracting some of the UI patterns people use today so that they specialize appropriately. For example, on an iPad you tend to use 'Split View' controllers which are similar to having a content view with a 'menu' callout button on iPhones. Conceptually (if you ignore the actual layout / rendering) these are almost the same - it is just the rendering and interaction which are different.

Warmest Regards,

Mark.

--
Mark Waddingham ~ m...@livecode.com ~ http://www.livecode.com/
LiveCode: Everyone can create apps

_______________________________________________
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