unofficial mirror of guile-user@gnu.org 
 help / color / mirror / Atom feed
* lalr parser: on Bison-like source locations
@ 2014-10-26 20:11 Jan Nieuwenhuizen
  2014-10-28 10:11 ` Nala Ginrut
  0 siblings, 1 reply; 6+ messages in thread
From: Jan Nieuwenhuizen @ 2014-10-26 20:11 UTC (permalink / raw)
  To: NalaGinrut; +Cc: guile-user

[-- Attachment #1: Type: text/plain, Size: 763 bytes --]

Hi,

Saw your question on irc.

Attached is a modification on your `simple' language that demonstrates
transparent source locations.

The explicit, Bison-like locations work just like they do in Bison...eg
something like:

    ;; helper
    (define (note-location ast loc)
      (when (supports-source-properties? ast)
          (set-source-property! ast 'loc loc))
      ast)

  (define (make-parser)
    (lalr-parser
    ;; ...
    ;; production rules
    (variable
     (type Identifier = expression semicolon) : `(variable ,$2 ,$1 ,(note-location `(expression ,$4) @3))
     (Identifier dot Identifier Identifier = expression semicolon) : `(variable ,$4 (type ,$3 ,$1) ,(note-location `(expression ,$6) @5)))

Does that answer your question?

Greetings, Jan


[-- Attachment #2: simple.scm --]
[-- Type: application/octet-stream, Size: 3562 bytes --]

;;  Copyright (C) 2014
;;      "Mu Lei" known as "NalaGinrut" <NalaGinrut@gmail.com>
;;  This file is free software: you can redistribute it and/or modify
;;  it under the terms of the GNU General Public License as published by
;;  the Free Software Foundation, either version 3 of the License, or
;;  (at your option) any later version.

;;  This file is distributed in the hope that it will be useful,
;;  but WITHOUT ANY WARRANTY; without even the implied warranty of
;;  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
;;  GNU General Public License for more details.

;;  You should have received a copy of the GNU General Public License
;;  along with this program.  If not, see <http://www.gnu.org/licenses/>.

(define-module (language simple simple)
  #:use-module (system base lalr)
  #:use-module (language tree-il)
  #:use-module (ice-9 and-let-star)
  #:use-module (ice-9 match)
  #:export (make-simple-tokenizer make-parser compile-tree-il))

;; Two helper macros to create the token struct for returning
(define-syntax-rule (port-source-location port)
  (make-source-location (port-filename port)
                        (port-line port)
                        (port-column port)
                        (false-if-exception (ftell port))
                        #f))
(define-syntax-rule (return port category value)
  (make-lexical-token category (port-source-location port) value))

(define (is-whitespace? c) (char-set-contains? char-set:whitespace c))
(define (is-number? c) (char-set-contains? char-set:hex-digit c))
;; operators, in this simple case, we just have four operators
(define (is-op? c) (string-contains "+-*/" (string c)))
(define (is-delimiter? c)
  (or (eof-object? c) (string-contains " +-*/;\n" (string c))))
(define (get-number port)
 (let lp((c (peek-char port)) (ret '()))
   (cond
    ((is-delimiter? c) ; encounter delimiter, finish to read a number
     ;; convert to a number representation
     (string->number (list->string (reverse ret))))
    (else
     (read-char port) ; next char
     (lp (peek-char port) (cons c ret))))))
(define (get-op port) (string->symbol (string (read-char port))))
(define (next-token port)
  (let ((c (peek-char port)))
    (cond
     ((or (eof-object? c) (char=? c #\nl)) ; end of line, or end src
      '*eoi*) ; return '*eoi* because LALR module need it
     ((is-whitespace? c)
      (read-char port)
      (next-token port)) ; skip white space
     ((is-number? c)
      (return port 'number (get-number port)))
     ((is-op? c)
      (return port (get-op port) #f))
     (else
      (read-char port)
      (next-token port)))))
(define (make-simple-tokenizer port) (lambda () (next-token port)))
(define (make-parser)
  (lalr-parser
   (driver: lr)
   ;;(driver: glr)
   (number (left: + -) (left: * /))
   (program (exp) : $1
            (*eoi*) : (call-with-input-string "" read)) ; *eof-object*
   (exp  (exp + term) : `(+ ,$1 ,$3)
         (exp - term) : `(- ,$1 ,$3)
         (term) : $1)
   (term (term * factor) : `(* ,$1 ,$3)
         (term / factor) : `(/ ,$1 ,$3)
         (factor) : $1)
   (factor (number) : `(number ,$1))))
(define (compile-tree-il exp env opts)
  (values (parse-tree-il (comp exp '())) env env))
(define (comp src e)
  (and-let* (((supports-source-properties? src))
             (loc (source-property src 'loc)))
            (format (current-error-port) "LOC [~a]: ~a\n" loc src))
  (match src
    (('number x) `(const ,x))
    ((op x y) `(apply (primitive ,op) ,(comp x e) ,(comp y e)))
    ((h t ...) (comp h e)))) ;; for driver glr

[-- Attachment #3: spec.scm --]
[-- Type: application/octet-stream, Size: 1097 bytes --]

;;  Copyright (C) 2014
;;      "Mu Lei" known as "NalaGinrut" <NalaGinrut@gmail.com>
;;  This file is free software: you can redistribute it and/or modify
;;  it under the terms of the GNU General Public License as published by
;;  the Free Software Foundation, either version 3 of the License, or
;;  (at your option) any later version.

;;  This file is distributed in the hope that it will be useful,
;;  but WITHOUT ANY WARRANTY; without even the implied warranty of
;;  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
;;  GNU General Public License for more details.

;;  You should have received a copy of the GNU General Public License
;;  along with this program.  If not, see <http://www.gnu.org/licenses/>.

(define-module (language simple spec)
  #:use-module (system base language)
  #:use-module (language simple simple)
  #:export (simple))
 
(define-language simple
  #:title       "simple"
  #:reader      (lambda (port env) 
                  ((make-parser) (make-simple-tokenizer port) error))
  #:compilers   `((tree-il . ,compile-tree-il))
  #:printer     write)

[-- Attachment #4: Type: text/plain, Size: 154 bytes --]


-- 
Jan Nieuwenhuizen <janneke@gnu.org> | GNU LilyPond http://lilypond.org
Freelance IT http://JoyofSource.com | Avatar®  http://AvatarAcademy.nl  

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: lalr parser: on Bison-like source locations
  2014-10-26 20:11 lalr parser: on Bison-like source locations Jan Nieuwenhuizen
@ 2014-10-28 10:11 ` Nala Ginrut
  2014-10-28 10:41   ` Jan Nieuwenhuizen
  0 siblings, 1 reply; 6+ messages in thread
From: Nala Ginrut @ 2014-10-28 10:11 UTC (permalink / raw)
  To: Jan Nieuwenhuizen; +Cc: Guile User, Ludovic Courtès

Thanks for reply!
I wonder if Guile master has updated to the latest lalr-scm, since I
can't see the expected result.
If the answer is no, I have to request for it, it's important for our
multi-lang hacking.

Thanks!

On Mon, Oct 27, 2014 at 4:11 AM, Jan Nieuwenhuizen <janneke@gnu.org> wrote:
> Hi,
>
> Saw your question on irc.
>
> Attached is a modification on your `simple' language that demonstrates
> transparent source locations.
>
> The explicit, Bison-like locations work just like they do in Bison...eg
> something like:
>
>     ;; helper
>     (define (note-location ast loc)
>       (when (supports-source-properties? ast)
>           (set-source-property! ast 'loc loc))
>       ast)
>
>   (define (make-parser)
>     (lalr-parser
>     ;; ...
>     ;; production rules
>     (variable
>      (type Identifier = expression semicolon) : `(variable ,$2 ,$1 ,(note-location `(expression ,$4) @3))
>      (Identifier dot Identifier Identifier = expression semicolon) : `(variable ,$4 (type ,$3 ,$1) ,(note-location `(expression ,$6) @5)))
>
> Does that answer your question?
>
> Greetings, Jan
>
>
>
> --
> Jan Nieuwenhuizen <janneke@gnu.org> | GNU LilyPond http://lilypond.org
> Freelance IT http://JoyofSource.com | Avatar®  http://AvatarAcademy.nl
>



^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: lalr parser: on Bison-like source locations
  2014-10-28 10:11 ` Nala Ginrut
@ 2014-10-28 10:41   ` Jan Nieuwenhuizen
  2014-10-28 10:51     ` Nala Ginrut
                       ` (2 more replies)
  0 siblings, 3 replies; 6+ messages in thread
From: Jan Nieuwenhuizen @ 2014-10-28 10:41 UTC (permalink / raw)
  To: Nala Ginrut; +Cc: Guile User, Ludovic Courtès

Nala Ginrut writes:

> I wonder if Guile master has updated to the latest lalr-scm, since I
> can't see the expected result.
> If the answer is no, I have to request for it, it's important for our
> multi-lang hacking.

Not yet, three patches I sent are pending, waiting for my copyright
assignment to get through, I think.

Jan

-- 
Jan Nieuwenhuizen <janneke@gnu.org> | GNU LilyPond http://lilypond.org
Freelance IT http://JoyofSource.com | Avatar®  http://AvatarAcademy.nl  



^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: lalr parser: on Bison-like source locations
  2014-10-28 10:41   ` Jan Nieuwenhuizen
@ 2014-10-28 10:51     ` Nala Ginrut
  2014-10-28 16:19     ` Ludovic Courtès
  2014-10-28 22:17     ` Ludovic Courtès
  2 siblings, 0 replies; 6+ messages in thread
From: Nala Ginrut @ 2014-10-28 10:51 UTC (permalink / raw)
  To: Jan Nieuwenhuizen; +Cc: Guile User, Ludovic Courtès

Oh, it took me more than a month for shipping the assignment paper
years before. ;-)
Anyway, it's fine for me, because you choose to implement it with
source-property which prevent me to modify the whole structure of
parsing tree and test cases. So I don't have to wait for the patch,
it's cool for me to continue the hacking. ;-D

Thanks!

On Tue, Oct 28, 2014 at 6:41 PM, Jan Nieuwenhuizen <janneke@gnu.org> wrote:
> Nala Ginrut writes:
>
>> I wonder if Guile master has updated to the latest lalr-scm, since I
>> can't see the expected result.
>> If the answer is no, I have to request for it, it's important for our
>> multi-lang hacking.
>
> Not yet, three patches I sent are pending, waiting for my copyright
> assignment to get through, I think.
>
> Jan
>
> --
> Jan Nieuwenhuizen <janneke@gnu.org> | GNU LilyPond http://lilypond.org
> Freelance IT http://JoyofSource.com | Avatar®  http://AvatarAcademy.nl



^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: lalr parser: on Bison-like source locations
  2014-10-28 10:41   ` Jan Nieuwenhuizen
  2014-10-28 10:51     ` Nala Ginrut
@ 2014-10-28 16:19     ` Ludovic Courtès
  2014-10-28 22:17     ` Ludovic Courtès
  2 siblings, 0 replies; 6+ messages in thread
From: Ludovic Courtès @ 2014-10-28 16:19 UTC (permalink / raw)
  To: Jan Nieuwenhuizen; +Cc: Guile User

Jan Nieuwenhuizen <janneke@gnu.org> skribis:

> Not yet, three patches I sent are pending, waiting for my copyright
> assignment to get through, I think.

Indeed, you’re not listed yet.  If it’s been more than 3 weeks or so,
don’t hesitate to ping them by email.

Ludo’.



^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: lalr parser: on Bison-like source locations
  2014-10-28 10:41   ` Jan Nieuwenhuizen
  2014-10-28 10:51     ` Nala Ginrut
  2014-10-28 16:19     ` Ludovic Courtès
@ 2014-10-28 22:17     ` Ludovic Courtès
  2 siblings, 0 replies; 6+ messages in thread
From: Ludovic Courtès @ 2014-10-28 22:17 UTC (permalink / raw)
  To: Jan Nieuwenhuizen; +Cc: Guile User

Jan Nieuwenhuizen <janneke@gnu.org> skribis:

> Not yet, three patches I sent are pending, waiting for my copyright
> assignment to get through, I think.

Well, we received it just now.  :-)

Ludo’.



^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2014-10-28 22:17 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-10-26 20:11 lalr parser: on Bison-like source locations Jan Nieuwenhuizen
2014-10-28 10:11 ` Nala Ginrut
2014-10-28 10:41   ` Jan Nieuwenhuizen
2014-10-28 10:51     ` Nala Ginrut
2014-10-28 16:19     ` Ludovic Courtès
2014-10-28 22:17     ` Ludovic Courtès

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).