Morgan Smith c7d170c5d1 Fix typos throughout codebase. 1 jaar geleden
..
ChangeLog-2008 6d66647d5b guile-tools is a scheme script that loads scheme modules 16 jaren geleden
README b8b0659879 rename `guile-tools' to `guild' 13 jaren geleden
api-diff.scm cc7d394490 Deprecate passing a non-zero size to make-module 5 jaren geleden
autofrisk.scm a1a2ed5342 more work on "guild list" 13 jaren geleden
compile.scm 45af53f65f Bump user-visible copyright years to 2023. 2 jaren geleden
disassemble.scm 93009a7aca ,xx for RTL images 11 jaren geleden
display-commentary.scm a1a2ed5342 more work on "guild list" 13 jaren geleden
doc-snarf.scm c7d170c5d1 Fix typos throughout codebase. 1 jaar geleden
frisk.scm 7b90947294 frisk: Fix incorrect #:autoload binding set leading to unbound variables. 5 jaren geleden
generate-autoload.scm a1a2ed5342 more work on "guild list" 13 jaren geleden
help.scm 3e7c80a62f scripts: help: Fix reference to the "Using Guile Tools" node. 7 jaren geleden
lint.scm a1a2ed5342 more work on "guild list" 13 jaren geleden
list.scm f5e772b2ba Fix a couple of warnings. 13 jaren geleden
punify.scm a1a2ed5342 more work on "guild list" 13 jaren geleden
read-rfc822.scm a1a2ed5342 more work on "guild list" 13 jaren geleden
read-scheme-source.scm a1a2ed5342 more work on "guild list" 13 jaren geleden
read-text-outline.scm a1a2ed5342 more work on "guild list" 13 jaren geleden
scan-api.scm a1a2ed5342 more work on "guild list" 13 jaren geleden
snarf-check-and-output-texi.scm 8f254172ad Remove redefinition of when & unless in snarf-check-and-output-texi 5 jaren geleden
snarf-guile-m4-docs.scm a1a2ed5342 more work on "guild list" 13 jaren geleden
summarize-guile-TODO.scm a1a2ed5342 more work on "guild list" 13 jaren geleden
use2dot.scm f329837fd1 use2dot: Fix incorrect #:autoload binding set leading to unbound variables. 5 jaren geleden

README

Overview and Usage
------------------

This directory contains Scheme programs, some useful in maintaining Guile.
On "make install", these programs are copied to PKGDATADIR/VERSION/scripts.

You can use guild to invoke a program from the shell, or alternatively,
load its file as a Guile Scheme module, and use its exported procedure(s)
from Scheme code. Typically for any PROGRAM:

(use-modules (scripts PROGRAM))
(PROGRAM ARG1 ARG2 ...)

For programs that write to stdout, you might try, instead:

(use-modules (scripts PROGRAM))
(with-output-to-string (lambda () (PROGRAM ARG1 ARG2 ...)))

Note that all args must be strings.

To see PROGRAM's commentary, which may or may not be helpful:

(help (scripts PROGRAM))

If you want to try the programs before installing Guile, you will probably
need to set environment variable GUILE_LOAD_PATH to be the parent directory.
This can be done in Bourne-compatible shells like so:

GUILE_LOAD_PATH=`(cd .. ; pwd)`
export GUILE_LOAD_PATH

[FIXME: Can someone supply the csh-compatible equivalent?]



How to Contribute
-----------------

See template file PROGRAM for a quick start.

Programs must follow the "guild" convention, documented here:

- The module name must be "(scripts PROGRAM)". A procedure named PROGRAM w/
signature "(PROGRAM . args)" must be exported. Basically, use some variant
of the form:

(define-module (scripts PROGRAM)
:export (PROGRAM))

Feel free to export other definitions useful in the module context.

- There must be the alias:

(define main PROGRAM)

However, `main' must NOT be exported.

Following these conventions allows the program file to be used as module
(scripts PROGRAM) in addition to being invoked by guild. Please also
include a helpful Commentary section w/ some usage info.


[README ends here]