All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.impalaframework.interactive.command.InteractiveCommandUtils Maven / Gradle / Ivy

There is a newer version: 1.0.3
Show newest version
/*
 * Copyright 2007-2010 the original author or authors.
 * 
 * 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.impalaframework.interactive.command;

import java.io.PrintWriter;
import java.io.StringWriter;

import org.impalaframework.command.framework.CommandPropertyValue;
import org.impalaframework.command.framework.GlobalCommandState;
import org.impalaframework.exception.NoServiceException;
import org.impalaframework.facade.Impala;
import org.impalaframework.module.RootModuleDefinition;
import org.impalaframework.util.MemoryUtils;
import org.springframework.util.Assert;
import org.springframework.util.StopWatch;

public class InteractiveCommandUtils {
    
    public static void printException(Throwable e) {
        StringWriter stringWriter = new StringWriter();
        PrintWriter printWriter = new PrintWriter(stringWriter);
        e.printStackTrace(printWriter);
        System.out.println(stringWriter.toString());
    }

    public static void printReloadInfo(String suppliedName, String actualName, StopWatch watch) {
        if (actualName != null) {
            System.out.println("Module '" + actualName + "' loaded in " + watch.getTotalTimeSeconds() + " seconds");
            System.out.println(MemoryUtils.getMemoryInfo());
        }
        else {
            System.out.println("No module found which matches the text '" + suppliedName + "'");
        }
    }   
    
    public static void printExecutionInfo(StopWatch watch) {
        System.out.println("Operation executed in " + watch.getTotalTimeSeconds() + " seconds");
        System.out.println(MemoryUtils.getMemoryInfo());
    }
    
    public static boolean isRootProject(String directoryName) {
        Assert.notNull(directoryName);
        String rootProject = getRootProject();
        
        return directoryName.equals(rootProject);
    }

    static String getRootProject() {
        
        RootModuleDefinition md;
        try {
            md = Impala.getRootModuleDefinition();
            return (md != null ? md.getName() : null);
        } catch (NoServiceException e) {
            CommandPropertyValue property = GlobalCommandState.getInstance().getProperty(CommandStateConstants.DEBUG_MODE);
            if (property != null && "true".equalsIgnoreCase(property.getValue())) {
                e.printStackTrace();
            }
        }       
        return null;
    
    }
    
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy