Wordpress 2.5.1 500 错误解决方法
随时听人讲有500错误。
今天在楚云blog上重现了。
抓住机会debug。
结果很快出来:
当你第二次用同样的标题并且标题中含有多字节文字时,有很大机会触发wp一个死循环,然后服务器cpu直接到100%,当运行时间超过max_execution_time时候出现500错误。
死循环在这里:wp-include/post.php
...... if ( 'draft' != $post_status ) { $post_name_check = $wpdb->get_var($wpdb->prepare("SELECT post_name FROM $wpdb->posts WHERE post_name = %s AND post_type = %s AND ID != %d AND post_parent = %d LIMIT 1", $post_name, $post_type, $post_ID, $post_parent)); if ($post_name_check || in_array($post_name, $wp_rewrite->feeds) ) { $suffix = 2; do { $alt_post_name = substr($post_name, 0, 200-(strlen($suffix)+1)). "-$suffix"; // expected_slashed ($alt_post_name, $post_name, $post_type) $post_name_check = $wpdb->get_var($wpdb->prepare("SELECT post_name FROM $wpdb->posts WHERE post_name = '$alt_post_name' AND post_type = '$post_type' AND ID != %d AND post_parent = %d LIMIT 1", $post_ID, $post_parent)); $suffix++; } while ($post_name_check); $post_name = $alt_post_name; } }
死循环触发点:wp-include/wp-db.php
...... /** * Prepares a SQL query for safe use, using sprintf() syntax */ function prepare($args=NULL) { if ( NULL === $args ) return; $args = func_get_args(); $query = array_shift($args); $query = str_replace("'%s'", '%s', $query); // in case someone mistakenly already singlequoted it $query = str_replace('"%s"', '%s', $query); // doublequote unquoting $query = str_replace('%s', "'%s'", $query); // quote the strings array_walk($args, array(&$this, 'escape_by_ref')); return @vsprintf($query, $args); }
post_name 中的的多字节文字被 urlencode 成这样 "%e6%88%91%e6%93%8d%ef%bc%81",只要 % 后面跟了 bcdeufFosxX 中任意一个(覆盖了大半个中文区域),就造成 vsprintf 函数调用失败,返回 false,而上层的循环一直在等它返回一个非false的值,直到程序死掉。
解决方法很简单:
修改 wp-include/wp-db.php
用下面的代码替换掉之前贴出的代码:
...... /** * Prepares a SQL query for safe use, using sprintf() syntax */ function prepare($args=NULL) { if ( NULL === $args ) return; $args = func_get_args(); $query = array_shift($args); $query = str_replace("'%s'", '%s', $query); // in case someone mistakenly already singlequoted it $query = str_replace('"%s"', '%s', $query); // doublequote unquoting $query = str_replace('%s', "'%s'", $query); // quote the strings array_walk($args, array(&$this, 'escape_by_ref')); // 旧的方法会引起其他问题 // $query = preg_replace("#(%[0-f]{2})#sie", "urldecode('$1')", $query); // $query = @vsprintf($query, $args); // $query = preg_replace("#([\x80-\xff])#se", "strtolower(urlencode('$1'))", $query); // 新的方法只针对重复标题时的死循环问题 $reg = "#post_name = '((?:%[0-9a-f]{2})+.+)'#Usi"; if (preg_match($reg, $query, $match)) { $he = $match[1]; $hd = urldecode($he); $query = str_replace($he, $hd, $query); $query = @vsprintf($query, $args); $query = str_replace($hd, $he, $query); } else { $query = @vsprintf($query, $args); } return $query; }
后来楚云坚持认为wp可以不用修改任何原始代码解决所有问题,所以找到了下面的方法:
下载这个文件:db.tgz 解压后得到 db.php 将它放到 wp-content/ 下。
---------
或许这只是其中一个造成500的原因,下次遇到再说吧。
--------- update --------
补充,此db.php为2.5.1的,后来才知道2.5.1比2.5.0也有更新,不保证其他版本没有意外情况。
--------- update 2008/05/10 --------
发现bug,更新了方法以及db.php下载链接。以前的方法太粗暴,一些其他的查询也被强制转码造成数据错误。
解决方法:重新下载db.php或按照前文代码重新修改wp-db.php。已经出错的数据,可重新编辑保存。已知会引发错误的地方:http://yourwpuri/wp-admin/widgets.php (也就是说你使用了之前的 db 文件后,有设置过 widgets 功能,最好重新设置一遍)
新装 Leopard 安装开发环境全记录
前期工作
安装光盘里的 Xcode,或者下载 iPhone SDK,2.1G,包括了最新的 Xcode 和 iPhone SDK。
安装好后会有 apache-2.2.6 / php-5.2.5 / ruby-1.8.6 / rails-1.2.6 / python-2.5.1 / java-1.5.0_13 / sqlite-3.4.0 …… gcc 会有2个版本:4.0.1 和 4.2.1,默认 /usr/bin/gcc 软连到 gcc-4.0,我们先让默认的 gcc 改用 4.2(2007年1月就 release 了,Changelog)
cd /usr/bin sudo unlink gcc sudo ln -s gcc-4.2 gcc
设置全局编译参数,编辑 /etc/profile,加上下面的全局变量,保存后重启终端
export MACOSX_DEPLOYMENT_TARGET=10.5 export ARCHFLAGS='-arch x86_64' export CFLAGS='-arch x86_64 -O3 -pipe' export CXXFLAGS=$CFLAGS export LDFLAGS='-arch x86_64 -bind_at_load'
如果需要编译兼容 i386、ppc、ppc64 版本的(编译出来的文件会增大不少),只要加上相应的 -arch 即可
export CFLAGS="-arch ppc -arch ppc64 -arch i386 -arch x86_64 -O3 -pipe" export CXXFLAGS=$CFLAGS export LDFLAGS="-arch ppc -arch ppc64 -arch i386 -arch x86_64 -bind_at_load"
如果需要编译针对 CPU 优化的,Apple 全系列已经升级到 Intel Core Duo,所以可以加上以下参数
CHOST="x86_64-pc-linux-gnu"
CFLAGS="-march=nocona -O2 -pipe"
CXXFLAGS="${CFLAGS}"-O 使用 O3,其他详见 http://www.gentoo-wiki.com/Safe_Cflags
因此我自己编译的最终参数是
export MACOSX_DEPLOYMENT_TARGET=10.5 export ARCHFLAGS='-arch x86_64' export CFLAGS='-arch x86_64 -march=nocona -pipe -O3 -pipe' export CXXFLAGS=$CFLAGS export LDFLAGS='-arch x86_64 -bind_at_load'
Java
虽然 Apple 总算在 2008年2月 放出了 JDK6 Preview,但是问题还是非常多。我们还是用 BSD 的一个移植版本 Soylatte,直接下载 64-bit JDK for Mac OS X 10.5: soylatte16-amd64-1.0.2.tar.bz2 (Username: 'jrl',Password: 'I am a Licensee in good standing')
解压后放到 /usr/local/soylatte16-amd64,软连 /usr/local/java 到这个目录:
cd /usr/local; sudo ln -s soylatte16-amd64 java cd /System/Library/Frameworks/JavaVM.framework/Versions/; sudo mkdir soylatte16-amd64 cd soylatte16-amd64; sudo ln -s /usr/local/java Home; sudo ln -s ./Home/bin ./Commands cd ../A; sudo mv Commands Commands.bak; sudo ln -s ../CurrentJDK/Commands ./ cd ..; sudo unlink CurrentJDK; sudo ln -s soylatte16-amd64 CurrentJDK java -version
显示如下,Java 就算搞定了
java version "1.6.0_03-p3" Java(TM) SE Runtime Environment (build 1.6.0_03-p3-landonf_03_feb_2008_01_32-b00) Java HotSpot(TM) 64-Bit Server VM (build 1.6.0_03-p3-landonf_03_feb_2008_01_32-b00, mixed mode)
基本库和命令
libtool
curl http://ftp.gnu.org/gnu/libtool/libtool-1.5.26.tar.gz > libtool-1.5.26.tar.gz tar xzf libtool-1.5.26.tar.gz cd libtool-1.5.26 ./configure make sudo make install
zlib
curl http://www.zlib.net/zlib-1.2.3.tar.gz > zlib-1.2.3.tar.gz tar xzf zlib-1.2.3.tar.gz cd zlib-1.2.3 ./configure make sudo make install
openssl/libssl
curl http://www.openssl.org/source/openssl-0.9.8g.tar.gz > openssl-0.9.8g.tar.gz tar xzf openssl-0.9.8g.tar.gz cd openssl-0.9.8g ./config --prefix=/usr/local --openssldir=/openssl threads zlib-dynamic vi Makefile # OPTIONS 里去掉 no-sse2 来开启 CPU 的 SSE2 指令集支持 # CFLAG 里 -arch i386 改为 -arch x86_64 # SHARED_LDFLAGS 同上 make sudo make install cd /usr/local/bin sudo ln -s ../openssl/bin/* ./
wget
curl http://ftp.gnu.org/gnu/wget/wget-1.11.tar.bz2 > wget-1.11.tar.bz2 tar xjf wget-1.11.tar.bz2 cd wget-1.11.tar.bz2 ./configure --with-libssl-prefix=/usr/local/openssl make sudo make install
libpng
wget http://downloads.sourceforge.net/libpng/lpng1225.tar.bz2 -O libpng-1.2.25.tar.bz2 tar xjf libpng-1.2.25.tar.bz2 cd libpng-1.2.25 ./configure make sudo make install
libjpeg
wget http://freshmeat.net/redir/libjpeg/5665/url_tgz/jpegsrc.v6b.tar.gz tar xzf jpegsrc.v6b.tar.gz cd jpeg-6b cp /usr/share/libtool/config.sub . cp /usr/share/libtool/config.guess . ./configure --enable-shared --enable-static make sudo mkdir -p /usr/local/man/man1 sudo make install -lib
freetype
wget http://download.savannah.gnu.org/releases/freetype/freetype-2.3.5.tar.gz tar xzf freetype-2.3.5.tar.gz cd freetype-2.3.5 ./configure make sudo make install
fontconfig
wget http://fontconfig.org/release/fontconfig-2.5.91.tar.gz tar xzf fontconfig-2.5.91.tar.gz cd fontconfig-2.5.91 ./configure --prefix=/usr/local --with-zlib --with-jpeg --with-png --with-freetype --disable-dependency-tracking make sudo make install
gd2
wget http://www.libgd.org/releases/gd-2.0.35.tar.bz2 tar xjf gd-2.0.35.tar.bz2 cd gd-2.0.35 ./configure --with-fontconfig=/usr/local/bin --disable-dependency-tracking make sudo make install
ImageMagick
wget ftp://ftp.imagemagick.org/pub/ImageMagick/ImageMagick-6.3.9-7.tar.bz2 tar xjf ImageMagick-6.3.9-7.tar.bz2 cd ImageMagick-6.3.9 ./configure --with-fontconfig make sudo make install
mysql
wget http://dev.mysql.com/get/Downloads/MySQL-5.0/mysql-5.0.51a.tar.gz/from/http://mirror.services.wisc.edu/mysql/ tar xzf mysql-5.0.51a.tar.gz cd mysql-5.0.51a ./configure --with-mysql-user=mysql --with-mysql-group=mysql --with-innodb --with-archive-storage-engine --with-ndbcluster --with-zlib-dir=/usr/local --with-pthread --with-extra-charsets=utf8 --disable-dependency-tracking make sudo make install
neon
wget http://www.webdav.org/neon/neon-0.25.5.tar.gz tar xzf neon-0.25.5.tar.gz cd neon-0.25.5 ./configure --with-ssl=openssl make sudo make install
Berkeley DB
# 为了让 subversion-1.4.6 使用,只能用 db-4.4 版本的 wget http://download.oracle.com/berkeley-db/db-4.4.20.tar.gz tar xzf db-4.4.20.tar.gz cd db-4.4.20/build_unix make sudo make install cd /usr/local/; sudo ln -s BerkeleyDB.4.4 bdb
subversion
wget http://apache.mirror.phpchina.com/httpd/httpd-2.2.8.tar.bz2 tar xjf httpd-2.2.8.tar.bz2 wget http://subversion.tigris.org/downloads/subversion-1.4.6.tar.bz2 tar xjf subversion-1.4.6.tar.bz2 cd subversion-1.4.6 cp -r ../httpd-2.2.8/srclib/apr* ./ ./configure --with-apxs=/usr/sbin/apxs --with-berkeley-db=/usr/local/bdb --with-ssl make sudo make install
libevent
wget http://www.monkey.org/~provos/libevent-1.4.2-rc.tar.gz tar xzf libevent-1.4.2-rc.tar.gz cd libevent-1.4.2-rc ./configure make sudo make install
memcached
wget http://www.danga.com/memcached/dist/memcached-1.2.5.tar.gz tar xzf memcached-1.2.5.tar.gz cd memcached-1.2.5 ./configure make sudo make install
pcre
wget http://nchc.dl.sourceforge.net/sourceforge/pcre/pcre-7.6.tar.bz2 tar xjf pcre-7.6.tar.bz2 cd pcre-7.6 ./configure --enable-utf8 make sudo make install
pkg-config
wget http://pkgconfig.freedesktop.org/releases/pkg-config-0.23.tar.gz tar xzf pkg-config-0.23.tar.gz cd pkg-config-0.23 make sudo make install export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig:/usr/lib/pkgconfig
libxml2
wget ftp://xmlsoft.org/libxml2/libxml2-2.6.31.tar.gz tar xzf libxml2-2.6.31.tar.gz cd libxml2-2.6.31
lighttpd
wget http://www.lighttpd.net/download/lighttpd-1.4.19.tar.bz2 tar xjf lighttpd-1.4.19.tar.bz2 cd lighttpd-1.4.19 ./configure --with-openssl --with-zlib --without-bzip2 --with-pcre --with-gdbm --with-memcache --with-ldap make sudo make install
好像大功告成了,还缺啥嘛?
关羽、张飞的武功的来历
看三国最让人不解的是那些超一流武将从一登场就有超一流的武功,至于这些武功是怎么来的,罗老先生却惜墨如金,不像金庸的人物,武功都是一天天炼出来的。即使如全庸金康之流,笔下人物也还能喝点蛇血什么的,内功一下暴涨60年,总算有个交待。
三国武将的武功自然不是喝蛇血喝出来的,那是不是一天天炼出来的呢?武将之中,张飞关羽的早期经历写的稍微多一点,我们就以这哥俩为例作一分析。
张飞简历:“某姓张,名飞,字翼德。世居涿郡,颇有庄田,卖酒屠猪,专好结交天下豪杰。恰才见公看榜而叹,故此相问。”
关羽简历:“吾姓关,名羽,字长生,后改云长,河东解良人也。因本处势豪,倚势凌人,被吾杀了;逃难江湖,五六年矣。今闻此处招军破贼,特来应募。”
两位都没有提自己的武功,连“自幼习武”这句都没说。更重要的是随后的情节。刘关张决定起兵后,“云长造青龙偃月刀,又名”冷艳锯“,重八十二斤。张飞造丈八点钢矛。”你看,在这之前,两位连兵器都没有。关羽还好说,毕竟扛着八十二斤的大刀逃难有点困难。张飞就不该了,有钱有房,要是练武,不至于连一杆像样的矛都造不起。
可见他们平时并不练武。
那关羽张飞的武功到底是怎么来的呢?
他们的武功来自他们的职业!
据北京体育大学武术学院的网站,“马克思主义认为,人类的生产活动是最基本的实践活动,是决定其他一切活动的东西。武术的产生,从来就是有生产活动决定的。”
关羽张飞也不能有例外。
汉末,武术还没有系统化,不具备通过向师傅学习成为武林高手的条件。要想成为高手,一要有天生体格,二要悟性高,能从生产活动中领悟攻防技术。以此为指导,我们来分析张飞关羽的武功与职业的关系。
张飞的主要职业是杀猪。杀猪要用杀猪刀。和张飞的兵器不同,但技术特点一致。杀猪时不是用杀猪刀砍,而是捅。所以本质上杀猪刀不是刀,而是和矛类似。猪杀死后要去毛,去毛前要给猪充气,使皮肤绷紧。通常做法是用铁钎从后啼一直捅到腹部,然后拔出铁钎,往腹部充气。张飞没有打气筒,只能用嘴吹。铁钎就是小号的矛,所以张飞自然选矛作武器。
另外,长期给猪吹气,张飞练就了巨大的肺活量,才能在长板坡前一声吼,吓退曹操百万兵。
三国演义中没有提关羽的职业,但大家都知道,关羽在逃亡途中卖过枣。卖了五六年的枣,怎么说也是一种职业了。关羽不擅生意,买不出好价钱,但仍能维持生计,说明其进货渠道不一般。如果正常付款进货,本钱早就陪光了。关羽有案在身,不大可能去抢枣。再说,要抢也应该去抢钱。关羽只能自己去枣园打枣。枣园是地主豪强的,打他的枣就是斗地主,不用付钱,心安理得。为了少惹麻烦,关羽总是穿一身绿,见有人来,便爬到枣树上躲起来。一身绿衣,一张枣红脸,藏在枣树上谁也别想看着。
想必关羽不会爱惜枣树,只顾拿大竹竿一通猛打。上高中时半夜拿大竹竿偷过学校的柿子,深知在枝叶中挥动竹竿需要多大的力气。关羽如此打了五六年,练就无穷臂力。从技术特点看,挥动竹竿和挥动大刀完全相同。所以关羽选择了八十二斤的大刀。
打枣成就了关羽的武功,也造成关羽武功的严重缺陷。
关羽曾和赵云在牛头山打过一仗。这场战斗发生在一条山道上,山道两旁全是树。
“关羽奋然上马,倒提青龙刀,凤目圆睁,蚕眉直竖,直冲卧牛山。遍山树枝如波开浪裂,关公径奔一白杨树。赵云见关羽不来斗将,却入无人之境,方欲问时,关羽赤兔马快,早到树前,手起一刀,将白杨树折做两段。”
关羽的武功源自打枣。在冲锋时精神高度集中,道旁的树木钩起了本能反应,挥刀直奔树木而去,大大出了一回洋相。
关羽也因此弱点被擒,丢了性命。
关羽冲出麦城,沿一条山路逃跑,不想赤兔马被绊倒,关羽落马被马忠所擒。关羽即使落马,但功夫仍在,马忠乃无名之辈,如何擒得关羽?想马超也曾步战,杀得韩遂及手下五将血肉横飞。关羽虽疲惫,对付一个马忠理应绰绰有余。怎奈又是山路,山路两旁又是树木。关羽举刀欲战,却见两旁树木众多,一时不知该砍哪棵。犹豫半分钟,早被马忠绑定。
总结:通过分析关羽张飞的武功特点及典型战例,我们得出结论,关羽张飞的武功源自他们的职业。我们相信该结论可推广到所有三国武将。根据此结论,我们可以分析各武将的弱点,从而设计合理战术,轻松打败他们。
交叉编译jpeg库的问题
./configure --enable-shared --enable-static
加了 --enable-shared 或者 --enable-statics 就会报
ltconfig: cannot guess host type; you must specify one
方法是安装最新版的 libtool 然后
cp /usr/share/libtool/config.sub . cp /usr/share/libtool/config.guess . ./configure --enable-shared --enable-static make; make install
洪七公生平简介
洪七公原名洪七,他不光杀了王重阳,江南5怪其实都是他杀的
王重阳的秘密是他偷走了辟邪剑法,然后就亲自练了,他无法躲闪林朝英的纠缠,就只好以 "国将不国,何以家为" 的口号躲避她,由于练了辟邪剑法,王重阳轻功极高,再加上他爱吃素食,整天神神秘秘的,所以大家叫他 "中神通。"
中神通有一个徒弟,一个传授了辟邪剑法的徒弟,就是洪七, 由于洪七也自宫了,所以中神通叫他 "洪七公公"
师徒二人惺惺相惜,到也相处的融洽,直到有一天,中神通的辟邪剑法练到了东方不败的地步,他开始把洪( 练辟邪剑法的人最终会发展到两个层次,一是东方不败的类型,就是对别人有性骚扰的, 二是岳不群,林平之类型的,对别人无害)
洪七公公迫不得己杀了中神通,碰巧给江南7怪撞见了,7怪看到辟邪剑法怪异的情景,急忙逃跑了, 而洪七公公只看到了7个人的身影,作贼心虚,就没有追赶。
江南7怪害怕辟邪剑法,一直跑到了大漠,于是就躲了起来,他们一边训练郭靖,一边苦练功夫,时刻准备敌人来灭口,这一躲就是18年.
中神通已死,全真教也待不下去了,洪七公公还要暗中查访那七个人,到哪里立足呢?,丐帮是个好去处,入丐帮的时候,他将名字中一个’公‘字去掉,就成了洪七公
洪七公生性好学,每天勤学苦练,他一腔精力无处发泄,加上辟邪剑法的轻功,洪七公很快就练就了打狗棒法和降龙18掌,并且当上了丐帮帮主
Leopard 编译 universal php5
因为自带的php没有gd所以要重编
因为服务器用的是x86_64 httpd+php5所以要编 x86_64
因为自带的httpd+php是 universal ,所以要这样做
自带的httpd很好,所以不搞它了
参考:
ppc就不要了
export MACOSX_DEPLOYMENT_TARGET=10.5
export ARCHFLAGS='-arch i386 -arch x86_64'
export CFLAGS='-arch i386 -arch x86_64 -O3 -pipe'
export CXXFLAGS='-arch i386 -arch x86_64 -O3 -pipe'
export LDFLAGS='-arch i386 -arch x86_64 -bind_at_load'
make时候可能出现这样的提示:
gcc-4.0: -E, -S, -save-temps and -M options are not allowed with multiple -arch flags
在 configure 的时候加上 --disable-dependency-tracking
'./configure' \
'--prefix=/usr' \
'--with-config-file-path=/private/etc' \
'--sysconfdir=/private/etc' \
'--with-apxs2=/usr/sbin/apxs' \
'--with-iconv=/usr/local' \
'--with-mhash=/usr/local' \
'--with-gettext=/usr/local' \
'--with-mysql=/usr/local' \
'--with-mysqli=/usr/local/bin/mysql_config' \
'--with-pdo-mysql=/usr/local' \
'--with-openssl=/usr' \
'--with-zlib=/usr' \
'--with-curl=/usr' \
'--with-gd' \
'--with-png-dir=/usr/X11' \
'--with-jpeg-dir=/usr/local' \
'--with-freetype-dir=/usr/X11' \
'--with-xpm-dir=/usr/X11' \
'--enable-gd-native-ttf' \
'--enable-mbstring' \
'--enable-sockets' \
已有的库就不重装了,只需自己安装 gawk, libiconv, mhash, gettext, mysql, jpeg
需要特别注意:系统自带的liviconv有问题,需要自己编一份到/usr/local(小心不要覆盖以前的,否则可能连sh都不能执行了),php在configure时就算指定了 --with-iconv=/usr/local 它还是首先找到 /usr/include/iconv.h ,而且 --help 里只提到 --with-iconv-dir=,应该使用 --with-iconv=
解决方法:
sh#mv /usr/include/iconv.h /usr/include/iconv.h.bak
Macosx Universal Binaries 减肥瘦身
三种方法
ditto –rsrc –arch i386 /Applications/Foo.app /Application/Foo-ppc.app
lipo -thin i386
lipo -remove ppc
iPhone的通讯录以拼音排序
在iphone中安装php
将代码保存为py.php
ssh 登陆iphone或者在iphone安装Term-vt100
执行 php py.php 等待重启完成
结束
支持的中文貌似很有限,拼音表的处理看来要自己搞一个了,这个在网上找的。
py.php
/** * @desc 将iPhone的通讯录以拼音排序, 需要安装PHP * @author Kafeifei <http://www.nimab.org> * @version 0.2beta */ error_reporting(0); $sqlite_file = '/private/var/root/Library/AddressBook/AddressBook.sqlitedb'; // 1.1.3 以前的版本 $sqlite_file = '/private/var/mobile/Library/AddressBook/AddressBook.sqlitedb'; // 1.1.3 以后的版本 if (!file_exists($sqlite_file)) { println("SQLiteDB:File Notfound."); die; } $dsn = "sqlite:{$sqlite_file}"; try { $dbh = new PDO($dsn); println("Open {$dsn} OK."); } catch (Exception $e) { println("Open {$dsn} ERROR:".$e->getMessage()); die; } $stmt = $dbh->query("SELECT ROWID, First, Last FROM ABPerson"); while ($person = $stmt->fetch(PDO::FETCH_ASSOC)) { $first = ucfirst(Py::parse(u2g($person['First']))); $last = ucfirst(Py::parse(u2g($person['Last']))); $dbh->query("update ABPerson set FirstSort='{$first}', LastSort='{$last}' where ROWID = {$person['ROWID']} ;\n"); println("{$person['ROWID']}\tOK."); } println("done."); println("rebooting..."); system('launchctl stop com.apple.SpringBoard'); function u2g($str) { return iconv('utf-8', 'gbk', $str); } function println($str) { echo "$str\n"; flush(); } class Py { private static $table = array( array("a",-20319), array("ai",-20317), array("an",-20304), array("ang",-20295), array("ao",-20292), array("ba",-20283), array("bai",-20265), array("ban",-20257), array("bang",-20242), array("bao",-20230), array("bei",-20051), array("ben",-20036), array("beng",-20032), array("bi",-20026), array("bian",-20002), array("biao",-19990), array("bie",-19986), array("bin",-19982), array("bing",-19976), array("bo",-19805), array("bu",-19784), array("ca",-19775), array("cai",-19774), array("can",-19763), array("cang",-19756), array("cao",-19751), array("ce",-19746), array("ceng",-19741), array("cha",-19739), array("chai",-19728), array("chan",-19725), array("chang",-19715), array("chao",-19540), array("che",-19531), array("chen",-19525), array("cheng",-19515), array("chi",-19500), array("chong",-19484), array("chou",-19479), array("chu",-19467), array("chuai",-19289), array("chuan",-19288), array("chuang",-19281), array("chui",-19275), array("chun",-19270), array("chuo",-19263), array("ci",-19261), array("cong",-19249), array("cou",-19243), array("cu",-19242), array("cuan",-19238), array("cui",-19235), array("cun",-19227), array("cuo",-19224), array("da",-19218), array("dai",-19212), array("dan",-19038), array("dang",-19023), array("dao",-19018), array("de",-19006), array("deng",-19003), array("di",-18996), array("dian",-18977), array("diao",-18961), array("die",-18952), array("ding",-18783), array("diu",-18774), array("dong",-18773), array("dou",-18763), array("du",-18756), array("duan",-18741), array("dui",-18735), array("dun",-18731), array("duo",-18722), array("e",-18710), array("en",-18697), array("er",-18696), array("fa",-18526), array("fan",-18518), array("fang",-18501), array("fei",-18490), array("fen",-18478), array("feng",-18463), array("fo",-18448), array("fou",-18447), array("fu",-18446), array("ga",-18239), array("gai",-18237), array("gan",-18231), array("gang",-18220), array("gao",-18211), array("ge",-18201), array("gei",-18184), array("gen",-18183), array("geng",-18181), array("gong",-18012), array("gou",-17997), array("gu",-17988), array("gua",-17970), array("guai",-17964), array("guan",-17961), array("guang",-17950), array("gui",-17947), array("gun",-17931), array("guo",-17928), array("ha",-17922), array("hai",-17759), array("han",-17752), array("hang",-17733), array("hao",-17730), array("he",-17721), array("hei",-17703), array("hen",-17701), array("heng",-17697), array("hong",-17692), array("hou",-17683), array("hu",-17676), array("hua",-17496), array("huai",-17487), array("huan",-17482), array("huang",-17468), array("hui",-17454), array("hun",-17433), array("huo",-17427), array("ji",-17417), array("jia",-17202), array("jian",-17185), array("jiang",-16983), array("jiao",-16970), array("jie",-16942), array("jin",-16915), array("jing",-16733), array("jiong",-16708), array("jiu",-16706), array("ju",-16689), array("juan",-16664), array("jue",-16657), array("jun",-16647), array("ka",-16474), array("kai",-16470), array("kan",-16465), array("kang",-16459), array("kao",-16452), array("ke",-16448), array("ken",-16433), array("keng",-16429), array("kong",-16427), array("kou",-16423), array("ku",-16419), array("kua",-16412), array("kuai",-16407), array("kuan",-16403), array("kuang",-16401), array("kui",-16393), array("kun",-16220), array("kuo",-16216), array("la",-16212), array("lai",-16205), array("lan",-16202), array("lang",-16187), array("lao",-16180), array("le",-16171), array("lei",-16169), array("leng",-16158), array("li",-16155), array("lia",-15959), array("lian",-15958), array("liang",-15944), array("liao",-15933), array("lie",-15920), array("lin",-15915), array("ling",-15903), array("liu",-15889), array("long",-15878), array("lou",-15707), array("lu",-15701), array("lv",-15681), array("luan",-15667), array("lue",-15661), array("lun",-15659), array("luo",-15652), array("ma",-15640), array("mai",-15631), array("man",-15625), array("mang",-15454), array("mao",-15448), array("me",-15436), array("mei",-15435), array("men",-15419), array("meng",-15416), array("mi",-15408), array("mian",-15394), array("miao",-15385), array("mie",-15377), array("min",-15375), array("ming",-15369), array("miu",-15363), array("mo",-15362), array("mou",-15183), array("mu",-15180), array("na",-15165), array("nai",-15158), array("nan",-15153), array("nang",-15150), array("nao",-15149), array("ne",-15144), array("nei",-15143), array("nen",-15141), array("neng",-15140), array("ni",-15139), array("nian",-15128