summaryrefslogtreecommitdiff
path: root/pkgconfig.h
diff options
context:
space:
mode:
authorChris Johns <chrisj@rtems.org>2012-05-07 08:47:11 +1000
committerChris Johns <chrisj@rtems.org>2012-05-07 08:47:11 +1000
commit75bb1e696321cf1b9ac6b124312b57560a06ff39 (patch)
tree510f1acc95a08ef2761aab7efba82ef5af894c8a /pkgconfig.h
Add to git.
Diffstat (limited to 'pkgconfig.h')
-rw-r--r--pkgconfig.h65
1 files changed, 65 insertions, 0 deletions
diff --git a/pkgconfig.h b/pkgconfig.h
new file mode 100644
index 0000000..ca38b83
--- /dev/null
+++ b/pkgconfig.h
@@ -0,0 +1,65 @@
+/*
+ * Copyright (c) 2011, Chris Johns <chrisj@rtems.org>
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#if !defined (_PKGCONFIG_H_)
+#define _PKGCONFIG_H_
+
+#include <map>
+#include <string>
+
+namespace pkgconfig
+{
+ /**
+ * A simple class to parse a pkgconfig file as used in RTEMS. The RTEMS use
+ * if simple and basically provides a simplified method to manage the various
+ * flags used to build and link modules for a specific BSP.
+ */
+ class package
+ {
+ public:
+ /**
+ * The type of defines and fields parsed from a package config file.
+ */
+ typedef std::map < std::string, std::string > table;
+
+ package ();
+
+ /**
+ * Load a package configuration file.
+ *
+ * @param name The file name of the package.
+ */
+ void load (const std::string& name);
+
+ /**
+ * Get a field from the package.
+ *
+ * @param label The label to search for.
+ * @param result The result of the search.
+ * @retval true The field was found.
+ * @retval false The field was not found.
+ */
+ bool get (const std::string& label, std::string& result);
+
+ private:
+ table defines; ///< The defines.
+ table fields; ///< The fields.
+
+ };
+
+}
+
+#endif