glib: Use libtool/automake.
authorMatt Birkholz <puck@birchwood-abbey.net>
Tue, 29 Mar 2016 22:08:20 +0000 (15:08 -0700)
committerMatt Birkholz <puck@birchwood-abbey.net>
Tue, 29 Mar 2016 23:50:47 +0000 (16:50 -0700)
30 files changed:
src/glib/AUTHORS [new file with mode: 0644]
src/glib/COPYING [new file with mode: 0644]
src/glib/ChangeLog [new file with mode: 0644]
src/glib/Makefile.am [new file with mode: 0644]
src/glib/Makefile.in [deleted file]
src/glib/NEWS [new file with mode: 0644]
src/glib/README
src/glib/autogen.sh [new file with mode: 0755]
src/glib/check-doc.scm [deleted file]
src/glib/check-doc.sh [new file with mode: 0755]
src/glib/check.scm [deleted file]
src/glib/compile.scm [deleted file]
src/glib/compile.sh [new file with mode: 0755]
src/glib/configure.ac
src/glib/gio.scm
src/glib/glib-check-copy.sh [new file with mode: 0755]
src/glib/glib-check-list.sh [new file with mode: 0755]
src/glib/glib-check.scm [deleted file]
src/glib/glib-main.scm
src/glib/glib-shim.h
src/glib/glib-tests.scm
src/glib/glib-thread.scm
src/glib/glib.cdecl
src/glib/glib.pkg
src/glib/glib.scm
src/glib/glibio.c
src/glib/gobject.scm
src/glib/make.scm
src/glib/mit-scheme-glib.texi [moved from src/glib/glib.texinfo with 96% similarity]
src/glib/optiondb.scm [moved from src/glib/glib-optiondb.scm with 78% similarity]

diff --git a/src/glib/AUTHORS b/src/glib/AUTHORS
new file mode 100644 (file)
index 0000000..11c76de
--- /dev/null
@@ -0,0 +1,5 @@
+To find out what should go in this file, see "Information For
+Maintainers of GNU Software" (maintain.texi), the section called
+"Recording Changes".
+
+Matthew Birkholz       Everything up to the initial automake conversion.
diff --git a/src/glib/COPYING b/src/glib/COPYING
new file mode 100644 (file)
index 0000000..bf50f20
--- /dev/null
@@ -0,0 +1,482 @@
+                 GNU LIBRARY GENERAL PUBLIC LICENSE
+                      Version 2, June 1991
+
+ Copyright (C) 1991 Free Software Foundation, Inc.
+                   59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+[This is the first released version of the library GPL.  It is
+ numbered 2 because it goes with version 2 of the ordinary GPL.]
+
+                           Preamble
+
+  The licenses for most software are designed to take away your
+freedom to share and change it.  By contrast, the GNU General Public
+Licenses are intended to guarantee your freedom to share and change
+free software--to make sure the software is free for all its users.
+
+  This license, the Library General Public License, applies to some
+specially designated Free Software Foundation software, and to any
+other libraries whose authors decide to use it.  You can use it for
+your libraries, too.
+
+  When we speak of free software, we are referring to freedom, not
+price.  Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+this service if you wish), that you receive source code or can get it
+if you want it, that you can change the software or use pieces of it
+in new free programs; and that you know you can do these things.
+
+  To protect your rights, we need to make restrictions that forbid
+anyone to deny you these rights or to ask you to surrender the rights.
+These restrictions translate to certain responsibilities for you if
+you distribute copies of the library, or if you modify it.
+
+  For example, if you distribute copies of the library, whether gratis
+or for a fee, you must give the recipients all the rights that we gave
+you.  You must make sure that they, too, receive or can get the source
+code.  If you link a program with the library, you must provide
+complete object files to the recipients so that they can relink them
+with the library, after making changes to the library and recompiling
+it.  And you must show them these terms so they know their rights.
+
+  Our method of protecting your rights has two steps: (1) copyright
+the library, and (2) offer you this license which gives you legal
+permission to copy, distribute and/or modify the library.
+
+  Also, for each distributor's protection, we want to make certain
+that everyone understands that there is no warranty for this free
+library.  If the library is modified by someone else and passed on, we
+want its recipients to know that what they have is not the original
+version, so that any problems introduced by others will not reflect on
+the original authors' reputations.
+\f
+  Finally, any free program is threatened constantly by software
+patents.  We wish to avoid the danger that companies distributing free
+software will individually obtain patent licenses, thus in effect
+transforming the program into proprietary software.  To prevent this,
+we have made it clear that any patent must be licensed for everyone's
+free use or not licensed at all.
+
+  Most GNU software, including some libraries, is covered by the ordinary
+GNU General Public License, which was designed for utility programs.  This
+license, the GNU Library General Public License, applies to certain
+designated libraries.  This license is quite different from the ordinary
+one; be sure to read it in full, and don't assume that anything in it is
+the same as in the ordinary license.
+
+  The reason we have a separate public license for some libraries is that
+they blur the distinction we usually make between modifying or adding to a
+program and simply using it.  Linking a program with a library, without
+changing the library, is in some sense simply using the library, and is
+analogous to running a utility program or application program.  However, in
+a textual and legal sense, the linked executable is a combined work, a
+derivative of the original library, and the ordinary General Public License
+treats it as such.
+
+  Because of this blurred distinction, using the ordinary General
+Public License for libraries did not effectively promote software
+sharing, because most developers did not use the libraries.  We
+concluded that weaker conditions might promote sharing better.
+
+  However, unrestricted linking of non-free programs would deprive the
+users of those programs of all benefit from the free status of the
+libraries themselves.  This Library General Public License is intended to
+permit developers of non-free programs to use free libraries, while
+preserving your freedom as a user of such programs to change the free
+libraries that are incorporated in them.  (We have not seen how to achieve
+this as regards changes in header files, but we have achieved it as regards
+changes in the actual functions of the Library.)  The hope is that this
+will lead to faster development of free libraries.
+
+  The precise terms and conditions for copying, distribution and
+modification follow.  Pay close attention to the difference between a
+"work based on the library" and a "work that uses the library".  The
+former contains code derived from the library, while the latter only
+works together with the library.
+
+  Note that it is possible for a library to be covered by the ordinary
+General Public License rather than by this special one.
+\f
+                 GNU LIBRARY GENERAL PUBLIC LICENSE
+   TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+  0. This License Agreement applies to any software library which
+contains a notice placed by the copyright holder or other authorized
+party saying it may be distributed under the terms of this Library
+General Public License (also called "this License").  Each licensee is
+addressed as "you".
+
+  A "library" means a collection of software functions and/or data
+prepared so as to be conveniently linked with application programs
+(which use some of those functions and data) to form executables.
+
+  The "Library", below, refers to any such software library or work
+which has been distributed under these terms.  A "work based on the
+Library" means either the Library or any derivative work under
+copyright law: that is to say, a work containing the Library or a
+portion of it, either verbatim or with modifications and/or translated
+straightforwardly into another language.  (Hereinafter, translation is
+included without limitation in the term "modification".)
+
+  "Source code" for a work means the preferred form of the work for
+making modifications to it.  For a library, complete source code means
+all the source code for all modules it contains, plus any associated
+interface definition files, plus the scripts used to control compilation
+and installation of the library.
+
+  Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope.  The act of
+running a program using the Library is not restricted, and output from
+such a program is covered only if its contents constitute a work based
+on the Library (independent of the use of the Library in a tool for
+writing it).  Whether that is true depends on what the Library does
+and what the program that uses the Library does.
+  
+  1. You may copy and distribute verbatim copies of the Library's
+complete source code as you receive it, in any medium, provided that
+you conspicuously and appropriately publish on each copy an
+appropriate copyright notice and disclaimer of warranty; keep intact
+all the notices that refer to this License and to the absence of any
+warranty; and distribute a copy of this License along with the
+Library.
+
+  You may charge a fee for the physical act of transferring a copy,
+and you may at your option offer warranty protection in exchange for a
+fee.
+\f
+  2. You may modify your copy or copies of the Library or any portion
+of it, thus forming a work based on the Library, and copy and
+distribute such modifications or work under the terms of Section 1
+above, provided that you also meet all of these conditions:
+
+    a) The modified work must itself be a software library.
+
+    b) You must cause the files modified to carry prominent notices
+    stating that you changed the files and the date of any change.
+
+    c) You must cause the whole of the work to be licensed at no
+    charge to all third parties under the terms of this License.
+
+    d) If a facility in the modified Library refers to a function or a
+    table of data to be supplied by an application program that uses
+    the facility, other than as an argument passed when the facility
+    is invoked, then you must make a good faith effort to ensure that,
+    in the event an application does not supply such function or
+    table, the facility still operates, and performs whatever part of
+    its purpose remains meaningful.
+
+    (For example, a function in a library to compute square roots has
+    a purpose that is entirely well-defined independent of the
+    application.  Therefore, Subsection 2d requires that any
+    application-supplied function or table used by this function must
+    be optional: if the application does not supply it, the square
+    root function must still compute square roots.)
+
+These requirements apply to the modified work as a whole.  If
+identifiable sections of that work are not derived from the Library,
+and can be reasonably considered independent and separate works in
+themselves, then this License, and its terms, do not apply to those
+sections when you distribute them as separate works.  But when you
+distribute the same sections as part of a whole which is a work based
+on the Library, the distribution of the whole must be on the terms of
+this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote
+it.
+
+Thus, it is not the intent of this section to claim rights or contest
+your rights to work written entirely by you; rather, the intent is to
+exercise the right to control the distribution of derivative or
+collective works based on the Library.
+
+In addition, mere aggregation of another work not based on the Library
+with the Library (or with a work based on the Library) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+  3. You may opt to apply the terms of the ordinary GNU General Public
+License instead of this License to a given copy of the Library.  To do
+this, you must alter all the notices that refer to this License, so
+that they refer to the ordinary GNU General Public License, version 2,
+instead of to this License.  (If a newer version than version 2 of the
+ordinary GNU General Public License has appeared, then you can specify
+that version instead if you wish.)  Do not make any other change in
+these notices.
+\f
+  Once this change is made in a given copy, it is irreversible for
+that copy, so the ordinary GNU General Public License applies to all
+subsequent copies and derivative works made from that copy.
+
+  This option is useful when you wish to copy part of the code of
+the Library into a program that is not a library.
+
+  4. You may copy and distribute the Library (or a portion or
+derivative of it, under Section 2) in object code or executable form
+under the terms of Sections 1 and 2 above provided that you accompany
+it with the complete corresponding machine-readable source code, which
+must be distributed under the terms of Sections 1 and 2 above on a
+medium customarily used for software interchange.
+
+  If distribution of object code is made by offering access to copy
+from a designated place, then offering equivalent access to copy the
+source code from the same place satisfies the requirement to
+distribute the source code, even though third parties are not
+compelled to copy the source along with the object code.
+
+  5. A program that contains no derivative of any portion of the
+Library, but is designed to work with the Library by being compiled or
+linked with it, is called a "work that uses the Library".  Such a
+work, in isolation, is not a derivative work of the Library, and
+therefore falls outside the scope of this License.
+
+  However, linking a "work that uses the Library" with the Library
+creates an executable that is a derivative of the Library (because it
+contains portions of the Library), rather than a "work that uses the
+library".  The executable is therefore covered by this License.
+Section 6 states terms for distribution of such executables.
+
+  When a "work that uses the Library" uses material from a header file
+that is part of the Library, the object code for the work may be a
+derivative work of the Library even though the source code is not.
+Whether this is true is especially significant if the work can be
+linked without the Library, or if the work is itself a library.  The
+threshold for this to be true is not precisely defined by law.
+
+  If such an object file uses only numerical parameters, data
+structure layouts and accessors, and small macros and small inline
+functions (ten lines or less in length), then the use of the object
+file is unrestricted, regardless of whether it is legally a derivative
+work.  (Executables containing this object code plus portions of the
+Library will still fall under Section 6.)
+
+  Otherwise, if the work is a derivative of the Library, you may
+distribute the object code for the work under the terms of Section 6.
+Any executables containing that work also fall under Section 6,
+whether or not they are linked directly with the Library itself.
+\f
+  6. As an exception to the Sections above, you may also compile or
+link a "work that uses the Library" with the Library to produce a
+work containing portions of the Library, and distribute that work
+under terms of your choice, provided that the terms permit
+modification of the work for the customer's own use and reverse
+engineering for debugging such modifications.
+
+  You must give prominent notice with each copy of the work that the
+Library is used in it and that the Library and its use are covered by
+this License.  You must supply a copy of this License.  If the work
+during execution displays copyright notices, you must include the
+copyright notice for the Library among them, as well as a reference
+directing the user to the copy of this License.  Also, you must do one
+of these things:
+
+    a) Accompany the work with the complete corresponding
+    machine-readable source code for the Library including whatever
+    changes were used in the work (which must be distributed under
+    Sections 1 and 2 above); and, if the work is an executable linked
+    with the Library, with the complete machine-readable "work that
+    uses the Library", as object code and/or source code, so that the
+    user can modify the Library and then relink to produce a modified
+    executable containing the modified Library.  (It is understood
+    that the user who changes the contents of definitions files in the
+    Library will not necessarily be able to recompile the application
+    to use the modified definitions.)
+
+    b) Accompany the work with a written offer, valid for at
+    least three years, to give the same user the materials
+    specified in Subsection 6a, above, for a charge no more
+    than the cost of performing this distribution.
+
+    c) If distribution of the work is made by offering access to copy
+    from a designated place, offer equivalent access to copy the above
+    specified materials from the same place.
+
+    d) Verify that the user has already received a copy of these
+    materials or that you have already sent this user a copy.
+
+  For an executable, the required form of the "work that uses the
+Library" must include any data and utility programs needed for
+reproducing the executable from it.  However, as a special exception,
+the source code distributed need not include anything that is normally
+distributed (in either source or binary form) with the major
+components (compiler, kernel, and so on) of the operating system on
+which the executable runs, unless that component itself accompanies
+the executable.
+
+  It may happen that this requirement contradicts the license
+restrictions of other proprietary libraries that do not normally
+accompany the operating system.  Such a contradiction means you cannot
+use both them and the Library together in an executable that you
+distribute.
+\f
+  7. You may place library facilities that are a work based on the
+Library side-by-side in a single library together with other library
+facilities not covered by this License, and distribute such a combined
+library, provided that the separate distribution of the work based on
+the Library and of the other library facilities is otherwise
+permitted, and provided that you do these two things:
+
+    a) Accompany the combined library with a copy of the same work
+    based on the Library, uncombined with any other library
+    facilities.  This must be distributed under the terms of the
+    Sections above.
+
+    b) Give prominent notice with the combined library of the fact
+    that part of it is a work based on the Library, and explaining
+    where to find the accompanying uncombined form of the same work.
+
+  8. You may not copy, modify, sublicense, link with, or distribute
+the Library except as expressly provided under this License.  Any
+attempt otherwise to copy, modify, sublicense, link with, or
+distribute the Library is void, and will automatically terminate your
+rights under this License.  However, parties who have received copies,
+or rights, from you under this License will not have their licenses
+terminated so long as such parties remain in full compliance.
+
+  9. You are not required to accept this License, since you have not
+signed it.  However, nothing else grants you permission to modify or
+distribute the Library or its derivative works.  These actions are
+prohibited by law if you do not accept this License.  Therefore, by
+modifying or distributing the Library (or any work based on the
+Library), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Library or works based on it.
+
+  10. Each time you redistribute the Library (or any work based on the
+Library), the recipient automatically receives a license from the
+original licensor to copy, distribute, link with or modify the Library
+subject to these terms and conditions.  You may not impose any further
+restrictions on the recipients' exercise of the rights granted herein.
+You are not responsible for enforcing compliance by third parties to
+this License.
+\f
+  11. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues),
+conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License.  If you cannot
+distribute so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you
+may not distribute the Library at all.  For example, if a patent
+license would not permit royalty-free redistribution of the Library by
+all those who receive copies directly or indirectly through you, then
+the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Library.
+
+If any portion of this section is held invalid or unenforceable under any
+particular circumstance, the balance of the section is intended to apply,
+and the section as a whole is intended to apply in other circumstances.
+
+It is not the purpose of this section to induce you to infringe any
+patents or other property right claims or to contest validity of any
+such claims; this section has the sole purpose of protecting the
+integrity of the free software distribution system which is
+implemented by public license practices.  Many people have made
+generous contributions to the wide range of software distributed
+through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing
+to distribute software through any other system and a licensee cannot
+impose that choice.
+
+This section is intended to make thoroughly clear what is believed to
+be a consequence of the rest of this License.
+
+  12. If the distribution and/or use of the Library is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Library under this License may add
+an explicit geographical distribution limitation excluding those countries,
+so that distribution is permitted only in or among countries not thus
+excluded.  In such case, this License incorporates the limitation as if
+written in the body of this License.
+
+  13. The Free Software Foundation may publish revised and/or new
+versions of the Library General Public License from time to time.
+Such new versions will be similar in spirit to the present version,
+but may differ in detail to address new problems or concerns.
+
+Each version is given a distinguishing version number.  If the Library
+specifies a version number of this License which applies to it and
+"any later version", you have the option of following the terms and
+conditions either of that version or of any later version published by
+the Free Software Foundation.  If the Library does not specify a
+license version number, you may choose any version ever published by
+the Free Software Foundation.
+\f
+  14. If you wish to incorporate parts of the Library into other free
+programs whose distribution conditions are incompatible with these,
+write to the author to ask for permission.  For software which is
+copyrighted by the Free Software Foundation, write to the Free
+Software Foundation; we sometimes make exceptions for this.  Our
+decision will be guided by the two goals of preserving the free status
+of all derivatives of our free software and of promoting the sharing
+and reuse of software generally.
+
+                           NO WARRANTY
+
+  15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
+WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
+EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
+OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY
+KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE
+IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+PURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
+LIBRARY IS WITH YOU.  SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME
+THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
+
+  16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN
+WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY
+AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU
+FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR
+CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE
+LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
+RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
+FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
+SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
+DAMAGES.
+
+                    END OF TERMS AND CONDITIONS
+\f
+           How to Apply These Terms to Your New Libraries
+
+  If you develop a new library, and you want it to be of the greatest
+possible use to the public, we recommend making it free software that
+everyone can redistribute and change.  You can do so by permitting
+redistribution under these terms (or, alternatively, under the terms of the
+ordinary General Public License).
+
+  To apply these terms, attach the following notices to the library.  It is
+safest to attach them to the start of each source file to most effectively
+convey the exclusion of warranty; and each file should have at least the
+"copyright" line and a pointer to where the full notice is found.
+
+    <one line to give the library's name and a brief idea of what it does.>
+    Copyright (C) <year>  <name of author>
+
+    This library is free software; you can redistribute it and/or
+    modify it under the terms of the GNU Library General Public
+    License as published by the Free Software Foundation; either
+    version 2 of the License, or (at your option) any later version.
+
+    This library 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
+    Library General Public License for more details.
+
+    You should have received a copy of the GNU Library General Public
+    License along with this library; if not, write to the 
+    Free Software Foundation, Inc., 59 Temple Place - Suite 330, 
+    Boston, MA  02111-1307  USA.
+
+Also add information on how to contact you by electronic and paper mail.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the library, if
+necessary.  Here is a sample; alter the names:
+
+  Yoyodyne, Inc., hereby disclaims all copyright interest in the
+  library `Frob' (a library for tweaking knobs) written by James Random Hacker.
+
+  <signature of Ty Coon>, 1 April 1990
+  Ty Coon, President of Vice
+
+That's all there is to it!
diff --git a/src/glib/ChangeLog b/src/glib/ChangeLog
new file mode 100644 (file)
index 0000000..a235a98
--- /dev/null
@@ -0,0 +1,8 @@
+-*-Text-*-
+
+Please see the git commit log:
+
+$ git clone git://git.savannah.gnu.org/mit-scheme.git
+$ git remote add puck git://birchwood-abbey.net/~matt/mit-scheme.git
+$ git fetch puck Gtk
+$ git log puck/Gtk -- src/glib/ | more
diff --git a/src/glib/Makefile.am b/src/glib/Makefile.am
new file mode 100644 (file)
index 0000000..5076095
--- /dev/null
@@ -0,0 +1,125 @@
+## Process this file with automake to produce Makefile.in
+##
+## Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+##     2016 Matthew Birkholz
+##
+## This file is part of a glib plugin for MIT/GNU Scheme.
+##
+## This plugin 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 plugin 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 plugin; if not, write to the Free Software
+## Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+## 02110-1301, USA.
+
+ACLOCAL_AMFLAGS = -I m4
+EXTRA_DIST = autogen.sh
+
+MIT_SCHEME_EXE = @MIT_SCHEME_EXE@
+scmlibdir = $(libdir)/mit-scheme-@MIT_SCHEME_ARCH@
+scmlib_glibdir = $(scmlibdir)/glib
+
+scmlib_LTLIBRARIES = glib-shim.la
+scmlib_DATA = glib-types.bin glib-const.bin
+
+scmlib_glib_DATA = gio.scm gio.bin gio.bci gio.com
+scmlib_glib_DATA += glib-main.scm glib-main.bin glib-main.bci glib-main.com
+scmlib_glib_DATA += glib-thread.scm glib-thread.bin glib-thread.bci glib-thread.com
+scmlib_glib_DATA += glib.scm glib.bin glib.bci glib.com
+scmlib_glib_DATA += gobject.scm gobject.bin gobject.bci gobject.com
+scmlib_glib_DATA += make.scm glib-@MIT_SCHEME_OS_SUFFIX@.pkd
+
+info_TEXINFOS = mit-scheme-glib.texi
+AM_MAKEINFOHTMLFLAGS = --no-split
+
+# Set these to the defaults used by Scheme.
+infodir = $(datarootdir)/info
+htmldir = $(libdir)/mit-scheme/doc
+dvidir = $(libdir)/mit-scheme/doc
+pdfdir = $(libdir)/mit-scheme/doc
+
+AM_CPPFLAGS = -I$(scmlibdir)
+AM_CFLAGS = `pkg-config --cflags gio-2.0`
+LIBS = `pkg-config --libs glib-2.0 gthread-2.0 gio-2.0`
+
+glib_shim_la_LIBADD = glibio.lo
+glib_shim_la_LDFLAGS = -module -avoid-version -shared
+
+noinst_PROGRAMS = glib-const
+glib_const_SOURCES = glib-const.c glib-shim.h
+
+glib-shim.c: stamp-shim
+glib-const.c: stamp-shim
+glib-types.bin: stamp-shim
+stamp-shim: glib.cdecl glib-shim.h Includes/*.cdecl Includes/*/*.cdecl
+       touch stamp-shim
+       echo '(generate-shim "glib" "#include \"glib-shim.h\"")' \
+       | $(MIT_SCHEME_EXE) --batch-mode \
+       || rm stamp-shim
+
+glib-const.bin: glib-const.scm
+       echo '(sf "glib-const")' | $(MIT_SCHEME_EXE) --batch-mode
+
+glib-const.scm: glib-const
+       ./glib-const
+
+gio.bin: stamp-scheme
+gio.bci: stamp-scheme
+gio.com: stamp-scheme
+glib-main.bin: stamp-scheme
+glib-main.bci: stamp-scheme
+glib-main.com: stamp-scheme
+glib-thread.bin: stamp-scheme
+glib-thread.bci: stamp-scheme
+glib-thread.com: stamp-scheme
+glib.bin: stamp-scheme
+glib.bci: stamp-scheme
+glib.com: stamp-scheme
+gobject.bin: stamp-scheme
+gobject.bci: stamp-scheme
+gobject.com: stamp-scheme
+glib-@MIT_SCHEME_OS_SUFFIX@.pkd: stamp-scheme
+stamp-scheme: stamp-shim gio.scm glib-main.scm glib-thread.scm glib.scm
+       touch stamp-scheme
+       ./compile.sh || rm stamp-scheme
+
+CLEANFILES = glib-const* glib-shim.c
+CLEANFILES += *.bin *.ext *.com *.bci *.moc *.fni *.crf *.fre *.pkd
+
+TESTS = glib-check-copy.sh glib-check-list.sh
+CLEANFILES += test-copy-1.txt
+
+check-local:
+       ./check-doc.sh
+
+ETAGS_FILES = glibio.c
+ETAGS_FILES += glib.scm gobject.scm glib-main.scm glib-thread.scm
+ETAGS_FILES += gio.scm glib-tests.scm
+ETAGS_CDECLS = glib.cdecl Includes/*.cdecl Includes/*/*.cdecl
+ETAGS_ARGS = $(ETAGS_FILES) -r '/^([^iI].*/' $(ETAGS_CDECLS)
+TAGS_DEPENDENCIES = $(ETAGS_FILES) $(ETAGS_CDECLS)
+
+install-data-hook:
+       echo '(update-optiondb "$(DESTDIR)$(scmlibdir)/")' \
+       | $(MIT_SCHEME_EXE) --batch-mode
+
+install-html: install-html-am
+       echo '(update-html-index "$(DESTDIR)$(htmldir)/")' \
+       | $(MIT_SCHEME_EXE) --batch-mode
+
+uninstall-hook:
+       echo '(update-optiondb "$(DESTDIR)$(scmlibdir)/")' \
+       | $(MIT_SCHEME_EXE) --batch-mode
+       [ -d "$(DESTDIR)$(scmlib_glibdir)" ] \
+       && rmdir "$(DESTDIR)$(scmlib_glibdir)"
+       [ -d "$(DESTDIR)$(htmldir)" ]                                   \
+       && ( echo  '(update-html-index "$(DESTDIR)$(htmldir)/")'        \
+            | $(MIT_SCHEME_EXE) --batch-mode )
diff --git a/src/glib/Makefile.in b/src/glib/Makefile.in
deleted file mode 100644 (file)
index 689da83..0000000
+++ /dev/null
@@ -1,116 +0,0 @@
-# Copyright (C) 2014 Matthew Birkholz
-#
-# This file is part of an extension to 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.
-
-MIT_SCHEME_EXE = mit-scheme
-exe = '$(MIT_SCHEME_EXE)' --batch-mode
-
-CFLAGS = @CFLAGS@
-CPPFLAGS = @CPPFLAGS@
-LDFLAGS = @LDFLAGS@
-LIBS = @LIBS@
-
-prefix = @prefix@
-datarootdir = @datarootdir@
-infodir = @infodir@
-
-all: glib-shim.so glib-types.bin glib-const.bin
-       echo '(load "compile")' | $(exe)
-       @if [ -s glib-unx.crf ]; then \
-            echo "glib-unx.crf:0: warning: non-empty"; exit 1; fi
-
-check:
-       ( echo '(begin'; \
-         echo '  (load "check")'; \
-         echo '  (load "check-doc"))' ) | $(exe)
-
-doc: mit-scheme-glib.info
-doc: mit-scheme-glib.html
-
-mit-scheme-glib.info: glib.texinfo
-       makeinfo --no-split --output=$@ $^
-
-mit-scheme-glib.html: glib.texinfo
-       makeinfo --html --no-split --output=$@ $^
-
-.PHONY: all check doc
-
-install:
-       ( echo '(begin'; \
-         echo '  (install-shim "$(DESTDIR)" "glib")'; \
-         echo '  (install-load-option "$(DESTDIR)" "glib"))' ) \
-       | $(exe) -- *.com *.bci *.pkd make.scm
-
-install-info: mit-scheme-glib.info
-       install $< $(DESTDIR)$(infodir)/
-       install-info $< $(DESTDIR)$(infodir)/dir
-
-install-html: mit-scheme-glib.html
-       echo "(install-html \"$(DESTDIR)\" \"GNOME interface\")" | $(exe) -- $<
-
-.PHONY: install install-info install-html
-
-clean:
-       rm -f glib-const.scm glib-const glib-const.c glib-shim.c
-       rm -f glib-*.crf glib-*.fre glib-*.pkd
-       rm -f *.o *.so *.bin *.ext *.com *.bci *.moc *.fni
-       rm -f mit-scheme-glib.html mit-scheme-glib.info
-
-distclean: clean
-       rm -f Makefile config.log config.status
-
-maintainer-clean: distclean
-       rm -f configure TAGS
-       rm -rf autom4te.cache
-
-tags:
-       etags *.h \
-           `echo *.c   | sed 's/ glib-const.c//; s/ glib-shim.c//'` \
-           `echo *.scm | sed 's/ glib-const.scm//'` \
-           -r '/^([^iI].*/' Includes/*.cdecl
-       ( echo "\f\n../sos/TAGS,include" \
-         echo "\f\n../TAGS,include") >>TAGS
-
-.PHONY: clean distclean maintainer-clean tags
-
-glib-shim.so: glib-shim.o glibio.o
-       echo "(link-shim)" | $(exe) -- $(LDFLAGS) -o $@ $^ $(LIBS) \
-                       `pkg-config --libs glib-2.0 gthread-2.0 gio-2.0`
-
-glibio.o: glibio.c
-       echo "(compile-shim)" | $(exe) -- `pkg-config --cflags gio-2.0` -c $<
-
-glib-shim.o: glib-shim.c glib-shim.h
-       echo "(compile-shim)" | $(exe) -- $(CPPFLAGS) $(CFLAGS) \
-                                       `pkg-config --cflags gio-2.0` -c $<
-
-glib-shim.c glib-const.c glib-types.bin: glib-shim.h glib.cdecl \
-                                       Includes/*.cdecl Includes/*/*.cdecl
-       echo '(generate-shim "glib" "#include \"glib-shim.h\"")' | $(exe)
-
-glib-const.bin: glib-const.scm
-       echo '(sf "glib-const")' | $(exe)
-
-glib-const.scm: glib-const
-       ./glib-const
-
-glib-const: glib-const.o
-       $(CC) $(LDFLAGS) -o $@ $^ $(LIBS)
-
-glib-const.o: glib-const.c glib-shim.h
-       $(CC) $(CPPFLAGS) $(CFLAGS) `pkg-config --cflags gio-2.0` -c $<
diff --git a/src/glib/NEWS b/src/glib/NEWS
new file mode 100644 (file)
index 0000000..7727644
--- /dev/null
@@ -0,0 +1,26 @@
+mit-scheme-glib NEWS -- history of user-visible changes.
+
+Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+    2016 Matthew Birkholz
+
+This file is part of a glib plugin for MIT/GNU Scheme.
+
+This plugin 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 plugin 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 plugin; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
+
+mit-scheme-glib 0.5 - Matt Birkholz, 2016-03-13
+===============================================
+
+* Use libtool and automake, rather than the microcode's disappearing
+  module support.
index ccab0e0ef86eb1a6a32462c968af0cdf9a928841..af35495240dc6b1e93f7ea39adf164ab93e1b901 100644 (file)
@@ -1,14 +1,20 @@
+-*-Text-*-
+
 The GLib GNOME utility library plugin.
 
-To build:
+To build and install:
 
-    ./configure...
+    ./configure
     make all check
-    make install install-info install-html
+    make install install-html
+
+To use:
+
+    (load-option 'GLIB)
+    (open-input-gfile "https://savannah.gnu.org/projects/mit-scheme")
+
+To import into a CREF package set (.pkg file):
 
-The install target copies a shared library shim and compiled Scheme
-files into the system library path, and re-writes the optiondb.scm
-found there.  You can override the default command name "mit-scheme"
-(and thus the system library path) by setting MIT_SCHEME_EXE.
+    (global-definitions glib/)
 
 For more information see the accompanying user / reference manual.
diff --git a/src/glib/autogen.sh b/src/glib/autogen.sh
new file mode 100755 (executable)
index 0000000..8af4031
--- /dev/null
@@ -0,0 +1,6 @@
+#!/bin/sh
+
+set -e
+rm -rf m4
+mkdir m4
+autoreconf --force --install -I m4
diff --git a/src/glib/check-doc.scm b/src/glib/check-doc.scm
deleted file mode 100644 (file)
index 1d85495..0000000
+++ /dev/null
@@ -1,113 +0,0 @@
-#| -*-Scheme-*-
-
-   Check that every binding in (glib) or exported to () has a
-   corresponding @deffn in glib.texinfo. |#
-
-(load-option 'cref)
-(define read-package-model)
-(define pmodel/packages)
-(define package/name)
-(define package/bindings)
-(define package/links)
-(define link/source)
-(define link/destination)
-(define binding/package)
-(define binding/name)
-(let ((cref (->environment '(cross-reference))))
-  (set! read-package-model (access read-package-model cref))
-  (set! pmodel/packages (access pmodel/packages cref))
-  (set! package/name (access package/name cref))
-  (set! package/bindings (access package/bindings cref))
-  (set! package/links (access package/links cref))
-  (set! link/source (access link/source cref))
-  (set! link/destination (access link/destination cref))
-  (set! binding/package (access binding/package cref))
-  (set! binding/name (access binding/name cref)))
-
-(define (deffn-name line)
-  (let ((regs (re-string-match
-              (string-append "@deffnx?"
-                             " \\(Class\\|Procedure\\|{Generic Procedure}\\)"
-                             " \\([-A-Za-z0-9<>?!+./:]+\\)")
-              line)))
-    (if regs
-       (intern (re-match-extract line regs 2))
-       (error "Could not find binding name:" line))))
-
-(define (texinfo-deffns lines)
-  (let ((len (vector-length lines)))
-    (let loop ((i 0) (deffns '()))
-      (if (fix:< i len)
-         (let ((line (vector-ref lines i)))
-           (loop (fix:1+ i)
-                 (if (string-prefix? "@deffn" line)
-                     (cons (deffn-name line) deffns)
-                     deffns)))
-         deffns))))
-
-(define (read-lines port)
-  (let loop ()
-    (let ((line (read-line port)))
-      (if (eof-object? line)
-         '()
-         (cons line (loop))))))
-
-(define (pmodel/find-package pmodel package-name)
-  (find-matching-item (pmodel/packages pmodel)
-                     (lambda (p) (equal? package-name (package/name p)))))
-
-(define (pmodel/global-exports pmodel)
-  (define (global-exports package)
-    (append-map! (lambda (link)
-                  (if (eq? '() (package/name
-                                (binding/package
-                                 (link/destination link))))
-                      (list (binding/name (link/destination link)))
-                      '()))
-                (package/links package)))
-  (append-map! global-exports (pmodel/packages pmodel)))
-
-(define (pmodel/package-bindings pmodel package-name)
-  (let ((package (pmodel/find-package pmodel package-name)))
-    (if package
-       (map binding/name (package/bindings package))
-       (error "No such package:" package-name))))
-
-(define (duplicates listset)
-  (let loop ((items listset) (duplicates '()))
-    (cond ((null? items)
-          (reverse! duplicates))
-         ((memq (car items) (cdr items))
-          (if (memq (car items) duplicates)
-              (loop (cdr items) duplicates)
-              (loop (cdr items) (cons (car items) duplicates))))
-         (else
-          (loop (cdr items) duplicates)))))
-
-(define (minus set1 set2)
-  (let loop ((items set1) (difference '()))
-    (cond ((null? items)
-          difference)
-         ((memq (car items) set2)
-          (loop (cdr items) difference))
-         (else
-          (loop (cdr items) (cons (car items) difference))))))
-
-(define (check)
-  (let* ((texinfo (list->vector (call-with-input-file "glib.texinfo"
-                                 read-lines)))
-        (deffns (texinfo-deffns texinfo))
-        (dups (duplicates deffns))
-        (pmodel (read-package-model "glib" microcode-id/operating-system))
-        (bindings (append (pmodel/global-exports pmodel)
-                          (pmodel/package-bindings pmodel '(glib))))
-        (missing (minus bindings deffns))
-        (extras (minus deffns bindings)))
-    (if (not (null? dups))
-       (for-each (lambda (name) (warn "multiple-descriptions:" name)) dups))
-    (if (not (null? extras))
-       (for-each (lambda (name) (warn "not bound:" name)) extras))
-    (if (not (null? missing))
-       (for-each (lambda (name) (warn "not documented:" name)) missing))))
-
-(check)
\ No newline at end of file
diff --git a/src/glib/check-doc.sh b/src/glib/check-doc.sh
new file mode 100755 (executable)
index 0000000..d0303b9
--- /dev/null
@@ -0,0 +1,147 @@
+#!/bin/bash
+# -*-Scheme-*-
+#
+# Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+#     2016 Matthew Birkholz
+#
+# This file is part of a glib plugin for MIT/GNU Scheme.
+#
+# This plugin 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 plugin 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 plugin; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301, USA.
+
+# Check the documentation.
+
+set -e
+: ${MIT_SCHEME_EXE=mit-scheme}
+${MIT_SCHEME_EXE} --batch-mode <<\EOF
+
+(let ((pkgset "glib")
+      (texi "mit-scheme-glib.texi")
+      (pkg '(glib)))
+  ;; Check that every binding exported to () or PKG has a
+  ;; corresponding @deffn in TEXI.
+
+  (parameterize ((param:suppress-loading-message? #t))
+    (load-option 'CREF))
+  (define read-package-model)
+  (define pmodel/packages)
+  (define package/name)
+  (define package/bindings)
+  (define package/links)
+  (define link/source)
+  (define link/destination)
+  (define binding/package)
+  (define binding/name)
+  (let ((cref (->environment '(cross-reference))))
+    (set! read-package-model (access read-package-model cref))
+    (set! pmodel/packages (access pmodel/packages cref))
+    (set! package/name (access package/name cref))
+    (set! package/bindings (access package/bindings cref))
+    (set! package/links (access package/links cref))
+    (set! link/source (access link/source cref))
+    (set! link/destination (access link/destination cref))
+    (set! binding/package (access binding/package cref))
+    (set! binding/name (access binding/name cref)))
+
+  (define (deffn-name line)
+    (let ((regs (re-string-match
+                (string-append "@deffnx?"
+                               " \\(Class\\|Procedure\\|{Generic Procedure}\\)"
+                               " \\([-A-Za-z0-9<>?!+./:]+\\)")
+                line)))
+      (if regs
+         (intern (re-match-extract line regs 2))
+         (error "Could not find binding name:" line))))
+
+  (define (texinfo-deffns lines)
+    (let ((len (vector-length lines)))
+      (let loop ((i 0) (deffns '()))
+       (if (fix:< i len)
+           (let ((line (vector-ref lines i)))
+             (loop (fix:1+ i)
+                   (if (string-prefix? "@deffn" line)
+                       (cons (deffn-name line) deffns)
+                       deffns)))
+           deffns))))
+
+  (define (read-lines port)
+    (let loop ()
+      (let ((line (read-line port)))
+       (if (eof-object? line)
+           '()
+           (cons line (loop))))))
+
+  (define (pmodel/find-package pmodel package-name)
+    (find-matching-item (pmodel/packages pmodel)
+                       (lambda (p) (equal? package-name (package/name p)))))
+
+  (define (pmodel/global-exports pmodel)
+    (define (global-exports package)
+      (append-map! (lambda (link)
+                    (if (eq? '() (package/name
+                                  (binding/package
+                                   (link/destination link))))
+                        (list (binding/name (link/destination link)))
+                        '()))
+                  (package/links package)))
+    (append-map! global-exports (pmodel/packages pmodel)))
+
+  (define (pmodel/package-bindings pmodel package-name)
+    (let ((package (pmodel/find-package pmodel package-name)))
+      (if package
+         (map binding/name (package/bindings package))
+         (error "No such package:" package-name))))
+
+  (define (duplicates listset)
+    (let loop ((items listset) (duplicates '()))
+      (cond ((null? items)
+            (reverse! duplicates))
+           ((memq (car items) (cdr items))
+            (if (memq (car items) duplicates)
+                (loop (cdr items) duplicates)
+                (loop (cdr items) (cons (car items) duplicates))))
+           (else
+            (loop (cdr items) duplicates)))))
+
+  (define (minus set1 set2)
+    (let loop ((items set1) (difference '()))
+      (cond ((null? items)
+            difference)
+           ((memq (car items) set2)
+            (loop (cdr items) difference))
+           (else
+            (loop (cdr items) (cons (car items) difference))))))
+
+  (define (check)
+    (let* ((texinfo (list->vector (call-with-input-file texi read-lines)))
+          (deffns (texinfo-deffns texinfo))
+          (dups (duplicates deffns))
+          (pmodel (read-package-model pkgset microcode-id/operating-system))
+          (bindings (append (pmodel/global-exports pmodel)
+                            (if (null? pkg)
+                                '()
+                                (pmodel/package-bindings pmodel pkg))))
+          (missing (minus bindings deffns))
+          (extras (minus deffns bindings)))
+      (if (not (null? dups))
+         (for-each (lambda (name) (warn "multiple-descriptions:" name)) dups))
+      (if (not (null? extras))
+         (for-each (lambda (name) (warn "not bound:" name)) extras))
+      (if (not (null? missing))
+         (for-each (lambda (name) (warn "not documented:" name)) missing))))
+
+  (check)
+  )
+EOF
diff --git a/src/glib/check.scm b/src/glib/check.scm
deleted file mode 100644 (file)
index 60c38ff..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-#| -*-Scheme-*- |#
-
-;;;; Test the glib wrapper.
-
-(let ((dirname (directory-pathname (current-load-pathname)))
-      (param (access library-directory-path
-                    (->environment '(runtime pathname)))))
-  (parameterize ((param (cons dirname (param))))
-    (set! *initial-options-file* (merge-pathnames "glib-optiondb" dirname))
-    (load-option 'GLIB)))
-
-(load "glib-check" (->environment '(GLIB)))
\ No newline at end of file
diff --git a/src/glib/compile.scm b/src/glib/compile.scm
deleted file mode 100644 (file)
index e63aef3..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-#| -*-Scheme-*-
-
-Copyright (C) 2014  Matthew Birkholz
-
-This file is part of an extension to 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.
-
-|#
-
-;;;; Compile the GLIB wrapper.
-
-(load-option 'CREF)
-(load-option 'SOS)
-(load-option 'FFI)
-(with-working-directory-pathname (directory-pathname (current-load-pathname))
-  (lambda ()
-    (with-system-library-directories
-       '("./")
-      (lambda ()
-       (if (name->package '(GLIB))
-           (error "The GLIB package already exists.")
-           (let ((package-set (package-set-pathname "glib")))
-             (if (not (file-modification-time<? "glib.pkg" package-set))
-                 (cref/generate-trivial-constructor "glib"))
-             (construct-packages-from-file (fasload package-set))))
-
-       ;; glib.scm includes the Glib c-includes, but does not otherwise
-       ;; use the FFI.
-       (compile-file "glib" '("glib-const.bin") (->environment '(glib)))
-       ;; Mostly to set! c-includes:
-       (load "glib" (->environment '(glib)))
-
-       ;; The wrappers use the FFI, c-includes, and some integrable
-       ;; definitions in glib.scm.  Dependencies between them are
-       ;; rare.
-       (compile-file "gobject" '("glib") (->environment '(gobject)))
-       (compile-file "gio" '("glib") (->environment '(gio)))
-       (compile-file "glib-main" '("glib") (->environment '(glib main)))
-       (compile-file "glib-thread" '("glib-main")
-                     (->environment '(glib thread)))
-
-       (cref/generate-constructors "glib" 'ALL)))))
\ No newline at end of file
diff --git a/src/glib/compile.sh b/src/glib/compile.sh
new file mode 100755 (executable)
index 0000000..1441f6d
--- /dev/null
@@ -0,0 +1,64 @@
+#!/bin/sh
+# -*-Scheme-*-
+#
+# Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+#     2016 Matthew Birkholz
+#
+# This file is part of a glib plugin for MIT/GNU Scheme.
+#
+# This plugin 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 plugin 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 plugin; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301, USA.
+
+# Compile the GLIB option.
+
+set -e
+: ${MIT_SCHEME_EXE=mit-scheme}
+${MIT_SCHEME_EXE} --prepend-library . --batch-mode <<\EOF
+(begin
+
+  (parameterize ((param:suppress-loading-message? #t))
+    (load-option 'CREF)
+    (load-option 'SOS)
+    (load-option 'FFI))
+
+  (if (name->package '(GLIB))
+      (error "The GLIB package already exists."))
+  (let ((package-set (package-set-pathname "glib")))
+    (if (not (file-modification-time<? "glib.pkg" package-set))
+       (cref/generate-trivial-constructor "glib" #f))
+    (construct-packages-from-file (fasload package-set)))
+
+  ;; glib.scm includes the Glib c-includes, but does not otherwise
+  ;; use the FFI.
+  (compile-file "glib" '("glib-const.bin") (->environment '(glib)))
+  ;; Mostly to set! c-includes:
+  (load "glib" (->environment '(glib)))
+
+  ;; The wrappers use the FFI, c-includes, and some integrable
+  ;; definitions in glib.scm.  Dependencies between them are
+  ;; rare.
+  (compile-file "gobject" '("glib") (->environment '(gobject)))
+  (compile-file "gio" '("glib") (->environment '(gio)))
+  (compile-file "glib-main" '("glib") (->environment '(glib main)))
+  (compile-file "glib-thread" '("glib-main")
+               (->environment '(glib thread)))
+
+  (cref/generate-constructors "glib")
+  )
+EOF
+SUFFIX=`echo "(display (microcode-id/operating-system-suffix))" \
+       | ${MIT_SCHEME_EXE} --batch-mode`
+REPORT=glib-$SUFFIX.crf
+if [ -s "$REPORT" ]; then echo "$REPORT:1: error: not empty"; exit 1; fi
index 8c97b3f86e37a90736fadd940f5dbe3e9bc0bbb0..8671e2895672dc54f0867ce90f06fc22337cc776 100644 (file)
@@ -1,64 +1,82 @@
 dnl Process this file with autoconf to produce a configure script.
 
-AC_INIT([MIT/GNU Scheme glib interface],
-        [0.1],
-        [bug-mit-scheme@gnu.org],
+AC_PREREQ([2.69])
+AC_INIT([MIT/GNU Scheme glib plugin],
+        [0.5],
+        [puck@birchwood-abbey.net],
         [mit-scheme-glib])
 AC_CONFIG_SRCDIR([glib.pkg])
+AC_CONFIG_MACRO_DIR([m4])
 
 AC_COPYRIGHT(
-[Copyright (C) 2014  Matthew Birkholz
+[Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+    2016 Matthew Birkholz
 
-This file is part of an extension to MIT/GNU Scheme.
+This file is part of a glib plugin for 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.
+This plugin 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
+This plugin 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.
+along with this plugin; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 ])
 
 AH_TOP([/*
 
-Copyright (C) 2014 Matthew Birkholz
+Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+    2016 Matthew Birkholz
 
-This file is part of MIT/GNU Scheme.
+This file is part of a glib plugin for 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.
+This plugin 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
+This plugin 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.
+along with this plugin; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 
 */])
 
+AM_INIT_AUTOMAKE
+
+AC_PROG_LIBTOOL
+AC_PROG_CC
+AC_PROG_CPP
+AC_PROG_INSTALL
+
+dnl Initialize libtool
+LT_PREREQ([2.2.6])
+LT_INIT([dlopen win32-dll])
+
 AC_CHECK_PROG([PKG_CONFIG], [pkg-config], [yes])
 
 if ! pkg-config --exists glib-2.0 2>/dev/null; then
     AC_MSG_ERROR([GLib 2.0 not found.])
 fi
 
-AC_SUBST([CFLAGS])
-AC_SUBST([CPPFLAGS])
-AC_SUBST([LDFLAGS])
-AC_SUBST([LIBS])
+: ${MIT_SCHEME_EXE=mit-scheme}
+MIT_SCHEME_ARCH=`echo "(display microcode-id/compiled-code-type)" \
+                | ${MIT_SCHEME_EXE} --batch-mode`
+MIT_SCHEME_OS_SUFFIX=`echo "(display (microcode-id/operating-system-suffix))" \
+                | ${MIT_SCHEME_EXE} --batch-mode`
+
+AC_SUBST([MIT_SCHEME_EXE])
+AC_SUBST([MIT_SCHEME_ARCH])
+AC_SUBST([MIT_SCHEME_OS_SUFFIX])
 AC_CONFIG_FILES([Makefile])
 AC_OUTPUT
index 127757958bf3b539feb88fe53f723a8d73418d7a..a0430724a0ba4d1a958389ff21dfb9fc00ee923d 100644 (file)
@@ -1,23 +1,23 @@
 #| -*-Scheme-*-
 
-Copyright (C) 2011, 2014  Matthew Birkholz
+Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+    2016 Matthew Birkholz
 
-This file is part of MIT/GNU Scheme.
+This file is part of a glib plugin for 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.
+This plugin 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
+This plugin 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.
+along with this plugin; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 
 |#
 
@@ -366,6 +366,7 @@ USA.
                         gstream* priority gcancellable* callback id))
               make-input-close-finish-callback
               (named-lambda (close-input-cleanup gio-info)
+                (free (g-stream-buffer gstream))
                 (cleanup-g-input-stream
                  gio-info (g-input-stream-cleanup-info gstream)))))
 
@@ -524,6 +525,7 @@ USA.
                         gstream* priority gcancellable* callback id))
               make-output-close-finish-callback
               (named-lambda (close-output-cleanup gio-info)
+                (free (g-stream-buffer gstream))
                 (cleanup-g-output-stream
                  gio-info (g-output-stream-cleanup-info gstream)))))
 
diff --git a/src/glib/glib-check-copy.sh b/src/glib/glib-check-copy.sh
new file mode 100755 (executable)
index 0000000..4f1637d
--- /dev/null
@@ -0,0 +1,42 @@
+#!/bin/sh
+# -*-Scheme-*-
+#
+# Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+#     2016 Matthew Birkholz
+#
+# This file is part of a glib plugin for MIT/GNU Scheme.
+#
+# This plugin 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 plugin 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 plugin; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301, USA.
+
+# Test the GLIB option: copy text file.
+#
+# Copy lines from a text file to a new file and compare the two.
+
+set -e
+: ${MIT_SCHEME_EXE=mit-scheme}
+${MIT_SCHEME_EXE} --prepend-library . <<\EOF
+(begin
+  (load-option 'GLIB)
+  (load "glib-tests")
+  (let ((file1 "mit-scheme-glib.texi")
+       (file2 "test-copy-1.txt"))
+    (gcp file1 file2)
+    (load-option 'MD5)
+    (if (not (equal? (md5-file file1) (md5-file file2)))
+       (error "gio copy failed")))
+  (assert-clean-ffi "gio copy")
+  )
+EOF
diff --git a/src/glib/glib-check-list.sh b/src/glib/glib-check-list.sh
new file mode 100755 (executable)
index 0000000..76c54f7
--- /dev/null
@@ -0,0 +1,43 @@
+#!/bin/sh
+# -*-Scheme-*-
+#
+# Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+#     2016 Matthew Birkholz
+#
+# This file is part of a glib plugin for MIT/GNU Scheme.
+#
+# This plugin 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 plugin 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 plugin; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# 02110-1301, USA.
+
+# Test the GLIB option: list the current directory.
+#
+# List the current directory using GIO and directory-read, and compare
+# the results.
+
+set -e
+: ${MIT_SCHEME_EXE=mit-scheme}
+${MIT_SCHEME_EXE} --prepend-library . <<\EOF
+(begin
+  (load-option 'GLIB)
+  (load "glib-tests")
+  (let ((native (sort (ls "./") string<?))
+       (gio (sort (gls "./") string<?)))
+    (if (or (null? gio)
+           (null? native)
+           (not (equal? native gio)))
+       (error "gio list failed")))
+  (assert-clean-ffi "gio list")
+  )
+EOF
diff --git a/src/glib/glib-check.scm b/src/glib/glib-check.scm
deleted file mode 100644 (file)
index 3a29a6b..0000000
+++ /dev/null
@@ -1,74 +0,0 @@
-#| -*-Scheme-*-
-
-Copyright (C) 2012, 2013, 2014  Matthew Birkholz
-
-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.
-
-|#
-
-;;;; Test the Glib interface.
-
-(let ((new (extend-top-level-environment (->environment '(glib))))
-      (ffi (->environment '(runtime ffi))))
-  (load "glib-tests" new)
-  (let ((gcp (access gcp new))
-       (gls (access gls new))
-       (ls (access ls new))
-       (registered-callback-count (access registered-callback-count ffi))
-       (malloced-aliens (named-lambda (malloced-aliens)
-                          (access malloced-aliens ffi))))
-
-    (define (run-test name thunk)
-      (let ((condition (ignore-errors thunk)))
-       (cond ((eq? condition #t)
-              (for-each display (list "; Test "name" succeeded.\n")))
-             ((condition? condition)
-              (for-each display (list "; Test "name" failed with error:\n"))
-              (write-condition-report condition (current-output-port))
-              (newline))
-             (else
-              (for-each display (list "; Test "name" returned "condition
-                                      ".\n"))))))
-
-    (define (assert = obj1 obj2 form)
-      (if (not (= obj1 obj2))
-         (error "Assertion failed:" form))
-      #t)
-
-    (run-test
-     'gio-copy
-     (let ((cwd (directory-pathname (current-load-pathname))))
-       (named-lambda (gio-copy-test)
-        (with-working-directory-pathname cwd
-          (lambda ()
-            (let ((file1 "../README.txt")
-                  (file2 "test-copy-1.txt"))
-              (gcp file1 file2)
-              (assert equal? (md5-file file2) (md5-file file1)
-                      `(GCP ,file1 ,file2))))))))
-
-    (run-test
-     'gio-list
-     (let ((cwd (directory-pathname (current-load-pathname))))
-       (named-lambda (gio-list-test)
-        (with-working-directory-pathname cwd
-          (lambda ()
-            (let ((native (sort (ls "../runtime/") string<?))
-                  (gio (sort (gls "../runtime/") string<?)))
-              (assert equal? gio native
-                      '(GLS "../runtime/"))))))))))
\ No newline at end of file
index 0f68cd5f927e9d9f0bbf1bc090dfcd4e04ff2432..3a186ae013ac6ea3e54e126135bea785c039a56b 100644 (file)
@@ -1,23 +1,23 @@
 #| -*-Scheme-*-
 
-Copyright (C) 2008, 2009, 2010, 2011, 2014  Matthew Birkholz
+Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+    2016 Matthew Birkholz
 
-This file is part of MIT/GNU Scheme.
+This file is part of a glib plugin for 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.
+This plugin 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
+This plugin 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.
+along with this plugin; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 
 |#
 
@@ -28,8 +28,8 @@ USA.
 
 (define (glib-start)
   ;; Called from glib/make.scm, from a (load-option 'Glib).
-  (let ((path (system-library-pathname "glib-shim.so")))
-    (if (not (file-loadable? path)) (error "Glib shim not loadable.")))
+  (if (not (plugin-available? "glib"))
+      (error "GLIB plugin not found"))
   (if (fix:zero? (C-call "start_glib"))
       (error "Could not start Glib main loop."))
   (create-glib-thread))
index 640c60162680132e0a159f697e9da59c35e65f28..f875112a38f4438dacfa8bf0bd04f26cdfe8646f 100644 (file)
@@ -1,23 +1,23 @@
 /* -*-C-*-
 
-Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2014  Matthew Birkholz
+Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+    2016 Matthew Birkholz
 
-This file is part of an extension to MIT/GNU Scheme.
+This file is part of a glib plugin for 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.
+This plugin 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
+This plugin 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.
+along with this plugin; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 
 */
 
index e576ec1dffdcd7dbd7d73005cf4f532ebbe13e81..f789a476e48e824c7c71b20746f31d5e9b894e5a 100644 (file)
@@ -1,23 +1,23 @@
 #| -*-Scheme-*-
 
-Copyright (C) 2010, 2011, 2012, 2013, 2014  Matthew Birkholz
+Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+    2016 Matthew Birkholz
 
-This file is part of an extension to MIT/GNU Scheme.
+This file is part of a glib plugin for 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.
+This plugin 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
+This plugin 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.
+along with this plugin; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 
 |#
 
@@ -25,25 +25,6 @@ USA.
 \f
 ;;; GIO tests.
 
-(define test-copy-integrity
-  (let ((cwd (directory-pathname (current-load-pathname))))
-    (named-lambda (test-copy-integrity)
-      (with-working-directory-pathname cwd
-       (lambda ()
-         (let ((file1 "../README.txt")
-               (file2 "test-copy-1.txt"))
-           (gcp file1 file2)
-           (assert-equal (md5-file file2) (md5-file file1))))))))
-
-(define test-child-enumeration
-  (let ((cwd (directory-pathname (current-load-pathname))))
-    (named-lambda (test-child-enumeration)
-      (with-working-directory-pathname cwd
-       (lambda ()
-         (let ((native (sort (ls "../runtime/") string<?))
-               (gio (sort (gls "../runtime/") string<?)))
-           (assert-equal gio native)))))))
-
 (define (gcp src dst)
   (let ((gsrc (open-input-gfile src))
        (gdst (open-output-gfile dst)))
@@ -85,4 +66,19 @@ USA.
   (sort (gdirectory-read uri) string<?))
 
 (define ->simple-namestring
-  (access ->simple-namestring (->environment '(gio))))
\ No newline at end of file
+  (access ->simple-namestring (->environment '(gio))))
+
+(define (assert-clean-ffi test-name)
+  ;;(gc-flip)
+  ;;(sleep-current-thread 100)         ;Ensure GC deamons run? Hope they don't?
+  (let ((ffi (->environment '(runtime ffi))))
+    (if (not (zero? (car ((access registered-callback-count ffi)))))
+       (error (string-append test-name" did not clean up its callbacks")))
+    (if (not (null? (access malloced-aliens ffi)))
+       (error (string-append test-name" did not free allocated memory:")
+              (map (lambda (elt)
+                     (let ((alien (weak-car elt)))
+                       (if (eq? 'uchar (alien/ctype alien))
+                           (c-peek-cstring alien)
+                           alien)))
+                   (access malloced-aliens ffi))))))
\ No newline at end of file
index 55bd2b30d94577e3590ef59148ac99a236f717bd..be84aa7ebaa51a8caf0e991153599ca047844aa1 100644 (file)
@@ -1,23 +1,23 @@
 #| -*-Scheme-*-
 
-Copyright (C) 2007, 2008, 2009, 2010, 2011, 2014  Matthew Birkholz
+Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+    2016 Matthew Birkholz
 
-This file is part of MIT/GNU Scheme.
+This file is part of a glib plugin for 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.
+This plugin 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
+This plugin 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.
+along with this plugin; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 
 |#
 
index ad5bf8f26745d76206f3c495a128ce4d601f0796..88787ba3d05c1cb82e2fa1b9d62ec2ccf81bb2b7 100644 (file)
@@ -1,27 +1,27 @@
 #| -*-Scheme-*-
 
-Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2014  Matthew Birkholz
+Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+    2016 Matthew Birkholz
 
-This file is part of an extension to MIT/GNU Scheme.
+This file is part of a glib plugin for 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.
+This plugin 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
+This plugin 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.
+along with this plugin; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 
 |#
 
-;;;; C declarations for glib-shim.so.
+;;;; C declarations for glib-shim.la.
 \f
 (include "Includes/glib")
 (include "Includes/glib-object")
index f70bcea5b406031d04eef1be584191831b2a5b2b..1396c5cc197d40740a316885997918ce7941fa2f 100644 (file)
@@ -1,23 +1,23 @@
 #| -*-Scheme-*-
 
-Copyright (C) 2014  Matthew Birkholz
+Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+    2016 Matthew Birkholz
 
-This file is part of an extension to MIT/GNU Scheme.
+This file is part of a glib plugin for 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.
+This plugin 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
+This plugin 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.
+along with this plugin; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 
 |#
 
index 9eb6f74027678e4ce6350d2405c6876cc1afa4e6..f363f9a159f73cbaa3b0398d138a4123c35a89db 100644 (file)
@@ -1,23 +1,23 @@
 #| -*-Scheme-*-
 
-Copyright (C) 2014  Matthew Birkholz
+Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+    2016 Matthew Birkholz
 
-This file is part of an extension to MIT/GNU Scheme.
+This file is part of a glib plugin for 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.
+This plugin 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
+This plugin 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.
+along with this plugin; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 
 |#
 
index a4b7a7e092914654270fced96c1399db12dcb8d7..729297c91300e89d35a308b1753064353f2f2288 100644 (file)
@@ -1,23 +1,23 @@
 /* -*-C-*-
 
-Copyright (C) 2008, 2009, 2010, 2011, 2012, 2013, 2014  Matthew Birkholz
+Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+    2016 Matthew Birkholz
 
-This file is part of MIT/GNU Scheme.
+This file is part of a glib plugin for 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.
+This plugin 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
+This plugin 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.
+along with this plugin; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 
 */
 
index 30bc55e070ab6bbc5b8a308078824494a7546534..6435554881b45d7221fb1d760d2c406b51c93f55 100644 (file)
@@ -1,23 +1,23 @@
 #| -*-Scheme-*-
 
-Copyright (C) 2007, 2008, 2009, 2010, 2011, 2014  Matthew Birkholz
+Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
+    2016 Matthew Birkholz
 
-This file is part of MIT/GNU Scheme.
+This file is part of a glib plugin for 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.
+This plugin 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
+This plugin 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.
+along with this plugin; if not, write to the Free Software Foundation,
+Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 
 |#
 
index 215b59af33d3efb86488add6b542cc56ec1ae205..bfc555ffd8addd372f59854eec88f4899b9f6f56 100644 (file)
@@ -6,5 +6,5 @@ Load the Glib option. |#
 (with-loader-base-uri (system-library-uri "glib/")
   (lambda ()
     (load-package-set "glib")))
-(add-subsystem-identification! "Glib" '(0 5))
+(add-subsystem-identification! "GLib" '(0 5))
 ((access glib-start (->environment '(glib main))))
\ No newline at end of file
similarity index 96%
rename from src/glib/glib.texinfo
rename to src/glib/mit-scheme-glib.texi
index 30f59632f017477a0c452571328718828b29b07c..7ba909a145c757ff73011ebf6dfa08b40cc33e10 100644 (file)
@@ -1,6 +1,6 @@
 \input texinfo @c -*-Texinfo-*-
 @comment %**start of header
-@setfilename mit-scheme-glib
+@setfilename mit-scheme-glib.info
 @set VERSION 0.5
 @settitle GLib Plugin @value{VERSION}
 @comment %**end of header
 @end ifnothtml
 
 @copying
-This manual documents MIT/GNU Scheme's GLib plugin @value{VERSION}.
+This manual documents a GLib plugin for MIT/GNU Scheme, version
+@value{VERSION}.
 
-Copyright @copyright{} 2008, 2009, 2010, 2011, 2012, 2013, 2014
-Matthew Birkholz
+Copyright @copyright{} 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014,
+    2015, 2016 Matthew Birkholz
 
 @quotation
 Permission is granted to copy, distribute and/or modify this document
@@ -48,7 +49,7 @@ Documentation License.''
 @titlepage
 @title The MIT/GNU Scheme GLib Plugin Manual
 @subtitle Schemely access (@value{VERSION}) to the GNOME toolkits
-@subtitle for MIT/GNU Scheme version 9.1
+@subtitle for MIT/GNU Scheme version 9.3
 @author by Matt Birkholz (@email{birkholz@@alum.mit.edu})
 @page
 @vskip 0pt plus 1filll
@@ -65,7 +66,6 @@ Documentation License.''
 @menu
 * Introduction::
 * API Reference::
-* Installation::
 * Implementation Notes:: This is for Scheme widget developers.
 * GNU Free Documentation License::
 @end menu
@@ -83,7 +83,7 @@ Scheme's representative of a toolkit resource is dropped and
 collected, the toolkit resource is freed, just as the C/Unix FFI's
 malloced aliens are automatically freed.
 
-@node API Reference, Installation, Introduction, Top
+@node API Reference, Implementation Notes, Introduction, Top
 @unnumberedsec The GLib Package
 
 Most of the GLib system's public bindings are in the @code{(glib)}
@@ -532,36 +532,12 @@ A convenient procedure to call in an emergency.
 If @var{trace?} is @code{#t}, turns on tracing of Scheme's GSource.
 @end deffn
 
-@node Installation, Implementation Notes, API Reference, Top
-@chapter Installation
-
-Unpack the source and build in the usual way, but do not call
-@code{./configure} with a @code{--prefix} argument.  This plugin will
-be installed in the system library path of the machine run by the
-@code{mit-scheme} command.  You can override this command name by
-setting @code{MIT_SCHEME_EXE}.  You can override the system library
-path of any machine by passing it the @code{--library} option on the
-commandline, or the @code{MITSCHEME_LIBRARY_PATH} variable in the
-environment.
-
-@example
-  tar xzf glib-0.5.tar.gz
-  cd gtk-0.5
-  ./configure
-  make
-  make check
-  make install
-  make install-info
-  make install-html
-  make install-pdf
-@end example
-
-@node Implementation Notes, GNU Free Documentation License, Installation, Top
+@node Implementation Notes, GNU Free Documentation License, API Reference, Top
 @chapter Implementation Notes
 
 This chapter is for the hapless debugger, or potential widget
 developer.  It provides an overview of the mechanisms behind the
-scenes, like gtk-thread.
+scenes, like glib-thread.
 
 The procedures implementing the API are thin wrappers, trivial
 convenience functions that do type checking and conversion, and hide
@@ -587,16 +563,16 @@ In the example call to @code{gtk-label-get-text} above, a Scheme
 object represents the GtkLabel.  It is a gtk-label instance, whose
 class is a specialization of the abstract gtk-object class.
 
-@unnumberedsec Gtk Thread
+@unnumberedsec Glib Thread
 
-When the Gtk system loads, it starts a toolkit main loop with Scheme
+When the Glib system loads, it starts a toolkit main loop with Scheme
 attached as an custom idle task.  The main loop then re-starts Scheme,
 which creates a thread to ``run'' the toolkit (actually, return to
 it).  Thus Scheme threads multitask with the toolkit.  Scheme runs as
 an idle task in the toolkit, and the toolkit runs in a Scheme thread.
-A program using the Gtk system does not call @code{gtk_init} nor
-@code{gtk_main}.  It need only create toolkit objects and attach
-signal handlers to them.
+A program using the Glib system does not call @code{g_main_loop_run}.
+It need only create toolkit objects and attach signal handlers to
+them.
 
 @unnumberedsec Toolkit Resource Usage
 
similarity index 78%
rename from src/glib/glib-optiondb.scm
rename to src/glib/optiondb.scm
index 3d0754f01df9cc0afed89d2a886e12650d36d4cc..54c1b10fbe90efdbac6c842aec442d18a428a474 100644 (file)
@@ -11,5 +11,5 @@
 
 (further-load-options
  (merge-pathnames "optiondb"
-                 (last ((access library-directory-path
-                                (->environment '(runtime pathname)))))))
\ No newline at end of file
+                 (cadr (access library-directory-path
+                               (->environment '(runtime pathname))))))
\ No newline at end of file