DefaultLogManager.java
01 /*
02  * Copyright 2012-2013 the original author or authors.
03  *
04  * Licensed under the Apache License, Version 2.0 (the "License");
05  * you may not use this file except in compliance with the License.
06  * You may obtain a copy of the License at
07  *
08  *      http://www.apache.org/licenses/LICENSE-2.0
09  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package org.codehaus.griffon.runtime.logging;
18 
19 import griffon.core.ApplicationHandler;
20 import griffon.core.GriffonApplication;
21 import griffon.util.logging.LogManager;
22 import groovy.lang.Closure;
23 import groovy.util.ConfigObject;
24 
25 /**
26  @author Andres Almiray
27  @since 1.2.0
28  */
29 public class DefaultLogManager implements LogManager, ApplicationHandler {
30     private final GriffonApplication app;
31 
32     public DefaultLogManager(GriffonApplication app) {
33         this.app = app;
34     }
35 
36     public GriffonApplication getApp() {
37         return app;
38     }
39 
40     public void configure(ConfigObject config) {
41         Object log4jConfig = app.getConfig().get("log4j");
42         if (log4jConfig instanceof Closure) {
43             org.apache.log4j.LogManager.resetConfiguration();
44             new Log4jConfig().configure((Closurelog4jConfig);
45         }
46     }
47 }