FreeBSD Bugzilla – Attachment 209203 Details for
Bug 242014
www/jetty8: jettyctl fails to run with Python 3: SyntaxError: invalid token
Home
|
New
|
Browse
|
Search
|
[?]
|
Reports
|
Help
|
New Account
|
Log In
Remember
[x]
|
Forgot Password
Login:
[x]
[patch]
proposed patch: use the upstream start/stop script
jetty8.patch (text/plain), 7.29 KB, created by
Martin Waschbüsch
on 2019-11-17 11:14:35 UTC
(
hide
)
Description:
proposed patch: use the upstream start/stop script
Filename:
MIME Type:
Creator:
Martin Waschbüsch
Created:
2019-11-17 11:14:35 UTC
Size:
7.29 KB
patch
obsolete
>diff -ruN jetty8.orig/Makefile jetty8/Makefile >--- jetty8.orig/Makefile 2016-04-01 14:33:55.000000000 +0000 >+++ jetty8/Makefile 2019-11-17 11:06:22.018324000 +0000 >@@ -23,7 +23,8 @@ > USE_RC_SUBR= ${PORTNAME} > USE_JAVA= yes > JAVA_VERSION= 1.6+ >-USES= python >+USES= shebangfix >+SHEBANG_FILES= bin/jetty.sh > PKGMESSAGE= ${WRKDIR}/pkg-message > PLIST_SUB+= RUNASUSER=${RUNASUSER} GROUP=${GROUP} > >@@ -55,7 +56,6 @@ > SUB_FILES= \ > pkg-install \ > pkg-deinstall \ >- ${APP_NAME}ctl \ > ${APP_NAME} \ > message \ > message-advanced >@@ -67,6 +67,6 @@ > do-install: > @${MKDIR} ${STAGEDIR}${APP_HOME} > cd ${WRKSRC} && ${FIND} -H * | ${EGREP} -v "^(bin/|bin$$)" | ${CPIO} -pdmuL ${STAGEDIR}${APP_HOME} >- ${INSTALL_SCRIPT} ${WRKDIR}/${APP_NAME}ctl ${STAGEDIR}${PREFIX}/sbin >+ cd ${WRKSRC} && ${INSTALL_SCRIPT} bin/${PORTNAME}.sh ${STAGEDIR}${PREFIX}/sbin > > .include <bsd.port.mk> >diff -ruN jetty8.orig/files/jetty.in jetty8/files/jetty.in >--- jetty8.orig/files/jetty.in 2015-12-06 20:12:58.000000000 +0000 >+++ jetty8/files/jetty.in 2019-11-17 07:59:42.868379000 +0000 >@@ -18,7 +18,7 @@ > name=%%APP_NAME%% > rcvar=%%APP_NAME%%_enable > >-command="%%PREFIX%%/sbin/%%APP_NAME%%ctl" >+command="%%PREFIX%%/sbin/%%APP_NAME%%.sh" > command_args="start" > pidfile=%%PID_FILE%% > >diff -ruN jetty8.orig/files/jettyctl.in jetty8/files/jettyctl.in >--- jetty8.orig/files/jettyctl.in 2013-01-16 10:21:51.000000000 +0000 >+++ jetty8/files/jettyctl.in 1970-01-01 00:00:00.000000000 +0000 >@@ -1,176 +0,0 @@ >-#! %%PYTHON_CMD%% >- >-################################################################################ >-# Author: Jean-Baptiste Quenot <jb.quenot@caraldi.com> >-# Purpose: Manage resin pid file and log files >-# Date Created: 2005-01-21 15:43:19 >-# Revision: $FreeBSD: head/www/jetty8/files/jettyctl.in 310487 2013-01-16 10:21:51Z olgeni $ >-################################################################################ >-# Copyright (c) 2004, Jean-Baptiste Quenot <jb.quenot@caraldi.com> >-# All rights reserved. >-# >-# Redistribution and use in source and binary forms, with or without >-# modification, are permitted provided that the following conditions are met: >-# >-# * Redistributions of source code must retain the above copyright notice, this >-# list of conditions and the following disclaimer. >-# * Redistributions in binary form must reproduce the above copyright notice, >-# this list of conditions and the following disclaimer in the documentation >-# and/or other materials provided with the distribution. >-# * The name of the contributors may not be used to endorse or promote products >-# derived from this software without specific prior written permission. >-# >-# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" >-# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE >-# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE >-# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE >-# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL >-# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR >-# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER >-# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, >-# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE >-# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. >-################################################################################ >-# >-# Files handled by this script (pid file, log files) must reside in a writable >-# directory, ie the directory must be owned by the user running the program. >- >-import sys, os, signal, time, stat, re >- >-# -socketwait 12345 >-# -stdout $APP_HOME/log/stdout.log >-# -stderr $APP_HOME/log/stderr.log >- >-def readProcessId(): >- f = open(PID_FILE, 'r') >- pid = int(f.readline()) >- f.close() >- return pid >- >-def isProgramRunning(pid): >- # Send a dummy signal to the process. If it died, an exception is >- # thrown >- try: >- os.kill(pid, signal.SIGCONT) >- return 1 >- except OSError: >- return 0 >- >-def usage(): >- print >> sys.stderr, "Usage: %s {start|stop|restart}" % sys.argv[0] >- >-def start(): >- cwd = os.getcwd() >- if os.path.exists(PID_FILE): >- # Read the process id >- pid = readProcessId() >- >- if isProgramRunning(pid): >- print >> sys.stderr, '%s already started' % APP_NAME >- sys.exit(3) >- >- if not(os.path.exists(COMMAND)): >- print >> sys.stderr, '%s cannot be found' % COMMAND >- sys.exit(3) >- >- # Append program output to a log file >- l = open(LOG_FILE, 'a') >- orig_stderr = os.dup(sys.stderr.fileno()) >- os.dup2(l.fileno(), sys.stdout.fileno()) >- os.dup2(l.fileno(), sys.stderr.fileno()) >- >- finfo = os.stat(COMMAND)[stat.ST_MODE] >- executable = stat.S_IMODE(finfo) & 0111 >- if not(executable): >- sys.stderr = os.fdopen(orig_stderr, 'w') >- print >> sys.stderr, 'Cannot run %s, execute bit is missing' % COMMAND >- sys.exit(5) >- >- if APP_HOME: >- # Change current directory to APP_HOME >- os.chdir(APP_HOME) >- >- # Start program in the background >- pid = os.spawnv(os.P_NOWAIT, COMMAND, ARGS) >- >- # Wait a little >- time.sleep(.4) >- (status_pid, status) = os.waitpid(pid, os.WNOHANG) >- >- # Check program exit status, if available >- if status_pid != 0 and os.WIFEXITED(status): >- sys.stderr = os.fdopen(orig_stderr, 'w') >- print >> sys.stderr, 'Could not start %s. Check %s for errors.' % (APP_NAME, LOG_FILE) >- sys.exit(2) >- >- # It's alive, so write down the process id >- os.chdir(cwd) >- f = open(PID_FILE, 'w') >- print >> f, pid >- f.close() >- >-def warnNotRunning(): >- if sys.argv[1] == "stop": >- print >> sys.stderr, '%s is not running' % APP_NAME >- else: >- print >> sys.stderr, 'Warning: %s was not running' % APP_NAME >- >-def cleanup(): >- os.unlink(PID_FILE) >- >-def stop(): >- if os.path.exists(PID_FILE): >- # Read the process id >- pid = readProcessId() >- else: >- warnNotRunning() >- return >- >- if not(isProgramRunning(pid)): >- warnNotRunning() >- cleanup() >- return >- >- # Terminate program >- os.kill(pid, signal.SIGTERM) >- >- while isProgramRunning(pid): >- time.sleep(.1) >- >- cleanup() >- >-if __name__ == '__main__': >- LOG_FILE = "%%LOG_FILE%%" >- APP_NAME = "%%APP_NAME%%" >- APP_HOME = "%%APP_HOME%%" >- PID_FILE = "%%PID_FILE%%" >- COMMAND = "%%PREFIX%%/bin/java" >- ARGS = [COMMAND] >- >- ARGS += sys.argv[1:-1] >- >- ARGS += [ >- "-Djetty.home=%%APP_HOME%%", >- "-jar", >- "%%APP_HOME%%/start.jar" >- ] >- >- os.environ['PATH'] = "%%LOCALBASE%%/bin:/usr/bin:/bin" >- >- if len(sys.argv) < 2: >- usage() >- sys.exit(1) >- >- if sys.argv[-1] == "start": >- start() >- >- elif sys.argv[-1] == "stop": >- stop() >- >- elif sys.argv[-1] == "restart": >- stop() >- start() >- >- else: >- usage() >- sys.exit(1) >diff -ruN jetty8.orig/pkg-plist jetty8/pkg-plist >--- jetty8.orig/pkg-plist 2015-12-21 12:31:27.000000000 +0000 >+++ jetty8/pkg-plist 2019-11-17 08:11:20.342022000 +0000 >@@ -1,4 +1,4 @@ >-sbin/jettyctl >+sbin/jetty.sh > @owner %%RUNASUSER%% > @group %%GROUP%% > jetty/LICENSE-APACHE-2.0.txt
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 Diff
View Attachment As Raw
Flags:
martin
:
maintainer-approval?
(
olgeni
)
Actions:
View
|
Diff
Attachments on
bug 242014
: 209203