Annotation of gforth/savesys.fs, revision 1.1
1.1 ! anton 1: \ image dump 15nov94py
! 2:
! 3: \ Copyright (C) 1995 Free Software Foundation, Inc.
! 4:
! 5: \ This file is part of Gforth.
! 6:
! 7: \ Gforth is free software; you can redistribute it and/or
! 8: \ modify it under the terms of the GNU General Public License
! 9: \ as published by the Free Software Foundation; either version 2
! 10: \ of the License, or (at your option) any later version.
! 11:
! 12: \ This program is distributed in the hope that it will be useful,
! 13: \ but WITHOUT ANY WARRANTY; without even the implied warranty of
! 14: \ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
! 15: \ GNU General Public License for more details.
! 16:
! 17: \ You should have received a copy of the GNU General Public License
! 18: \ along with this program; if not, write to the Free Software
! 19: \ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
! 20:
! 21: : save-string-dict { addr1 u -- addr2 u }
! 22: here { addr2 }
! 23: u allot
! 24: addr1 addr2 u move
! 25: addr2 u ;
! 26:
! 27: : update-image-included-files ( -- )
! 28: included-files 2@ { addr cnt }
! 29: image-included-files 2@ { old-addr old-cnt }
! 30: align here { new-addr }
! 31: cnt 2* cells allot
! 32: new-addr cnt image-included-files 2!
! 33: old-addr new-addr old-cnt 2* cells move
! 34: cnt old-cnt
! 35: U+DO
! 36: addr i 2* cells + 2@ save-string-dict
! 37: new-addr i 2* cells + 2!
! 38: LOOP
! 39: maxalign ;
! 40:
! 41: : dump-fi ( addr u -- )
! 42: w/o bin create-file throw >r
! 43: update-image-included-files
! 44: here forthstart - forthstart 2 cells + !
! 45: forthstart
! 46: begin \ search for start of file ("#! " at a multiple of 8)
! 47: 8 -
! 48: dup 3 s" #! " compare 0=
! 49: until ( imagestart )
! 50: here over - r@ write-file throw
! 51: r> close-file throw ;
! 52:
! 53: : savesystem ( "name" -- ) \ gforth
! 54: name dump-fi ;
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>