";;; This file is part of GNU epsilon, a functional language implementation\n"
"\n"
";;; Copyright (C) 2003 Luca Saiu\n"
"\n"
";;; GNU epsilon is free software; you can redistribute it and/or modify\n"
";;; it under the terms of the GNU General Public License as published\n"
";;; by the Free Software Foundation; either version 2, or (at your\n"
";;; option) any later version.\n"
"\n"
";;; GNU epsilon is distributed in the hope that it will be useful, but\n"
";;; WITHOUT ANY WARRANTY; without even the implied warranty of\n"
";;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU\n"
";;; General Public License for more details.\n"
"\n"
";;; You should have received a copy of the GNU General Public License\n"
";;; along with epsilon; see the file COPYING.  If not, write to the\n"
";;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,\n"
";;; Boston, MA 02111-1307, USA. */\n"
"\n"
"\n"
";;; Code for the s_clsr instruction\n"
"\n"
"(let* ((closure (make-vector 2))\n"
"       (new-environment (make-vector 2)))\n"
"  (vector-set! new-environment 0 environment)\n"
"  (vector-set! new-environment 1 closure)\n"
"  (vector-set! closure 0 label-parameter-1)\n"
"  (vector-set! closure 1 new-environment)\n"
"  (push-stack closure)\n"
"  ;; The value to return\n"
"  (1+ instruction-pointer))\n"
""
