racket/s/patch.ss
Matthew Flatt b78838a641 cp0: move only known-single-valued out of single-value context
In safe compilation modes, avoid turning an error like

 (let ([x (values 1 2)]) x)

or

 (car (list (values 1 2)))

into a program that returns multiple values or

 (if (list (values 1 2)) 3 4)

into a program that returns without an error.

In addition, refrain from moving an expression from a non-tail
position within a procedure to a tail position, unless the expression
is not only single valued but also gauarnteed not to inspect the
immediate continuation (e.g., using `call/cc` and comparing the result
to a previously captured continuation). This constraint applies even
in unsafe compilation modes, because the intent it to provide some
guarantees about non-tail positions to complement existing guarantees
of tail positions.

original commit: 91e9631576e7b97137be856e985609320e327f32
2019-01-08 20:27:26 -07:00

36 lines
1.2 KiB
Scheme

;;; patch.ss
;;; Copyright 1984-2017 Cisco Systems, Inc.
;;;
;;; Licensed under the Apache License, Version 2.0 (the "License");
;;; you may not use this file except in compliance with the License.
;;; You may obtain a copy of the License at
;;;
;;; http://www.apache.org/licenses/LICENSE-2.0
;;;
;;; Unless required by applicable law or agreed to in writing, software
;;; distributed under the License is distributed on an "AS IS" BASIS,
;;; WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
;;; See the License for the specific language governing permissions and
;;; limitations under the License.
(define ($value x) x)
(printf "loading ~s cross compiler~%" (constant machine-type-name))
; (current-expand (lambda args (apply sc-expand args)))
; (current-eval (lambda args (apply interpret args)))
(when-feature pthreads
(meta-cond
[(not (threaded?))
; we must be cross-compiling from nonthreaded to threaded version
; handle thread parameter creation
(define-syntax with-mutex
(syntax-rules ()
[(_ mexp e0 e1 ...) (begin e0 e1 ...)]))
(set! make-thread-parameter make-parameter)
(set! mutex-acquire (lambda (m) (void)))
(set! mutex-release (lambda (m) (void)))
(set! $tc-mutex (void))]))