13
13
import requests
14
14
15
15
16
- BUNDLE_DATA = "latest_bundle_data.json"
17
- BUNDLE_TAG = "latest_bundle_tag.json"
16
+ ADAFRUIT_BUNDLE_DATA = "latest_bundle_data.json"
17
+ ADAFRUIT_BUNDLE_TAG = "latest_bundle_tag.json"
18
+
19
+ COMMUNITY_BUNDLE_DATA = "latest_community_bundle_data.json"
20
+ COMMUNITY_BUNDLE_TAG = "latest_community_bundle_tag.json"
21
+
22
+ ADAFRUIT_BUNDLE_S3_URL = "https://adafruit-circuit-python.s3.amazonaws.com/bundles/adafruit/adafruit-circuitpython-bundle-{tag}.json" # pylint: disable=line-too-long
23
+ COMMUNITY_BUNDLE_S3_URL = "https://adafruit-circuit-python.s3.amazonaws.com/bundles/community/circuitpython-community-bundle-{tag}.json" # pylint: disable=line-too-long
18
24
19
25
SUBDIRECTORY_FILECOUNT_LIMIT = 10
20
26
38
44
SHOWN_FILETYPES_EXAMPLE = [s for s in SHOWN_FILETYPES if s != "py" ]
39
45
40
46
41
- def get_bundle (tag ):
42
- """Download the given bundle's data to BUNDLE_DATA"""
43
- url = f"https://adafruit-circuit-python.s3.amazonaws.com/bundles/adafruit/adafruit-circuitpython-bundle-{ tag } .json" # pylint: disable=line-too-long
44
- print (f"get bundle metadata from { url } " )
45
- r = requests .get (url )
46
- with open (BUNDLE_DATA , "wb" ) as bundle_file :
47
+ def get_bundle (bundle_url , bundle_data_file ):
48
+ """Download the Adafruit and Community bundles data"""
49
+ print (f"get bundle metadata from { bundle_url } " )
50
+ r = requests .get (bundle_url )
51
+ with open (bundle_data_file , "wb" ) as bundle_file :
47
52
bundle_file .write (r .content )
48
53
49
54
50
- LATEST_BUNDLE_VERSION = ""
51
-
52
-
53
55
def get_latest_release_from_url (url ):
54
56
"""
55
57
Find the tag name of the latest release by using HTTP HEAD and decoding the redirect.
@@ -67,44 +69,40 @@ def get_latest_release_from_url(url):
67
69
return tag
68
70
69
71
70
- def get_latest_tag ():
72
+ def get_latest_tag (repo_url ):
71
73
"""
72
74
Find the value of the latest tag for the Adafruit CircuitPython library
73
75
bundle.
74
76
:return: The most recent tag value for the project.
75
77
"""
76
- global LATEST_BUNDLE_VERSION # pylint: disable=global-statement
77
- if LATEST_BUNDLE_VERSION == "" :
78
- LATEST_BUNDLE_VERSION = get_latest_release_from_url (
79
- "https://github.com/adafruit/Adafruit_CircuitPython_Bundle/releases/latest"
80
- )
81
- return LATEST_BUNDLE_VERSION
82
78
79
+ return get_latest_release_from_url (repo_url )
83
80
84
- def ensure_latest_bundle ():
81
+
82
+ def ensure_latest_bundle (bundle_url , bundle_s3_url , bundle_tag_file , bundle_data_file ):
85
83
"""
86
84
Ensure that there's a copy of the latest library bundle available so circup
87
85
can check the metadata contained therein.
88
86
"""
89
87
print ("Checking for library updates." )
90
- tag = get_latest_tag ()
88
+ tag = get_latest_tag (bundle_url )
91
89
old_tag = "0"
92
- if os .path .isfile (BUNDLE_TAG ):
93
- with open (BUNDLE_TAG , encoding = "utf-8" ) as data :
90
+ if os .path .isfile (bundle_tag_file ):
91
+ with open (bundle_tag_file , encoding = "utf-8" ) as data :
94
92
try :
95
93
old_tag = json .load (data )["tag" ]
96
94
except json .decoder .JSONDecodeError as _ :
97
95
# Sometimes (why?) the JSON file becomes corrupt. In which case
98
96
# log it and carry on as if setting up for first time.
99
- print (f"Could not parse { BUNDLE_TAG :r} " )
97
+ print (f"Could not parse { bundle_tag_file :r} " )
100
98
if tag > old_tag :
101
99
print (f"New version available { tag } ." )
102
100
try :
103
- get_bundle (tag )
104
- with open (BUNDLE_TAG , "w" , encoding = "utf-8" ) as data :
101
+ get_bundle (bundle_s3_url . replace ( "{ tag}" , tag ), bundle_data_file )
102
+ with open (bundle_tag_file , "w" , encoding = "utf-8" ) as data :
105
103
json .dump ({"tag" : tag }, data )
106
104
except requests .exceptions .HTTPError as _ :
107
- # See #20 for reason this this
105
+ # See #20 for reason this
108
106
print (
109
107
(
110
108
"There was a problem downloading the bundle. "
@@ -116,11 +114,25 @@ def ensure_latest_bundle():
116
114
print (f"Current library bundle up to date { tag } " )
117
115
118
116
119
- ensure_latest_bundle ()
117
+ ensure_latest_bundle (
118
+ "https://github.com/adafruit/Adafruit_CircuitPython_Bundle/releases/latest" ,
119
+ ADAFRUIT_BUNDLE_S3_URL ,
120
+ ADAFRUIT_BUNDLE_TAG ,
121
+ ADAFRUIT_BUNDLE_DATA ,
122
+ )
123
+ ensure_latest_bundle (
124
+ "https://github.com/adafruit/CircuitPython_Community_Bundle/releases/latest" ,
125
+ COMMUNITY_BUNDLE_S3_URL ,
126
+ COMMUNITY_BUNDLE_TAG ,
127
+ COMMUNITY_BUNDLE_DATA ,
128
+ )
120
129
121
- with open ("latest_bundle_data.json" , "r" , encoding = "utf-8" ) as f :
130
+ with open (ADAFRUIT_BUNDLE_DATA , "r" , encoding = "utf-8" ) as f :
122
131
bundle_data = json .load (f )
123
132
133
+ with open (COMMUNITY_BUNDLE_DATA , "r" , encoding = "utf-8" ) as f :
134
+ community_bundle_data = json .load (f )
135
+
124
136
125
137
def get_files_for_project (project_name ):
126
138
"""Get the set of files for a learn project"""
@@ -164,7 +176,7 @@ def get_libs_for_project(project_name):
164
176
165
177
for cur_import in found_imports :
166
178
cur_lib = cur_import .name .split ("." )[0 ]
167
- if cur_lib in bundle_data :
179
+ if cur_lib in bundle_data or cur_lib in community_bundle_data :
168
180
found_libs .add (cur_lib )
169
181
170
182
return found_libs
0 commit comments