forked from Ericsson/codechecker
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[feat] Implicit include paths added with -idirafter
GCC has implicit include paths that are forwarded to Clang. Until now these paths were added with -isystem flag, but sometimes the priority of this is too high: https://gcc.gnu.org/onlinedocs/gcc/Directory-Options.html The implicit include paths should be searched the last, so -isystem has been changed to -idirafter. In case of potential backward compatibility break --add-gcc-include-dirs-with-isystem has been introduced for "CodeChecker analyze" command.
- Loading branch information
Showing
11 changed files
with
172 additions
and
26 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
# ------------------------------------------------------------------------- | ||
# | ||
# Part of the CodeChecker project, under the Apache License v2.0 with | ||
# LLVM Exceptions. See LICENSE for license information. | ||
# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | ||
# | ||
# ------------------------------------------------------------------------- | ||
|
||
import argparse | ||
from codechecker_analyzer.cmd import analyze | ||
|
||
|
||
class NoExitArgumentParser(argparse.ArgumentParser): | ||
""" | ||
ArgumentParser that does not exit on error. | ||
""" | ||
def error(self, _): | ||
pass | ||
|
||
|
||
def create_analyze_argparse(args=None): | ||
""" | ||
Create argparse object for analyze command. | ||
:param args: list of command line arguments to parse. | ||
""" | ||
if args is None: | ||
args = [] | ||
|
||
parser = NoExitArgumentParser() | ||
analyze.add_arguments_to_parser(parser) | ||
|
||
return parser.parse_args(args) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,65 @@ | ||
# ------------------------------------------------------------------------- | ||
# | ||
# Part of the CodeChecker project, under the Apache License v2.0 with | ||
# LLVM Exceptions. See LICENSE for license information. | ||
# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | ||
# | ||
# ------------------------------------------------------------------------- | ||
|
||
import argparse | ||
import unittest | ||
from codechecker_analyzer.analyzers.clangsa.analyzer import ClangSA | ||
from codechecker_analyzer.buildlog import log_parser | ||
from codechecker_analyzer.cmd import analyze | ||
from libtest.cmd_line import create_analyze_argparse | ||
|
||
|
||
def create_analyzer_sa(args=None): | ||
parser = argparse.ArgumentParser() | ||
analyze.add_arguments_to_parser(parser) | ||
cfg_handler = ClangSA.construct_config_handler( | ||
create_analyze_argparse(args)) | ||
|
||
action = { | ||
'file': 'main.cpp', | ||
'command': "g++ -o main main.cpp", | ||
'directory': '/'} | ||
build_action = log_parser.parse_options(action) | ||
|
||
return ClangSA(cfg_handler, build_action) | ||
|
||
|
||
def create_result_handler(analyzer): | ||
""" | ||
Create result handler for construct_analyzer_cmd call. | ||
""" | ||
|
||
build_action = analyzer.buildaction | ||
|
||
rh = analyzer.construct_result_handler( | ||
build_action, | ||
build_action.directory, | ||
None) | ||
|
||
rh.analyzed_source_file = build_action.source | ||
|
||
return rh | ||
|
||
|
||
class AnalyzerCommandClangSATest(unittest.TestCase): | ||
def test_isystem_idirafter(self): | ||
""" | ||
Test that the implicit include paths are added to the analyzer command | ||
with -idirafter. | ||
""" | ||
analyzer = create_analyzer_sa(['--add-gcc-include-dirs-with-isystem']) | ||
|
||
result_handler = create_result_handler(analyzer) | ||
cmd = analyzer.construct_analyzer_cmd(result_handler) | ||
self.assertIn('-isystem', cmd) | ||
|
||
analyzer = create_analyzer_sa() | ||
|
||
result_handler = create_result_handler(analyzer) | ||
cmd = analyzer.construct_analyzer_cmd(result_handler) | ||
self.assertIn('-idirafter', cmd) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters