File: usage.cc

package info (click to toggle)
icmake 13.05.01-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 7,132 kB
  • sloc: cpp: 11,595; fortran: 883; makefile: 853; sh: 546; pascal: 342
file content (84 lines) | stat: -rw-r--r-- 4,702 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#include "main.ih"

namespace {
char const info[] = R"_( [options] [arg]
Where:
    [options] - optional arguments (short options between parentheses, quotes
                in the descriptions must be omitted when used as option
                arguments): 
       --colors (-c)        - the compiler uses diagnostic colors 
                              (default: no colors).
       --dependencies (-d)  - no compilation, merely show the dependencies
       --extension (-x) ext - ext: source file extension. By default .cc
       --extern (-e) arg    - the currrent project's .gcm files may depend on
                              .gcm files defined by other (external)
                              projects. Those external .gcm files are located
                              in the directory 'arg' or in the directory
                              location(s) argified in separate
                              lines of the file `arg' (ignoring its empty
                              lines and lines starting with //.
                              Those external .gcm files (and the .gcm files
                              they depend on) are soft-linked to the project's
                              gcm.cache directory.
       --help (-h)          - provide this help and end the program
       --ignore (-i) list   - all subdirs except for those listed in 'list'
                              are visited, CLASSES is not used. 
                              Use --ignore '' to visit all subdirs.
       --library (-l) lib   - the path (relative to the project's top-level
                              directory) to a file containing the project's .o
                              files.
       --mark (-m) arg      - arg can be +, ++, or a filename. When --mark is
                              specified interface units depending on other
                              modified interface units are also compiled.  
                              If arg is '++' then the last write times of all
                              files implementing or using those interface
                              units are set to the current time.
                              If arg isn't + or ++ then it specifies a
                              filename to receive the names of the files
                              otherwise processed by '++'.
       --quiet (-q) what    - by default compiler calls and dependencies are 
                              written to the std. output stream. 
                              Specify 'what' as:
                                c - to suppress showing the compiler commands
                                d - to suppress showing the dependencies.
                                  Anything else: both 'c' and 'd'
                              --verbose suppresses --quiet
       --subdir (-s)        - the compiled module/partition files (.o files)
                              are located in in their source file directories.
                              By default in the project's tmp/o sub-directory.
                              Each .o file is prefixed by a unique number
                              (e.g., 1module.o, 2module.o, ...).
       --version (-v)       - show version information and end the program.
       --verbose (-V)       - show details of performed steps.

    arg - the action to perform:
        no argument - perform the default cconfigured module-mapping according
            to the specified options (no options: using CLASSES and performing
            compilations). 
            
        clean - remove the gcm.cache directories in the current working
                directory and in the project's subdirectories

        other argument - the module/partition source files are not compiled,
                but their names (beyond the current working directory) are
                written in the order they should be compiled to the stdandard
                output stream if arg is - and otherwise to the file whose name
                is specified by arg.
        
    Files are compiled using the C++ standard compiler option specified by the
    ICMAKE_CPPSTD environment variable. If ICMAKE_CPPSTD isn't defined the
    compiler's default C++ standard is used.
)_";

//       --file (-f) name     - the module/partition source files are not
//                              compiled, but their names (beyond the current
//                              working directory) are written to 'name'. Use
//                              name '-' to write the namesn to the stdandard
//                              output stream.

}

void usage(std::string const &progname)
{
    Tools::usageTop(progname) << info;
}