5 from collections
import OrderedDict
8 current_path
= os
.path
.dirname(os
.path
.realpath(__file__
))
10 # name, (url, recursive clone, develop)
13 ("migen", ("https://github.com/m-labs/", True, True)),
16 ("litex", ("https://github.com/enjoy-digital/", True, True)),
18 # LiteX cores ecosystem
19 ("liteeth", ("https://github.com/enjoy-digital/", False, True)),
20 ("litedram", ("https://github.com/enjoy-digital/", False, True)),
21 ("litepcie", ("https://github.com/enjoy-digital/", False, True)),
22 ("litesata", ("https://github.com/enjoy-digital/", False, True)),
23 ("litesdcard", ("https://github.com/enjoy-digital/", False, True)),
24 ("liteiclink", ("https://github.com/enjoy-digital/", False, True)),
25 ("litevideo", ("https://github.com/enjoy-digital/", False, True)),
26 ("litescope", ("https://github.com/enjoy-digital/", False, True)),
27 ("litejesd204b", ("https://github.com/enjoy-digital/", False, True)),
28 ("litespi", ("https://github.com/litex-hub/", False, True)),
30 # LiteX boards support
31 ("litex-boards", ("https://github.com/litex-hub/", False, True)),
33 repos
= OrderedDict(repos
)
36 print("Available commands:")
38 print("- install (add --user to install to user directory)")
42 if "init" in sys
.argv
[1:]:
43 for name
in repos
.keys():
44 url
, need_recursive
, need_develop
= repos
[name
]
45 # clone repo (recursive if needed)
46 print("[cloning " + name
+ "]...")
48 opts
= "--recursive" if need_recursive
else ""
49 os
.system("git clone " + full_url
+ " " + opts
)
51 if "install" in sys
.argv
[1:]:
52 for name
in repos
.keys():
53 url
, need_recursive
, need_develop
= repos
[name
]
55 print("[installing " + name
+ "]...")
57 os
.chdir(os
.path
.join(current_path
, name
))
58 if "--user" in sys
.argv
[1:]:
59 os
.system("python3 setup.py develop --user")
61 os
.system("python3 setup.py develop")
63 if "update" in sys
.argv
[1:]:
64 for name
in repos
.keys():
66 print("[updating " + name
+ "]...")
67 os
.chdir(os
.path
.join(current_path
, name
))