mongoose/examples/http-proxy-client/Makefile

36 lines
1.7 KiB
Makefile
Raw Normal View History

2023-02-21 23:16:39 +08:00
PROG ?= example # Program we are building
DELETE = rm -rf # Command to remove files
OUT ?= -o $(PROG) # Compiler argument for output file
2023-09-07 01:53:41 +08:00
SOURCES = main.c mongoose.c packed_fs.c # Source code files, packed_fs.c contains ca.pem, which contains CA certs for TLS
2023-02-21 23:16:39 +08:00
CFLAGS = -W -Wall -Wextra -g -I. # Build options
2020-12-23 05:01:14 +08:00
2023-02-21 23:16:39 +08:00
# Mongoose build options. See https://mongoose.ws/documentation/#build-options
2023-09-07 01:53:41 +08:00
CFLAGS_MONGOOSE += -DMG_ENABLE_LINES=1 -DMG_ENABLE_PACKED_FS=1
2023-02-21 23:16:39 +08:00
// see tutorial at https://mongoose.ws/tutorials/http-proxy-client/
ARGS ?= 167.235.63.238:3128 http://info.cern.ch/ # default call arguments
2023-02-21 23:16:39 +08:00
ifeq ($(OS),Windows_NT) # Windows settings. Assume MinGW compiler. To use VC: make CC=cl CFLAGS=/MD OUT=/Feprog.exe
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
MAKE += WINDOWS=1 CC=$(CC)
2020-12-23 05:01:14 +08:00
endif
2023-02-21 23:16:39 +08:00
all: $(PROG) # Default target. Build and run program
$(RUN) ./$(PROG) $(ARGS)
$(PROG): $(SOURCES) # Build program from sources
$(CC) $(SOURCES) $(CFLAGS) $(CFLAGS_MONGOOSE) $(CFLAGS_EXTRA) $(OUT)
2020-12-23 05:01:14 +08:00
2023-02-21 23:16:39 +08:00
clean: # Cleanup. Delete built program and all build artifacts
$(DELETE) $(PROG) *.o *.obj *.exe *.dSYM mbedtls
2020-12-23 05:01:14 +08:00
2023-02-21 23:16:39 +08:00
# see https://mongoose.ws/tutorials/tls/#how-to-build for TLS build options
2020-12-23 05:01:14 +08:00
2023-02-21 23:16:39 +08:00
mbedtls: # Pull and build mbedTLS library
git clone --depth 1 -b v2.28.2 https://github.com/mbed-tls/mbedtls $@
$(MAKE) -C mbedtls/library