X-Authentication-Warning: delorie.com: mail set sender to geda-user-bounces using -f X-Recipient: geda-user AT delorie DOT com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:date:message-id:subject:from:to:content-type; bh=niU2TYGlBv7ahmVZvtyjbJBY/ruHofB1dPh1AxQX/cw=; b=zKsPohaYyDetYYJjCt3wxX8ccq1Q0ziJUrb/QJtSyYc0UGrAixsCTfzB/ZLmiW3uNm zeZOrkppcfhWVJbnR4B74N0pC5y9So1QNnAigC1rrJgi8Djzxt8l8ob3yEHDGyjdwKQJ LnevkzMGL72VsUlc++FeLPWCI/rMaKLpwLEKFK2mGSGTImeQp1JR/0hjkFsS2f+yGfQb Q4E+aoJU7nnEwoU4vKLwc3dLLiXYJiBUwwbvjPRTVhFl+ceDqrRf3cyVMNEEWaQB1Vaz iWDMVeO0eu7ntfjKAuV0mnu4IgZcDfTwVh4KoHtbp3/PaiAqN6I8p7XPqnuc4PqTGk0P eRZg== MIME-Version: 1.0 X-Received: by 10.60.85.38 with SMTP id e6mr735410oez.65.1423185756056; Thu, 05 Feb 2015 17:22:36 -0800 (PST) Date: Thu, 5 Feb 2015 20:22:36 -0500 Message-ID: <CAOFvGD7pJTo8A=MXVbuuXO=++0vGukUyqVfckVtnCi99ziqWJQ@mail.gmail.com> Subject: [geda-user] Using Lua to safely read configuration and layout files (program attached) From: Jason White <whitewaterssoftwareinfo AT gmail DOT com> To: geda-user AT delorie DOT com Content-Type: text/plain; charset=UTF-8 Reply-To: geda-user AT delorie DOT com ==Introduction== In the FOSDEM thread their currently is a raging discussion considering (among other things) the possibility of adding a modern scripting language such as Lua or Python to geda. This offers the exciting opportunity to make geda more accessible its many users. However, it also affords variety exciting new opportunities which I highlight below. Below I use Lua as an example, but this applies equally to other languages as well. However, I have written a demonstration of the concepts below using a C program with an embedded Lua interpreter. The link to try out the program is at the bottom of this email. ==(Safely) Hitting two birds with one stone== I wish to highlight two further uses beyond scripting that we could utilize a language such as Lua for. In addition to improved scripting, it also provides a robust pre-canned solution for the storage and retrieval of plain text information. I see two uses for this * Human readable configuration files * A more portable and maintainable file format for schematics and layouts. The advantage of using a scripting language as a storage mechanism for board information is that work flow automation become very easy since your board is literally nothing more than a variable that has been defined in the scripting language. Since the board is represented by an array, it makes it very easy to modify and autogenerate board information with Lua scripts. I would like to emphasize that when used for configuration and layout files, the Lua interpreter would not allow function calls, control structures, or loops to be executed; effectively only allowing variable definitions and math operations to take place. This is achieved in my example program by disabling the execution of the corresponding instructions in the Lua virtual machine. ==An Example Program (Written With Safety in Mind)== I would like to encourage everyone to try to make my example program behave in an unsafe manner using the Lua script that is read into it. I think you all will have a very difficult time making it do anything other than define variables since I added a "protected mode" to the interpreter. The "protected mode" disables the execution of function calls, loops, and control structures. This effectively makes it so that you can only define and reference variables in scripts with it enabled. Here is the link to download my example program. It is a simple C program which uses an embedded Lua interpreter to read arrays defined in a .lua file and print it to the console. https://drive.google.com/file/d/0BwP0qhqyaTIIVHl3UzcwSGFabGM/view?usp=sharing Type "./configure" then "make" to build it. Type "cd ./src" then "./example" to run it. ==Input and Feedback== I would like to hear your feedback! I see this as an efficient use of the tool. I figure, if we are going to have something like Lua, we may as well make use of it! Something like YAML brings in another dependency and makes is more difficult to use with scripts since it needs to be parsed first. -- Jason White