X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=org.argeo.slc.core%2Fsrc%2Forg%2Fargeo%2Fslc%2Fcore%2Fexecution%2Fdoc%2FConsoleContextDescriber.java;fp=org.argeo.slc.core%2Fsrc%2Forg%2Fargeo%2Fslc%2Fcore%2Fexecution%2Fdoc%2FConsoleContextDescriber.java;h=6504a3de39400b74a8e427f3ebaaaaef98f0b000;hb=a9b97cc33383ded70277f49aa287f84903334e70;hp=0000000000000000000000000000000000000000;hpb=d1298659fe6f179d1cbbc8c89f108a0bbc5b4edf;p=gpl%2Fargeo-slc.git diff --git a/org.argeo.slc.core/src/org/argeo/slc/core/execution/doc/ConsoleContextDescriber.java b/org.argeo.slc.core/src/org/argeo/slc/core/execution/doc/ConsoleContextDescriber.java new file mode 100644 index 000000000..6504a3de3 --- /dev/null +++ b/org.argeo.slc.core/src/org/argeo/slc/core/execution/doc/ConsoleContextDescriber.java @@ -0,0 +1,49 @@ +/* + * Copyright (C) 2007-2012 Argeo GmbH + * + * 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.slc.core.execution.doc; + +import org.springframework.beans.MutablePropertyValues; +import org.springframework.beans.PropertyValue; +import org.springframework.beans.factory.config.BeanDefinition; +import org.springframework.beans.factory.support.BeanDefinitionRegistry; + +public class ConsoleContextDescriber implements ContextDescriber { + public void describeContext(BeanDefinitionRegistry registry) { + String[] beanNames = registry.getBeanDefinitionNames(); + for (String beanName : beanNames) { + log("\n## BEAN: " + beanName); + describeBean(registry.getBeanDefinition(beanName)); + } + } + + public void describeBean(BeanDefinition beanDefinition) { + log("BeanDefinition class: "+beanDefinition.getClass()); + log("# ATTRIBUTES"); + for(String attr:beanDefinition.attributeNames()){ + log(attr+"="+beanDefinition.getAttribute(attr)); + } + log("# PROPERTIES"); + MutablePropertyValues pValues = beanDefinition.getPropertyValues(); + for (PropertyValue pv : pValues.getPropertyValues()) { + log(pv.getName() + "= (" + pv.getValue().getClass() + ") " + + pv.getValue()); + } + } + + protected void log(Object obj){ + System.out.println(obj); + } +}