X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=org.argeo.cms%2Fsrc%2Forg%2Fargeo%2Fcms%2Facr%2FTypesManager.java;h=23d6042d7ac23c53a8d7a797c74cd8274e07c4f0;hb=c0342975a37c70895c2e8f6b341d790700168d7f;hp=72bb26f209c49e5437d5eaa8895fcffc78c12d7d;hpb=e41a5f598aa4692ee4109e5442e5fcd8565e98bd;p=lgpl%2Fargeo-commons.git diff --git a/org.argeo.cms/src/org/argeo/cms/acr/TypesManager.java b/org.argeo.cms/src/org/argeo/cms/acr/TypesManager.java index 72bb26f20..23d6042d7 100644 --- a/org.argeo.cms/src/org/argeo/cms/acr/TypesManager.java +++ b/org.argeo.cms/src/org/argeo/cms/acr/TypesManager.java @@ -65,7 +65,7 @@ class TypesManager { private XSModel xsModel; private SortedMap> types; - private boolean validating = true; + private boolean validating = false; private final static boolean limited = false; @@ -77,35 +77,30 @@ class TypesManager { } - public synchronized void init() { -// prefixes.put(CrName.CR_DEFAULT_PREFIX, CrName.CR_NAMESPACE_URI); -// prefixes.put("basic", CrName.CR_NAMESPACE_URI); -// prefixes.put("owner", CrName.CR_NAMESPACE_URI); -// prefixes.put("posix", CrName.CR_NAMESPACE_URI); - + public void init() { for (CmsContentTypes cs : CmsContentTypes.values()) { - StreamSource source = new StreamSource(cs.getResource().toExternalForm()); - sources.add(source); -// if (prefixes.containsKey(cs.getDefaultPrefix())) -// throw new IllegalStateException("Prefix " + cs.getDefaultPrefix() + " is already mapped with " -// + prefixes.get(cs.getDefaultPrefix())); -// prefixes.put(cs.getDefaultPrefix(), cs.getNamespace()); + if (cs.getResource() != null) { + StreamSource source = new StreamSource(cs.getResource().toExternalForm()); + sources.add(source); + } RuntimeNamespaceContext.register(cs.getNamespace(), cs.getDefaultPrefix()); } reload(); } - public synchronized void registerTypes(String defaultPrefix, String namespace, String xsdSystemId) { + public void registerTypes(String defaultPrefix, String namespace, String xsdSystemId) { // if (prefixes.containsKey(defaultPrefix)) // throw new IllegalStateException( // "Prefix " + defaultPrefix + " is already mapped with " + prefixes.get(defaultPrefix)); // prefixes.put(defaultPrefix, namespace); RuntimeNamespaceContext.register(namespace, defaultPrefix); - if (xsdSystemId != null) + if (xsdSystemId != null) { sources.add(new StreamSource(xsdSystemId)); - reload(); + reload(); + log.debug(() -> "Registered types " + namespace + " from " + xsdSystemId); + } } public Set listTypes() { @@ -458,7 +453,8 @@ class TypesManager { try { validator.validate(source); } catch (SAXException e) { - throw new IllegalArgumentException("Provided source is not valid", e); + log.error(source + " is not valid ", e); + // throw new IllegalArgumentException("Provided source is not valid", e); } }