Provided by: erlang-manpages_25.3.2.8+dfsg-1ubuntu4_all bug

NAME

       file_sorter - File sorter.

DESCRIPTION

       This  module  contains  functions  for sorting terms on files, merging already sorted files, and checking
       files for sortedness. Chunks containing binary terms are read from a sequence of files, sorted internally
       in  memory  and written on temporary files, which are merged producing one sorted file as output. Merging
       is provided as an optimization; it is faster when the files are already sorted, but it  always  works  to
       sort instead of merge.

       On  a  file,  a  term  is represented by a header and a binary. Two options define the format of terms on
       files:

         {header, HeaderLength}:
           HeaderLength determines the number of bytes preceding each binary and containing the  length  of  the
           binary in bytes. Defaults to 4. The order of the header bytes is defined as follows: if B is a binary
           containing a header only, size Size of the binary is calculated as <<Size:HeaderLength/unit:8>> = B.

         {format, Format}:
           Option Format determines the function that is applied to binaries to create the terms to  be  sorted.
           Defaults  to  binary_term, which is equivalent to fun binary_to_term/1. Value binary is equivalent to
           fun(X) -> X end, which means that the binaries are sorted as they are. This is the fastest format. If
           Format  is  term,  io:read/2  is called to read terms. In that case, only the default value of option
           header is allowed.

           Option format also determines what is written to the sorted output file:  if  Format  is  term,  then
           io:format/3  is  called  to  write  each  term, otherwise the binary prefixed by a header is written.
           Notice that the binary written is the same binary that was read; the  results  of  applying  function
           Format are thrown away when the terms have been sorted. Reading and writing terms using the io module
           is much slower than reading and writing binaries.

       Other options are:

         {order, Order}:
           The default is to sort terms in ascending order, but that can be changed by value  descending  or  by
           specifying  an  ordering  function Fun. An ordering function is antisymmetric, transitive, and total.
           Fun(A, B) is to return true if A comes before B in the ordering, otherwise false.  An  example  of  a
           typical  ordering  function is less than or equal to, =</2. Using an ordering function slows down the
           sort considerably. Functions keysort, keymerge and keycheck do not accept ordering functions.

         {unique, boolean()}:
           When sorting or merging files, only the first of a sequence of  terms  that  compare  equal  (==)  is
           output  if  this  option is set to true. Defaults to false, which implies that all terms that compare
           equal are output. When checking files for sortedness, a check  that  no  pair  of  consecutive  terms
           compares equal is done if this option is set to true.

         {tmpdir, TempDirectory}:
           The  directory  where temporary files are put can be chosen explicitly. The default, implied by value
           "", is to put temporary files on the same directory as  the  sorted  output  file.  If  output  is  a
           function  (see  below),  the  directory  returned  by  file:get_cwd()  is  used instead. The names of
           temporary files are derived from the Erlang nodename (node()), the process identifier of the  current
           Erlang  emulator  (os:getpid()),  and a unique integer (erlang:unique_integer([positive])). A typical
           name is fs_mynode@myhost_1763_4711.17, where 17 is a sequence number. Existing files are overwritten.
           Temporary files are deleted unless some uncaught EXIT signal occurs.

         {compressed, boolean()}:
           Temporary  files  and  the  output file can be compressed. Defaults false, which implies that written
           files are not compressed. Regardless of the value of option compressed, compressed files  can  always
           be  read.  Notice that reading and writing compressed files are significantly slower than reading and
           writing uncompressed files.

         {size, Size}:
           By default about 512*1024 bytes read from files are sorted internally. This option is rarely needed.

         {no_files, NoFiles}:
           By default 16 files are merged at a time. This option is rarely needed.

       As an alternative to sorting files, a function of one argument can be specified  as  input.  When  called
       with argument read, the function is assumed to return either of the following:

         * end_of_input or {end_of_input, Value}} when there is no more input (Value is explained below).

         * {Objects,  Fun},  where  Objects is a list of binaries or terms depending on the format, and Fun is a
           new input function.

       Any other value is immediately returned as value of the current call  to  sort  or  keysort.  Each  input
       function is called exactly once. If an error occurs, the last function is called with argument close, the
       reply of which is ignored.

       A function of one argument can be specified as output. The results of sorting or  merging  the  input  is
       collected  in a non-empty sequence of variable length lists of binaries or terms depending on the format.
       The output function is called with one list at a time, and is assumed to return a  new  output  function.
       Any  other  return  value  is  immediately  returned  as  value  of the current call to the sort or merge
       function. Each output function is called exactly once. When some output function has been applied to  all
       of  the  results  or  an  error occurs, the last function is called with argument close, and the reply is
       returned as value of the current call to the sort or merge function.

       If a function is specified as input and the  last  input  function  returns  {end_of_input,  Value},  the
       function  specified  as output is called with argument {value, Value}. This makes it easy to initiate the
       sequence of output functions with a value calculated by the input functions.

       As an example, consider sorting the terms on a disk log file. A function that reads chunks from the  disk
       log and returns a list of binaries is used as input. The results are collected in a list of terms.

       sort(Log) ->
           {ok, _} = disk_log:open([{name,Log}, {mode,read_only}]),
           Input = input(Log, start),
           Output = output([]),
           Reply = file_sorter:sort(Input, Output, {format,term}),
           ok = disk_log:close(Log),
           Reply.

       input(Log, Cont) ->
           fun(close) ->
                   ok;
              (read) ->
                   case disk_log:chunk(Log, Cont) of
                       {error, Reason} ->
                           {error, Reason};
                       {Cont2, Terms} ->
                           {Terms, input(Log, Cont2)};
                       {Cont2, Terms, _Badbytes} ->
                           {Terms, input(Log, Cont2)};
                       eof ->
                           end_of_input
                   end
           end.

       output(L) ->
           fun(close) ->
                   lists:append(lists:reverse(L));
              (Terms) ->
                   output([Terms | L])
           end.

       For  more  examples  of  functions  as  input and output, see the end of the file_sorter module; the term
       format is implemented with functions.

       The possible values of Reason returned when an error occurs are:

         * bad_object, {bad_object, FileName} - Applying the format function failed  for  some  binary,  or  the
           key(s) could not be extracted from some term.

         * {bad_term, FileName} - io:read/2 failed to read some term.

         * {file_error, FileName, file:posix()} - For an explanation of file:posix(), see file(3erl).

         * {premature_eof, FileName} - End-of-file was encountered inside some binary term.

DATA TYPES

       file_name() = file:name()

       file_names() = [file:name()]

       i_command() = read | close

       i_reply() =
           end_of_input |
           {end_of_input, value()} |
           {[object()], infun()} |
           input_reply()

       infun() = fun((i_command()) -> i_reply())

       input() = file_names() | infun()

       input_reply() = term()

       o_command() = {value, value()} | [object()] | close

       o_reply() = outfun() | output_reply()

       object() = term() | binary()

       outfun() = fun((o_command()) -> o_reply())

       output() = file_name() | outfun()

       output_reply() = term()

       value() = term()

       options() = [option()] | option()

       option() =
           {compressed, boolean()} |
           {header, header_length()} |
           {format, format()} |
           {no_files, no_files()} |
           {order, order()} |
           {size, size()} |
           {tmpdir, tmp_directory()} |
           {unique, boolean()}

       format() = binary_term | term | binary | format_fun()

       format_fun() = fun((binary()) -> term())

       header_length() = integer() >= 1

       key_pos() = integer() >= 1 | [integer() >= 1]

       no_files() = integer() >= 1

       order() = ascending | descending | order_fun()

       order_fun() = fun((term(), term()) -> boolean())

       size() = integer() >= 0

       tmp_directory() = [] | file:name()

       reason() =
           bad_object |
           {bad_object, file_name()} |
           {bad_term, file_name()} |
           {file_error,
            file_name(),
            file:posix() | badarg | system_limit} |
           {premature_eof, file_name()}

EXPORTS

       check(FileName) -> Reply

       check(FileNames, Options) -> Reply

              Types:

                 FileNames = file_names()
                 Options = options()
                 Reply = {ok, [Result]} | {error, reason()}
                 Result = {FileName, TermPosition, term()}
                 FileName = file_name()
                 TermPosition = integer() >= 1

              Checks  files for sortedness. If a file is not sorted, the first out-of-order element is returned.
              The first term on a file has position 1.

              check(FileName) is equivalent to check([FileName], []).

       keycheck(KeyPos, FileName) -> Reply

       keycheck(KeyPos, FileNames, Options) -> Reply

              Types:

                 KeyPos = key_pos()
                 FileNames = file_names()
                 Options = options()
                 Reply = {ok, [Result]} | {error, reason()}
                 Result = {FileName, TermPosition, term()}
                 FileName = file_name()
                 TermPosition = integer() >= 1

              Checks files for sortedness. If a file is not sorted, the first out-of-order element is  returned.
              The first term on a file has position 1.

              keycheck(KeyPos, FileName) is equivalent to keycheck(KeyPos, [FileName], []).

       keymerge(KeyPos, FileNames, Output) -> Reply

       keymerge(KeyPos, FileNames, Output, Options) -> Reply

              Types:

                 KeyPos = key_pos()
                 FileNames = file_names()
                 Output = output()
                 Options = options()
                 Reply = ok | {error, reason()} | output_reply()

              Merges tuples on files. Each input file is assumed to be sorted on key(s).

              keymerge(KeyPos, FileNames, Output) is equivalent to keymerge(KeyPos, FileNames, Output, []).

       keysort(KeyPos, FileName) -> Reply

              Types:

                 KeyPos = key_pos()
                 FileName = file_name()
                 Reply = ok | {error, reason()} | input_reply() | output_reply()

              Sorts tuples on files.

              keysort(N, FileName) is equivalent to keysort(N, [FileName], FileName).

       keysort(KeyPos, Input, Output) -> Reply

       keysort(KeyPos, Input, Output, Options) -> Reply

              Types:

                 KeyPos = key_pos()
                 Input = input()
                 Output = output()
                 Options = options()
                 Reply = ok | {error, reason()} | input_reply() | output_reply()

              Sorts  tuples on files. The sort is performed on the element(s) mentioned in KeyPos. If two tuples
              compare equal (==) on one element, the next element according to KeyPos is compared. The  sort  is
              stable.

              keysort(N, Input, Output) is equivalent to keysort(N, Input, Output, []).

       merge(FileNames, Output) -> Reply

       merge(FileNames, Output, Options) -> Reply

              Types:

                 FileNames = file_names()
                 Output = output()
                 Options = options()
                 Reply = ok | {error, reason()} | output_reply()

              Merges terms on files. Each input file is assumed to be sorted.

              merge(FileNames, Output) is equivalent to merge(FileNames, Output, []).

       sort(FileName) -> Reply

              Types:

                 FileName = file_name()
                 Reply = ok | {error, reason()} | input_reply() | output_reply()

              Sorts terms on files.

              sort(FileName) is equivalent to sort([FileName], FileName).

       sort(Input, Output) -> Reply

       sort(Input, Output, Options) -> Reply

              Types:

                 Input = input()
                 Output = output()
                 Options = options()
                 Reply = ok | {error, reason()} | input_reply() | output_reply()

              Sorts terms on files.

              sort(Input, Output) is equivalent to sort(Input, Output, []).