;;; This file is part of GNU epsilon, a functional language implementation

;;; Copyright (C) 2003 Luca Saiu

;;; GNU epsilon 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 2, or (at your
;;; option) any later version.

;;; GNU epsilon 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 epsilon; see the file COPYING.  If not, write to the
;;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
;;; Boston, MA 02111-1307, USA. */


;;; Code for the s_clsr instruction

(let* ((closure (make-vector 2))
       (new-environment (make-vector 2)))
  (vector-set! new-environment 0 environment)
  (vector-set! new-environment 1 closure)
  (vector-set! closure 0 label-parameter-1)
  (vector-set! closure 1 new-environment)
  (push-stack closure)
  ;; The value to return
  (1+ instruction-pointer))
