This repository has been archived by the owner on Dec 4, 2024. It is now read-only.
forked from conan-io/conan-center-index
-
Notifications
You must be signed in to change notification settings - Fork 0
/
freebsd-center.py
169 lines (149 loc) · 7.24 KB
/
freebsd-center.py
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
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
# pylint: disable = invalid-name, too-many-locals
import os
import json
import asyncio
import logging
import sys
import re
from typing import Dict, List
import yaml
sem = asyncio.Semaphore(1)
async def process_ref(package: str) -> None: # noqa: MC0001
package_restrictions: Dict[str, List[str]] = {
"bacnet-stack": [],
"b2": [],
"ncurses": [],
"geotrans": [],
"icu": ["70.1"],
"cmake": ["3.22.3"],
"glib": ["2.72.0"],
"cppcheck": ["2.7.3"],
"proj": ["9.0.0"],
}
async with sem:
config_file = os.path.join(package, "config.yml")
if not os.path.isfile(config_file):
logging.error("no config file for %s", package)
return
with open(config_file, "r", encoding="latin_1") as stream:
config = yaml.safe_load(stream)
p = await asyncio.create_subprocess_exec("conan", "remove", "--outdated", f"{package}/*")
await p.wait()
if p.returncode != 0:
logging.error("error during conan remove %s: %s", package, p.returncode)
for version in config["versions"]:
if package in package_restrictions and version not in package_restrictions[package]:
logging.info("skipping %s/%s", package, version)
continue
folder = config["versions"][version]["folder"]
conandata_path = os.path.join(os.path.join(package, folder), "conandata.yml")
conandata_full_path = os.path.join(os.path.join(package, folder), "conandata_full.yml")
if os.path.isfile(conandata_path):
if os.path.isfile(conandata_full_path):
os.remove(conandata_full_path)
os.rename(conandata_path, conandata_full_path)
with open(conandata_full_path, "r", encoding="latin_1") as stream:
conandata_yml = yaml.safe_load(stream)
info: Dict[str, Dict[str, str]] = {}
for entry in conandata_yml:
if version not in conandata_yml[entry]:
continue
info[entry] = {}
info[entry][version] = conandata_yml[entry][version]
with open(conandata_path, "w", encoding="latin_1") as stream:
yaml.safe_dump(info, default_flow_style=False, stream=stream)
ref = f"{package}/{version}@"
p = await asyncio.create_subprocess_exec("conan", "export", os.path.join(package, folder), ref)
await p.wait()
if p.returncode != 0:
logging.error("error during conan export %s %s: %s", os.path.join(package, folder), ref, p.returncode)
continue
if os.path.isfile(conandata_full_path):
if os.path.isfile(conandata_path):
os.remove(conandata_path)
os.rename(conandata_full_path, conandata_path)
info_file = os.path.join(package, "info.json")
p = await asyncio.create_subprocess_exec("conan", "info", ref, "--json", info_file)
await p.wait()
if p.returncode == 6:
logging.info("ignoring invalid package %s", ref)
continue
if p.returncode == 1:
logging.error("missing binary requirement of %s ?", ref)
continue
if p.returncode != 0:
logging.error("error during conan info %s: %s", ref, p.returncode)
continue
with open(info_file, "r", encoding="latin_1") as stream:
infos = json.load(stream)
os.remove(info_file)
if any(info["id"] == "INVALID" for info in infos):
logging.info("ignoring invalid package %s", ref)
continue
bin_id = None
for info_ in infos:
if info_["reference"] + "@" == ref:
bin_id = info_["id"]
if not bin_id:
logging.error("could not find %s in %s", ref, infos)
sys.exit(-3)
if any("deprecated" in info for info in infos):
logging.info("skipping %s because it is deprecated", ref)
continue
revision_file = os.path.join(package, "revision.json")
p = await asyncio.create_subprocess_exec("conan", "search", ref, "--revisions", "--json", revision_file)
await p.wait()
if p.returncode != 0:
logging.error("error during conan search %s --revisions --json %s: %s", ref, revision_file, p.returncode)
continue
with open(revision_file, "r", encoding="latin_1") as stream:
revisions = json.load(stream)
os.remove(revision_file)
if len(revisions) == 0:
rev = ""
elif len(revisions) == 1:
rev = revisions[0]["revision"]
else:
logging.error("unexpected revisions for %s: %s", ref, revisions)
fullref = f"{ref}#{rev}"
binaries_file = os.path.join(package, "binaries.json")
p = await asyncio.create_subprocess_exec("conan", "search", fullref, "-r", "all", "--json", binaries_file)
await p.wait()
if p.returncode != 0:
logging.error("error during conan search %s -r all --json %s: %s", fullref, binaries_file, p.returncode)
continue
with open(binaries_file, "r", encoding="latin_1") as stream:
binaries = json.load(stream)
os.remove(binaries_file)
assert not binaries["error"]
if any(p["id"] == bin_id for r in binaries["results"] for i in r["items"] for p in i["packages"]):
continue
logging.info("no binaries for %s", fullref)
p = await asyncio.create_subprocess_exec("conan", "install", fullref, "-b", package)
await p.wait()
if p.returncode == 1:
logging.error("error while building %s, ignored", ref)
continue
if p.returncode != 0:
logging.error("error during conan install %s -b %s: %s", fullref, package, p.returncode)
continue
p = await asyncio.create_subprocess_exec("conan", "test", os.path.join(package, folder, "test_package", "conanfile.py"), fullref)
await p.wait()
if p.returncode == 1:
logging.error("Test of %s failed", ref)
continue
if p.returncode != 0:
logging.error("error during conan test %s %s: %s", os.path.join(package, folder, "test_package", "conanfile.py"), fullref, p.returncode)
continue
p = await asyncio.create_subprocess_exec("conan", "upload", fullref, "--all")
await p.wait()
if p.returncode != 0:
logging.error("error during conan upload %s --all: %s", fullref, p.returncode)
continue
if __name__ == "__main__":
os.chdir("CCI")
os.chdir("recipes")
pattern = re.compile(sys.argv[1] if len(sys.argv) >= 2 else ".*")
async def main():
await asyncio.gather(*[process_ref(filename.name) for filename in os.scandir() if filename.is_dir() and pattern.match(filename.name)])
asyncio.run(main())