]>
Commit | Line | Data |
---|---|---|
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 | |
17 | package net.sf.antcontrib.cpptasks.compiler;\r | |
18 | import java.io.File;\r | |
19 | import 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 | |
25 | public 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 |