33 lines
1.4 KiB
Makefile
Raw Normal View History

2023-02-20 16:20:28 -03:00
PROG ?= example # Program we are building
DELETE = rm -rf # Command to remove files
OUT ?= -o $(PROG) # Compiler argument for output file
2023-02-16 16:50:06 -03:00
SOURCES = main.c mongoose.c # Source code files
CFLAGS = -W -Wall -Wextra -g -I. # Build options
# Mongoose build options. See https://mongoose.ws/documentation/#build-options
CFLAGS_MONGOOSE += -DMG_ENABLE_LINES=1
2020-12-10 13:26:05 +00:00
2023-02-20 16:20:28 -03:00
ifeq ($(OS),Windows_NT) # Windows settings. Assume MinGW compiler. To use VC: make CC=cl CFLAGS=/MD OUT=/Feprog.exe
2023-02-16 16:50:06 -03:00
PROG ?= example.exe # Use .exe suffix for the binary
CC = gcc # Use MinGW gcc compiler
CFLAGS += -lws2_32 # Link against Winsock library
DELETE = cmd /C del /Q /F /S # Command prompt command to delete files
OUT ?= -o $(PROG) # Build output
2023-02-20 16:20:28 -03:00
MAKE += WINDOWS=1 CC=$(CC)
2021-01-30 13:03:11 +00:00
endif
2023-02-20 16:20:28 -03:00
all: $(PROG) # Default target. Build and run program
$(RUN) ./$(PROG) $(ARGS)
2020-12-10 13:26:05 +00:00
2023-02-20 16:20:28 -03:00
$(PROG): $(SOURCES) # Build program from sources
2023-02-16 16:50:06 -03:00
$(CC) $(SOURCES) $(CFLAGS) $(CFLAGS_MONGOOSE) $(CFLAGS_EXTRA) $(OUT)
2022-03-21 14:38:42 +00:00
2023-02-20 16:20:28 -03:00
clean: # Cleanup. Delete built program and all build artifacts
$(DELETE) $(PROG) *.o *.obj *.exe *.dSYM mbedtls
# see https://mongoose.ws/tutorials/tls/#how-to-build for TLS build options
mbedtls: # Pull and build mbedTLS library
git clone --depth 1 -b v2.28.2 https://github.com/mbed-tls/mbedtls $@
$(MAKE) -C mbedtls/library