Go to:
Gentoo Home
Documentation
Forums
Lists
Bugs
Planet
Store
Wiki
Get Gentoo!
Gentoo's Bugzilla – Attachment 222691 Details for
Bug 308481
www-server/nginx-0.7.65 new ebuild with useflag expansion
Home
|
New
–
[Ex]
|
Browse
|
Search
|
Privacy Policy
|
[?]
|
Reports
|
Requests
|
Help
|
New Account
|
Log In
[x]
|
Forgot Password
Login:
[x]
ebuild with useflag expansion
nginx-0.7.65.ebuild (text/plain), 8.48 KB, created by
Chris Beswick
on 2010-03-08 16:07:40 UTC
(
hide
)
Description:
ebuild with useflag expansion
Filename:
MIME Type:
Creator:
Chris Beswick
Created:
2010-03-08 16:07:40 UTC
Size:
8.48 KB
patch
obsolete
># Copyright 1999-2010 Gentoo Foundation ># Distributed under the terms of the GNU General Public License v2 ># $Header: $ > ># ruby-ng.eclass only supports EAPI 2 >EAPI="2" > ># ruby is needed for passenger and must be setup before we inherit the eclass >USE_RUBY="ruby18 ruby19 ree18" >RUBY_OPTIONAL="yes" >MODULE_PASSENGER_P="passenger-2.2.11" > >inherit eutils ssl-cert toolchain-funcs perl-module ruby-ng flag-o-matic > >DESCRIPTION="Robust, small and high performance http and reverse proxy server" >HOMEPAGE="http://nginx.net/" >SRC_URI="http://sysoev.ru/nginx/${P}.tar.gz \ > nginx_modules_http_passenger? ( mirror://rubyforge/passenger/${MODULE_PASSENGER_P}.tar.gz )" > >LICENSE="BSD" >SLOT="0" >KEYWORDS="amd64 ppc x86" >IUSE="debug +http +http-cache ipv6 +pcre ssl" > ># list of modules dumped from configure --help >NGINX_MODULES_HTTP_STD="charset gzip ssi userid access auth_basic autoindex geo map referer rewrite proxy fastcgi memcached limit_zone limit_req empty_gif browser upstream_ip_hash" >NGINX_MODULES_HTTP_OPT="realip addition xslt image_filter geoip sub dav flv gzip_static random_index secure_link stub_status perl" >NGINX_MODULES_HTTP_3RD="passenger" >NGINX_MODULES_MAIL_OPT="imap pop3 smtp" > >for module in $NGINX_MODULES_HTTP_STD; do > IUSE="${IUSE} +nginx_modules_http_${module}" >done > >for module in $NGINX_MODULES_HTTP_OPT; do > IUSE="${IUSE} nginx_modules_http_${module}" >done > >for module in $NGINX_MODULES_HTTP_3RD; do > IUSE="${IUSE} nginx_modules_http_${module}" >done > >for module in $NGINX_MODULES_MAIL_OPT; do > IUSE="${IUSE} nginx_modules_mail_${module}" >done > >DEPEND="ssl? ( dev-libs/openssl ) > pcre? ( >=dev-libs/libpcre-4.2 ) > http-cache? ( userland_GNU? ( dev-libs/openssl ) ) > nginx_modules_http_geo? ( dev-libs/geoip ) > nginx_modules_http_gzip? ( sys-libs/zlib ) > nginx_modules_http_gzip_static? ( sys-libs/zlib ) > nginx_modules_http_perl? ( >=dev-lang/perl-5.8 ) > nginx_modules_http_rewrite? ( >=dev-libs/libpcre-4.2 ) > nginx_modules_http_secure_link? ( userland_GNU? ( dev-libs/openssl ) ) > nginx_modules_http_xslt? ( dev-libs/libxml2 dev-libs/libxslt ) > nginx_modules_http_passenger? ( > >=dev-ruby/rubygems-0.9.0 > >=dev-ruby/rake-0.8.1 > >=dev-ruby/fastthread-1.0.1 > >=dev-ruby/rack-1.0.0 )" >RDEPEND="${DEPEND}" > >pkg_setup() { > ebegin "Creating nginx user and group" > enewgroup ${PN} > enewuser ${PN} -1 -1 -1 ${PN} > eend ${?} > > if use ipv6; then > ewarn "Note that ipv6 support in nginx is still experimental." > ewarn "Be sure to read comments on gentoo bug #274614" > ewarn "http://bugs.gentoo.org/show_bug.cgi?id=274614" > fi > > use nginx_modules_http_passenger && { > ruby-ng_pkg_setup > # fix strict-aliasing warnings in boost portion of passenger module > append-flags -fno-strict-aliasing > use debug && append-flags -DPASSENGER_DEBUG > } >} > ># prevent ruby-ng.eclass from messing with src_unpack >src_unpack() { > default >} > >src_prepare() { > sed -i 's/ make/ \\$(MAKE)/' "${S}"/auto/lib/perl/make > > # fix passenger Rakefile to accept our CFLAGS > use nginx_modules_http_passenger && { > cd "${WORKDIR}/${MODULE_PASSENGER_P}" > epatch "${FILESDIR}/passenger-CFLAGS.patch" > } >} > >src_configure() { > local myconf= enable_http=false enable_mail=false > > use debug && myconf="${myconf} --with-debug" > use ipv6 && myconf="${myconf} --with-ipv6" > # pcre are needed for http_rewrite, but can also be used for config files > if use pcre || use nginx_modules_http_rewrite; then > myconf="${myconf} --with-pcre" > else > myconf="${myconf} --without-pcre" > fi > > # standard default modules > for module in ${NGINX_MODULES_HTTP_STD}; do > if use "nginx_modules_http_${module}"; then > enable_http=true > else > myconf="${myconf} --without-http_${module}_module" > fi > done > > # optional modules > for module in ${NGINX_MODULES_HTTP_OPT}; do > if use "nginx_modules_http_${module}"; then > myconf="${myconf} --with-http_${module}_module" > enable_http=true > fi > done > > # 3rd party modules > # passenger will compile itself in the configure step, nothing we can do > if use nginx_modules_http_passenger; then > myconf="${myconf} --add-module=../${MODULE_PASSENGER_P}/ext/nginx" > enable_http=true > fi > > # while good for security, not sure this is techically required > use nginx_modules_http_fastcgi && \ > myconf="${myconf} --with-http_realip_module" > > # had http been specified directly via useflag > if use http || use http-cache; then > enable_http=true > fi > > # do we need http support > if $enable_http; then > use http-cache || myconf="${myconf} --without-http-cache" > use ssl && myconf="${myconf} --with-http_ssl_module" > else > myconf="${myconf} --without-http --without-http-cache" > fi > > # mail modules > for module in ${NGINX_MODULES_MAIL_OPT}; do > if use "nginx_modules_mail_${module}"; then > myconf="${myconf} --without-mail_${module}_module" > enable_mail=true > fi > done > > # do we need mail support > if $enable_mail; then > myconf="${myconf} --with-mail" > use ssl && myconf="${myconf} --with-mail_ssl_module" > fi > > # http://bugs.gentoo.org/show_bug.cgi?id=286772 > export LANG=C LC_ALL=C > tc-export CC > > ./configure \ > --prefix=/usr \ > --sbin-path=/usr/sbin/nginx \ > --conf-path=/etc/${PN}/${PN}.conf \ > --http-log-path=/var/log/${PN}/access.log \ > --error-log-path=/var/log/${PN}/error.log \ > --pid-path=/var/run/${PN}.pid \ > --lock-path=/var/lock/nginx.lock \ > --http-client-body-temp-path=/var/tmp/${PN}/client \ > --http-proxy-temp-path=/var/tmp/${PN}/proxy \ > --http-fastcgi-temp-path=/var/tmp/${PN}/fastcgi \ > --with-cc-opt="-I${ROOT}usr/include" \ > --with-ld-opt="-L${ROOT}usr/lib" \ > --user=${PN} --group=${PN} \ > ${myconf} || die "configure failed" >} > >src_compile() { > # http://bugs.gentoo.org/show_bug.cgi?id=286772 > export LANG=C LC_ALL=C > emake LINK="${CC} ${LDFLAGS}" OTHERLDFLAGS="${LDFLAGS}" || die "emake failed" >} > >src_install() { > keepdir /var/log/${PN} /var/tmp/${PN}/{client,proxy,fastcgi} > > dosbin objs/nginx > newinitd "${FILESDIR}"/nginx.init nginx || die "failed to install init script" > > dodir /etc/${PN} > insinto /etc/${PN} > doins "${FILESDIR}"/nginx.conf > doins conf/mime.types > > dodir /etc/${PN}/sites.d > insinto /etc/${PN}/sites.d > doins "${FILESDIR}"/sites.d/* > > dodir /etc/${PN}/modules.d > insinto /etc/${PN}/modules.d > use nginx_modules_http_gzip && doins "${FILESDIR}"/modules.d/gzip > use ssl && doins "${FILESDIR}"/modules.d/ssl > > dodoc CHANGES{,.ru} README > > insinto /etc/logrotate.d > newins "${FILESDIR}"/nginx.logrotate nginx || die "failed to install logrotate script" > > use nginx_modules_http_perl && { > cd "${S}"/objs/src/http/modules/perl/ > einstall DESTDIR="${D}" INSTALLDIRS=vendor || die "failed to install perl stuff" > fixlocalpod > } > > use nginx_modules_http_passenger && { > insinto /etc/${PN}/modules.d > doins "${FILESDIR}"/modules.d/passenger > > cd "${WORKDIR}/${MODULE_PASSENGER_P}" > > # install ruby stuff to multiple targets > for RUBY in ${USE_RUBY}; do > # are we actually using this ruby target? > use ruby_targets_${RUBY} || continue > > insinto $(${RUBY} -rrbconfig -e 'print Config::CONFIG["archdir"]')/phusion_passenger > insopts -m 0755 > doins ext/phusion_passenger/native_support.so > > doruby -r lib/phusion_passenger > done > > exeinto /usr/sbin > doexe bin/passenger-memory-stats bin/passenger-status > > exeinto /usr/libexec/passenger/bin > doexe bin/passenger-spawn-server > > exeinto /usr/libexec/passenger/ext/nginx > doexe ext/nginx/HelperServer > } >} > >pkg_postinst() { > if use ssl && [ ! -f "${ROOT}"/etc/ssl/${PN}/${PN}.key ]; then > install_cert /etc/ssl/${PN}/${PN} > chown ${PN}:${PN} "${ROOT}"/etc/ssl/${PN}/${PN}.{crt,csr,key,pem} > fi > > # create an "its working" page if none exists > if [[ ! -e "${ROOT}"/var/www/default ]] ; then > mkdir -p "${ROOT}"/var/www/default/{public,log} > echo "<html><body><h1>nginx on $(hostname -f) is working!!!</h1></body></html>" \ > > "${ROOT}"/var/www/default/public/index.html > chown -R ${PN}:${PN} "${ROOT}"/var/www/default > fi >}
You cannot view the attachment while viewing its details because your browser does not support IFRAMEs.
View the attachment on a separate page
.
View Attachment As Raw
Actions:
View
Attachments on
bug 308481
:
222687
|
222689
| 222691