Package grails.build.logging

Source Code of grails.build.logging.GrailsEclipseConsole

/*
* 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 grails.build.logging;

import java.io.IOException;
import java.io.OutputStream;

import jline.Terminal;
import jline.UnsupportedTerminal;

/**
* This class is meant to keep changes made in support of Eclipse separate from
* the standard GrailsConsole implementation.
* <p>
* It is activated by setting system property "grails.console.class" to the
* fully qualified name of this class.
* <p>
* Having the changes in a class triggered by system property also leaves open
* the option to have Eclipse provide a different version of the class at
* runtime, to allow for further customisation to support not yet
* anticipated needs.
*
* @author Kris De Volder
*
* @since 2.0.0.M2
*/
public class GrailsEclipseConsole extends GrailsConsole {

    private static final boolean DEBUG = boolProp("grails.console.eclipse.debug");
    private static final String ECLIPSE_SUPPORTS_ANSI_PROP = "grails.console.eclipse.ansi";

    private Boolean eclipseSupportsAnsi = null; //lazy initialized because implicitly used from super constructor.

    /**
     * Create a GrailsConsole that has some customizations to work better with STS. Note that
     * this console implicitly captures and redirects System.out, System.err and System.in in the
     * super class. So extreme care must be taken to ensure these streams are setup correctly
     * before creating an instance.
     */
    public GrailsEclipseConsole() throws IOException {
        super();
    }

    @Override
    protected OutputStream ansiWrap(OutputStream out) {
        if (DEBUG) {
            try {
                out.write(("<<<"+ECLIPSE_SUPPORTS_ANSI_PROP+":"+eclipseSupportsAnsi()+">>>\n").getBytes("UTF-8"));
            } catch (IOException e) {
            }
        }
        //This method is called from the super constructor so eclipseSupportsAnsi field
        //must be lazy initialised (it can't be initialised before we get called!)
        if (eclipseSupportsAnsi()) {
            return out; // expose unfiltered output to eclipse
        }
        return super.ansiWrap(out);
    }

    private boolean eclipseSupportsAnsi() {
        if (eclipseSupportsAnsi == null) {
            eclipseSupportsAnsi = boolProp(ECLIPSE_SUPPORTS_ANSI_PROP);
        }
        return eclipseSupportsAnsi;
    }

    private static Boolean boolProp(String propName) {
        try {
            String prop =  System.getProperty(propName);
            return prop != null && Boolean.valueOf(prop);
        } catch (Exception e) {
            return false;
        }
    }

    @Override
    protected Terminal createTerminal() {
        // unix or windows terminal have no relation at all to the behavior of an Eclipse console.
        return new UnsupportedTerminal();
    }
}
TOP

Related Classes of grails.build.logging.GrailsEclipseConsole

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.