Compare commits
	
		
			No commits in common. "325ac9a5b2a1547129b213a72cf311c8e0085e9a" and "ee9b93317b537bd18fa441e37cbc3d16cc1e4a52" have entirely different histories.
		
	
	
		
			325ac9a5b2
			...
			ee9b93317b
		
	
		
							
								
								
									
										0
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							| @ -404,10 +404,8 @@ namespace utl { | |||||||
|       using type = decltype(check<_Tp, _Up>(0)); |       using type = decltype(check<_Tp, _Up>(0)); | ||||||
|    }; |    }; | ||||||
|    #else |    #else | ||||||
|    template<typename Tp> |    using is_swappable = std::is_swappable; | ||||||
|    using is_swappable = std::is_swappable<Tp>; |    using is_swappable_with = std::is_swappable_with; | ||||||
|    template<typename T, typename U> |  | ||||||
|    using is_swappable_with = std::is_swappable_with<T, U>; |  | ||||||
|    #endif |    #endif | ||||||
| 
 | 
 | ||||||
|    // != std:: on CommonReference
 |    // != std:: on CommonReference
 | ||||||
|  | |||||||
							
								
								
									
										0
									
								
								include/utl/core/version.h
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								include/utl/core/version.h
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										143
									
								
								test/Makefile
									
									
									
									
									
								
							
							
						
						
									
										143
									
								
								test/Makefile
									
									
									
									
									
								
							| @ -1,7 +1,9 @@ | |||||||
| #
 | #
 | ||||||
| # Makefile for utl Unit test
 | # Makefile
 | ||||||
|  | # 
 | ||||||
|  | # Main makefile for utl Unit test
 | ||||||
| #
 | #
 | ||||||
| # Copyright (C) 2019-2020 Christos Choutouridis <christos@choutouridis.net>
 | # Copyright (C) 2019 Christos Choutouridis <christos@choutouridis.net>
 | ||||||
| #
 | #
 | ||||||
| # This program is free software: you can redistribute it and/or modify
 | # This program is free software: you can redistribute it and/or modify
 | ||||||
| # it under the terms of the GNU Lesser General Public License as
 | # it under the terms of the GNU Lesser General Public License as
 | ||||||
| @ -18,69 +20,50 @@ | |||||||
| #
 | #
 | ||||||
| 
 | 
 | ||||||
| # ========== Project settings ==========
 | # ========== Project settings ==========
 | ||||||
| # Excecutable's name
 | TARGET   	:= utlTest.exe | ||||||
| TARGET          := utlTest | SRC_DIR		:= tests gtest | ||||||
| 
 | INC_DIR		:= ../include gtest | ||||||
| # List(space seperated) of source directories
 | EXC_FILE	:=  | ||||||
| # 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   := |  | ||||||
| 
 | 
 | ||||||
| # build directories
 | # build directories
 | ||||||
| BUILD_DIR       := bin | BUILD_DIR  	:= bin | ||||||
| OBJ_DIR         := $(BUILD_DIR)/obj | OBJ_DIR  	:= $(BUILD_DIR)/obj | ||||||
| DEP_DIR         := $(BUILD_DIR)/.dep | DEP_DIR		:= $(BUILD_DIR)/.dep | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| # ========== Compiler settings ==========
 | # ========== Compiler settings ==========
 | ||||||
| CLANGXX         := clang++ | CXX			:= g++ | ||||||
| CLANGPP         := clang++ -E | CPP			:= g++ -E | ||||||
| GCCXX           := g++ | CSIZE			:= size | ||||||
| GCCPP           := g++ -E |  | ||||||
| 
 | 
 | ||||||
| CXX             := $(GCCXX) | CFLAGS 		:= -std=c++14 -Wall -Wextra | ||||||
| CPP             := $(GCCPP) | DEB_FLAGS	:= -DDEBUG -g3 | ||||||
| CSIZE           := size | REL_FLAGS	:= -O3 | ||||||
|  | LDFLAGS  	:= | ||||||
| 
 | 
 | ||||||
| CFLAGS          := -Wall -Wextra | PRE_DEFS		:=  | ||||||
| DEB_FLAGS       := -DDEBUG -g3 | 
 | ||||||
| REL_FLAGS       := -O2 | MAP_FILE		:= $(BUILD_DIR)/output.map | ||||||
| # example: LDFLAGS := -pthread -lm
 | MAP_FLAG		:= -Xlinker -Map=$(MAP_FILE) | ||||||
| LDFLAGS         := -pthread |  | ||||||
| # example: MYCAB=1729 SUPER_MODE
 |  | ||||||
| PRE_DEFS        := |  | ||||||
| 
 | 
 | ||||||
| MAP_FILE        := $(BUILD_DIR)/output.map |  | ||||||
| MAP_FLAG        := -Xlinker -Map=$(MAP_FILE) |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| #
 | #
 | ||||||
| # =========== Main body and Patterns ===========
 | # =========== 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)) | 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
 |  | ||||||
| # 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))) |  | ||||||
| 
 | 
 | ||||||
| OBJ     := $(foreach file,$(SRC:%.cpp=%.o),$(OBJ_DIR)$(file)) | # source files
 | ||||||
| DEP     := $(foreach file,$(SRC:%.cpp=%.d),$(DEP_DIR)$(file)) | # recursive search into current and source directories
 | ||||||
|  | SRC			:= $(wildcard *.cpp) | ||||||
|  | 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)) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| # Make Dependencies pattern.
 | # Make Dependencies pattern.
 | ||||||
| @ -90,12 +73,13 @@ DEP     := $(foreach file,$(SRC:%.cpp=%.d),$(DEP_DIR)$(file)) | |||||||
| # It is based on Tom Tromey's method.
 | # It is based on Tom Tromey's method.
 | ||||||
| # 
 | # 
 | ||||||
| # Invoke cpp to create makefile rules with dependencies for each source file
 | # Invoke cpp to create makefile rules with dependencies for each source file
 | ||||||
| $(DEP_DIR)%.d: %.cpp | $(DEP_DIR)/%.d: %.cpp | ||||||
| 	@mkdir -p $(@D) | 	@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 
 | # 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) | 	@mkdir -p $(@D) | ||||||
| 	$(CXX) -c $(CFLAGS) $(INC) $(DEF) -o $@ $< | 	$(CXX) -c $(CFLAGS) $(INC) $(DEF) -o $@ $< | ||||||
| 
 | 
 | ||||||
| @ -117,6 +101,7 @@ $(BUILD_DIR)/$(TARGET): $(OBJ) | |||||||
| 	@$(CSIZE) $(@D)/$(TARGET) | 	@$(CSIZE) $(@D)/$(TARGET) | ||||||
| 	@echo Done | 	@echo Done | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| .PHONY: clean | .PHONY: clean | ||||||
| clean: | clean: | ||||||
| 	@echo Cleaning build directories | 	@echo Cleaning build directories | ||||||
| @ -125,63 +110,21 @@ clean: | |||||||
| 	@rm -rf $(BUILD_DIR) | 	@rm -rf $(BUILD_DIR) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| #
 | #
 | ||||||
| # ============ User Rules =============
 | # ============ 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 | .PHONY: debug | ||||||
| debug: CFLAGS += $(DEB_FLAGS) | debug: CFLAGS += $(DEB_FLAGS) | ||||||
| debug: $(BUILD_DIR)/$(TARGET) | debug: $(BUILD_DIR)/$(TARGET) | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| .PHONY: release | .PHONY: release | ||||||
| release: CFLAGS += $(REL_FLAGS) | release: CFLAGS += $(REL_FLAGS) | ||||||
| release: clean $(BUILD_DIR)/$(TARGET) | release: clean $(BUILD_DIR)/$(TARGET) | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| .PHONY: all | .PHONY: all | ||||||
| all: clean release | all: clean release | ||||||
|  | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user