<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Oct 18, 2016 at 12:48 AM, Travis Ayres <span dir="ltr"><<a href="mailto:trayres@gmail.com" target="_blank">trayres@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><p dir="ltr">I'm all for this effort, and hope it leads to new and modern tutorials, books or notes that would be useful for others that use FreePascal/Lazarus to convey graphical system interactions. If there's any need to proofread such materials, I'll gladly help out!</p>
<div class="gmail_extra"><br></div></blockquote><div><br></div><div>To test a large program , I want to use Petri Nets to drive the testing steps in an information processing , let's say network , to simulate a business environment : <br><br><br><a href="https://en.wikipedia.org/wiki/Petri_net">https://en.wikipedia.org/wiki/Petri_net</a><br>( Petri net )<br><br><a href="https://en.wikipedia.org/wiki/Category:Petri_nets">https://en.wikipedia.org/wiki/Category:Petri_nets</a><br>Category:Petri nets<br><br></div><div>( My work on this is "Perhaps" now ... )<br></div><div><br><br></div><div>One unfortunate situation is that there is not much Pascal software for Petri Nets processing , except the following ( which its license is very ambiguous means not usable ) and may be considered very old with respect to new Pascal language level :<br><br><br><a href="http://staff.um.edu.mt/jskl1/petrisim/">http://staff.um.edu.mt/jskl1/petrisim/</a> <br>PetriSim - Discrete Simulation Environment<br><br><br></div><div>There are others , perhaps , but again , not usable very well .<br><br><br></div><div>Petri Nets are a vast subject now . There are some Petri Nets processing software but their licenses being copy left are not friendly for commercial environment .<br><br><br></div><div>For event driven systems , Petri Nets are very important .<br><br><br></div><div>My opinion is that a "good" , "permissively" licensed , as much as general purpose Petri Nets simulation software may be a very useful tool for the students to simulate their event driven system definition , and , then write its special purpose Pascal program by using Lazarus easily .<br><br><br></div><div>Actually , it is not compulsory to use Pascal , but Pascal will supply the Pascal programming language learners a very good example , its license will permit them to use some of its parts whatever they want to do without any hostile restriction in any environment .<br></div><div><br><br></div><div>In such a tool , only it is necessary to describe the nodes , information flow between nodes , etc. .<br></div><div>( Please see above link about PetriSim . ) <br><br><br></div><div><br></div><div>Mehmet Erol Sanliturk<br><br><br> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div class="gmail_extra"><div class="gmail_quote">On Oct 17, 2016 6:32 PM, "Mehmet Erol Sanliturk via Lazarus" <<a href="mailto:lazarus@lists.lazarus-ide.org" target="_blank">lazarus@lists.lazarus-ide.org</a><wbr>> wrote:<br type="attribution"><blockquote class="gmail-m_3438228858920087360quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote"><div class="gmail-m_3438228858920087360quoted-text">On Mon, Oct 17, 2016 at 12:05 PM, Lars via Lazarus <span dir="ltr"><<a href="mailto:lazarus@lists.lazarus-ide.org" target="_blank">lazarus@lists.lazarus-ide.org</a><wbr>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">> On 14/10/16 08:30, Michael Schnell via Lazarus wrote:<br>
><br>
><br>
> Of course there are decent drawbacks regarding relying too much on RAD<br>
> and about not really understanding the fundamentals behind it. But in the<br>
> end the addressees are non-computer engineers.<br>
<br>
The big issue with teaching using a RAD tool, is welding the program logic<br>
into the onclick events, instead of decoupling the logic in separate<br>
procedures that can be reused elsewhere. RAD tools are superior at<br>
prototyping... I can't believe how awesome they are at that. They are<br>
inferior, however, when it comes to bad habits being brought on. With<br>
this warning, RAD tools can still be very useful for writing solid<br>
programs, as long as one knows this warning ahead of time.<br>
<br>
When I first learned delphi I made the mistake of putting code in the<br>
onClick events and similar, and then when you expand your app later you<br>
realize all that code is welded in place and cannot be reused outside of<br>
the events.<br>
<br>
Of course decoupling the logic from the GUI leads to more layers of code.<br>
<br></blockquote></div><div><br>-------------<br><br><br> </div><div class="gmail-m_3438228858920087360quoted-text"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
How I got rid of my bad habits when I first learned delphi: I started<br>
writing console apps with no object oriented programming, no events, and<br>
learned that not everything is a click event in computer programming.<br>
<br></blockquote></div><div><br><br>-------------<br><br><br></div><div>My opinion is that the above ideas are really very good to be applied during teaching :<br></div><div>First , teach language on , let's say , "atomic" problems . Then , use these "atomic" concepts in further problems either embedded in a GUI or console program .<br></div><div><br></div><div>One obvious point is that an "event" driven programming knowledge is a must to become a competent programmer . The problem is how this can be learned . Without knowing how to program an algorithm when a related event is occurred , will bring any one to nothing means ( not to a success ) .<br></div><div><br>-------------<br><br> </div><div class="gmail-m_3438228858920087360quoted-text"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
People late in the game (learned programming when GUI's were available)<br>
and have no experience with console mode apps will earn some bad habits<br>
because of the GUI oriented programming. Those with experience in other<br>
areas of programming such as old Dos programs, web programs (basically<br>
like a dos or unix console program) will learn different ways of<br>
organizing code without everything being tied to a GUI event driven code.<br>
<br>
I suppose even doing a plain Win32 API app with no delphi code (pure win<br>
api) would help someone learn how to organize code from a second opinion<br>
view, without being forced to use the event driven system you were given<br>
by the RAD tool.<br>
<br></blockquote></div><div><br><br>-------------<br><br> </div><div class="gmail-m_3438228858920087360quoted-text"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
Of course, also learning other programming languages helps (although, IMO<br>
learning too many brain dead languages and hip cool ones will not help, as<br>
much as others claim... Basic programmers from the 80's or 70's still<br>
think in GOTO's and line numbers)<br>
<span class="gmail-m_3438228858920087360m_3099101574644270306gmail-HOEnZb"><font color="#888888">--</font></span><br></blockquote></div></div><br><br>-------------<br><br><br><br></div><div class="gmail_extra">With respect to researches ( I am not able to supply links now because this view is based on old times readings , but I am sure that such research findings can be found ) ,<br><br></div><div class="gmail_extra">people ( mostly ) uses a "primary" language for her/his profession and a "secondary" language for some her/his works as an additional tool .<br></div><div class="gmail_extra"><br></div><div class="gmail_extra">This shows that during teaching , this feature should be taken into consideration : Guide the students to discover which language she/he will prefer to use in much of her/his works , and attempt to teach that language in a "best" way to be used by the students in their profession .<br><br></div><div class="gmail_extra">A similar approach should also be used for a "secondary" language .<br></div><div class="gmail_extra"><br></div><div class="gmail_extra">If a language is taught just for fun or whatever else other than being a possible candidate for "primary" or "secondary" is likely that , if it not a necessity for the learner , is only a waste of everything is involved .<br><br><br><br></div><div class="gmail_extra">Mehmet Erol Sanliturk<br></div><div class="gmail_extra"> <br></div><div class="gmail_extra"><br></div></div><span class="gmail-HOEnZb"><font color="#888888">
<br>--<br>
______________________________<wbr>_________________<br>
Lazarus mailing list<br>
<a href="mailto:Lazarus@lists.lazarus-ide.org" target="_blank">Lazarus@lists.lazarus-ide.org</a><br>
<a href="http://lists.lazarus-ide.org/listinfo/lazarus" rel="noreferrer" target="_blank">http://lists.lazarus-ide.org/l<wbr>istinfo/lazarus</a><br>
<br></font></span></blockquote></div><br></div>
</blockquote></div><br></div></div>