<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title>[12446] CalendarServer/trunk</title>
</head>
<body>
<style type="text/css"><!--
#msg dl.meta { border: 1px #006 solid; background: #369; padding: 6px; color: #fff; }
#msg dl.meta dt { float: left; width: 6em; font-weight: bold; }
#msg dt:after { content:':';}
#msg dl, #msg dt, #msg ul, #msg li, #header, #footer, #logmsg { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; }
#msg dl a { font-weight: bold}
#msg dl a:link { color:#fc3; }
#msg dl a:active { color:#ff0; }
#msg dl a:visited { color:#cc6; }
h3 { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; font-weight: bold; }
#msg pre { overflow: auto; background: #ffc; border: 1px #fa0 solid; padding: 6px; }
#logmsg { background: #ffc; border: 1px #fa0 solid; padding: 1em 1em 0 1em; }
#logmsg p, #logmsg pre, #logmsg blockquote { margin: 0 0 1em 0; }
#logmsg p, #logmsg li, #logmsg dt, #logmsg dd { line-height: 14pt; }
#logmsg h1, #logmsg h2, #logmsg h3, #logmsg h4, #logmsg h5, #logmsg h6 { margin: .5em 0; }
#logmsg h1:first-child, #logmsg h2:first-child, #logmsg h3:first-child, #logmsg h4:first-child, #logmsg h5:first-child, #logmsg h6:first-child { margin-top: 0; }
#logmsg ul, #logmsg ol { padding: 0; list-style-position: inside; margin: 0 0 0 1em; }
#logmsg ul { text-indent: -1em; padding-left: 1em; }#logmsg ol { text-indent: -1.5em; padding-left: 1.5em; }
#logmsg > ul, #logmsg > ol { margin: 0 0 1em 0; }
#logmsg pre { background: #eee; padding: 1em; }
#logmsg blockquote { border: 1px solid #fa0; border-left-width: 10px; padding: 1em 1em 0 1em; background: white;}
#logmsg dl { margin: 0; }
#logmsg dt { font-weight: bold; }
#logmsg dd { margin: 0; padding: 0 0 0.5em 0; }
#logmsg dd:before { content:'\00bb';}
#logmsg table { border-spacing: 0px; border-collapse: collapse; border-top: 4px solid #fa0; border-bottom: 1px solid #fa0; background: #fff; }
#logmsg table th { text-align: left; font-weight: normal; padding: 0.2em 0.5em; border-top: 1px dotted #fa0; }
#logmsg table td { text-align: right; border-top: 1px dotted #fa0; padding: 0.2em 0.5em; }
#logmsg table thead th { text-align: center; border-bottom: 1px solid #fa0; }
#logmsg table th.Corner { text-align: left; }
#logmsg hr { border: none 0; border-top: 2px dashed #fa0; height: 1px; }
#header, #footer { color: #fff; background: #636; border: 1px #300 solid; padding: 6px; }
#patch { width: 100%; }
#patch h4 {font-family: verdana,arial,helvetica,sans-serif;font-size:10pt;padding:8px;background:#369;color:#fff;margin:0;}
#patch .propset h4, #patch .binary h4 {margin:0;}
#patch pre {padding:0;line-height:1.2em;margin:0;}
#patch .diff {width:100%;background:#eee;padding: 0 0 10px 0;overflow:auto;}
#patch .propset .diff, #patch .binary .diff {padding:10px 0;}
#patch span {display:block;padding:0 10px;}
#patch .modfile, #patch .addfile, #patch .delfile, #patch .propset, #patch .binary, #patch .copfile {border:1px solid #ccc;margin:10px 0;}
#patch ins {background:#dfd;text-decoration:none;display:block;padding:0 10px;}
#patch del {background:#fdd;text-decoration:none;display:block;padding:0 10px;}
#patch .lines, .info {color:#888;background:#fff;}
--></style>
<div id="msg">
<dl class="meta">
<dt>Revision</dt> <dd><a href="http://trac.calendarserver.org//changeset/12446">12446</a></dd>
<dt>Author</dt> <dd>wsanchez@apple.com</dd>
<dt>Date</dt> <dd>2014-01-24 11:05:48 -0800 (Fri, 24 Jan 2014)</dd>
</dl>
<h3>Log Message</h3>
<pre>omg-dont-use-this-its-so-last-year</pre>
<h3>Added Paths</h3>
<ul>
<li><a href="#CalendarServertrunkrunomgdontusethisitssolastyear">CalendarServer/trunk/run.omg-dont-use-this-its-so-last-year</a></li>
</ul>
<h3>Removed Paths</h3>
<ul>
<li><a href="#CalendarServertrunkrun">CalendarServer/trunk/run</a></li>
</ul>
</div>
<div id="patch">
<h3>Diff</h3>
<a id="CalendarServertrunkrun"></a>
<div class="delfile"><h4>Deleted: CalendarServer/trunk/run (12445 => 12446)</h4>
<pre class="diff"><span>
<span class="info">--- CalendarServer/trunk/run        2014-01-24 17:53:33 UTC (rev 12445)
+++ CalendarServer/trunk/run        2014-01-24 19:05:48 UTC (rev 12446)
</span><span class="lines">@@ -1,250 +0,0 @@
</span><del>-#!/usr/bin/env bash
-# -*- sh-basic-offset: 2 -*-
-
-##
-# Copyright (c) 2005-2014 Apple Inc. All rights reserved.
-#
-# Licensed under the Apache License, Version 2.0 (the "License");
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-##
-
-##
-# WARNING: This script is intended for use by developers working on
-# the Calendar Server code base. It is not intended for use in a
-# deployment configuration.
-#
-# DO NOT use this script as a system startup tool (eg. in /etc/init.d,
-# /Library/StartupItems, launchd plists, etc.)
-#
-# For those uses, install the server properly (eg. with "./run -i
-# /tmp/foo && cd /tmp/foo && pax -pe -rvw . /") and use the caldavd
-# executable to start the server.
-##
-
-set -e;
-set -u;
-
-wd="$(cd "$(dirname "$0")" && pwd)";
-
-# Echo the usage for the main 'run' script, then exit with an error.
-usage () {
- program="$(basename "$0")";
-
- if [ "${1--}" != "-" ]; then
- echo "$@";
- echo;
- fi;
-
- echo "Usage: ${program} [-hvgsfnpdkrR] [-K key] [-iIb dst] [-t type] [-S statsdirectory] [-P plugin]";
- echo "Options:";
- echo "        -h Print this help and exit";
- echo "        -v Be verbose";
- echo "        -g Get dependencies only; don't run setup or run the server.";
- echo "        -s Run setup only; don't run server";
- echo "        -f Force setup to run";
- echo "        -n Do not run setup";
- echo "        -p Print PYTHONPATH value for server and exit";
- echo "        -e Print =-separated environment variables required to run and exit";
- echo "        -d Run caldavd as a daemon";
- echo "        -k Stop caldavd";
- echo "        -r Restart caldavd";
- echo "        -K Print value of configuration key and exit";
- echo "        -i Perform a system install into dst; implies -s";
- echo "        -I Perform a home install into dst; implies -s";
- echo "        -b Perform a bundled install (include all dependencies) into dst; implies -s";
- echo "        -t Select the server process type (Master, Slave or Combined) [${service_type}]";
- echo "        -S Write a pstats object for each process to the given directory when the server is stopped.";
- echo "        -P Select the twistd plugin name [${plugin_name}]";
- echo "        -R Twisted Reactor plugin to execute [${reactor}]";
-
- if [ "${1-}" == "-" ]; then
- return 0;
- fi;
- exit 64;
-}
-
-# Parse command-line options to set up state which controls the behavior of the
-# functions in build.sh.
-parse_options () {
- OPTIND=1;
- while getopts "ahvgsfnpedkrK:i:I:b:t:S:P:R:" option; do
- case "${option}" in
- '?') usage; ;;
- 'h') usage -; exit 0; ;;
- 'v') verbose="-v"; ;;
- 'f') force_setup="true"; ;;
- 'k') kill="true"; ;;
- 'r') restart="true"; ;;
- 'd') daemonize=""; ;;
- 'P') plugin_name="${OPTARG}"; ;;
- 'R') reactor="-R ${OPTARG}"; ;;
- 't') service_type="${OPTARG}"; ;;
- 'K') read_key="${OPTARG}"; ;;
- 'S') profile="-p ${OPTARG}"; ;;
- 'g') do_get="true" ; do_setup="false"; do_run="false"; ;;
- 's') do_get="true" ; do_setup="true" ; do_run="false"; ;;
- 'p')
- do_get="false"; do_setup="false"; do_run="false"; print_path="true";
- ;;
- 'e')
- do_get="false"; do_setup="false"; do_run="false"; print_path="true";
- print_environment="true";
- ;;
- 'i')
- do_get="true";
- do_setup="true";
- do_run="false";
- install="${OPTARG}";
- install_flag="--root=";
- ;;
- 'I')
- do_get="true";
- do_setup="true";
- do_run="false";
- install="${wd}/build/dst";
- install_flag="--root=";
- install_home="${OPTARG}";
- ;;
- 'b')
- do_bundle="true";
- do_get="true";
- do_setup="true";
- do_run="false";
- install="${OPTARG}";
- install_flag="--root=";
- ;;
- 'n') do_get="false" ; do_setup="false"; ;;
- esac;
- done;
- shift $((${OPTIND} - 1));
- if [ $# != 0 ]; then
- usage "Unrecognized arguments:" "$@";
- fi;
-}
-
-. "${wd}/support/build.sh";
-
-# Actually run the server. (Or, exit, if things aren't sufficiently set up in
-# order to do that.)
-run () {
- echo "Using ${python} as Python";
-
- if "${do_run}"; then
- if [ ! -f "${config}" ]; then
- echo "";
- echo "Missing config file: ${config}";
- echo "You might want to start by copying the test configuration:";
- echo "";
- echo " cp conf/caldavd-test.plist conf/caldavd-dev.plist";
- echo "";
- if [ -t 0 ]; then
- # Interactive shell
- echo -n "Would you like to copy the test configuration now? [y/n]";
- read answer;
- case "${answer}" in
- y|yes|Y|YES|Yes)
- echo "Copying test cofiguration...";
- cp "${wd}/conf/caldavd-test.plist" "${wd}/conf/caldavd-dev.plist";
- ;;
- *)
- exit 1;
- ;;
- esac;
- else
- exit 1;
- fi;
- fi;
-
- cd "${wd}";
- if [ ! -d "${wd}/data" ]; then
- mkdir "${wd}/data";
- fi;
-
- echo "";
- echo "Starting server...";
- exec ${caldavd_wrapper_command} \
- "${caldav}/bin/caldavd" ${daemonize} \
- -f "${config}" \
- -P "${plugin_name}" \
- -t "${service_type}" \
- ${reactor} \
- ${profile};
- cd /;
- fi;
-}
-
-
-# The main-point of the 'run' script: parse all options, decide what to do,
-# then do it.
-run_main () {
- parse_options "$@";
-
- # If we've been asked to read a configuration key, just read it and exit.
- if [ -n "${read_key}" ]; then
- value="$("${caldav}/bin/calendarserver_config" "${read_key}")";
- IFS="="; set ${value}; echo "$2"; unset IFS;
- exit $?;
- fi;
-
- if "${kill}" || "${restart}"; then
- pidfile="$("${caldav}/bin/calendarserver_config" "PIDFile")";
- # Split key and value on "=" and just grab the value
- IFS="="; set ${pidfile}; pidfile="$2"; unset IFS;
- if [ ! -r "${pidfile}" ]; then
- echo "Unreadable PID file: ${pidfile}";
- exit 1
- fi;
- pid="$(cat "${pidfile}" | head -1)";
- if [ -z "${pid}" ]; then
- echo "No PID in PID file: ${pidfile}";
- exit 1;
- fi;
- echo "Killing process ${pid}";
- kill -TERM "${pid}";
- if ! "${restart}"; then
- exit 0;
- fi;
- fi;
-
- # About to do something for real; let's enumerate (and depending on options,
- # possibly download and/or install) the dependencies.
- dependencies;
-
- # Now that all the dependencies are set up, let's see if we're just being
- # asked to print the path.
- if "${print_path}"; then
- if "${print_environment}"; then
- "${PYTHON}" -c "import os; print repr(dict(os.environ))"
- else
- echo "${PYTHONPATH}";
- fi;
- exit 0;
- fi;
-
- # If we're installing, install the calendar server itself.
- py_install "Calendar Server" "${caldav}";
-
- if [ -n "${install_home:-}" ]; then
- do_home_install;
- fi;
-
- if "${do_bundle}"; then
- write_environment;
- fi;
-
- # Finally, run the server.
- run;
-}
-
-
-run_main "$@";
-
</del></span></pre></div>
<a id="CalendarServertrunkrunomgdontusethisitssolastyearfromrev12442CalendarServertrunkrun"></a>
<div class="copfile"><h4>Copied: CalendarServer/trunk/run.omg-dont-use-this-its-so-last-year (from rev 12442, CalendarServer/trunk/run) (0 => 12446)</h4>
<pre class="diff"><span>
<span class="info">--- CalendarServer/trunk/run.omg-dont-use-this-its-so-last-year         (rev 0)
+++ CalendarServer/trunk/run.omg-dont-use-this-its-so-last-year        2014-01-24 19:05:48 UTC (rev 12446)
</span><span class="lines">@@ -0,0 +1,250 @@
</span><ins>+#!/usr/bin/env bash
+# -*- sh-basic-offset: 2 -*-
+
+##
+# Copyright (c) 2005-2014 Apple Inc. All rights reserved.
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+##
+
+##
+# WARNING: This script is intended for use by developers working on
+# the Calendar Server code base. It is not intended for use in a
+# deployment configuration.
+#
+# DO NOT use this script as a system startup tool (eg. in /etc/init.d,
+# /Library/StartupItems, launchd plists, etc.)
+#
+# For those uses, install the server properly (eg. with "./run -i
+# /tmp/foo && cd /tmp/foo && pax -pe -rvw . /") and use the caldavd
+# executable to start the server.
+##
+
+set -e;
+set -u;
+
+wd="$(cd "$(dirname "$0")" && pwd)";
+
+# Echo the usage for the main 'run' script, then exit with an error.
+usage () {
+ program="$(basename "$0")";
+
+ if [ "${1--}" != "-" ]; then
+ echo "$@";
+ echo;
+ fi;
+
+ echo "Usage: ${program} [-hvgsfnpdkrR] [-K key] [-iIb dst] [-t type] [-S statsdirectory] [-P plugin]";
+ echo "Options:";
+ echo "        -h Print this help and exit";
+ echo "        -v Be verbose";
+ echo "        -g Get dependencies only; don't run setup or run the server.";
+ echo "        -s Run setup only; don't run server";
+ echo "        -f Force setup to run";
+ echo "        -n Do not run setup";
+ echo "        -p Print PYTHONPATH value for server and exit";
+ echo "        -e Print =-separated environment variables required to run and exit";
+ echo "        -d Run caldavd as a daemon";
+ echo "        -k Stop caldavd";
+ echo "        -r Restart caldavd";
+ echo "        -K Print value of configuration key and exit";
+ echo "        -i Perform a system install into dst; implies -s";
+ echo "        -I Perform a home install into dst; implies -s";
+ echo "        -b Perform a bundled install (include all dependencies) into dst; implies -s";
+ echo "        -t Select the server process type (Master, Slave or Combined) [${service_type}]";
+ echo "        -S Write a pstats object for each process to the given directory when the server is stopped.";
+ echo "        -P Select the twistd plugin name [${plugin_name}]";
+ echo "        -R Twisted Reactor plugin to execute [${reactor}]";
+
+ if [ "${1-}" == "-" ]; then
+ return 0;
+ fi;
+ exit 64;
+}
+
+# Parse command-line options to set up state which controls the behavior of the
+# functions in build.sh.
+parse_options () {
+ OPTIND=1;
+ while getopts "ahvgsfnpedkrK:i:I:b:t:S:P:R:" option; do
+ case "${option}" in
+ '?') usage; ;;
+ 'h') usage -; exit 0; ;;
+ 'v') verbose="-v"; ;;
+ 'f') force_setup="true"; ;;
+ 'k') kill="true"; ;;
+ 'r') restart="true"; ;;
+ 'd') daemonize=""; ;;
+ 'P') plugin_name="${OPTARG}"; ;;
+ 'R') reactor="-R ${OPTARG}"; ;;
+ 't') service_type="${OPTARG}"; ;;
+ 'K') read_key="${OPTARG}"; ;;
+ 'S') profile="-p ${OPTARG}"; ;;
+ 'g') do_get="true" ; do_setup="false"; do_run="false"; ;;
+ 's') do_get="true" ; do_setup="true" ; do_run="false"; ;;
+ 'p')
+ do_get="false"; do_setup="false"; do_run="false"; print_path="true";
+ ;;
+ 'e')
+ do_get="false"; do_setup="false"; do_run="false"; print_path="true";
+ print_environment="true";
+ ;;
+ 'i')
+ do_get="true";
+ do_setup="true";
+ do_run="false";
+ install="${OPTARG}";
+ install_flag="--root=";
+ ;;
+ 'I')
+ do_get="true";
+ do_setup="true";
+ do_run="false";
+ install="${wd}/build/dst";
+ install_flag="--root=";
+ install_home="${OPTARG}";
+ ;;
+ 'b')
+ do_bundle="true";
+ do_get="true";
+ do_setup="true";
+ do_run="false";
+ install="${OPTARG}";
+ install_flag="--root=";
+ ;;
+ 'n') do_get="false" ; do_setup="false"; ;;
+ esac;
+ done;
+ shift $((${OPTIND} - 1));
+ if [ $# != 0 ]; then
+ usage "Unrecognized arguments:" "$@";
+ fi;
+}
+
+. "${wd}/support/build.sh";
+
+# Actually run the server. (Or, exit, if things aren't sufficiently set up in
+# order to do that.)
+run () {
+ echo "Using ${python} as Python";
+
+ if "${do_run}"; then
+ if [ ! -f "${config}" ]; then
+ echo "";
+ echo "Missing config file: ${config}";
+ echo "You might want to start by copying the test configuration:";
+ echo "";
+ echo " cp conf/caldavd-test.plist conf/caldavd-dev.plist";
+ echo "";
+ if [ -t 0 ]; then
+ # Interactive shell
+ echo -n "Would you like to copy the test configuration now? [y/n]";
+ read answer;
+ case "${answer}" in
+ y|yes|Y|YES|Yes)
+ echo "Copying test cofiguration...";
+ cp "${wd}/conf/caldavd-test.plist" "${wd}/conf/caldavd-dev.plist";
+ ;;
+ *)
+ exit 1;
+ ;;
+ esac;
+ else
+ exit 1;
+ fi;
+ fi;
+
+ cd "${wd}";
+ if [ ! -d "${wd}/data" ]; then
+ mkdir "${wd}/data";
+ fi;
+
+ echo "";
+ echo "Starting server...";
+ exec ${caldavd_wrapper_command} \
+ "${caldav}/bin/caldavd" ${daemonize} \
+ -f "${config}" \
+ -P "${plugin_name}" \
+ -t "${service_type}" \
+ ${reactor} \
+ ${profile};
+ cd /;
+ fi;
+}
+
+
+# The main-point of the 'run' script: parse all options, decide what to do,
+# then do it.
+run_main () {
+ parse_options "$@";
+
+ # If we've been asked to read a configuration key, just read it and exit.
+ if [ -n "${read_key}" ]; then
+ value="$("${caldav}/bin/calendarserver_config" "${read_key}")";
+ IFS="="; set ${value}; echo "$2"; unset IFS;
+ exit $?;
+ fi;
+
+ if "${kill}" || "${restart}"; then
+ pidfile="$("${caldav}/bin/calendarserver_config" "PIDFile")";
+ # Split key and value on "=" and just grab the value
+ IFS="="; set ${pidfile}; pidfile="$2"; unset IFS;
+ if [ ! -r "${pidfile}" ]; then
+ echo "Unreadable PID file: ${pidfile}";
+ exit 1
+ fi;
+ pid="$(cat "${pidfile}" | head -1)";
+ if [ -z "${pid}" ]; then
+ echo "No PID in PID file: ${pidfile}";
+ exit 1;
+ fi;
+ echo "Killing process ${pid}";
+ kill -TERM "${pid}";
+ if ! "${restart}"; then
+ exit 0;
+ fi;
+ fi;
+
+ # About to do something for real; let's enumerate (and depending on options,
+ # possibly download and/or install) the dependencies.
+ dependencies;
+
+ # Now that all the dependencies are set up, let's see if we're just being
+ # asked to print the path.
+ if "${print_path}"; then
+ if "${print_environment}"; then
+ "${PYTHON}" -c "import os; print repr(dict(os.environ))"
+ else
+ echo "${PYTHONPATH}";
+ fi;
+ exit 0;
+ fi;
+
+ # If we're installing, install the calendar server itself.
+ py_install "Calendar Server" "${caldav}";
+
+ if [ -n "${install_home:-}" ]; then
+ do_home_install;
+ fi;
+
+ if "${do_bundle}"; then
+ write_environment;
+ fi;
+
+ # Finally, run the server.
+ run;
+}
+
+
+run_main "$@";
+
</ins></span></pre>
</div>
</div>
</body>
</html>