*: remove "Options:" string from help texts
[platform/upstream/busybox.git] / debianutils / mktemp.c
1 /* vi: set sw=4 ts=4: */
2 /*
3  * Mini mktemp implementation for busybox
4  *
5  *
6  * Copyright (C) 2000 by Daniel Jacobowitz
7  * Written by Daniel Jacobowitz <dan@debian.org>
8  *
9  * Licensed under GPLv2 or later, see file LICENSE in this source tree.
10  */
11
12 /* Coreutils 6.12 man page says:
13  *        mktemp [OPTION]... [TEMPLATE]
14  * Create a temporary file or directory, safely, and print its name. If
15  * TEMPLATE is not specified, use tmp.XXXXXXXXXX.
16  * -d, --directory
17  *        create a directory, not a file
18  * -q, --quiet
19  *        suppress diagnostics about file/dir-creation failure
20  * -u, --dry-run
21  *        do not create anything; merely print a name (unsafe)
22  * --tmpdir[=DIR]
23  *        interpret TEMPLATE relative to DIR. If DIR is not specified,
24  *        use  $TMPDIR if set, else /tmp.  With this option, TEMPLATE must
25  *        not be an absolute name. Unlike with -t, TEMPLATE may contain
26  *        slashes, but even here, mktemp still creates only the final com-
27  *        ponent.
28  * -p DIR use DIR as a prefix; implies -t [deprecated]
29  * -t     interpret TEMPLATE as a single file name component, relative  to
30  *        a  directory:  $TMPDIR, if set; else the directory specified via
31  *        -p; else /tmp [deprecated]
32  */
33
34 //usage:#define mktemp_trivial_usage
35 //usage:       "[-dt] [-p DIR] [TEMPLATE]"
36 //usage:#define mktemp_full_usage "\n\n"
37 //usage:       "Create a temporary file with name based on TEMPLATE and print its name.\n"
38 //usage:       "TEMPLATE must end with XXXXXX (e.g. [/dir/]nameXXXXXX).\n"
39 //usage:       "Without TEMPLATE, -t tmp.XXXXXX is assumed.\n"
40 //usage:     "\n        -d      Make directory, not file"
41 ////usage:   "\n        -q      Fail silently on errors" - we ignore this opt
42 //usage:     "\n        -t      Prepend base directory name to TEMPLATE"
43 //usage:     "\n        -p DIR  Use DIR as a base directory (implies -t)"
44 //usage:     "\n"
45 //usage:     "\nBase directory is: -p DIR, else $TMPDIR, else /tmp"
46 //usage:
47 //usage:#define mktemp_example_usage
48 //usage:       "$ mktemp /tmp/temp.XXXXXX\n"
49 //usage:       "/tmp/temp.mWiLjM\n"
50 //usage:       "$ ls -la /tmp/temp.mWiLjM\n"
51 //usage:       "-rw-------    1 andersen andersen        0 Apr 25 17:10 /tmp/temp.mWiLjM\n"
52
53 #include "libbb.h"
54
55 int mktemp_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
56 int mktemp_main(int argc UNUSED_PARAM, char **argv)
57 {
58         const char *path;
59         char *chp;
60         unsigned opts;
61         enum {
62                 OPT_d = 1 << 0,
63                 OPT_q = 1 << 1,
64                 OPT_t = 1 << 2,
65                 OPT_p = 1 << 3,
66         };
67
68         path = getenv("TMPDIR");
69         if (!path || path[0] == '\0')
70                 path = "/tmp";
71
72         /* -q is ignored */
73         opt_complementary = "?1"; /* 1 argument max */
74         opts = getopt32(argv, "dqtp:", &path);
75
76         chp = argv[optind];
77         if (!chp) {
78                 /* GNU coreutils 8.4:
79                  * bare "mktemp" -> "mktemp -t tmp.XXXXXX"
80                  */
81                 chp = xstrdup("tmp.XXXXXX");
82                 opts |= OPT_t;
83         }
84         if (opts & (OPT_t|OPT_p))
85                 chp = concat_path_file(path, chp);
86
87         if (opts & OPT_d) {
88                 if (mkdtemp(chp) == NULL)
89                         return EXIT_FAILURE;
90         } else {
91                 if (mkstemp(chp) < 0)
92                         return EXIT_FAILURE;
93         }
94
95         puts(chp);
96
97         return EXIT_SUCCESS;
98 }