diff --git a/mx.fastr/mx_fastr.py b/mx.fastr/mx_fastr.py index e988670b4ac635033917a10b5aaf23654f1f6e89..45fe60855596a97f0244bd6ac909e16d9b26526d 100644 --- a/mx.fastr/mx_fastr.py +++ b/mx.fastr/mx_fastr.py @@ -27,6 +27,7 @@ import mx import mx_gate import mx_fastr_pkgs import mx_fastr_dists +from mx_fastr_dists import FastRNativeProject, FastRTestNativeProject, FastRReleaseProject #pylint: disable=unused-import import os ''' @@ -500,31 +501,6 @@ def rcmplib(args): cp = mx.classpath([pcp.name for pcp in mx.projects_opt_limit_to_suites()]) mx.run_java(['-cp', cp, 'com.oracle.truffle.r.test.tools.cmpr.CompareLibR'] + cmpArgs) -class FastRNativeProject(mx_fastr_dists.DelFastRNativeProject): - ''' - Custom class for building the com.oracle.truffle.r.native project. - Delegates to mx_fastr_dists.DelFastRNativeProject to keep this file uncluttered - ''' - def __init__(self, suite, name, deps, workingSets, theLicense, **args): - mx_fastr_dists.DelFastRNativeProject.__init__(self, suite, name, deps, workingSets, theLicense) - -class FastRTestNativeProject(mx_fastr_dists.DelFastRTestNativeProject): - ''' - Custom class for building the com.oracle.truffle.r.test.native project. - Delegates to mx_fastr_dists.DelFastRTestNativeProject to keep this file uncluttered - ''' - def __init__(self, suite, name, deps, workingSets, theLicense, **args): - mx_fastr_dists.DelFastRTestNativeProject.__init__(self, suite, name, deps, workingSets, theLicense) - -class FastRReleaseProject(mx_fastr_dists.DelFastRReleaseProject): - ''' - Custom class for creating the FastR release project, which supports the - FASTR_RELEASE distribution. - Delegates to mx_fastr_dists.DelFastRReleaseProject to keep this file uncluttered - ''' - def __init__(self, suite, name, deps, workingSets, theLicense, **args): - mx_fastr_dists.DelFastRReleaseProject.__init__(self, suite, name, deps, workingSets, theLicense) - def mx_post_parse_cmd_line(opts): mx_fastr_dists.mx_post_parse_cmd_line(opts) diff --git a/mx.fastr/mx_fastr_dists.py b/mx.fastr/mx_fastr_dists.py index 50f64b3bdf3ef6e9ae9239c5e1673a8f7f067d71..aabb3e7c0de0a763a6b63b72875088af0e70c933 100644 --- a/mx.fastr/mx_fastr_dists.py +++ b/mx.fastr/mx_fastr_dists.py @@ -43,7 +43,7 @@ class FastRProjectAdapter(mx.ArchivableProject): results.append(join(root, f)) -class DelFastRNativeProject(FastRProjectAdapter): +class FastRNativeProject(FastRProjectAdapter): ''' Custom class for building the com.oracle.truffle.r.native project. The customization is to support the creation of an exact FASTR_NATIVE_DEV distribution. @@ -111,7 +111,7 @@ class DelFastRNativeProject(FastRProjectAdapter): return results -class DelFastRTestNativeProject(FastRProjectAdapter): +class FastRTestNativeProject(FastRProjectAdapter): ''' Custom class for building the com.oracle.truffle.r.native project. The customization is to support the creation of an exact FASTR_NATIVE_DEV distribution. @@ -147,7 +147,7 @@ class DelFastRTestNativeProject(FastRProjectAdapter): results.append(join(self.dir, 'urand', 'lib', 'liburand.so')) return results -class DelFastRReleaseProject(FastRProjectAdapter): +class FastRReleaseProject(FastRProjectAdapter): ''' Custom class for creating the FastR release project, which supports the FASTR_RELEASE distribution. @@ -159,6 +159,7 @@ class DelFastRReleaseProject(FastRProjectAdapter): results = [] for rdir in ['bin', 'lib', 'library', 'etc', 'share', 'doc']: self._get_files(rdir, results) + results.append(join(self.dir, 'LICENSE.FASTR')) return results def getBuildTask(self, args): @@ -186,6 +187,18 @@ class ReleaseBuildTask(mx.NativeBuildTask): if os.path.exists(target_dir): shutil.rmtree(target_dir) shutil.copytree(join(fastr_dir, d), target_dir) + + # copyrights + copyrights_dir = join(fastr_dir,'mx.fastr', 'copyrights') + with open(join(output_dir, 'LICENSE.FASTR'), 'w') as outfile: + for copyright_file in os.listdir(copyrights_dir): + basename = os.path.basename(copyright_file) + if not basename.endswith('copyright.star') and not basename.endswith('copyright.hash'): + continue + with open(join(copyrights_dir, copyright_file)) as infile: + data = infile.read() + outfile.write(data) + # canonicalize R_HOME_DIR in bin/R bin_dir = join(output_dir, 'bin') rcmd = join(bin_dir, 'R') @@ -256,7 +269,7 @@ class FastRArchiveParticipant: # Since we have already encapsulated the class files in 'jjars/fastr.jar' we # suppress their inclusion here by resetting the deps filed. A bit of a hack. if self.dist.name == "FASTR_RELEASE": - assert isinstance(self.dist.deps[0], DelFastRReleaseProject) + assert isinstance(self.dist.deps[0], FastRReleaseProject) self.dist.deps[0].deps = [] def __add__(self, arcname, contents):