Skip to content

Commit bbefa73

Browse files
committed
selfcheck.sh: also run with system includes made available
1 parent 435a74c commit bbefa73

3 files changed

Lines changed: 48 additions & 3 deletions

File tree

.github/workflows/CI-unixish.yml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@ jobs:
77

88
strategy:
99
matrix:
10+
# TODO: do not run g++ on macos-* as it is just an alias for clang++
1011
compiler: [clang++, g++]
1112
os: [ubuntu-22.04, ubuntu-24.04, macos-13, macos-14, macos-15]
1213
fail-fast: false

Makefile

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,7 @@ test: testrunner simplecpp
1616
python3 -m pytest integration_test.py -vv
1717

1818
selfcheck: simplecpp
19-
./selfcheck.sh
19+
CXX=$(CXX) ./selfcheck.sh
2020

2121
simplecpp: main.o simplecpp.o
2222
$(CXX) $(LDFLAGS) main.o simplecpp.o -o simplecpp

selfcheck.sh

Lines changed: 46 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -4,8 +4,52 @@ output=$(./simplecpp simplecpp.cpp -e -f 2>&1)
44
ec=$?
55
errors=$(echo "$output" | grep -v 'Header not found: <')
66
if [ $ec -ne 0 ]; then
7-
# only fail if got errors which do not refer to missing system includes
7+
# only fail if we got errors which do not refer to missing system includes
88
if [ ! -z "$errors" ]; then
99
exit $ec
1010
fi
11-
fi
11+
fi
12+
13+
if [ -z "$CXX" ]; then
14+
exit 0
15+
fi
16+
17+
cxx_type=$($CXX --version | head -1 | cut -d' ' -f1)
18+
if [ "$cxx_type" = "Ubuntu" ]; then
19+
cxx_type=$($CXX --version | head -1 | cut -d' ' -f2)
20+
fi
21+
if [ "$cxx_type" = "g++" ]; then
22+
gcc_ver=$($CXX -dumpversion)
23+
./simplecpp simplecpp.cpp -e -f -std=gnu++11 -D__GNUC__ -D__STDC__ -D__STDC_HOSTED__ -D__CHAR_BIT__=8 -I"/usr/include" -I"/usr/include/linux" -I"/usr/include/c++/$gcc_ver" -I"/usr/include/x86_64-linux-gnu/c++/$gcc_ver"
24+
ec=$?
25+
if [ $ec -ne 0 ]; then
26+
exit $ec
27+
fi
28+
elif [ "$cxx_type" = "clang" ]; then
29+
clang_ver=$($CXX -dumpversion)
30+
clang_ver=${clang_ver%%.*}
31+
find /usr/include -name stubs-32.h
32+
cxx_inc="/usr/include/c++/v1"
33+
if [ ! -d "$cxx_inc" ]; then
34+
cxx_inc="/usr/lib/llvm-$clang_ver/include/c++/v1"
35+
fi
36+
./simplecpp simplecpp.cpp -e -f -std=gnu++11 -D__BYTE_ORDER__ -D__linux__ -I"$cxx_inc" -I"/usr/include" -I"/usr/include/x86_64-linux-gnu"
37+
ec=$?
38+
if [ $ec -ne 0 ]; then
39+
exit $ec
40+
fi
41+
elif [ "$cxx_type" = "Apple" ]; then
42+
find /Applications -name endian.h
43+
xcode_path="/Applications/Xcode_16.4.app"
44+
if [ ! -d "$xcode_path" ]; then
45+
xcode_path="/Applications/Xcode_15.2.app"
46+
fi
47+
./simplecpp simplecpp.cpp -e -f -std=gnu++11 -D__BYTE_ORDER__ -D__APPLE__ -I"$xcode_path/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include" -I"$xcode_path/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include/c++/v1"
48+
ec=$?
49+
if [ $ec -ne 0 ]; then
50+
exit $ec
51+
fi
52+
else
53+
echo "unknown compiler '$cxx_type'"
54+
exit 1
55+
fi

0 commit comments

Comments
 (0)