"/* 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_cctba instruction */\n"
"\n"
"const word_t* first_array = (word_t*)UNDERTOP;\n"
"const integer_t size_of_first_array = ((integer_t*)first_array)[0];\n"
"const word_t* second_array = (word_t*)top;\n"
"const integer_t size_of_second_array = ((integer_t*)second_array)[0];\n"
"const integer_t size_of_new_array = size_of_first_array +\n"
"                                    size_of_second_array;\n"
"word_t* new_array;\n"
"integer_t i;\n"
"\n"
"/* Allocate the new array: */\n"
"ASSIGN_CREATE_ARRAY(new_array, size_of_new_array + 1);\n"
"\n"
"/* Set the size element: */\n"
"new_array[0] = (word_t)size_of_new_array;\n"
"\n"
"/* Copy the content of arrays: */\n"
"memcpy(new_array + 1, first_array + 1, size_of_first_array * sizeof(word_t));\n"
"memcpy(new_array + 1 + size_of_first_array, second_array + 1, \n"
"       size_of_second_array * sizeof(word_t));\n"
"\n"
"/* Emulate pop, pop, push(new_array): */\n"
"top = new_array;\n"
"undertop_stack_pointer--;\n"
""
