1 \input texinfo @c -*- texinfo -*-
7 @c We use @&key, etc to escape & from TeX in lambda lists --
8 @c so we need to define them for info as well.
9 @macro &allow-other-keys
26 @dircategory Software development
28 * asdf: (asdf). Another System Definition Facility (for Common Lisp)
32 This manual describes ASDF, a system definition facility
33 for Common Lisp programs and libraries.
35 You can find the latest version of this manual at
36 @url{http://common-lisp.net/project/asdf/asdf.html}.
38 ASDF Copyright @copyright{} 2001-2012 Daniel Barlow and contributors.
40 This manual Copyright @copyright{} 2001-2012 Daniel Barlow and contributors.
42 This manual revised @copyright{} 2009-2012 Robert P. Goldman and Francois-Rene Rideau.
44 Permission is hereby granted, free of charge, to any person obtaining
45 a copy of this software and associated documentation files (the
46 ``Software''), to deal in the Software without restriction, including
47 without limitation the rights to use, copy, modify, merge, publish,
48 distribute, sublicense, and/or sell copies of the Software, and to
49 permit persons to whom the Software is furnished to do so, subject to
50 the following conditions:
52 The above copyright notice and this permission notice shall be
53 included in all copies or substantial portions of the Software.
55 THE SOFTWARE IS PROVIDED ``AS IS'', WITHOUT WARRANTY OF ANY KIND,
56 EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
57 MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
58 NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
59 LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
60 OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
61 WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
68 @title ASDF: Another System Definition Facility
70 @c The following two commands start the copyright page.
72 @vskip 0pt plus 1filll
76 @c Output the table of contents at the beginning.
79 @c -------------------
83 @node Top, Introduction, (dir), (dir)
84 @top asdf: another system definition facility
93 * Defining systems with defsystem::
94 * The object model of ASDF::
95 * Controlling where ASDF searches for systems::
96 * Controlling where ASDF saves compiled files::
98 * Miscellaneous additional functionality::
99 * Getting the latest version::
104 * Function and Class Index::
108 @c --- The Detailed Node Listing ---
110 @c Defining systems with defsystem
112 @c * The defsystem form::
113 @c * A more involved example::
114 @c * The defsystem grammar::
115 @c * Other code in .asd files::
117 @c The object model of ASDF
124 @c * Predefined operations of ASDF::
125 @c * Creating new operations::
129 @c * Common attributes of components::
130 @c * Pre-defined subclasses of component::
131 @c * Creating new component types::
135 @c * Pre-defined subclasses of component::
136 @c * Creating new component types::
143 @c -------------------
145 @node Introduction, Loading ASDF, Top, Top
146 @comment node-name, next, previous, up
147 @chapter Introduction
148 @cindex ASDF-related features
150 @cindex Testing for ASDF
151 @cindex ASDF versions
155 ASDF is Another System Definition Facility:
156 a tool for specifying how systems of Common Lisp software
157 are comprised of components (sub-systems and files),
158 and how to operate on these components in the right order
159 so that they can be compiled, loaded, tested, etc.
161 ASDF presents three faces:
162 one for users of Common Lisp software who want to reuse other people's code,
163 one for writers of Common Lisp software who want to specify how to build their systems,
164 one for implementers of Common Lisp extensions who want to extend the build system.
165 @xref{Using ASDF,,Loading a system},
166 to learn how to use ASDF to load a system.
167 @xref{Defining systems with defsystem},
168 to learn how to define a system of your own.
169 @xref{The object model of ASDF}, for a description of
170 the ASDF internals and how to extend ASDF.
173 We have released ASDF 2.000 on May 31st 2010.
174 Subsequent releases of ASDF 2 have since then been included
175 in all actively maintained CL implementations that used to bundle ASDF 1,
176 plus some implementations that didn't use to,
177 and has been made to work with all actively used CL implementations and a few more.
178 @xref{FAQ,,``What has changed between ASDF 1 and ASDF 2?''}.
179 Furthermore, it is possible to upgrade from ASDF 1 to ASDF 2 on the fly.
180 For this reason, we have stopped supporting ASDF 1;
181 if you are using ASDF 1 and are experiencing any kind of issues or limitations,
182 we recommend you upgrade to ASDF 2
183 --- and we explain how to do that. @xref{Loading ASDF}.
185 Also note that ASDF is not to be confused with ASDF-Install.
186 ASDF-Install is not part of ASDF, but a separate piece of software.
187 ASDF-Install is also unmaintained and obsolete.
188 We recommend you use Quicklisp instead,
189 which works great and is being actively maintained.
190 If you want to download software from version control instead of tarballs,
191 so you may more easily modify it, we recommend clbuild.
194 @node Loading ASDF, Configuring ASDF, Introduction, Top
195 @comment node-name, next, previous, up
196 @chapter Loading ASDF
197 @vindex *central-registry*
200 @findex require-system
201 @findex compile-system
203 @cindex system directory designator
208 @c * Installing ASDF::
212 @section Loading a pre-installed ASDF
214 Many Lisp implementations include a copy of ASDF.
215 You can usually load this copy using Common Lisp's @code{require} function:
221 As of the writing of this manual,
222 the following implementations provide ASDF 2 this way:
223 abcl allegro ccl clisp cmucl ecl lispworks mkcl sbcl xcl.
224 The following implementation doesn't provide it yet but will in a future release:
226 The following implementations are obsolete, not actively maintained,
227 and most probably will never bundle it:
228 cormanlisp gcl genera mcl.
230 If the implementation you are using doesn't provide ASDF 2,
231 see @pxref{Loading ASDF,,Loading an otherwise installed ASDF} below.
232 If that implementation is still actively maintained,
233 you may also send a bug report to your Lisp vendor and complain
234 about their failing to provide ASDF.
236 NB: all implementations except clisp also accept
237 @code{(require "ASDF")}, @code{(require 'asdf)} and @code{(require :asdf)}.
238 For portability's sake, you probably want to use @code{(require "asdf")}.
241 @section Checking whether ASDF is loaded
243 To check whether ASDF is properly loaded in your current Lisp image,
244 you can run this form:
250 If it returns a string,
251 that is the version of ASDF that is currently installed.
253 If it raises an error,
254 then either ASDF is not loaded, or
255 you are using an old version of ASDF.
257 You can check whether an old version is loaded
258 by checking if the ASDF package is present.
259 The form below will allow you to programmatically determine
260 whether a recent version is loaded, an old version is loaded,
264 (or #+asdf2 (asdf:asdf-version) #+asdf :old)
267 If it returns a version number, that's the version of ASDF installed.
268 If it returns the keyword @code{:OLD},
269 then you're using an old version of ASDF (from before 1.635).
270 If it returns @code{NIL} then ASDF is not installed.
272 If you are experiencing problems with ASDF,
273 please try upgrading to the latest released version,
274 using the method below,
275 before you contact us and raise an issue.
278 @section Upgrading ASDF
280 If your implementation does provide ASDF 2 or later,
281 and you want to upgrade to a more recent version,
282 just install ASDF like any other package
283 (see @pxref{Loading ASDF,,Loading an otherwise installed ASDF} below),
284 configure ASDF as usual (see @pxref{Configuring ASDF} below),
289 (asdf:load-system :asdf)
292 If on the other hand, your implementation only provides an old ASDF,
293 you will require a special configuration step and an old-style loading:
297 (push #p"@var{/path/to/new/asdf/}" asdf:*central-registry*)
298 (asdf:oos 'asdf:load-op :asdf)
301 Don't forget the trailing @code{/} at the end of your pathname.
303 Also, note that older versions of ASDF won't redirect their output,
304 or at least won't do it according to your usual ASDF 2 configuration.
305 You therefore need write access on the directory
306 where you install the new ASDF,
307 and make sure you're not using it
308 for multiple mutually incompatible implementations.
309 At worst, you may have to have multiple copies of the new ASDF,
310 e.g. one per implementation installation, to avoid clashes.
311 Note that to our knowledge all implementations that provide ASDF
312 provide ASDF 2 in their latest release, so
313 you may want to upgrade your implementation rather than go through that hoop.
315 Finally, note that there are some limitations to upgrading ASDF:
318 Any ASDF extension becomes invalid, and will need to be reloaded.
319 This applies to e.g. CFFI-Grovel, or to hacks used by ironclad, etc.
320 Starting with ASDF 2.014.8, ASDF will actually invalidate
321 all previously loaded systems when it is loaded on top of
322 a different ASDF version.
324 Until all implementations provide ASDF 2.015 or later,
325 it is safer if you upgrade ASDF and its extensions as a special step
326 at the very beginning of whatever script you are running,
327 before you start using ASDF to load anything else.
329 Until all implementations provide ASDF 2.015 or later,
330 it is unsafe to upgrade ASDF as part of loading a system
331 that depends on a more recent version of ASDF,
332 since the new one might shadow the old one while the old one is running,
333 and the running old one will be confused
334 when extensions are loaded into the new one.
335 In the meantime, we recommend that your systems should @emph{not} specify
336 @code{:depends-on (:asdf)}, or @code{:depends-on ((:version :asdf "2.010"))},
337 but instead that they check that a recent enough ASDF is installed,
340 (unless (or #+asdf2 (asdf:version-satisfies
341 (asdf:asdf-version) *required-asdf-version*))
342 (error "FOO requires ASDF ~A or later." *required-asdf-version*))
347 @section Loading an otherwise installed ASDF
349 If your implementation doesn't include ASDF,
350 if for some reason the upgrade somehow fails,
351 does not or cannot apply to your case,
352 you will have to install the file @file{asdf.lisp}
353 somewhere and load it with:
356 (load "/path/to/your/installed/asdf.lisp")
359 The single file @file{asdf.lisp} is all you normally need to use ASDF.
361 You can extract this file from latest release tarball on the
362 @url{http://common-lisp.net/project/asdf/,ASDF website}.
363 If you are daring and willing to report bugs, you can get
364 the latest and greatest version of ASDF from its git repository.
365 @xref{Getting the latest version}.
367 For maximum convenience you might want to have ASDF loaded
368 whenever you start your Lisp implementation,
369 for example by loading it from the startup script or dumping a custom core
370 --- check your Lisp implementation's manual for details.
373 @node Configuring ASDF, Using ASDF, Loading ASDF, Top
374 @comment node-name, next, previous, up
376 @chapter Configuring ASDF
378 @section Configuring ASDF to find your systems
380 So it may compile and load your systems, ASDF must be configured to find
381 the @file{.asd} files that contain system definitions.
383 Since ASDF 2, the preferred way to configure where ASDF finds your systems is
384 the @code{source-registry} facility,
385 fully described in its own chapter of this manual.
386 @xref{Controlling where ASDF searches for systems}.
388 The default location for a user to install Common Lisp software is under
389 @file{~/.local/share/common-lisp/source/}.
390 If you install software there, you don't need further configuration.
391 If you're installing software yourself at a location that isn't standard,
392 you have to tell ASDF where you installed it. See below.
393 If you're using some tool to install software (e.g. Quicklisp),
394 the authors of that tool should already have configured ASDF.
396 The simplest way to add a path to your search path,
397 say @file{/home/luser/.asd-link-farm/}
398 is to create the directory
399 @file{~/.config/common-lisp/source-registry.conf.d/}
400 and there create a file with any name of your choice,
401 and with the type @file{conf},
402 for instance @file{42-asd-link-farm.conf}
405 @kbd{(:directory "/home/luser/.asd-link-farm/")}
407 If you want all the subdirectories under @file{/home/luser/lisp/}
408 to be recursively scanned for @file{.asd} files, instead use:
410 @kbd{(:tree "/home/luser/lisp/")}
412 Note that your Operating System distribution or your system administrator
413 may already have configured system-managed libraries for you.
415 The required @file{.conf} extension allows you to have disabled files
416 or editor backups (ending in @file{~}), and works portably
417 (for instance, it is a pain to allow both empty and non-empty extension on CLISP).
418 Excluded are files the name of which start with a @file{.} character.
419 It is customary to start the filename with two digits
420 that specify the order in which the directories will be scanned.
422 ASDF will automatically read your configuration
423 the first time you try to find a system.
424 You can reset the source-registry configuration with:
427 (asdf:clear-source-registry)
430 And you probably should do so before you dump your Lisp image,
431 if the configuration may change
432 between the machine where you save it at the time you save it
433 and the machine you resume it at the time you resume it.
436 @section Configuring ASDF to find your systems --- old style
438 The old way to configure ASDF to find your systems is by
439 @code{push}ing directory pathnames onto the variable
440 @code{asdf:*central-registry*}.
442 You must configure this variable between the time you load ASDF
443 and the time you first try to use it.
444 Loading and configuring ASDF presumably happen
445 as part of some initialization script that builds or starts
446 your Common Lisp software system.
447 (For instance, some SBCL users used to put it in their @file{~/.sbclrc}.)
449 The @code{asdf:*central-registry*} is empty by default in ASDF 2,
450 but is still supported for compatibility with ASDF 1.
451 When used, it takes precedence over the above source-registry@footnote{
452 It is possible to further customize
453 the system definition file search.
454 That's considered advanced use, and covered later:
456 @code{*system-definition-search-functions*}.
457 @xref{Defining systems with defsystem}.}.
459 For instance, if you wanted ASDF to find the @file{.asd} file
460 @file{/home/me/src/foo/foo.asd} your initialization script
461 could after it loads ASDF with @code{(require "asdf")}
465 (push "/home/me/src/foo/" asdf:*central-registry*)
468 Note the trailing slash: when searching for a system,
469 ASDF will evaluate each entry of the central registry
470 and coerce the result to a pathname@footnote{
471 ASDF will indeed call @code{EVAL} on each entry.
472 It will also skip entries that evaluate to @code{NIL}.
474 Strings and pathname objects are self-evaluating,
475 in which case the @code{EVAL} step does nothing;
476 but you may push arbitrary SEXP onto the central registry,
477 that will be evaluated to compute e.g. things that depend
478 on the value of shell variables or the identity of the user.
480 The variable @code{asdf:*central-registry*} is thus a list of
481 ``system directory designators''.
482 A @dfn{system directory designator} is a form
483 which will be evaluated whenever a system is to be found,
484 and must evaluate to a directory to look in.
485 By ``directory'' here, we mean
486 ``designator for a pathname with a supplied DIRECTORY component''.
488 at which point the presence of the trailing directory name separator
489 is necessary to tell Lisp that you're discussing a directory
492 Typically, however, there are a lot of @file{.asd} files, and
493 a common idiom was to have to put
494 a bunch of @emph{symbolic links} to @file{.asd} files
495 in a common directory
496 and push @emph{that} directory (the ``link farm'')
498 @code{asdf:*central-registry*}
499 instead of pushing each of the many involved directories
500 to the @code{asdf:*central-registry*}.
501 ASDF knows how to follow such @emph{symlinks}
502 to the actual file location when resolving the paths of system components
503 (on Windows, you can use Windows shortcuts instead of POSIX symlinks;
504 if you try aliases under MacOS, we are curious to hear about your experience).
506 For example, if @code{#p"/home/me/cl/systems/"} (note the trailing slash)
507 is a member of @code{*central-registry*}, you could set up the
508 system @var{foo} for loading with asdf with the following
509 commands at the shell:
512 $ cd /home/me/cl/systems/
513 $ ln -s ~/src/foo/foo.asd .
516 This old style for configuring ASDF is not recommended for new users,
517 but it is supported for old users, and for users who want to programmatically
518 control what directories are added to the ASDF search path.
521 @section Configuring where ASDF stores object files
522 @findex clear-output-translations
524 ASDF lets you configure where object files will be stored.
525 Sensible defaults are provided and
526 you shouldn't normally have to worry about it.
528 This allows the same source code repository may be shared
529 between several versions of several Common Lisp implementations,
530 between several users using different compilation options
531 and without write privileges on shared source directories, etc.
532 This also allows to keep source directories uncluttered
533 by plenty of object files.
535 Starting with ASDF 2, the @code{asdf-output-translations} facility
536 was added to ASDF itself, that controls where object files will be stored.
537 This facility is fully described in a chapter of this manual,
538 @ref{Controlling where ASDF saves compiled files}.
540 The simplest way to add a translation to your search path,
541 say from @file{/foo/bar/baz/quux/}
542 to @file{/where/i/want/my/fasls/}
543 is to create the directory
544 @file{~/.config/common-lisp/asdf-output-translations.conf.d/}
545 and there create a file with any name of your choice and the type @file{conf},
546 for instance @file{42-bazquux.conf}
549 @kbd{("/foo/bar/baz/quux/" "/where/i/want/my/fasls/")}
551 To disable output translations for source under a given directory,
552 say @file{/toto/tata/}
553 you can create a file @file{40-disable-toto.conf}
556 @kbd{("/toto/tata/")}
558 To wholly disable output translations for all directories,
559 you can create a file @file{00-disable.conf}
564 Note that your Operating System distribution or your system administrator
565 may already have configured translations for you.
566 In absence of any configuration, the default is to redirect everything
567 under an implementation-dependent subdirectory of @file{~/.cache/common-lisp/}.
568 @xref{Controlling where ASDF searches for systems}, for full details.
570 The required @file{.conf} extension allows you to have disabled files
571 or editor backups (ending in @file{~}), and works portably
572 (for instance, it is a pain to allow both empty and non-empty extension on CLISP).
573 Excluded are files the name of which start with a @file{.} character.
574 It is customary to start the filename with two digits
575 that specify the order in which the directories will be scanned.
577 ASDF will automatically read your configuration
578 the first time you try to find a system.
579 You can reset the source-registry configuration with:
582 (asdf:clear-output-translations)
585 And you probably should do so before you dump your Lisp image,
586 if the configuration may change
587 between the machine where you save it at the time you save it
588 and the machine you resume it at the time you resume it.
590 Finally note that before ASDF 2,
591 other ASDF add-ons offered the same functionality,
592 each in subtly different and incompatible ways:
593 ASDF-Binary-Locations, cl-launch, common-lisp-controller.
594 ASDF-Binary-Locations is now not needed anymore and should not be used.
595 cl-launch 3.000 and common-lisp-controller 7.2 have been updated
596 to just delegate this functionality to ASDF.
598 @node Using ASDF, Defining systems with defsystem, Configuring ASDF, Top
599 @comment node-name, next, previous, up
602 @section Resetting Configuration
604 When you dump and restore an image, or when you tweak your configuration,
605 you may want to reset the ASDF configuration.
606 For that you may use the following function:
608 @defun clear-configuration
609 undoes any ASDF configuration,
610 regarding source-registry or output-translations.
613 If you use SBCL, CMUCL or SCL, you may use this snippet
614 so that the ASDF configuration be cleared automatically as you dump an image:
618 (pushnew 'clear-configuration
619 #+(or cmu scl) ext:*before-save-initializations*
620 #+sbcl sb-ext:*save-hooks*)
623 For compatibility with all Lisp implementations, however,
624 you might want instead your build script to explicitly call
625 @code{(asdf:clear-configuration)} at an appropriate moment before dumping.
630 @section Loading a system
632 The system @var{foo} is loaded (and compiled, if necessary)
633 by evaluating the following Lisp form:
636 (asdf:load-system :@var{foo})
639 On some implementations (namely recent versions of
640 ABCL, Allegro CL, Clozure CL, CMUCL, ECL, GNU CLISP, LispWorks, MKCL, SBCL and XCL),
641 ASDF hooks into the @code{CL:REQUIRE} facility
642 and you can just use:
648 In older versions of ASDF, you needed to use
649 @code{(asdf:oos 'asdf:load-op :@var{foo})}.
650 If your ASDF is too old to provide @code{asdf:load-system} though
651 we recommend that you upgrade to ASDF 2.
652 @xref{Loading ASDF,,Loading an otherwise installed ASDF}.
654 Note the name of a system is specified as a string or a symbol,
656 If a symbol (including a keyword), its name is taken and lowercased.
657 The name must be a suitable value for the @code{:name} initarg
658 to @code{make-pathname} in whatever filesystem the system is to be found.
659 The lower-casing-symbols behaviour is unconventional,
660 but was selected after some consideration.
661 Observations suggest that the type of systems we want to support
662 either have lowercase as customary case (unix, mac, windows)
663 or silently convert lowercase to uppercase (lpns),
664 so this makes more sense than attempting to use @code{:case :common},
665 which is reported not to work on some implementations
668 @section Other Operations
670 ASDF provides three commands for the most common system operations:
671 @code{load-system}, @code{compile-system} or @code{test-system}.
672 It also provides @code{require-system}, a version of @code{load-system}
673 that skips trying to update systems that are already loaded.
675 Because ASDF is an extensible system
676 for defining @emph{operations} on @emph{components},
677 it also provides a generic function @code{operate}
678 (which is usually abbreviated by @code{oos}).
679 You'll use @code{oos} whenever you want to do something beyond
680 compiling, loading and testing.
682 Output from ASDF and ASDF extensions are supposed to be sent
683 to the CL stream @code{*standard-output*},
684 and so rebinding that stream around calls to @code{asdf:operate}
685 should redirect all output from ASDF operations.
687 Reminder: before ASDF can operate on a system, however,
688 it must be able to find and load that system's definition.
689 @xref{Configuring ASDF,,Configuring ASDF to find your systems}.
698 Load ASDF itself into your Lisp image, either through
699 @code{(require "asdf")} or else through
700 @code{(load "/path/to/asdf.lisp")}.
703 Make sure ASDF can find system definitions
704 thanks to proper source-registry configuration.
707 Load a system with @code{(load-system :my-system)}
708 or use some other operation on some system of your choice.
714 That's all you need to know to use ASDF to load systems written by others.
715 The rest of this manual deals with writing system definitions
716 for Common Lisp software you write yourself,
717 including how to extend ASDF to define new operation and component types.
720 @node Defining systems with defsystem, The object model of ASDF, Using ASDF, Top
721 @comment node-name, next, previous, up
722 @chapter Defining systems with defsystem
724 This chapter describes how to use asdf to define systems and develop
729 * The defsystem form::
730 * A more involved example::
731 * The defsystem grammar::
732 * Other code in .asd files::
735 @node The defsystem form, A more involved example, Defining systems with defsystem, Defining systems with defsystem
736 @comment node-name, next, previous, up
737 @section The defsystem form
739 Systems can be constructed programmatically
740 by instantiating components using @code{make-instance}.
741 Most of the time, however, it is much more practical to use
742 a static @code{defsystem} form.
743 This section begins with an example of a system definition,
744 then gives the full grammar of @code{defsystem}.
746 Let's look at a simple system.
747 This is a complete file that would
748 usually be saved as @file{hello-lisp.asd}:
753 (defsystem "hello-lisp"
754 :description "hello-lisp: a sample Lisp system."
756 :author "Joe User <joe@@example.com>"
757 :licence "Public Domain"
758 :components ((:file "packages")
759 (:file "macros" :depends-on ("packages"))
760 (:file "hello" :depends-on ("macros"))))
763 Some notes about this example:
768 The file starts with an @code{in-package} form
769 to use package @code{asdf}.
770 You could instead start your definition by using
771 a qualified name @code{asdf:defsystem}.
774 If in addition to simply using @code{defsystem},
775 you are going to define functions,
776 create ASDF extension, globally bind symbols, etc.,
777 it is recommended that to avoid namespace pollution between systems,
778 you should create your own package for that purpose,
779 for instance replacing the above @code{(in-package :asdf)} with:
782 (defpackage :foo-system
785 (in-package :foo-system)
789 The @code{defsystem} form defines a system named @code{hello-lisp}
790 that contains three source files:
791 @file{packages}, @file{macros} and @file{hello}.
794 The file @file{macros} depends on @file{packages}
795 (presumably because the package it's in is defined in @file{packages}),
796 and the file @file{hello} depends on @file{macros}
797 (and hence, transitively on @file{packages}).
798 This means that ASDF will compile and load @file{packages} and @file{macros}
799 before starting the compilation of file @file{hello}.
802 The files are located in the same directory
803 as the file with the system definition.
804 ASDF resolves symbolic links (or Windows shortcuts)
805 before loading the system definition file and
806 stores its location in the resulting system@footnote{
807 It is possible, though almost never necessary, to override this behaviour.}.
808 This is a good thing because the user can move the system sources
809 without having to edit the system definition.
811 @c FIXME: Should have cross-reference to "Version specifiers" in the
812 @c defsystem grammar, but the cross-referencing is so broken by
813 @c insufficient node breakdown that I have not put one in.
815 Make sure you know how the @code{:version} numbers will be parsed! They
816 are parsed as period-separated lists of integers. I.e., in the example,
817 @code{0.2.1} is to be interpreted, roughly speaking, as @code{(0 2 1)}.
818 In particular, version @code{0.2.1} is interpreted the same as
819 @code{0.0002.1} and is strictly version-less-than version @code{0.20.1},
820 even though the two are the same when interpreted as decimal fractions.
821 @cindex version specifiers
826 @node A more involved example, The defsystem grammar, The defsystem form, Defining systems with defsystem
827 @comment node-name, next, previous, up
828 @section A more involved example
830 Let's illustrate some more involved uses of @code{defsystem} via a
831 slightly convoluted example:
836 :components ((:module "mod"
837 :components ((:file "bar")
840 :perform (compile-op :after (op c)
842 :explain (compile-op :after (op c)
843 (explain-something c)))
847 The @code{:module} component named @code{"mod"} is a collection of three files,
848 which will be located in a subdirectory of the main code directory named
849 @file{mod} (this location can be overridden; see the discussion of the
850 @code{:pathname} option in @ref{The defsystem grammar}).
852 The method-form tokens provide a shorthand for defining methods on
853 particular components. This part
856 :perform (compile-op :after (op c)
858 :explain (compile-op :after (op c)
859 (explain-something c))
865 (defmethod perform :after ((op compile-op) (c (eql ...)))
867 (defmethod explain :after ((op compile-op) (c (eql ...)))
868 (explain-something c))
871 where @code{...} is the component in question.
872 In this case @code{...} would expand to something like
875 (find-component (find-system "foo") "mod")
878 For more details on the syntax of such forms, see @ref{The defsystem
880 For more details on what these methods do, @pxref{Operations} in
881 @ref{The object model of ASDF}.
883 @c The following plunge into the weeds is not appropriate in this
884 @c location. [2010/10/03:rpg]
885 @c note that although this also supports @code{:before} methods,
886 @c they may not do what you want them to ---
887 @c a @code{:before} method on perform @code{((op compile-op) (c (eql ...)))}
888 @c will run after all the dependencies and sub-components have been processed,
889 @c but before the component in question has been compiled.
891 @node The defsystem grammar, Other code in .asd files, A more involved example, Defining systems with defsystem
892 @comment node-name, next, previous, up
893 @section The defsystem grammar
895 @c FIXME: @var typesetting not consistently used here. We should either expand
896 @c its use to everywhere, or we should kill it everywhere.
900 system-definition := ( defsystem system-designator @var{system-option}* )
902 system-option := :defsystem-depends-on system-list
903 | :weakly-depends-on @var{system-list}
904 | :class class-name (see discussion below)
908 module-option := :components component-list
909 | :serial [ t | nil ]
910 | :if-component-dep-fails component-dep-fail-option
913 | :pathname pathname-specifier
914 | :default-component-class class-name
915 | :perform method-form
916 | :explain method-form
917 | :output-files method-form
918 | :operation-done-p method-form
919 | :depends-on ( @var{dependency-def}* )
920 | :in-order-to ( @var{dependency}+ )
923 system-list := ( @var{simple-component-name}* )
925 component-list := ( @var{component-def}* )
927 component-def := ( component-type simple-component-name @var{option}* )
929 component-type := :system | :module | :file | :static-file | other-component-type
931 other-component-type := symbol-by-name (@pxref{The defsystem grammar,,Component types})
933 dependency-def := simple-component-name
935 | ( :version simple-component-name version-specifier)
937 dependency := (dependent-op @var{requirement}+)
938 requirement := (required-op @var{required-component}+)
939 | (feature feature-name)
940 dependent-op := operation-name
941 required-op := operation-name | feature
943 simple-component-name := string
946 pathname-specifier := pathname | string | symbol
948 method-form := (operation-name qual lambda-list @&rest body)
949 qual := method qualifier
951 component-dep-fail-option := :fail | :try-next | :ignore
955 @subsection Component names
957 Component names (@code{simple-component-name})
958 may be either strings or symbols.
960 @subsection Component types
962 Component type names, even if expressed as keywords, will be looked up
963 by name in the current package and in the asdf package, if not found in
964 the current package. So a component type @code{my-component-type}, in
965 the current package @code{my-system-asd} can be specified as
966 @code{:my-component-type}, or @code{my-component-type}.
968 @subsection System class names
970 A system class name will be looked up in the same way as a Component
971 type (see above). Typically, one will not need to specify a system
972 class name, unless using a non-standard system class defined in some
973 ASDF extension, typically loaded through @code{DEFSYSTEM-DEPENDS-ON},
974 see below. For such class names in the ASDF package, we recommend that
975 the @code{:class} option be specified using a keyword symbol, such as
978 :class :MY-NEW-SYSTEM-SUBCLASS
981 This practice will ensure that package name conflicts are avoided.
982 Otherwise, the symbol @code{MY-NEW-SYSTEM-SUBCLASS} will be read into
983 the current package @emph{before} it has been exported from the ASDF
984 extension loaded by @code{:defsystem-depends-on}, causing a name
985 conflict in the current package.
987 @subsection Defsystem depends on
988 @cindex :defsystem-depends-on
990 The @code{:defsystem-depends-on} option to @code{defsystem} allows the
991 programmer to specify another ASDF-defined system or set of systems that
992 must be loaded @emph{before} the system definition is processed.
993 Typically this is used to load an ASDF extension that is used in the
996 @subsection Weakly depends on
997 @cindex :weakly-depends-on
999 The @code{:weakly-depends-on} option to @code{defsystem} allows the
1000 programmer to specify another ASDF-defined system or set of systems that
1001 ASDF should @emph{try} to load, but need not load in order to be
1002 successful. Typically this is used if there are a number of systems
1003 that, if present, could provide additional functionality, but which are
1004 not necessary for basic function.
1006 Currently, although it is specified to be an option only to
1007 @code{defsystem}, this option is accepted at any component, but it probably
1008 only makes sense at the @code{defsystem} level. Programmers are cautioned not
1009 to use this component option except at the @code{defsystem} level, as
1010 this anomalous behavior may be removed without warning.
1012 @subsection Pathname specifiers
1013 @cindex pathname specifiers
1015 A pathname specifier (@code{pathname-specifier})
1016 may be a pathname, a string or a symbol.
1017 When no pathname specifier is given for a component,
1018 which is the usual case, the component name itself is used.
1020 If a string is given, which is the usual case,
1021 the string will be interpreted as a Unix-style pathname
1022 where @code{/} characters will be interpreted as directory separators.
1023 Usually, Unix-style relative pathnames are used
1024 (i.e. not starting with @code{/}, as opposed to absolute pathnames);
1025 they are relative to the path of the parent component.
1026 Finally, depending on the @code{component-type},
1027 the pathname may be interpreted as either a file or a directory,
1029 a file type may be added corresponding to the @code{component-type},
1030 or else it will be extracted from the string itself (if applicable).
1032 For instance, the @code{component-type} @code{:module}
1033 wants a directory pathname, and so a string @code{"foo/bar"}
1034 will be interpreted as the pathname @file{#p"foo/bar/"}.
1035 On the other hand, the @code{component-type} @code{:file}
1036 wants a file of type @code{lisp}, and so a string @code{"foo/bar"}
1037 will be interpreted as the pathname @file{#p"foo/bar.lisp"},
1038 and a string @code{"foo/bar.quux"}
1039 will be interpreted as the pathname @file{#p"foo/bar.quux.lisp"}.
1040 Finally, the @code{component-type} @code{:static-file}
1041 wants a file without specifying a type, and so a string @code{"foo/bar"}
1042 will be interpreted as the pathname @file{#p"foo/bar"},
1043 and a string @code{"foo/bar.quux"}
1044 will be interpreted as the pathname @file{#p"foo/bar.quux"}.
1046 ASDF does not interpret the string @code{".."} to designate the parent
1047 directory. This string will be passed through to the underlying
1048 operating system for interpretation. We @emph{believe} that this will
1049 work on all platforms where ASDF is deployed, but do not guarantee this
1050 behavior. A pathname object with a relative directory component of
1051 @code{:up} or @code{:back} is the only guaranteed way to specify a
1054 If a symbol is given, it will be translated into a string,
1055 and downcased in the process.
1056 The downcasing of symbols is unconventional,
1057 but was selected after some consideration.
1058 Observations suggest that the type of systems we want to support
1059 either have lowercase as customary case (Unix, Mac, windows)
1060 or silently convert lowercase to uppercase (lpns),
1061 so this makes more sense than attempting to use @code{:case :common}
1062 as argument to @code{make-pathname},
1063 which is reported not to work on some implementations.
1065 Pathname objects may be given to override the path for a component.
1066 Such objects are typically specified using reader macros such as @code{#p}
1067 or @code{#.(make-pathname ...)}.
1068 Note however, that @code{#p...} is a shorthand for @code{#.(parse-namestring ...)}
1069 and that the behavior of @code{parse-namestring} is completely non-portable,
1070 unless you are using Common Lisp @code{logical-pathname}s
1071 (@pxref{The defsystem grammar,,Using logical pathnames}, below).
1072 Pathnames made with @code{#.(make-pathname ...)}
1073 can usually be done more easily with the string syntax above.
1074 The only case that you really need a pathname object is to override
1075 the component-type default file type for a given component.
1076 Therefore, pathname objects should only rarely be used.
1077 Unhappily, ASDF 1 didn't properly support
1078 parsing component names as strings specifying paths with directories,
1079 and the cumbersome @code{#.(make-pathname ...)} syntax had to be used.
1081 Note that when specifying pathname objects,
1082 ASDF does not do any special interpretation of the pathname
1083 influenced by the component type, unlike the procedure for
1084 pathname-specifying strings.
1085 On the one hand, you have to be careful to provide a pathname that correctly
1086 fulfills whatever constraints are required from that component type
1087 (e.g. naming a directory or a file with appropriate type);
1088 on the other hand, you can circumvent the file type that would otherwise
1089 be forced upon you if you were specifying a string.
1091 @subsection Version specifiers
1092 @cindex version specifiers
1095 Version specifiers are parsed as period-separated lists of integers. I.e., in the example,
1096 @code{0.2.1} is to be interpreted, roughly speaking, as @code{(0 2 1)}.
1097 In particular, version @code{0.2.1} is interpreted the same as
1098 @code{0.0002.1} and is strictly version-less-than version @code{0.20.1},
1099 even though the two are the same when interpreted as decimal fractions.
1101 System definers are encouraged to use version identifiers of the form
1102 @var{x}.@var{y}.@var{z} for major version, minor version (compatible
1103 API) and patch level.
1105 @xref{Common attributes of components}.
1108 @subsection Using logical pathnames
1109 @cindex logical pathnames
1111 We do not generally recommend the use of logical pathnames,
1112 especially not so to newcomers to Common Lisp.
1113 However, we do support the use of logical pathnames by old timers,
1114 when such is their preference.
1116 To use logical pathnames,
1117 you will have to provide a pathname object as a @code{:pathname} specifier
1118 to components that use it, using such syntax as
1119 @code{#p"LOGICAL-HOST:absolute;path;to;component.lisp"}.
1121 You only have to specify such logical pathname
1122 for your system or some top-level component.
1123 Sub-components' relative pathnames,
1124 specified using the string syntax for names,
1125 will be properly merged with the pathnames of their parents.
1126 The specification of a logical pathname host however is @emph{not}
1127 otherwise directly supported in the ASDF syntax
1128 for pathname specifiers as strings.
1130 The @code{asdf-output-translation} layer will
1131 avoid trying to resolve and translate logical pathnames.
1132 The advantage of this is that
1133 you can define yourself what translations you want to use
1134 with the logical pathname facility.
1135 The disadvantage is that if you do not define such translations,
1136 any system that uses logical pathnames will behave differently under
1137 asdf-output-translations than other systems you use.
1139 If you wish to use logical pathnames you will have to configure the
1140 translations yourself before they may be used.
1141 ASDF currently provides no specific support
1142 for defining logical pathname translations.
1144 Note that the reasons we do not recommend logical pathnames are that
1145 (1) there is no portable way to set up logical pathnames before they are used,
1146 (2) logical pathnames are limited to only portably use
1147 a single character case, digits and hyphens.
1148 While you can solve the first issue on your own,
1149 describing how to do it on each of fifteen implementations supported by ASDF
1150 is more than we can document.
1151 As for the second issue, mind that the limitation is notably enforced on SBCL,
1152 and that you therefore can't portably violate the limitations
1153 but must instead define some encoding of your own and add individual mappings
1154 to name physical pathnames that do not fit the restrictions.
1155 This can notably be a problem when your Lisp files are part of a larger project
1156 in which it is common to name files or directories in a way that
1157 includes the version numbers of supported protocols,
1158 or in which files are shared with software written
1159 in different programming languages where conventions include the use of
1160 underscores, dots or CamelCase in pathnames.
1163 @subsection Serial dependencies
1164 @cindex serial dependencies
1166 If the @code{:serial t} option is specified for a module,
1167 ASDF will add dependencies for each child component,
1168 on all the children textually preceding it.
1169 This is done as if by @code{:depends-on}.
1173 :components ((:file "a") (:file "b") (:file "c"))
1179 :components ((:file "a")
1180 (:file "b" :depends-on ("a"))
1181 (:file "c" :depends-on ("a" "b")))
1185 @subsection Source location
1187 The @code{:pathname} option is optional in all cases for systems
1188 defined via @code{defsystem},
1189 and in the usual case the user is recommended not to supply it.
1191 Instead, ASDF follows a hairy set of rules that are designed so that
1195 will load a system from disk
1196 and have its pathname default to the right place.
1198 This pathname information will not be overwritten with
1199 @code{*default-pathname-defaults*}
1200 (which could be somewhere else altogether)
1201 if the user loads up the @file{.asd} file into his editor
1202 and interactively re-evaluates that form.
1205 If a system is being loaded for the first time,
1206 its top-level pathname will be set to:
1210 The host/device/directory parts of @code{*load-truename*},
1213 @code{*default-pathname-defaults*}, otherwise.
1216 If a system is being redefined, the top-level pathname will be
1220 changed, if explicitly supplied or obtained from @code{*load-truename*}
1221 (so that an updated source location is reflected in the system definition)
1223 changed if it had previously been set from @code{*default-pathname-defaults*}
1225 left as before, if it had previously been set from @code{*load-truename*}
1226 and @code{*load-truename*} is currently unbound
1227 (so that a developer can evaluate a @code{defsystem} form
1228 from within an editor without clobbering its source location)
1231 @subsection if-component-dep-fails option
1233 This option is only appropriate for module components (including
1234 systems), not individual source files.
1236 For more information about this option, @pxref{Pre-defined subclasses of component}.
1238 @node Other code in .asd files, , The defsystem grammar, Defining systems with defsystem
1239 @section Other code in .asd files
1241 Files containing @code{defsystem} forms
1242 are regular Lisp files that are executed by @code{load}.
1243 Consequently, you can put whatever Lisp code you like into these files
1244 (e.g., code that examines the compile-time environment
1245 and adds appropriate features to @code{*features*}).
1246 However, some conventions should be followed,
1247 so that users can control certain details of execution
1248 of the Lisp in @file{.asd} files:
1252 Any informative output
1253 (other than warnings and errors,
1254 which are the condition system's to dispose of)
1255 should be sent to the standard CL stream @code{*standard-output*},
1256 so that users can easily control the disposition
1257 of output from ASDF operations.
1261 @node The object model of ASDF, Controlling where ASDF searches for systems, Defining systems with defsystem, Top
1262 @comment node-name, next, previous, up
1263 @chapter The object model of ASDF
1265 ASDF is designed in an object-oriented way from the ground up.
1266 Both a system's structure and the operations that can be performed on systems
1268 ASDF is extensible to new operations and to new component types.
1269 This allows the addition of behaviours:
1270 for example, a new component could be added for Java JAR archives,
1271 and methods specialised on @code{compile-op} added for it
1272 that would accomplish the relevant actions.
1274 This chapter deals with @emph{components}, the building blocks of a system,
1275 and @emph{operations}, the actions that can be performed on a system.
1285 @node Operations, Components, The object model of ASDF, The object model of ASDF
1286 @comment node-name, next, previous, up
1290 An @dfn{operation} object of the appropriate type is instantiated
1291 whenever the user wants to do something with a system like
1294 @item compile all its files
1295 @item load the files into a running lisp environment
1296 @item copy its source files somewhere else
1299 Operations can be invoked directly, or examined
1300 to see what their effects would be without performing them.
1301 @emph{FIXME: document how!}
1302 There are a bunch of methods specialised on operation and component type
1303 that actually do the grunt work.
1305 The operation object contains whatever state is relevant for this purpose
1306 (perhaps a list of visited nodes, for example)
1307 but primarily is a nice thing to specialise operation methods on
1308 and easier than having them all be @code{EQL} methods.
1310 Operations are invoked on systems via @code{operate}.
1312 @deffn {Generic function} @code{operate} @var{operation} @var{system} @&rest @var{initargs}
1313 @deffnx {Generic function} @code{oos} @var{operation} @var{system} @&rest @var{initargs}
1314 @code{operate} invokes @var{operation} on @var{system}.
1315 @code{oos} is a synonym for @code{operate}.
1317 @var{operation} is a symbol that is passed, along with the supplied
1318 @var{initargs}, to @code{make-instance} to create the operation object.
1319 @var{system} is a system designator.
1321 The @var{initargs} are passed to the @code{make-instance} call
1322 when creating the operation object.
1323 Note that dependencies may cause the operation
1324 to invoke other operations on the system or its components:
1325 the new operations will be created
1326 with the same @var{initargs} as the original one.
1331 * Predefined operations of ASDF::
1332 * Creating new operations::
1335 @node Predefined operations of ASDF, Creating new operations, Operations, Operations
1336 @comment node-name, next, previous, up
1337 @subsection Predefined operations of ASDF
1339 All the operations described in this section are in the @code{asdf} package.
1340 They are invoked via the @code{operate} generic function.
1343 (asdf:operate 'asdf:@var{operation-name} :@var{system-name} @{@var{operation-options ...}@})
1346 @deffn Operation @code{compile-op} @&key @code{proclamations}
1348 This operation compiles the specified component.
1349 If proclamations are supplied, they will be proclaimed.
1350 This is a good place to specify optimization settings.
1352 When creating a new component type,
1353 you should provide methods for @code{compile-op}.
1355 When @code{compile-op} is invoked,
1356 component dependencies often cause some parts of the system
1357 to be loaded as well as compiled.
1358 Invoking @code{compile-op}
1359 does not necessarily load all the parts of the system, though;
1360 use @code{load-op} to load a system.
1363 @deffn Operation @code{load-op} @&key @code{proclamations}
1365 This operation loads a system.
1367 The default methods for @code{load-op} compile files before loading them.
1368 For parity, your own methods on new component types should probably do so too.
1371 @deffn Operation @code{load-source-op}
1373 This operation will load the source for the files in a module
1374 even if the source files have been compiled.
1375 Systems sometimes have knotty dependencies
1376 which require that sources are loaded
1377 before they can be compiled.
1378 This is how you do that.
1380 If you are creating a component type,
1381 you need to implement this operation --- at least, where meaningful.
1385 @deffn Operation @code{test-op}
1387 This operation will perform some tests on the module.
1388 The default method will do nothing.
1389 The default dependency is to require
1390 @code{load-op} to be performed on the module first.
1391 The default @code{operation-done-p} is that the operation is @emph{never} done
1393 we assume that if you invoke the @code{test-op},
1394 you want to test the system, even if you have already done so.
1396 The results of this operation are not defined by ASDF.
1397 It has proven difficult to define how the test operation
1398 should signal its results to the user
1399 in a way that is compatible with all of the various test libraries
1400 and test techniques in use in the community.
1403 @c @deffn Operation test-system-version @&key minimum
1405 @c Asks the system whether it satisfies a version requirement.
1407 @c The default method accepts a string, which is expected to contain of a
1408 @c number of integers separated by #\. characters. The method is not
1409 @c recursive. The component satisfies the version dependency if it has
1410 @c the same major number as required and each of its sub-versions is
1411 @c greater than or equal to the sub-version number required.
1414 @c (defun version-satisfies (x y)
1415 @c (labels ((bigger (x y)
1416 @c (cond ((not y) t)
1418 @c ((> (car x) (car y)) t)
1419 @c ((= (car x) (car y))
1420 @c (bigger (cdr x) (cdr y))))))
1421 @c (and (= (car x) (car y))
1422 @c (or (not (cdr y)) (bigger (cdr x) (cdr y))))))
1425 @c If that doesn't work for your system, you can override it. I hope
1426 @c you have as much fun writing the new method as @verb{|#lisp|} did
1427 @c reimplementing this one.
1430 @c @deffn Operation feature-dependent-op
1432 @c An instance of @code{feature-dependent-op} will ignore any components
1433 @c which have a @code{features} attribute, unless the feature combination
1434 @c it designates is satisfied by @code{*features*}. This operation is
1435 @c not intended to be instantiated directly, but other operations may
1440 @node Creating new operations, , Predefined operations of ASDF, Operations
1441 @comment node-name, next, previous, up
1442 @subsection Creating new operations
1444 ASDF was designed to be extensible in an object-oriented fashion.
1445 To teach ASDF new tricks, a programmer can implement the behaviour he wants
1446 by creating a subclass of @code{operation}.
1448 ASDF's pre-defined operations are in no way ``privileged'',
1449 but it is requested that developers never use the @code{asdf} package
1450 for operations they develop themselves.
1451 The rationale for this rule is that we don't want to establish a
1452 ``global asdf operation name registry'',
1453 but also want to avoid name clashes.
1455 An operation must provide methods for the following generic functions
1456 when invoked with an object of type @code{source-file}:
1457 @emph{FIXME describe this better}
1461 @item @code{output-files}
1462 The @code{output-files} method determines where the method will put its files.
1463 It returns two values, a list of pathnames, and a boolean.
1464 If the boolean is @code{T} then the pathnames are marked
1465 not be translated by enclosing @code{:around} methods.
1466 If the boolean is @code{NIL} then enclosing @code{:around} methods
1467 may translate these pathnames, e.g. to ensure object files
1468 are somehow stored in some implementation-dependent cache.
1469 @item @code{perform}
1470 The @code{perform} method must call @code{output-files}
1471 to find out where to put its files,
1472 because the user is allowed to override.
1473 @item @code{output-files}
1474 for local policy @code{explain}
1475 @item @code{operation-done-p},
1476 if you don't like the default one
1480 Operations that print output should send that output to the standard
1481 CL stream @code{*standard-output*}, as the Lisp compiler and loader do.
1483 @node Components, Functions, Operations, The object model of ASDF
1484 @comment node-name, next, previous, up
1488 @cindex system designator
1489 @vindex *system-definition-search-functions*
1491 A @dfn{component} represents a source file or
1492 (recursively) a collection of components.
1493 A @dfn{system} is (roughly speaking) a top-level component
1494 that can be found via @code{find-system}.
1496 A @dfn{system designator} is a string or symbol
1497 and behaves just like any other component name
1498 (including with regard to the case conversion rules for component names).
1501 @defun find-system system-designator &optional (error-p t)
1503 Given a system designator, @code{find-system} finds and returns a system.
1504 If no system is found, an error of type
1505 @code{missing-component} is thrown,
1506 or @code{nil} is returned if @code{error-p} is false.
1508 To find and update systems, @code{find-system} funcalls each element
1509 in the @code{*system-definition-search-functions*} list,
1510 expecting a pathname to be returned, or a system object,
1511 from which a pathname may be extracted, and that will be registered.
1512 The resulting pathname (if any) is loaded
1513 if one of the following conditions is true:
1517 there is no system of that name in memory
1519 the pathname is different from that which was previously loaded
1521 the file's @code{last-modified} time exceeds the @code{last-modified} time
1522 of the system in memory
1525 When system definitions are loaded from @file{.asd} files,
1526 a new scratch package is created for them to load into,
1527 so that different systems do not overwrite each others operations.
1528 The user may also wish to (and is recommended to)
1529 include @code{defpackage} and @code{in-package} forms
1530 in his system definition files, however,
1531 so that they can be loaded manually if need be.
1533 The default value of @code{*system-definition-search-functions*}
1534 is a list of two functions.
1535 The first function looks in each of the directories given
1536 by evaluating members of @code{*central-registry*}
1537 for a file whose name is the name of the system and whose type is @file{asd}.
1538 The first such file is returned,
1539 whether or not it turns out to actually define the appropriate system.
1540 The second function does something similar,
1541 for the directories specified in the @code{source-registry}.
1542 Hence, it is strongly advised to define a system
1543 @var{foo} in the corresponding file @var{foo.asd}.
1548 * Common attributes of components::
1549 * Pre-defined subclasses of component::
1550 * Creating new component types::
1553 @node Common attributes of components, Pre-defined subclasses of component, Components, Components
1554 @comment node-name, next, previous, up
1555 @subsection Common attributes of components
1557 All components, regardless of type, have the following attributes.
1558 All attributes except @code{name} are optional.
1562 A component name is a string or a symbol.
1563 If a symbol, its name is taken and lowercased.
1565 Unless overridden by a @code{:pathname} attribute,
1566 the name will be interpreted as a pathname specifier according
1567 to a Unix-style syntax.
1568 @xref{The defsystem grammar,,Pathname specifiers}.
1570 @subsubsection Version identifier
1571 @findex version-satisfies
1574 This optional attribute is used by the generic function
1575 @code{version-satisfies}, which tests to see if @code{:version}
1576 dependencies are satisfied.
1577 the version should be a string of integers separated by dots,
1578 for example @samp{1.0.11}.
1579 For more information on the semantics of version specifiers, see @ref{The defsystem grammar}.
1581 @c This optional attribute is intended to be used by the @code{test-system-version} operation.
1582 @c @xref{Predefined operations of ASDF}.
1583 @c @emph{Nota Bene}:
1584 @c This operation, planned for ASDF 1,
1585 @c is still not implemented yet as of ASDF 2.
1586 @c Don't hold your breath.
1590 @subsubsection Required features
1592 @emph{FIXME: This subsection seems to contradict the
1593 @code{defsystem} grammar subsection,
1594 which doesn't provide any obvious way to specify required features.
1595 Furthermore, in 2009, discussions on the
1596 @url{http://common-lisp.net/cgi-bin/mailman/listinfo/asdf-devel,asdf-devel mailing list}
1597 suggested that the specification of required features may be broken,
1598 and that no one may have been using them for a while.
1600 @url{http://common-lisp.net/cgi-bin/mailman/listinfo/asdf-devel,asdf-devel mailing list}
1601 if you are interested in getting this features feature fixed.}
1603 Traditionally defsystem users have used reader conditionals
1604 to include or exclude specific per-implementation files.
1605 This means that any single implementation cannot read the entire system,
1606 which becomes a problem if it doesn't wish to compile it,
1607 but instead for example to create an archive file containing all the sources,
1608 as it will omit to process the system-dependent sources for other systems.
1610 Each component in an asdf system may therefore specify features using
1611 the same syntax as @code{#+} does, and it will (somehow) be ignored for
1612 certain operations unless the feature conditional is a member of
1616 @subsubsection Dependencies
1618 This attribute specifies dependencies of the component on its siblings.
1619 It is optional but often necessary.
1621 There is an excitingly complicated relationship between the initarg
1622 and the method that you use to ask about dependencies
1624 Dependencies are between (operation component) pairs.
1625 In your initargs for the component, you can say
1628 :in-order-to ((compile-op (load-op "a" "b") (compile-op "c"))
1629 (load-op (load-op "foo")))
1632 This means the following things:
1635 before performing compile-op on this component, we must perform
1636 load-op on @var{a} and @var{b}, and compile-op on @var{c},
1638 before performing @code{load-op}, we have to load @var{foo}
1641 The syntax is approximately
1644 (this-op {(other-op required-components)}+)
1646 simple-component-name := string
1649 required-components := simple-component-name
1650 | (required-components required-components)
1652 component-name := simple-component-name
1653 | (:version simple-component-name minimum-version-object)
1658 This is on a par with what ACL defsystem does.
1659 mk-defsystem is less general: it has an implied dependency
1662 for all x, (load x) depends on (compile x)
1665 and using a @code{:depends-on} argument to say that @var{b} depends on
1666 @var{a} @emph{actually} means that
1669 (compile b) depends on (load a)
1672 This is insufficient for e.g. the McCLIM system, which requires that
1673 all the files are loaded before any of them can be compiled ]
1677 In ASDF, the dependency information for a given component and operation
1678 can be queried using @code{(component-depends-on operation component)},
1679 which returns a list
1682 ((load-op "a") (load-op "b") (compile-op "c") ...)
1685 @code{component-depends-on} can be subclassed for more specific
1686 component/operation types: these need to @code{(call-next-method)}
1687 and append the answer to their dependency, unless
1688 they have a good reason for completely overriding the default dependencies.
1690 If it weren't for CLISP, we'd be using @code{LIST} method
1691 combination to do this transparently.
1692 But, we need to support CLISP.
1693 If you have the time for some CLISP hacking,
1694 I'm sure they'd welcome your fixes.
1695 @c Doesn't CLISP now support LIST method combination?
1697 See the discussion of the semantics of @code{:version} in the defsystem
1700 @c FIXME: Should have cross-reference to "Version specifiers" in the
1701 @c defsystem grammar, but the cross-referencing is so broken by
1702 @c insufficient node breakdown that I have not put one in.
1705 @subsubsection pathname
1707 This attribute is optional and if absent (which is the usual case),
1708 the component name will be used.
1710 @xref{The defsystem grammar,,Pathname specifiers},
1711 for an explanation of how this attribute is interpreted.
1713 Note that the @code{defsystem} macro (used to create a ``top-level'' system)
1714 does additional processing to set the filesystem location of
1715 the top component in that system.
1716 This is detailed elsewhere. @xref{Defining systems with defsystem}.
1719 @subsubsection properties
1721 This attribute is optional.
1723 Packaging systems often require information about files or systems
1724 in addition to that specified by ASDF's pre-defined component attributes.
1725 Programs that create vendor packages out of ASDF systems therefore
1726 have to create ``placeholder'' information to satisfy these systems.
1727 Sometimes the creator of an ASDF system may know the additional
1728 information and wish to provide it directly.
1730 @code{(component-property component property-name)} and
1731 associated @code{setf} method will allow
1732 the programmatic update of this information.
1733 Property names are compared as if by @code{EQL},
1734 so use symbols or keywords or something.
1737 * Pre-defined subclasses of component::
1738 * Creating new component types::
1741 @node Pre-defined subclasses of component, Creating new component types, Common attributes of components, Components
1742 @comment node-name, next, previous, up
1743 @subsection Pre-defined subclasses of component
1745 @deffn Component source-file
1747 A source file is any file that the system does not know how to
1748 generate from other components of the system.
1750 Note that this is not necessarily the same thing as
1751 ``a file containing data that is typically fed to a compiler''.
1752 If a file is generated by some pre-processor stage
1753 (e.g. a @file{.h} file from @file{.h.in} by autoconf)
1754 then it is not, by this definition, a source file.
1755 Conversely, we might have a graphic file
1756 that cannot be automatically regenerated,
1757 or a proprietary shared library that we received as a binary:
1758 these do count as source files for our purposes.
1760 Subclasses of source-file exist for various languages.
1761 @emph{FIXME: describe these.}
1764 @deffn Component module
1766 A module is a collection of sub-components.
1768 A module component has the following extra initargs:
1772 @code{:components} the components contained in this module
1775 @code{:default-component-class}
1776 All children components which don't specify their class explicitly
1777 are inferred to be of this type.
1780 @code{:if-component-dep-fails}
1781 This attribute takes one of the values
1782 @code{:fail}, @code{:try-next}, @code{:ignore},
1783 its default value is @code{:fail}.
1784 The other values can be used for implementing conditional compilation
1785 based on implementation @code{*features*},
1786 for the case where it is not necessary for all files in a module to be
1788 @emph{FIXME: such conditional compilation has been reported
1789 to be broken in 2009.}
1792 @code{:serial} When this attribute is set,
1793 each subcomponent of this component is assumed to depend on all subcomponents
1794 before it in the list given to @code{:components}, i.e.
1795 all of them are loaded before a compile or load operation is performed on it.
1799 The default operation knows how to traverse a module, so
1800 most operations will not need to provide methods specialised on modules.
1802 @code{module} may be subclassed to represent components such as
1803 foreign-language linked libraries or archive files.
1806 @deffn Component system
1808 @code{system} is a subclass of @code{module}.
1810 A system is a module with a few extra attributes for documentation
1811 purposes; these are given elsewhere.
1812 @xref{The defsystem grammar}.
1814 Users can create new classes for their systems:
1815 the default @code{defsystem} macro takes a @code{:class} keyword argument.
1818 @node Creating new component types, , Pre-defined subclasses of component, Components
1819 @comment node-name, next, previous, up
1820 @subsection Creating new component types
1822 New component types are defined by subclassing one of the existing
1823 component classes and specializing methods on the new component class.
1825 @emph{FIXME: this should perhaps be explained more throughly,
1826 not only by example ...}
1828 As an example, suppose we have some implementation-dependent
1829 functionality that we want to isolate
1830 in one subdirectory per Lisp implementation our system supports.
1831 We create a subclass of
1832 @code{cl-source-file}:
1835 (defclass unportable-cl-source-file (cl-source-file)
1839 Function @code{asdf:implementation-type} (exported since 2.014.14)
1840 gives us the name of the subdirectory.
1841 All that's left is to define how to calculate the pathname
1842 of an @code{unportable-cl-source-file}.
1845 (defmethod component-pathname ((component unportable-cl-source-file))
1847 (coerce-pathname (format nil "~(~A~)/" (asdf:implementation-type)))
1848 (call-next-method)))
1851 The new component type is used in a @code{defsystem} form in this way:
1858 (:unportable-cl-source-file "threads"
1859 :depends-on ("packages" ...))
1864 @node Functions, , Components, The object model of ASDF
1865 @comment node-name, next, previous, up
1867 @findex version-satisfies
1869 @deffn version-satisfies @var{version} @var{version-spec}
1870 Does @var{version} satisfy the @var{version-spec}. A generic function.
1871 ASDF provides built-in methods for @var{version} being a
1872 @code{component} or @code{string}. @var{version-spec} should be a
1875 In the wild, we typically see version numbering only on components of
1878 For more information about how @code{version-satisfies} interprets
1879 version strings and specifications, @pxref{The defsystem grammar} and
1880 @ref{Common attributes of components}.
1883 @node Controlling where ASDF searches for systems, Controlling where ASDF saves compiled files, The object model of ASDF, Top
1884 @comment node-name, next, previous, up
1885 @chapter Controlling where ASDF searches for systems
1887 @section Configurations
1889 Configurations specify paths where to find system files.
1894 The search registry may use some hardcoded wrapping registry specification.
1895 This allows some implementations (notably SBCL) to specify where to find
1896 some special implementation-provided systems that
1897 need to precisely match the version of the implementation itself.
1900 An application may explicitly initialize the source-registry configuration
1901 using the configuration API
1902 (@pxref{Controlling where ASDF searches for systems,Configuration API,Configuration API}, below)
1903 in which case this takes precedence.
1904 It may itself compute this configuration from the command-line,
1905 from a script, from its own configuration file, etc.
1908 The source registry will be configured from
1909 the environment variable @code{CL_SOURCE_REGISTRY} if it exists.
1912 The source registry will be configured from
1913 user configuration file
1914 @file{$XDG_CONFIG_DIRS/common-lisp/source-registry.conf}
1916 @file{~/.config/common-lisp/source-registry.conf})
1920 The source registry will be configured from
1921 user configuration directory
1922 @file{$XDG_CONFIG_DIRS/common-lisp/source-registry.conf.d/}
1924 @file{~/.config/common-lisp/source-registry.conf.d/})
1928 The source registry will be configured from
1929 system configuration file
1930 @file{/etc/common-lisp/source-registry.conf}
1934 The source registry will be configured from
1935 system configuration directory
1936 @file{/etc/common-lisp/source-registry.conf.d/}
1940 The source registry will be configured from a default configuration.
1941 This configuration may allow for implementation-specific systems
1942 to be found, for systems to be found the current directory
1943 (at the time that the configuration is initialized) as well as
1944 @code{:directory} entries for @file{$XDG_DATA_DIRS/common-lisp/systems/} and
1945 @code{:tree} entries for @file{$XDG_DATA_DIRS/common-lisp/source/}.
1946 For instance, SBCL will include directories for its contribs
1947 when it can find them; it will look for them where SBCL was installed,
1948 or at the location specified by the @code{SBCL_HOME} environment variable.
1952 Each of these configurations is specified as an s-expression
1953 in a trivial domain-specific language (defined below).
1954 Additionally, a more shell-friendly syntax is available
1955 for the environment variable (defined yet below).
1957 Each of these configurations is only used if the previous
1958 configuration explicitly or implicitly specifies that it
1959 includes its inherited configuration.
1961 Additionally, some implementation-specific directories
1962 may be automatically prepended to whatever directories are specified
1963 in configuration files, no matter if the last one inherits or not.
1965 @section XDG base directory
1967 Note that we purport to respect the XDG base directory specification
1968 as to where configuration files are located,
1969 where data files are located,
1970 where output file caches are located.
1971 Mentions of XDG variables refer to that document.
1973 @url{http://standards.freedesktop.org/basedir-spec/basedir-spec-latest.html}
1975 This specification allows the user to specify some environment variables
1976 to customize how applications behave to his preferences.
1978 On Windows platforms, when not using Cygwin,
1979 instead of the XDG base directory specification,
1980 we try to use folder configuration from the registry regarding
1981 @code{Common AppData} and similar directories.
1982 However, support for querying the Windows registry is limited as of ASDF 2,
1983 and on many implementations, we may fall back to always using the defaults
1984 without consulting the registry.
1987 @section Backward Compatibility
1989 For backward compatibility as well as to provide a practical backdoor for hackers,
1990 ASDF will first search for @code{.asd} files in the directories specified in
1991 @code{asdf:*central-registry*}
1992 before it searches in the source registry above.
1994 @xref{Configuring ASDF,,Configuring ASDF to find your systems --- old style}.
1996 By default, @code{asdf:*central-registry*} will be empty.
1998 This old mechanism will therefore not affect you if you don't use it,
1999 but will take precedence over the new mechanism if you do use it.
2001 @section Configuration DSL
2003 Here is the grammar of the s-expression (SEXP) DSL for source-registry
2006 @c FIXME: This is too wide for happy compilation into pdf.
2009 ;; A configuration is a single SEXP starting with keyword :source-registry
2010 ;; followed by a list of directives.
2011 CONFIGURATION := (:source-registry DIRECTIVE ...)
2013 ;; A directive is one of the following:
2015 ;; INHERITANCE DIRECTIVE:
2016 ;; Your configuration expression MUST contain
2017 ;; exactly one of either of these:
2018 :inherit-configuration | ; splices inherited configuration (often specified last)
2019 :ignore-inherited-configuration | ; drop inherited configuration (specified anywhere)
2021 ;; forward compatibility directive (since ASDF 2.011.4), useful when
2022 ;; you want to use new configuration features but have to bootstrap a
2023 ;; the newer required ASDF from an older release that doesn't sport said features:
2024 :ignore-invalid-entries | ; drops subsequent invalid entries instead of erroring out
2026 ;; add a single directory to be scanned (no recursion)
2027 (:directory DIRECTORY-PATHNAME-DESIGNATOR) |
2029 ;; add a directory hierarchy, recursing but excluding specified patterns
2030 (:tree DIRECTORY-PATHNAME-DESIGNATOR) |
2032 ;; override the defaults for exclusion patterns
2033 (:exclude EXCLUSION-PATTERN ...) |
2034 ;; augment the defaults for exclusion patterns
2035 (:also-exclude EXCLUSION-PATTERN ...) |
2036 ;; Note that the scope of a an exclude pattern specification is
2037 ;; the rest of the current configuration expression or file.
2039 ;; splice the parsed contents of another config file
2040 (:include REGULAR-FILE-PATHNAME-DESIGNATOR) |
2042 ;; This directive specifies that some default must be spliced.
2045 REGULAR-FILE-PATHNAME-DESIGNATOR := PATHNAME-DESIGNATOR ;; interpreted as a file
2046 DIRECTORY-PATHNAME-DESIGNATOR := PATHNAME-DESIGNATOR ;; interpreted as a directory name
2048 PATHNAME-DESIGNATOR :=
2049 NIL | ;; Special: skip this entry.
2050 ABSOLUTE-COMPONENT-DESIGNATOR ;; see pathname DSL
2052 EXCLUSION-PATTERN := a string without wildcards, that will be matched exactly
2053 against the name of a any subdirectory in the directory component
2054 of a path. e.g. @code{"_darcs"} will match @file{#p"/foo/bar/_darcs/src/bar.asd"}
2057 Pathnames are designated using another DSL,
2058 shared with the output-translations configuration DSL below.
2059 The DSL is resolved by the function @code{asdf::resolve-location},
2060 to be documented and exported at some point in the future.
2063 ABSOLUTE-COMPONENT-DESIGNATOR :=
2064 (ABSOLUTE-COMPONENT-DESIGNATOR RELATIVE-COMPONENT-DESIGNATOR ...) |
2065 STRING | ;; namestring (better be absolute or bust, directory assumed where applicable).
2066 ;; In output-translations, directory is assumed and **/*.*.* added if it's last.
2067 ;; On MCL, a MacOSX-style POSIX namestring (for MacOS9 style, use #p"...");
2068 ;; Note that none of the above applies to strings used in *central-registry*,
2069 ;; which doesn't use this DSL: they are processed as normal namestrings.
2070 ;; however, you can compute what you put in the *central-registry*
2071 ;; based on the results of say (asdf::resolve-location "/Users/fare/cl/cl-foo/")
2072 PATHNAME | ;; pathname (better be an absolute path, or bust)
2073 ;; In output-translations, unless followed by relative components,
2074 ;; it better have appropriate wildcards, as in **/*.*.*
2075 :HOME | ;; designates the user-homedir-pathname ~/
2076 :USER-CACHE | ;; designates the default location for the user cache
2077 :HERE | ;; designates the location of the configuration file
2078 ;; (or *default-pathname-defaults*, if invoked interactively)
2079 :ROOT ;; magic, for output-translations source only: paths that are relative
2080 ;; to the root of the source host and device
2081 ;; Not valid anymore: :SYSTEM-CACHE (was a security hazard)
2083 RELATIVE-COMPONENT-DESIGNATOR :=
2084 (RELATIVE-COMPONENT-DESIGNATOR RELATIVE-COMPONENT-DESIGNATOR ...) |
2085 STRING | ;; relative directory pathname as interpreted by coerce-pathname.
2086 ;; In output translations, if last component, **/*.*.* is added
2087 PATHNAME | ;; pathname; unless last component, directory is assumed.
2088 :IMPLEMENTATION | ;; directory based on implementation, e.g. sbcl-1.0.45-linux-x64
2089 :IMPLEMENTATION-TYPE | ;; a directory based on lisp-implementation-type only, e.g. sbcl
2090 :DEFAULT-DIRECTORY | ;; a relativized version of the default directory
2091 :*/ | ;; any direct subdirectory (since ASDF 2.011.4)
2092 :**/ | ;; any recursively inferior subdirectory (since ASDF 2.011.4)
2093 :*.*.* | ;; any file (since ASDF 2.011.4)
2094 ;; Not supported (anymore): :UID and :USERNAME
2097 For instance, as a simple case, my @file{~/.config/common-lisp/source-registry.conf},
2098 which is the default place ASDF looks for this configuration, once contained:
2101 (:tree (:home "cl")) ;; will expand to e.g. "/home/joeluser/cl/"
2102 :inherit-configuration)
2105 @section Configuration Directories
2107 Configuration directories consist in files each containing
2108 a list of directives without any enclosing @code{(:source-registry ...)} form.
2109 The files will be sorted by namestring as if by @code{string<} and
2110 the lists of directives of these files with be concatenated in order.
2111 An implicit @code{:inherit-configuration} will be included
2112 at the @emph{end} of the list.
2114 This allows for packaging software that has file granularity
2115 (e.g. Debian's @code{dpkg} or some future version of @code{clbuild})
2116 to easily include configuration information about distributed software.
2118 The convention is that, for sorting purposes,
2119 the names of files in such a directory begin with two digits
2120 that determine the order in which these entries will be read.
2121 Also, the type of these files is conventionally @code{"conf"}
2122 and as a limitation to some implementations (e.g. GNU clisp),
2123 the type cannot be @code{NIL}.
2125 Directories may be included by specifying a directory pathname
2126 or namestring in an @code{:include} directive, e.g.:
2129 (:include "/foo/bar/")
2132 Hence, to achieve the same effect as
2133 my example @file{~/.config/common-lisp/source-registry.conf} above,
2134 I could simply create a file
2135 @file{~/.config/common-lisp/source-registry.conf.d/33-home-fare-cl.conf}
2136 alone in its directory with the following contents:
2138 (:tree "/home/fare/cl/")
2141 @subsection The :here directive
2143 The @code{:here} directive is an absolute pathname designator that
2144 refers to the directory containing the configuration file currently
2147 The @code{:here} directive is intended to simplify the delivery of
2148 complex CL systems, and for easy configuration of projects shared through
2149 revision control systems, in accordance with our design principle that
2150 each participant should be able to provide all and only the information
2151 available to him or her.
2153 Consider a person X who has set up the source code repository for a
2154 complex project with a master directory @file{dir/}. Ordinarily, one
2155 might simply have the user add a directive that would look something
2158 (:tree "path/to/dir")
2160 But what if X knows that there are very large subtrees
2161 under dir that are filled with, e.g., Java source code, image files for
2162 icons, etc.? All of the asdf system definitions are contained in the
2163 subdirectories @file{dir/src/lisp/} and @file{dir/extlib/lisp/}, and
2164 these are the only directories that should be searched.
2166 In this case, X can put into @file{dir/} a file @file{asdf.conf} that
2167 contains the following:
2170 (:tree (:here "src/lisp/"))
2171 (:tree (:here "extlib/lisp"))
2172 (:directory (:here "outlier/")))
2175 Then when someone else (call her Y) checks out a copy of this
2176 repository, she need only add
2178 (:include "/path/to/my/checkout/directory/asdf.conf")
2180 to one of her previously-existing asdf source location configuration
2181 files, or invoke @code{initialize-source-registry} with a configuration
2182 form containing that s-expression. ASDF will find the .conf file that X
2183 has provided, and then set up source locations within the working
2184 directory according to X's (relative) instructions.
2186 @section Shell-friendly syntax for configuration
2188 When considering environment variable @code{CL_SOURCE_REGISTRY}
2189 ASDF will skip to next configuration if it's an empty string.
2190 It will @code{READ} the string as a SEXP in the DSL
2191 if it begins with a paren @code{(}
2192 and it will be interpreted much like @code{TEXINPUTS}
2193 list of paths, where
2195 * paths are separated
2196 by a @code{:} (colon) on Unix platforms (including cygwin),
2197 by a @code{;} (semicolon) on other platforms (mainly, Windows).
2199 * each entry is a directory to add to the search path.
2201 * if the entry ends with a double slash @code{//}
2202 then it instead indicates a tree in the subdirectories
2203 of which to recurse.
2205 * if the entry is the empty string (which may only appear once),
2206 then it indicates that the inherited configuration should be
2210 @section Search Algorithm
2211 @vindex *default-source-registry-exclusions*
2213 In case that isn't clear, the semantics of the configuration is that
2214 when searching for a system of a given name,
2215 directives are processed in order.
2217 When looking in a directory, if the system is found, the search succeeds,
2218 otherwise it continues.
2220 When looking in a tree, if one system is found, the search succeeds.
2221 If multiple systems are found, the consequences are unspecified:
2222 the search may succeed with any of the found systems,
2223 or an error may be raised.
2224 ASDF currently returns the first system found,
2225 XCVB currently raised an error.
2226 If none is found, the search continues.
2228 Exclude statements specify patterns of subdirectories
2229 the systems from which to ignore.
2230 Typically you don't want to use copies of files kept by such
2231 version control systems as Darcs.
2232 Exclude statements are not propagated to further included or inherited
2233 configuration files or expressions;
2234 instead the defaults are reset around every configuration statement
2235 to the default defaults from @code{asdf::*default-source-registry-exclusions*}.
2237 Include statements cause the search to recurse with the path specifications
2238 from the file specified.
2240 An inherit-configuration statement cause the search to recurse with the path
2241 specifications from the next configuration
2242 (@pxref{Controlling where ASDF searches for systems,,Configurations} above).
2245 @section Caching Results
2247 The implementation is allowed to either eagerly compute the information
2248 from the configurations and file system, or to lazily re-compute it
2249 every time, or to cache any part of it as it goes.
2250 To explicitly flush any information cached by the system, use the API below.
2253 @section Configuration API
2255 The specified functions are exported from your build system's package.
2256 Thus for ASDF the corresponding functions are in package ASDF,
2257 and for XCVB the corresponding functions are in package XCVB.
2259 @defun initialize-source-registry @&optional PARAMETER
2260 will read the configuration and initialize all internal variables.
2261 You may extend or override configuration
2262 from the environment and configuration files
2263 with the given @var{PARAMETER}, which can be
2264 @code{NIL} (no configuration override),
2265 or a SEXP (in the SEXP DSL),
2266 a string (as in the string DSL),
2267 a pathname (of a file or directory with configuration),
2268 or a symbol (fbound to function that when called returns one of the above).
2271 @defun clear-source-registry
2272 undoes any source registry configuration
2273 and clears any cache for the search algorithm.
2274 You might want to call this function
2275 (or better, @code{clear-configuration})
2276 before you dump an image that would be resumed
2277 with a different configuration,
2278 and return an empty configuration.
2279 Note that this does not include clearing information about
2280 systems defined in the current image, only about
2281 where to look for systems not yet defined.
2284 @defun ensure-source-registry @&optional PARAMETER
2285 checks whether a source registry has been initialized.
2286 If not, initialize it with the given @var{PARAMETER}.
2289 Every time you use ASDF's @code{find-system}, or
2290 anything that uses it (such as @code{operate}, @code{load-system}, etc.),
2291 @code{ensure-source-registry} is called with parameter NIL,
2292 which the first time around causes your configuration to be read.
2293 If you change a configuration file,
2294 you need to explicitly @code{initialize-source-registry} again,
2295 or maybe simply to @code{clear-source-registry} (or @code{clear-configuration})
2296 which will cause the initialization to happen next time around.
2301 If this mechanism is successful, in the future, we may declare
2302 @code{asdf:*central-registry*} obsolete and eventually remove it.
2303 Any hook into implementation-specific search mechanisms will by then
2304 have been integrated in the @code{:default-configuration} which everyone
2305 should either explicitly use or implicit inherit. Some shell syntax
2306 for it should probably be added somehow.
2308 But we're not there yet. For now, let's see how practical this new
2312 @section Rejected ideas
2314 Alternatives I considered and rejected included:
2317 @item Keep @code{asdf:*central-registry*} as the master with its current semantics,
2318 and somehow the configuration parser expands the new configuration
2319 language into a expanded series of directories of subdirectories to
2320 lookup, pre-recursing through specified hierarchies. This is kludgy,
2321 and leaves little space of future cleanups and extensions.
2323 @item Keep @code{asdf:*central-registry*} remains the master but extend its semantics
2324 in completely new ways, so that new kinds of entries may be implemented
2325 as a recursive search, etc. This seems somewhat backwards.
2327 @item Completely remove @code{asdf:*central-registry*}
2328 and break backwards compatibility.
2329 Hopefully this will happen in a few years after everyone migrate to
2330 a better ASDF and/or to XCVB, but it would be very bad to do it now.
2332 @item Replace @code{asdf:*central-registry*} by a symbol-macro with appropriate magic
2333 when you dereference it or setf it. Only the new variable with new
2334 semantics is handled by the new search procedure.
2335 Complex and still introduces subtle semantic issues.
2339 I've been suggested the below features, but have rejected them,
2340 for the sake of keeping ASDF no more complex than strictly necessary.
2344 More syntactic sugar: synonyms for the configuration directives, such as
2345 @code{(:add-directory X)} for @code{(:directory X)}, or @code{(:add-directory-hierarchy X)}
2346 or @code{(:add-directory X :recurse t)} for @code{(:tree X)}.
2349 The possibility to register individual files instead of directories.
2352 Integrate Xach Beane's tilde expander into the parser,
2353 or something similar that is shell-friendly or shell-compatible.
2354 I'd rather keep ASDF minimal. But maybe this precisely keeps it
2355 minimal by removing the need for evaluated entries that ASDF has?
2356 i.e. uses of @code{USER-HOMEDIR-PATHNAME} and @code{$SBCL_HOME}
2357 Hopefully, these are already superseded by the @code{:default-registry}
2360 Using the shell-unfriendly syntax @code{/**} instead of @code{//} to specify recursion
2361 down a filesystem tree in the environment variable.
2362 It isn't that Lisp friendly either.
2372 @section Credits for the source-registry
2374 Thanks a lot to Stelian Ionescu for the initial idea.
2376 Thanks to Rommel Martinez for the initial implementation attempt.
2378 All bad design ideas and implementation bugs are to mine, not theirs.
2379 But so are good design ideas and elegant implementation tricks.
2381 --- Francois-Rene Rideau @email{fare@@tunes.org}, Mon, 22 Feb 2010 00:07:33 -0500
2385 @node Controlling where ASDF saves compiled files, Error handling, Controlling where ASDF searches for systems, Top
2386 @comment node-name, next, previous, up
2387 @chapter Controlling where ASDF saves compiled files
2388 @cindex asdf-output-translations
2389 @vindex ASDF_OUTPUT_TRANSLATIONS
2391 Each Common Lisp implementation has its own format
2392 for compiled files (fasls for short, short for ``fast loading'').
2393 If you use multiple implementations
2394 (or multiple versions of the same implementation),
2395 you'll soon find your source directories
2396 littered with various @file{fasl}s, @file{dfsl}s, @file{cfsl}s and so on.
2397 Worse yet, some implementations use the same file extension
2398 while changing formats from version to version (or platform to platform)
2399 which means that you'll have to recompile binaries
2400 as you switch from one implementation to the next.
2402 ASDF 2 includes the @code{asdf-output-translations} facility
2403 to mitigate the problem.
2405 @section Configurations
2407 Configurations specify mappings from input locations to output locations.
2408 Once again we rely on the XDG base directory specification for configuration.
2409 @xref{Controlling where ASDF searches for systems,,XDG base directory}.
2414 Some hardcoded wrapping output translations configuration may be used.
2415 This allows special output translations (or usually, invariant directories)
2416 to be specified corresponding to the similar special entries in the source registry.
2419 An application may explicitly initialize the output-translations
2420 configuration using the Configuration API
2421 in which case this takes precedence.
2422 (@pxref{Controlling where ASDF saves compiled files,,Configuration API}.)
2423 It may itself compute this configuration from the command-line,
2424 from a script, from its own configuration file, etc.
2427 The source registry will be configured from
2428 the environment variable @code{ASDF_OUTPUT_TRANSLATIONS} if it exists.
2431 The source registry will be configured from
2432 user configuration file
2433 @file{$XDG_CONFIG_DIRS/common-lisp/asdf-output-translations.conf}
2435 @file{~/.config/common-lisp/asdf-output-translations.conf})
2439 The source registry will be configured from
2440 user configuration directory
2441 @file{$XDG_CONFIG_DIRS/common-lisp/asdf-output-translations.conf.d/}
2443 @file{~/.config/common-lisp/asdf-output-translations.conf.d/})
2447 The source registry will be configured from
2448 system configuration file
2449 @file{/etc/common-lisp/asdf-output-translations.conf}
2453 The source registry will be configured from
2454 system configuration directory
2455 @file{/etc/common-lisp/asdf-output-translations.conf.d/}
2460 Each of these configurations is specified as a SEXP
2461 in a trival domain-specific language (defined below).
2462 Additionally, a more shell-friendly syntax is available
2463 for the environment variable (defined yet below).
2465 Each of these configurations is only used if the previous
2466 configuration explicitly or implicitly specifies that it
2467 includes its inherited configuration.
2469 Note that by default, a per-user cache is used for output files.
2470 This allows the seamless use of shared installations of software
2471 between several users, and takes files out of the way of the developers
2472 when they browse source code,
2473 at the expense of taking a small toll when developers have to clean up
2474 output files and find they need to get familiar with output-translations first.
2477 @section Backward Compatibility
2478 @cindex ASDF-BINARY-LOCATIONS compatibility
2481 We purposefully do NOT provide backward compatibility with earlier versions of
2482 @code{ASDF-Binary-Locations} (8 Sept 2009),
2483 @code{common-lisp-controller} (7.0) or
2484 @code{cl-launch} (2.35),
2485 each of which had similar general capabilities.
2486 The previous APIs of these programs were not designed
2487 for configuration by the end-user
2488 in an easy way with configuration files.
2489 Recent versions of same packages use
2490 the new @code{asdf-output-translations} API as defined below:
2491 @code{common-lisp-controller} (7.2) and @code{cl-launch} (3.000).
2492 @code{ASDF-Binary-Locations} is fully superseded and not to be used anymore.
2494 This incompatibility shouldn't inconvenience many people.
2495 Indeed, few people use and customize these packages;
2496 these few people are experts who can trivially adapt to the new configuration.
2497 Most people are not experts, could not properly configure these features
2498 (except inasmuch as the default configuration of
2499 @code{common-lisp-controller} and/or @code{cl-launch}
2500 might have been doing the right thing for some users),
2501 and yet will experience software that ``just works'',
2502 as configured by the system distributor, or by default.
2504 Nevertheless, if you are a fan of @code{ASDF-Binary-Locations},
2505 we provide a limited emulation mode:
2507 @defun enable-asdf-binary-locations-compatibility @&key centralize-lisp-binaries default-toplevel-directory include-per-user-information map-all-source-files source-to-target-mappings
2508 This function will initialize the new @code{asdf-output-translations} facility in a way
2509 that emulates the behavior of the old @code{ASDF-Binary-Locations} facility.
2510 Where you would previously set global variables
2511 @var{*centralize-lisp-binaries*},
2512 @var{*default-toplevel-directory*},
2513 @var{*include-per-user-information*},
2514 @var{*map-all-source-files*} or @var{*source-to-target-mappings*}
2515 you will now have to pass the same values as keyword arguments to this function.
2516 Note however that as an extension the @code{:source-to-target-mappings} keyword argument
2517 will accept any valid pathname designator for @code{asdf-output-translations}
2518 instead of just strings and pathnames.
2521 If you insist, you can also keep using the old @code{ASDF-Binary-Locations}
2522 (the one available as an extension to load of top of ASDF,
2523 not the one built into a few old versions of ASDF),
2524 but first you must disable @code{asdf-output-translations}
2525 with @code{(asdf:disable-output-translations)},
2526 or you might experience ``interesting'' issues.
2528 Also, note that output translation is enabled by default.
2529 To disable it, use @code{(asdf:disable-output-translations)}.
2532 @section Configuration DSL
2534 Here is the grammar of the SEXP DSL
2535 for @code{asdf-output-translations} configuration:
2538 ;; A configuration is single SEXP starting with keyword :source-registry
2539 ;; followed by a list of directives.
2540 CONFIGURATION := (:output-translations DIRECTIVE ...)
2542 ;; A directive is one of the following:
2544 ;; INHERITANCE DIRECTIVE:
2545 ;; Your configuration expression MUST contain
2546 ;; exactly one of either of these:
2547 :inherit-configuration | ; splices inherited configuration (often specified last)
2548 :ignore-inherited-configuration | ; drop inherited configuration (specified anywhere)
2550 ;; forward compatibility directive (since ASDF 2.011.4), useful when
2551 ;; you want to use new configuration features but have to bootstrap a
2552 ;; the newer required ASDF from an older release that doesn't sport said features:
2553 :ignore-invalid-entries | ; drops subsequent invalid entries instead of erroring out
2555 ;; include a configuration file or directory
2556 (:include PATHNAME-DESIGNATOR) |
2558 ;; enable global cache in ~/.common-lisp/cache/sbcl-1.0.45-linux-amd64/ or something.
2559 :enable-user-cache |
2560 ;; Disable global cache. Map / to /
2563 ;; add a single directory to be scanned (no recursion)
2564 (DIRECTORY-DESIGNATOR DIRECTORY-DESIGNATOR)
2566 ;; use a function to return the translation of a directory designator
2567 (DIRECTORY-DESIGNATOR (:function TRANSLATION-FUNCTION))
2569 DIRECTORY-DESIGNATOR :=
2570 NIL | ;; As source: skip this entry. As destination: same as source
2571 T | ;; as source matches anything, as destination leaves pathname unmapped.
2572 ABSOLUTE-COMPONENT-DESIGNATOR ;; same as in the source-registry language
2574 TRANSLATION-FUNCTION :=
2575 SYMBOL | ;; symbol of a function that takes two arguments,
2576 ;; the pathname to be translated and the matching DIRECTORY-DESIGNATOR
2577 LAMBDA ;; A form which evalutates to a function taking two arguments consisting of
2578 ;; the pathname to be translated and the matching DIRECTORY-DESIGNATOR
2582 Relative components better be either relative
2583 or subdirectories of the path before them, or bust.
2585 The last component, if not a pathname, is notionally completed by @file{/**/*.*}.
2586 You can specify more fine-grained patterns
2587 by using a pathname object as the last component
2588 e.g. @file{#p"some/path/**/foo*/bar-*.fasl"}
2590 You may use @code{#+features} to customize the configuration file.
2592 The second designator of a mapping may be @code{NIL}, indicating that files are not mapped
2593 to anything but themselves (same as if the second designator was the same as the first).
2595 When the first designator is @code{t},
2596 the mapping always matches.
2597 When the first designator starts with @code{:root},
2598 the mapping matches any host and device.
2599 In either of these cases, if the second designator
2600 isn't @code{t} and doesn't start with @code{:root},
2601 then strings indicating the host and pathname are somehow copied
2602 in the beginning of the directory component of the source pathname
2603 before it is translated.
2605 When the second designator is @code{t}, the mapping is the identity.
2606 When the second designator starts with @code{:root},
2607 the mapping preserves the host and device of the original pathname.
2608 Notably, this allows you to map files
2609 to a subdirectory of the whichever directory the file is in.
2610 Though the syntax is not quite as easy to use as we'd like,
2611 you can have an (source destination) mapping entry such as follows
2612 in your configuration file,
2613 or you may use @code{enable-asdf-binary-locations-compatibility}
2614 with @code{:centralize-lisp-binaries nil}
2615 which will do the same thing internally for you:
2617 #.(let ((wild-subdir (make-pathname :directory '(:relative :wild-inferiors)))
2618 (wild-file (make-pathname :name :wild :version :wild :type :wild)))
2619 `((:root ,wild-subdir ,wild-file) ;; Or using the implicit wildcard, just :root
2620 (:root ,wild-subdir :implementation ,wild-file)))
2622 Starting with ASDF 2.011.4, you can use the simpler:
2623 @code{`(:root (:root :**/ :implementation :*.*.*))}
2627 @code{:include} statements cause the search to recurse with the path specifications
2628 from the file specified.
2630 If the @code{translate-pathname} mechanism cannot achieve a desired
2631 translation, the user may provide a function which provides the
2632 required algorithim. Such a translation function is specified by
2633 supplying a list as the second @code{directory-designator}
2634 the first element of which is the keyword @code{:function},
2635 and the second element of which is
2636 either a symbol which designates a function or a lambda expression.
2637 The function designated by the second argument must take two arguments,
2638 the first being the pathname of the source file,
2639 the second being the wildcard that was matched.
2640 The result of the function invocation should be the translated pathname.
2642 An @code{:inherit-configuration} statement cause the search to recurse with the path
2643 specifications from the next configuration.
2644 @xref{Controlling where ASDF saves compiled files,,Configurations}, above.
2648 @code{:enable-user-cache} is the same as @code{(t :user-cache)}.
2650 @code{:disable-cache} is the same as @code{(t t)}.
2652 @code{:user-cache} uses the contents of variable @code{asdf::*user-cache*}
2653 which by default is the same as using
2654 @code{(:home ".cache" "common-lisp" :implementation)}.
2656 @code{:system-cache} uses the contents of variable @code{asdf::*system-cache*}
2657 which by default is the same as using
2658 @code{("/var/cache/common-lisp" :uid :implementation-type)}
2659 (on Unix and cygwin), or something semi-sensible on Windows.
2663 @section Configuration Directories
2665 Configuration directories consist in files each contains
2666 a list of directives without any enclosing
2667 @code{(:output-translations ...)} form.
2668 The files will be sorted by namestring as if by @code{string<} and
2669 the lists of directives of these files with be concatenated in order.
2670 An implicit @code{:inherit-configuration} will be included
2671 at the @emph{end} of the list.
2673 This allows for packaging software that has file granularity
2674 (e.g. Debian's @command{dpkg} or some future version of @command{clbuild})
2675 to easily include configuration information about software being distributed.
2677 The convention is that, for sorting purposes,
2678 the names of files in such a directory begin with two digits
2679 that determine the order in which these entries will be read.
2680 Also, the type of these files is conventionally @code{"conf"}
2681 and as a limitation of some implementations, the type cannot be @code{NIL}.
2683 Directories may be included by specifying a directory pathname
2684 or namestring in an @code{:include} directive, e.g.:
2686 (:include "/foo/bar/")
2689 @section Shell-friendly syntax for configuration
2691 When considering environment variable @code{ASDF_OUTPUT_TRANSLATIONS}
2692 ASDF will skip to next configuration if it's an empty string.
2693 It will @code{READ} the string as an SEXP in the DSL
2694 if it begins with a paren @code{(}
2695 and it will be interpreted as a list of directories.
2696 Directories should come by pairs, indicating a mapping directive.
2697 Entries are separated
2698 by a @code{:} (colon) on Unix platforms (including cygwin),
2699 by a @code{;} (semicolon) on other platforms (mainly, Windows).
2701 The magic empty entry,
2702 if it comes in what would otherwise be the first entry in a pair,
2703 indicates the splicing of inherited configuration.
2704 If it comes as the second entry in a pair,
2705 it indicates that the directory specified first is to be left untranslated
2706 (which has the same effect as if the directory had been repeated).
2709 @section Semantics of Output Translations
2711 From the specified configuration,
2712 a list of mappings is extracted in a straightforward way:
2713 mappings are collected in order, recursing through
2714 included or inherited configuration as specified.
2715 To this list is prepended some implementation-specific mappings,
2716 and is appended a global default.
2718 The list is then compiled to a mapping table as follows:
2719 for each entry, in order, resolve the first designated directory
2720 into an actual directory pathname for source locations.
2721 If no mapping was specified yet for that location,
2722 resolve the second designated directory to an output location directory
2723 add a mapping to the table mapping the source location to the output location,
2724 and add another mapping from the output location to itself
2725 (unless a mapping already exists for the output location).
2727 Based on the table, a mapping function is defined,
2728 mapping source pathnames to output pathnames:
2729 given a source pathname, locate the longest matching prefix
2730 in the source column of the mapping table.
2731 Replace that prefix by the corresponding output column
2732 in the same row of the table, and return the result.
2733 If no match is found, return the source pathname.
2734 (A global default mapping the filesystem root to itself
2735 may ensure that there will always be a match,
2736 with same fall-through semantics).
2738 @section Caching Results
2740 The implementation is allowed to either eagerly compute the information
2741 from the configurations and file system, or to lazily re-compute it
2742 every time, or to cache any part of it as it goes.
2743 To explicitly flush any information cached by the system, use the API below.
2746 @section Output location API
2748 The specified functions are exported from package ASDF.
2750 @defun initialize-output-translations @&optional PARAMETER
2751 will read the configuration and initialize all internal variables.
2752 You may extend or override configuration
2753 from the environment and configuration files
2754 with the given @var{PARAMETER}, which can be
2755 @code{NIL} (no configuration override),
2756 or a SEXP (in the SEXP DSL),
2757 a string (as in the string DSL),
2758 a pathname (of a file or directory with configuration),
2759 or a symbol (fbound to function that when called returns one of the above).
2762 @defun disable-output-translations
2763 will initialize output translations in a way
2764 that maps every pathname to itself,
2765 effectively disabling the output translation facility.
2768 @defun clear-output-translations
2769 undoes any output translation configuration
2770 and clears any cache for the mapping algorithm.
2771 You might want to call this function
2772 (or better, @code{clear-configuration})
2773 before you dump an image that would be resumed
2774 with a different configuration,
2775 and return an empty configuration.
2776 Note that this does not include clearing information about
2777 systems defined in the current image, only about
2778 where to look for systems not yet defined.
2781 @defun ensure-output-translations @&optional PARAMETER
2782 checks whether output translations have been initialized.
2783 If not, initialize them with the given @var{PARAMETER}.
2784 This function will be called before any attempt to operate on a system.
2787 @defun apply-output-translations PATHNAME
2788 Applies the configured output location translations to @var{PATHNAME}
2789 (calls @code{ensure-output-translations} for the translations).
2792 Every time you use ASDF's @code{output-files}, or
2793 anything that uses it (that may compile, such as @code{operate}, @code{perform}, etc.),
2794 @code{ensure-output-translations} is called with parameter NIL,
2795 which the first time around causes your configuration to be read.
2796 If you change a configuration file,
2797 you need to explicitly @code{initialize-output-translations} again,
2798 or maybe @code{clear-output-translations} (or @code{clear-configuration}),
2799 which will cause the initialization to happen next time around.
2802 @section Credits for output translations
2804 Thanks a lot to Bjorn Lindberg and Gary King for @code{ASDF-Binary-Locations},
2805 and to Peter van Eynde for @code{Common Lisp Controller}.
2807 All bad design ideas and implementation bugs are to mine, not theirs.
2808 But so are good design ideas and elegant implementation tricks.
2810 --- Francois-Rene Rideau @email{fare@@tunes.org}
2812 @c @section Default locations
2813 @c @findex output-files-for-system-and-operation
2815 @c The default binary location for each Lisp implementation
2816 @c is a subdirectory of each source directory.
2817 @c To account for different Lisps, Operating Systems, Implementation versions,
2818 @c and so on, ASDF borrows code from SLIME
2819 @c to create reasonable custom directory names.
2820 @c Here are some examples:
2824 @c SBCL, version 1.0.45 on Mac OS X for Intel: @code{sbcl-1.0.45-darwin-x86}
2827 @c Franz Allegro, version 8.0, ANSI Common Lisp: @code{allegro-8.0a-macosx-x86}
2830 @c Franz Allegro, version 8.1, Modern (case sensitive) Common Lisp: @code{allegro-8.1m-macosx-x86}
2833 @c By default, all output file pathnames will be relocated
2834 @c to some thus-named subdirectory of @file{~/.cache/common-lisp/}.
2836 @c See the document @file{README.asdf-output-translations}
2837 @c for a full specification on how to configure @code{asdf-output-translations}.
2839 @node Error handling, Miscellaneous additional functionality, Controlling where ASDF saves compiled files, Top
2840 @comment node-name, next, previous, up
2841 @chapter Error handling
2842 @findex SYSTEM-DEFINITION-ERROR
2843 @findex OPERATION-ERROR
2845 @section ASDF errors
2847 If ASDF detects an incorrect system definition, it will signal a generalised instance of
2848 @code{SYSTEM-DEFINITION-ERROR}.
2850 Operations may go wrong (for example when source files contain errors).
2851 These are signalled using generalised instances of
2852 @code{OPERATION-ERROR}.
2854 @section Compilation error and warning handling
2855 @vindex *compile-file-warnings-behaviour*
2856 @vindex *compile-file-errors-behavior*
2858 ASDF checks for warnings and errors when a file is compiled.
2859 The variables @var{*compile-file-warnings-behaviour*} and
2860 @var{*compile-file-errors-behavior*}
2861 control the handling of any such events.
2862 The valid values for these variables are
2863 @code{:error}, @code{:warn}, and @code{:ignore}.
2865 @node Miscellaneous additional functionality, Getting the latest version, Error handling, Top
2866 @comment node-name, next, previous, up
2867 @chapter Miscellaneous additional functionality
2869 ASDF includes several additional features that are generally
2870 useful for system definition and development.
2872 @section Controlling file compilation
2874 When declaring a component (system, module, file),
2875 you can specify a keyword argument @code{:around-compile function}.
2876 If left unspecified,
2877 the value will be inherited from the parent component if any,
2878 or with a default of @code{nil}
2879 if no value is specified in any transitive parent.
2881 The argument must be a either @code{nil}, a fbound symbol,
2882 a lambda-expression (e.g. @code{(lambda (thunk) ...(funcall thunk ...) ...)})
2883 a function object (e.g. using @code{#.#'} but that's discouraged
2884 because it prevents the introspection done by e.g. asdf-dependency-grovel),
2885 or a string that when read yields a symbol or a lambda-expression.
2886 @code{nil} means the normal compile-file function will be called.
2887 A non-nil value designates a function of one argument
2888 that will be called with a function that
2889 calls the @code{*compile-op-compile-file-function*} (usually @code{compile-file*})
2890 with proper arguments;
2891 the around-compile hook may supply additional arguments
2892 to pass to that @code{*compile-op-compile-file-function*}.
2893 One notable argument that is heeded by @code{compile-file*} is
2894 @code{:compile-check}, a function called when the compilation was otherwise a success,
2895 with the same arguments as @code{compile-file},
2896 to determine whether
2897 (NB: The ability to pass such extra flags is only available starting with asdf 2.22.1.)
2899 Note that by using a string, you may reference
2900 a function, symbol and/or package
2901 that will only be created later during the build, but
2902 isn't yet present at the time the defsystem form is evaluated.
2903 However, if your entire system is using such a hook, you may have to
2904 explicitly override the hook with @code{nil} for all the modules and files
2905 that are compiled before the hook is defined.
2907 Using this hook, you may achieve such effects as:
2908 locally renaming packages,
2909 binding @var{*readtables*} and other syntax-controlling variables,
2910 handling warnings and other conditions,
2911 proclaiming consistent optimization settings,
2912 saving code coverage information,
2913 maintaining meta-data about compilation timings,
2914 setting gensym counters and PRNG seeds and other sources of non-determinism,
2915 overriding the source-location and/or timestamping systems,
2916 checking that some compile-time side-effects were properly balanced,
2919 Note that there is no around-load hook. This is on purpose.
2920 Some implementations such as ECL, GCL or MKCL link object files,
2921 which allows for no such hook.
2922 Other implementations allow for concatenating FASL files,
2923 which doesn't allow for such a hook either.
2924 We aim to discourage something that's not portable,
2925 and has some dubious impact on performance and semantics
2926 even when it is possible.
2927 Things you might want to do with an around-load hook
2928 are better done around-compile,
2929 though it may at times require some creativity
2930 (see e.g. the @code{package-renaming} system).
2933 @section Controlling source file character encoding
2935 Starting with ASDF 2.21, components accept a @code{:encoding} option
2936 so authors may specify which character encoding should be used
2937 to read and evaluate their source code.
2938 When left unspecified, the encoding is inherited
2939 from the parent module or system;
2940 if no encoding is specified at any point,
2941 the default @code{:autodetect} is assumed.
2942 By default, only @code{:default}, @code{:utf-8}
2943 and @code{:autodetect} are accepted.
2944 @code{:autodetect}, the default, calls
2945 @code{*encoding-detection-hook*} which by default always returns
2946 @code{*default-encoding*} which itself defaults to @code{:default}.
2948 In other words, there now are plenty of extension hooks, but
2949 by default ASDF follows the backwards compatible behavior
2950 of using whichever @code{:default} encoding your implementation uses,
2951 which itself may or may not vary based on environment variables
2952 and other locale settings.
2953 In practice this means that only source code that only uses ASCII
2954 is guaranteed to be read the same on all implementations
2955 independently from any user setting.
2957 Additionally, for backward-compatibility with older versions of ASDF
2958 and/or with implementations that do not support unicode and its many encodings,
2960 the reader conditionals @code{#+asdf-unicode #+asdf-unicode}
2961 to protect any @code{:encoding @emph{encoding}} statement
2962 as @code{:asdf-unicode} will be present in @code{*features*}
2963 only if you're using a recent ASDF
2964 on an implementation that supports unicode.
2965 We recommend that you avoid using unprotected @code{:encoding} specifications
2966 until after ASDF 2.21 or later becomes widespread, hopefully by the end of 2012.
2968 While it offers plenty of hooks for extension,
2969 and one such extension is being developed (see below),
2970 ASDF itself only recognizes one encoding beside @code{:default},
2971 and that is @code{:utf-8}, which is the @emph{de facto} standard,
2972 already used by the vast majority of libraries that use more than ASCII.
2973 On implementations that do not support unicode,
2974 the feature @code{:asdf-unicode} is absent, and
2975 the @code{:default} external-format is used
2976 to read even source files declared as @code{:utf-8}.
2977 On these implementations, non-ASCII characters
2978 intended to be read as one CL character
2979 may thus end up being read as multiple CL characters.
2980 In most cases, this shouldn't affect the software's semantics:
2981 comments will be skipped just the same, strings with be read and printed
2982 with slightly different lengths, symbol names will be accordingly longer,
2983 but none of it should matter.
2984 But a few systems that actually depend on unicode characters
2985 may fail to work properly, or may work in a subtly different way.
2986 See for instance @code{lambda-reader}.
2988 We invite you to embrace UTF-8
2989 as the encoding for non-ASCII characters starting today,
2990 even without any explicit specification in your @code{.asd} files.
2991 Indeed, on some implementations and configurations,
2992 UTF-8 is already the @code{:default},
2993 and loading your code may cause errors if it is encoded in anything but UTF-8.
2994 Therefore, even with the legacy behavior,
2995 non-UTF-8 is guaranteed to break for some users,
2996 whereas UTF-8 is pretty much guaranteed not to break anywhere
2997 (provided you do @emph{not} use a BOM),
2998 although it might be read incorrectly on some implementations.
2999 In the future, we intend to make @code{:utf-8}
3000 the default value of @code{*default-encoding*},
3001 to be enforced everywhere, so at least the code is guaranteed
3002 to be read correctly everywhere it can be.
3004 If you need non-standard character encodings for your source code,
3005 use the extension system @code{asdf-encodings}, by specifying
3006 @code{:defsystem-depends-on (:asdf-encodings)} in your @code{defsystem}.
3007 This extension system will register support for more encodings using the
3008 @code{*encoding-external-format-hook*} facility,
3009 so you can explicitly specify @code{:encoding :latin1}
3010 in your @code{.asd} file.
3011 Using the @code{*encoding-detection-hook*} it will also
3012 eventually implement some autodetection of a file's encoding
3013 from an emacs-style @code{-*- mode: lisp ; coding: latin1 -*-} declaration,
3014 or otherwise based on an analysis of octet patterns in the file.
3015 At this point, asdf-encoding only supports the encodings
3016 that are supported as part of your implementation.
3017 Since the list varies depending on implementations,
3018 we once again recommend you use @code{:utf-8} everywhere,
3019 which is the most portable (next is @code{:latin1}).
3021 If you're not using a version of Quicklisp that has it,
3022 you may get the source for @code{asdf-encodings} using git:
3023 @kbd{git clone git://common-lisp.net/projects/asdf/asdf-encodings.git}
3025 @kbd{git clone ssh://common-lisp.net/project/asdf/git/asdf-encodings.git}.
3026 You can also browse the repository on
3027 @url{http://common-lisp.net/gitweb?p=projects/asdf/asdf-encodings.git}.
3029 In the future, we intend to change the default @code{*default-encoding*}
3030 to @code{:utf-8}, which is already the de facto standard
3031 for most libraries that use non-ASCII characters:
3032 utf-8 works everywhere and was backhandedly enforced by
3033 a lot of people using SBCL and utf-8 and sending reports to authors
3034 so they make their packages compatible.
3035 A survey showed only about a handful few libraries
3036 are incompatible with non-UTF-8, and then, only in comments,
3037 and we believe that authors will adopt UTF-8 when prompted.
3038 See the April 2012 discussion on the asdf-devel mailing-list.
3039 For backwards compatibility with users who insist on a non-UTF-8 encoding,
3040 but cannot immediately transition to using @code{asdf-encodings}
3041 (maybe because it isn't ready), it will still be possible to use
3042 the @code{:encoding :default} option in your @code{defsystem} form
3043 to restore the behavior of ASDF 2.20 and earlier.
3044 This shouldn't be required in libraries,
3045 because user pressure as mentioned above will already have pushed
3046 library authors towards using UTF-8;
3047 but authors of end-user programs might care.
3049 When you use @code{asdf-encodings}, any further loaded @code{.asd} file
3050 will use the autodetection algorithm to determine its encoding;
3051 yet if you depend on this detection happening,
3052 you may want to explicitly load @code{asdf-encodings} early in your build,
3053 for by the time you can use @code{:defsystem-depends-on},
3054 it is already too late to load it.
3055 In practice, this means that the @code{*default-encoding*}
3056 is usually used for @code{.asd} files.
3057 Currently, this defaults to @code{:default} for backwards compatibility,
3058 and that means that you shouldn't rely on non-ASCII characters in a .asd file.
3059 Since component (path)names are the only real data in these files,
3060 and non-ASCII characters are not very portable for file names,
3061 this isn't too much of an issue.
3062 We still encourage you to use either plain ASCII or UTF-8
3063 in @code{.asd} files,
3064 as we intend to make @code{:utf-8} the default encoding in the future.
3065 This might matter, for instance, in meta-data about author's names.
3068 @section Miscellaneous Exported Functions
3070 @defun coerce-pathname name @&key type defaults
3072 This function (available starting with ASDF 2.012.11)
3073 takes an argument, and portably interprets it as a pathname.
3074 If the argument @var{name} is a pathname or @code{nil}, it is passed through;
3075 if it's a symbol, it's interpreted as a string by downcasing it;
3076 if it's a string, it is first separated using @code{/} into substrings;
3077 the leading substrings denote subdirectories of a relative pathname.
3078 If @var{type} is @code{:directory} or the string ends with @code{/},
3079 the last substring is also a subdirectory;
3080 if @var{type} is a string, it is used as the type of the pathname, and
3081 the last substring is the name component of the pathname;
3082 if @var{type} is @code{nil}, the last substring specifies both name and type components
3083 of the pathname, with the last @code{.} separating them, or only the name component
3084 if there's no last @code{.} or if there is only one dot and it's the first character.
3085 The host, device and version components come from @var{defaults}, which defaults to
3086 @var{*default-pathname-defaults*}; but that shouldn't matter if you use @code{merge-pathnames*}.
3090 @defun merge-pathnames* @&key specified defaults
3092 This function is a replacement for @code{merge-pathnames} that uses the host and device
3093 from the @var{defaults} rather than the @var{specified} pathname when the latter
3094 is a relative pathname. This allows ASDF and its users to create and use relative pathnames
3095 without having to know beforehand what are the host and device
3096 of the absolute pathnames they are relative to.
3100 @defun system-relative-pathname system name @&key type
3102 It's often handy to locate a file relative to some system.
3103 The @code{system-relative-pathname} function meets this need.
3105 It takes two mandatory arguments @var{system} and @var{name}
3106 and a keyword argument @var{type}:
3107 @var{system} is name of a system, whereas @var{name} and optionally @var{type}
3108 specify a relative pathname, interpreted like a component pathname specifier
3109 by @code{coerce-pathname}. @xref{The defsystem grammar,,Pathname specifiers}.
3111 It returns a pathname built from the location of the system's
3112 source directory and the relative pathname. For example:
3115 > (asdf:system-relative-pathname 'cl-ppcre "regex.data")
3116 #P"/repository/other/cl-ppcre/regex.data"
3121 @defun system-source-directory system-designator
3123 ASDF does not provide a turnkey solution for locating
3124 data (or other miscellaneous) files
3125 that are distributed together with the source code of a system.
3126 Programmers can use @code{system-source-directory} to find such files.
3127 Returns a pathname object.
3128 The @var{system-designator} may be a string, symbol, or ASDF system object.
3131 @defun clear-system system-designator
3133 It is sometimes useful to force recompilation of a previously loaded system.
3134 In these cases, it may be useful to @code{(asdf:clear-system :foo)}
3135 to remove the system from the table of currently loaded systems;
3136 the next time the system @code{foo} or one that depends on it is re-loaded,
3137 @code{foo} will then be loaded again.
3138 Alternatively, you could touch @code{foo.asd} or
3139 remove the corresponding fasls from the output file cache.
3140 (It was once conceived that one should provide
3141 a list of systems the recompilation of which to force
3142 as the @code{:force} keyword argument to @code{load-system};
3143 but this has never worked, and though the feature was fixed in ASDF 2.000,
3144 it remains @code{cerror}'ed out as nobody ever used it.)
3146 Note that this does not and cannot by itself undo the previous loading
3147 of the system. Common Lisp has no provision for such an operation,
3148 and its reliance on irreversible side-effects to global datastructures
3149 makes such a thing impossible in the general case.
3150 If the software being re-loaded is not conceived with hot upgrade in mind,
3151 this re-loading may cause many errors, warnings or subtle silent problems,
3152 as packages, generic function signatures, structures, types, macros, constants, etc.
3153 are being redefined incompatibly.
3154 It is up to the user to make sure that reloading is possible and has the desired effect.
3155 In some cases, extreme measures such as recursively deleting packages,
3156 unregistering symbols, defining methods on @code{update-instance-for-redefined-class}
3157 and much more are necessary for reloading to happen smoothly.
3158 ASDF itself goes through notable pains to make such a hot upgrade possible
3159 with respect to its own code, and what it does is ridiculously complex;
3160 look at the beginning of @file{asdf.lisp} to see what it does.
3163 @defun run-shell-command
3165 This function is obsolete and present only for the sake of backwards-compatibility:
3166 ``If it's not backwards, it's not compatible''. We strongly discourage its use.
3167 Its current behavior is only well-defined on Unix platforms
3168 (which include MacOS X and cygwin). On Windows, anything goes.
3170 Instead we recommend the use of such a function as
3171 @code{xcvb-driver:run-program/}
3172 from the @code{xcvb-driver} system that is distributed with XCVB:
3173 @url{http://common-lisp.net/project/xcvb}.
3174 It's the only alternative that supports
3175 as many implementations and operating systems as ASDF does,
3176 and provides well-defined behavior outside Unix (i.e. on Windows).
3177 (The only unsupported exception is Genera, since on it
3178 @code{run-shell-command} doesn't make sense anyway on that platform).
3180 @code{run-shell-command} takes as arguments a @code{format} control-string
3181 and arguments to be passed to @code{format} after this control-string
3182 to produce a string.
3183 This string is a command that will be evaluated with a POSIX shell if possible;
3184 yet, on Windows, some implementations will use CMD.EXE,
3185 while others (like SBCL) will make an attempt at invoking a POSIX shell
3186 (and fail if it is not present).
3190 @node Getting the latest version, FAQ, Miscellaneous additional functionality, Top
3191 @comment node-name, next, previous, up
3192 @chapter Getting the latest version
3194 Decide which version you want.
3195 The @code{master} branch is where development happens;
3196 its @code{HEAD} is usually OK, including the latest fixes and portability tweaks,
3197 but an occasional regression may happen despite our (limited) test suite.
3199 The @code{release} branch is what cautious people should be using;
3200 it has usually been tested more, and releases are cut at a point
3201 where there isn't any known unresolved issue.
3203 You may get the ASDF source repository using git:
3204 @kbd{git clone git://common-lisp.net/projects/asdf/asdf.git}
3206 You will find the above referenced tags in this repository.
3207 You can also browse the repository on
3208 @url{http://common-lisp.net/gitweb?p=projects/asdf/asdf.git}.
3210 Discussion of ASDF development is conducted on the
3212 @kbd{asdf-devel@@common-lisp.net}.
3213 @url{http://common-lisp.net/cgi-bin/mailman/listinfo/asdf-devel}
3216 @node FAQ, TODO list, Getting the latest version, Top
3217 @comment node-name, next, previous, up
3220 @section ``Where do I report a bug?''
3222 ASDF bugs are tracked on launchpad: @url{https://launchpad.net/asdf}.
3224 If you're unsure about whether something is a bug, or for general discussion,
3225 use the @url{http://common-lisp.net/cgi-bin/mailman/listinfo/asdf-devel,asdf-devel mailing list}
3228 @section ``What has changed between ASDF 1 and ASDF 2?''
3230 @subsection What are ASDF 1 and ASDF 2?
3232 On May 31st 2010, we have released ASDF 2.
3233 ASDF 2 refers to release 2.000 and later.
3234 (Releases between 1.656 and 1.728 were development releases for ASDF 2.)
3235 ASDF 1 to any release earlier than 1.369 or so.
3236 If your ASDF doesn't sport a version, it's an old ASDF 1.
3238 ASDF 2 and its release candidates push
3239 @code{:asdf2} onto @code{*features*} so that if you are writing
3240 ASDF-dependent code you may check for this feature
3241 to see if the new API is present.
3242 @emph{All} versions of ASDF should have the @code{:asdf} feature.
3244 Additionally, all versions of asdf 2
3245 define a function @code{(asdf:asdf-version)} you may use to query the version;
3246 and the source code of recent versions of asdf 2 features the version number
3247 prominently on the second line of its source code.
3249 If you are experiencing problems or limitations of any sort with ASDF 1,
3250 we recommend that you should upgrade to ASDF 2,
3251 or whatever is the latest release.
3254 @subsection ASDF can portably name files in subdirectories
3256 Common Lisp namestrings are not portable,
3257 except maybe for logical pathnamestrings,
3258 that themselves have various limitations and require a lot of setup
3259 that is itself ultimately non-portable.
3261 In ASDF 1, the only portable ways to refer to pathnames inside systems and components
3262 were very awkward, using @code{#.(make-pathname ...)} and
3263 @code{#.(merge-pathnames ...)}.
3264 Even the above were themselves were inadequate in the general case
3265 due to host and device issues, unless horribly complex patterns were used.
3266 Plenty of simple cases that looked portable actually weren't,
3267 leading to much confusion and greavance.
3269 ASDF 2 implements its own portable syntax for strings as pathname specifiers.
3270 Naming files within a system definition becomes easy and portable again.
3271 @xref{Miscellaneous additional functionality,asdf:system-relative-pathname},
3272 @code{merge-pathnames*},
3273 @code{coerce-pathname}.
3275 On the other hand, there are places where systems used to accept namestrings
3276 where you must now use an explicit pathname object:
3277 @code{(defsystem ... :pathname "LOGICAL-HOST:PATH;TO;SYSTEM;" ...)}
3278 must now be written with the @code{#p} syntax:
3279 @code{(defsystem ... :pathname #p"LOGICAL-HOST:PATH;TO;SYSTEM;" ...)}
3281 @xref{The defsystem grammar,,Pathname specifiers}.
3284 @subsection Output translations
3286 A popular feature added to ASDF was output pathname translation:
3287 @code{asdf-binary-locations}, @code{common-lisp-controller},
3288 @code{cl-launch} and other hacks were all implementing it in ways
3289 both mutually incompatible and difficult to configure.
3291 Output pathname translation is essential to share
3292 source directories of portable systems across multiple implementations
3293 or variants thereof,
3294 or source directories of shared installations of systems across multiple users,
3295 or combinations of the above.
3297 In ASDF 2, a standard mechanism is provided for that,
3298 @code{asdf-output-translations},
3299 with sensible defaults, adequate configuration languages,
3300 a coherent set of configuration files and hooks,
3301 and support for non-Unix platforms.
3303 @xref{Controlling where ASDF saves compiled files}.
3305 @subsection Source Registry Configuration
3307 Configuring ASDF used to require special magic
3308 to be applied just at the right moment,
3309 between the moment ASDF is loaded and the moment it is used,
3310 in a way that is specific to the user,
3311 the implementation he is using and the application he is building.
3313 This made for awkward configuration files and startup scripts
3314 that could not be shared between users, managed by administrators
3315 or packaged by distributions.
3317 ASDF 2 provides a well-documented way to configure ASDF,
3318 with sensible defaults, adequate configuration languages,
3319 and a coherent set of configuration files and hooks.
3321 We believe it's a vast improvement because it decouples
3322 application distribution from library distribution.
3323 The application writer can avoid thinking where the libraries are,
3324 and the library distributor (dpkg, clbuild, advanced user, etc.)
3325 can configure them once and for every application.
3326 Yet settings can be easily overridden where needed,
3327 so whoever needs control has exactly as much as required.
3329 At the same time, ASDF 2 remains compatible
3330 with the old magic you may have in your build scripts
3331 (using @code{*central-registry*} and
3332 @code{*system-definition-search-functions*})
3333 to tailor the ASDF configuration to your build automation needs,
3334 and also allows for new magic, simpler and more powerful magic.
3336 @xref{Controlling where ASDF searches for systems}.
3339 @subsection Usual operations are made easier to the user
3341 In ASDF 1, you had to use the awkward syntax
3342 @code{(asdf:oos 'asdf:load-op :foo)}
3344 and similarly for @code{compile-op}, @code{test-op}.
3346 In ASDF 2, you can use shortcuts for the usual operations:
3347 @code{(asdf:load-system :foo)}, and
3348 similarly for @code{compile-system}, @code{test-system}.
3351 @subsection Many bugs have been fixed
3353 The following issues and many others have been fixed:
3357 The infamous TRAVERSE function has been revamped significantly,
3358 with many bugs squashed.
3359 In particular, dependencies were not correctly propagated
3360 across submodules within a system but now are.
3361 The :version and :feature features and
3362 the :force (system1 .. systemN) feature have been fixed.
3365 Performance has been notably improved for large systems
3366 (say with thousands of components) by using
3367 hash-tables instead of linear search,
3368 and linear-time list accumulation
3369 instead of quadratic-time recursive appends.
3372 Many features used to not be portable,
3373 especially where pathnames were involved.
3374 Windows support was notably quirky because of such non-portability.
3377 The internal test suite used to massively fail on many implementations.
3378 While still incomplete, it now fully passes
3379 on all implementations supported by the test suite,
3380 except for GCL (due to GCL bugs).
3383 Support was lacking for some implementations.
3384 ABCL and GCL were notably wholly broken.
3385 ECL extensions were not integrated in the ASDF release.
3388 The documentation was grossly out of date.
3393 @subsection ASDF itself is versioned
3395 Between new features, old bugs fixed, and new bugs introduced,
3396 there were various releases of ASDF in the wild,
3397 and no simple way to check which release had which feature set.
3398 People using or writing systems had to either make worst-case assumptions
3399 as to what features were available and worked,
3400 or take great pains to have the correct version of ASDF installed.
3402 With ASDF 2, we provide a new stable set of working features
3403 that everyone can rely on from now on.
3404 Use @code{#+asdf2} to detect presence of ASDF 2,
3405 @code{(asdf:version-satisfies (asdf:asdf-version) "2.345.67")}
3406 to check the availability of a version no earlier than required.
3409 @subsection ASDF can be upgraded
3411 When an old version of ASDF was loaded,
3412 it was very hard to upgrade ASDF in your current image
3413 without breaking everything.
3414 Instead you had to exit the Lisp process and
3415 somehow arrange to start a new one from a simpler image.
3416 Something that can't be done from within Lisp,
3417 making automation of it difficult,
3418 which compounded with difficulty in configuration,
3419 made the task quite hard.
3420 Yet as we saw before, the task would have been required
3421 to not have to live with the worst case or non-portable
3422 subset of ASDF features.
3424 With ASDF 2, it is easy to upgrade
3425 from ASDF 2 to later versions from within Lisp,
3426 and not too hard to upgrade from ASDF 1 to ASDF 2 from within Lisp.
3427 We support hot upgrade of ASDF and any breakage is a bug
3428 that we will do our best to fix.
3429 There are still limitations on upgrade, though,
3430 most notably the fact that after you upgrade ASDF,
3431 you must also reload or upgrade all ASDF extensions.
3433 @subsection Decoupled release cycle
3435 When vendors were releasing their Lisp implementations with ASDF,
3436 they had to basically never change version
3437 because neither upgrade nor downgrade was possible
3438 without breaking something for someone,
3439 and no obvious upgrade path was visible and recommendable.
3441 With ASDF 2, upgrade is possible, easy and can be recommended.
3442 This means that vendors can safely ship a recent version of ASDF,
3443 confident that if a user isn't fully satisfied,
3444 he can easily upgrade ASDF and deal
3445 with a supported recent version of it.
3446 This means that release cycles will be causally decoupled,
3447 the practical consequence of which will mean faster convergence
3448 towards the latest version for everyone.
3451 @subsection Pitfalls of the transition to ASDF 2
3453 The main pitfalls in upgrading to ASDF 2 seem to be related
3454 to the output translation mechanism.
3459 Output translations is enabled by default. This may surprise some users,
3460 most of them in pleasant way (we hope), a few of them in an unpleasant way.
3461 It is trivial to disable output translations.
3462 @xref{FAQ,,``How can I wholly disable the compiler output cache?''}.
3465 Some systems in the large have been known not to play well with output translations.
3466 They were relatively easy to fix.
3467 Once again, it is also easy to disable output translations,
3468 or to override its configuration.
3471 The new ASDF output translations are incompatible with ASDF-Binary-Locations.
3472 They replace A-B-L, and there is compatibility mode to emulate
3473 your previous A-B-L configuration.
3474 See @code{enable-asdf-binary-locations-compatibility} in
3475 @pxref{Controlling where ASDF saves compiled files,,Backward Compatibility}.
3476 But thou shalt not load ABL on top of ASDF 2.
3480 Other issues include the following:
3485 ASDF pathname designators are now specified in places where they were unspecified,
3486 and a few small adjustments have to be made to some non-portable defsystems.
3487 Notably, in the @code{:pathname} argument to a @code{defsystem} and its components,
3488 a logical pathname (or implementation-dependent hierarchical pathname)
3489 must now be specified with @code{#p} syntax
3490 where the namestring might have previously sufficed;
3491 moreover when evaluation is desired @code{#.} must be used,
3492 where it wasn't necessary in the toplevel @code{:pathname} argument
3493 (but necessary in other @code{:pathname} arguments).
3496 There is a slight performance bug, notably on SBCL,
3497 when initially searching for @file{asd} files,
3498 the implicit @code{(directory "/configured/path/**/*.asd")}
3499 for every configured path @code{(:tree "/configured/path/")}
3500 in your @code{source-registry} configuration can cause a slight pause.
3501 Try to @code{(time (asdf:initialize-source-registry))}
3502 to see how bad it is or isn't on your system.
3503 If you insist on not having this pause,
3504 you can avoid the pause by overriding the default source-registry configuration
3505 and not use any deep @code{:tree} entry but only @code{:directory} entries
3506 or shallow @code{:tree} entries.
3507 Or you can fix your implementation to not be quite that slow
3508 when recursing through directories.
3509 @emph{Update}: This performance bug fixed the hard way in 2.010.
3512 On Windows, only LispWorks supports proper default configuration pathnames
3513 based on the Windows registry.
3514 Other implementations make do with environment variables,
3515 that you may have to define yourself if you're using an older version of Windows.
3516 Windows support is somewhat less tested than Unix support.
3517 Please help report and fix bugs.
3520 The mechanism by which one customizes a system so that Lisp files
3521 may use a different extension from the default @file{.lisp} has changed.
3522 Previously, the pathname for a component was lazily computed when operating on a system,
3524 @code{(defmethod source-file-type ((component cl-source-file) (system (eql (find-system 'foo))))
3525 (declare (ignorable component system)) "lis")}.
3526 Now, the pathname for a component is eagerly computed when defining the system,
3527 and instead you will @code{(defclass cl-source-file.lis (cl-source-file) ((type :initform "lis")))}
3528 and use @code{:default-component-class cl-source-file.lis} as argument to @code{defsystem},
3529 as detailed in a @pxref{FAQ,How do I create a system definition where all the source files have a .cl extension?} below.
3531 @findex source-file-type
3537 @section Issues with installing the proper version of ASDF
3539 @subsection ``My Common Lisp implementation comes with an outdated version of ASDF. What to do?''
3541 We recommend you upgrade ASDF.
3542 @xref{Loading ASDF,,Upgrading ASDF}.
3544 If this does not work, it is a bug, and you should report it.
3545 @xref{FAQ, report-bugs, Where do I report a bug}.
3546 In the meantime, you can load @file{asdf.lisp} directly.
3547 @xref{Loading ASDF,Loading an otherwise installed ASDF}.
3550 @subsection ``I'm a Common Lisp implementation vendor. When and how should I upgrade ASDF?''
3552 Starting with current candidate releases of ASDF 2,
3553 it should always be a good time to upgrade to a recent ASDF.
3554 You may consult with the maintainer for which specific version they recommend,
3555 but the latest @code{release} should be correct.
3556 We trust you to thoroughly test it with your implementation before you release it.
3557 If there are any issues with the current release,
3558 it's a bug that you should report upstream and that we will fix ASAP.
3560 As to how to include ASDF, we recommend the following:
3564 If ASDF isn't loaded yet, then @code{(require "asdf")}
3565 should load the version of ASDF that is bundled with your system.
3566 If possible so should @code{(require "ASDF")}.
3567 You may have it load some other version configured by the user,
3568 if you allow such configuration.
3571 If your system provides a mechanism to hook into @code{CL:REQUIRE},
3572 then it would be nice to add ASDF to this hook the same way that
3573 ABCL, CCL, CLISP, CMUCL, ECL, SBCL and SCL do it.
3576 You may, like SBCL, have ASDF be implicitly used to require systems
3577 that are bundled with your Lisp distribution.
3578 If you do have a few magic systems that come with your implementation
3579 in a precompiled way such that one should only use the binary version
3580 that goes with your distribution, like SBCL does,
3581 then you should add them in the beginning of @code{wrapping-source-registry}.
3584 If you have magic systems as above, like SBCL does,
3585 then we explicitly ask you to @emph{NOT} distribute
3586 @file{asdf.asd} as part of those magic systems.
3587 You should still include the file @file{asdf.lisp} in your source distribution
3588 and precompile it in your binary distribution,
3589 but @file{asdf.asd} if included at all,
3590 should be secluded from the magic systems,
3591 in a separate file hierarchy;
3592 alternatively, you may provide the system
3593 after renaming it and its @file{.asd} file to e.g.
3594 @code{asdf-ecl} and @file{asdf-ecl.asd}, or
3595 @code{sb-asdf} and @file{sb-asdf.asd}.
3596 Indeed, if you made @file{asdf.asd} a magic system,
3597 then users would no longer be able to upgrade ASDF using ASDF itself
3598 to some version of their preference that
3599 they maintain independently from your Lisp distribution.
3602 If you do not have any such magic systems, or have other non-magic systems
3603 that you want to bundle with your implementation,
3604 then you may add them to the @code{default-source-registry},
3605 and you are welcome to include @file{asdf.asd} amongst them.
3608 Please send us upstream any patches you make to ASDF itself,
3609 so we can merge them back in for the benefit of your users
3610 when they upgrade to the upstream version.
3616 @section Issues with configuring ASDF
3618 @subsection ``How can I customize where fasl files are stored?''
3620 @xref{Controlling where ASDF saves compiled files}.
3622 Note that in the past there was an add-on to ASDF called
3623 @code{ASDF-binary-locations}, developed by Gary King.
3624 That add-on has been merged into ASDF proper,
3625 then superseded by the @code{asdf-output-translations} facility.
3627 Note that use of @code{asdf-output-translations}
3628 can interfere with one aspect of your systems
3629 --- if your system uses @code{*load-truename*} to find files
3630 (e.g., if you have some data files stored with your program),
3631 then the relocation that this ASDF customization performs
3632 is likely to interfere.
3633 Use @code{asdf:system-relative-pathname} to locate a file
3634 in the source directory of some system, and
3635 use @code{asdf:apply-output-translations} to locate a file
3636 whose pathname has been translated by the facility.
3638 @subsection ``How can I wholly disable the compiler output cache?''
3640 To permanently disable the compiler output cache
3641 for all future runs of ASDF, you can:
3644 mkdir -p ~/.config/common-lisp/asdf-output-translations.conf.d/
3645 echo ':disable-cache' > ~/.config/common-lisp/asdf-output-translations.conf.d/99-disable-cache.conf
3648 This assumes that you didn't otherwise configure the ASDF files
3649 (if you did, edit them again),
3650 and don't somehow override the configuration at runtime
3651 with a shell variable (see below) or some other runtime command
3652 (e.g. some call to @code{asdf:initialize-output-translations}).
3654 To disable the compiler output cache in Lisp processes
3655 run by your current shell, try (assuming @code{bash} or @code{zsh})
3656 (on Unix and cygwin only):
3659 export ASDF_OUTPUT_TRANSLATIONS=/:
3662 To disable the compiler output cache just in the current Lisp process,
3663 use (after loading ASDF but before using it):
3666 (asdf:disable-output-translations)
3669 @section Issues with using and extending ASDF to define systems
3671 @subsection ``How can I cater for unit-testing in my system?''
3673 ASDF provides a predefined test operation, @code{test-op}.
3674 @xref{Predefined operations of ASDF, test-op}.
3675 The test operation, however, is largely left to the system definer to specify.
3676 @code{test-op} has been
3677 a topic of considerable discussion on the
3678 @url{http://common-lisp.net/cgi-bin/mailman/listinfo/asdf-devel,asdf-devel mailing list},
3680 @url{https://launchpad.net/asdf,launchpad bug-tracker}.
3682 Here are some guidelines:
3686 For a given system, @var{foo}, you will want to define a corresponding
3687 test system, such as @var{foo-test}. The reason that you will want this
3688 separate system is that ASDF does not out of the box supply components
3689 that are conditionally loaded. So if you want to have source files
3690 (with the test definitions) that will not be loaded except when testing,
3691 they should be put elsewhere.
3694 The @var{foo-test} system can be defined in an asd file of its own or
3695 together with @var{foo}. An aesthetic preference against cluttering up
3696 the filesystem with extra asd files should be balanced against the
3697 question of whether one might want to directly load @var{foo-test}.
3698 Typically one would not want to do this except in early stages of
3702 Record that testing is implemented by @var{foo-test}. For example:
3704 (defsystem @var{foo}
3705 :in-order-to ((test-op (test-op @var{foo-test})))
3708 (defsystem @var{foo-test}
3709 :depends-on (@var{foo} @var{my-test-library} ...)
3714 This procedure will allow you to support users who do not wish to
3715 install your test framework.
3717 One oddity of ASDF is that @code{operate} (@pxref{Operations,operate})
3718 does not return a value. So in current versions of ASDF there is no
3719 reliable programmatic means of determining whether or not a set of tests
3720 has passed, or which tests have failed. The user must simply read the
3721 console output. This limitation has been the subject of much
3724 @subsection ``How can I cater for documentation generation in my system?''
3726 The ASDF developers are currently working to add a @code{doc-op}
3727 to the set of predefined ASDF operations.
3728 @xref{Predefined operations of ASDF}.
3729 See also @url{https://bugs.launchpad.net/asdf/+bug/479470}.
3733 @subsection ``How can I maintain non-Lisp (e.g. C) source files?''
3735 See @code{cffi}'s @code{cffi-grovel}.
3737 @anchor{report-bugs}
3740 @subsection ``I want to put my module's files at the top level. How do I do this?''
3742 By default, the files contained in an asdf module go
3743 in a subdirectory with the same name as the module.
3744 However, this can be overridden by adding a @code{:pathname ""} argument
3745 to the module description.
3746 For example, here is how it could be done
3747 in the spatial-trees ASDF system definition for ASDF 2:
3750 (asdf:defsystem :spatial-trees
3756 (:file "basedefs" :depends-on ("package"))
3757 (:file "rectangles" :depends-on ("package"))))
3763 (:file "greene-trees" :depends-on ("r-trees"))
3764 (:file "rstar-trees" :depends-on ("r-trees"))
3765 (:file "rplus-trees" :depends-on ("r-trees"))
3766 (:file "x-trees" :depends-on ("r-trees" "rstar-trees"))))
3771 ((:static-file "spatial-tree-viz.lisp")))
3776 ((:static-file "spatial-tree-test.lisp")))
3777 (:static-file "LICENCE")
3778 (:static-file "TODO")))
3781 All of the files in the @code{tree-impls} module are at the top level,
3782 instead of in a @file{tree-impls/} subdirectory.
3784 Note that the argument to @code{:pathname} can be either a pathname object or a string.
3785 A pathname object can be constructed with the @file{#p"foo/bar/"} syntax,
3786 but this is discouraged because the results of parsing a namestring are not portable.
3787 A pathname can only be portably constructed with such syntax as
3788 @code{#.(make-pathname :directory '(:relative "foo" "bar"))},
3789 and similarly the current directory can only be portably specified as
3790 @code{#.(make-pathname :directory '(:relative))}.
3791 However, as of ASDF 2, you can portably use a string to denote a pathname.
3792 The string will be parsed as a @code{/}-separated path from the current directory,
3793 such that the empty string @code{""} denotes the current directory, and
3794 @code{"foo/bar"} (no trailing @code{/} required in the case of modules)
3795 portably denotes the same subdirectory as above.
3796 When files are specified, the last @code{/}-separated component is interpreted
3797 either as the name component of a pathname
3798 (if the component class specifies a pathname type),
3799 or as a name component plus optional dot-separated type component
3800 (if the component class doesn't specifies a pathname type).
3802 @subsection How do I create a system definition where all the source files have a .cl extension?
3804 Starting with ASDF 2.014.14, you may just pass
3805 the builtin class @code{cl-source-file.cl} as
3806 the @code{:default-component-class} argument to @code{defsystem}:
3809 (defsystem my-cl-system
3810 :default-component-class cl-source-file.cl
3814 Another builtin class @code{cl-source-file.lsp} is offered
3815 for files ending in @file{.lsp}.
3817 If you want to use a different extension
3818 for which ASDF doesn't provide builtin support,
3819 or want to support versions of ASDF
3820 earlier than 2.014.14 (but later than 2.000),
3821 you can define a class as follows:
3824 ;; Prologue: make sure we're using a sane package.
3825 (defpackage :my-asdf-extension
3826 (:use :asdf :common-lisp)
3827 (:export #:cl-source-file.lis))
3828 (in-package :my-asdf-extension)
3830 (defclass cl-source-file.lis (cl-source-file)
3831 ((type :initform "lis")))
3834 Then you can use it as follows:
3836 (defsystem my-cl-system
3837 :default-component-class my-asdf-extension:cl-source-file.lis
3841 Of course, if you're in the same package, e.g. in the same file,
3842 you won't need to use the package qualifier before @code{cl-source-file.lis}.
3843 Actually, if all you're doing is defining this class
3844 and using it in the same file without other fancy definitions,
3845 you might skip package complications:
3849 (defclass cl-source-file.lis (cl-source-file)
3850 ((type :initform "lis")))
3851 (defsystem my-cl-system
3852 :default-component-class cl-source-file.lis
3856 It is possible to achieve the same effect
3857 in a way that supports both ASDF 1 and ASDF 2,
3858 but really, friends don't let friends use ASDF 1.
3859 Please upgrade to ASDF 2.
3860 In short, though: do same as above, but
3861 @emph{before} you use the class in a @code{defsystem},
3862 you also define the following method:
3865 (defmethod source-file-type ((f cl-source-file.lis) (m module))
3866 (declare (ignorable f m))
3870 @comment FIXME: Add a FAQ about how to use a new system class...
3873 @node TODO list, Inspiration, FAQ, Top
3874 @comment node-name, next, previous, up
3877 Here is an old list of things to do,
3878 in addition to the bugs that are now tracked on launchpad:
3879 @url{https://launchpad.net/asdf}.
3881 @section Outstanding spec questions, things to add
3883 ** packaging systems
3885 *** manual page component?
3887 ** style guide for .asd files
3889 You should either use keywords or be careful
3890 with the package that you evaluate defsystem forms in.
3891 Otherwise @code{(defsystem partition ...)}
3892 being read in the @code{cl-user} package
3893 will intern a @code{cl-user:partition} symbol,
3894 which will then collide with the @code{partition:partition} symbol.
3896 Actually there's a hairier packages problem to think about too.
3897 @code{in-order-to} is not a keyword:
3898 if you read @code{defsystem} forms in a package that doesn't use ASDF,
3899 odd things might happen.
3902 ** extending defsystem with new options
3904 You might not want to write a whole parser,
3905 but just to add options to the existing syntax.
3906 Reinstate @code{parse-option} or something akin.
3909 ** document all the error classes
3911 ** what to do with compile-file failure
3913 Should check the primary return value from compile-file and see if
3914 that gets us any closer to a sensible error handling strategy
3918 lift unix-dso stuff from db-sockets
3922 A ``dry run'' of an operation can be made with the following form:
3925 (traverse (make-instance '<operation-name>)
3926 (find-system <system-name>)
3930 This uses unexported symbols.
3931 What would be a nice interface for this functionality?
3933 @section Missing bits in implementation
3935 ** reuse the same scratch package whenever a system is reloaded from disk
3937 ** proclamations probably aren't
3939 ** when a system is reloaded with fewer components than it previously had, odd things happen
3941 We should do something inventive when processing a @code{defsystem} form,
3942 like take the list of kids and @code{setf} the slot to @code{nil},
3943 then transfer children from old to new list as they're found.
3945 ** (stuff that might happen later)
3947 *** Propagation of the @code{:force} option.
3951 @code{(asdf:compile-system :araneida :force t)}
3953 also forces compilation of every other system the @code{:araneida} system depends on.
3954 This is rarely useful to me;
3955 usually, when I want to force recompilation of something more than a single source file,
3956 I want to recompile only one system.
3957 So it would be more useful to have @code{make-sub-operation}
3958 refuse to propagate @code{:force t} to other systems, and
3959 propagate only something like @code{:force :recursively}.
3961 Ideally what we actually want is some kind of criterion that says
3962 to which systems (and which operations) a @code{:force} switch will propagate.
3964 The problem is perhaps that ``force'' is a pretty meaningless concept.
3965 How obvious is it that @code{load :force t} should force @emph{compilation}?
3966 But we don't really have the right dependency setup
3967 for the user to compile @code{:force t} and expect it to work
3968 (files will not be loaded after compilation, so the compile
3969 environment for subsequent files will be emptier than it needs to be)
3971 What does the user actually want to do when he forces?
3972 Usually, for me, update for use with a new version of the Lisp compiler.
3973 Perhaps for recovery when he suspects that something has gone wrong.
3974 Or else when he's changed compilation options or configuration
3975 in some way that's not reflected in the dependency graph.
3977 Other possible interface: have a ``revert'' function akin to @code{make clean}.
3980 (asdf:revert 'asdf:compile-op 'araneida)
3983 would delete any files produced by @code{(compile-system :araneida)}.
3984 Of course, it wouldn't be able to do much about stuff in the image itself.
3986 How would this work?
3990 There's a difference between a module's dependencies (peers)
3991 and its components (children).
3992 Perhaps there's a similar difference in operations?
3993 For example, @code{(load "use") depends-on (load "macros")} is a peer,
3994 whereas @code{(load "use") depends-on (compile "use")}
3995 is more of a ``subservient'' relationship.
3997 @node Inspiration, Concept Index, TODO list, Top
3998 @comment node-name, next, previous, up
3999 @chapter Inspiration
4001 @section mk-defsystem (defsystem-3.x)
4003 We aim to solve basically the same problems as @code{mk-defsystem} does.
4004 However, our architecture for extensibility
4005 better exploits CL language features (and is documented),
4006 and we intend to be portable rather than just widely-ported.
4007 No slight on the @code{mk-defsystem} authors and maintainers is intended here;
4008 that implementation has the unenviable task
4009 of supporting pre-ANSI implementations, which is no longer necessary.
4011 The surface defsystem syntax of asdf is more-or-less compatible with
4012 @code{mk-defsystem}, except that we do not support
4013 the @code{source-foo} and @code{binary-foo} prefixes
4014 for separating source and binary files, and
4015 we advise the removal of all options to specify pathnames.
4017 The @code{mk-defsystem} code for topologically sorting
4018 a module's dependency list was very useful.
4020 @section defsystem-4 proposal
4022 Marco and Peter's proposal for defsystem 4 served as the driver for
4023 many of the features in here. Notable differences are:
4027 We don't specify output files or output file extensions
4028 as part of the system.
4030 If you want to find out what files an operation would create,
4034 We don't deal with CL packages
4036 If you want to compile in a particular package, use an @code{in-package} form
4037 in that file (ilisp / SLIME will like you more if you do this anyway)
4040 There is no proposal here that @code{defsystem} does version control.
4042 A system has a given version which can be used to check dependencies,
4046 The defsystem 4 proposal tends to look more at the external features,
4047 whereas this one centres on a protocol for system introspection.
4049 @section kmp's ``The Description of Large Systems'', MIT AI Memo 801
4051 Available in updated-for-CL form on the web at
4052 @url{http://nhplace.com/kent/Papers/Large-Systems.html}
4054 In our implementation we borrow kmp's overall @code{PROCESS-OPTIONS}
4055 and concept to deal with creating component trees
4056 from @code{defsystem} surface syntax.
4057 [ this is not true right now, though it used to be and
4058 probably will be again soon ]
4061 @c -------------------
4064 @node Concept Index, Function and Class Index, Inspiration, Top
4065 @unnumbered Concept Index
4069 @node Function and Class Index, Variable Index, Concept Index, Top
4070 @unnumbered Function and Class Index
4074 @node Variable Index, , Function and Class Index, Top
4075 @unnumbered Variable Index