X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=org.argeo.cms%2Fsrc%2Forg%2Fargeo%2Fcms%2Facr%2FContentUtils.java;h=272a5c5a148d3f51b3315fad79918e4837aed3c9;hb=4c7e1885b8bf3c93fa0919ace122e3f289a925ea;hp=5609cf7778ca65555824c500e48d3769be944f69;hpb=da9d144b6b241e1526a3bd255dff905a7969a5bc;p=lgpl%2Fargeo-commons.git diff --git a/org.argeo.cms/src/org/argeo/cms/acr/ContentUtils.java b/org.argeo.cms/src/org/argeo/cms/acr/ContentUtils.java index 5609cf777..272a5c5a1 100644 --- a/org.argeo.cms/src/org/argeo/cms/acr/ContentUtils.java +++ b/org.argeo.cms/src/org/argeo/cms/acr/ContentUtils.java @@ -1,12 +1,13 @@ package org.argeo.cms.acr; import java.io.PrintStream; +import java.util.ArrayList; +import java.util.List; import java.util.function.BiConsumer; import javax.xml.namespace.QName; import org.argeo.api.acr.Content; -import org.argeo.api.cms.CmsSession; /** Utilities and routines around {@link Content}. */ public class ContentUtils { @@ -50,18 +51,56 @@ public class ContentUtils { // return t instanceof String; // } + public static final char SLASH = '/'; + public static final String ROOT_SLASH = "" + SLASH; + /** * Split a path (with '/' separator) in an array of length 2, the first part * being the parent path (which could be either absolute or relative), the - * second one being the last segment, (guaranteed to be with '/'). + * second one being the last segment, (guaranteed to be without a '/'). */ public static String[] getParentPath(String path) { - int parentIndex = path.lastIndexOf('/'); - // TODO make it more robust - return new String[] { parentIndex != 0 ? path.substring(0, parentIndex) : "/", + if (path == null) + throw new IllegalArgumentException("Path cannot be null"); + if (path.length() == 0) + throw new IllegalArgumentException("Path cannot be empty"); + checkDoubleSlash(path); + int parentIndex = path.lastIndexOf(SLASH); + if (parentIndex == path.length() - 1) {// trailing '/' + path = path.substring(0, path.length() - 1); + parentIndex = path.lastIndexOf(SLASH); + } + + if (parentIndex == -1) // no '/' + return new String[] { "", path }; + + return new String[] { parentIndex != 0 ? path.substring(0, parentIndex) : "" + SLASH, path.substring(parentIndex + 1) }; } + public static List toPathSegments(String path) { + List res = new ArrayList<>(); + if ("".equals(path) || ROOT_SLASH.equals(path)) + return res; + collectPathSegments(path, res); + return res; + } + + private static void collectPathSegments(String path, List segments) { + String[] parent = getParentPath(path); + if ("".equals(parent[1])) // root + return; + segments.add(0, parent[1]); + if ("".equals(parent[0])) // end + return; + collectPathSegments(parent[0], segments); + } + + public static void checkDoubleSlash(String path) { + if (path.contains(SLASH + "" + SLASH)) + throw new IllegalArgumentException("Path " + path + " contains //"); + } + /** Singleton. */ private ContentUtils() {