Make sure that ports use ISO 8859-1 coding.
authorChris Hanson <org/chris-hanson/cph>
Fri, 7 Jun 2019 06:10:07 +0000 (23:10 -0700)
committerChris Hanson <org/chris-hanson/cph>
Fri, 7 Jun 2019 06:10:07 +0000 (23:10 -0700)
src/edwin/adapters.scm [new file with mode: 0644]
src/edwin/decls.scm
src/edwin/ed-ffi.scm
src/edwin/edwin.ldr
src/edwin/edwin.pkg

diff --git a/src/edwin/adapters.scm b/src/edwin/adapters.scm
new file mode 100644 (file)
index 0000000..aca5e3e
--- /dev/null
@@ -0,0 +1,60 @@
+#| -*-Scheme-*-
+
+Copyright (C) 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, 1994,
+    1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
+    2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015, 2016,
+    2017, 2018, 2019 Massachusetts Institute of Technology
+
+This file is part of MIT/GNU Scheme.
+
+MIT/GNU Scheme 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.
+
+MIT/GNU Scheme 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 MIT/GNU Scheme; if not, write to the Free Software
+Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301,
+USA.
+
+|#
+
+;;;; Runtime-system adapters
+;;; package: (edwin adapters)
+
+;;; This file contains adapters that bridge between Edwin and the runtime
+;;; system.  These are necessary because Edwin has assumptions about the
+;;; behavior of the runtime system that are no longer valid.  Since some of
+;;; these assumptions are deeply rooted, it's easier to adapt around them rather
+;;; than rewrite Edwin.
+
+;;; The most critical assumption is that Edwin relies on an older model of
+;;; strings, in which each character is a byte, and the default coding is ISO
+;;; 8859-1, while the runtime system now supports full Unicode and uses a
+;;; default coding of UTF 8.  Most of that is taken care of by the (edwin
+;;; string) package, which contains a copy of the runtime's old string
+;;; implementation.  Other things, like file I/O, are handled here.
+
+(declare (usual-integrations))
+\f
+(define (call-with-file-adapter procedure)
+  (lambda (pathname receiver)
+    (procedure pathname
+               (lambda (port)
+                 (port/set-coding port 'iso-8859-1)
+                 (receiver port)))))
+
+
+(define edwin:call-with-append-file
+  (call-with-file-adapter call-with-append-file))
+
+(define edwin:call-with-input-file
+  (call-with-file-adapter call-with-input-file))
+
+(define edwin:call-with-output-file
+  (call-with-file-adapter call-with-output-file))
\ No newline at end of file
index f1e74de1b99c9b8ed06d0fa75dfd1de64328b97e..620a7c67a1a4c8c4ba6635cfc736cf256d4fb2f9 100644 (file)
@@ -109,6 +109,7 @@ USA.
     (for-each (lambda (filename)
                (apply sf-edwin filename includes))
              '("abbrev"
+                "adapters"
                "argred"
                "artdebug"
                "autold"
index 7aa7f8d1e4fce2aa76018ad9173a1b859dfe6f27..f4917dbc3a62de50add14bb6e399c6e585e8badb 100644 (file)
@@ -30,6 +30,7 @@ USA.
 
 (standard-scheme-find-file-initialization
  '#(("abbrev"  (edwin))
+    ("adapters"        (edwin adapters))
     ("ansi"    (edwin screen console-screen))
     ("argred"  (edwin command-argument))
     ("artdebug"        (edwin debugger))
@@ -151,6 +152,7 @@ USA.
     ("simple"  (edwin))
     ("snr"     (edwin news-reader))
     ("sort"    (edwin))
+    ("string"  (edwin string))
     ("strpad"  (edwin))
     ("strtab"  (edwin))
     ("struct"  (edwin))
index cbfe05a7cbe2b8602ebe17fdc2d59d0ffe843f0a..1c11dd4444abc10df38bbca1b1549ae6ecdfb81d 100644 (file)
@@ -81,6 +81,7 @@ USA.
 
       (let ((environment (->environment '(edwin))))
        (load "utils" environment)
+       (load "adapters" (->environment '(edwin adapters)))
        (load "string" (->environment '(edwin string)))
        (load "nvector" environment)
        (load "ring" environment)
index 01a52a7213264a24fdbcbb366170a9d91a3e560b..3c5f15166d8eb07b89f43f16716303878dba7718 100644 (file)
@@ -150,6 +150,14 @@ USA.
   (export (edwin class-macros)
          class-instance-transforms))
 
+(define-package (edwin adapters)
+  (files "adapters")
+  (parent ())
+  (export (edwin)
+          (call-with-append-file edwin:call-with-append-file)
+          (call-with-input-file edwin:call-with-input-file)
+          (call-with-output-file edwin:call-with-output-file)))
+
 (define-package (edwin string)
   (files "string")
   (parent (edwin))