6 #include <msp/datafile/objectloader.h>
7 #include <msp/fs/path.h>
10 Stores information about compiler command line parameters in a more abstract
11 form. Allows combining with other BuildInfos to support package dependencies.
18 FORCE_STATIC, //< Only accept static libraries
19 STATIC, //< Prefer static libraries but accept dynamic as well
20 DYNAMIC, //< Prefer dynamic libraries but accept static as well
21 FORCE_DYNAMIC //< Only accept dynamic libraries
24 class Loader: public Msp::DataFile::ObjectLoader<BuildInfo>
29 void incpath(const std::string &);
30 void define(const std::string &, const std::string &);
31 void libmode_for_lib(const std::string &, LibraryMode);
32 void libpath(const std::string &);
33 void library(const std::string &);
34 void local_incpath(const std::string &);
35 void sysroot(const std::string &);
40 LOCAL, //< Include all information
41 DEPENDENCY, //< Include all but code generation options
42 CHAINED //< Include only compilation options
46 A wrapper which tracks the set status of the wrapped variable. A default
47 value may be provided in initialization without causing it to be treated as
48 set. Assigning from a raw value flags the Tracked object as set. Assigning
49 from another Tracked object will only change the value of the target if the
63 Tracked(): value(T()), set(false) { }
64 Tracked(T v): value(v), set(false) { }
65 Tracked &operator=(const Tracked &v) { if(v.set) { value = v.value; set = true; } return *this; }
67 Tracked &operator=(T v) { value = v; set = true; return *this; }
68 operator T() const { return value; }
71 typedef std::map<std::string, std::string> DefineMap;
72 typedef std::list<Msp::FS::Path> PathList;
73 typedef std::list<std::string> WordList;
74 typedef std::map<std::string, LibraryMode> LibModeMap;
76 Tracked<Msp::FS::Path> sysroot;
79 PathList local_incpath;
82 Tracked<LibraryMode> libmode;
84 Tracked<bool> threads;
86 Tracked<int> optimize;
88 Tracked<unsigned> warning_level;
89 Tracked<bool> fatal_warnings;
93 /** Returns the library mode for linking a particular library. If no mode
94 has been specified for that library, the the global library mode is
96 LibraryMode get_libmode_for(const std::string &) const;
98 /** Updates the BuildInfo from another one. Lists are concatenated, with
99 the first occurrence of each item preserved. Scalars are overwritten.
101 The update level determines what information is updated. */
102 void update_from(const BuildInfo &, UpdateLevel = LOCAL);