View Javadoc
1   package org.codehaus.plexus.personality.plexus.lifecycle.phase;
2   
3   /*
4    * Copyright 2001-2007 Codehaus Foundation.
5    *
6    * Licensed under the Apache License, Version 2.0 (the "License");
7    * you may not use this file except in compliance with the License.
8    * You may obtain a copy of the License at
9    *
10   *      http://www.apache.org/licenses/LICENSE-2.0
11   *
12   * Unless required by applicable law or agreed to in writing, software
13   * distributed under the License is distributed on an "AS IS" BASIS,
14   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15   * See the License for the specific language governing permissions and
16   * limitations under the License.
17   */
18  
19  import org.codehaus.plexus.classworlds.realm.ClassRealm;
20  import org.codehaus.plexus.component.manager.ComponentManager;
21  import org.codehaus.plexus.lifecycle.phase.AbstractPhase;
22  import org.codehaus.plexus.logging.LogEnabled;
23  import org.codehaus.plexus.logging.Logger;
24  import org.codehaus.plexus.logging.LoggerManager;
25  
26  public class LogEnablePhase
27      extends AbstractPhase
28  {
29      public void execute( Object object, ComponentManager componentManager, ClassRealm lookupRealm )
30          throws PhaseExecutionException
31      {
32          if ( object instanceof LogEnabled )
33          {
34              LogEnabled logEnabled = (LogEnabled) object;
35  
36              LoggerManager loggerManager = componentManager.getContainer().getLoggerManager();
37  
38              Logger logger = loggerManager.getLoggerForComponent( componentManager.getRole(), componentManager.getRoleHint() );
39  
40              logEnabled.enableLogging( logger );
41          }
42      }
43  }