Compare commits

..

No commits in common. "325ac9a5b2a1547129b213a72cf311c8e0085e9a" and "ee9b93317b537bd18fa441e37cbc3d16cc1e4a52" have entirely different histories.

5 changed files with 45 additions and 104 deletions

0
.gitignore vendored Normal file → Executable file
View File

0
README.md Normal file → Executable file
View File

View File

@ -404,10 +404,8 @@ namespace utl {
using type = decltype(check<_Tp, _Up>(0));
};
#else
template<typename Tp>
using is_swappable = std::is_swappable<Tp>;
template<typename T, typename U>
using is_swappable_with = std::is_swappable_with<T, U>;
using is_swappable = std::is_swappable;
using is_swappable_with = std::is_swappable_with;
#endif
// != std:: on CommonReference

0
include/utl/core/version.h Normal file → Executable file
View File

View File

@ -1,7 +1,9 @@
#
# Makefile for utl Unit test
# Makefile
#
# Copyright (C) 2019-2020 Christos Choutouridis <christos@choutouridis.net>
# Main makefile for utl Unit test
#
# Copyright (C) 2019 Christos Choutouridis <christos@choutouridis.net>
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as
@ -18,23 +20,10 @@
#
# ========== Project settings ==========
# Excecutable's name
TARGET := utlTest
# List(space seperated) of source directories
# ex:
# SRC_DIR_LIST := src1 /var/src2 ../src3
SRC_DIR_LIST := tests gtest
# List(space seperated) of include directories
# ex:
# INC_DIR_LIST := inc /var/inc ../include2
INC_DIR_LIST := ../include gtest
# List(space seperated) of exclude files (filenames only)
# ex:
# EXC_FILE_LIST := bad.cpp old.cpp
EXC_FILE_LIST :=
TARGET := utlTest.exe
SRC_DIR := tests gtest
INC_DIR := ../include gtest
EXC_FILE :=
# build directories
BUILD_DIR := bin
@ -43,44 +32,38 @@ DEP_DIR := $(BUILD_DIR)/.dep
# ========== Compiler settings ==========
CLANGXX := clang++
CLANGPP := clang++ -E
GCCXX := g++
GCCPP := g++ -E
CXX := $(GCCXX)
CPP := $(GCCPP)
CXX := g++
CPP := g++ -E
CSIZE := size
CFLAGS := -Wall -Wextra
CFLAGS := -std=c++14 -Wall -Wextra
DEB_FLAGS := -DDEBUG -g3
REL_FLAGS := -O2
# example: LDFLAGS := -pthread -lm
LDFLAGS := -pthread
# example: MYCAB=1729 SUPER_MODE
REL_FLAGS := -O3
LDFLAGS :=
PRE_DEFS :=
MAP_FILE := $(BUILD_DIR)/output.map
MAP_FLAG := -Xlinker -Map=$(MAP_FILE)
#
# =========== Main body and Patterns ===========
#
INC := $(foreach dir,$(INC_DIR_LIST),-I$(dir))
INC := $(foreach dir,$(INC_DIR),-I$(dir))
DEF := $(foreach def,$(PRE_DEFS),-D$(def))
EXC := $(foreach fil,$(EXC_FILE_LIST), \
$(foreach dir,$(SRC_DIR_LIST),$(wildcard $(dir)/$(fil))) \
)
# source files. object and dependencies list
# source files
# recursive search into current and source directories
SRC := $(wildcard *.cpp)
SRC += $(foreach dir,$(SRC_DIR_LIST),$(wildcard $(dir)/*.cpp))
SRC += $(foreach dir,$(SRC_DIR_LIST),$(wildcard $(dir)/**/*.cpp))
SRC := $(abspath $(filter-out $(EXC),$(SRC)))
SRC += $(foreach dir,$(SRC_DIR),$(wildcard $(dir)/*.cpp))
SRC += $(foreach dir,$(SRC_DIR),$(wildcard $(dir)/**/*.cpp))
# exclude every file from the exclude file list
SRC := $(filter-out $(wildcard $(EXC_FILE)),$(SRC))
OBJ := $(foreach file,$(SRC:%.cpp=%.o),$(OBJ_DIR)$(file))
DEP := $(foreach file,$(SRC:%.cpp=%.d),$(DEP_DIR)$(file))
OBJ := $(foreach file,$(SRC:%.cpp=%.o),$(OBJ_DIR)/$(file))
DEP := $(foreach file,$(SRC:%.cpp=%.d),$(DEP_DIR)/$(file))
# Make Dependencies pattern.
@ -90,12 +73,13 @@ DEP := $(foreach file,$(SRC:%.cpp=%.d),$(DEP_DIR)$(file))
# It is based on Tom Tromey's method.
#
# Invoke cpp to create makefile rules with dependencies for each source file
$(DEP_DIR)%.d: %.cpp
$(DEP_DIR)/%.d: %.cpp
@mkdir -p $(@D)
@$(CPP) $(CFLAGS) $(INC) $(DEF) -MM -MT $(OBJ_DIR)$(<:.cpp=.o) -MF $@ $<
@$(CPP) $(CFLAGS) $(INC) $(DEF) -MM -MT $(OBJ_DIR)/$(<:.cpp=.o) -MF $@ $<
# objects depent on .cpp AND dependency files, which have an empty recipe
$(OBJ_DIR)%.o: %.cpp $(DEP_DIR)%.d
$(OBJ_DIR)/%.o: %.cpp $(DEP_DIR)/%.d
@mkdir -p $(@D)
$(CXX) -c $(CFLAGS) $(INC) $(DEF) -o $@ $<
@ -117,6 +101,7 @@ $(BUILD_DIR)/$(TARGET): $(OBJ)
@$(CSIZE) $(@D)/$(TARGET)
@echo Done
.PHONY: clean
clean:
@echo Cleaning build directories
@ -125,63 +110,21 @@ clean:
@rm -rf $(BUILD_DIR)
#
# ============ User Rules =============
#
.PHONY: gcc14
gcc14: CFLAGS += $(DEB_FLAGS)
gcc14: CFLAGS += -std=c++14
gcc14: $(BUILD_DIR)/$(TARGET)
.PHONY: gcc14_conc
gcc14_conc: CFLAGS += $(DEB_FLAGS)
gcc14_conc: CFLAGS += -std=c++14 -fconcepts
gcc14_conc: $(BUILD_DIR)/$(TARGET)
.PHONY: gcc17
gcc17: CFLAGS += $(DEB_FLAGS)
gcc17: CFLAGS += -std=c++17
gcc17: $(BUILD_DIR)/$(TARGET)
.PHONY: gcc17_conc
gcc17_conc: CFLAGS += $(DEB_FLAGS)
gcc17_conc: CFLAGS += -std=c++17 -fconcepts
gcc17_conc: $(BUILD_DIR)/$(TARGET)
.PHONY: gcc2a
gcc2a: CFLAGS += $(DEB_FLAGS)
gcc2a: CFLAGS += -std=c++2a
gcc2a: $(BUILD_DIR)/$(TARGET)
.PHONY: clang14
clang14: CXX := $(CLANGXX)
clang14: CPP := $(CLANGPP)
clang14: CFLAGS += $(DEB_FLAGS)
clang14: CFLAGS += -std=c++14
clang14: $(BUILD_DIR)/$(TARGET)
.PHONY: clang17
clang14: CXX := $(CLANGXX)
clang14: CPP := $(CLANGPP)
clang14: CFLAGS += $(DEB_FLAGS)
clang14: CFLAGS += -std=c++17
clang14: $(BUILD_DIR)/$(TARGET)
.PHONY: clang2a
clang14: CXX := $(CLANGXX)
clang14: CPP := $(CLANGPP)
clang14: CFLAGS += $(DEB_FLAGS)
clang14: CFLAGS += -std=c++2a
clang14: $(BUILD_DIR)/$(TARGET)
.PHONY: debug
debug: CFLAGS += $(DEB_FLAGS)
debug: $(BUILD_DIR)/$(TARGET)
.PHONY: release
release: CFLAGS += $(REL_FLAGS)
release: clean $(BUILD_DIR)/$(TARGET)
.PHONY: all
all: clean release