/*
* Copyright (c) 2007 Adobe Systems Incorporated
*
* Permission is hereby granted, free of charge, to any person obtaining a copy of
* this software and associated documentation files (the "Software"), to deal in
* the Software without restriction, including without limitation the rights to
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
* the Software, and to permit persons to whom the Software is furnished to do so,
* subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*
*/
package com.adobe.dp.epub.util;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.util.Stack;
import java.util.StringTokenizer;
public class PathUtil {
public static String resolveRelativeReference(String base, String ref)
throws IllegalArgumentException {
if( ref.startsWith("data:") )
return ref;
try {
ref = URLDecoder.decode(ref, "UTF-8");
} catch (UnsupportedEncodingException e) {
throw new InternalError(e.toString()); // UTF-8 is guaranteed to be
// supported
}
if (ref.startsWith("#")) {
int index = base.indexOf("#");
if (index < 0)
ref = base + ref;
else
ref = base.substring(0, index) + ref;
} else {
int index = base.lastIndexOf("/");
ref = base.substring(0, index + 1) + ref;
}
return normalizePath(ref);
}
public static String normalizePath(String path)
throws IllegalArgumentException {
if (path.indexOf("..") < 0)
return path;
Stack pathSegments = new Stack();
StringTokenizer tokenizer = new StringTokenizer(path, "/");
while (tokenizer.hasMoreTokens()) {
String pathSegment = tokenizer.nextToken();
if (pathSegment.equals("."))
continue;
if (pathSegment.equals("..")) {
if (pathSegments.size() == 0)
throw new IllegalArgumentException("Invalid path: " + path);
pathSegments.pop();
} else
pathSegments.push(pathSegment);
}
StringBuffer sb = new StringBuffer();
String sep = "";
int len = pathSegments.size();
for (int i = 0; i < len; i++) {
sb.append(sep);
sb.append(pathSegments.elementAt(i));
sep = "/";
}
return sb.toString();
}
}