Skip to content

Commit

Permalink
CI: add static analysis
Browse files Browse the repository at this point in the history
and fix some issues found
  • Loading branch information
black-sliver committed Nov 2, 2024
1 parent 499795d commit e04d509
Show file tree
Hide file tree
Showing 8 changed files with 140 additions and 38 deletions.
56 changes: 56 additions & 0 deletions .github/workflows/scan-build.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
name: Native Code Static Analysis

on:
push:
paths:
- '**.c'
- '**.cc'
- '**.cpp'
- '**.cxx'
- '**.h'
- '**.hh'
- '**.hpp'
- '.github/workflows/scan-build.yml'
pull_request:
paths:
- '**.c'
- '**.cc'
- '**.cpp'
- '**.cxx'
- '**.h'
- '**.hh'
- '**.hpp'
- '.github/workflows/scan-build.yml'

jobs:
scan-build:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4
with:
submodules: recursive
- name: Install dependencies (apt)
run: |
sudo apt-get update -y -qq
sudo apt-get install coreutils build-essential libsdl2-dev libsdl2-image-dev libsdl2-ttf-dev libgtest-dev
- name: Install newer Clang
run: |
wget https://apt.llvm.org/llvm.sh
chmod +x ./llvm.sh
sudo ./llvm.sh 18
- name: Install scan-build command
run: |
sudo apt install clang-tools-18
- name: scan-build
run: |
scan-build-18 --status-bugs -o scan-build-reports \
--exclude build --exclude lib/lua \
--exclude lib/miniz \
make -j3
- name: Store report
if: failure()
uses: actions/upload-artifact@v4
with:
name: scan-build-reports
path: scan-build-reports
81 changes: 52 additions & 29 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -117,9 +117,25 @@ WIN64_TEST_OBJ := $(patsubst %.cpp, $(WIN64_BUILD_DIR)/%.o, $(TEST_SRC))
WIN64_OBJ_DIRS := $(sort $(dir $(WIN64_OBJ)) $(dir $(WIN64_TEST_OBJ)))

# tools
CC = gcc # TODO: use ?=
CPP = g++ # TODO: use ?=
AR = ar # TODO: use ?=
CC ?= gcc
CXX ?= g++
AR ?= ar

ifeq ($(CC), cc)
CC = gcc
CPP = $(CC) -E
endif
ifeq ($(CXX), cpp)
CXX = g++
endif
ifeq ($(AR), ar)
AR = ar
endif

$(info using CC=${CC})
$(info using CPP=${CPP})
$(info using CXX=${CXX})
$(info using AR=${AR})

# cross tools
EMCC ?= emcc
Expand All @@ -137,29 +153,36 @@ WIN64STRIP = x86_64-w64-mingw32-strip
WIN64WINDRES = x86_64-w64-mingw32-windres

# tool config
#TODO: -fsanitize=address -fno-omit-frame-pointer ?
C_FLAGS = -Wall -std=c99 -D_REENTRANT
LUA_C_FLAGS = -Wall -D_REENTRANT # we actually use C++ for lua now
ifeq ($(CONF), DEBUG) # DEBUG
C_FLAGS += -Og -g -fno-omit-frame-pointer -fstack-protector-all -fno-common -ftrapv
LUA_C_FLAGS += -Og -g -fno-omit-frame-pointer -fstack-protector-all -fno-common -DLUA_USE_APICHECK -DLUAI_ASSERT -ftrapv
ifdef IS_LLVM # DEBUG with LLVM
CPP_FLAGS = -Wall -Wnon-virtual-dtor -Wno-unused-function -Wno-deprecated-declarations -fstack-protector-all -g -Og -ffunction-sections -fdata-sections -pthread -fno-omit-frame-pointer
LD_FLAGS = -Wl,-dead_strip -fstack-protector-all -pthread -fno-omit-frame-pointer
else # DEBUG with GCC
CPP_FLAGS = -Wall -Wnon-virtual-dtor -Wno-unused-function -Wno-deprecated-declarations -fstack-protector-all -g -Og -ffunction-sections -fdata-sections -pthread -fno-omit-frame-pointer
LD_FLAGS = -Wl,--gc-sections -fstack-protector-all -pthread -fno-omit-frame-pointer
endif
else
C_FLAGS += -O2 -fno-stack-protector -fno-common
LUA_CFALGS += -O2 -fno-stack-protector -fno-common
ifdef IS_LLVM # RELEASE or DIST with LLVM
CPP_FLAGS = -Wno-deprecated-declarations -O2 -ffunction-sections -fdata-sections -DNDEBUG -flto -pthread -g
LD_FLAGS = -Wl,-dead_strip -O2 -flto
else # RELEASE or DIST with GCC
CPP_FLAGS = -Wno-deprecated-declarations -O2 -s -ffunction-sections -fdata-sections -DNDEBUG -flto=8 -pthread
LD_FLAGS = -Wl,--gc-sections -O2 -s -flto=8 -pthread
endif
C_FLAGS += -Og -g -fno-omit-frame-pointer -fstack-protector-all -fno-common -ftrapv
LUA_C_FLAGS += -Og -g -fno-omit-frame-pointer -fstack-protector-all -fno-common -DLUA_USE_APICHECK -DLUAI_ASSERT -ftrapv
ifdef IS_LLVM # DEBUG with LLVM
CPP_FLAGS = -Wall -Wnon-virtual-dtor -Wno-unused-function -Wno-deprecated-declarations -fstack-protector-all -g -Og -ffunction-sections -fdata-sections -pthread -fno-omit-frame-pointer
LD_FLAGS = -Wl,-dead_strip -fstack-protector-all -pthread -fno-omit-frame-pointer
ifdef IS_LINUX # clang calls regular LD on linux
LD_FLAGS = -Wl,--gc-sections -fstack-protector-all -pthread -fno-omit-frame-pointer
endif
else # DEBUG with GCC
CPP_FLAGS = -Wall -Wnon-virtual-dtor -Wno-unused-function -Wno-deprecated-declarations -fstack-protector-all -g -Og -ffunction-sections -fdata-sections -pthread -fno-omit-frame-pointer
LD_FLAGS = -Wl,--gc-sections -fstack-protector-all -pthread -fno-omit-frame-pointer
endif
#CPP_FLAGS += -fsanitize=address
#LD_FLAGS += -fsanitize=address
else # RELEASE or DIST
C_FLAGS += -O2 -fno-stack-protector -fno-common
LUA_CFALGS += -O2 -fno-stack-protector -fno-common
ifdef IS_LLVM # RELEASE or DIST with LLVM
CPP_FLAGS = -Wno-deprecated-declarations -O2 -ffunction-sections -fdata-sections -DNDEBUG -flto -pthread -g
LD_FLAGS = -Wl,-dead_strip -O2 -flto
ifdef IS_LINUX # clang calls regular LD on linux
LD_FLAGS = -Wl,--gc-sections -O2 -s -flto=8 -pthread
endif
else # RELEASE or DIST with GCC
CPP_FLAGS = -Wno-deprecated-declarations -O2 -s -ffunction-sections -fdata-sections -DNDEBUG -flto=8 -pthread
LD_FLAGS = -Wl,--gc-sections -O2 -s -flto=8 -pthread
endif
endif

CPP_FLAGS += -DLUA_CPP
Expand Down Expand Up @@ -209,7 +232,7 @@ ifdef IS_WIN32
EXE = $(WIN32_EXE)
TEST_EXE = $(WIN32_TEST_EXE)
WIN32CC = $(CC)
WIN32CPP = $(CPP)
WIN32CPP = $(CXX)
WIN32AR = $(AR)
WIN32STRIP = strip
WIN32WINDRES = windres
Expand All @@ -224,7 +247,7 @@ else ifdef IS_WIN64
EXE = $(WIN64_EXE)
TEST_EXE = $(WIN64_TEST_EXE)
WIN64CC = $(CC)
WIN64CPP = $(CPP)
WIN64CPP = $(CXX)
WIN64AR = $(AR)
WIN64STRIP = strip
WIN64WINDRES = windres
Expand Down Expand Up @@ -275,10 +298,10 @@ $(HTML): $(SRC) $(WASM_BUILD_DIR)/liblua.a $(HDR) | $(WASM_BUILD_DIR)
$(EMPP) $(SRC) $(WASM_BUILD_DIR)/liblua.a -std=c++17 -fexceptions $(INCLUDE_DIRS) -Os -s USE_SDL=2 -s USE_SDL_IMAGE=2 -s USE_SDL_TTF=2 -s SDL2_IMAGE_FORMATS='["png","gif"]' -s ALLOW_MEMORY_GROWTH=1 --preload-file assets --preload-file packs -o $@

$(NIX_EXE): $(NIX_OBJ) $(NIX_BUILD_DIR)/liblua.a $(HDR) | $(NIX_BUILD_DIR)
$(CPP) -std=c++1z $(NIX_OBJ) $(NIX_BUILD_DIR)/liblua.a -ldl $(NIX_LD_FLAGS) `sdl2-config --libs` $(NIX_LIBS) -o $@
$(CXX) -std=c++1z $(NIX_OBJ) $(NIX_BUILD_DIR)/liblua.a -ldl $(NIX_LD_FLAGS) `sdl2-config --libs` $(NIX_LIBS) -o $@

$(NIX_TEST_EXE): $(NIX_TEST_OBJ) $(NIX_BUILD_DIR)/liblua.a $(HDR) | $(NIX_BUILD_DIR)
$(CPP) -std=c++1z $(NIX_TEST_OBJ) -l gtest -l gtest_main $(NIX_BUILD_DIR)/liblua.a -ldl $(NIX_LD_FLAGS) `sdl2-config --libs` $(NIX_LIBS) -o $@
$(CXX) -std=c++1z $(NIX_TEST_OBJ) -l gtest -l gtest_main $(NIX_BUILD_DIR)/liblua.a -ldl $(NIX_LD_FLAGS) `sdl2-config --libs` $(NIX_LIBS) -o $@

$(WIN32_EXE): $(WIN32_OBJ) $(WIN32_BUILD_DIR)/app.res $(WIN32_BUILD_DIR)/liblua.a $(HDR) | $(WIN32_BUILD_DIR)
# FIXME: static 32bit exe does not work for some reason
Expand Down Expand Up @@ -358,7 +381,7 @@ $(WASM_BUILD_DIR)/liblua.a: lib/lua/makefile lib/lua/luaconf.h | $(WASM_BUILD_DI
$(NIX_BUILD_DIR)/liblua.a: lib/lua/makefile lib/lua/luaconf.h | $(NIX_BUILD_DIR)
mkdir -p $(NIX_BUILD_DIR)/lib
cp -R lib/lua $(NIX_BUILD_DIR)/lib/
(cd $(NIX_BUILD_DIR)/lib/lua && make -f makefile a CC=$(CPP) AR="$(AR) rc" CFLAGS="$(NIX_LUA_C_FLAGS)" MYCFLAGS="" MYLIBS="")
(cd $(NIX_BUILD_DIR)/lib/lua && make -f makefile a CC=$(CXX) AR="$(AR) rc" CFLAGS="$(NIX_LUA_C_FLAGS)" MYCFLAGS="" MYLIBS="")
mv $(NIX_BUILD_DIR)/lib/lua/$(notdir $@) $@
rm -rf $(NIX_BUILD_DIR)/lib/lua
$(WIN32_BUILD_DIR)/liblua.a: lib/lua/makefile lib/lua/luaconf.h | $(WIN32_BUILD_DIR)
Expand Down Expand Up @@ -399,7 +422,7 @@ $(DIST_DIR):
$(NIX_OBJ_DIRS): | $(NIX_BUILD_DIR)
mkdir -p $@
$(NIX_BUILD_DIR)/%.o: %.c* $(HDR) | $(NIX_OBJ_DIRS)
$(CPP) -std=c++1z $(INCLUDE_DIRS) $(NIX_CPP_FLAGS) `sdl2-config --cflags` -c $< -o $@
$(CXX) -std=c++1z $(INCLUDE_DIRS) $(NIX_CPP_FLAGS) `sdl2-config --cflags` -c $< -o $@
$(WIN32_OBJ_DIRS): | $(WIN32_BUILD_DIR)
mkdir -p $@
$(WIN32_BUILD_DIR)/%.o: %.c* $(HDR) | $(WIN32_OBJ_DIRS)
Expand Down
2 changes: 2 additions & 0 deletions src/core/scripthost.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
#include <luaglue/lua_json.h>
#include <stdio.h>
#include "gameinfo.h"
#include "util.h"


#ifdef DEBUG_TRACKER
Expand Down Expand Up @@ -431,6 +432,7 @@ json ScriptHost::RunScriptAsync(const std::string& file, const json& arg, LuaRef
std::string script;
if (!_tracker || !_tracker->getPack() || !_tracker->getPack()->ReadFile(file, script)) {
luaL_error(_L, "Could not load script!");
util::unreachable(); // luaL_error does not return
}
return runAsync(file, script, arg, completeCallback, progressCallback);
}
Expand Down
21 changes: 21 additions & 0 deletions src/core/util.h
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,12 @@
#include <cstring>
#include "fs.h"

#ifdef __has_include
# if __has_include(<utility>)
# include <utility>
# endif
#endif


template< class Type, ptrdiff_t n >
static ptrdiff_t countOf( Type (&)[n] ) { return n; }
Expand Down Expand Up @@ -102,4 +108,19 @@ static void strip(std::string& s, const char* whitespace = " \t\r\n")
}
}

namespace util {
#ifdef __cpp_lib_unreachable
using unreachable = std::unreachable;
#else
[[noreturn]] static inline void unreachable()
{
# if defined(_MSC_VER) && !defined(__clang__) // MSVC
__assume(false);
# else // GCC, Clang
__builtin_unreachable();
# endif
}
#endif
}

#endif // _CORE_UTIL_H
3 changes: 0 additions & 3 deletions src/ui/mapwidget.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -189,9 +189,6 @@ void MapWidget::render(Renderer renderer, int offX, int offY)
// move to drawing offset
innerx += dstx;
innery += dsty;
// calculate top left corner of border
int outerx = innerx-borderScreenSize;
int outery = innery-borderScreenSize;

int state = (int)pos.state;
if (state == -1) continue; // hidden
Expand Down
2 changes: 1 addition & 1 deletion src/uilib/dlg.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -321,7 +321,7 @@ Dlg::Result Dlg::MsgBox(const std::string& title, const std::string& message, Dl
int res;
switch (btns) {
case Dlg::Buttons::OK:
res = tinyfd_messageBox(title.c_str(), message.c_str(), "ok", tfdicon, 0);
tinyfd_messageBox(title.c_str(), message.c_str(), "ok", tfdicon, 0);
return Dlg::Result::OK;
case Dlg::Buttons::OKCancel:
res = tinyfd_messageBox(title.c_str(), message.c_str(), "okcancel", tfdicon, dflt==Dlg::Result::OK ? 1 : 0);
Expand Down
9 changes: 6 additions & 3 deletions src/uilib/dock.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
#include "dock.h"
#include <map>
#include <cassert>

namespace Ui {

Expand Down Expand Up @@ -99,6 +99,7 @@ void Dock::relayout()
// 1. set hgrow/vgrow and minsize to signal parent based on children and dock options
// 2. actually layout children based on (current) size
// TODO: implement this better
assert(_docks.size() == _children.size());
bool isHorizontal = false;
bool isVertical = false;
int nUndefined = 0; // number of floaters
Expand Down Expand Up @@ -237,13 +238,16 @@ void Dock::relayout()
}
}
}
if (!nUndefined)
return;
// actually layout floating children
dockIt = _docks.begin();
childIt = _children.begin();
Size extraSpace = { (right-left), (bottom-top) };
for (;dockIt != _docks.end() && childIt != _children.end(); dockIt++, childIt++)
{
if (*dockIt != Direction::UNDEFINED) continue;
if (*dockIt != Direction::UNDEFINED)
continue;
#if 0
int childHGrow = (*childIt)->getHGrow() ? (*childIt)->getHGrow() : 1;
int childVGrow = (*childIt)->getVGrow() ? (*childIt)->getVGrow() : 1;
Expand All @@ -265,7 +269,6 @@ void Dock::relayout()
top += (*childIt)->getHeight();
}
}

}

void Dock::setSize(Size size)
Expand Down
4 changes: 2 additions & 2 deletions src/uilib/ui.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -164,8 +164,8 @@ bool Ui::render()

#define FRAME_TIME (1000/_fpsLimit) // TODO: microseconds

uint32_t t0 = SDL_GetTicks(); // TODO: microseconds
uint32_t t1 = t0;
const uint32_t t0 = SDL_GetTicks(); // TODO: microseconds
uint32_t t1;

do {
#ifndef __EMSCRIPTEN__
Expand Down

0 comments on commit e04d509

Please sign in to comment.