From 15ae477b3203a9f0588037c88dfa20408c79773c Mon Sep 17 00:00:00 2001 From: stefled Date: Fri, 24 Nov 2023 10:21:12 +0100 Subject: [PATCH 1/3] fix[conan]: manage conan pkgdeps conditions with space (generate conanfile without quotes) fix[conan]: disable duplicated dependencies and conditions in conanfile generation fix[subdeps]: fix on search recursive dependencies (when build dependencies tree) --- packagedependencies-parser.pri | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/packagedependencies-parser.pri b/packagedependencies-parser.pri index 91b68cd..13c69ea 100644 --- a/packagedependencies-parser.pri +++ b/packagedependencies-parser.pri @@ -32,7 +32,8 @@ contains(DEPENDENCIESCONFIG,recurse)|contains(DEPENDENCIESCONFIG,recursive) { subDepsTree += $$member(subDepsList,2) } } else { - subDepsFilesList = + # fix search sub dependencies + #subDepsFilesList = !contains(subDepsTree, $${subDepsList}) { subDepsTree += $${subDepsList} } @@ -235,19 +236,19 @@ for(depfile, packagedepsfiles) { conanOptionPrefix = $$take_first(conanOptionInfo) isEmpty(conanOptionInfo) { equals(CONAN_MAJOR_VERSION,1) { - remakenConanOptions += $${pkg.name}:$${conanOption} + remakenConanOptions += $${pkg.name}:$$replace(conanOption, "\"","") } else { - remakenConanOptions += $${pkg.name}/*:$${conanOption} + remakenConanOptions += $${pkg.name}/*:$$replace(conanOption, "\"","") } } else { equals(CONAN_MAJOR_VERSION,1) { - remakenConanOptions += $${conanOption} - } - else { + remakenConanOptions += $$replace(conanOption, "\"","") + } + else { conanOptionPkgOption = $$member(conanOptionInfo,0) - remakenConanOptions += $${conanOptionPrefix}/*:$${conanOptionPkgOption} + remakenConanOptions += $${conanOptionPrefix}/*:$$replace(conanOptionPkgOption, "\"","") } } } @@ -410,7 +411,9 @@ for(depfile, packagedepsfiles) { #create conanfile.txt CONANFILECONTENT="[requires]" for (dep,remakenConanDeps) { - CONANFILECONTENT+=$${dep} + !contains(CONANFILECONTENT,$${dep}) { + CONANFILECONTENT+=$${dep} + } } CONANFILECONTENT+="" CONANFILECONTENT+="[generators]" @@ -425,7 +428,9 @@ for(depfile, packagedepsfiles) { CONANFILECONTENT+="" CONANFILECONTENT+="[options]" for (option,remakenConanOptions) { - CONANFILECONTENT+=$${option} + !contains(CONANFILECONTENT,$${option}) { + CONANFILECONTENT+=$${option} + } } write_file($${REMAKEN_CONAN_DEPS_OUTPUTDIR}/conanfile.txt, CONANFILECONTENT) contains(CONFIG,c++11) { From 8c38cb903afda2c2fe44c5c25b743ff9a018f246 Mon Sep 17 00:00:00 2001 From: stefled Date: Fri, 1 Dec 2023 13:43:51 +0100 Subject: [PATCH 2/3] fix[conanv2] : add /* on conan options when generates conanfile.txt, only if not exist in packagedependencies.txt --- packagedependencies-parser.pri | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/packagedependencies-parser.pri b/packagedependencies-parser.pri index 13c69ea..1f28863 100644 --- a/packagedependencies-parser.pri +++ b/packagedependencies-parser.pri @@ -227,7 +227,11 @@ for(depfile, packagedepsfiles) { remakenConanOptions += $${pkg.name}:shared=$${sharedLinkMode} } else { - remakenConanOptions += $${pkg.name}/*:shared=$${sharedLinkMode} + equals(pkg.name, $$replace(pkg.name, "/*","")) { + remakenConanOptions += $${pkg.name}/*:shared=$${sharedLinkMode} + } else { + remakenConanOptions += $${pkg.name}:shared=$${sharedLinkMode} + } } } conanOptions = $$split(pkg.toolOptions, $$LITERAL_HASH) @@ -239,7 +243,11 @@ for(depfile, packagedepsfiles) { remakenConanOptions += $${pkg.name}:$$replace(conanOption, "\"","") } else { - remakenConanOptions += $${pkg.name}/*:$$replace(conanOption, "\"","") + equals(pkg.name, $$replace(pkg.name, "/*","")) { + remakenConanOptions += $${pkg.name}/*:$$replace(conanOption, "\"","") + } else { + remakenConanOptions += $${pkg.name}:$$replace(conanOption, "\"","") + } } } else { @@ -248,7 +256,11 @@ for(depfile, packagedepsfiles) { } else { conanOptionPkgOption = $$member(conanOptionInfo,0) - remakenConanOptions += $${conanOptionPrefix}/*:$$replace(conanOptionPkgOption, "\"","") + equals(conanOptionPrefix, $$replace(conanOptionPrefix, "/*","")) { + remakenConanOptions += $${conanOptionPrefix}/*:$$replace(conanOptionPkgOption, "\"","") + } else { + remakenConanOptions += $${conanOptionPrefix}:$$replace(conanOptionPkgOption, "\"","") + } } } } From 885d399aaa0c6302e63d09849028cc0c639f3a77 Mon Sep 17 00:00:00 2001 From: stefled Date: Fri, 15 Dec 2023 16:34:04 +0100 Subject: [PATCH 3/3] [fix] #15 - always regenerate packageignoreinstall.txt file in .build-rules folder --- install_dependencies.pri | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/install_dependencies.pri b/install_dependencies.pri index 5e22ee2..129ba60 100644 --- a/install_dependencies.pri +++ b/install_dependencies.pri @@ -33,9 +33,8 @@ defineReplace(aggregateIgnoreDepsFiles) { IGNOREDEPFILE_CONTENT = $$aggregateIgnoreDepsFiles($${packageignoredepsfiles}) IGNOREPKGDEPFILENAME=packageignoreinstall.txt -!isEmpty(IGNOREDEPFILE_CONTENT) { - write_file($$_PRO_FILE_PWD_/$${REMAKEN_BUILD_RULES_FOLDER}/$${REMAKEN_FULL_PLATFORM}/$${IGNOREPKGDEPFILENAME}, IGNOREDEPFILE_CONTENT) -} +write_file($$_PRO_FILE_PWD_/$${REMAKEN_BUILD_RULES_FOLDER}/$${REMAKEN_FULL_PLATFORM}/$${IGNOREPKGDEPFILENAME}, IGNOREDEPFILE_CONTENT) +QMAKE_CLEAN += $$_PRO_FILE_PWD_/$${REMAKEN_BUILD_RULES_FOLDER}/$${REMAKEN_FULL_PLATFORM}/$${IGNOREPKGDEPFILENAME} defined(PROJECTDEPLOYDIR,var) { packageignore_files.path = $${PROJECTDEPLOYDIR}