source: trunk/devel/run

Last change on this file was 1532, checked in by moo, 5 days ago

define XCACHE_DEBUG in phpized

  • Property svn:executable set to *
File size: 8.0 KB
Line 
1#!/bin/bash
2# this script is for developers only
3
4set -e
5MAKE=/usr/bin/make
6
7true() { # {{{1
8    return 0
9}
10
11hi() { # {{{1
12    colors=(4 2 3 5 6 7 8 9)
13    re=()
14    i=0
15    for r in "$@"; do
16        ((color=$i % ${#colors[@]})) || true
17        color=${colors[$color]}
18        r="${r/\#/\\#}"
19        r="s#$r#[4${color}m[31m\0[0m#g"
20        re[$i]="-e$r"
21        ((i=i+1))
22    done
23    sed -ur "${re[@]}"
24}
25hiecho() { # {{{1
26    echo "[32m""$@""[0m"
27}
28
29# }}}
30
31stopfpm() { # {{{1
32    if [[ -f $1 ]]; then
33        local pid=`cat $1 2>/dev/null || true`
34        if [[ $pid -gt 0 ]]; then
35            hiecho Stopping fpm $pid @ $1
36            kill $pid || true
37        fi
38    fi
39}
40
41xtest() { # {{{1
42    $MAKE ${MAKEOPTS} -f devel/test.mak
43}
44
45prep() { # {{{1
46    $MAKE ${MAKEOPTS} -f devel/prepare.mak "$@"
47}
48
49mergepo() { # {{{1
50    prep
51    local i
52    find htdocs -iname '*.po' | while read -r i; do
53        if [[ -f $i-merged ]]; then
54            mv $i-merged $i
55        fi
56    done
57}
58
59po2php() { # {{{1
60    mergepo
61
62    local phpfile
63    find htdocs -iname '*.po' | while read -r i; do
64        phpfile=${i/.po/.php}
65        devel/po2php.awk < $i > $phpfile.tmp
66        mv $phpfile.tmp $phpfile
67    done
68}
69
70updatedeps() { # {{{1
71    pwd=$(readlink -f "$(pwd)")
72    builddir=$(readlink -f ../trunk-php5-debug-zts)
73    if [[ -z $builddir ]]; then
74        hiecho required ../trunk-php5-debug-zts not found
75        return 1
76    fi
77    find . -iname \*.c | LANG=C sort | while read -r sourceFile; do
78        sourceFile=${sourceFile#./}
79        {
80            case "$sourceFile" in
81            includes.c)
82                echo '$(XCACHE_INCLUDES_I)'
83                ;;
84            esac
85            echo ${sourceFile%.c}.lo '$(builddir)/'${sourceFile%.c}.lo:
86            hiecho "Checking $sourceFile ..." >&2
87            for dependency in $(gcc -DHAVE_XCACHE_TEST -DHAVE_XCACHE_DPRINT -DXCACHE_DEBUG -MM $sourceFile -I$PHPSDIR/$phpbasename/include/php/{,main,Zend,TSRM} -I. -I${builddir} -MG | sed 's#.*:##g' | sed 's#\\##g'); do
88                dependency=$(readlink -f "$dependency")
89                case "$dependency" in
90                $pwd/*)
91                    dependency=${dependency#$pwd/}
92                    ;;
93                $builddir/*)
94                    dependency="\$(builddir)/"${dependency#$builddir/}
95                    ;;
96                esac
97
98                case "$dependency" in
99                *xc_const_string_opcodes_php*)
100                    for dependency in xcache/xc_const_string_*.h; do
101                        echo '$(srcdir)/'$dependency
102                    done
103                    ;;
104
105                /*) ;;
106                $sourceFile) ;;
107
108                xc_processor.h|\$\(builddir\)/xc_processor.h)
109                    echo '$(XCACHE_PROC_H)'
110                    ;;
111                xc_processor.c.h|\$\(builddir\)/xc_processor.c.h)
112                    echo '$(XCACHE_PROC_C)'
113                    ;;
114                *)
115                    if [[ -r $dependency ]]; then
116                        echo '$(srcdir)/'$dependency
117                    else
118                        hiecho "$dependency not found" >&2
119                    fi
120                esac
121            done | LANG=C sort | uniq
122        } | xargs
123    done > Makefile.frag.deps
124}
125# }}}1
126
127hiecho "Loading config devel/run.cfg"
128. devel/run.cfg
129PHPSDIR=${PHPSDIR:-$HOME/test}
130
131if [[ $# -eq 0 ]]; then
132    set -- "${args[@]}"
133fi
134
135basename=$(basename $(pwd))
136case "$basename" in
137*-*)
138    # in build dir, starts from src dir
139    dirs="${basename#*-}"
140    xcachesrcdir=../${basename%%-*}
141    cd $xcachesrcdir
142    ;;
143*)
144    # in src dir
145    dirs=${dirs:-php5-debug-zts}
146    xcachesrcdir=../$basename
147    ;;
148esac
149
150touch devel.pid
151svn propget svn:ignore . > .svnignore
152
153# ==========================
154
155do_phpize() { # {{{1
156    if [[ ! -x $PHPSDIR/$phpbasename/bin/phpize ]]; then
157        hiecho $PHPSDIR/$phpbasename/bin/phpize not found
158        exit
159    fi
160    export PATH=$PHPSDIR/$phpbasename/bin:$PATH
161    local pedantic=
162    case $phpbasename in
163    php5|php5.4) pedantic=-pedantic-errors;;
164    *) pedantic=-pedantic;;
165    esac
166    phpize --clean \
167    && phpize \
168    && CFLAGS="$CFLAGS -g -O0 $pedantic -Wno-variadic-macros -Wno-long-long -Wall -Wno-unused-parameter -Wno-unused-function -W -Wshadow -Werror=implicit-function-declaration -std=c89 -D_GNU_SOURCE -D_POSIX_SOURCE -Dinline=" ./configure \
169        --enable-xcache-cacher \
170        --enable-xcache-optimizer \
171        --enable-xcache-encoder \
172        --enable-xcache-decoder \
173        --enable-xcache-disassembler \
174        --enable-xcache-assembler \
175        --enable-xcache-coverager \
176        --enable-xcache-test \
177        --enable-xcache-dprint \
178        --enable-xcache-constant
179}
180do_make() { # {{{1
181    if [[ ! -f Makefile ]]; then
182        do_phpize
183    fi
184    LANG=C $MAKE $MAKEOPTS "$@" 2>&1 \
185    | sed -ur \
186        -e 's#Werror=implicit-function-declaration#We/rror=i/mplicit-function-declaration#' \
187        -e 's#-pedantic-errors#-pedantic-e/rrors#' \
188        -e 's#\./xc_processor\.h#'$PWD'/xc_processor.h#' \
189        -e 's#\./xc_processor\.c\.h#'$PWD'/xc_processor.c.h#' \
190    | hi error implicit warn FAIL
191    ret=${PIPESTATUS[0]}
192    if [[ $ret -ne 0 ]]; then
193        exit $ret
194    fi
195}
196cleanfpm() { # {{{1
197    echo
198    stopfpm $pidfile
199}
200# }}}
201run() {
202    pidfile=$xcachesrcdir/devel.pid
203
204    # prepare {{{1
205    case "$1" in
206    phpize)
207        if [[ -r Makefile ]]; then
208            $MAKE $MAKEOPTS xcachesvnclean || true
209        fi
210        ;;
211    esac
212
213    rm -f php-src
214    find -L . -type d -print0 | xargs -0 rmdir -p 2>/dev/null || true
215    find -L . -type l -print0 | xargs -0 rm -fv
216    lndir "$xcachesrcdir" >/dev/null || true
217    find . -iname .\*.swp -print0 | xargs -0 rm -f
218    ln -snf ~/src/php/${phpbasename%%-*} php-src
219    for i in ~/src/php/$phpbasename/sapi/cgi/php{,-cgi}; do
220        if [[ -r $i ]]; then
221            ln -snf "$i" php-cgi
222        fi
223    done
224    ln -snf ~/src/php/$phpbasename/sapi/cli/php php-cli
225    f=~/src/php/$phpbasename/sapi/cli/php; [ -f "$f" ] && ln -snf "$f" php-cli
226    f=~/src/php/$phpbasename/sapi/fpm/php-fpm; [ -f "$f" ] && ln -snf "$f" php-fpm
227
228    case "$1" in
229    phpized) CFLAGS=-DXCACHE_DEBUG do_phpize; return $?;;
230    phpize) do_phpize; return $?;;
231    make) shift; do_make "$@"; return $?;;
232    *) do_make;;
233    esac
234    # }}}1
235
236    if [[ -z $1 ]]; then
237        set -- devel/sample.cpp.php
238    fi
239
240    cmd=()
241    phpApp=()
242    tracer=()
243
244    # run utils {{{1
245    case "$1" in
246    retest)
247        shift
248        lastResult=$(ls php_test_results_*.txt | LANG=C sort | tail -n1)
249        $MAKE $MAKEOPTS xcachetest "$@" TESTS="$(grep '^/.*\.phpt$' $lastResult | uniq | xargs)"
250        return
251        ;;
252    test)
253        shift
254        case "$1" in
255        *.phpt)
256            $MAKE $MAKEOPTS xcachetest TEST_ARGS=-v TESTS="$*"
257            return
258            ;;
259        */)
260            $MAKE $MAKEOPTS xcachetest TESTS="$*"
261            return
262            ;;
263        *)
264            $MAKE $MAKEOPTS xcachetest
265            return
266            ;;
267        esac
268        ;;
269    esac
270    # }}}
271    # pick tracer {{{1
272    case "$1" in
273    ltr*)
274        shift
275        export USE_ZEND_ALLOC=0
276        tracer=(ltrace -s1024 -e malloc,realloc,free,write)
277        ;;
278    str*)
279        shift
280        tracer=(strace -s1024 -T)
281        ;;
282    gdb)
283        shift
284        #USE_ZEND_ALLOC=0
285        tracer=(gdb --args)
286        ;;
287    val*)
288        shift
289        export USE_ZEND_ALLOC=0
290        export ZEND_DONT_UNLOAD_MODULES=1
291        tracer=(valgrind -v --gen-suppressions=all)
292        ;;
293    esac
294
295    # pick sapi {{{1
296    case "$phpbasename" in
297    *-apache1*)
298        cmd=($HOME/apache1/bin/httpd -X)
299        ;;
300    *-apache*)
301        echo "Don't know how to run apache"
302        exit 1
303        ;;
304    *)
305        case "$1" in
306        dc)
307            shift
308            cmd=(./php-cli -c devel.ini)
309            phpApp=(./bin/phpdc.phpr)
310            ;;
311        dop)
312            shift
313            cmd=(./php-cli -c devel.ini)
314            phpApp=(./bin/phpdop.phpr)
315            ;;
316        fcgi)
317            shift
318            cmd=(./php-cgi -q -c devel.ini)
319            set -- -b 1026
320            ;;
321        fpm)
322            shift
323            cmd=(./php-fpm -c devel.ini -y devel.fpm -g $(readlink -f $pidfile))
324            set --
325            ;;
326        *)
327            cmd=(./php-cgi -q -c devel.ini)
328            ;;
329        esac
330
331        "${cmd[@]}" -v || true
332    esac
333
334    # hack sample.cpp.php {{{1
335    case "$1" in
336    *.cpp.php)
337        < "$1" \
338        sed -r -e 's#__#____#g' \
339        | cpp -C -P -traditional-cpp -DPHP_VERSION=$phpVersion \
340        | sed -r -e 's#^ +##g' -e 's#\t +#\t#g' -e 's#____#__#g' > devel.php || exit $?
341        shift
342        set -- devel.php "$@"
343        ;;
344    esac
345
346    # run {{{1
347    set -- "${tracer[@]}" "${cmd[@]}" "${phpApp[@]}" "$@"
348
349    case "${cmd[0]}" in
350    *php-fpm*)
351        stopfpm
352        hiecho Starting fpm "$@" ...
353        "$@" | tee output.php
354        echo -n "Ctrl-C to stop"
355        trap cleanfpm SIGINT SIGTERM exit
356        cat > /dev/null || true
357        stopfpm
358        return
359        ;;
360    *)
361        hiecho "$@"
362        case "${tracer[@]}" in
363        gdb*|val*)
364            "$@"
365            ;;
366        *)
367            "$@" | tee output.php
368            ;;
369        esac
370        ;;
371    esac
372    # }}}
373}
374
375for phpbasename in "${dirs[@]}"; do
376    phpVersion=${phpbasename%%-*}
377    phpVersion=${phpVersion##php}
378    phpVersion=${phpVersion/./}
379    case "$phpVersion" in
380    ??) phpVersion="${phpVersion}0";;
381    ?) phpVersion="${phpVersion}00";;
382    esac
383
384    # devel actions
385    case "$1" in
386    prep*) shift; prep "$@"; exit;;
387    tags) shift; rm -f tags; prep tags "$@"; exit;;
388    po2php) po2php; exit;;
389    mergepo) mergepo; exit;;
390    dep*) updatedeps; exit;;
391    xtest) xtest; exit;;
392    stopfpm) stopfpm devel.pid; exit;;
393    esac
394
395    mkdir -p ${xcachesrcdir}-${phpbasename}
396    cd ${xcachesrcdir}-${phpbasename} || exit
397    lndir ${xcachesrcdir} >/dev/null || true
398
399    pwd
400    run "$@"
401done
Note: See TracBrowser for help on using the repository browser.