"/* This file is part of GNU epsilon, a functional language implementation\n"
"\n"
"Copyright (C) 2002 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"
"/* Build a circular closure: the closure itself contains the label \n"
"   LABEL_PARAMETER and the pointer to an environment; this environment\n"
"   has the current environment in its s-link, and the circular closure\n"
"   itself as the only local object. */\n"
"word_t* closure;\n"
"word_t* environment_for_subprogram;\n"
"\n"
"ASSIGN_MY_MALLOC(environment_for_subprogram, 2);\n"
"ASSIGN_CONS(closure, ((word_t)LABEL_PARAMETER),\n"
"                     (word_t)environment_for_subprogram);\n"
"environment_for_subprogram[0] = (word_t)environment;\n"
"environment_for_subprogram[1] = (word_t)closure;\n"
"\n"
"PUSH_OBJECT((word_t)closure);\n"
""
