--- gforth/prim 2009/04/20 19:14:46 1.241 +++ gforth/prim 2010/04/05 22:17:56 1.246 @@ -1,6 +1,6 @@ \ Gforth primitives -\ Copyright (C) 1995,1996,1997,1998,2000,2003,2004,2005,2006,2007,2008 Free Software Foundation, Inc. +\ Copyright (C) 1995,1996,1997,1998,2000,2003,2004,2005,2006,2007,2008,2009 Free Software Foundation, Inc. \ This file is part of Gforth. @@ -233,6 +233,19 @@ SET_IP(DOES_CODE1(CFA)); ""just a slot to have an encoding for the DOESJUMP, which is no longer used anyway (!! eliminate this)"" +(doabicode) ( s:... f:... -- s:... f:...) gforth-internal paren_doabicode +""run-time routine for ABI-CODE definitions"" +struct abi_code_ret_t { + Cell *sp; + double * fp; +} ret = ((struct abi_code_ret_t(*)(Cell *, double *))(PFA(CFA)))(sp, fp); +sp = ret.sp; +fp = ret.fp; +#ifdef NO_IP +INST_TAIL; +goto *next_code; +#endif /* defined(NO_IP) */ + \F [endif] \g control @@ -625,6 +638,14 @@ k ( R:w R:w1 R:w2 R:w3 R:w4 -- w R:w R:w \ digit is high-level: 0/0% +abi-call ( #a_callee s:... f:... -- s:... f:... ) gforth abi_call +struct abi_code_ret_t { + Cell *sp; + double * fp; +} ret = ((struct abi_code_ret_t(*)(Cell *, double *))(a_callee))(sp, fp); +sp = ret.sp; +fp = ret.fp; + \g strings move ( c_from c_to ucount -- ) core @@ -1836,13 +1857,15 @@ wior = IOR(ftruncate(fileno((FILE *)wfil read-file ( c_addr u1 wfileid -- u2 wior ) file read_file /* !! fread does not guarantee enough */ u2 = fread(c_addr, sizeof(Char), u1, (FILE *)wfileid); +if (u2>0) + gf_regetc((FILE *)wfileid); wior = FILEIO(u2