]> git.proxmox.com Git - mirror_edk2.git/blame - Tools/Source/Cpptasks/net/sf/antcontrib/cpptasks/compiler/CompilerConfiguration.java
Changed spelling to manifest
[mirror_edk2.git] / Tools / Source / Cpptasks / net / sf / antcontrib / cpptasks / compiler / CompilerConfiguration.java
CommitLineData
878ddf1f 1/*\r
2 * \r
3 * Copyright 2002-2004 The Ant-Contrib project\r
4 *\r
5 * Licensed under the Apache License, Version 2.0 (the "License");\r
6 * you may not use this file except in compliance with the License.\r
7 * You may obtain a copy of the License at\r
8 *\r
9 * http://www.apache.org/licenses/LICENSE-2.0\r
10 *\r
11 * Unless required by applicable law or agreed to in writing, software\r
12 * distributed under the License is distributed on an "AS IS" BASIS,\r
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
14 * See the License for the specific language governing permissions and\r
15 * limitations under the License.\r
16 */\r
17package net.sf.antcontrib.cpptasks.compiler;\r
18import java.io.File;\r
19\r
20import net.sf.antcontrib.cpptasks.CCTask;\r
21import net.sf.antcontrib.cpptasks.CompilerParam;\r
22import net.sf.antcontrib.cpptasks.DependencyInfo;\r
23\r
24import org.apache.tools.ant.BuildException;\r
25/**\r
26 * A configuration for a compiler\r
27 * \r
28 * @author Curt Arnold\r
29 */\r
30public interface CompilerConfiguration extends ProcessorConfiguration {\r
31 void compile(CCTask task, File outputDir, String[] sourceFiles,\r
32 boolean relentless, ProgressMonitor monitor) throws BuildException;\r
33 /**\r
34 * \r
35 * This method may be used to get two distinct compiler configurations, one\r
36 * for compiling the specified file and producing a precompiled header\r
37 * file, and a second for compiling other files using the precompiled\r
38 * header file.\r
39 * \r
40 * The last (preferrably only) include directive in the prototype file will\r
41 * be used to mark the boundary between pre-compiled and normally compiled\r
42 * headers.\r
43 * \r
44 * @param prototype\r
45 * A source file (for example, stdafx.cpp) that is used to build\r
46 * the precompiled header file. @returns null if precompiled\r
47 * headers are not supported or a two element array containing\r
48 * the precompiled header generation configuration and the\r
49 * consuming configuration\r
50 * \r
51 */\r
52 CompilerConfiguration[] createPrecompileConfigurations(File prototype,\r
53 String[] nonPrecompiledFiles);\r
54 /**\r
55 * Returns an digest for the include path for the configuration.\r
56 * \r
57 * This is used to determine if cached dependency information is invalid\r
58 * because the include paths have changed\r
59 */\r
60 String getIncludePathIdentifier();\r
61 public CompilerParam getParam(String name);\r
62 boolean isPrecompileGeneration();\r
63 DependencyInfo parseIncludes(CCTask task, File baseDir, File source);\r
64}\r