From 23f99379d3d3d445c15f7a3c2e29e44c06afb255 Mon Sep 17 00:00:00 2001 From: Anthony Green Date: Tue, 6 Jul 2004 02:52:54 +0000 Subject: File.java (toURI): Merge from Classpath. 2004-07-05 Anthony Green * java/io/File.java (toURI): Merge from Classpath. From-SVN: r84145 --- libjava/ChangeLog | 4 ++++ libjava/java/io/File.java | 24 ++++++++++++++++++++++++ 2 files changed, 28 insertions(+) diff --git a/libjava/ChangeLog b/libjava/ChangeLog index 4cff650..66f3f41 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,7 @@ +2004-07-05 Anthony Green + + * java/io/File.java (toURI): Merge from Classpath. + 2004-07-05 Bryce McKinlay * gnu/gcj/runtime/VMClassLoader.java (init): Check classpath entry diff --git a/libjava/java/io/File.java b/libjava/java/io/File.java index 53ae529..47f18b5 100644 --- a/libjava/java/io/File.java +++ b/libjava/java/io/File.java @@ -40,6 +40,8 @@ exception statement from your version. */ package java.io; import java.net.MalformedURLException; +import java.net.URI; +import java.net.URISyntaxException; import java.net.URL; import gnu.classpath.Configuration; import gnu.gcj.runtime.FileDeleter; @@ -875,6 +877,28 @@ public class File implements Serializable, Comparable } /** + * @return A URI for this object. + */ + public URI toURI() + { + String abspath = getAbsolutePath(); + + if (isDirectory()) + abspath = abspath + separator; + + try + { + return new URI("file", "", abspath.replace(separatorChar, '/')); + } + catch (URISyntaxException use) + { + // Can't happen. + throw (InternalError) new InternalError("Unconvertible file: " + + this).initCause(use); + } + } + + /** * This method returns a URL with the file: * protocol that represents this file. The exact form of this URL is * system dependent. -- cgit v1.1