Skip to content

Commit

Permalink
allow old 'enum' package to compile and run (#585)
Browse files Browse the repository at this point in the history
  • Loading branch information
markro49 authored Jul 3, 2024
1 parent a56a3f3 commit c6be812
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 4 deletions.
19 changes: 15 additions & 4 deletions framework/core/Project/Lang.pm
Original file line number Diff line number Diff line change
Expand Up @@ -89,10 +89,21 @@ sub _post_checkout {
Utils::convert_file_encoding($work_dir."/".$result->{src}."/org/apache/commons/lang3/text/translate/EntityArrays.java");
Utils::convert_file_encoding($work_dir."/".$result->{src}."/org/apache/commons/lang/Entities.java");

# remove old pre Java 1.5 code
print($work_dir."/".$result->{src}."/org/apache/commons/lang/enum\n");
rmtree($work_dir."/".$result->{src}."/org/apache/commons/lang/enum");
rmtree($work_dir."/".$result->{test}."/org/apache/commons/lang/enum");
# Some of the Lang tests were created pre Java 1.5 and contain an 'enum' package.
# The is now a reserved word in Java so we convert all references to 'oldenum'.
my $cmd = "grep -lR '\.enum;' $work_dir'/'$result->{src}'/org/apache/commons/lang/enum/'";
my $log = `$cmd`;
my $ret = $?;
if ($ret == 0 && length($log) > 0) {
Utils::exec_cmd("grep -lR '\\.enum;' $work_dir'/'$result->{src}'/org/apache/commons/lang/enum/' | xargs sed -i'' 's/\\.enum;/\\.oldenum;/'", "Rename enum 1") or die;
}

$cmd = "grep -lR '\.enum;' $work_dir'/'$result->{test}'/org/apache/commons/lang/enum/'";
$log = `$cmd`;
$ret = $?;
if ($ret == 0 && length($log) > 0) {
Utils::exec_cmd("grep -lR '\\.enum;' $work_dir'/'$result->{test}'/org/apache/commons/lang/enum/' | xargs sed -i'' 's/\\.enum;/\\.oldenum;/'", "Rename enum 2") or die;
}

# Fix compilation errors if necessary
my $compile_errors = "$PROJECTS_DIR/$self->{pid}/compile-errors/";
Expand Down
16 changes: 16 additions & 0 deletions framework/projects/Lang/compile-errors/test-65-65.diff
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
index 38d578aba..a0ae9fc73 100644
--- a/src/java/org/apache/commons/lang/enum/ValuedEnum.java
+++ b/src/java/org/apache/commons/lang/enum/ValuedEnum.java
@@ -140,9 +140,9 @@ public abstract class ValuedEnum extends Enum {
}
List list = Enum.getEnumList(enumClass);
for (Iterator it = list.iterator(); it.hasNext();) {
- ValuedEnum enum = (ValuedEnum) it.next();
- if (enum.getValue() == value) {
- return enum;
+ ValuedEnum enumer = (ValuedEnum) it.next();
+ if (enumer.getValue() == value) {
+ return enumer;
}
}
return null;

0 comments on commit c6be812

Please sign in to comment.