<div dir="ltr">Right, it's not scripting using a classic programming environment, like VBA, the BASIC that comes with LibreOffice, or  Python. <div><br></div><div>The idea is that you extend the spreadsheet idiom to program the spreadsheet from a sheet or virtual workbook in the spreadsheet without leaving the spreadsheet to work in a classical imperative programming environment like VBA or Python.</div><div><br></div><div><br></div><div><font face="monospace">  |A               | B              | C              | </font></div><div><font face="monospace">1|PARAMETERS(B1,C1)|<put input here>|<put input here>| </font></div><div><font face="monospace">2|                 |                |                |</font></div><div><font face="monospace">3|</font><span style="font-family:monospace;font-size:10.5625px">RETURN(B1*C1)    |                |                |</span></div><div><font face="monospace">FUNCTION SHEET("MY_FUNCTION")</font></div><div><font face="monospace"><br></font></div><div>You have data, it's a spreadsheet.</div><div>The moral equivalent of sequence is referencing another cell, including one that contains a function.</div><div>You have selection with the IF() function.</div><div>With the addition of just two keywords, PARAMETERS and RETURN you have real functions.</div><div>You have looping with functions calling themselves (recursion), and possibly circular references.</div><div><br></div><div>My understanding is that's a complete programming paradigm.</div><div><br></div><div>Trent.</div><div><br></div></div><br><div class="gmail_quote"><div dir="ltr">On Thu, Nov 2, 2017 at 9:58 AM Stephen Partington <<a href="mailto:cryptworks@gmail.com">cryptworks@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_default" style="font-family:trebuchet ms,sans-serif">Google and LibreOffice both have similar functionality. (not VB, but they have built in scripting tools)</div></div><div class="gmail_extra"></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Nov 2, 2017 at 8:03 AM,  <span dir="ltr"><<a href="mailto:techlists@phpcoderusa.com" target="_blank">techlists@phpcoderusa.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="font-size:10pt;font-family:Verdana,Geneva,sans-serif">
<p><br></p>
<p>How would this be different from using Visual Basic for Applications (VBA).  It has literally been 20 years since I used VBA, however I seem to recall that the VBA was built in and internal so one would not need to use external resources to do the VBA automation.</p><div><div class="m_1088989942437648376h5">
<div> </div>
<p><br></p>
<p>On 2017-11-02 01:51, trent shipley wrote:</p>
</div></div><blockquote type="cite" style="padding:0 0.4em;border-left:#1010ff 2px solid;margin:0"><div><div class="m_1088989942437648376h5">
<div dir="ltr">
<div>Dear PLUG list,</div>
<div> </div>
<div>I've been working on a think-piece about a programmable spreadsheet product and project. It runs 29 pages. I'm going to try to find a way to put the "proposal" on the internet. </div>
<div> </div>
<div>However, I've included the introduction and conclusion below, and I'd be interested in people's thoughts, especially Joseph Sinclair's or anyone in academia. I'd also very much like to know if anyone knows if anything like this exists or existed.</div>
<div> </div>
<div>Note that I'm not proposing using something like VBA or Python. I am proposing that spreadsheets themselves be programmable without leaving the spreadsheet environment or paradigm.</div>
<div> </div>
<div>The long paper should be ready to put on the internet in a week or two. I'd be interested in any thoughts about how to do that too.</div>
<div> </div>
<div>Regards,</div>
<div> </div>
<div>Trent</div>
<div> </div>
<div>------------------------------------------------------------------------</div>
<div> </div>
<div>Scriptsheets: A Spreadsheet You Can Program from the Sheet Environment</div>
<div>Scriptsheets v0e0r0b0. First Proposal (unstable, draft)</div>
<div> </div>
<div>Trent Shipley</div>
<div><a href="mailto:trent1967.48@outlook.com" target="_blank">trent1967.48@outlook.com</a></div>
<div>2017-11-02</div>
<div> </div>
<div>     1  Concept</div>
<div> </div>
<div>To program in current spreadsheets you typically use a built-in scripting language like VBA. There are those who claim that spreadsheets are very close to a pure functional language. Others have claimed to implement a multi-tape Turing machine in Excel. You can ALMOST program in Excel without resorting to VBA.</div>
<div> </div>
<div>The goal of Scriptsheets is to create a spreadsheet environment where you can program natively from within a spreadsheet itself, without resorting to a separate programming language and programming environment. It is expected that Scriptsheets will be useful to scientists, engineers, and data scientists, and even in economics and finance. However Scriptsheets will be more complex than a typical spreadsheet product, and thus should have less appeal ingeneral business than existing spreadsheet products. Scriptsheets will be more powerful than existing spreadsheet products, but also harder to use.</div>
<div> </div>
<div>     2  License1</div>
<div> </div>
<div>Scriptsheets will have a free, open source, and minimally viral license.</div>
<div> </div>
<div>
<div>     6  Summary</div>
<div> </div>
<div>In this paper I proposed developing a spreadsheet that would be programmable from the native spreadsheet environment, without resorting to a more traditional language like Visual Basic for Applications or Python. The working name for the product is Scriptsheets. The core of the spreadsheet product's programmability would be the designated function sheet, accompanied by the PARAMETER "function" keyword. It is expected that an inherently programmable spreadsheet would have applications in engineering, data science, science, economics, and finance.  The added complexity would make Scriptsheets less useful in general business applications.</div>
<div> </div>
<div>Design of Scriptsheets would emphasize security first. The security model would be comprehensive and fine grained. It assumes a client-server architecture with a system administrator, application administrator, and users, including developers.</div>
<div> </div>
<div>The core Scriptsheets product will be a functionally complete, but minimal spreadsheet. The core product will be highly extensible, and will encourage modularity. I proposed some critical plugins that should exist before the v1e0 release of Scriptsheets. In this paper, the concept of virtual workbooks were presented briefly. Virtual workbooks can exist in the file-based workbook. Virtual workbooks can nest, and provide one way to extend a spreadsheet beyond three dimensions. It will be possible to make packages of file-based workbooks. Unlike other spreadsheets, Scriptsheets will be typed. However, the dynamic type will be the default type, and will allow Scriptsheets to behave like a typical spreadsheet. Since Scriptsheets will be programmable, developers will be able to perform IO from the spreadsheet itself. Scriptsheets will provide objects, likely through prototyping.</div>
<div> </div>
<div>Scriptsheets will re-purpose as much material as possible from license compatible spreadsheet products. Much of this essay drew on LibreOffice Calc documentation. </div>
<div> </div>
<div>A rich native development environment will exist by the v1e0 release.</div>
<div> </div>
<div>I said that, if feasible, the development team would use a polyglot development environment consisting of Scala, Java, C++, and C, pretty much in that order. Since Scriptsheets' native spreadsheet programming environment in many ways will approximate a functional programming paradigm, I suspect it will be convenient to program much of Scriptsheets in a typed, functional programming language like Scala. </div>
</div>
<div> </div>
</div>
<br>
</div></div><div class="m_1088989942437648376m_-8636996006551092665pre" style="margin:0;padding:0;font-family:monospace">---------------------------------------------------<br> PLUG-discuss mailing list - <a href="mailto:PLUG-discuss@lists.phxlinux.org" target="_blank">PLUG-discuss@lists.phxlinux.org</a><br> To subscribe, unsubscribe, or to change your mail settings:<br> <a href="http://lists.phxlinux.org/mailman/listinfo/plug-discuss" target="_blank">http://lists.phxlinux.org/mailman/listinfo/plug-discuss</a></div>
</blockquote>
</div>
<br>---------------------------------------------------<br>
PLUG-discuss mailing list - <a href="mailto:PLUG-discuss@lists.phxlinux.org" target="_blank">PLUG-discuss@lists.phxlinux.org</a><br>
To subscribe, unsubscribe, or to change your mail settings:<br>
<a href="http://lists.phxlinux.org/mailman/listinfo/plug-discuss" rel="noreferrer" target="_blank">http://lists.phxlinux.org/mailman/listinfo/plug-discuss</a><br></blockquote></div><br><br clear="all"><div><br></div></div><div class="gmail_extra">-- <br><div class="m_1088989942437648376gmail_signature" data-smartmail="gmail_signature">A mouse trap, placed on top of your alarm clock, will prevent you from rolling over and going back to sleep after you hit the snooze button.<br><br>Stephen<br><br></div>
</div>
---------------------------------------------------<br>
PLUG-discuss mailing list - <a href="mailto:PLUG-discuss@lists.phxlinux.org" target="_blank">PLUG-discuss@lists.phxlinux.org</a><br>
To subscribe, unsubscribe, or to change your mail settings:<br>
<a href="http://lists.phxlinux.org/mailman/listinfo/plug-discuss" rel="noreferrer" target="_blank">http://lists.phxlinux.org/mailman/listinfo/plug-discuss</a></blockquote></div>