From: Tom Tromey Date: Thu, 17 Apr 2008 17:16:09 +0000 (+0000) Subject: re PR libgcj/35950 (jar produces files ecj won't handle) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=6afce8909c4c8e04169364b92742d9ccc202410d;p=gcc.git re PR libgcj/35950 (jar produces files ecj won't handle) PR libgcj/35950: * tools/gnu/classpath/tools/jar/Entry.java: New version from Classpath. * tools/classes/gnu/classpath/tools/jar/Entry.class: Update. From-SVN: r134402 --- diff --git a/libjava/classpath/ChangeLog.gcj b/libjava/classpath/ChangeLog.gcj index ffc357133b6..093b2fbe0e4 100644 --- a/libjava/classpath/ChangeLog.gcj +++ b/libjava/classpath/ChangeLog.gcj @@ -1,3 +1,10 @@ +2008-04-17 Tom Tromey + + PR libgcj/35950: + * tools/gnu/classpath/tools/jar/Entry.java: New version from + Classpath. + * tools/classes/gnu/classpath/tools/jar/Entry.class: Update. + 2008-03-02 Jakub Jelinek * gnu/java/rmi/registry/RegistryImpl.java (version): Update diff --git a/libjava/classpath/tools/classes/gnu/classpath/tools/jar/Entry.class b/libjava/classpath/tools/classes/gnu/classpath/tools/jar/Entry.class index d030d92ddd8..b517df7439d 100644 Binary files a/libjava/classpath/tools/classes/gnu/classpath/tools/jar/Entry.class and b/libjava/classpath/tools/classes/gnu/classpath/tools/jar/Entry.class differ diff --git a/libjava/classpath/tools/gnu/classpath/tools/jar/Entry.java b/libjava/classpath/tools/gnu/classpath/tools/jar/Entry.java index aa8679aab55..b9108798a16 100644 --- a/libjava/classpath/tools/gnu/classpath/tools/jar/Entry.java +++ b/libjava/classpath/tools/gnu/classpath/tools/jar/Entry.java @@ -1,5 +1,5 @@ /* Entry.java - represent a single file to write to a jar - Copyright (C) 2006 Free Software Foundation, Inc. + Copyright (C) 2006, 2007 Free Software Foundation, Inc. This file is part of GNU Classpath. @@ -49,12 +49,22 @@ public class Entry public Entry(File file, String name) { this.file = file; - this.name = name; + + /* Removes any './' prefixes automatically. Those caused trouble + * in (boot) classpath use-cases. See #32516. + */ + int start = 0; + while (name.length() > start + 2 + && name.codePointAt(start) == '.' + && name.codePointAt(start + 1) == File.separatorChar) + start += 2; + + this.name = name.substring(start); } public Entry(File file) { - this.file = file; - this.name = file.toString(); + this(file, file.toString()); } + }