diff options
Diffstat (limited to 'tutorial/chapter-9')
-rw-r--r-- | tutorial/chapter-9/app/app.qbs | 9 | ||||
-rw-r--r-- | tutorial/chapter-9/app/main.c | 14 | ||||
-rw-r--r-- | tutorial/chapter-9/lib/lib.c | 10 | ||||
-rw-r--r-- | tutorial/chapter-9/lib/lib.h | 8 | ||||
-rw-r--r-- | tutorial/chapter-9/lib/lib.qbs | 10 | ||||
-rw-r--r-- | tutorial/chapter-9/lib/lib_global.h | 25 | ||||
-rw-r--r-- | tutorial/chapter-9/myproject.qbs | 32 | ||||
-rw-r--r-- | tutorial/chapter-9/qbs/imports/MyApplication.qbs | 10 | ||||
-rw-r--r-- | tutorial/chapter-9/qbs/imports/MyAutoTest.qbs | 3 | ||||
-rw-r--r-- | tutorial/chapter-9/qbs/imports/MyLibrary.qbs | 26 | ||||
-rw-r--r-- | tutorial/chapter-9/qbs/modules/mybuildconfig/mybuildconfig.qbs | 30 | ||||
-rw-r--r-- | tutorial/chapter-9/test/test.c | 18 | ||||
-rw-r--r-- | tutorial/chapter-9/test/test.qbs | 5 | ||||
-rw-r--r-- | tutorial/chapter-9/version-header/version-header.qbs | 57 | ||||
-rw-r--r-- | tutorial/chapter-9/version-header/version.h.in | 9 |
15 files changed, 266 insertions, 0 deletions
diff --git a/tutorial/chapter-9/app/app.qbs b/tutorial/chapter-9/app/app.qbs new file mode 100644 index 000000000..837b66da3 --- /dev/null +++ b/tutorial/chapter-9/app/app.qbs @@ -0,0 +1,9 @@ +//! [0] +MyApplication { + Depends { name: "mylib" } + Depends { name: "version_header" } + name: "My Application" + targetName: "myapp" + files: "main.c" +} +//! [0] diff --git a/tutorial/chapter-9/app/main.c b/tutorial/chapter-9/app/main.c new file mode 100644 index 000000000..d6cefc2ff --- /dev/null +++ b/tutorial/chapter-9/app/main.c @@ -0,0 +1,14 @@ +//![0] +#include <lib.h> +#include <version.h> + +#include <stdio.h> + +int main() +{ + printf("Hello, world\n"); + printf("%s\n", get_string()); + printf("ProductVersion = %s\n", kProductVersion); + return 0; +} +//![0] diff --git a/tutorial/chapter-9/lib/lib.c b/tutorial/chapter-9/lib/lib.c new file mode 100644 index 000000000..5dcae0de3 --- /dev/null +++ b/tutorial/chapter-9/lib/lib.c @@ -0,0 +1,10 @@ +#include "lib.h" + +#ifndef CRUCIAL_DEFINE +# error CRUCIAL_DEFINE not defined +#endif + +const char *get_string() +{ + return "Hello from library"; +} diff --git a/tutorial/chapter-9/lib/lib.h b/tutorial/chapter-9/lib/lib.h new file mode 100644 index 000000000..ef39ca4a1 --- /dev/null +++ b/tutorial/chapter-9/lib/lib.h @@ -0,0 +1,8 @@ +#ifndef LIB_H +#define LIB_H + +#include "lib_global.h" + +MYLIB_EXPORT const char *get_string(); + +#endif // LIB_H diff --git a/tutorial/chapter-9/lib/lib.qbs b/tutorial/chapter-9/lib/lib.qbs new file mode 100644 index 000000000..e8cf9bdb9 --- /dev/null +++ b/tutorial/chapter-9/lib/lib.qbs @@ -0,0 +1,10 @@ +MyLibrary { + name: "mylib" + files: [ + "lib.c", + "lib.h", + ] + Depends { name: 'cpp' } + cpp.defines: ['CRUCIAL_DEFINE'] +} + diff --git a/tutorial/chapter-9/lib/lib_global.h b/tutorial/chapter-9/lib/lib_global.h new file mode 100644 index 000000000..329b62fd3 --- /dev/null +++ b/tutorial/chapter-9/lib/lib_global.h @@ -0,0 +1,25 @@ +#ifndef LIB_GLOBAL_H +#define LIB_GLOBAL_H + +#if defined(_WIN32) || defined(WIN32) +#define MY_LIB_DECL_EXPORT __declspec(dllexport) +#define MY_LIB_DECL_IMPORT __declspec(dllimport) +#else +#define MY_LIB_DECL_EXPORT __attribute__((visibility("default"))) +#define MY_LIB_DECL_IMPORT __attribute__((visibility("default"))) +#endif + +// ![0] +// lib/lib_global.h +#if defined(MYLIB_STATIC_LIBRARY) +#define MYLIB_EXPORT +#else +#if defined(MYLIB_LIBRARY) +#define MYLIB_EXPORT MY_LIB_DECL_EXPORT +#else +#define MYLIB_EXPORT MY_LIB_DECL_IMPORT +#endif +#endif +// ![0] + +#endif // LIB_GLOBAL_H diff --git a/tutorial/chapter-9/myproject.qbs b/tutorial/chapter-9/myproject.qbs new file mode 100644 index 000000000..fac217b71 --- /dev/null +++ b/tutorial/chapter-9/myproject.qbs @@ -0,0 +1,32 @@ +Project { + property string version: "1.0.0" + property bool withTests: true + property bool installDebugInformation: true + property stringList autotestArguments: [] + property stringList autotestWrapper: [] + + name: "My Project" + minimumQbsVersion: "2.0" + //! [0] + // myproject.qbs + references: [ + "app/app.qbs", + "lib/lib.qbs", + "version-header/version-header.qbs", + ] + //! [0] + qbsSearchPaths: "qbs" + + SubProject { + filePath: "test/test.qbs" + Properties { + condition: parent.withTests + } + } + + AutotestRunner { + condition: parent.withTests + arguments: parent.autotestArguments + wrapper: parent.autotestWrapper + } +} diff --git a/tutorial/chapter-9/qbs/imports/MyApplication.qbs b/tutorial/chapter-9/qbs/imports/MyApplication.qbs new file mode 100644 index 000000000..451065190 --- /dev/null +++ b/tutorial/chapter-9/qbs/imports/MyApplication.qbs @@ -0,0 +1,10 @@ +CppApplication { + Depends { name: "mybuildconfig" } + version: mybuildconfig.productVersion + + cpp.rpaths: mybuildconfig.libRPaths + consoleApplication: true + installDir: mybuildconfig.appInstallDir + install: true + installDebugInformation: project.installDebugInformation +} diff --git a/tutorial/chapter-9/qbs/imports/MyAutoTest.qbs b/tutorial/chapter-9/qbs/imports/MyAutoTest.qbs new file mode 100644 index 000000000..1faecdc33 --- /dev/null +++ b/tutorial/chapter-9/qbs/imports/MyAutoTest.qbs @@ -0,0 +1,3 @@ +MyApplication { + type: ["application", "autotest"] +} diff --git a/tutorial/chapter-9/qbs/imports/MyLibrary.qbs b/tutorial/chapter-9/qbs/imports/MyLibrary.qbs new file mode 100644 index 000000000..9f2590f50 --- /dev/null +++ b/tutorial/chapter-9/qbs/imports/MyLibrary.qbs @@ -0,0 +1,26 @@ +// ![0] +Library { + Depends { name: "cpp" } + Depends { name: "mybuildconfig" } + type: mybuildconfig.staticBuild ? "staticlibrary" : "dynamiclibrary" + version: mybuildconfig.productVersion + install: !mybuildconfig.staticBuild || mybuildconfig.installStaticLib + installDir: mybuildconfig.libInstallDir + + readonly property string _nameUpper : name.replace(" ", "_").toUpperCase() + property string libraryMacro: _nameUpper + "_LIBRARY" + property string staticLibraryMacro: _nameUpper + "_STATIC_LIBRARY" + cpp.defines: mybuildconfig.staticBuild ? [staticLibraryMacro] : [libraryMacro] + cpp.sonamePrefix: qbs.targetOS.contains("darwin") ? "@rpath" : undefined + + Export { + Depends { name: "cpp" } + cpp.includePaths: [exportingProduct.sourceDirectory] + cpp.defines: exportingProduct.mybuildconfig.staticBuild + ? [exportingProduct.staticLibraryMacro] : [] + } + + Depends { name: "bundle" } + bundle.isBundle: false +} +// ![0] diff --git a/tutorial/chapter-9/qbs/modules/mybuildconfig/mybuildconfig.qbs b/tutorial/chapter-9/qbs/modules/mybuildconfig/mybuildconfig.qbs new file mode 100644 index 000000000..7aed8f7eb --- /dev/null +++ b/tutorial/chapter-9/qbs/modules/mybuildconfig/mybuildconfig.qbs @@ -0,0 +1,30 @@ +import qbs.FileInfo + +//! [0] +// qbs/modules/mybuildconfig/mybuildconfig.qbs +Module { + Depends { name: "cpp" } + + property string productVersion: "1.0.0" + // ... + //! [0] + property string appInstallDir: "bin" + property string libDirName: "lib" + property string libInstallDir: qbs.targetOS.contains("windows") ? "bin" : libDirName + property bool staticBuild: false + property bool installStaticLib: true + property bool enableRPath: true + + property stringList libRPaths: { + if (enableRPath && cpp.rpathOrigin && product.installDir) { + return [ + FileInfo.joinPaths( + cpp.rpathOrigin, + FileInfo.relativePath( + FileInfo.joinPaths('/', product.installDir), + FileInfo.joinPaths('/', libDirName))) + ]; + } + return []; + } +} diff --git a/tutorial/chapter-9/test/test.c b/tutorial/chapter-9/test/test.c new file mode 100644 index 000000000..1fef24685 --- /dev/null +++ b/tutorial/chapter-9/test/test.c @@ -0,0 +1,18 @@ +#include "lib.h" + +#include <stdio.h> +#include <string.h> + +int main(int argc, char *argv[]) +{ + if (argc > 2) { + printf("usage: test [value]\n"); + return 1; + } + const char *expected = argc == 2 ? argv[1] : "Hello from library"; + if (strcmp(get_string(), expected) != 0) { + printf("text differs\n"); + return 1; + } + return 0; +} diff --git a/tutorial/chapter-9/test/test.qbs b/tutorial/chapter-9/test/test.qbs new file mode 100644 index 000000000..1e911da47 --- /dev/null +++ b/tutorial/chapter-9/test/test.qbs @@ -0,0 +1,5 @@ +MyAutoTest { + Depends { name: "mylib" } + name: "mytest" + files: "test.c" +} diff --git a/tutorial/chapter-9/version-header/version-header.qbs b/tutorial/chapter-9/version-header/version-header.qbs new file mode 100644 index 000000000..0a416d572 --- /dev/null +++ b/tutorial/chapter-9/version-header/version-header.qbs @@ -0,0 +1,57 @@ +//! [5] +// version-header/version-header.qbs +//! [0] +import qbs.TextFile + +Product { + name: "version_header" + type: "hpp" + + Depends { name: "mybuildconfig" } +//! [0] + +//! [1] + Group { + files: ["version.h.in"] + fileTags: ["version_h_in"] + } +//! [1] + +//! [2] + Rule { + inputs: ["version_h_in"] + Artifact { + filePath: "version.h" + fileTags: "hpp" + } +//! [2] +//! [3] + prepare: { + var cmd = new JavaScriptCommand(); + cmd.description = "generating " + output.fileName; + cmd.highlight = "codegen"; + cmd.sourceCode = function() { + var file = new TextFile(input.filePath, TextFile.ReadOnly); + var content = file.readAll(); + + content = content.replace( + "${PRODUCT_VERSION}", + product.mybuildconfig.productVersion); + + file = new TextFile(output.filePath, TextFile.WriteOnly); + file.write(content); + file.close(); + } + return cmd; + } +//! [3] + } + +//! [4] + Export { + Depends { name: "cpp" } + cpp.includePaths: exportingProduct.buildDirectory + } +//! [4] +} +//! [5] diff --git a/tutorial/chapter-9/version-header/version.h.in b/tutorial/chapter-9/version-header/version.h.in new file mode 100644 index 000000000..2e6604967 --- /dev/null +++ b/tutorial/chapter-9/version-header/version.h.in @@ -0,0 +1,9 @@ +//! [0] +// version-header/version.h.in +#ifndef VERSION_H +#define VERSION_H + +const char kProductVersion[] = "${PRODUCT_VERSION}"; + +#endif // VERSION_H +//! [0] |