Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
 /*
  * Copyright 2011 SpringSource
  *
  * 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.codehaus.groovy.grails.compiler.logging;
Adds a log method to all artifacts.

Author(s):
Graeme Rocher
Since:
2.0
public class LoggingTransformer implements AllArtefactClassInjector{
    public static final String LOG_PROPERTY = "log";
    private static final String FILTERS_ARTEFACT_TYPE_SUFFIX = "Filters";
    public static final String CONF_DIR = "conf";
    public static final String FILTERS_ARTEFACT_TYPE = "filters";
    public void performInjection(SourceUnit sourceGeneratorContext contextClassNode classNode) {
        final FieldNode existingField = classNode.getDeclaredField();
        if (existingField == null && !classNode.isInterface()) {
            final String path = source.getName();
            String artefactType = path != null ? GrailsResourceUtils.getArtefactDirectory(path) : null;
            // little bit of a hack, since filters aren't kept in a grails-app/filters directory as they probably should be
            if (artefactType != null && .equals(artefactType) && classNode.getName().endsWith()) {
                artefactType = ;
            }
            String logName = artefactType == null ? classNode.getName() : "grails.app." + artefactType + "." + classNode.getName();
            addLogField(classNodelogName);
        }
    }
    public static void addLogField(ClassNode classNodeString logName) {
        FieldNode logVariable = new FieldNode(,
                                              . | .,
                                              new ClassNode(Log.class),
                                              classNode,
                                              new MethodCallExpression(new ClassExpression(new ClassNode(LogFactory.class)), "getLog"new ArgumentListExpression(new ConstantExpression(logName))));
        classNode.addField(logVariable);
    }
    public void performInjection(SourceUnit sourceClassNode classNode) {
        performInjection(sourcenullclassNode);
    }
    @Override
    public void performInjectionOnAnnotatedClass(SourceUnit sourceClassNode classNode) {
        performInjection(sourcenullclassNode);
    }
    public boolean shouldInject(URL url) {
        return true// Add log property to all artifact types
    }
New to GrepCode? Check out our FAQ X