NAMES(2)                                                 NAMES(2)

     NAME
          Names: basename, cleanname, dirname, elements, isprefix,
          pathname, relative, rooted - file name manipulation

     SYNOPSIS
          include "names.m";
          names := load Names Names->PATH;

          basename:  fn(name: string, suffix: string): string;
          cleanname: fn(name: string): string;
          dirname:   fn(name: string): string;
          elements:  fn(name: string): list of string;
          isprefix:  fn(a: string, b: string): int;
          pathname:  fn(els: list of string): string;
          relative:  fn(name: string, root: string): string;
          rooted:    fn(root: string, name: string): string;

     DESCRIPTION
          Names provides operations on file names (path names):

          basename   Return the trailing component of name (the text
                     after the final `/'), shorn of suffix (which may
                     be null).

          cleanname  Return a `cleaner' version of name: there are no
                     redundant and trailing slashes, and directory
                     names `.'  and `..'  have been interpreted lexi-
                     cally.  If the result would otherwise be the
                     empty string, the name `.'  is returned instead.

          dirname    Return the directory component of name: the
                     string up to but not including the final
                     slash(es).

          elements   Return a list of the path elements of name: the
                     words between slashes.  If name starts with a
                     `/', the head of the list will be the string "/"
                     but otherwise slashes do not appear.

          pathname   Return a path name formed from a list of elements
                     as produced by elements.

          isprefix   Return true iff path name a is a prefix of path
                     name b.

          relative   If name is root/X for some X, return X; otherwise
                     return name unchanged.

          rooted     Return the path name for name relative to a given

     Page 1                       Plan 9              (printed 1/3/25)

     NAMES(2)                                                 NAMES(2)

                     root directory (either name may be nil).  If name
                     itself starts with `/' or `#', the result is
                     name; otherwise it is root/name.

          See sys-intro(2) for details of file name syntax and its
          interpretation.

     SOURCE
          /appl/lib/names.b

     SEE ALSO
          sys-intro(2), sys-fd2path(2), workdir(2)

     Page 2                       Plan 9              (printed 1/3/25)