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.component.repository.ComponentDescriptor;
22  import org.codehaus.plexus.lifecycle.phase.AbstractPhase;
23  import org.codehaus.plexus.logging.LogEnabled;
24  import org.codehaus.plexus.logging.Logger;
25  import org.codehaus.plexus.logging.LoggerManager;
26  
27  public class LogEnablePhase
28      extends AbstractPhase
29  {
30      public void execute( Object object, ComponentManager componentManager, ClassRealm lookupRealm )
31          throws PhaseExecutionException
32      {
33          if ( object instanceof LogEnabled )
34          {
35              LogEnabled logEnabled = (LogEnabled) object;
36  
37              LoggerManager loggerManager = componentManager.getContainer().getLoggerManager();
38  
39              Logger logger = loggerManager.getLoggerForComponent( componentManager.getRole(), componentManager.getRoleHint() );
40  
41              logEnabled.enableLogging( logger );
42          }
43      }
44  }