mirror of
https://github.com/apache/impala.git
synced 2026-01-01 09:00:42 -05:00
This patch adds a script bin/cppclean.sh that runs cppclean over the BE code and writes the output to stdout. cppclean is a tool for detecting various issues with C++ code: https://github.com/myint/cppclean To simplify the above step this change also modifies CMakeLists.txt to allow dumping of all include paths to a file, like this: cmake -DDUMP_INCLUDE_PATHS=output_file.txt Change-Id: I5cd064344bdf47d77058fb570f034bb324308103 Reviewed-on: http://gerrit.cloudera.org:8080/3237 Reviewed-by: Alex Behm <alex.behm@cloudera.com> Tested-by: Alex Behm <alex.behm@cloudera.com>
43 lines
1.3 KiB
Bash
Executable File
43 lines
1.3 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# Copyright 2016 Cloudera Inc.
|
|
#
|
|
# 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
|
|
#
|
|
# http://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.
|
|
#
|
|
#
|
|
# Runs cppclean on the BE code and prints the results to stdout.
|
|
#
|
|
# cppclean is a tool for detecting various issues with C++ code.
|
|
# https://github.com/myint/cppclean
|
|
#
|
|
# Requires cppclean:
|
|
# sudo pip install cppclean
|
|
|
|
. $IMPALA_HOME/bin/impala-config.sh &> /dev/null
|
|
|
|
# Use CMake to dump the BE include paths.
|
|
INCLUDE_PATHS_FILE="/tmp/be_include_paths.txt"
|
|
pushd $IMPALA_HOME
|
|
cmake -DDUMP_INCLUDE_PATHS=$INCLUDE_PATHS_FILE &> /dev/null
|
|
popd
|
|
|
|
# Generate include path arguments for cppclean.
|
|
INCLUDE_PATH_ARGS=" --include-path=$IMPALA_HOME/be/src"
|
|
INCLUDE_PATH_ARGS+=" --include-path=$IMPALA_HOME/be/generated-sources"
|
|
for dir in $(cat $INCLUDE_PATHS_FILE)
|
|
do
|
|
INCLUDE_PATH_ARGS+=" --include-path=$dir"
|
|
done
|
|
|
|
cppclean ${INCLUDE_PATH_ARGS} $@ $IMPALA_HOME/be
|