Discussion:
conditional code segments
Matt Wette
2018-06-01 23:37:10 UTC
Permalink
In C I can use `#ifdef' .. `#endif' to "comment out" code segments.

In Scheme, one can use `#|' and '|#' which is OK but requires dealing with both ends of the
segment to switch on / off. And emacs (v 24.5) scheme mode does not always fontify the buffer
correctly with #|...|#.

I can use (if #f (begin ....)) but it's not pretty and indents 4 spaces (or an ugly 1 space).

I tried using cond-expand but it does not work as expected:
scheme@(guile-user)> (cond-expand-provide (current-module) '(abc))
$1 = (abc)
scheme@(guile-user)> (cond-expand (abc #t))
While compiling expression:
Syntax error:
unknown file:2:0: cond-expand: unfulfilled cond-expand in form (cond-expand (abc #t))

My current attempt is to add this:

(define-syntax-rule (if-true form ...) (begin form ...))
(define-syntax-rule (if-false form ...) (begin))

(if-false
(define x ...)
...
)

(if-true
(define x ...)
...
)

Any other solutions / suggestions?
Alex Vong
2018-06-02 01:11:45 UTC
Permalink
Post by Matt Wette
In C I can use `#ifdef' .. `#endif' to "comment out" code segments.
In Scheme, one can use `#|' and '|#' which is OK but requires dealing with both ends of the
segment to switch on / off. And emacs (v 24.5) scheme mode does not always fontify the buffer
correctly with #|...|#.
I can use (if #f (begin ....)) but it's not pretty and indents 4 spaces (or an ugly 1 space).
$1 = (abc)
unknown file:2:0: cond-expand: unfulfilled cond-expand in form (cond-expand (abc #t))
(define-syntax-rule (if-true form ...) (begin form ...))
(define-syntax-rule (if-false form ...) (begin))
(if-false
(define x ...)
...
)
(if-true
(define x ...)
...
)
Any other solutions / suggestions?
Maybe you can try to use #; to comment out s-exp? I prefer this way
because it feels very lispy to me.
Mark H Weaver
2018-06-02 01:56:36 UTC
Permalink
Hi Matt,
Post by Matt Wette
In C I can use `#ifdef' .. `#endif' to "comment out" code segments.
In Scheme, one can use `#|' and '|#' which is OK but requires dealing with both ends of the
segment to switch on / off. And emacs (v 24.5) scheme mode does not always fontify the buffer
correctly with #|...|#.
There's another kind of comment in standard Scheme (both R6RS and R7RS)
that's supported by Guile, but unfortunately it doesn't seem to be
documented in our manual. Simply put the two characters "#;" before any
datum, and the entire datum will be skipped by the reader. Whitespace
may appear between "#;" and the datum. So, for example:

#;
(let ()
...)

will cause the entire 'let' form (which is a datum) to be skipped.
Emacs and paredit understand this syntax, and will act accordingly.

It works not only at top-level, but also nested arbitrarily deeply
within datums. So, for example:

scheme@(guile-user)> (let ()
(display "1\n")
(display "2\n")
#;
(display "3\n"))
1
2
scheme@(guile-user)>

and if you put that code in an Emacs buffer in Scheme mode, the
(display "3\n") will be colorized as a comment, but the final closing
parenthesis will have the default color.
Post by Matt Wette
$1 = (abc)
unknown file:2:0: cond-expand: unfulfilled cond-expand in form (cond-expand (abc #t))
It didn't work because when a 'cond-expand' form is used in module FOO,
it looks for the features (e.g. 'abc') in all of the modules that are
imported by FOO, but not in FOO itself.

Mark
Matt Wette
2018-06-02 02:34:23 UTC
Permalink
Post by Mark H Weaver
Hi Matt,
Post by Matt Wette
In C I can use `#ifdef' .. `#endif' to "comment out" code segments.
In Scheme, one can use `#|' and '|#' which is OK but requires dealing with both ends of the
segment to switch on / off. And emacs (v 24.5) scheme mode does not always fontify the buffer
correctly with #|...|#.
There's another kind of comment in standard Scheme (both R6RS and R7RS)
that's supported by Guile, but unfortunately it doesn't seem to be
documented in our manual. Simply put the two characters "#;" before any
datum, and the entire datum will be skipped by the reader. Whitespace
#;
(let ()
...)
will cause the entire 'let' form (which is a datum) to be skipped.
Emacs and paredit understand this syntax, and will act accordingly.
It works not only at top-level, but also nested arbitrarily deeply
(display "1\n")
(display "2\n")
#;
(display "3\n"))
1
2
and if you put that code in an Emacs buffer in Scheme mode, the
(display "3\n") will be colorized as a comment, but the final closing
parenthesis will have the default color.
I use #; a lot.   So for large number of forms then #;(begin ...) should work.
And I didn't know white space can separate the #; from the Scheme form.  Cool.
Post by Mark H Weaver
$1 = (abc)
unknown file:2:0: cond-expand: unfulfilled cond-expand in form (cond-expand (abc #t))
It didn't work because when a 'cond-expand' form is used in module FOO,
it looks for the features (e.g. 'abc') in all of the modules that are
imported by FOO, but not in FOO itself.
Thanks much.

Loading...