advopt.txt 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. Advanced commands:
  2. //compileToC, cc compile project with C code generator
  3. //compileToCpp, cpp compile project to C++ code
  4. //compileToOC, objc compile project to Objective C code
  5. //js compile project to Javascript
  6. //e run a Nimscript file
  7. //rst2html convert a reStructuredText file to HTML
  8. use `--docCmd:skip` to skip compiling snippets
  9. //rst2tex convert a reStructuredText file to LaTeX
  10. //doc2tex extract the documentation to a LaTeX file
  11. //jsondoc extract the documentation to a json file
  12. //ctags create a tags file
  13. //buildIndex build an index for the whole documentation
  14. //genDepend generate a DOT file containing the
  15. module dependency graph
  16. //dump dump all defined conditionals and search paths
  17. see also: --dump.format:json (useful with: `| jq`)
  18. //check checks the project for syntax and semantics
  19. (can be combined with --defusages)
  20. Runtime checks (see -x):
  21. --objChecks:on|off turn obj conversion checks on|off
  22. --fieldChecks:on|off turn case variant field checks on|off
  23. --rangeChecks:on|off turn range checks on|off
  24. --boundChecks:on|off turn bound checks on|off
  25. --overflowChecks:on|off turn int over-/underflow checks on|off
  26. --floatChecks:on|off turn all floating point (NaN/Inf) checks on|off
  27. --nanChecks:on|off turn NaN checks on|off
  28. --infChecks:on|off turn Inf checks on|off
  29. Advanced options:
  30. --defusages:FILE,LINE,COL
  31. find the definition and all usages of a symbol
  32. -o:FILE, --out:FILE set the output filename
  33. --outdir:DIR set the path where the output file will be written
  34. --usenimcache will use `outdir=$$nimcache`, whichever it resolves
  35. to after all options have been processed
  36. --stdout:on|off output to stdout
  37. --colors:on|off turn compiler messages coloring on|off
  38. --filenames:abs|canonical|legacyRelProj
  39. customize how filenames are rendered in compiler messages,
  40. defaults to `abs` (absolute)
  41. --processing:dots|filenames|off
  42. show files as they're being processed by nim compiler
  43. --unitsep:on|off use the ASCII unit separator (31) between error
  44. messages, useful for IDE-like tooling
  45. --declaredLocs:on|off show declaration locations in messages
  46. --spellSuggest|:num show at most `num >= 0` spelling suggestions on typos.
  47. if `num` is not specified (or `auto`), return
  48. an implementation defined set of suggestions.
  49. --hints:on|off|list. `on|off` enables or disables hints.
  50. `list` reports which hints are selected.
  51. --hint:X:on|off turn specific hint X on|off. `hint:X` means `hint:X:on`,
  52. as with similar flags. `all` is the set of all hints
  53. (only `all:off` is supported).
  54. --hintAsError:X:on|off turn specific hint X into an error on|off
  55. -w:on|off|list, --warnings:on|off|list
  56. same as `--hints` but for warnings.
  57. --warning:X:on|off ditto
  58. --warningAsError:X:on|off ditto
  59. --styleCheck:off|hint|error
  60. produce hints or errors for Nim identifiers that
  61. do not adhere to Nim's official style guide
  62. https://nim-lang.org/docs/nep1.html
  63. --styleCheck:usages only enforce consistent spellings of identifiers,
  64. do not enforce the style on declarations
  65. --showAllMismatches:on|off
  66. show all mismatching candidates in overloading
  67. resolution
  68. --lib:PATH set the system library path
  69. --import:PATH add an automatically imported module
  70. see also `patchFile` in nimscript which offers more flexibility.
  71. --include:PATH add an automatically included module
  72. --nimcache:PATH set the path used for generated files
  73. see also https://nim-lang.org/docs/nimc.html#compiler-usage-generated-c-code-directory
  74. -c, --compileOnly:on|off compile Nim files only; do not assemble or link
  75. --noLinking:on|off compile Nim and generated files but do not link
  76. --noMain:on|off do not generate a main procedure
  77. --genScript:on|off generate a compile script (in the 'nimcache'
  78. subdirectory named 'compile_$$project$$scriptext'),
  79. and a '.deps' file containing the dependencies;
  80. implies --compileOnly
  81. --os:SYMBOL set the target operating system (cross-compilation)
  82. --cpu:SYMBOL set the target processor (cross-compilation)
  83. --debuginfo:on|off enables debug information
  84. -t, --passC:OPTION pass an option to the C compiler
  85. -l, --passL:OPTION pass an option to the linker
  86. --cc:SYMBOL specify the C compiler
  87. --cincludes:DIR modify the C compiler header search path
  88. --clibdir:DIR modify the linker library search path
  89. --clib:LIBNAME link an additional C library
  90. (you should omit platform-specific extensions)
  91. --project document the whole project (doc)
  92. --docRoot:path `nim doc --docRoot:/foo --project --outdir:docs /foo/sub/main.nim`
  93. generates: docs/sub/main.html
  94. if path == @pkg, will use nimble file enclosing dir
  95. if path == @path, will use first matching dir in `--path`
  96. if path == @default (the default and most useful), will use
  97. best match among @pkg,@path.
  98. if these are nonexistent, will use project path
  99. -b, --backend:c|cpp|js|objc
  100. sets backend to use with commands like `nim doc` or `nim r`
  101. --docCmd:cmd if `cmd == skip`, skips runnableExamples
  102. else, runs runnableExamples with given options, e.g.:
  103. `--docCmd:"-d:foo --threads:on"`
  104. --docSeeSrcUrl:url activate 'see source' for doc command
  105. (see doc.item.seesrc in config/nimdoc.cfg)
  106. --docInternal also generate documentation for non-exported symbols
  107. --lineDir:on|off generation of #line directive on|off
  108. --embedsrc:on|off embeds the original source code as comments
  109. in the generated output
  110. --tlsEmulation:on|off turn thread local storage emulation on|off
  111. --implicitStatic:on|off turn implicit compile time evaluation on|off
  112. --trmacros:on|off turn term rewriting macros on|off
  113. --multimethods:on|off turn multi-methods on|off
  114. --hotCodeReloading:on|off
  115. turn support for hot code reloading on|off
  116. --excessiveStackTrace:on|off
  117. stack traces use full file paths
  118. --stackTraceMsgs:on|off enable user defined stack frame msgs via `setFrameMsg`
  119. --skipCfg:on|off do not read the nim installation's configuration file
  120. --skipUserCfg:on|off do not read the user's configuration file
  121. --skipParentCfg:on|off do not read the parent dirs' configuration files
  122. --skipProjCfg:on|off do not read the project's configuration file
  123. --gc:refc|arc|orc|markAndSweep|boehm|go|none|regions
  124. select the GC to use; default is 'refc'
  125. --exceptions:setjmp|cpp|goto|quirky
  126. select the exception handling implementation
  127. --index:on|off turn index file generation on|off
  128. --putenv:key=value set an environment variable
  129. --NimblePath:PATH add a path for Nimble support
  130. --noNimblePath deactivate the Nimble path
  131. --clearNimblePath empty the list of Nimble package search paths
  132. --cppCompileToNamespace:namespace
  133. use the provided namespace for the generated C++ code,
  134. if no namespace is provided "Nim" will be used
  135. --expandMacro:MACRO dump every generated AST from MACRO
  136. --expandArc:PROCNAME show how PROCNAME looks like after diverse optimizations
  137. before the final backend phase (mostly ARC/ORC specific)
  138. --excludePath:PATH exclude a path from the list of search paths
  139. --dynlibOverride:SYMBOL marks SYMBOL so that dynlib:SYMBOL
  140. has no effect and can be statically linked instead;
  141. symbol matching is fuzzy so
  142. that --dynlibOverride:lua matches
  143. dynlib: "liblua.so.3"
  144. --dynlibOverrideAll
  145. disables the effects of the dynlib pragma
  146. --listCmd list the compilation commands; can be combined with
  147. `--hint:exec:on` and `--hint:link:on`
  148. --asm produce assembler code
  149. --parallelBuild:0|1|... perform a parallel build
  150. value = number of processors (0 for auto-detect)
  151. --incremental:on|off only recompile the changed modules (experimental!)
  152. --verbosity:0|1|2|3 set Nim's verbosity level (1 is default)
  153. --errorMax:N stop compilation after N errors; 0 means unlimited
  154. --maxLoopIterationsVM:N set max iterations for all VM loops
  155. --experimental:$1
  156. enable experimental language feature
  157. --legacy:$2
  158. enable obsolete/legacy language feature
  159. --useVersion:1.0|1.2 emulate Nim version X of the Nim compiler, for testing
  160. --benchmarkVM:on|off turn benchmarking of VM code with cpuTime() on|off
  161. --profileVM:on|off turn compile time VM profiler on|off
  162. --sinkInference:on|off turn sink parameter inference on|off (default: on)
  163. --panics:on|off turn panics into process terminations (default: off)
  164. --deepcopy:on|off enable 'system.deepCopy' for ``--gc:arc|orc``