Mercurial Hosting > luan
annotate website/src/learn.html.luan @ 2019:cbc5a66217d7
windows fix
| author | Franklin Schmidt <fschmidt@gmail.com> | 
|---|---|
| date | Fri, 03 Oct 2025 18:28:21 -0600 | 
| parents | 9048199efd8f | 
| children | 
| rev | line source | 
|---|---|
| 1651 | 1 local Luan = require "luan:Luan.luan" | 
| 2 local error = Luan.error | |
| 3 local Io = require "luan:Io.luan" | |
| 1938 | 4 local Site_translator = require "luan:ai/Site_translator.luan" | 
| 1929 | 5 local get_lang = Site_translator.get_lang or error() | 
| 6 local text_writer = Site_translator.text_writer or error() | |
| 1651 | 7 local Shared = require "site:/lib/Shared.luan" | 
| 8 local head = Shared.head or error() | |
| 1927 | 9 local header = Shared.docs_header or error() | 
| 1932 | 10 local reactionary_url = Shared.reactionary_url or error() | 
| 1651 | 11 | 
| 12 | |
| 13 return function() | |
| 1929 | 14 Io.stdout = text_writer() | 
| 1651 | 15 %> | 
| 1216 | 16 <!doctype html> | 
| 1929 | 17 <html lang="<%=get_lang()%>"> | 
| 391 
2f5cc9c2cbf0
replace Html.simply_html_page with simply_html_head and simply_html_body_bottom
 Franklin Schmidt <fschmidt@gmail.com> parents: 
386diff
changeset | 18 <head> | 
| 1651 | 19 <% head() %> | 
| 1927 | 20 <title>Learning Luan</title> | 
| 391 
2f5cc9c2cbf0
replace Html.simply_html_page with simply_html_head and simply_html_body_bottom
 Franklin Schmidt <fschmidt@gmail.com> parents: 
386diff
changeset | 21 </head> | 
| 
2f5cc9c2cbf0
replace Html.simply_html_page with simply_html_head and simply_html_body_bottom
 Franklin Schmidt <fschmidt@gmail.com> parents: 
386diff
changeset | 22 <body> | 
| 1651 | 23 <% header() %> | 
| 24 <div content> | |
| 1927 | 25 | 
| 26 <h1>Learning Luan</h1> | |
| 27 | |
| 1929 | 28 <p>To understand the idea behind Luan, you must read <a href="scripting.html">Ousterhout's paper</a>. In terms of this paper, Luan is the scripting language and Java is the system programming language. In other words, these two languages are a pair of tools that work together. Luan is the tool for writing applications, and Java is the tool for writing libraries.</p> | 
| 1927 | 29 | 
| 30 <p>No other modern scripting language (except Tcl) follows this model. This means that you are limited to whatever functionality the scripting language provides. Of modern scripting languages, only Python is big enough to really have enough functionality through libraries. But tiny Luan has as much functionality as Python does because Luan has access to all of the functionality available in Java.</p> | |
| 1924 | 31 | 
| 1927 | 32 <p>It is the tight integration of Luan with Java that makes this possible. Often, making a Java function available in Luan is as simple as:</p> | 
| 33 | |
| 34 <code block> | |
| 35 Luan_table.luan_function = JavaClass.javaFunction | |
| 36 </code> | |
| 37 | |
| 1929 | 38 <p>In other cases, there is a very thin layer between Luan and Java. And if you know Java, then this code is easy to read. This means that the Luan source code is actually perfectly suitable documentation for the Luan API. If I was to document all of the Luan API, I would actually be mostly duplicating the <a href="https://docs.oracle.com/javase/8/docs/api/overview-summary.html">Java API documentation</a>. So while I will continue to expand the <a href="manual.html">Luan Reference Manual</a>, this is not my top priority. To use Luan, you must get <a href="https://hg.reactionary.software/repo/luan/">the source</a> and get a basic understanding of the API which is in <a href="https://hg.reactionary.software/repo/luan/file/tip/src/luan/modules">luan/src/luan/modules</a>.</p> | 
| 1323 
3860ed4b8552
simplify website css
 Franklin Schmidt <fschmidt@gmail.com> parents: 
1310diff
changeset | 39 | 
| 1927 | 40 <p>Here are my suggested steps for learning Luan:</p> | 
| 41 | |
| 42 <ol> | |
| 1932 | 43 <li>Follow my <a href="<%=reactionary_url()%>/learn.html">Learn Reactionary Programming</a> course up to and including <b>Java 8</b>.</li> | 
| 1929 | 44 <li>Read <a href="pil.html">Programming in Lua</a>. It is actually an excellent book which means that I don't have to write an extensive Luan tutorial. Then read <a href="diff.html">How Luan differs from Lua</a>.</li> | 
| 45 <li>Next read the short <a href="tutorial.html">Luan Tutorial</a>.</li> | |
| 1927 | 46 </ol> | 
| 1924 | 47 | 
| 1927 | 48 <p>What comes next depends on whether you want to do web development or desktop development.</p> | 
| 49 | |
| 50 <p>For web development, start by looking at the example in <a href="https://hg.reactionary.software/repo/luan/file/tip/examples/blog">luan/examples/blog</a>. This is a minimal website. Next look at <a href="https://chat.luan.software/about.html">Luan Chat</a>. Get the source. It uses <a href="https://en.wikipedia.org/wiki/Server-sent_events">server-sent events</a> which is implemented in Luan with <code>Http.push</code>. Luan Chat is fully functional and is what I use to chat with people. So this code is an example of a complete website.</p> | |
| 51 | |
| 1974 | 52 <p>For desktop development, you need to learn the relevant Java tools which include <a href="https://docs.oracle.com/javase/tutorial/uiswing/">Swing</a>, <a href="http://www.miglayout.com/">MigLayout</a>, <a href="https://www.formdev.com/flatlaf/">FlatLaf</a>, and <a href="https://docs.oracle.com/javase/tutorial/2d/">2D Graphics</a>. Then you can look at examples in <a href="https://hg.reactionary.software/repo/luan/file/tip/src/luan/modules/swing/examples">luan/src/luan/modules/swing/examples</a>. And then get <a href="https://editor.luan.software/">Luan Editor</a>. This is a fully functional text editor. It will show you how to use Swing in Luan.</p> | 
| 1927 | 53 | 
| 1929 | 54 <p>With popular programming languages, you can get help from ChatGPT. But ChatGPT doesn't know Luan. ChatGPT can help you understand Java, but that's all. So for Luan questions, just <a href="support.html">contact me</a>.</p> | 
| 1927 | 55 | 
| 1579 | 56 </div> | 
| 391 
2f5cc9c2cbf0
replace Html.simply_html_page with simply_html_head and simply_html_body_bottom
 Franklin Schmidt <fschmidt@gmail.com> parents: 
386diff
changeset | 57 </body> | 
| 
2f5cc9c2cbf0
replace Html.simply_html_page with simply_html_head and simply_html_body_bottom
 Franklin Schmidt <fschmidt@gmail.com> parents: 
386diff
changeset | 58 </html> | 
| 1651 | 59 <% | 
| 60 end | 
