View Javadoc

1   /*
2    * #%L
3    * Native ARchive plugin for Maven
4    * %%
5    * Copyright (C) 2002 - 2014 NAR Maven Plugin developers.
6    * %%
7    * Licensed under the Apache License, Version 2.0 (the "License");
8    * you may not use this file except in compliance with the License.
9    * You may obtain a copy of the License at
10   * 
11   * http://www.apache.org/licenses/LICENSE-2.0
12   * 
13   * Unless required by applicable law or agreed to in writing, software
14   * distributed under the License is distributed on an "AS IS" BASIS,
15   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16   * See the License for the specific language governing permissions and
17   * limitations under the License.
18   * #L%
19   */
20  package com.github.maven_nar.cpptasks.gcc.cross.sparc_sun_solaris2;
21  
22  import com.github.maven_nar.cpptasks.compiler.LinkType;
23  import com.github.maven_nar.cpptasks.compiler.Linker;
24  import com.github.maven_nar.cpptasks.gcc.AbstractArLibrarian;
25  
26  /**
27   * Adapter for the 'ar' archiver
28   *
29   * @author Adam Murdoch
30   */
31  public final class GccLibrarian extends AbstractArLibrarian {
32    private static String[] objFileExtensions = new String[] {
33      ".o"
34    };
35    private static GccLibrarian instance = new GccLibrarian(GccCCompiler.CMD_PREFIX + "ar", objFileExtensions, false,
36        new GccLibrarian(GccCCompiler.CMD_PREFIX + "ar", objFileExtensions, true, null));
37  
38    public static GccLibrarian getInstance() {
39      return instance;
40    }
41  
42    private GccLibrarian(final String command, final String[] inputExtensions, final boolean isLibtool,
43        final GccLibrarian libtoolLibrarian) {
44      super(command, "V", inputExtensions, new String[0], "lib", ".a", isLibtool, libtoolLibrarian);
45    }
46  
47    @Override
48    public Linker getLinker(final LinkType type) {
49      return GccLinker.getInstance().getLinker(type);
50    }
51  }