robust unhygienic macros
Chris Hanson
(21 Aug 2022 22:29 UTC)
|
Re: robust unhygienic macros
Ray Dillinger
(22 Aug 2022 00:59 UTC)
|
Re: robust unhygienic macros
Marc Nieper-Wißkirchen
(22 Aug 2022 06:17 UTC)
|
Re: robust unhygienic macros
Ray Dillinger
(23 Aug 2022 02:05 UTC)
|
Re: robust unhygienic macros
Chris Hanson
(27 Aug 2022 21:49 UTC)
|
Re: robust unhygienic macros
Marc Nieper-Wißkirchen
(28 Aug 2022 15:20 UTC)
|
Re: robust unhygienic macros
Arthur A. Gleckler
(28 Aug 2022 20:51 UTC)
|
Re: robust unhygienic macros
Chris Hanson
(29 Aug 2022 08:25 UTC)
|
Re: robust unhygienic macros Marc Nieper-Wißkirchen (29 Aug 2022 15:42 UTC)
|
Re: robust unhygienic macros
Chris Hanson
(29 Aug 2022 20:43 UTC)
|
Re: robust unhygienic macros
Marc Nieper-Wißkirchen
(07 Nov 2022 13:44 UTC)
|
Am Mo., 29. Aug. 2022 um 10:25 Uhr schrieb Chris Hanson <xxxxxx@chris-hanson.org>: > > I’m still having trouble understanding exactly what you mean about not > returning raw symbols in their output. Since there’s no code in the SRFI I > can’t read it to figure it out. The comment about returning raw symbols was about ER (without extensions), which doesn't have forms like `close-syntax'. > If I make the following change to foo, it takes care of the problem: > > (define-syntax foo > (er-macro-transformer > (lambda (x r c) > (capture-syntactic-environment > (lambda (use-env) > `(,(r 'loop) (exit ,(close-syntax (cadr x) use-env)))))))) > > This captures the environment in which foo is used, then closes the argument > in that environment, ensuring that it gets the expected binding of exit. But > the raw symbol exit appearing in the output instead gets the exit bound by > loop’s expansion. Yes, this works, of course. But this is outside of what the note discusses as ER doesn't have `close-syntax'. > I’m pretty sure this isn’t what you are suggesting though. But in the context > of using syntactic closures it pretty clearly specifies what’s supposed to > happen. The issue I have is that it doesn't play well with syntax-rules. The `foo' macro should also work as expected when written with syntax-rules (which in turn is implemented with syntactic closures). In any case, this discussion shows that I should weaken the paragraph about syntactic closures added at the last minute to make it clear that I haven't yet found a satisfying way to write SC macros that are also robust in conjunction with syntax-rules. When we write every macro using an unhygienic one with the full power of SC (and not syntax-rules or the ER subset), the problem does not seem to occur, so I shouldn't say in isolation that I find SC broken. (There are still some robust unhygienic macros that can be formulated in syntax-case but not in syntactic closures, but these may not be too interesting.) Thanks, Marc > > Thanks, > Chris > > On Sunday, August 21, 2022 11:16:50 PM PDT Marc Nieper-Wißkirchen wrote: > > Am Mo., 22. Aug. 2022 um 00:29 Uhr schrieb Chris Hanson <xxxxxx@chris- > hanson.org>: > > > I’m not familiar with the term "robust unhygienic macros” and an internet > > > search didn’t reveal any definitions. > > > > The term was coined by myself for the purpose of SRFI 211. > > > > > Is there a definition of this term, or better yet, a paper? > > > > Unfortunately no. > > > > What I mean by a "robust unhygienic macro" is an unhygienic macro that > > even works when the unhygienic macro becomes part of the body of a > > second macro expansion. > > > > Please see "Note 2" under "Explicit-renaming macro" for an example. > > > > > I’m a little confused because the SRFI claims that explicit-renaming > > > macros > > > can produce "robust unhygienic macros” yet syntactic-closure macros > > > cannot. > > > However, explicit-renaming is virtually identical to “reverse” syntactic- > > > closure macros, which are syntactic-closure macros with the definition and > > > use environments flipped. > > > > ER macros implemented with SC (syntactic closures) are indeed not > > "robust" (according to my findings). SRFI 211 describes a variation of > > ER (implemented with marks & substitutions) that can be used to define > > unhygienic macros that are "robust". The variation of ER is not 100% > > compatible with how ER is classically implemented. > > > > You can write down the example in Note 2 for SC as well. > > > > Does this help? > > > > Thanks, > > > > Marc > > > > PS My time this week is limited, so please excuse the rather brief reply. > > > >