home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / mitsch75.zip / scheme-7_5_17-src.zip / scheme-7.5.17 / src / compiler / base / mvalue.scm < prev    next >
Text File  |  1999-01-02  |  2KB  |  68 lines

  1. #| -*-Scheme-*-
  2.  
  3. $Id: mvalue.scm,v 3.1 1999/01/02 06:06:43 cph Exp $
  4.  
  5. Copyright (c) 1987, 1999 Massachusetts Institute of Technology
  6.  
  7. This program is free software; you can redistribute it and/or modify
  8. it under the terms of the GNU General Public License as published by
  9. the Free Software Foundation; either version 2 of the License, or (at
  10. your option) any later version.
  11.  
  12. This program is distributed in the hope that it will be useful, but
  13. WITHOUT ANY WARRANTY; without even the implied warranty of
  14. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  15. General Public License for more details.
  16.  
  17. You should have received a copy of the GNU General Public License
  18. along with this program; if not, write to the Free Software
  19. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  20. |#
  21.  
  22. ;;;; Multiple Value Support
  23.  
  24. (declare (usual-integrations))
  25.  
  26. (define (transmit-values transmitter receiver)
  27.   (transmitter receiver))
  28.  
  29. (define (multiple-value-list transmitter)
  30.   (transmitter list))
  31.  
  32. (define (return . values)
  33.   (lambda (receiver)
  34.     (apply receiver values)))
  35.  
  36. ;;; For efficiency:
  37.  
  38. (define (return-2 v0 v1)
  39.   (lambda (receiver)
  40.     (receiver v0 v1)))
  41.  
  42. (define (return-3 v0 v1 v2)
  43.   (lambda (receiver)
  44.     (receiver v0 v1 v2)))
  45.  
  46. (define (return-4 v0 v1 v2 v3)
  47.   (lambda (receiver)
  48.     (receiver v0 v1 v2 v3)))
  49.  
  50. (define (return-5 v0 v1 v2 v3 v4)
  51.   (lambda (receiver)
  52.     (receiver v0 v1 v2 v3 v4)))
  53.  
  54. (define (return-6 v0 v1 v2 v3 v4 v5)
  55.   (lambda (receiver)
  56.     (receiver v0 v1 v2 v3 v4 v5)))
  57.  
  58. (define (list-multiple first . rest)
  59.   (apply call-multiple list first rest))
  60.  
  61. (define (cons-multiple cars cdrs)
  62.   (call-multiple cons cars cdrs))
  63.  
  64. (define (call-multiple procedure . transmitters)
  65.   (apply return
  66.      (apply map
  67.         procedure
  68.         (map multiple-value-list transmitters))))