lilypond-user
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: scheme with Frescobaldi


From: Urs Liska
Subject: Re: scheme with Frescobaldi
Date: Wed, 27 Jun 2018 08:39:56 +0200
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0



Am 27.06.2018 um 07:34 schrieb Freeman Gilmore:


                           
                           
Thanks Urs:

That worked.   Problem was that I did not know that the results would be displayed in the log window.   The tutorial I am using had some example like  (+ 1 2 3)  =>  and I was expecting 6 in the same window on the next line when I compiled.

This is what one refers to as a REPL (read-eval-print-loop), which is what LilyPond's Scheme sandbox does.

  This may be what you mean by " but no immediate _expression_ evaluation". 

Yes. Frescobaldi deals with LilyPond *files*, not an immediate _expression_ evaluation.

Is => valid in guile?  

No.

 How would I display the results of (+ 1 2 3), at this point of the tutorial it just says  "(+ 1 2 3)  =>   6"?

When a tutorial writes "=>" it means: "You type in '(+ 1 2 3)', and the REPL will display '6'. So "=>" isn't a syntactical construct but a typographical convention for "the _expression_ to the left evaluates to the datum on the right".

Tutorials usually want you to learn from this immediate evaluation, and in Frescobaldi you have to always do that extra step to display something. But in general it's worth the effort, and I do that 90% of the time when I want to try something out or learn more about Scheme.

​​
For displaying values you can use #(display) or #(ly:message "Some value: ~a" data) (to start with ...)

HTH
Urs


Thank you,
ƒg
​Urs:

In you first example #(let...) what function does 'let' preform?    From your examples in "​For displaying values you can use #(display) or #(ly:message "Some value: ~a" data) (to start with ...)", could you please give me examples of each?   I need this to study the tutorial using Frescobaldi.

OK, it probably wasn't such a good idea to use non-atomic examples.
Let me try to put it another way: what you have in Frescobaldi is a LilyPond file. This file may include Scheme code, and LilyPond even works if there is *only* Scheme code in the file and no score is even generated. That way you can use LilyPond and Frescobaldi as a tool to experiment with Scheme code.
​When I started this post​ I was hoping that Scheme work with out score.

The way to include Scheme in LilyPond is the '#'. Whenever LilyPond encounters this hash it will have the immediately following _expression_ evaluated by Scheme. Essentially the _expression_ is replaced by the resulting value.
​This helped​
 
​a lot.​

What you have already noticed is that this Scheme code is not evaluated immediately (as is done on a REPL and what your tutorial seems to assume), but only when compiling the LilyPond file.

One more thing to understand is the following: any Scheme _expression_ *evaluates to* something (like (+ 1 2 3) evaluates to 6). In a REPL this value is displayed but in LilyPond/Frescobaldi it is not. If you write #(+ 1 2 3) in a LilyPond file it *will* evaluate to 6 but it only has the effect of placing that value 6 in the LilyPond file, which will have no effect at all.
​I figured this​.

The additional effort you have to make is explicitly print any value you want to inspect to the log window. Scheme provides some functions for that purpose: display, print, pretty-print, and more.
​​
  #(define my-var 12)
  #(display my-var)
will print '12' to the log window,
  #(display (+ 1 2 3))
will print '6'
​Now this helped because I was making it work with #(let...; above is much simpler.

Note that display won't add a line break, so when you want to see more than one value you'll want to add #(newline) expressions in between.
​Read that sum place.​
 

A final remark: there are many Scheme implementations (or dialects) around, with more or less subtle differences. When you use LilyPond you have a very specific dialect available (the Guile implementation in its version 1.8), plus when starting up LilyPond a number of extra Guile modules and many LilyPond features are automatically added. This means that when you follow a "Scheme tutorial" not necessarily everything will match what you find in LilyPond.

[And please allow me a plug: you may find rewarding to have a look at https://scheme-book.ursliska.de, which is far from complete but aims at giving a slow-paced and detailed introduction specifically from a LilyPond perspective]
​This is what I have been looking for.   Is there a PDF?    ​
 

No, and currently my (Gitbook) build system is broken, so I can't even upload updates. But the content is available in a bunch of Markdown files, and I'd be ready to move on to a new system, possibly Pandoc-based. If someone has a good suggestion for a tool/set-up to create PDF documents and HTML sites from Markdown content (with LilyPond syntax highlighting and inclusion of LilyPond scores) I'd be glad to look into it.

​Check your ​URL in this:
"You can and should for now ignore everything you don't know about that (we'll soon cover it in the chapter about variable binding) but simply realize that within that “mess” we have inserted ..."

Well, like with Wiki systems you can enter links to pages that don't exist yet. So that's simply part of the incompleteness of the "book", and I can't do anything about it right now.

Best
Urs


​Thank you, ƒg
   
Best
Urs


​Thank you,
ƒg​
 
         
​​
              

 



reply via email to

[Prev in Thread] Current Thread [Next in Thread]