Skip to content

Commit

Permalink
Merge remote-tracking branch 'upstream/master' into aws-sdk-cpp-res
Browse files Browse the repository at this point in the history
  • Loading branch information
dvirtz committed Feb 2, 2022
2 parents 574fb48 + a59a124 commit f5fad7c
Show file tree
Hide file tree
Showing 771 changed files with 12,583 additions and 5,156 deletions.
32 changes: 32 additions & 0 deletions .github/recipe_linter.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
{
"problemMatcher": [
{
"owner": "recipe_linter_errors",
"severity": "error",
"pattern": [
{
"regexp": "(\\S+):(\\d+):(\\d+):\\s(E\\d+):\\s(.+)\\s\\((\\S+)\\)",
"file": 1,
"line": 2,
"column": 3,
"message": 5,
"code": 4
}
]
},
{
"owner": "recipe_linter_warnings",
"severity": "warning",
"pattern": [
{
"regexp": "(\\S+):(\\d+):(\\d+):\\s(W\\d+):\\s(.+)\\s\\((\\S+)\\)",
"file": 1,
"line": 2,
"column": 3,
"message": 5,
"code": 4
}
]
}
]
}
57 changes: 57 additions & 0 deletions .github/runlint.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
import os
import yaml
import requests
import packaging.version
import subprocess
import platform
import sys


def main(pr):
session = requests.session()
session.headers = {}
token = os.getenv("GH_TOKEN")
if token:
session.headers["Authorization"] = "token %s" % token

session.headers["Accept"] = "application/vnd.github.v3+json"
session.headers["User-Agent"] = "request"
session.auth = None
# if user and pw:
# session.auth = requests.auth.HTTPBasicAuth(user, pw)

github_server_url = os.getenv("GITHUB_SERVER_URL")
github_repo = os.getenv("GITHUB_REPOSITORY")

r = session.request("GET", f"{github_server_url}/{github_repo}/pull/{pr}.diff")
r.raise_for_status()
diff = r.text
packages = set()
for line in diff.split("\n"):
if line.startswith("+++ b/recipes/") or line.startswith("--- a/recipes/"):
parts = line.split("/")
if len(parts) >= 5:
packages.add(parts[2] + "/" + parts[3])
for line in packages:
package = line.split("/")[0]
version = None
folder = line.split("/")[1]
with open(os.path.join("recipes", package, "config.yml"), "r") as file:
config = yaml.safe_load(file)
for v in config["versions"]:
if config["versions"][v]["folder"] != folder:
continue
try:
if not version or packaging.version.Version(v) > packaging.version.Version(version):
version = v
except packaging.version.InvalidVersion:
print("Error parsing version %s for package %s in pr %s" % (v, package, pr))

if version:
shell = bool(platform.system() != "Windows")
command = "conan export %s %s/%s@" % (os.path.join("recipes", package, folder), package, version)
p = subprocess.run(command, shell=shell, check=False)

if __name__ == "__main__":
# execute only if run as a script
main(sys.argv[1])
33 changes: 33 additions & 0 deletions .github/workflows/linters.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
name: run linters

on:
pull_request:

jobs:
lint:
env:
CONAN_YAMLLINT_WERR: 1
CONAN_PYLINT_WERR: 1
strategy:
fail-fast: false
matrix:
hook: ["yaml_linter", "recipe_linter"]
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v2
- uses: actions/setup-python@v2.2.2
with:
python-version: "3.8"

- run: "pip3 install conan yamllint packaging pylint==2.10.2 astroid"

- name: install hook
run: |
conan config install https://github.com/conan-io/hooks.git
conan config set hooks.${{ matrix.hook }}
- name: run lint
run: |
echo "::add-matcher::.github/${{ matrix.hook }}.json"
python3 .github/runlint.py ${{ github.event.pull_request.number }}
18 changes: 18 additions & 0 deletions .github/yaml_linter.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
{
"problemMatcher": [
{
"owner": "yaml_linter",
"pattern": [
{
"regexp": "^\\[HOOK\\s-\\syaml_linter\\.py\\]\\spre_export\\(\\):\\s(.+):(\\d+):(\\d+):\\s\\[(\\S+)\\]\\s(.+)\\s\\((.+)\\)$",
"file": 1,
"line": 2,
"column": 3,
"severity": 4,
"message": 5,
"code": 6
}
]
}
]
}
4 changes: 4 additions & 0 deletions docs/changelog.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
# Changelog

### 18-January-2022 - 16:49 CET

- [config] Bump Conan client version to 1.43.3.

### 29-December-2021 - 16:41 CET

- [config] Add Linux GCC 11, Clang 12 & 13 configurations with new epoch feature.
Expand Down
13 changes: 11 additions & 2 deletions docs/faqs.md
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ This section gathers the most common questions from the community related to pac
* [What is the policy for supported python versions?](#what-is-the-policy-for-supported-python-versions)
* [How to package libraries that depend on proprietary closed-source libraries?](#how-to-package-libraries-that-depend-on-proprietary-closed-source-libraries)
* [How to _protect_ my project from breaking changes in recipes?](#how-to-_protect_-my-project-from-breaking-changes-in-recipes)<!-- endToc -->
* [Why are version ranges not allowed?](#why-are-version-ranges-not-allowed)<!-- endToc -->

## What is the policy on recipe name collisions?

Expand Down Expand Up @@ -138,7 +139,9 @@ There are some recipes in `conan-center-index` that provide packages that contai

We decided that these packages (as long as they match the premises) should list all the settings needed to build, so building from sources will generate the expected binary, but they will **remove `compiler` setting inside the `package_id()` method**. As a consequence, the CI will generate packages only for one compiler reducing the workload in the pipeline and the number of possible package IDs.

Note about `build_type`.- We retain the `build_type` setting to make it possible for the users to _debug_ these installer packages. We considered removing this settings and it would be possible to compile these packages in _debug_ mode, but if we remove it from the packageID, the compiled package would override the existing _release_ binary, and it'd be quite inconvenient for the users to compile the binary every time they need to switch from _debug_ to _release_.
Notes about `build_type`:

We retain the `build_type` setting to make it possible for the users to _debug_ these installer packages. We considered removing this settings and it would be possible to compile these packages in _debug_ mode, but if we remove it from the packageID, the compiled package would override the existing _release_ binary, and it'd be quite inconvenient for the users to compile the binary every time they need to switch from _debug_ to _release_.

## Can I remove an option from recipe

Expand Down Expand Up @@ -187,7 +190,7 @@ def configure(self):
tools.check_min_cppstd(self, 14) 👈 Wrong!
```

This fails to cover the waste number of use cases for the following reasons:
This fails to cover the vast number of use cases for the following reasons:

1. `cppstd` is not configured in the `--detect`ed profiles generated by Conan, the majority of users simply do not have this setting.
2. A shocking number of projects override this setting within their respective build scripts, this setting does not get applied in those cases.
Expand Down Expand Up @@ -334,3 +337,9 @@ To isolate from this changes there are different strategies you can follow:
and lockfiles.

Keep reading in the [consuming recipes section](consuming_recipes.md).

## Why are version ranges not allowed?

Version ranges are a useful Conan feature, find the documentation [here](https://docs.conan.io/en/latest/versioning/version_ranges.html). However, in the context of ConanCenter they pose a few key challenges, most notably "Build Reproducibility".

If consumers try to download and build the recipe at a later time, it may resolve to a different package version that may not be compatible. In order to prevent these types of issues, we have decided to only allow exact requirements versions.
6 changes: 3 additions & 3 deletions docs/supported_platforms_and_configurations.md
Original file line number Diff line number Diff line change
Expand Up @@ -38,8 +38,8 @@ For more information see [conan-io/conan-docker-tools](https://github.com/conan-

- Compilers: Visual Studio:

- 2017 (19.16.27035)
- 2019 (19.28.29333)
- 2017 (19.16.27045)
- 2019 (19.29.30139)

- Release (MT/MD) and Debug (MTd, MDd)
- Architectures: x86_64
Expand All @@ -65,7 +65,7 @@ For more information see [conan-io/conan-docker-tools](https://github.com/conan-

## MacOS

- Compilers: Apple-clang versions 11.0.0, 12.0.0, 12.0.0
- Compilers: Apple-clang versions 11.0.0, 12.0.0, 12.0.0, 13.0.0
- C++ Standard Library (`libcxx`): `libc++`
- Architectures: x86_64, armv8
- Build types: Release, Debug
Expand Down
6 changes: 5 additions & 1 deletion recipes/abseil/all/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
cmake_minimum_required(VERSION 3.5)
cmake_minimum_required(VERSION 3.8)
project(cmake_wrapper)

include(conanbuildinfo.cmake)
Expand All @@ -8,4 +8,8 @@ if(MSVC)
add_definitions("-D_HAS_DEPRECATED_RESULT_OF")
endif()

if(NOT CMAKE_SYSTEM_PROCESSOR)
set(CMAKE_SYSTEM_PROCESSOR ${CONAN_ABSEIL_SYSTEM_PROCESSOR})
endif()

add_subdirectory(source_subfolder)
49 changes: 13 additions & 36 deletions recipes/abseil/all/conandata.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,55 +5,32 @@ sources:
"20210324.2":
url: "https://github.com/abseil/abseil-cpp/archive/20210324.2.tar.gz"
sha256: "59b862f50e710277f8ede96f083a5bb8d7c9595376146838b9580be90374ee1f"
"20210324.1":
url: "https://github.com/abseil/abseil-cpp/archive/refs/tags/20210324.1.tar.gz"
sha256: "441db7c09a0565376ecacf0085b2d4c2bbedde6115d7773551bc116212c2a8d6"
"20210324.0":
url: "https://github.com/abseil/abseil-cpp/archive/refs/tags/20210324.0.tar.gz"
sha256: "dd7db6815204c2a62a2160e32c55e97113b0a0178b2f090d6bab5ce36111db4b"
"20200923.3":
url: "https://github.com/abseil/abseil-cpp/archive/20200923.3.tar.gz"
sha256: "ebe2ad1480d27383e4bf4211e2ca2ef312d5e6a09eba869fd2e8a5c5d553ded2"
"20200923.2":
url: "https://github.com/abseil/abseil-cpp/archive/20200923.2.tar.gz"
sha256: "bf3f13b13a0095d926b25640e060f7e13881bd8a792705dd9e161f3c2b9aa976"
"20200923.1":
url: "https://github.com/abseil/abseil-cpp/archive/20200923.1.tar.gz"
sha256: "808350c4d7238315717749bab0067a1acd208023d41eaf0c7360f29cc8bc8f21"
"20200923":
url: "https://github.com/abseil/abseil-cpp/archive/20200923.tar.gz"
sha256: "b3744a4f7a249d5eaf2309daad597631ce77ea62e0fc6abffbab4b4c3dc0fc08"
"20200225.3":
url: "https://github.com/abseil/abseil-cpp/archive/20200225.3.tar.gz"
sha256: "66d4d009050f39c104b03f79bdca9d930c4964016f74bf24867a43fbdbd00d23"
"20200225.2":
url: "https://github.com/abseil/abseil-cpp/archive/20200225.2.tar.gz"
sha256: "f41868f7a938605c92936230081175d1eae87f6ea2c248f41077c8f88316f111"
"20200205":
url: "https://github.com/abseil/abseil-cpp/archive/08a7e7bf972c8451855a5022f2faf3d3655db015.tar.gz"
sha256: 3c554df4909c5c55a6d251f6eadc2c78ff20db5ad4471fd9cbf8085c51b76797
patches:
"20200923.2":
- patch_file: "patches/20200205-missing-numeric_limits.h.patch"
"20211102.0":
- patch_file: "patches/0003-absl-string-libm.patch"
base_path: "source_subfolder"
"20200923.1":
- patch_file: "patches/20200205-missing-numeric_limits.h.patch"
"20210324.2":
- patch_file: "patches/0003-absl-string-libm.patch"
base_path: "source_subfolder"
"20200923":
- patch_file: "patches/20200205-missing-numeric_limits.h.patch"
- patch_file: "patches/0004-cpp-standard-20210324.patch"
base_path: "source_subfolder"
"20200225.3":
- patch_file: "patches/20200205-cmake-install.patch"
"20200923.3":
- patch_file: "patches/0003-absl-string-libm.patch"
base_path: "source_subfolder"
- patch_file: "patches/20200205-missing-numeric_limits.h.patch"
- patch_file: "patches/0004-cpp-standard-20200923.patch"
base_path: "source_subfolder"
"20200225.2":
- patch_file: "patches/20200205-cmake-install.patch"
"20200225.3":
- patch_file: "patches/0001-cmake-install.patch"
base_path: "source_subfolder"
- patch_file: "patches/20200205-missing-numeric_limits.h.patch"
- patch_file: "patches/0002-missing-numeric_limits.h.patch"
base_path: "source_subfolder"
"20200205":
- patch_file: "patches/20200205-cmake-install.patch"
- patch_file: "patches/0003-absl-string-libm.patch"
base_path: "source_subfolder"
- patch_file: "patches/20200205-missing-numeric_limits.h.patch"
- patch_file: "patches/0004-cpp-standard-20200225.patch"
base_path: "source_subfolder"
Loading

0 comments on commit f5fad7c

Please sign in to comment.