-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathgenindex.py
executable file
·159 lines (145 loc) · 6.11 KB
/
genindex.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
#!/usr/bin/env python3
import json
import common
class MissingUses(Exception):
pass
class DuplicateVersions(Exception):
pass
def onlyVersioninSemVer(ver):
ver.prerelease = []
ver.build = []
return ver
def onlyMainVersion(ver):
v = common.VersionNumber(ver)
return "%d.%d.%d" % (v.major, v.minor, v.patch)
def allProvidesAndVersion(lib):
res = set()
for provides in lib.get('provides',[]):
res.add(onlyMainVersion(provides))
res.add(onlyMainVersion(lib['version']))
return res
def checkProvides2(worklist, visited, origLibName, origVisited, indexdata):
while worklist:
(libName, lib) = worklist.pop()
wasVisited = False
for (name, myset) in visited:
if libName == name:
if origLibName == name:
origVisited.add(onlyMainVersion(lib['version']))
if onlyMainVersion(lib['version']) not in myset:
raise DuplicateVersions("%s needs to load both version %s and %s. Visited nodes:\n%s" % (libName, lib['version'], myset, visited))
wasVisited = True
break
if wasVisited:
continue
visited += [(libName, allProvidesAndVersion(lib))]
uses = lib.get('uses',{})
for usesName in uses.keys():
usesVersion = uses[usesName]
usesVersions = indexdata["libs"][usesName]["versions"].values()
versionsThatProvideTheUses = [v for v in usesVersions if usesVersion in v.get('provides',[]) or onlyVersioninSemVer(common.VersionNumber(usesVersion)) == onlyVersioninSemVer(common.VersionNumber(v['version']))]
if len(versionsThatProvideTheUses) == 1:
worklist += [((usesName,versionsThatProvideTheUses[0]))]
elif not versionsThatProvideTheUses:
allVersions = set()
for v in usesVersions:
allVersions = allVersions.union(allProvidesAndVersion(v))
raise MissingUses("%s %s depends on %s %s that does not exist. Existing versions: %s" % (libName,lib["version"],usesName,usesVersion,allVersions))
else:
lst = []
for ver in versionsThatProvideTheUses:
try:
res = checkProvides2(worklist.copy() + [(usesName,ver)], visited.copy(), origLibName, origVisited.copy(), indexdata)
lst += [res]
except DuplicateVersions:
pass
except MissingUses:
pass
if not lst:
raise MissingUses("%d/%d provides worked for %s: %s with visited %s" % (len(lst),len(versionsThatProvideTheUses),usesName,[v["version"] for v in versionsThatProvideTheUses],visited))
noConflict = False
for l in lst:
if not l:
noConflict = True
if noConflict:
continue
for l in lst:
origVisited = origVisited.union(l)
return origVisited
def checkProvides(libName, lib, indexdata):
worklist=[(libName, lib)]
visited=[]
origVisited = set()
origVisited = checkProvides2(worklist, visited, libName, origVisited, indexdata)
if origVisited:
print("Found cycle. Changing provides to convertFromVersion: %s %s %s" % (libName,lib['version'],origVisited))
lib['convertFromVersion'] = lib.get("convertFromVersion",[]) + lib['provides']
del lib['provides']
def main():
repos = json.load(open("repos.json"))
rawdata = json.load(open("rawdata.json"))
indexdata = {"libs": {}, "mirrors": ["https://libraries.openmodelica.org/cache/"]}
for firstKey in rawdata.keys():
data = rawdata[firstKey]
for refKey in data["refs"].keys():
r = data["refs"][refKey]
if "broken" in r:
continue
if "libs" not in r:
raise Exception(firstKey+" "+refKey)
for libName in r["libs"]:
lib = r["libs"][libName]
if libName not in indexdata["libs"]:
if "github" in repos[firstKey]:
indexdata["libs"][libName] = {"git": "https://github.com/%s.git" % repos[firstKey]["github"], "versions": {}}
isgit = True
elif "git" in repos[firstKey]:
indexdata["libs"][libName] = {"git": repos[firstKey]["git"], "versions": {}}
isgit = True
else:
indexdata["libs"][libName] = {"versions": {}}
isgit = False
libdict = indexdata["libs"][libName]["versions"]
if lib['version'] in libdict.keys():
if len(common.VersionNumber(refKey).prerelease)>0:
continue
print('Duplicate entry for %s %s (%s)' % (libName, lib['version'], refKey))
entry = {}
if isgit:
if "sha" in r or "zip" not in r: # If we have zip-file but no sha, we might use a releases zip for a tag we don't know the SHA of
entry['sha'] = r['sha']
entry['path'] = lib['path']
entry['version'] = lib['version']
if "zip" in r:
entry['zipfile'] = r["zip"]
elif "github" in repos[firstKey]:
entry['zipfile'] = "https://github.com/%s/archive/%s.zip" % (repos[firstKey]["github"], r['sha'])
elif "zipfile" in repos[firstKey]:
entry['zipfile'] = repos[firstKey]["zipfile"].format(r['sha'])
else:
raise Exception("Entry does not list an entry \"zip\" (manually added zip-file), \"github\" (project name), or \"zipfile\" URL from where to download the git hash (gitlab/etc):\n"+str(r))
if 'provides' in lib:
entry['provides'] = lib['provides']
if 'uses' in lib:
entry['uses'] = lib['uses']
if 'convertFromVersion' in lib:
entry['convertFromVersion'] = lib['convertFromVersion']
if repos[firstKey].get('singleFileStructureCopyAllFiles'):
entry['singleFileStructureCopyAllFiles'] = True
entry['support'] = common.getSupportLevel(lib['version'], repos[firstKey]['support'])
libdict[lib['version']] = entry
# print(entry)
# for lib in data["libs"].keys():
for libName in indexdata["libs"].keys():
versions = indexdata["libs"][libName]["versions"]
for version in versions.keys():
lib = versions[version]
if 'provides' in lib:
try:
checkProvides(libName, lib, indexdata)
except MissingUses:
pass
with open("index.json","w") as io:
json.dump(indexdata, io, sort_keys=True, indent=0)
if __name__ == '__main__':
main()