blob: 110f7eded5ace3c18694b42c70c9a219ca2d6ce2 [file] [log] [blame]
/*
* Copyright 2000-2009 JetBrains s.r.o.
*
* 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.
*/
/*
* User: anna
* Date: 27-Dec-2007
*/
package com.intellij.openapi.roots;
import com.intellij.openapi.module.Module;
import com.intellij.openapi.vfs.VirtualFile;
import com.intellij.openapi.vfs.pointers.VirtualFilePointer;
import org.jetbrains.annotations.NonNls;
import org.jetbrains.annotations.Nullable;
public abstract class CompilerModuleExtension extends ModuleExtension {
@NonNls public static final String PRODUCTION = "production";
@NonNls public static final String TEST = "test";
public static @Nullable CompilerModuleExtension getInstance(final Module module) {
return ModuleRootManager.getInstance(module).getModuleExtension(CompilerModuleExtension.class);
}
/**
* Returns a compiler output path for production sources of the module, if it is valid.
*
* @return the compile output path, or null if one is not valid.
*/
@Nullable
public abstract VirtualFile getCompilerOutputPath();
public abstract void setCompilerOutputPath(VirtualFile file);
/**
* Returns a compiler output path url for production sources of the module.
*
* @return the compiler output path URL, or null if it has never been set.
*/
@Nullable
public abstract String getCompilerOutputUrl();
public abstract void setCompilerOutputPath(String url);
/**
* Returns a compiler output path for test sources of the module, if it is valid.
*
* @return the compile output path for the test sources, or null if one is not valid.
*/
@Nullable
public abstract VirtualFile getCompilerOutputPathForTests();
public abstract void setCompilerOutputPathForTests(VirtualFile file);
/**
* Returns a compiler output path url for test sources of the module.
*
* @return the compiler output path URL, or null if it has never been set.
*/
@Nullable
public abstract String getCompilerOutputUrlForTests();
public abstract void setCompilerOutputPathForTests(String url);
/**
* Makes this module inheriting compiler output from its project
* @param inherit wether or not compiler output is inherited
*/
public abstract void inheritCompilerOutputPath(boolean inherit);
/**
* Returns <code>true</code> if compiler output for this module is inherited from a project
* @return true if compiler output path is inherited, false otherwise
*/
public abstract boolean isCompilerOutputPathInherited();
public abstract VirtualFilePointer getCompilerOutputPointer();
public abstract VirtualFilePointer getCompilerOutputForTestsPointer();
public abstract void setExcludeOutput(boolean exclude);
public abstract boolean isExcludeOutput();
public abstract VirtualFile[] getOutputRoots(boolean includeTests);
public abstract String[] getOutputRootUrls(boolean includeTests);
}