# Copyright 2012-2023 The Meson development team # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # https://www.apache.org/licenses/LICENSE-2.0 # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # Core public classes for linkers. from __future__ import annotations import enum import typing as T if T.TYPE_CHECKING: from ..environment import Environment @enum.unique class RSPFileSyntax(enum.Enum): """Which RSP file syntax the compiler supports.""" MSVC = enum.auto() GCC = enum.auto() class ArLikeLinker: # POSIX requires supporting the dash, GNU permits omitting it std_args = ['-csr'] def can_linker_accept_rsp(self) -> bool: # armar / AIX can't accept arguments using the @rsp syntax # in fact, only the 'ar' id can return False def get_std_link_args(self, env: 'Environment', is_thin: bool) -> T.List[str]: return self.std_args def get_output_args(self, target: str) -> T.List[str]: return [target] def rsp_file_syntax(self) -> RSPFileSyntax: return RSPFileSyntax.GCC