#!/bin/bash ##################################################################################### # the main output dir, all configure and make output are in this dir. ##################################################################################### # create the main objs SRS_OBJS="objs" mkdir -p ${SRS_OBJS} ##################################################################################### # parse user options, set the variables like SRS_SSL/SRS_HLS/SRS_FFMPEG/SRS_HTTP ##################################################################################### # parse options, exit with error when parse options invalid. . auto/options.sh # clean the exists # do this only when the options is ok. if [[ -f Makefile ]]; then make clean fi ##################################################################################### # generate auto headers file, depends on the finished of options.sh ##################################################################################### # write user options to headers SRS_AUTO_HEADERS_H="${SRS_OBJS}/srs_auto_headers.hpp" echo "#define SRS_CONFIGURE \"${SRS_CONFIGURE}\"" > $SRS_AUTO_HEADERS_H echo "#define SRS_BUILD_DATE \"`date \"+%Y-%m-%d %H:%M:%S\"`\"" >> $SRS_AUTO_HEADERS_H echo "#define SRS_BUILD_TS \"`date +%s`\"" >> $SRS_AUTO_HEADERS_H # apply user options. . auto/depends.sh # new empty line to auto headers file. echo "" >> $SRS_AUTO_HEADERS_H ##################################################################################### # generate Makefile. ##################################################################################### ##################################################################################### echo "generate Makefile" SRS_MAKEFILE="Makefile" cat << END > ${SRS_MAKEFILE} .PHONY: default help clean server bandwidth _prepare_dir default: server bandwidth help: @echo "Usage: make |||" @echo " help display this help menu" @echo " clean cleanup project" @echo " server build the srs(simple rtmp server) over st(state-threads)" @echo " bandwidth build the bandwidth test client tool." clean: (rm -f Makefile; cd ${SRS_OBJS}; rm -rf srs bandwidth Makefile *.hpp src st_*_load research) server: _prepare_dir @echo "build the srs(simple rtmp server) over st(state-threads)" \$(MAKE) -f ${SRS_OBJS}/${SRS_MAKEFILE} srs bandwidth: _prepare_dir @echo "build the bandwidth test client tool" \$(MAKE) -f ${SRS_OBJS}/${SRS_MAKEFILE} bandwidth # the ./configure will generate it. _prepare_dir: @mkdir -p ${SRS_OBJS} END ##################################################################################### # build tools or compiler args. # the performance analysis, uncomments the following when use gperf to analysis the performance. see third-party/readme.txt Performance="-pg" # enable gdb debug GDBDebug="-g -O0" # the warning level. WarnLevel="-Wall" # the compile standard. CppStd="-ansi" # the cxx flag generated. CXXFLAGS="${CppStd} ${WarnLevel} ${GDBDebug}" #CXXFLAGS="${CppStd} ${WarnLevel} ${GDBDebug} ${Performance}" cat << END > ${SRS_OBJS}/${SRS_MAKEFILE} CC ?= gcc GCC ?= gcc CXX ?= g++ AR ?= ar CXXFLAGS = ${CXXFLAGS} LINK = g++ .PHONY: default srs bandwidth default: END ##################################################################################### # Libraries, external library to build in srs, # header(.h): add to ModuleLibIncs if need the specified library. for example, LibSTRoot # library(.a): add to ModuleLibFiles if binary need the specifeid library. for example, LibSTfile # # st(state-threads) the basic network library for SRS. LibSTRoot="${SRS_OBJS}/st" LibSTfile="${LibSTRoot}/libst.a" # hp(http-parser) the http request/url parser, for SRS to support HTTP callback. LibHttpParserRoot="" LibHttpParserfile="" if [ $SRS_HTTP = YES ]; then LibHttpParserRoot="${SRS_OBJS}/hp" LibHttpParserfile="${LibHttpParserRoot}/libhttp_parser.a" fi # openssl-1.0.1f, for the RTMP complex handshake. LibSSLRoot="" LibSSLfile="" if [ $SRS_SSL = YES ]; then LibSSLRoot="${SRS_OBJS}/openssl/include" LibSSLfile="${SRS_OBJS}/openssl/lib/libssl.a ${SRS_OBJS}/openssl/lib/libcrypto.a" fi ##################################################################################### # Modules, compile each module, then link to binary # #Core, depends only on system apis. MODULE_ID="CORE" MODULE_DEPENDS=() ModuleLibIncs=(${SRS_OBJS}) MODULE_FILES=("srs_core" "srs_core_autofree") MODULE_DIR="src/core" . auto/modules.sh CORE_OBJS="${MODULE_OBJS[@]}" # #Kernel, depends on core, provides error/log/config, nothing about stream information. MODULE_ID="KERNEL" MODULE_DEPENDS=("CORE") ModuleLibIncs=(${SRS_OBJS}) MODULE_FILES=("srs_kernel_error" "srs_kernel_log" "srs_kernel_reload" "srs_kernel_config" "srs_kernel_stream" "srs_kernel_buffer" "srs_kernel_pithy_print") MODULE_DIR="src/kernel" . auto/modules.sh KERNEL_OBJS="${MODULE_OBJS[@]}" # #Protocol, depends on core/kernel, provides rtmp/htttp protocol features. MODULE_ID="PROTOCOL" MODULE_DEPENDS=("CORE" "KERNEL") ModuleLibIncs=(${SRS_OBJS} ${LibSSLRoot}) MODULE_FILES=("srs_protocol_amf0" "srs_protocol_io" "srs_protocol_rtmp_stack" "srs_protocol_rtmp" "srs_protocol_handshake") MODULE_DIR="src/pro" . auto/modules.sh PROTOCOL_OBJS="${MODULE_OBJS[@]}" # #App Module MODULE_ID="APP" MODULE_DEPENDS=("CORE" "KERNEL" "PROTOCOL") ModuleLibIncs=(${LibSTRoot} ${LibHttpParserRoot} ${SRS_OBJS}) MODULE_FILES=("srs_core_server" "srs_core_conn" "srs_core_client" "srs_core_socket" "srs_core_source" "srs_core_codec" "srs_core_refer" "srs_core_hls" "srs_core_forward" "srs_core_encoder" "srs_core_http" "srs_core_thread" "srs_core_bandwidth" "srs_core_st" "srs_core_log_context") MODULE_DIR="src/app" . auto/modules.sh APP_OBJS="${MODULE_OBJS[@]}" # #Main Module MODULE_ID="MAIN" MODULE_DEPENDS=("CORE" "KERNEL" "PROTOCOL" "APP") ModuleLibIncs=(${LibSTRoot} ${SRS_OBJS}) MODULE_FILES=("srs_main_server" "srs_main_bandcheck") MODULE_DIR="src/main" . auto/modules.sh MAIN_OBJS="${MODULE_OBJS[@].o}" ##################################################################################### # Binaries, main entrances, link the module and its depends modules, # then link to a binary, for example, objs/srs # # all main entrances MAIN_ENTRANCES=("srs_main_server" "srs_main_bandcheck") # # all depends libraries ModuleLibFiles=(${LibSTfile} ${LibHttpParserfile} ${LibSSLfile}) # all depends objects MODULE_OBJS="${CORE_OBJS[@]} ${KERNEL_OBJS[@]} ${PROTOCOL_OBJS[@]} ${APP_OBJS[@]} ${MAIN_OBJS[@]}" LINK_OPTIONS="-ldl" # # srs: # srs(simple rtmp server) over st(state-threads) BUILD_KEY="srs" APP_MAIN="srs_main_server" APP_NAME="srs" . auto/apps.sh # # bandwidth # bandwidth test tool, to test the bandwidth to server BUILD_KEY="bandwidth" APP_MAIN="srs_main_bandcheck" APP_NAME="bandwidth" . auto/apps.sh echo 'configure ok! ' ##################################################################################### # when configure success, prepare build ##################################################################################### # create objs/logs for ffmpeg to write log. mkdir -p ${SRS_OBJS}/logs ##################################################################################### # configure summary ##################################################################################### # linux shell color support. RED="\\e[31m" GREEN="\\e[32m" YELLOW="\\e[33m" BLACK="\\e[0m" # summary echo "" echo "configure summary:" if [ $SRS_HLS = YES ]; then echo -e "${GREEN}HLS over nginx is enabled${BLACK}" else echo -e "${YELLOW}warning: without HLS support${BLACK}" fi if [ $SRS_SSL = YES ]; then echo -e "${GREEN}rtmp complex handshake is enabled${BLACK}" else echo -e "${YELLOW}warning: without rtmp complex handshake support, donot support h264/aac to adobe flash player${BLACK}" fi if [ $SRS_FFMPEG = YES ]; then echo -e "${GREEN}live stream transcoding over FFMPEG is enabled${BLACK}" else echo -e "${YELLOW}warning: without live stream transcoding over FFMPEG support${BLACK}" fi if [ $SRS_HTTP = YES ]; then echo -e "${GREEN}http hooks callback over CherryPy is enabled${BLACK}" else echo -e "${YELLOW}warning: without http hooks callback over CherryPy support${BLACK}" fi if [ $SRS_RESEARCH = YES ]; then echo -e "${GREEN}research tools are builded${BLACK}" else echo -e "${BLACK}note: research tools are not builded${BLACK}" fi ##################################################################################### # next step ##################################################################################### ip=`ifconfig|grep "inet addr"| grep -v "127.0.0.1"|awk '{print $2}'|awk -F ':' 'NR==1 {print $2}'` echo "" echo "you can:" echo "\" make \" to build the srs(simple rtmp server)." echo "\" make help \" to get the usage of make" if [ $SRS_HLS = YES ]; then echo "\" sudo ./objs/nginx/sbin/nginx \" to start the nginx http server for hls" echo "\" http://$ip \" rtmp players(OSMF/JWPlayer)" fi if [ $SRS_FFMPEG = YES ]; then echo -e "\" ./objs/ffmpeg/bin/ffmpeg \" is used for live stream transcoding" fi if [ $SRS_HTTP = YES ]; then echo -e "\" python ./research/api-server/server.py 8085 \" to start the api-server" fi echo "\" ./objs/srs -c conf/srs.conf \" to start the srs live server"