mirror of https://github.com/jeelabs/esp-link.git
upstream
parent
b458df915e
commit
ccc179f533
@ -1,3 +1,3 @@ |
|||||||
[submodule "lib/heatshrink"] |
[submodule "lib/heatshrink"] |
||||||
path = lib/heatshrink |
path = libesphttpd/lib/heatshrink |
||||||
url = https://github.com/atomicobject/heatshrink.git |
url = https://github.com/atomicobject/heatshrink.git |
||||||
|
@ -0,0 +1,28 @@ |
|||||||
|
# --------------- esphttpd config options ---------------
|
||||||
|
|
||||||
|
# If GZIP_COMPRESSION is set to "yes" then the static css, js, and html files will be compressed with gzip before added to the espfs image
|
||||||
|
# and will be served with gzip Content-Encoding header.
|
||||||
|
# This could speed up the downloading of these files, but might break compatibility with older web browsers not supporting gzip encoding
|
||||||
|
# because Accept-Encoding is simply ignored. Enable this option if you have large static files to serve (for e.g. JQuery, Twitter bootstrap)
|
||||||
|
# By default only js, css and html files are compressed.
|
||||||
|
# If you have text based static files with different extensions what you want to serve compressed then you will need to add the extension to the following places:
|
||||||
|
# - Add the extension to this Makefile at the webpages.espfs target to the find command
|
||||||
|
# - Add the extension to the gzippedFileTypes array in the user/httpd.c file
|
||||||
|
#
|
||||||
|
# Adding JPG or PNG files (and any other compressed formats) is not recommended, because GZIP compression does not works effectively on compressed files.
|
||||||
|
|
||||||
|
#Static gzipping is disabled by default.
|
||||||
|
GZIP_COMPRESSION ?= no
|
||||||
|
|
||||||
|
# If COMPRESS_W_YUI is set to "yes" then the static css and js files will be compressed with yui-compressor
|
||||||
|
# This option works only when GZIP_COMPRESSION is set to "yes"
|
||||||
|
# http://yui.github.io/yuicompressor/
|
||||||
|
#Disabled by default.
|
||||||
|
COMPRESS_W_YUI ?= no
|
||||||
|
YUI-COMPRESSOR ?= /usr/bin/yui-compressor
|
||||||
|
|
||||||
|
#If USE_HEATSHRINK is set to "yes" then the espfs files will be compressed with Heatshrink and decompressed
|
||||||
|
#on the fly while reading the file. Because the decompression is done in the esp8266, it does not require
|
||||||
|
#any support in the browser.
|
||||||
|
USE_HEATSHRINK ?= yes
|
||||||
|
|
@ -0,0 +1,9 @@ |
|||||||
|
build/ |
||||||
|
espfs/mkespfsimage/*.o |
||||||
|
espfs/mkespfsimage/mkespfsimage |
||||||
|
webpages.espfs |
||||||
|
libesphttpd.a |
||||||
|
espfs/espfstest/*.o |
||||||
|
espfs/espfstest/espfstest |
||||||
|
*.DS_Store |
||||||
|
html_compressed/ |
@ -0,0 +1,140 @@ |
|||||||
|
|
||||||
|
# Directory the Makefile is in. Please don't include other Makefiles before this.
|
||||||
|
THISDIR:=$(dir $(abspath $(lastword $(MAKEFILE_LIST))))
|
||||||
|
|
||||||
|
#Include httpd config from lower level
|
||||||
|
-include ../esphttpdconfig.mk |
||||||
|
|
||||||
|
|
||||||
|
#Default options. If you want to change them, please create ../esphttpdconfig.mk with the options you want in it.
|
||||||
|
GZIP_COMPRESSION ?= no
|
||||||
|
COMPRESS_W_YUI ?= no
|
||||||
|
YUI-COMPRESSOR ?= /usr/bin/yui-compressor
|
||||||
|
USE_HEATSHRINK ?= yes
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Output directors to store intermediate compiled files
|
||||||
|
# relative to the project directory
|
||||||
|
BUILD_BASE = build
|
||||||
|
|
||||||
|
# Base directory for the compiler. Needs a / at the end; if not set it'll use the tools that are in
|
||||||
|
# the PATH.
|
||||||
|
XTENSA_TOOLS_ROOT ?=
|
||||||
|
|
||||||
|
# base directory of the ESP8266 SDK package, absolute
|
||||||
|
SDK_BASE ?= /opt/Espressif/ESP8266_SDK
|
||||||
|
|
||||||
|
# name for the target project
|
||||||
|
LIB = libesphttpd.a
|
||||||
|
|
||||||
|
# which modules (subdirectories) of the project to include in compiling
|
||||||
|
#MODULES = driver user lwip/api lwip/app lwip/core lwip/core/ipv4 lwip/netif
|
||||||
|
MODULES = espfs core util
|
||||||
|
EXTRA_INCDIR = ./include \
|
||||||
|
. \
|
||||||
|
lib/heatshrink/
|
||||||
|
|
||||||
|
|
||||||
|
# compiler flags using during compilation of source files
|
||||||
|
CFLAGS = -Os -ggdb -std=c99 -Werror -Wpointer-arith -Wundef -Wall -Wl,-EL -fno-inline-functions \
|
||||||
|
-nostdlib -mlongcalls -mtext-section-literals -D__ets__ -DICACHE_FLASH -D_STDINT_H \
|
||||||
|
-Wno-address
|
||||||
|
|
||||||
|
# various paths from the SDK used in this project
|
||||||
|
SDK_LIBDIR = lib
|
||||||
|
SDK_LDDIR = ld
|
||||||
|
SDK_INCDIR = include include/json
|
||||||
|
|
||||||
|
# select which tools to use as compiler, librarian and linker
|
||||||
|
CC := $(XTENSA_TOOLS_ROOT)xtensa-lx106-elf-gcc
|
||||||
|
AR := $(XTENSA_TOOLS_ROOT)xtensa-lx106-elf-ar
|
||||||
|
LD := $(XTENSA_TOOLS_ROOT)xtensa-lx106-elf-gcc
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
####
|
||||||
|
#### no user configurable options below here
|
||||||
|
####
|
||||||
|
SRC_DIR := $(MODULES)
|
||||||
|
BUILD_DIR := $(addprefix $(BUILD_BASE)/,$(MODULES))
|
||||||
|
|
||||||
|
SDK_INCDIR := $(addprefix -I$(SDK_BASE)/,$(SDK_INCDIR))
|
||||||
|
|
||||||
|
SRC := $(foreach sdir,$(SRC_DIR),$(wildcard $(sdir)/*.c))
|
||||||
|
OBJ := $(patsubst %.c,$(BUILD_BASE)/%.o,$(SRC))
|
||||||
|
|
||||||
|
INCDIR := $(addprefix -I,$(SRC_DIR))
|
||||||
|
EXTRA_INCDIR := $(addprefix -I,$(EXTRA_INCDIR))
|
||||||
|
MODULE_INCDIR := $(addsuffix /include,$(INCDIR))
|
||||||
|
|
||||||
|
V ?= $(VERBOSE)
|
||||||
|
ifeq ("$(V)","1") |
||||||
|
Q :=
|
||||||
|
vecho := @true
|
||||||
|
else |
||||||
|
Q := @
|
||||||
|
vecho := @echo
|
||||||
|
endif |
||||||
|
|
||||||
|
ifeq ("$(GZIP_COMPRESSION)","yes") |
||||||
|
CFLAGS += -DGZIP_COMPRESSION
|
||||||
|
endif |
||||||
|
|
||||||
|
ifeq ("$(USE_HEATSHRINK)","yes") |
||||||
|
CFLAGS += -DESPFS_HEATSHRINK
|
||||||
|
endif |
||||||
|
|
||||||
|
vpath %.c $(SRC_DIR) |
||||||
|
|
||||||
|
define compile-objects |
||||||
|
$1/%.o: %.c |
||||||
|
$(vecho) "CC $$<"
|
||||||
|
$(Q) $(CC) $(INCDIR) $(MODULE_INCDIR) $(EXTRA_INCDIR) $(SDK_INCDIR) $(CFLAGS) -c $$< -o $$@
|
||||||
|
endef |
||||||
|
|
||||||
|
.PHONY: all checkdirs clean webpages.espfs |
||||||
|
|
||||||
|
all: checkdirs $(LIB) webpages.espfs |
||||||
|
|
||||||
|
|
||||||
|
$(LIB): $(OBJ) |
||||||
|
$(vecho) "AR $@"
|
||||||
|
$(Q) $(AR) cru $@ $^
|
||||||
|
|
||||||
|
checkdirs: $(BUILD_DIR) |
||||||
|
|
||||||
|
$(BUILD_DIR): |
||||||
|
$(Q) mkdir -p $@
|
||||||
|
|
||||||
|
|
||||||
|
webpages.espfs: $(HTMLDIR) espfs/mkespfsimage/mkespfsimage |
||||||
|
ifeq ("$(COMPRESS_W_YUI)","yes") |
||||||
|
$(Q) rm -rf html_compressed;
|
||||||
|
$(Q) cp -r ../html html_compressed;
|
||||||
|
$(Q) echo "Compression assets with yui-compressor. This may take a while..."
|
||||||
|
$(Q) for file in `find html_compressed -type f -name "*.js"`; do $(YUI-COMPRESSOR) --type js $$file -o $$file; done
|
||||||
|
$(Q) for file in `find html_compressed -type f -name "*.css"`; do $(YUI-COMPRESSOR) --type css $$file -o $$file; done
|
||||||
|
$(Q) awk "BEGIN {printf \"YUI compression ratio was: %.2f%%\\n\", (`du -b -s html_compressed/ | sed 's/\([0-9]*\).*/\1/'`/`du -b -s ../html/ | sed 's/\([0-9]*\).*/\1/'`)*100}"
|
||||||
|
|
||||||
|
# mkespfsimage will compress html, css and js files with gzip by default if enabled
|
||||||
|
# override with -g cmdline parameter
|
||||||
|
$(Q) cd html_compressed; find | $(THISDIR)/espfs/mkespfsimage/mkespfsimage > $(THISDIR)/webpages.espfs; cd ..;
|
||||||
|
else |
||||||
|
$(Q) cd ../html; find | $(THISDIR)/espfs/mkespfsimage/mkespfsimage > $(THISDIR)/webpages.espfs; cd ..
|
||||||
|
endif |
||||||
|
|
||||||
|
espfs/mkespfsimage/mkespfsimage: espfs/mkespfsimage/ |
||||||
|
$(Q) $(MAKE) -C espfs/mkespfsimage USE_HEATSHRINK="$(USE_HEATSHRINK)" GZIP_COMPRESSION="$(GZIP_COMPRESSION)"
|
||||||
|
|
||||||
|
clean: |
||||||
|
$(Q) rm -f $(LIB)
|
||||||
|
$(Q) find $(BUILD_BASE) -type f | xargs rm -f
|
||||||
|
$(Q) make -C espfs/mkespfsimage/ clean
|
||||||
|
$(Q) rm -rf $(FW_BASE)
|
||||||
|
$(Q) rm -f webpages.espfs
|
||||||
|
ifeq ("$(COMPRESS_W_YUI)","yes") |
||||||
|
$(Q) rm -rf html_compressed
|
||||||
|
endif |
||||||
|
|
||||||
|
$(foreach bdir,$(BUILD_DIR),$(eval $(call compile-objects,$(bdir)))) |
@ -1,7 +1,7 @@ |
|||||||
GZIP_COMPRESSION ?= no
|
GZIP_COMPRESSION ?= no
|
||||||
USE_HEATSHRINK ?= yes
|
USE_HEATSHRINK ?= yes
|
||||||
|
|
||||||
CFLAGS=-I../../lib/heatshrink -I.. -std=gnu99
|
CFLAGS=-I../../lib/heatshrink -I../../include -I.. -std=gnu99
|
||||||
ifeq ("$(GZIP_COMPRESSION)","yes") |
ifeq ("$(GZIP_COMPRESSION)","yes") |
||||||
CFLAGS += -DESPFS_GZIP
|
CFLAGS += -DESPFS_GZIP
|
||||||
endif |
endif |
@ -0,0 +1 @@ |
|||||||
|
|
Loading…
Reference in new issue