mirror of
https://github.com/php/php-src.git
synced 2024-11-24 02:15:04 +08:00
NetWare specific openssl build file
This commit is contained in:
parent
d1106bb4dc
commit
d725f3af91
185
ext/openssl/openssl.mak
Normal file
185
ext/openssl/openssl.mak
Normal file
@ -0,0 +1,185 @@
|
||||
# Temporarily here -- later may go into some batch file
|
||||
# which will set this as an environment variable
|
||||
PROJECT_ROOT = ..\..
|
||||
|
||||
# Module details
|
||||
MODULE_NAME = php_ossl
|
||||
MODULE_DESC = "PHP 5 - OpenSSL Extension"
|
||||
VMAJ = 1
|
||||
VMIN = 0
|
||||
VREV = 0
|
||||
|
||||
#include the common settings
|
||||
include $(PROJECT_ROOT)/netware/common.mif
|
||||
|
||||
# OpenSSL directory
|
||||
OSSL_DIR = P:/APPS/script/sw/OpenSSL
|
||||
|
||||
# Build type defaults to 'release'
|
||||
ifndef BUILD
|
||||
BUILD = release
|
||||
endif
|
||||
|
||||
# Extensions of all input and output files
|
||||
.SUFFIXES:
|
||||
.SUFFIXES: .nlm .lib .obj .cpp .c .msg .mlc .mdb .xdc .d
|
||||
|
||||
# Source files
|
||||
C_SRC = openssl.c \
|
||||
xp_ssl.c \
|
||||
start.c \
|
||||
|
||||
CPP_SRC_NODIR = $(notdir $(CPP_SRC))
|
||||
C_SRC_NODIR = $(notdir $(C_SRC))
|
||||
SRC_DIR = $(dir $(CPP_SRC) $(C_SRC))
|
||||
|
||||
# Library files
|
||||
LIBRARY = $(OSSL_DIR)/lib/RSAglue.lib \
|
||||
$(OSSL_DIR)/lib/crypto.lib \
|
||||
$(OSSL_DIR)/lib/ssl.lib
|
||||
|
||||
# Destination directories and files
|
||||
OBJ_DIR = $(BUILD)
|
||||
FINAL_DIR = $(BUILD)
|
||||
MAP_FILE = $(FINAL_DIR)\$(MODULE_NAME).map
|
||||
OBJECTS = $(addprefix $(OBJ_DIR)/,$(CPP_SRC_NODIR:.c=.obj) $(C_SRC_NODIR:.c=.obj))
|
||||
DEPDS = $(addprefix $(OBJ_DIR)/,$(CPP_SRC_NODIR:.c=.d) $(C_SRC_NODIR:.c=.d))
|
||||
|
||||
# Binary file
|
||||
ifndef BINARY
|
||||
BINARY=$(FINAL_DIR)\$(MODULE_NAME).nlm
|
||||
endif
|
||||
|
||||
# Compile flags
|
||||
C_FLAGS += -c -maxerrors 25 -msgstyle gcc
|
||||
C_FLAGS += -wchar_t on -bool on -processor Pentium
|
||||
C_FLAGS += -nostdinc -nosyspath
|
||||
C_FLAGS += -relax_pointers # To remove type-casting errors
|
||||
C_FLAGS += -DNETWARE -DZTS
|
||||
C_FLAGS += -DUSE_OLD_FUNCTIONS -DCOMPILE_DL_OPENSSL=1
|
||||
|
||||
C_FLAGS += -I. -I$(PROJECT_ROOT) -I$(PROJECT_ROOT)/main
|
||||
C_FLAGS += -I$(PROJECT_ROOT)/ext/standard -I$(PROJECT_ROOT)/netware
|
||||
C_FLAGS += -I$(PROJECT_ROOT)/zend -I$(PROJECT_ROOT)/tsrm
|
||||
C_FLAGS += -I- -I$(SDK_DIR)/include -I$(MWCIncludes)
|
||||
C_FLAGS += -I$(OSSL_DIR)/include
|
||||
|
||||
ifndef STACK_SIZE
|
||||
STACK_SIZE=8192
|
||||
endif
|
||||
|
||||
# Extra stuff based on debug / release builds
|
||||
ifeq '$(BUILD)' 'debug'
|
||||
SYM_FILE = $(FINAL_DIR)\$(MODULE_NAME).sym
|
||||
C_FLAGS += -inline smart -sym on -sym codeview4 -opt off -opt intrinsics -sym internal -DDEBUGGING -DDKFBPON
|
||||
C_FLAGS += -exc cw -DZEND_DEBUG=1
|
||||
LD_FLAGS += -sym on -sym codeview4 -osym $(SYM_FILE)
|
||||
export MWLibraryFiles=$(SDK_DIR)/imports/libcpre.o;mwcrtld.lib
|
||||
else
|
||||
C_FLAGS += -opt all -inline on -inline smart -inline auto -sym off
|
||||
C_FLAGS += -opt intrinsics -opt level=4 -DZEND_DEBUG=0
|
||||
LD_FLAGS += -sym off
|
||||
export MWLibraryFiles=$(SDK_DIR)/imports/libcpre.o;mwcrtl.lib
|
||||
endif
|
||||
|
||||
|
||||
# Dependencies
|
||||
MODULE = LibC \
|
||||
phplib
|
||||
IMPORT = @$(SDK_DIR)/imports/libc.imp \
|
||||
@$(SDK_DIR)/imports/ws2nlm.imp \
|
||||
@$(SDK_DIR)/imports/netware.imp \
|
||||
@$(MPK_DIR)/import/mpkOrg.imp \
|
||||
@$(PROJECT_ROOT)/netware/phplib.imp
|
||||
EXPORT = ($(MODULE_NAME)) get_module
|
||||
API = OutputToScreen
|
||||
|
||||
# Virtual paths
|
||||
vpath %.cpp .
|
||||
vpath %.c . ..\..\netware
|
||||
vpath %.obj $(OBJ_DIR)
|
||||
|
||||
|
||||
all: prebuild project
|
||||
|
||||
.PHONY: all
|
||||
|
||||
prebuild:
|
||||
@if not exist $(OBJ_DIR) md $(OBJ_DIR)
|
||||
|
||||
project: $(BINARY)
|
||||
@echo Build complete.
|
||||
|
||||
$(OBJ_DIR)/%.d: %.cpp
|
||||
@echo Building Dependencies for $(<F)
|
||||
@$(CC) -M $< $(C_FLAGS) -o $@
|
||||
|
||||
$(OBJ_DIR)/%.d: %.c
|
||||
@echo Building Dependencies for $(<F)
|
||||
@$(CC) -M $< $(C_FLAGS) -o $@
|
||||
|
||||
$(OBJ_DIR)/%.obj: %.cpp
|
||||
@echo Compiling $?...
|
||||
@$(CC) $< $(C_FLAGS) -o $@
|
||||
|
||||
$(OBJ_DIR)/%.obj: %.c
|
||||
@echo Compiling $?...
|
||||
@$(CC) $< $(C_FLAGS) -o $@
|
||||
|
||||
|
||||
$(BINARY): $(OBJECTS)
|
||||
@echo Import $(IMPORT) > $(basename $@).def
|
||||
ifdef API
|
||||
@echo Import $(API) >> $(basename $@).def
|
||||
endif
|
||||
@echo Module $(MODULE) >> $(basename $@).def
|
||||
ifdef EXPORT
|
||||
@echo Export $(EXPORT) >> $(basename $@).def
|
||||
endif
|
||||
@echo AutoUnload >> $(basename $@).def
|
||||
ifeq '$(BUILD)' 'debug'
|
||||
@echo Debug >> $(basename $@).def
|
||||
endif
|
||||
@echo Flag_On 0x00000008 >> $(basename $@).def
|
||||
@echo Start _LibCPrelude >> $(basename $@).def
|
||||
@echo Exit _LibCPostlude >> $(basename $@).def
|
||||
|
||||
# Two functions imported to build the openssl extension
|
||||
@echo Import GetProcessSwitchCount >> $(basename $@).def
|
||||
@echo Import RunningProcess >> $(basename $@).def
|
||||
|
||||
$(MPKTOOL) $(XDCFLAGS) $(basename $@).xdc
|
||||
@echo xdcdata $(basename $@).xdc >> $(basename $@).def
|
||||
|
||||
@echo Linking $@...
|
||||
@echo $(LD_FLAGS) -commandfile $(basename $@).def > $(basename $@).link
|
||||
|
||||
@echo $(LIBRARY) $(OBJECTS) >> $(basename $@).link
|
||||
|
||||
@$(LINK) @$(basename $@).link
|
||||
|
||||
|
||||
.PHONY: clean
|
||||
clean: cleanobj cleanbin
|
||||
|
||||
.PHONY: cleand
|
||||
cleand:
|
||||
@echo Deleting all dependency files...
|
||||
-@del "$(OBJ_DIR)\*.d"
|
||||
|
||||
.PHONY: cleanobj
|
||||
cleanobj:
|
||||
@echo Deleting all object files...
|
||||
-@del "$(OBJ_DIR)\*.obj"
|
||||
|
||||
.PHONY: cleanbin
|
||||
cleanbin:
|
||||
@echo Deleting binary files...
|
||||
-@del "$(FINAL_DIR)\$(MODULE_NAME).nlm"
|
||||
@echo Deleting MAP, DEF files, etc....
|
||||
-@del "$(FINAL_DIR)\$(MODULE_NAME).map"
|
||||
-@del "$(FINAL_DIR)\$(MODULE_NAME).def"
|
||||
-@del "$(FINAL_DIR)\$(MODULE_NAME).link"
|
||||
ifeq '$(BUILD)' 'debug'
|
||||
-@del $(FINAL_DIR)\$(MODULE_NAME).sym
|
||||
endif
|
Loading…
Reference in New Issue
Block a user