compilesettings.nim 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. #
  2. #
  3. # The Nim Compiler
  4. # (c) Copyright 2020 Nim Contributors
  5. #
  6. # See the file "copying.txt", included in this
  7. # distribution, for details about the copyright.
  8. #
  9. ## This module allows querying the compiler about
  10. ## diverse configuration settings. See also `compileOption`.
  11. # Note: Only add new enum values at the end to ensure binary compatibility with
  12. # other Nim compiler versions!
  13. type
  14. SingleValueSetting* {.pure.} = enum ## \
  15. ## settings resulting in a single string value
  16. arguments, ## experimental: the arguments passed after '-r'
  17. outFile, ## experimental: the output file
  18. outDir, ## the output directory
  19. nimcacheDir, ## the location of the 'nimcache' directory
  20. projectName, ## the project's name that is being compiled
  21. projectPath, ## experimental: some path to the project that is being compiled
  22. projectFull, ## the full path to the project that is being compiled
  23. command, ## experimental: the command (e.g. 'c', 'cpp', 'doc') passed to
  24. ## the Nim compiler
  25. commandLine, ## experimental: the command line passed to Nim
  26. linkOptions, ## additional options passed to the linker
  27. compileOptions, ## additional options passed to the C/C++ compiler
  28. ccompilerPath ## the path to the C/C++ compiler
  29. backend ## the backend (eg: c|cpp|objc|js); both `nim doc --backend:js`
  30. ## and `nim js` would imply backend=js
  31. libPath ## the absolute path to the stdlib library, i.e. nim's `--lib`, since 1.5.1
  32. gc ## gc selected
  33. MultipleValueSetting* {.pure.} = enum ## \
  34. ## settings resulting in a seq of string values
  35. nimblePaths, ## the nimble path(s)
  36. searchPaths, ## the search path for modules
  37. lazyPaths, ## experimental: even more paths
  38. commandArgs, ## the arguments passed to the Nim compiler
  39. cincludes, ## the #include paths passed to the C/C++ compiler
  40. clibs ## libraries passed to the C/C++ compiler
  41. proc querySetting*(setting: SingleValueSetting): string {.
  42. compileTime, noSideEffect.} =
  43. ## Can be used to get a string compile-time option.
  44. ##
  45. ## See also:
  46. ## * `compileOption <system.html#compileOption,string>`_ for `on|off` options
  47. ## * `compileOption <system.html#compileOption,string,string>`_ for enum options
  48. ##
  49. runnableExamples:
  50. const nimcache = querySetting(SingleValueSetting.nimcacheDir)
  51. proc querySettingSeq*(setting: MultipleValueSetting): seq[string] {.
  52. compileTime, noSideEffect.} =
  53. ## Can be used to get a multi-string compile-time option.
  54. ##
  55. ## See also:
  56. ## * `compileOption <system.html#compileOption,string>`_ for `on|off` options
  57. ## * `compileOption <system.html#compileOption,string,string>`_ for enum options
  58. runnableExamples:
  59. const nimblePaths = querySettingSeq(MultipleValueSetting.nimblePaths)