void del_pack_sym(CL_FORM *base) { LOAD_SMALLFIXNUM(1, ARG(3)); LOAD_SMALLFIXNUM(0, ARG(4)); COPY(SYMVAL(Slisp, 0), ARG(5)); /* MOST-POSITIVE-FIXNUM */ COPY(ARG(0), ARG(6)); COPY(ARG(1), ARG(7)); COPY(ARG(2), ARG(8)); Fsvref(ARG(7)); LOAD_NIL(ARG(8)); LOAD_NIL(ARG(9)); LOAD_NIL(ARG(10)); COPY(ARG(4), ARG(11)); COPY(ARG(5), ARG(12)); COPY(ARG(3), ARG(13)); LOAD_NIL(ARG(14)); delete1(ARG(6)); COPY(ARG(6), ARG(3)); COPY(ARG(3), ARG(0)); Fset_svref(ARG(0)); }
void export1(CL_FORM *base) { coerce_to_package(ARG(1)); if(CL_LISTP(ARG(0))) { } else { COPY(ARG(0), ARG(2)); Flist(ARG(2), 1); COPY(ARG(2), ARG(0)); } LOAD_NIL(ARG(2)); COPY(ARG(0), ARG(3)); M1_1:; if(CL_ATOMP(ARG(3))) { LOAD_NIL(ARG(2)); goto RETURN1; } COPY(ARG(3), ARG(4)); COPY(GET_CAR(ARG(4)), ARG(2)); if(CL_SYMBOLP(ARG(2))) { LOAD_SMSTR(SYM_NAME(ARG(2)), ARG(4)); } else { if(CL_TRUEP(ARG(2))) { COPY(SYMVAL(Slisp, 676), ARG(4)); /* SYM_EXPECTED */ COPY(ARG(2), ARG(5)); Ferror(ARG(4), 2); } else { LOAD_SMSTR((CL_FORM *)&KClisp[266], ARG(4)); /* NIL */ } } COPY(ARG(1), ARG(5)); find_symbol1(ARG(4)); COPY(&mv_buf[0], ARG(5)); { int nargs; nargs = 2; mv_count = 1; { switch(nargs) { case 0: LOAD_NIL(ARG(4)); case 1: LOAD_NIL(ARG(5)); nargs = 2; } if(CL_TRUEP(ARG(5))) { LOAD_NIL(ARG(6)); } else { LOAD_SYMBOL(SYMBOL(Slisp, 48), ARG(6)); /* T */ } if(CL_TRUEP(ARG(6))) { goto THEN1; } else { if(EQ(ARG(4), ARG(2))) { goto ELSE2; } else { goto THEN1; } } { THEN1:; LOAD_SMSTR((CL_FORM *)&Kexport1[0], ARG(6)); /* ~S is not accessible in ~S */ COPY(ARG(2), ARG(7)); COPY(ARG(1), ARG(8)); Ferror(ARG(6), 3); } ELSE2:; if(CL_SYMBOLP(ARG(5)) && GET_SYMBOL(ARG(5)) == SYMBOL(Slisp, 385)) /* EXTERNAL */ { goto RETURN1; } LOAD_NIL(ARG(6)); COPY(ARG(1), ARG(7)); LOAD_SYMBOL(SYMBOL(Slisp, 354), ARG(8)); /* PACKAGE */ rt_struct_typep(ARG(7)); if(CL_TRUEP(ARG(7))) { COPY(OFFSET(AR_BASE(GET_FORM(ARG(1))), 6 + 1), ARG(7)); } else { COPY(SYMVAL(Slisp, 352), ARG(7)); /* NO_STRUCT */ COPY(ARG(1), ARG(8)); LOAD_SYMBOL(SYMBOL(Slisp, 354), ARG(9)); /* PACKAGE */ Ferror(ARG(7), 3); } M2_1:; if(CL_ATOMP(ARG(7))) { LOAD_NIL(ARG(6)); goto RETURN2; } COPY(ARG(7), ARG(8)); COPY(GET_CAR(ARG(8)), ARG(6)); if(CL_SYMBOLP(ARG(2))) { LOAD_SMSTR(SYM_NAME(ARG(2)), ARG(8)); } else { if(CL_TRUEP(ARG(2))) { COPY(SYMVAL(Slisp, 676), ARG(8)); /* SYM_EXPECTED */ COPY(ARG(2), ARG(9)); Ferror(ARG(8), 2); } else { LOAD_SMSTR((CL_FORM *)&KClisp[266], ARG(8)); /* NIL */ } } COPY(ARG(6), ARG(9)); find_symbol1(ARG(8)); COPY(&mv_buf[0], ARG(9)); { int nargs; nargs = 2; mv_count = 1; { switch(nargs) { case 0: LOAD_NIL(ARG(8)); case 1: LOAD_NIL(ARG(9)); nargs = 2; } if(CL_TRUEP(ARG(9))) { if(EQ(ARG(8), ARG(2))) { goto ELSE3; } else { COPY(ARG(6), ARG(10)); LOAD_SYMBOL(SYMBOL(Slisp, 354), ARG(11)); /* PACKAGE */ rt_struct_typep(ARG(10)); if(CL_TRUEP(ARG(10))) { COPY(OFFSET(AR_BASE(GET_FORM(ARG(6))), 4 + 1), ARG(10)); } else { COPY(SYMVAL(Slisp, 352), ARG(10)); /* NO_STRUCT */ COPY(ARG(6), ARG(11)); LOAD_SYMBOL(SYMBOL(Slisp, 354), ARG(12)); /* PACKAGE */ Ferror(ARG(10), 3); } COPY(ARG(8), ARG(11)); COPY(ARG(10), ARG(12)); LOAD_NIL(ARG(13)); LOAD_NIL(ARG(14)); LOAD_NIL(ARG(15)); member1(ARG(11)); COPY(ARG(11), ARG(10)); if(CL_TRUEP(ARG(10))) { goto ELSE3; } else { goto THEN4; } } } else { goto ELSE3; } { THEN4:; LOAD_SMSTR((CL_FORM *)&Kexport1[2], ARG(10)); /* ~S will cause a name conflict in ~S */ COPY(ARG(2), ARG(11)); COPY(ARG(6), ARG(12)); Ferror(ARG(10), 3); } ELSE3:; } } COPY(ARG(7), ARG(8)); COPY(GET_CDR(ARG(8)), ARG(7)); goto M2_1; RETURN2:; if(CL_SYMBOLP(ARG(2))) { LOAD_SMSTR(SYM_NAME(ARG(2)), ARG(6)); } else { if(CL_TRUEP(ARG(2))) { COPY(SYMVAL(Slisp, 676), ARG(6)); /* SYM_EXPECTED */ COPY(ARG(2), ARG(7)); Ferror(ARG(6), 2); } else { LOAD_SMSTR((CL_FORM *)&KClisp[266], ARG(6)); /* NIL */ } } LOAD_FIXNUM(ARG(7), 101, ARG(7)); COPY(ARG(6), ARG(8)); string_to_simple_string(ARG(8)); rt_sxhash_string(ARG(8)); COPY(ARG(8), ARG(9)); LOAD_FIXNUM(ARG(10), 101, ARG(10)); rt_floor(ARG(9)); COPY(&mv_buf[0], ARG(10)); mv_count = 1; { COPY(ARG(10), ARG(6)); } if(CL_SYMBOLP(ARG(5)) && GET_SYMBOL(ARG(5)) == SYMBOL(Slisp, 384)) /* INTERNAL */ { COPY(ARG(2), ARG(7)); COPY(ARG(1), ARG(8)); LOAD_SYMBOL(SYMBOL(Slisp, 354), ARG(9)); /* PACKAGE */ rt_struct_typep(ARG(8)); if(CL_TRUEP(ARG(8))) { COPY(OFFSET(AR_BASE(GET_FORM(ARG(1))), 2 + 1), ARG(8)); } else { COPY(SYMVAL(Slisp, 352), ARG(8)); /* NO_STRUCT */ COPY(ARG(1), ARG(9)); LOAD_SYMBOL(SYMBOL(Slisp, 354), ARG(10)); /* PACKAGE */ Ferror(ARG(8), 3); } COPY(ARG(6), ARG(9)); del_pack_sym(ARG(7)); } COPY(ARG(1), ARG(7)); LOAD_SYMBOL(SYMBOL(Slisp, 354), ARG(8)); /* PACKAGE */ rt_struct_typep(ARG(7)); if(CL_TRUEP(ARG(7))) { COPY(OFFSET(AR_BASE(GET_FORM(ARG(1))), 3 + 1), ARG(7)); } else { COPY(SYMVAL(Slisp, 352), ARG(7)); /* NO_STRUCT */ COPY(ARG(1), ARG(8)); LOAD_SYMBOL(SYMBOL(Slisp, 354), ARG(9)); /* PACKAGE */ Ferror(ARG(7), 3); } COPY(ARG(7), ARG(9)); COPY(ARG(6), ARG(10)); Fsvref(ARG(9)); ALLOC_CONS(ARG(10), ARG(2), ARG(9), ARG(8)); COPY(ARG(8), ARG(9)); COPY(ARG(7), ARG(10)); COPY(ARG(6), ARG(11)); Fset_svref(ARG(9)); } } COPY(ARG(3), ARG(4)); COPY(GET_CDR(ARG(4)), ARG(3)); goto M1_1; RETURN1:; LOAD_SYMBOL(SYMBOL(Slisp, 48), ARG(0)); /* T */ }
void rt_setup_symbol(CL_FORM *base) { if(CL_SYMBOLP(ARG(0))) { COPY(SYM_PACKAGE(ARG(0)), ARG(2)); } else { if(CL_TRUEP(ARG(0))) { LOAD_NIL(ARG(2)); } else { COPY(SYMVAL(Slisp, 679), ARG(2)); /* *NIL-PACKAGE* */ } } if(CL_TRUEP(ARG(2))) { COPY(ARG(1), ARG(3)); COPY(ARG(2), ARG(4)); Fminusp(ARG(4)); if(CL_TRUEP(ARG(4))) { COPY(ARG(2), ARG(4)); Fminus(ARG(4), 1); } else { COPY(ARG(2), ARG(4)); } Fsvref(ARG(3)); if(CL_SYMBOLP(ARG(0))) { LOAD_SMSTR(SYM_NAME(ARG(0)), ARG(4)); } else { if(CL_TRUEP(ARG(0))) { COPY(SYMVAL(Slisp, 676), ARG(4)); /* SYM_EXPECTED */ COPY(ARG(0), ARG(5)); Ferror(ARG(4), 2); } else { LOAD_SMSTR((CL_FORM *)&KClisp[266], ARG(4)); /* NIL */ } } LOAD_FIXNUM(ARG(5), 101, ARG(5)); COPY(ARG(4), ARG(6)); string_to_simple_string(ARG(6)); rt_sxhash_string(ARG(6)); COPY(ARG(6), ARG(7)); LOAD_FIXNUM(ARG(8), 101, ARG(8)); rt_floor(ARG(7)); COPY(&mv_buf[0], ARG(8)); mv_count = 1; { COPY(ARG(8), ARG(4)); } COPY(ARG(0), ARG(5)); COPY(ARG(3), ARG(6)); set_symbol_package(ARG(5)); COPY(ARG(2), ARG(5)); Fplusp(ARG(5)); if(CL_TRUEP(ARG(5))) { COPY(ARG(3), ARG(5)); Ppackage_internal(ARG(5)); COPY(ARG(5), ARG(7)); COPY(ARG(4), ARG(8)); Fsvref(ARG(7)); ALLOC_CONS(ARG(8), ARG(0), ARG(7), ARG(6)); COPY(ARG(5), ARG(7)); COPY(ARG(4), ARG(8)); Fset_svref(ARG(6)); COPY(ARG(6), ARG(0)); } else { COPY(ARG(3), ARG(5)); Ppackage_external(ARG(5)); COPY(ARG(5), ARG(7)); COPY(ARG(4), ARG(8)); Fsvref(ARG(7)); ALLOC_CONS(ARG(8), ARG(0), ARG(7), ARG(6)); COPY(ARG(5), ARG(7)); COPY(ARG(4), ARG(8)); Fset_svref(ARG(6)); COPY(ARG(6), ARG(0)); } } else { LOAD_NIL(ARG(0)); } }
void setup_symbol(CL_FORM *base) { LOAD_NIL(STACK(base, 2)); COPY(STACK(base, 0), STACK(base, 2)); symbol_package_index(STACK(base, 2)); if(CL_TRUEP(STACK(base, 2))) { COPY(STACK(base, 1), STACK(base, 3)); COPY(STACK(base, 2), STACK(base, 4)); Fminusp(STACK(base, 4)); if(CL_TRUEP(STACK(base, 4))) { COPY(STACK(base, 2), STACK(base, 4)); Fminus(STACK(base, 4), 1); } else { COPY(STACK(base, 2), STACK(base, 4)); } vref(STACK(base, 3)); COPY(STACK(base, 0), STACK(base, 4)); Fsymbol_name(STACK(base, 4)); LOAD_FIXNUM(101, STACK(base, 5)); string_hash(STACK(base, 4)); COPY(STACK(base, 3), STACK(base, 5)); COPY(STACK(base, 0), STACK(base, 6)); set_symbol_package(STACK(base, 5)); COPY(STACK(base, 2), STACK(base, 5)); LOAD_FIXNUM(0, STACK(base, 6)); Fle(STACK(base, 5), 2); if(CL_TRUEP(STACK(base, 5))) { COPY(STACK(base, 3), STACK(base, 5)); LOAD_FIXNUM(3, STACK(base, 6)); LOAD_SYMBOL(SYMBOL(Slisp, 273), STACK(base, 7)); /* PACKAGE */ struct_ref(STACK(base, 5)); COPY(STACK(base, 5), STACK(base, 6)); COPY(STACK(base, 4), STACK(base, 7)); Fsvref(STACK(base, 6)); { CL_FORM *lptr; lptr = form_alloc(STACK(base, 7), 2); COPY(STACK(base, 0), CAR(lptr)); COPY(STACK(base, 6), CDR(lptr)); LOAD_CONS(lptr, STACK(base, 6)); } COPY(STACK(base, 6), STACK(base, 0)); COPY(STACK(base, 5), STACK(base, 1)); COPY(STACK(base, 4), STACK(base, 2)); Fset_svref(STACK(base, 0)); } else { COPY(STACK(base, 3), STACK(base, 5)); LOAD_FIXNUM(2, STACK(base, 6)); LOAD_SYMBOL(SYMBOL(Slisp, 273), STACK(base, 7)); /* PACKAGE */ struct_ref(STACK(base, 5)); COPY(STACK(base, 5), STACK(base, 6)); COPY(STACK(base, 4), STACK(base, 7)); Fsvref(STACK(base, 6)); { CL_FORM *lptr; lptr = form_alloc(STACK(base, 7), 2); COPY(STACK(base, 0), CAR(lptr)); COPY(STACK(base, 6), CDR(lptr)); LOAD_CONS(lptr, STACK(base, 6)); } COPY(STACK(base, 6), STACK(base, 0)); COPY(STACK(base, 5), STACK(base, 1)); COPY(STACK(base, 4), STACK(base, 2)); Fset_svref(STACK(base, 0)); } } else { LOAD_NIL(STACK(base, 0)); } }