]> git.proxmox.com Git - mirror_edk2.git/blame - Tools/Source/Cpptasks/net/sf/antcontrib/cpptasks/compiler/Linker.java
Initial import.
[mirror_edk2.git] / Tools / Source / Cpptasks / net / sf / antcontrib / cpptasks / compiler / Linker.java
CommitLineData
878ddf1f 1/*\r
2 * \r
3 * Copyright 2001-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
19import net.sf.antcontrib.cpptasks.types.LibraryTypeEnum;\r
20/**\r
21 * A linker for executables, and static and dynamic libraries.\r
22 * \r
23 * @author Adam Murdoch\r
24 */\r
25public interface Linker extends Processor {\r
26 /**\r
27 * Extracts the significant part of a library name to ensure there aren't\r
28 * collisions\r
29 */\r
30 String getLibraryKey(File libname);\r
31 /**\r
32 * returns the library path for the linker\r
33 */\r
34 File[] getLibraryPath();\r
35 /**\r
36 * Returns a set of filename patterns corresponding to library names.\r
37 * \r
38 * For example, "advapi32" would be expanded to "advapi32.dll" by\r
39 * DevStudioLinker and to "libadvapi32.a" and "libadvapi32.so" by\r
40 * GccLinker.\r
41 * \r
42 * @param libnames\r
43 * array of library names\r
44 */\r
45 String[] getLibraryPatterns(String[] libnames, LibraryTypeEnum libraryType);\r
46 /**\r
47 * Gets the linker for the specified link type.\r
48 * \r
49 * @return appropriate linker or null, will return this if this linker can\r
50 * handle the specified link type\r
51 */\r
52 Linker getLinker(LinkType linkType);\r
53 /**\r
54 * Returns true if the linker is case-sensitive\r
55 */\r
56 boolean isCaseSensitive();\r
57}\r