mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-04-30 03:40:34 +02:00
Fix expansion of 'error' primitive with a non-constant argument.
Fixes <https://bugs.gnu.org/39509>. Reported by Klaus Stehle <klaus.stehle@uni-tuebingen.de>. * module/language/tree-il/primitives.scm (error): Remove extra "?" argument when the first argument is not a constant. * test-suite/tests/tree-il.test ("primitives")["error"]: New test prefix.
This commit is contained in:
parent
5d96e42158
commit
d49453259b
2 changed files with 37 additions and 4 deletions
|
@ -1,6 +1,6 @@
|
|||
;;; open-coding primitive procedures
|
||||
|
||||
;; Copyright (C) 2009-2015, 2017-2019 Free Software Foundation, Inc.
|
||||
;; Copyright (C) 2009-2015, 2017-2020 Free Software Foundation, Inc.
|
||||
|
||||
;;;; This library is free software; you can redistribute it and/or
|
||||
;;;; modify it under the terms of the GNU Lesser General Public
|
||||
|
@ -395,7 +395,6 @@
|
|||
(list (make-const src 'misc-error)
|
||||
(make-const src #f)
|
||||
(make-const src msg)
|
||||
(make-const src "?")
|
||||
(make-primcall src 'list (cons message args))
|
||||
(make-const src #f)))))))
|
||||
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
;;;; tree-il.test --- test suite for compiling tree-il -*- scheme -*-
|
||||
;;;; Andy Wingo <wingo@pobox.com> --- May 2009
|
||||
;;;;
|
||||
;;;; Copyright (C) 2009-2014,2018-2019 Free Software Foundation, Inc.
|
||||
;;;; Copyright (C) 2009-2014,2018-2020 Free Software Foundation, Inc.
|
||||
;;;;
|
||||
;;;; This library is free software; you can redistribute it and/or
|
||||
;;;; modify it under the terms of the GNU Lesser General Public
|
||||
|
@ -114,7 +114,41 @@
|
|||
|
||||
(pass-if-primitives-resolved
|
||||
(primcall equal? (const #nil) (toplevel x))
|
||||
(primcall eq? (const #nil) (toplevel x)))))
|
||||
(primcall eq? (const #nil) (toplevel x))))
|
||||
|
||||
(with-test-prefix "error"
|
||||
(pass-if-primitives-resolved
|
||||
(primcall error (const "message"))
|
||||
(primcall throw (const misc-error) (const #f)
|
||||
(const "message") (primcall list) (const #f)))
|
||||
|
||||
(pass-if-primitives-resolved
|
||||
(primcall error (const "message") (const 42))
|
||||
(primcall throw (const misc-error) (const #f)
|
||||
(const "message ~S") (primcall list (const 42))
|
||||
(const #f)))
|
||||
|
||||
(pass-if-equal "https://bugs.gnu.org/39509"
|
||||
'(throw 'misc-error #f "~A" (list "message") #f)
|
||||
(let ((module (make-fresh-user-module)))
|
||||
(decompile (expand-primitives
|
||||
(resolve-primitives
|
||||
(compile '(error ((lambda () "message")))
|
||||
#:to 'tree-il)
|
||||
module))
|
||||
#:from 'tree-il
|
||||
#:to 'scheme)))
|
||||
|
||||
(pass-if-equal "https://bugs.gnu.org/39509 with argument"
|
||||
'(throw 'misc-error #f "~A ~S" (list "message" 42) #f)
|
||||
(let ((module (make-fresh-user-module)))
|
||||
(decompile (expand-primitives
|
||||
(resolve-primitives
|
||||
(compile '(error ((lambda () "message")) 42)
|
||||
#:to 'tree-il)
|
||||
module))
|
||||
#:from 'tree-il
|
||||
#:to 'scheme)))))
|
||||
|
||||
|
||||
(with-test-prefix "tree-il->scheme"
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue