X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=org.argeo.cms%2Fsrc%2Forg%2Fargeo%2Fcms%2Facr%2FMountManager.java;h=75ca427c7e25bdee4d96e7bbd768c65c959b3e90;hb=117eaabc86f6c09eff9a4b971ac137d51f45e953;hp=36b0cfe5ed051f05a129f40864b2ef4f05380001;hpb=975fb5e581d0650768afc68a0e839657f318e77a;p=lgpl%2Fargeo-commons.git diff --git a/org.argeo.cms/src/org/argeo/cms/acr/MountManager.java b/org.argeo.cms/src/org/argeo/cms/acr/MountManager.java index 36b0cfe5e..75ca427c7 100644 --- a/org.argeo.cms/src/org/argeo/cms/acr/MountManager.java +++ b/org.argeo.cms/src/org/argeo/cms/acr/MountManager.java @@ -47,6 +47,7 @@ class MountManager { return partitions.get(mountPath); } + /** The content provider for this path. */ synchronized ContentProvider findContentProvider(String path) { // if (ContentUtils.EMPTY.equals(path)) // return partitions.firstEntry().getValue(); @@ -65,4 +66,17 @@ class MountManager { assert mountPath.equals(contentProvider.getMountPath()); return contentProvider; } + + /** All content provider under this path. */ + synchronized NavigableMap findContentProviders(String path) { + NavigableMap res = new TreeMap<>(); + tail: for (Map.Entry provider : partitions.tailMap(path).entrySet()) { + if (!provider.getKey().startsWith(path)) + break tail; + res.put(provider.getKey(), provider.getValue()); + } + return res; + + } + }