X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=server%2Fruntime%2Forg.argeo.server.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fserver%2Fdao%2FAbstractMemoryDaoSupport.java;h=900b0d5b76f5af5f26089cc2d4764601c0cdae86;hb=1d5afdce3e91054f07ddd3c98309c363b4cf1d46;hp=39655d4fe04812fc9a2027cab7c4fd1723b27294;hpb=d8c2b3440de26af2f60e90e4e1b1f4fdbc7b0735;p=lgpl%2Fargeo-commons.git diff --git a/server/runtime/org.argeo.server.core/src/main/java/org/argeo/server/dao/AbstractMemoryDaoSupport.java b/server/runtime/org.argeo.server.core/src/main/java/org/argeo/server/dao/AbstractMemoryDaoSupport.java index 39655d4fe..900b0d5b7 100644 --- a/server/runtime/org.argeo.server.core/src/main/java/org/argeo/server/dao/AbstractMemoryDaoSupport.java +++ b/server/runtime/org.argeo.server.core/src/main/java/org/argeo/server/dao/AbstractMemoryDaoSupport.java @@ -1,3 +1,18 @@ +/* + * Copyright (C) 2007-2012 Mathieu Baudier + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package org.argeo.server.dao; import java.beans.PropertyEditor; @@ -12,12 +27,11 @@ import java.util.TreeMap; import org.apache.commons.io.IOUtils; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; -import org.argeo.server.ArgeoServerException; +import org.argeo.ArgeoException; import org.springframework.beans.BeanWrapper; import org.springframework.beans.BeanWrapperImpl; import org.springframework.beans.BeansException; import org.springframework.beans.factory.InitializingBean; -import org.springframework.beans.factory.generic.GenericBeanFactoryAccessor; import org.springframework.context.ApplicationContext; import org.springframework.context.ApplicationContextAware; import org.springframework.core.io.Resource; @@ -37,7 +51,7 @@ public abstract class AbstractMemoryDaoSupport implements LightDaoSupport, private List scannedPackages = new ArrayList(); - private List workbooks = new ArrayList(); + private List resources = new ArrayList(); private Map, PropertyEditor> customEditors = new HashMap, PropertyEditor>();; @@ -50,19 +64,21 @@ public abstract class AbstractMemoryDaoSupport implements LightDaoSupport, } public void init() { - // used to resolve inner references - // Map> tempRefs = new HashMap>(); + for (PropertyEditor propertyEditor : customEditors.values()) + if (propertyEditor instanceof LightDaoAware) { + ((LightDaoAware) propertyEditor).setLightDaoSupport(this); + } + // Load data List references = new ArrayList(); - for (Resource res : workbooks) { + for (Resource res : resources) { InputStream in = null; try { in = res.getInputStream(); load(in, references); } catch (Exception e) { - throw new ArgeoServerException("Cannot load stream", e); + throw new ArgeoException("Cannot load stream", e); } finally { IOUtils.closeQuietly(in); } @@ -112,6 +128,8 @@ public abstract class AbstractMemoryDaoSupport implements LightDaoSupport, @SuppressWarnings("unchecked") public T getByKey(Class clss, Object key) { + if (key == null) + throw new ArgeoException("Key is null for " + clss); return (T) model.get(findClass(clss)).get(key); } @@ -141,8 +159,7 @@ public abstract class AbstractMemoryDaoSupport implements LightDaoSupport, res.addAll((Collection) model.get(classToUse).values()); if (applicationContext != null) - res.addAll(new GenericBeanFactoryAccessor(applicationContext) - .getBeansOfType(clss).values()); + res.addAll(applicationContext.getBeansOfType(clss).values()); return res; } @@ -196,12 +213,12 @@ public abstract class AbstractMemoryDaoSupport implements LightDaoSupport, return scannedPackages; } - public void setWorkbooks(List workbooks) { - this.workbooks = workbooks; + public void setResources(List workbooks) { + this.resources = workbooks; } - public List getWorkbooks() { - return workbooks; + public List getResources() { + return resources; } public void setClassLoader(ClassLoader classLoader) {