Provided by: texlive-extra-utils_2024.20250309-2_all bug

NAME

       bundledoc - bundle all the files needed by a LaTeX document

SYNOPSIS

       bundledoc [--version] [--help] [--[no]verbose] [--texfile=file.tex] [--directory=directory]
       [--[no]localonly] [--exclude=string] [--include=filespec] [--manifest=file]
       [--listdeps=[yes|no|only|rel]...]  [--[no]keepdirs] [--config=file.cfg] file.dep

DESCRIPTION

       bundledoc is a post-processor for the snapshot package that bundles together all the classes, packages,
       and files needed to build a given LaTeX document.  It reads the .dep file that snapshot produces, finds
       each of the files mentioned therein, and packages them into a single archive file (e.g., a .tar.gz file),
       suitable for moving across systems, transmitting to a colleague, etc.

       As the simplest example possible, consider a LaTeX file called, say, hello.tex:

           \RequirePackage{snapshot}       % Needed by bundledoc
           \documentclass[11pt]{article}

           \begin{document}
           Hello, world!
           \end{document}

       The "\RequirePackage{snapshot}" causes a hello.dep file to be produced.  When bundledoc is then given
       "hello.dep" as an argument, it locates the dependent files -- snapshot.sty, article.cls, and size11.clo
       -- and bundles them into a single archive file, along with hello.tex and a MANIFEST file (described in
       "OPTIONS", below).

OPTIONS

       In the following descriptions, somefile refers to the name of your main LaTeX document (no extension).

       bundledoc requires the name of the dependency file produced by snapshot, normally somefile.dep).  (For
       convenience, the file can be specified without its .dep extension.)  The following options may also be
       given:

       --version
           Output the bundledoc script's version number.  This overrides all of the remaining options.

       --help
           Give a brief usage message.  This overrides all of the remaining options.

       --[no]verbose                    (default: "noverbose")
           bundledoc  normally  does  not  output  anything except error messages.  With "--verbose", it outputs
           copious status messages.

       --texfile=main .tex file            (default: somefile.tex)
           snapshot's dependency file does not list the main LaTeX file (the one that gets passed to latex).  In
           order for bundledoc to find and bundle that file, bundledoc assumes it  has  the  same  name  as  the
           snapshot dependency file but with a .tex extension.  If this is not the case, then use "--texfile" to
           specify the correct filename.

       --directory=archive directory       (default: somefile)
           When  bundledoc  creates  an  archive (e.g., a .tar or .zip file) containing the document's files, it
           puts all of them in a directory to avoid cluttering the current directory with files.  If  the  given
           dependency  file  is  called  somefile.dep then the resulting archive will, by default, store all the
           dependent files in a somefile directory.  To change the directory name use the "--directory" option.

       --[no]localonly                  (default: "nolocalonly")
           Although bundledoc normally archives all of the files named  in  the  .dep  file,  the  "--localonly"
           option  tells  bundledoc  to  exclude  all  files  located  in a directory other than the .tex file's
           directory or one of its subdirectories.

       --exclude=string                    (default: none)
           While "--localonly" causes files outside of the .tex file's directory tree to  be  omitted  from  the
           archive,  "--exclude"  provides  finer-grained  control  over  files  to  omit from the archive.  The
           "--exclude" option, which can be specified repeatedly on the command line,  causes  all  files  whose
           name contains string to be omitted from the archive.

       --include=filespec                  (default: none)
           The "--include" option, which can be specified repeatedly on the command line, instructs bundledoc to
           include in the archive all of the files matching filespec, even if they're not referenced in the .dep
           file.

       --manifest=manifest file            (default: MANIFEST)
           In  addition to the dependent files, bundledoc includes in the archive file one extra file called, by
           default, ``MANIFEST''.  MANIFEST is a text  file  that  lists  the  original  filenames  of  all  the
           dependencies.   To  change  the  filename  from  ``MANIFEST'' to something else, use the "--manifest"
           option.  As a special case, "--manifest=""" tells bundledoc not to include a manifest file at all.

       --listdeps=[yes|no|only|rel]...]       (default: "no")
           "--listdeps" accepts one or more of "yes", "no", "only", or "rel" as a comma-separated list.  As long
           as "no" does not appear in this list, bundledoc outputs all of the main  LaTeX  file's  dependencies.
           If  the list contains "rel", then bundledoc outputs the list of dependencies with relative pathnames.
           If the list contains "only", then bundledoc exits after displaying the  list,  without  producing  an
           archive.

       --[no]keepdirs                   (default: "nokeepdirs")
           Normally, the archive file that bundledoc produces contains a single directory -- and subdirectories,
           if  the  document refers explicitly to them -- in which all the dependent files lie.  If "--keepdirs"
           is specified, all the dependent files are stored with their  original  pathnames.   For  example,  if
           somefile.tex  depends  on  figures/somefigure.eps,  article.cls,  and snapshot.sty, then the somefile
           archive will normally contain the following files:

           •   somefile/somefile.texsomefile/figures/somefigure.epssomefile/article.clssomefile/snapshot.stysomefile/MANIFEST

           However, "--keepdirs" will cause the somefile archive to contain the  following  sorts  of  filenames
           instead:

           •   home/me/mydocs/somefile.texhome/me/mydocs/figures/somefigure.epsusr/share/texmf/tex/latex/base/article.clsusr/share/texmf/tex/latex/snapshot/snapshot.sty

           "--directory"  is  not used when "--keepdirs" is in effect.  In addition, no manifest file is written
           to the archive file as it contains redundant information.

       --config=configuration file         (default: <none>)
           The "--config" option is used to point bundledoc to the appropriate  configuration  (.cfg)  file  for
           your  TeX distribution and operating system.  bundledoc comes with a few configuration files and it's
           easy to write more.  See "CONFIGURATION FILES" (below) for a description of  the  configuration  file
           format.  For convenience, the file can be specified without its .cfg extension.

CONFIGURATION FILES

   Format
       Configuration  files  follow a fairly simple format.  Lines beginning with "#" are comments.  Blank lines
       are ignored.  All other lines are of the form:

           variable: value

       The current version of bundledoc recognizes the following variables:

       bundle
           The command to use to bundle a set of files into a single archive file

       sink
           The affix to a command to discard its output

       find
           The command to find a file within the TeX tree(s).

       Values that are too long for one line can be split across multiple  lines  by  using  "\"  as  the  line-
       continuation symbol.

       There  are  two  environment  variables  that  bundledoc  makes  available  for use by configuration-file
       commands: "BDBASE", which is set to somefile (as in "OPTIONS"), and "BDINPUTS", which is set to a  space-
       separated  list  of  files  that a command is to operate upon.  That is, when the command associated with
       "bundle" is running, "BDINPUTS" contains the list of all the files that are to be archived.  In contrast,
       when the command associated with "find" is running, "BDINPUTS" contains the name of the  file  to  search
       for.

   Examples
       The  following  configuration file parallels bundledoc's default values of the various configuration-file
       variables, which represents a kpathsea-based TeX distribution running on a  generic  Unix  system,  which
       doesn't necessarily have any of the GNU tools, such as gzip or GNU tar:

           # "Default" configuration file
           # By Scott Pakin <scott+bdoc@pakin.org>

           bundle: (tar -cvf - $BDINPUTS | compress > $BDBASE.tar.Z)
           sink:   > /dev/null 2>&1
           find:   kpsewhich -progname=latex $BDINPUTS

       The  parentheses  in the "bundle:" line tell the Unix shell to run the command in a subshell.  This is to
       make the "sink:" affix work properly (i.e., so there aren't two ">"'s in the same command).

       Notice how the commands treat "BDBASE" and "BDINPUTS" like any other  environment  variables  in  a  Unix
       shell, using "$" to take their value.  Other operating systems use different conventions for referring to
       environment variables.  For instance, a configuration file for a Windows-based TeX distribution would use
       "%BDBASE%" and "%BDINPUTS%" instead.

       The  value  for  "sink:"  is specific to an operating system.  The value for "find:" is specific to a TeX
       distribution.  "bundle:" is where the most opportunity for customization lies.  You can use "bundle:"  to
       specify  your  favorite  archive format.  For example, you can produce a shar file on Unix with something
       like:

           bundle: (shar --archive-name="$BDBASE" $BDINPUTS > $BDBASE.sh)

       or a CAB file on Microsoft Windows with something like:

           bundle: cabarc -r -p N %BDBASE%.cab %BDINPUTS%

EXAMPLES

       Assume that myfile.dep was produced from myfile.tex by following  the  instructions  in  the  Description
       section.   The  following  command  produces  a  .zip  file  with  the MikTeX TeX distribution running on
       Microsoft Windows:

           bundledoc --config=miktex.cfg myfile.dep

       This can be abbreviated to

           bundledoc --config=miktex myfile

       The following builds a .tar.gz archive with the TeX Live distribution running on  a  Unix-like  operating
       system.   bundledoc  will  produce  verbose  output describing its operations.  All files not in the same
       directory tree as myfile.tex and all files containing  ".fd"  or  ".sty"  in  their  names  are  omitted.
       However, all .bib files in the current directory will be included in the archive even though none of them
       are referenced by myfile.dep.  Finally, no MANIFEST file will be produced.

           bundledoc --config=texlive-unix.cfg --verbose --localonly \
             --exclude=.fd --exclude=.cfg --include="*.bib" --manifest="" \
             myfile.dep

FILES

       The  user  must  have  previously installed snapshot.sty and used it to produce a dependency file for his
       document.  Besides that, the set of external files needed by bundledoc is system-specific and depends  on
       the configuration file used.  (See "CONFIGURATION FILES", above.)

       bundledoc currently comes with two configuration files:

       texlive-unix.cfg
           Configuration  file  for  TeX  Live installations on Unix or Linux.  TeX Live is a kpathsea-based TeX
           distribution that runs on various flavors of Unix and Microsoft  Windows.   texlive-unix.cfg  assumes
           you  have  gzip  and uses it to produce a .tar.gz archive file.  The configuration file has bundledoc
           use kpsewhich to find LaTeX files.

       miktex.cfg
           Configuration file for MikTeX installations.  MikTeX is a  popular  TeX  distribution  for  Microsoft
           Windows.   miktex.cfg  assumes  you  have  zip  and  uses  it  to  produce  a .zip archive file.  The
           configuration file now has bundledoc use kpsewhich to find  LaTeX  files;  older  version  of  MikTeX
           required the rather nonstandard initexmf for this purpose.

       texlive-unix-arlatex.cfg
           This is a variant of texlive-unix.cfg that uses arlatex instead of gzip to archive files.  arlatex is
           a  script  included in the bundledoc distribution that generates a self-extracting .tex file based on
           LaTeX's "filecontents" environment.

NOTES

   Including and excluding files
       The "--localonly", "--exclude", and "--include" options provide  control  over  the  archive's  contents.
       "--exclude"  and  "--include"  can be specified repeatedly on the command line.  The order in which these
       options are specified is immaterial; bundledoc processes file inclusions and exclusions in the  following
       order:

       1.  All files referenced by the .dep file are added to the list of files to archive.

       2.  If  "--localonly" is specified, all files not found in the .tex file's directory are removed from the
           list.

       3.  For each "--exclude" string specified, all files containing that string are removed from the list.

       4.  For each "--include" file specification, the set of files designated by its expansion  are  added  to
           the list.

   Issues When Running Under Microsoft Windows
       First, because bundledoc is a Perl script, you should do one of the following to run it under Windows:

       •   "perl bundledoc"

       •   Rename  bundledoc  to  bundledoc.pl  and  run  "bundledoc.pl".   (This  is  assuming  you have a file
           association set up for .pl.)

       •   Run the pl2bat script (if you have it) to convert bundledoc to bundledoc.bat, then run "bundledoc".

       Second, Windows uses a multi-rooted filesystem (i.e., multiple drive letters).  I wouldn't  be  surprised
       if  bad  things  were  to  happen  if  the files to be bundled are scattered across drives.  In addition,
       Windows supports ``UNC'' filenames, which have no drive letter at all, just a  machine  and  share  name.
       UNC filenames are also untested waters for bundledoc.  Be careful!

   Testing Status
       I have tested bundledoc only with Perl v5.6.0 and later and only on the following platforms:

       •   Linux + TeX Live

       •   Linux + teTeX

       •   Windows NT + MiKTeX

       •   Solaris + ??? (something kpathsea-based)

       It is my hope that bundledoc works on many more platforms than those.  I tried to make the program itself
       fairly  independent  of  the  operating system; only the configuration files should have to change to run
       bundledoc on a different system.

   Future Work
       I'd like bundledoc to work on as wide a variety of TeX distributions as possible.  If  your  platform  is
       significantly  different  from the ones listed in "Testing Status" (e.g., if you're running OS X) and you
       need to create a substantially different configuration file from texlive-unix.cfg and miktex.cfg,  please
       send it to me at the address listed in "AUTHOR" so I can include it in a future version of bundledoc.  (I
       make no promises, though).

       Once  bundledoc  works  on  all  the  major  operating  systems  and TeX distributions it would be really
       convenient if I could get bundledoc to detect the platform it's running on and  automatically  select  an
       appropriate configuration file.

       Finally,  it  would be handy for bundledoc to include fonts in the archive file.  At a minimum, it should
       include .tfm files, but it would be even better if it included .mf, .pfb, .ttf,  and  other  common  font
       formats, as well.

   Acknowledgments
       Thanks  to  Fabien  Vignes-Tourneret  for  suggesting  what  became  the  "--localonly"  option and for a
       discussion that led to the "--exclude" and "--include" options; to Marius Kleiner for updating  bundledoc
       to properly handle document subdirectories; and to Frank Mittelbach for suggesting using Kpathsea to help
       find .cfg files and to automatically append .cfg and .dep extensions if necessary.

SEE ALSO

       arlatex(1), gzip(1), kpsewhich(1), latex(1), perl(1), zip(1), the snapshot documentation

AUTHOR

       Scott Pakin, scott+bdoc@pakin.org

v3.5                                               2025-02-26                                       BUNDLEDOC(1)