William Prothero wrote:

> I put almost all of my code in substacks, but haven’t tried text only
> stacks yet. I can’t see having a jillion small text files to keep
> track of. But then, a lot of folks seem to love them, so I wonder at
> the advantages. Of course, there’s the github thing.

That's pretty much it. Xtalks give us the option of sharing code between projects in stack files, or keeping lots of stacks tidily tucked away in substacks if they're only used in one project. And with the flexibility of LC's Standalone Builder, we can even have shared library stacks included with out mainstack at build time, to deliver a convenient single-file standalone that truly stands alone.

Chipp Walters, Ken Ray, and others have made check-in/check-out style tools for many years to handle multi-person team development rather well. In Gain Momentum (an xTalk I once used made by Sybase) they had a system like that built in.

But that's just us, here in our relatively small corner of the world.

Then there's the rest of the world: a landscape filled with text files. Lots of them. An app made in C++ or Python or most other languages is a rather sizable collection of text files. The LC code base, for example, has hundreds. The Linux kernel, one of the largest software projects on earth, uses more than 38,000 source files.

Given how those languages work, it made sense for version control systems to be created which are based around managing lots of tiny text files.

Our world and theirs happily coexisted much as Native Americans and Europeans did for so many centuries: life was easy for centuries, until they met.

LiveCode's audience is growing, and the use of traditional version control systems has also grown.

Today, so many dev shops are so attached to the work flows afforded by modern VCSes like Github that it would be a severe impairment for them to do without. And unless LiveCode could adapt to those VCSes, that would mean no LiveCode for them.

So script-only stacks are part of an evolutionary process for LiveCode, a way to play nice with others.

Now that behavior scripts (which I still believe would be less ambiguous and more descriptive if called by their original name, "parentScripts") can use script-only stacks as well, and now that Widgets are externally written script files, most of the code in even the most complex LiveCode app can be put into text files for those that need it, leaving only relatively small UI stacks as binary files, no worse than XCode's NIB files.

I still feel there's a role for other versioning systems, including the sorts of stack-file-based check-in/check-out systems we've seen. But I believe it's a limited one, best suited for certain type of development shops.

As much as those may seem like with-the-grain solutions for LiveCode, they also arguably contribute to LiveCode being a sort of island, marginalized outside of the infrastructure through which the rest of the world shares code.

And best IMO is that this is not merely a theoretical exercise: the team is eating their own haggis by putting these features to work in the IDE, one of the most complex LiveCode apps around.

And if you follow the team's progress on Github you can see the benefits for large projects immediately:
https://github.com/livecode/livecode/pulse

It would take significant effort to make a VCS ourselves that was as complete, but that and more is available for free there.



> Code that’s portable between apps is important. Perhaps that would
> be something to discuss. And I really haven’t messed with
> implementing personal code “Libraries”. The requirement for strict
> ID’s for behaviors makes them less portable. Do text only stacks help
> in this regard?

Not necessarily, but if you're working in teams they can be tremendously beneficial by allowing you to use common diff tools to quickly identify changes.

And for those working on open source projects I would consider script-only libraries almost essential, since folks likely to contribute to such projects are already on Github and know the flow.


> So, I think what I’m “seconding” is that a higher lever than “newby”
> tutorials on code organization through Libraries, Text only stacks,
> substacks, etc, would be useful and I would give it a hard look-see.
> Currently, I’m pretty satisfied with my current approach, but over
> the last year, I’ve changed it so much as I learned more about
> LiveCode, that I wonder what I’m missing.

You and me both. Just like the LC IDE now undergoing its fourth major revision, every few years I look at my code and the mix of new language features plus what I've learned since I wrote it and I dive in for a rewrite.

In other language the scope of materials Bramanathaswami described is handled in a book, of which several compete in the pursuit of a "best".

All I know is I can't write one of them: given how long it takes to write a good book by the time I finished I'd be doing things differently than what I'd written. :)


> Thanks, Richard, for all your comments and help on this list.

That's very kind of you, Bill. Given your many accomplishments over the long years I've known you that means a lot to me.

--
 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