]>
Commit | Line | Data |
---|---|---|
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 | |
17 | package net.sf.antcontrib.cpptasks.compiler;\r | |
18 | import java.io.File;\r | |
19 | \r | |
20 | import net.sf.antcontrib.cpptasks.CCTask;\r | |
21 | import net.sf.antcontrib.cpptasks.CompilerParam;\r | |
22 | import net.sf.antcontrib.cpptasks.DependencyInfo;\r | |
23 | \r | |
24 | import org.apache.tools.ant.BuildException;\r | |
25 | /**\r | |
26 | * A configuration for a compiler\r | |
27 | * \r | |
28 | * @author Curt Arnold\r | |
29 | */\r | |
30 | public 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 |