1 /*** 2 * Copyright (C) 2006 Philipp Mpalampanis 3 * 4 * License: MPL 1.1/GPL 2.0/LGPL 2.1 5 * 6 * The contents of this file are subject to the Mozilla Public License Version 7 * 1.1 (the "License"); you may not use this file except in compliance with 8 * the License. You may obtain a copy of the License at 9 * http://www.mozilla.org/MPL/ 10 * 11 * Software distributed under the License is distributed on an "AS IS" basis, 12 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License 13 * for the specific language governing rights and limitations under the 14 * License. 15 * 16 * Alternatively, the contents of this file may be used under the terms of 17 * either the GNU General Public License Version 2 or later (the "GPL"), or 18 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), 19 * in which case the provisions of the GPL or the LGPL are applicable instead 20 * of those above. If you wish to allow use of your version of this file only 21 * under the terms of either the GPL or the LGPL, and not to allow others to 22 * use your version of this file under the terms of the MPL, indicate your 23 * decision by deleting the provisions above and replace them with the notice 24 * and other provisions required by the GPL or the LGPL. If you do not delete 25 * the provisions above, a recipient may use your version of this file under 26 * the terms of any one of the MPL, the GPL or the LGPL. 27 */ 28 29 package net.sf.echobinding; 30 31 import java.util.Map; 32 33 import net.sf.echobinding.binding.BindingContext; 34 import net.sf.echobinding.binding.PropertyAdapter; 35 36 import org.apache.log4j.Logger; 37 38 /*** 39 * 40 */ 41 public abstract class ConfigurationSetup { 42 43 private static Logger _logger = Logger.getLogger( ConfigurationSetup.class ); 44 45 private static BindingConfiguration _configuration = new BindingConfiguration();; 46 47 /*** 48 * initializes the configuration 49 */ 50 public void initialize() { 51 _logger.info("loading binding configuration"); 52 configure(); 53 showConfiguration(); 54 } 55 56 /*** 57 * 58 */ 59 private void showConfiguration() { 60 Map<String, BindingContext> contexts = _configuration.getContexts(); 61 for(String contextName : contexts.keySet() ) { 62 String msg = "binding context '"+contextName+"' configured. "; 63 BindingContext context = contexts.get(contextName); 64 if(context.getPropertyAdapters() != null && context.getPropertyAdapters().size() > 0) { 65 msg+=" (property adapters: "; 66 for(PropertyAdapter binding : context.getPropertyAdapters()) { 67 msg+=binding.getId()+", "; 68 } 69 msg+=")"; 70 } 71 _logger.info(msg); 72 } 73 } 74 75 protected abstract void configure(); 76 77 78 /*** 79 * @return Returns the binding configuration. 80 */ 81 public static BindingConfiguration getConfiguration() { 82 return _configuration; 83 } 84 }