1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
var FileInfo = loadExtension("qbs.FileInfo");
function applicationFileName(product) {
return product.moduleProperty("cpp", "executablePrefix")
+ product.targetName
+ product.moduleProperty("cpp", "executableSuffix");
}
function applicationFilePath(product) {
if (product.moduleProperty("bundle", "isBundle"))
return product.moduleProperty("bundle", "executablePath");
else
return applicationFileName(product);
}
function loadableModuleFileName(product) {
return product.moduleProperty("cpp", "loadableModulePrefix")
+ product.targetName
+ product.moduleProperty("cpp", "loadableModuleSuffix");
}
function loadableModuleFilePath(product) {
if (product.moduleProperty("bundle", "isBundle"))
return product.moduleProperty("bundle", "executablePath");
else
return loadableModuleFileName(product);
}
function staticLibraryFileName(product) {
return product.moduleProperty("cpp", "staticLibraryPrefix")
+ product.targetName
+ product.moduleProperty("cpp", "staticLibrarySuffix");
}
function staticLibraryFilePath(product) {
if (product.moduleProperty("bundle", "isBundle"))
return product.moduleProperty("bundle", "executablePath");
else
return staticLibraryFileName(product);
}
function dynamicLibraryFileName(product, version, maxParts) {
// If no override version was given, use the product's version
// We specifically want to differentiate between undefined and i.e.
// empty string as empty string should be taken to mean "no version"
// and undefined should be taken to mean "use the product's version"
// (which could still end up being "no version")
if (version === undefined)
version = product.moduleProperty("cpp", "internalVersion");
// If we have a version number, potentially strip off some components
maxParts = parseInt(maxParts, 10);
if (maxParts === 0)
version = undefined;
else if (maxParts && version)
version = version.split('.').slice(0, maxParts).join('.');
// Start with prefix + name (i.e. libqbs, qbs)
var fileName = product.moduleProperty("cpp", "dynamicLibraryPrefix") + product.targetName;
// For Darwin platforms, append the version number if there is one (i.e. libqbs.1.0.0)
var targetOS = product.moduleProperty("qbs", "targetOS");
if (version && targetOS.contains("darwin")) {
fileName += "." + version;
version = undefined;
}
// Append the suffix (i.e. libqbs.1.0.0.dylib, libqbs.so, qbs.dll)
fileName += product.moduleProperty("cpp", "dynamicLibrarySuffix");
// For non-Darwin Unix platforms, append the version number if there is one (i.e. libqbs.so.1.0.0)
if (version && targetOS.contains("unix") && !targetOS.contains("darwin"))
fileName += "." + version;
return fileName;
}
function dynamicLibraryFilePath(product, version, maxParts) {
if (product.moduleProperty("bundle", "isBundle"))
return product.moduleProperty("bundle", "executablePath");
else
return dynamicLibraryFileName(product, version, maxParts);
}
function importLibraryFilePath(product) {
return product.moduleProperty("cpp", "dynamicLibraryPrefix")
+ product.targetName
+ product.moduleProperty("cpp", "dynamicLibraryImportSuffix");
}
function debugInfoFileName(product) {
if (product.moduleProperty("bundle", "isBundle"))
return product.moduleProperty("bundle", "bundleName") + product.moduleProperty("cpp", "debugInfoSuffix");
else if (product.type.contains("application"))
return applicationFileName(product) + product.moduleProperty("cpp", "debugInfoSuffix");
else if (product.type.contains("dynamiclibrary"))
return dynamicLibraryFileName(product) + product.moduleProperty("cpp", "debugInfoSuffix");
else if (product.type.contains("loadablemodule"))
return loadableModuleFileName(product) + product.moduleProperty("cpp", "debugInfoSuffix");
else if (product.type.contains("staticlibrary"))
return staticLibraryFileName(product) + product.moduleProperty("cpp", "debugInfoSuffix");
else
return product.targetName + product.moduleProperty("cpp", "debugInfoSuffix");
}
// Returns whether the string looks like a library filename
function isLibraryFileName(product, fileName, prefix, suffixes, isShared) {
var suffix, i;
var os = product.moduleProperty("qbs", "targetOS");
for (i = 0; i < suffixes.length; ++i) {
suffix = suffixes[i];
if (isShared && os.contains("unix") && !os.contains("darwin"))
suffix += "(\\.[0-9]+){0,3}";
if (fileName.match("^" + prefix + ".+?\\" + suffix + "$"))
return true;
}
return false;
}
function frameworkExecutablePath(frameworkPath) {
var suffix = ".framework";
var isAbsoluteFrameworkPath = frameworkPath.slice(-suffix.length) === suffix;
if (isAbsoluteFrameworkPath) {
var frameworkName = FileInfo.fileName(frameworkPath).slice(0, -suffix.length);
return FileInfo.joinPaths(frameworkPath, frameworkName);
}
return undefined;
}
|