blob: 7beaede088cbe7779a678fdc195cd98bbda0f70c [file] [log] [blame]
Ian Zernydcb172e2022-02-22 15:36:45 +01001#!/usr/bin/env python3
Rico Windb4621c12017-08-28 12:48:53 +02002# Copyright (c) 2017, the R8 project authors. Please see the AUTHORS file
3# for details. All rights reserved. Use of this source code is governed by a
4# BSD-style license that can be found in the LICENSE file.
5
Ian Zerny3f54e222019-02-12 10:51:17 +01006import jdk
Rico Wind63a13562018-12-10 14:31:02 +01007import optparse
Rico Windb4621c12017-08-28 12:48:53 +02008import os
Clément Béra3718ad02023-09-05 14:12:48 +02009
10import create_maven_release
11import gradle
12
Morten Krogh-Jespersenfe0d7e12020-01-31 08:50:17 +010013try:
14 import resource
15except ImportError:
16 # Not a Unix system. Do what Gandalf tells you not to.
17 pass
Mathias Ravdd6a6de2018-05-18 10:18:33 +020018import shutil
Rico Wind0c24ae72017-09-08 11:33:56 +020019import subprocess
Rico Windb4621c12017-08-28 12:48:53 +020020import sys
21import utils
Yohann Roussel73f58e12017-10-13 17:33:14 +020022import zipfile
Rico Windb4621c12017-08-28 12:48:53 +020023
Rico Wind792e8c72017-08-30 09:43:46 +020024ARCHIVE_BUCKET = 'r8-releases'
Rico Windb4621c12017-08-28 12:48:53 +020025
Rico Wind63a13562018-12-10 14:31:02 +010026def ParseOptions():
27 result = optparse.OptionParser()
28 result.add_option('--dry-run', '--dry_run',
29 help='Build only, no upload.',
30 default=False, action='store_true')
Søren Gjessec425e6a2019-06-28 11:41:14 +020031 result.add_option('--dry-run-output', '--dry_run_output',
32 help='Output directory for \'build only, no upload\'.',
33 type="string", action="store")
Søren Gjesse1b035b32022-08-19 08:53:57 +020034 result.add_option('--skip-gradle-build', '--skip_gradle_build',
35 help='Skip Gradle build. Can only be used for local testing.',
36 default=False, action='store_true')
Rico Wind63a13562018-12-10 14:31:02 +010037 return result.parse_args()
38
Rico Windb4621c12017-08-28 12:48:53 +020039def GetVersion():
Rico Windd31b5892022-04-25 11:06:30 +020040 output = subprocess.check_output([
41 jdk.GetJavaExecutable(), '-cp', utils.R8_JAR, 'com.android.tools.r8.R8',
42 '--version'
43 ]).decode('utf-8')
44 r8_version = output.splitlines()[0].strip()
45 return r8_version.split()[1]
Rico Windb4621c12017-08-28 12:48:53 +020046
Rico Wind0c24ae72017-09-08 11:33:56 +020047def GetGitBranches():
48 return subprocess.check_output(['git', 'show', '-s', '--pretty=%d', 'HEAD'])
Rico Windb4621c12017-08-28 12:48:53 +020049
Rico Wind0c24ae72017-09-08 11:33:56 +020050def GetGitHash():
Rico Windfd186372022-02-28 08:55:48 +010051 return subprocess.check_output(['git', 'rev-parse', 'HEAD']).decode('utf-8').strip()
Rico Windb4621c12017-08-28 12:48:53 +020052
Rico Wind1b52acf2021-03-21 12:36:55 +010053def IsMain(version):
Rico Windfd186372022-02-28 08:55:48 +010054 branches = subprocess.check_output(['git', 'branch', '-r', '--contains',
55 'HEAD']).decode('utf-8')
Rico Wind1b52acf2021-03-21 12:36:55 +010056 # CL runs from gerrit does not have a branch, we always treat them as main
Rico Windd450ba12019-04-24 13:18:40 +020057 # commits to archive these to the hash based location
58 if len(branches) == 0:
59 return True
Rico Wind1b52acf2021-03-21 12:36:55 +010060 if not version == 'main':
Rico Wind0c24ae72017-09-08 11:33:56 +020061 # Sanity check, we don't want to archive on top of release builds EVER
62 # Note that even though we branch, we never push the bots to build the same
Rico Wind1b52acf2021-03-21 12:36:55 +010063 # commit as main on a branch since we always change the version to
64 # not be just 'main' (or we crash here :-)).
65 if 'origin/main' in branches:
66 raise Exception('We are seeing origin/main in a commit that '
67 'don\'t have \'main\' as version')
Mads Agerac794132017-11-09 11:38:45 +010068 return False
Rico Wind1b52acf2021-03-21 12:36:55 +010069 if not 'origin/main' in branches:
70 raise Exception('We are not seeing origin/main '
71 'in a commit that have \'main\' as version')
Mads Agerac794132017-11-09 11:38:45 +010072 return True
Rico Wind0c24ae72017-09-08 11:33:56 +020073
Rico Windc0b16382018-05-17 13:23:43 +020074def GetStorageDestination(storage_prefix,
75 version_or_path,
76 file_name,
Rico Wind293d6e02023-09-14 15:15:47 +020077 is_main,
78 new_gradle=False):
Rico Wind1b52acf2021-03-21 12:36:55 +010079 # We archive main commits under raw/main instead of directly under raw
Rico Windc0b16382018-05-17 13:23:43 +020080 version_dir = GetVersionDestination(storage_prefix,
81 version_or_path,
Rico Wind293d6e02023-09-14 15:15:47 +020082 is_main,
83 new_gradle)
Rico Wind1a29c4f2018-01-25 08:43:08 +010084 return '%s/%s' % (version_dir, file_name)
85
Rico Wind293d6e02023-09-14 15:15:47 +020086def GetVersionDestination(storage_prefix, version_or_path, is_main,
87 new_gradle=False):
Rico Wind453e7e22023-10-03 08:37:51 +020088 assert new_gradle
Rico Wind1b52acf2021-03-21 12:36:55 +010089 archive_dir = 'raw/main' if is_main else 'raw'
Rico Wind453e7e22023-10-03 08:37:51 +020090 bucket = ARCHIVE_BUCKET
Rico Wind293d6e02023-09-14 15:15:47 +020091 return '%s%s/%s/%s' % (storage_prefix, bucket,
Rico Windc0b16382018-05-17 13:23:43 +020092 archive_dir, version_or_path)
Rico Wind0c24ae72017-09-08 11:33:56 +020093
Rico Wind293d6e02023-09-14 15:15:47 +020094def GetUploadDestination(version_or_path, file_name, is_main,
95 new_gradle=False):
96 return GetStorageDestination('gs://', version_or_path, file_name, is_main,
97 new_gradle)
Rico Wind0c24ae72017-09-08 11:33:56 +020098
Rico Wind293d6e02023-09-14 15:15:47 +020099def GetUrl(version_or_path, file_name, is_main, new_gradle=False):
Rico Wind70d614f2020-01-31 08:45:21 +0100100 return GetStorageDestination('https://storage.googleapis.com/',
Rico Wind293d6e02023-09-14 15:15:47 +0200101 version_or_path, file_name, is_main, new_gradle)
Rico Windc0b16382018-05-17 13:23:43 +0200102
Rico Wind293d6e02023-09-14 15:15:47 +0200103def GetMavenUrl(is_main, new_gradle=False):
104 return GetVersionDestination('https://storage.googleapis.com/', '', is_main,
105 new_gradle)
Rico Windb4621c12017-08-28 12:48:53 +0200106
Rico Wind7219bb02019-03-18 08:30:12 +0100107def SetRLimitToMax():
108 (soft, hard) = resource.getrlimit(resource.RLIMIT_NOFILE)
109 resource.setrlimit(resource.RLIMIT_NOFILE, (hard, hard))
110
Rico Windcea9ce02019-03-06 14:25:52 +0100111def PrintResourceInfo():
112 (soft, hard) = resource.getrlimit(resource.RLIMIT_NOFILE)
113 print('INFO: Open files soft limit: %s' % soft)
114 print('INFO: Open files hard limit: %s' % hard)
115
Rico Wind293d6e02023-09-14 15:15:47 +0200116
Rico Windb4621c12017-08-28 12:48:53 +0200117def Main():
Rico Wind63a13562018-12-10 14:31:02 +0100118 (options, args) = ParseOptions()
Rico Wind293d6e02023-09-14 15:15:47 +0200119 Run(options, True)
120
121def Run(options, new_gradle):
Rico Wind453e7e22023-10-03 08:37:51 +0200122 assert new_gradle
Rico Wind089ca042019-03-06 13:27:25 +0000123 if not utils.is_bot() and not options.dry_run:
Søren Gjessec425e6a2019-06-28 11:41:14 +0200124 raise Exception('You are not a bot, don\'t archive builds. '
125 + 'Use --dry-run to test locally')
Søren Gjessec425e6a2019-06-28 11:41:14 +0200126 if (options.dry_run_output and
127 (not os.path.exists(options.dry_run_output) or
128 not os.path.isdir(options.dry_run_output))):
129 raise Exception(options.dry_run_output
130 + ' does not exist or is not a directory')
Søren Gjesse1b035b32022-08-19 08:53:57 +0200131 if (options.skip_gradle_build and not options.dry_run):
132 raise Exception('Using --skip-gradle-build only supported with --dry-run')
Tamas Kenez180be092018-12-05 15:23:06 +0100133
Morten Krogh-Jespersenfe0d7e12020-01-31 08:50:17 +0100134 if utils.is_bot() and not utils.IsWindows():
Rico Wind7219bb02019-03-18 08:30:12 +0100135 SetRLimitToMax()
Morten Krogh-Jespersenfe0d7e12020-01-31 08:50:17 +0100136 if not utils.IsWindows():
137 PrintResourceInfo()
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200138
Yohann Roussel73f58e12017-10-13 17:33:14 +0200139 with utils.TempDir() as temp:
140 version_file = os.path.join(temp, 'r8-version.properties')
141 with open(version_file,'w') as version_writer:
142 version_writer.write('version.sha=' + GetGitHash() + '\n')
Søren Gjessec425e6a2019-06-28 11:41:14 +0200143 if not os.environ.get('SWARMING_BOT_ID') and not options.dry_run:
144 raise Exception('Environment variable SWARMING_BOT_ID not set')
145
146 releaser = \
147 ("<local developer build>" if options.dry_run
148 else 'releaser=go/r8bot ('
Rico Wind293d6e02023-09-14 15:15:47 +0200149 + (os.environ.get('SWARMING_BOT_ID') or 'foo') + ')\n')
Søren Gjessec425e6a2019-06-28 11:41:14 +0200150 version_writer.write(releaser)
Yohann Roussel73f58e12017-10-13 17:33:14 +0200151 version_writer.write('version-file.version.code=1\n')
152
Søren Gjesse1b035b32022-08-19 08:53:57 +0200153 create_maven_release.generate_r8_maven_zip(
154 utils.MAVEN_ZIP_LIB,
Søren Gjesse1b035b32022-08-19 08:53:57 +0200155 version_file=version_file,
Rico Wind293d6e02023-09-14 15:15:47 +0200156 skip_gradle_build=options.skip_gradle_build,
157 new_gradle=new_gradle)
158
Rico Windcdc39b62022-04-08 12:37:57 +0200159
160 # Generate and copy a full build without dependencies.
Søren Gjesse1b035b32022-08-19 08:53:57 +0200161 if (not options.skip_gradle_build):
Rico Wind293d6e02023-09-14 15:15:47 +0200162 if (new_gradle):
163 gradle.RunGradle([':main:swissArmyKnife'], new_gradle=True)
164 else:
165 gradle.RunGradleExcludeDeps([utils.R8, utils.R8_SRC])
166 if (not new_gradle):
167 shutil.copyfile(utils.R8_JAR, utils.R8_FULL_EXCLUDE_DEPS_JAR)
Rico Windcdc39b62022-04-08 12:37:57 +0200168
169 # Ensure all archived artifacts has been built before archiving.
170 # The target tasks postfixed by 'lib' depend on the actual target task so
171 # building it invokes the original task first.
172 # The '-Pno_internal' flag is important because we generate the lib based on uses in tests.
Søren Gjesse1b035b32022-08-19 08:53:57 +0200173 if (not options.skip_gradle_build):
Rico Wind293d6e02023-09-14 15:15:47 +0200174 if (new_gradle):
Rico Winde386dc72023-09-19 10:45:02 +0200175 gradle.RunGradle([
Rico Wind0cdd1912023-09-25 11:24:32 +0200176 ':keepanno:keepAnnoAnnotationsJar',
Rico Winde386dc72023-09-19 10:45:02 +0200177 ':main:consolidatedLicense',
178 ':main:r8WithRelocatedDeps',
179 ':main:swissArmyKnife',
180 ':test:r8LibNoDeps',
181 ':test:r8LibWithRelocatedDeps',
182 ':test:retraceNoDeps',
183 ':test:retraceWithRelocatedDeps',
184 ':test:sourcesJar',
185 ':test:sourcesJar',
186 '-Pno_internal'
187 ], new_gradle=True)
Rico Wind293d6e02023-09-14 15:15:47 +0200188 else:
189 gradle.RunGradle([
190 utils.R8,
191 utils.R8LIB,
192 utils.R8LIB_NO_DEPS,
193 utils.R8RETRACE,
194 utils.R8RETRACE_NO_DEPS,
195 utils.LIBRARY_DESUGAR_CONVERSIONS,
196 utils.KEEPANNO_ANNOTATIONS_TARGET,
197 '-Pno_internal'
198 ])
Rico Windcdc39b62022-04-08 12:37:57 +0200199
200 # Create maven release of the desuage_jdk_libs configuration. This require
201 # an r8.jar with dependencies to have been built.
202 create_maven_release.generate_desugar_configuration_maven_zip(
203 utils.DESUGAR_CONFIGURATION_MAVEN_ZIP,
204 utils.DESUGAR_CONFIGURATION,
Søren Gjessee18fa6e2022-06-24 15:14:53 +0200205 utils.DESUGAR_IMPLEMENTATION,
206 utils.LIBRARY_DESUGAR_CONVERSIONS_LEGACY_ZIP)
Rico Windcdc39b62022-04-08 12:37:57 +0200207 create_maven_release.generate_desugar_configuration_maven_zip(
Søren Gjessee18fa6e2022-06-24 15:14:53 +0200208 utils.DESUGAR_CONFIGURATION_JDK11_LEGACY_MAVEN_ZIP,
Rico Windcdc39b62022-04-08 12:37:57 +0200209 utils.DESUGAR_CONFIGURATION_JDK11_LEGACY,
Søren Gjessee18fa6e2022-06-24 15:14:53 +0200210 utils.DESUGAR_IMPLEMENTATION_JDK11,
211 utils.LIBRARY_DESUGAR_CONVERSIONS_LEGACY_ZIP)
Rico Windcdc39b62022-04-08 12:37:57 +0200212
Søren Gjesse2b047692022-08-19 16:34:38 +0200213 create_maven_release.generate_desugar_configuration_maven_zip(
214 utils.DESUGAR_CONFIGURATION_JDK11_MINIMAL_MAVEN_ZIP,
215 utils.DESUGAR_CONFIGURATION_JDK11_MINIMAL,
216 utils.DESUGAR_IMPLEMENTATION_JDK11,
217 utils.LIBRARY_DESUGAR_CONVERSIONS_ZIP)
218 create_maven_release.generate_desugar_configuration_maven_zip(
219 utils.DESUGAR_CONFIGURATION_JDK11_MAVEN_ZIP,
220 utils.DESUGAR_CONFIGURATION_JDK11,
221 utils.DESUGAR_IMPLEMENTATION_JDK11,
222 utils.LIBRARY_DESUGAR_CONVERSIONS_ZIP)
223 create_maven_release.generate_desugar_configuration_maven_zip(
224 utils.DESUGAR_CONFIGURATION_JDK11_NIO_MAVEN_ZIP,
225 utils.DESUGAR_CONFIGURATION_JDK11_NIO,
226 utils.DESUGAR_IMPLEMENTATION_JDK11,
227 utils.LIBRARY_DESUGAR_CONVERSIONS_ZIP)
228
Rico Windcdc39b62022-04-08 12:37:57 +0200229 version = GetVersion()
230 is_main = IsMain(version)
231 if is_main:
232 # On main we use the git hash to archive with
233 print('On main, using git hash for archiving')
234 version = GetGitHash()
235
Rico Windddff0bd2023-09-15 13:49:24 +0200236 destination = GetVersionDestination('gs://', version, is_main, new_gradle)
Rico Windcdc39b62022-04-08 12:37:57 +0200237 if utils.cloud_storage_exists(destination) and not options.dry_run:
238 raise Exception('Target archive directory %s already exists' % destination)
239
240 # Create pom file for our maven repository that we build for testing.
241 default_pom_file = os.path.join(temp, 'r8.pom')
242 create_maven_release.write_default_r8_pom_file(default_pom_file, version)
Rico Wind293d6e02023-09-14 15:15:47 +0200243 for_archiving = [
244 utils.R8_JAR,
245 utils.R8LIB_JAR,
246 utils.R8LIB_JAR + '.map',
247 utils.R8LIB_JAR + '_map.zip',
248 utils.R8_FULL_EXCLUDE_DEPS_JAR,
249 utils.R8LIB_EXCLUDE_DEPS_JAR,
250 utils.R8LIB_EXCLUDE_DEPS_JAR + '.map',
251 utils.R8LIB_EXCLUDE_DEPS_JAR + '_map.zip',
252 utils.MAVEN_ZIP_LIB,
253 utils.DESUGAR_CONFIGURATION,
254 utils.DESUGAR_CONFIGURATION_MAVEN_ZIP,
255 utils.DESUGAR_CONFIGURATION_JDK11_LEGACY,
256 utils.DESUGAR_CONFIGURATION_JDK11_LEGACY_MAVEN_ZIP,
257 utils.DESUGAR_CONFIGURATION_JDK11_MINIMAL_MAVEN_ZIP,
258 utils.DESUGAR_CONFIGURATION_JDK11_MAVEN_ZIP,
259 utils.DESUGAR_CONFIGURATION_JDK11_NIO_MAVEN_ZIP,
Rico Winde386dc72023-09-19 10:45:02 +0200260 utils.R8_SRC_JAR,
261 utils.R8RETRACE_JAR,
262 utils.R8RETRACE_JAR + '.map',
263 utils.R8RETRACE_JAR + '_map.zip',
264 utils.R8RETRACE_EXCLUDE_DEPS_JAR,
265 utils.R8RETRACE_EXCLUDE_DEPS_JAR + '.map',
266 utils.R8RETRACE_EXCLUDE_DEPS_JAR + '_map.zip',
267 utils.KEEPANNO_ANNOTATIONS_JAR,
268 utils.GENERATED_LICENSE]
Rico Wind293d6e02023-09-14 15:15:47 +0200269 for file in for_archiving:
Mads Agerac794132017-11-09 11:38:45 +0100270 file_name = os.path.basename(file)
Yohann Roussel73f58e12017-10-13 17:33:14 +0200271 tagged_jar = os.path.join(temp, file_name)
Mads Agerac794132017-11-09 11:38:45 +0100272 shutil.copyfile(file, tagged_jar)
Mads Agerb10c07f2017-11-27 13:25:52 +0100273 if file_name.endswith('.jar') and not file_name.endswith('-src.jar'):
Mads Agerafc0cda2017-11-27 13:04:27 +0100274 with zipfile.ZipFile(tagged_jar, 'a') as zip:
275 zip.write(version_file, os.path.basename(version_file))
Rico Wind293d6e02023-09-14 15:15:47 +0200276 destination = GetUploadDestination(version, file_name, is_main,
277 new_gradle=new_gradle)
Yohann Roussel73f58e12017-10-13 17:33:14 +0200278 print('Uploading %s to %s' % (tagged_jar, destination))
Rico Wind63a13562018-12-10 14:31:02 +0100279 if options.dry_run:
Søren Gjessec425e6a2019-06-28 11:41:14 +0200280 if options.dry_run_output:
281 dry_run_destination = os.path.join(options.dry_run_output, file_name)
282 print('Dry run, not actually uploading. Copying to '
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200283 + dry_run_destination)
Søren Gjessec425e6a2019-06-28 11:41:14 +0200284 shutil.copyfile(tagged_jar, dry_run_destination)
285 else:
286 print('Dry run, not actually uploading')
Rico Wind63a13562018-12-10 14:31:02 +0100287 else:
288 utils.upload_file_to_cloud_storage(tagged_jar, destination)
Rico Wind293d6e02023-09-14 15:15:47 +0200289 print('File available at: %s' % GetUrl(version, file_name, is_main,
290 new_gradle=new_gradle))
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200291
292 # Upload R8 to a maven compatible location.
Rico Windc0b16382018-05-17 13:23:43 +0200293 if file == utils.R8_JAR:
Søren Gjesse1c115b52019-08-14 12:43:57 +0200294 maven_dst = GetUploadDestination(utils.get_maven_path('r8', version),
Rico Wind293d6e02023-09-14 15:15:47 +0200295 'r8-%s.jar' % version, is_main,
296 new_gradle=new_gradle)
Rico Wind257044c2019-11-22 08:21:21 +0100297 maven_pom_dst = GetUploadDestination(
298 utils.get_maven_path('r8', version),
Rico Wind293d6e02023-09-14 15:15:47 +0200299 'r8-%s.pom' % version, is_main, new_gradle=new_gradle)
Rico Wind63a13562018-12-10 14:31:02 +0100300 if options.dry_run:
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200301 print('Dry run, not actually creating maven repo for R8')
Rico Wind63a13562018-12-10 14:31:02 +0100302 else:
303 utils.upload_file_to_cloud_storage(tagged_jar, maven_dst)
Rico Wind257044c2019-11-22 08:21:21 +0100304 utils.upload_file_to_cloud_storage(default_pom_file, maven_pom_dst)
Rico Wind293d6e02023-09-14 15:15:47 +0200305 print('Maven repo root available at: %s' % GetMavenUrl(
306 is_main, new_gradle=new_gradle))
Rico Windc0b16382018-05-17 13:23:43 +0200307
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200308 # Upload desugar_jdk_libs configuration to a maven compatible location.
309 if file == utils.DESUGAR_CONFIGURATION:
Rico Wind92f796f2020-08-25 14:36:18 +0200310 jar_basename = 'desugar_jdk_libs_configuration.jar'
311 jar_version_name = 'desugar_jdk_libs_configuration-%s.jar' % version
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200312 maven_dst = GetUploadDestination(
313 utils.get_maven_path('desugar_jdk_libs_configuration', version),
Rico Wind293d6e02023-09-14 15:15:47 +0200314 jar_version_name, is_main,
315 new_gradle=new_gradle)
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200316
317 with utils.TempDir() as tmp_dir:
Rico Wind92f796f2020-08-25 14:36:18 +0200318 desugar_jdk_libs_configuration_jar = os.path.join(tmp_dir,
319 jar_version_name)
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200320 create_maven_release.generate_jar_with_desugar_configuration(
Søren Gjesse17fc67d2019-12-04 14:50:17 +0100321 utils.DESUGAR_CONFIGURATION,
Søren Gjessedd1f8152020-10-30 13:00:01 +0100322 utils.DESUGAR_IMPLEMENTATION,
Søren Gjesse17fc67d2019-12-04 14:50:17 +0100323 utils.LIBRARY_DESUGAR_CONVERSIONS_ZIP,
324 desugar_jdk_libs_configuration_jar)
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200325
326 if options.dry_run:
327 print('Dry run, not actually creating maven repo for '
328 + 'desugar configuration.')
Søren Gjesse706f7552019-09-23 13:34:58 +0200329 if options.dry_run_output:
330 shutil.copyfile(
331 desugar_jdk_libs_configuration_jar,
Rico Wind92f796f2020-08-25 14:36:18 +0200332 os.path.join(options.dry_run_output, jar_version_name))
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200333 else:
334 utils.upload_file_to_cloud_storage(
335 desugar_jdk_libs_configuration_jar, maven_dst)
Rico Wind293d6e02023-09-14 15:15:47 +0200336 print('Maven repo root available at: %s' % GetMavenUrl(is_main,
337 new_gradle=new_gradle))
Rico Wind92f796f2020-08-25 14:36:18 +0200338 # Also archive the jar as non maven destination for Google3
339 jar_destination = GetUploadDestination(
Rico Wind293d6e02023-09-14 15:15:47 +0200340 version, jar_basename, is_main, new_gradle=new_gradle)
Rico Wind92f796f2020-08-25 14:36:18 +0200341 utils.upload_file_to_cloud_storage(
342 desugar_jdk_libs_configuration_jar, jar_destination)
343
Søren Gjessee78b1652022-06-30 12:38:36 +0200344 # TODO(b/237636871): Refactor this to avoid the duplication of what is above.
Søren Gjessee18fa6e2022-06-24 15:14:53 +0200345 # Upload desugar_jdk_libs JDK-11 legacyconfiguration to a maven compatible location.
346 if file == utils.DESUGAR_CONFIGURATION_JDK11_LEGACY:
347 jar_basename = 'desugar_jdk_libs_configuration.jar'
348 jar_version_name = 'desugar_jdk_libs_configuration-%s-jdk11-legacy.jar' % version
349 maven_dst = GetUploadDestination(
350 utils.get_maven_path('desugar_jdk_libs_configuration', version),
Rico Wind293d6e02023-09-14 15:15:47 +0200351 jar_version_name, is_main,
352 new_gradle=new_gradle)
Søren Gjessee18fa6e2022-06-24 15:14:53 +0200353
354 with utils.TempDir() as tmp_dir:
355 desugar_jdk_libs_configuration_jar = os.path.join(tmp_dir,
356 jar_version_name)
357 create_maven_release.generate_jar_with_desugar_configuration(
358 utils.DESUGAR_CONFIGURATION_JDK11_LEGACY,
359 utils.DESUGAR_IMPLEMENTATION_JDK11,
360 utils.LIBRARY_DESUGAR_CONVERSIONS_ZIP,
361 desugar_jdk_libs_configuration_jar)
362
363 if options.dry_run:
364 print('Dry run, not actually creating maven repo for '
365 + 'desugar configuration.')
366 if options.dry_run_output:
367 shutil.copyfile(
368 desugar_jdk_libs_configuration_jar,
369 os.path.join(options.dry_run_output, jar_version_name))
370 else:
371 utils.upload_file_to_cloud_storage(
372 desugar_jdk_libs_configuration_jar, maven_dst)
Rico Wind293d6e02023-09-14 15:15:47 +0200373 print('Maven repo root available at: %s' % GetMavenUrl(
374 is_main, new_gradle=new_gradle))
Søren Gjessee18fa6e2022-06-24 15:14:53 +0200375 # Also archive the jar as non maven destination for Google3
376 jar_destination = GetUploadDestination(
Rico Wind293d6e02023-09-14 15:15:47 +0200377 version, jar_basename, is_main, new_gradle=new_gradle)
Søren Gjessee18fa6e2022-06-24 15:14:53 +0200378 utils.upload_file_to_cloud_storage(
379 desugar_jdk_libs_configuration_jar, jar_destination)
Rico Windb4621c12017-08-28 12:48:53 +0200380
381if __name__ == '__main__':
382 sys.exit(Main())