From 3d56214133207e25e13d2a0357098d3fd7ddf3a1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?agentzh=20=28=E7=AB=A0=E4=BA=A6=E6=98=A5=29?= Date: Sun, 6 Mar 2011 14:37:22 +0800 Subject: [PATCH] checked in util/configure. --- util/configure | 344 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 344 insertions(+) diff --git a/util/configure b/util/configure index b4cdbb2..99a4f16 100644 --- a/util/configure +++ b/util/configure @@ -3,4 +3,348 @@ use strict; use warnings; +use File::Spec; + +sub shell (@); +sub cd ($); +sub auto_complete ($); +sub usage ($); + +cd "bundle"; + +my @modules = ( + [http_iconv => 'iconv-nginx-module', 'disabled'], + [http_echo => 'echo-nginx-module'], + [http_xss => 'xss-nginx-module'], + [ndk => 'ngx_devel_kit'], + [http_form_input => 'form-input-nginx-module'], + [http_encrypted_session => 'encrypted-session-nginx-module'], + [http_drizzle => 'drizzle-nginx-module'], + [http_postgres => 'drizzle-nginx-module', 'disabled'], + [http_lua => 'lua-nginx-module'], + [http_headers_more => 'headers-more-nginx-module'], + [http_srcache => 'srcache-nginx-module'], + [http_array_var => 'array-var-nginx-module'], + [http_memc => 'memc-nginx-module'], + [http_upstream_keepalive => 'upstream-keepalive-nginx-module'], + [http_auth_request => 'auth-request-nginx-module'], + [http_rds_json => 'rds-json-nginx-module'], +); + +my $without_resty_mods_regex; +{ + my $s = '^--without-(' + . join('|', + map { $_->[0] } + grep { @$_ == 2 && $_->[0] =~ /^http_/ } + @modules + ) + . ')_module$'; + + #warn "without regex: $s"; + + $without_resty_mods_regex = qr/$s/; +} + +my $with_resty_mods_regex; +{ + my $s = '^--with-(' + . join('|', + map { $_->[0] } + grep { @$_ == 3 && $_->[0] =~ /^http_/ } + @modules + ) + . ')_module$'; + + #warn "with regex: $s"; + + $with_resty_mods_regex = qr/$s/; +} + + +cd ".."; + +my $prefix = '/usr/local/openresty'; +my %resty_opts; + +my @ngx_opts; +for my $opt (@ARGV) { + if ($opt =~ /^--prefix=(.*)/) { + $prefix = $1; + + } elsif ($opt eq '--with-debug') { + $resty_opts{debug} = 1; + + } elsif ($opt eq '--help') { + usage 0; + + } elsif ($opt =~ $without_resty_mods_regex) { + die "No $1\n"; + $resty_opts{"no_http_$1"} = 1; + + } elsif ($opt eq '--without-ngx_devel_kit_module') { + $resty_opts{no_ndk} = 1; + + } elsif ($opt =~ $with_resty_mods_regex) { + $resty_opts{"http_$1"} = 1; + + } elsif ($opt eq '--with-luajit') { + $resty_opts{luajit} = 1; + + } elsif ($opt eq '--with-http_ssl_module') { + $resty_opts{http_ssl} = 1; + + } elsif ($opt =~ /^--\w.*/) { + push @ngx_opts, $opt; + + } else { + die "Invalid option $opt\n"; + } +} + +if (-d 'build') { + system("rm -rf build"); +} + +if (-f 'build') { + die "build/ directory already exists\n"; +} + +shell "cp -r bundle/ build/"; + +cd 'build'; + +my $ngx_dir = auto_complete "nginx"; + +cd $ngx_dir; + +my $ngx_prefix = "$prefix/nginx"; + +shell "./configure --prefix=$ngx_prefix" + . " --with-ld-opt='-Wl,-rpath=$ngx_prefix/lib'" + . build_resty_opts(\%resty_opts) + . " " . join(" ", @ngx_opts); + ; + +sub shell (@) { + print "@_\n"; + system(@_) == 0 or die "failed to run command @_\n"; +} + +sub auto_complete ($) { + my $name = shift; + my @dirs = glob "$name-*" or + die "No source directory found for $name\n"; + + if (@dirs > 1) { + die "More than one hits for $name: @dirs\n"; + } + + return $dirs[0]; +} + +sub cd ($) { + my $dir = shift; + print("cd $dir\n"); + chdir $dir or die "failed to cd $dir: $!\n"; +} + +sub build_resty_opts { + my $opts = shift; + + if ($opts->{no_ndk}) { + for my $name (qw(lua set_misc iconv lz_session form_input array_var)) { + if (! $opts->{"no_http_$name"}) { + warn "WARNING: ngx_http_${name}_module is automatically disabled ", + "because ngx_devel_kit_module is disabled.\n"; + $opts->{"no_http_$name"} = 1; + } + } + } + + if ($opts->{luajit}) { + $opts->{no_lua} = 1; + } + + if (! $opts->{no_http_drizzle}) { + $opts->{libdrizzle} = 1; + } + + if ($opts->{no_http_ssl} && $opts->{http_ssl}) { + die "--with-http_ssl_module conflicts with --without-http_ssl_module\n"; + } + + my $opts_line = ''; + + if ($resty_opts{debug}) { + $opts_line .= " --with-cc-opt='-O0' --with-debug"; + } else { + $opts_line .= " --with-cc-opt='-O2'"; + } +} + +sub usage ($) { + my $retval = shift; + my $msg = <<'_EOC_'; + --help this message + + --prefix=PATH set the installation prefix + + --with-debug enable the debugging logging and also enable -O0 + + --without-http_iconv_module disable ngx_http_iconv_module + --without-http_echo_module disable ngx_http_echo_module + --without-http_xss_module disable ngx_http_xss_module + --without-http_set_misc_module disable ngx_http_set_misc_module + --without-http_form_input_module disable ngx_http_form_input_module + --without-http_encrypted_session_module + disable ngx_http_encrypted_session_module + --without-http_drizzle_module disable ngx_http_drizzle_module + --without-http_lua_module disable ngx_http_lua_module + --without-http_headers_more_module disable ngx_http_headers_more_module + --without-http_srcache_module disable ngx_http_srcache_module + --without-http_array_var_module disable ngx_http_array_var_module + --without-http_memc_module disable ngx_http_memc_module + --without-http_upstream_keepalive_module + disable ngx_http_upstream_keepalive_module + --without-http_memc_module disable ngx_http_auth_request_module + --without-http_rds_json_module disable ngx_http_rds_json_module + --without-http_lz_st_module disable ngx_http_lz_st_module + --without-ngx_devel_kit_module disable ngx_devel_kit_module + --without-http_ssl_module disable ngx_http_ssl_module + + --with-http_postgres_module enable ngx_http_postgres_module + --with-luajit enable LuaJIT 2.0 + +Options directly inherited from nginx + + --sbin-path=PATH set path to the nginx binary file + --conf-path=PATH set path to the nginx.conf file + --error-log-path=PATH set path to the error log + --pid-path=PATH set path to nginx.pid file + --lock-path=PATH set path to nginx.lock file + + --user=USER set non-privilege user + for the worker processes + --group=GROUP set non-privilege group + for the worker processes + + --builddir=DIR set the build directory + + --with-rtsig_module enable rtsig module + --with-select_module enable select module + --without-select_module disable select module + --with-poll_module enable poll module + --without-poll_module disable poll module + + --with-file-aio enable file aio support + --with-ipv6 enable ipv6 support + + --with-http_realip_module enable ngx_http_realip_module + --with-http_addition_module enable ngx_http_addition_module + --with-http_xslt_module enable ngx_http_xslt_module + --with-http_image_filter_module enable ngx_http_image_filter_module + --with-http_geoip_module enable ngx_http_geoip_module + --with-http_sub_module enable ngx_http_sub_module + --with-http_dav_module enable ngx_http_dav_module + --with-http_flv_module enable ngx_http_flv_module + --with-http_gzip_static_module enable ngx_http_gzip_static_module + --with-http_random_index_module enable ngx_http_random_index_module + --with-http_secure_link_module enable ngx_http_secure_link_module + --with-http_degradation_module enable ngx_http_degradation_module + --with-http_stub_status_module enable ngx_http_stub_status_module + + --without-http_charset_module disable ngx_http_charset_module + --without-http_gzip_module disable ngx_http_gzip_module + --without-http_ssi_module disable ngx_http_ssi_module + --without-http_userid_module disable ngx_http_userid_module + --without-http_access_module disable ngx_http_access_module + --without-http_auth_basic_module disable ngx_http_auth_basic_module + --without-http_autoindex_module disable ngx_http_autoindex_module + --without-http_geo_module disable ngx_http_geo_module + --without-http_map_module disable ngx_http_map_module + --without-http_split_clients_module disable ngx_http_split_clients_module + --without-http_referer_module disable ngx_http_referer_module + --without-http_rewrite_module disable ngx_http_rewrite_module + --without-http_proxy_module disable ngx_http_proxy_module + --without-http_fastcgi_module disable ngx_http_fastcgi_module + --without-http_uwsgi_module disable ngx_http_uwsgi_module + --without-http_scgi_module disable ngx_http_scgi_module + --without-http_memcached_module disable ngx_http_memcached_module + --without-http_limit_zone_module disable ngx_http_limit_zone_module + --without-http_limit_req_module disable ngx_http_limit_req_module + --without-http_empty_gif_module disable ngx_http_empty_gif_module + --without-http_browser_module disable ngx_http_browser_module + --without-http_upstream_ip_hash_module + disable ngx_http_upstream_ip_hash_module + + --with-http_perl_module enable ngx_http_perl_module + --with-perl_modules_path=PATH set path to the perl modules + --with-perl=PATH set path to the perl binary + + --http-log-path=PATH set path to the http access log + --http-client-body-temp-path=PATH set path to the http client request body + temporary files + --http-proxy-temp-path=PATH set path to the http proxy temporary files + --http-fastcgi-temp-path=PATH set path to the http fastcgi temporary + files + --http-uwsgi-temp-path=PATH set path to the http uwsgi temporary files + --http-scgi-temp-path=PATH set path to the http scgi temporary files + + --without-http disable HTTP server + --without-http-cache disable HTTP cache + + --with-mail enable POP3/IMAP4/SMTP proxy module + --with-mail_ssl_module enable ngx_mail_ssl_module + --without-mail_pop3_module disable ngx_mail_pop3_module + --without-mail_imap_module disable ngx_mail_imap_module + --without-mail_smtp_module disable ngx_mail_smtp_module + + --with-google_perftools_module enable ngx_google_perftools_module + --with-cpp_test_module enable ngx_cpp_test_module + + --add-module=PATH enable an external module + + --with-cc=PATH set path to C compiler + --with-cpp=PATH set path to C preprocessor + --with-cc-opt=OPTIONS set additional options for C compiler + --with-ld-opt=OPTIONS set additional options for linker + --with-cpu-opt=CPU build for specified CPU, the valid values: + pentium, pentiumpro, pentium3, pentium4, + athlon, opteron, sparc32, sparc64, ppc64 + + --without-pcre disable PCRE library usage + --with-pcre force PCRE library usage + --with-pcre=DIR set path to PCRE library sources + --with-pcre-opt=OPTIONS set additional options for PCRE building + + --with-md5=DIR set path to md5 library sources + --with-md5-opt=OPTIONS set additional options for md5 building + --with-md5-asm use md5 assembler sources + + --with-sha1=DIR set path to sha1 library sources + --with-sha1-opt=OPTIONS set additional options for sha1 building + --with-sha1-asm use sha1 assembler sources + + --with-zlib=DIR set path to zlib library sources + --with-zlib-opt=OPTIONS set additional options for zlib building + --with-zlib-asm=CPU use zlib assembler sources optimized + for specified CPU, the valid values: + pentium, pentiumpro + + --with-libatomic force libatomic_ops library usage + --with-libatomic=DIR set path to libatomic_ops library sources + + --with-openssl=DIR set path to OpenSSL library sources + --with-openssl-opt=OPTIONS set additional options for OpenSSL building +_EOC_ + + if ($retval == 0) { + print $msg; + exit 0; + } + + warn $msg; + exit $retval; +}