home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
OS/2 Shareware BBS: 10 Tools
/
10-Tools.zip
/
mitsch75.zip
/
scheme-7_5_17-src.zip
/
scheme-7.5.17
/
src
/
runtime
/
wrkdir.scm
< prev
next >
Wrap
Text File
|
1999-01-02
|
2KB
|
68 lines
#| -*-Scheme-*-
$Id: wrkdir.scm,v 14.8 1999/01/02 06:19:10 cph Exp $
Copyright (c) 1988-1999 Massachusetts Institute of Technology
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or (at
your option) any later version.
This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|#
;;;; Working Directory
;;; package: (runtime working-directory)
(declare (usual-integrations))
(define (initialize-package!)
(reset!)
(add-event-receiver! event:after-restore reset!))
(define (reset!)
(let ((pathname
(pathname-simplify
(pathname-as-directory
((ucode-primitive working-directory-pathname))))))
(set! *working-directory-pathname* pathname)
(set! *default-pathname-defaults* pathname))
unspecific)
(define *working-directory-pathname*)
(define (working-directory-pathname)
*working-directory-pathname*)
(define (set-working-directory-pathname! name)
(let ((pathname
(pathname-as-directory
(merge-pathnames name *working-directory-pathname*))))
(if (not (file-directory? pathname))
(error "Not a valid directory:" pathname))
(let ((pathname (pathname-simplify pathname)))
(set! *working-directory-pathname* pathname)
(set! *default-pathname-defaults*
(merge-pathnames pathname *default-pathname-defaults*))
(cmdl/set-default-directory (nearest-cmdl) pathname)
pathname)))
(define (with-working-directory-pathname name thunk)
(let ((pathname
(pathname-as-directory
(merge-pathnames name *working-directory-pathname*))))
(if (not (file-directory? pathname))
(error "Not a valid directory:" pathname))
(let ((pathname (pathname-simplify pathname)))
(fluid-let ((*working-directory-pathname* pathname)
(*default-pathname-defaults*
(merge-pathnames pathname *default-pathname-defaults*)))
(thunk)))))