diff -Nru trac-0.11.7/contrib/bugzilla2trac.py trac-0.12.1~ppa2/contrib/bugzilla2trac.py --- trac-0.11.7/contrib/bugzilla2trac.py 2010-03-09 22:49:39.000000000 +0000 +++ trac-0.12.1~ppa2/contrib/bugzilla2trac.py 2010-02-27 09:59:34.000000000 +0000 @@ -19,7 +19,7 @@ Reworked, Jeroen Ruigrok van der Werven Jeff Moreland -$Id: bugzilla2trac.py 9282 2010-02-26 10:06:58Z cboos $ +$Id: bugzilla2trac.py 9298 2010-02-27 09:59:34Z cboos $ """ import re @@ -912,12 +912,14 @@ trac.addAttachment(author, a) print "\n8. Importing users and passwords..." - if BZ_VERSION >= 2167: + if BZ_VERSION >= 2164: selectlogins = "SELECT login_name, cryptpassword FROM profiles"; if IGNORE_DISABLED_USERS: selectlogins = selectlogins + " WHERE disabledtext=''" mysql_cur.execute(selectlogins) users = mysql_cur.fetchall() + else: + users = () htpasswd = file("htpasswd", 'w') for user in users: if LOGIN_MAP.has_key(user['login_name']): diff -Nru trac-0.11.7/contrib/checkwiki.py trac-0.12.1~ppa2/contrib/checkwiki.py --- trac-0.11.7/contrib/checkwiki.py 2010-03-09 22:49:39.000000000 +0000 +++ trac-0.12.1~ppa2/contrib/checkwiki.py 2010-04-11 07:39:05.000000000 +0100 @@ -45,6 +45,7 @@ "TracPlugins", "TracQuery", "TracReports", + "TracRepositoryAdmin", "TracRevisionLog", "TracRoadmap", "TracRss", @@ -70,7 +71,7 @@ "WikiRestructuredTextLinks" ] -def get_page_from_file (pname): +def get_page_from_file(prefix, pname): d = '' try: f = open(pname ,'r') @@ -80,23 +81,24 @@ print "Missing page: %s" % pname return d -def get_page_from_web (pname): +def get_page_from_web(prefix, pname): host = "trac.edgewall.org" - rfile = "/wiki/%s?format=txt" % pname + rfile = "/wiki/%s%s?format=txt" % (prefix, pname) c = httplib.HTTPConnection(host) c.request("GET", rfile) + print "Getting", rfile r = c.getresponse() d = r.read() - if r.status != 200 or d == ("describe %s here\n" % pname): - c.close() - print "Missing page: %s" % pname + if r.status == 200 and d: + f = open(pname, 'w+') + f.write(d) + f.close() + else: + print "Missing or empty page" c.close() - f = open(pname, 'w+') - f.write(d) - f.close() return d -def check_links (data): +def check_links(data): def get_refs(t, refs=[]): r = "(?P(^|(?<=[^A-Za-z]))[!]?[A-Z][a-z/]+(?:[A-Z][a-z/]+)+)" m = re.search (r, t) @@ -119,18 +121,27 @@ if __name__ == '__main__': try: - opts, args = getopt.getopt(sys.argv[1:], "d") + opts, args = getopt.getopt(sys.argv[1:], "dCp:") except getopt.GetoptError: # print help information and exit: - print "%s [-d] [PAGE ...]" % sys.argv[0] - print "\t-d -- Download pages from the main project wiki." + print "%s [-d] [-C] [-p prefix] [PAGE ...]" % sys.argv[0] + print "\t-d -- Download pages from the main project wiki." + print "\t-C -- Don't try to check links (it's broken anyway)" + print "\t-p prefix -- When downloading, prepend 'prefix/' to the page." sys.exit() get_page = get_page_from_file + prefix = '' + check = True for o,a in opts: if o == '-d': get_page = get_page_from_web + elif o == '-p': + prefix = a+'/' + elif o == '-C': + check = False data = {} for p in args or wiki_pages: - data[p] = get_page (p) - check_links(data) + data[p] = get_page(prefix, p) + if check: + check_links(data) diff -Nru trac-0.11.7/contrib/emailfilter.py trac-0.12.1~ppa2/contrib/emailfilter.py --- trac-0.11.7/contrib/emailfilter.py 2010-03-09 22:49:39.000000000 +0000 +++ trac-0.12.1~ppa2/contrib/emailfilter.py 2009-10-26 21:55:07.000000000 +0000 @@ -7,6 +7,13 @@ Copyright 2005, Daniel Lundin Copyright 2005, Edgewall Software +Please note: + +This is only a starting point. See + * http://trac.edgewall.org/ticket/5327 and + * http://trac-hacks.org/intertrac/EmailtoTracScript +for more complete and advanced examples. + The scripts reads emails from stdin and inserts directly into a Trac database. MIME headers are mapped as follows: diff -Nru trac-0.11.7/contrib/trac-post-commit-hook trac-0.12.1~ppa2/contrib/trac-post-commit-hook --- trac-0.11.7/contrib/trac-post-commit-hook 2010-03-09 22:49:39.000000000 +0000 +++ trac-0.12.1~ppa2/contrib/trac-post-commit-hook 1970-01-01 01:00:00.000000000 +0100 @@ -1,209 +0,0 @@ -#!/usr/bin/env python - -# trac-post-commit-hook -# ---------------------------------------------------------------------------- -# Copyright (c) 2004 Stephen Hansen -# -# Permission is hereby granted, free of charge, to any person obtaining a copy -# of this software and associated documentation files (the "Software"), to -# deal in the Software without restriction, including without limitation the -# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or -# sell copies of the Software, and to permit persons to whom the Software is -# furnished to do so, subject to the following conditions: -# -# The above copyright notice and this permission notice shall be included in -# all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL -# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING -# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS -# IN THE SOFTWARE. -# ---------------------------------------------------------------------------- - -# This Subversion post-commit hook script is meant to interface to the -# Trac (http://www.edgewall.com/products/trac/) issue tracking/wiki/etc -# system. -# -# It should be called from the 'post-commit' script in Subversion, such as -# via: -# -# REPOS="$1" -# REV="$2" -# TRAC_ENV="/path/to/tracenv" -# -# /usr/bin/python /usr/local/src/trac/contrib/trac-post-commit-hook \ -# -p "$TRAC_ENV" -r "$REV" -# -# (all the other arguments are now deprecated and not needed anymore) -# -# It searches commit messages for text in the form of: -# command #1 -# command #1, #2 -# command #1 & #2 -# command #1 and #2 -# -# Instead of the short-hand syntax "#1", "ticket:1" can be used as well, e.g.: -# command ticket:1 -# command ticket:1, ticket:2 -# command ticket:1 & ticket:2 -# command ticket:1 and ticket:2 -# -# In addition, the ':' character can be omitted and issue or bug can be used -# instead of ticket. -# -# You can have more than one command in a message. The following commands -# are supported. There is more than one spelling for each command, to make -# this as user-friendly as possible. -# -# close, closed, closes, fix, fixed, fixes -# The specified issue numbers are closed with the contents of this -# commit message being added to it. -# references, refs, addresses, re, see -# The specified issue numbers are left in their current status, but -# the contents of this commit message are added to their notes. -# -# A fairly complicated example of what you can do is with a commit message -# of: -# -# Changed blah and foo to do this or that. Fixes #10 and #12, and refs #12. -# -# This will close #10 and #12, and add a note to #12. - -import re -import os -import sys -from datetime import datetime -from optparse import OptionParser - -parser = OptionParser() -depr = '(not used anymore)' -parser.add_option('-e', '--require-envelope', dest='envelope', default='', - help=""" -Require commands to be enclosed in an envelope. -If -e[], then commands must be in the form of [closes #4]. -Must be two characters.""") -parser.add_option('-p', '--project', dest='project', - help='Path to the Trac project.') -parser.add_option('-r', '--revision', dest='rev', - help='Repository revision number.') -parser.add_option('-u', '--user', dest='user', - help='The user who is responsible for this action '+depr) -parser.add_option('-m', '--msg', dest='msg', - help='The log message to search '+depr) -parser.add_option('-c', '--encoding', dest='encoding', - help='The encoding used by the log message '+depr) -parser.add_option('-s', '--siteurl', dest='url', - help=depr+' the base_url from trac.ini will always be used.') - -(options, args) = parser.parse_args(sys.argv[1:]) - -if not 'PYTHON_EGG_CACHE' in os.environ: - os.environ['PYTHON_EGG_CACHE'] = os.path.join(options.project, '.egg-cache') - -from trac.env import open_environment -from trac.ticket.notification import TicketNotifyEmail -from trac.ticket import Ticket -from trac.ticket.web_ui import TicketModule -# TODO: move grouped_changelog_entries to model.py -from trac.util.text import to_unicode -from trac.util.datefmt import utc -from trac.versioncontrol.api import NoSuchChangeset - -ticket_prefix = '(?:#|(?:ticket|issue|bug)[: ]?)' -ticket_reference = ticket_prefix + '[0-9]+' -ticket_command = (r'(?P[A-Za-z]*).?' - '(?P%s(?:(?:[, &]*|[ ]?and[ ]?)%s)*)' % - (ticket_reference, ticket_reference)) - -if options.envelope: - ticket_command = r'\%s%s\%s' % (options.envelope[0], ticket_command, - options.envelope[1]) - -command_re = re.compile(ticket_command) -ticket_re = re.compile(ticket_prefix + '([0-9]+)') - -class CommitHook: - _supported_cmds = {'close': '_cmdClose', - 'closed': '_cmdClose', - 'closes': '_cmdClose', - 'fix': '_cmdClose', - 'fixed': '_cmdClose', - 'fixes': '_cmdClose', - 'addresses': '_cmdRefs', - 're': '_cmdRefs', - 'references': '_cmdRefs', - 'refs': '_cmdRefs', - 'see': '_cmdRefs'} - - def __init__(self, project=options.project, author=options.user, - rev=options.rev, url=options.url): - self.env = open_environment(project) - repos = self.env.get_repository() - repos.sync() - - # Instead of bothering with the encoding, we'll use unicode data - # as provided by the Trac versioncontrol API (#1310). - try: - chgset = repos.get_changeset(rev) - except NoSuchChangeset: - return # out of scope changesets are not cached - self.author = chgset.author - self.rev = rev - self.msg = "(In [%s]) %s" % (rev, chgset.message) - self.now = datetime.now(utc) - - cmd_groups = command_re.findall(self.msg) - - tickets = {} - for cmd, tkts in cmd_groups: - funcname = CommitHook._supported_cmds.get(cmd.lower(), '') - if funcname: - for tkt_id in ticket_re.findall(tkts): - func = getattr(self, funcname) - tickets.setdefault(tkt_id, []).append(func) - - for tkt_id, cmds in tickets.iteritems(): - try: - db = self.env.get_db_cnx() - - ticket = Ticket(self.env, int(tkt_id), db) - for cmd in cmds: - cmd(ticket) - - # determine sequence number... - cnum = 0 - tm = TicketModule(self.env) - for change in tm.grouped_changelog_entries(ticket, db): - if change['permanent']: - cnum += 1 - - ticket.save_changes(self.author, self.msg, self.now, db, cnum+1) - db.commit() - - tn = TicketNotifyEmail(self.env) - tn.notify(ticket, newticket=0, modtime=self.now) - except Exception, e: - # import traceback - # traceback.print_exc(file=sys.stderr) - print>>sys.stderr, 'Unexpected error while processing ticket ' \ - 'ID %s: %s' % (tkt_id, e) - - - def _cmdClose(self, ticket): - ticket['status'] = 'closed' - ticket['resolution'] = 'fixed' - - def _cmdRefs(self, ticket): - pass - - -if __name__ == "__main__": - if len(sys.argv) < 5: - print "For usage: %s --help" % (sys.argv[0]) - print - print "Note that the deprecated options will be removed in Trac 0.12." - else: - CommitHook() diff -Nru trac-0.11.7/contrib/trac-post-commit-hook.cmd trac-0.12.1~ppa2/contrib/trac-post-commit-hook.cmd --- trac-0.11.7/contrib/trac-post-commit-hook.cmd 2010-03-09 22:49:39.000000000 +0000 +++ trac-0.12.1~ppa2/contrib/trac-post-commit-hook.cmd 1970-01-01 01:00:00.000000000 +0100 @@ -1,38 +0,0 @@ -@ECHO OFF -:: -:: Trac post-commit-hook script for Windows -:: -:: Contributed by markus, modified by cboos. - -:: Usage: -:: -:: 1) Insert the following line in your post-commit.bat script -:: -:: call %~dp0\trac-post-commit-hook.cmd %1 %2 -:: -:: 2) Check the 'Modify paths' section below, be sure to set at least TRAC_ENV - - -:: ---------------------------------------------------------- -:: Modify paths here: - -:: -- this one *must* be set -SET TRAC_ENV= - -:: -- set if Python is not in the system path -SET PYTHON_PATH= - -:: -- set to the folder containing trac/ if installed in a non-standard location -SET TRAC_PATH= -:: ---------------------------------------------------------- - -:: Do not execute hook if trac environment does not exist -IF NOT EXIST %TRAC_ENV% GOTO :EOF - -set PATH=%PYTHON_PATH%;%PATH% -set PYTHONPATH=%TRAC_PATH%;%PYTHONPATH% - -SET REV=%2 - -Python "%~dp0\trac-post-commit-hook" -p "%TRAC_ENV%" -r "%REV%" - diff -Nru trac-0.11.7/contrib/trac-svn-hook trac-0.12.1~ppa2/contrib/trac-svn-hook --- trac-0.11.7/contrib/trac-svn-hook 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/contrib/trac-svn-hook 2010-02-16 10:12:24.000000000 +0000 @@ -0,0 +1,219 @@ +#!/bin/sh +# +# = trac-svn-hook = +# +# Purpose:: this script is meant to be called from the Subversion hooks +# for notifying Trac when changesets are added or modified. +# +# Scope:: The http://trac.edgewall.org/wiki/0.12/TracRepositoryAdmin page +# describes how to directly call the relevant trac-admin commands +# from the Subversion hooks. In most cases this should be enough, +# however this script should make troubleshooting easier and +# has support for notifying multiple Trac environments. +# +# Usage:: copy this script to some central place, for example in your +# TRAC_ENV or TRAC_PARENT_ENV folder +# **Be sure to read the Configuration Notes section below first** +# then fill in the variables listed below the Configuration section. +# +# For each Subversion repository $REPOS that has to be monitored by +# your Trac environment(s), you need to modify the hooks in order to +# call the present script: +# +# Add this to your `$REPOS/hooks/post-commit` script: +# +# /path/to/trac-svn-hook $REPOS $REV +# +# If you allow revision property editing in `$REPOS/hooks/pre-revprop-change`, +# then you can let Trac know about modified changesets by adding the following +# lines to the `$REPOS/hooks/post-revprop-change` script: +# +# if [ "$PROPNAME" = "svn:log" -o "$PROPNAME" = "svn:author" ]; then +# /path/to/trac-svn-hook $REPOS $REV $USER $PROPNAME +# fi +# +# See also http://svnbook.red-bean.com/en/1.5/svn.reposadmin.create.html#svn.reposadmin.create.hooks +# +# Platform:: Unix or Cygwin. +# +# On Windows, if you have Cygwin installed, you can also use this +# script instead of the `trac-svn-hook.cmd`. +# In your `post-commit.bat` and `post-revprop-change.bat` hooks, call +# this script using: +# +# bash /path/to/trac-svn-hook "%1" "%2" "%3" "%4" +# +# ----------------------------------------------------------------------------- +# +# == Configuration +# +# Uncomment and adapt to your local setup: +# +# export TRAC_ENV=/path/to/trac-env:/path/to/another/trac-env +# export PATH=/path/to/python/bin:$PATH +# export LD_LIBRARY_PATH=/path/to/python/lib:$LD_LIBRARY_PATH +# +# ----------------------------------------------------------------------------- +# +# == Configuration Notes +# +# As a preliminary remark, you should be aware that Subversion usually +# run the hooks in a very minimal environment. +# This is why we have to be very explicit about where to find things. +# +# According to http://subversion.apache.org/faq.html#hook-debugging, +# one useful method for getting the post-commit hook to work is to call +# the hook manually from a shell, as the user(s) which will end up running +# the hook (e.g. wwwrun, www-data, nobody). For example: +# +# env - $REPOS/hooks/post-commit $REPOS 1234 +# +# or: +# +# env - $REPOS/hooks/post-revprop-change $REPOS 1234 nobody svn:log +# +# +# The environment variables that have to be set in this script are +# TRAC_ENV, PATH and eventually LD_LIBRARY_PATH. +# +# TRAC_ENV:: the path(s) to the Trac environment(s) +# +# In case you need to maintain more than one environment in sync with +# the repository (using a different scope or not), simply specify more +# than one path, using the ":" path separator (or ";" if the script is +# used on Windows with Cygwin's bash - in this case also don't forget to +# enclose the list of paths in quotes, e.g. TRAC_ENV="path1;path2"). +# +# Note that if you have to maintain multiple repositories and multiple Trac +# environments, and you have some non-trivial mapping between repositories +# and Trac environments, then you can leave the TRAC_ENV setting out of +# this file and put it directly in your post-commit and post-revprop-change +# hooks, so that the changes to each repositories are notified to the +# appropriate environments (don't forget to export TRAC_ENV in this case). +# +# PATH:: the folder containing the trac-admin script +# +# This folder is typically the same as your Python installation bin/ folder. +# If this is /usr/bin, then you probably don't need to put it in the PATH. +# +# Note that if you're using a python program installed in a non-default +# location (such as /usr/local or a virtual environment), then you need +# to add it to the PATH as well. +# +# LD_LIBRARY_PATH:: folder(s) containing additional required libraries +# +# You may also need to setup the LD_LIBRARY_PATH accordingly. +# The same goes for any custom dependency, such as SQLite libraries or +# SVN libraries: make sure everything is reachable. +# For example, if you get errors like "global name 'sqlite' is not defined" +# or similar, then make sure the LD_LIBRARY_PATH contains the path to all +# the required libraries (libsqlite3.so in the above example). +# +# +# ----------------------------------------------------------------------------- +# +# == Examples +# +# === Minimal setup example === +# +# Python is installed in /usr/bin, Trac was easy_install'ed. +# +# {{{ +# export TRAC_ENV=/srv/trac/the_trac_env +# }}} +# +# +# === Virtualenv setup example === +# +# Here we're using a Trac installation set up using virtualenv +# (http://pypi.python.org/pypi/virtualenv). +# +# In this example, the virtualenv is located in +# /packages/trac/branches/trac-multirepos +# and is based off a custom Python installation (/opt/python-2.4.4). +# We're also using a custom SQLite build (/opt/sqlite-3.3.8). +# +# Note that virtualenv's activate script doesn't seem to care +# about LD_LIBRARY_PATH and the only other thing it does and that +# we need here is to set the PATH, we can as well do that ourselves: +# +# We also want to notify two Trac instances: +# +# {{{ +# export TRAC_ENV=/srv/trac/the_trac_env:/srv/trac/trac_other_trac_env +# export PATH=/packages/trac/branches/trac-multirepos/bin:$PATH +# export LD_LIBRARY_PATH=/opt/python-2.4.4/lib:/opt/sqlite-3.3.8/lib:$LD_LIBRARY_PATH +# }}} +# +# +# === Cygwin setup example === +# +# {{{ +# export TRAC_ENV=C:/Workspace/local/trac/devel +# export PYTHONPATH=C:/Workspace/src/trac/repos/multirepos +# export PATH=/C/Dev/Python261/Scripts:$PATH +# }}} +# +# ----------------------------------------------------------------------------- +# +# This is the script itself, you shouldn't need to modify this part. + +# -- Command line arguments (cf. usage) + +REPOS="$1" +REV="$2" +USER="$3" +PROPNAME="$4" + +# -- Foolproofing + +if [ -z "$REPOS" -o -z "$REV" ]; then + echo "Usage: $0 REPOS REV" + exit 2 +fi + +if ! python -V 2>/dev/null; then + echo "python is not in the PATH ($PATH), check PATH and LD_LIBRARY_PATH." + exit 2 +fi + +if [ -z "$TRAC_ENV" ]; then + echo "TRAC_ENV is not set." + exit 2 +fi + +# -- Feedback + +echo "----" + +if [ -z "$USER" -a -z "$PROPNAME" ]; then + EVENT="added" + echo "Changeset $REV was added in $REPOS" +else + EVENT="modified" + echo "Changeset $REV was modified by $USER in $REPOS" +fi + +# -- Call "trac-admin ... changeset ... $REPOS $REV" for each Trac environment + +ifs=$IFS +IFS=: +if [ -n "$BASH_VERSION" ]; then # we can use Bash syntax + if [[ ${BASH_VERSINFO[5]} = *cygwin ]]; then + IFS=";" + fi +fi +for env in $TRAC_ENV; do + if [ -r "$env/VERSION" ]; then + log=$env/log/svn-hooks-`basename $REPOS`.log + nohup sh <> $log 2>&1 & + echo "Changeset $REV $EVENT" + trac-admin $env changeset $EVENT $REPOS $REV && \ + echo "OK" || echo "FAILED: see the Trac log" +EOF + else + echo "$env doesn't seem to be a Trac environment, skipping..." + fi +done +IFS=$ifs + diff -Nru trac-0.11.7/contrib/trac-svn-post-commit-hook.cmd trac-0.12.1~ppa2/contrib/trac-svn-post-commit-hook.cmd --- trac-0.11.7/contrib/trac-svn-post-commit-hook.cmd 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/contrib/trac-svn-post-commit-hook.cmd 2010-02-03 17:07:11.000000000 +0000 @@ -0,0 +1,84 @@ +@ECHO OFF +:: +:: Trac post-commit-hook script for Windows +:: +:: Contributed by markus, modified by cboos. +:: Modified for the multirepos branch to use the `changeset` command. + +:: Usage: +:: +:: 1. Insert the following line in your REPOS/hooks/post-commit.bat script: +:: +:: call %~dp0\trac-post-commit-hook.cmd %1 %2 +:: +:: 2. Check the 'Modify paths' section below, be sure to set at least TRAC_ENV +:: +:: 3. Verify that the hook is working: +:: +:: - enable DEBUG level logging to a file and to the console +:: (see TracLogging) +:: +:: - call the trac-post-commit-hook.cmd from a cmd.exe shell: +:: +:: trac-post-commit-hook.cmd 123 +:: +:: - call the post-commit.bat hook from a cmd.exe shell (check that +:: no unwanted side-effects could be triggered when doing this...): +:: +:: post-commit.bat 123 +:: +:: - in each case, verify that you actually see the logging from Trac +:: and in particular that you see something like (near the end): +:: +:: DEBUG: Event changeset_added on for revision 123 +:: + + +:: ---------------------------------------------------------- +:: Modify paths here: + +:: -- this one *must* be set +set TRAC_ENV= + +:: -- set if Python is not in the system path +set PYTHON_PATH= + +:: -- set to the folder containing trac/ if installed in a non-standard location +set TRAC_PATH= +:: ---------------------------------------------------------- + +:: -- Do not execute hook if trac environment does not exist +if not exist %TRAC_ENV% goto :EOF + +:: -- Determine trac-admin + +:: By default assume it's reachable from the PATH +set TRAC_ADMIN=trac-admin.exe + +:: ... or take it from the Scripts folder of the specified Python installation +if not %PYTHON_PATH%.==. set TRAC_ADMIN="%PYTHON_PATH%/Scripts/trac-admin.exe" + +:: ... or take it from the specified Trac source checkout +if not %TRAC_PATH%.==. set TRAC_ADMIN=python.exe "%TRAC_PATH%/trac/admin/console.py" + +:: -- Setup the environment +set PATH=%PYTHON_PATH%;%PATH% +set PYTHONPATH=%TRAC_PATH%;%PYTHONPATH% + +:: -- Retrieve the information that Subversion gave to the hook +set REPOS=%1 +set REV=%2 + +:: Now we're about to call trac-admin's changeset added command. +:: We have to call it like that: +:: +:: repository changeset added +:: +:: where can be the repository symbolic name or directly +:: the repository directory, which we happen to have in %REPOS%. + +%TRAC_ADMIN% "%TRAC_ENV%" changeset added "%REPOS%" "%REV%" + +:: Based on either the symbolic name or the %REPOS% information, +:: Trac will figure out which repository (or which scoped repositories) +:: it has to synchronize. diff -Nru trac-0.11.7/contrib/workflow/showworkflow trac-0.12.1~ppa2/contrib/workflow/showworkflow --- trac-0.11.7/contrib/workflow/showworkflow 2010-03-09 22:49:39.000000000 +0000 +++ trac-0.12.1~ppa2/contrib/workflow/showworkflow 2010-04-13 22:07:26.000000000 +0100 @@ -23,6 +23,11 @@ exit 1 fi -dot -T png -o "$png" "$dot" -dot -T ps -o "$ps" "$dot" && ps2pdf "$ps" "$pdf" || exit 1 -kpdf "$pdf" +cat "$dot" +if [ "$OSTYPE" = cygwin ]; then + dot -T png -o "$png" "$dot" + cmd /c start $png +else + dot -T ps -o "$ps" "$dot" && ps2pdf "$ps" "$pdf" || exit 1 + kpdf "$pdf" +fi diff -Nru trac-0.11.7/contrib/workflow/workflow_parser.py trac-0.12.1~ppa2/contrib/workflow/workflow_parser.py --- trac-0.11.7/contrib/workflow/workflow_parser.py 2010-03-09 22:49:39.000000000 +0000 +++ trac-0.12.1~ppa2/contrib/workflow/workflow_parser.py 2010-04-13 22:07:26.000000000 +0100 @@ -9,7 +9,7 @@ from trac.config import Configuration from trac.ticket.default_workflow import parse_workflow_config -_debug = True +_debug = False def debug(s): if _debug: sys.stderr.write(s) @@ -46,7 +46,13 @@ """Returns a list of lines to be fed to graphviz.""" # The size value makes it easier to create a useful printout. color_scheme = ColorScheme() - digraph_lines = ['digraph G {\ncenter=1\nsize="10,8"\n'] + digraph_lines = [""" +digraph G { + center=1 + size="10,8" + { rank=source; new [ shape=invtrapezium ] } + { rank=sink; closed [ shape=trapezium ] } + """] for action, attributes in actions.items(): label = [attributes['name'], ] if show_ops: @@ -58,10 +64,10 @@ for oldstate in attributes['oldstates']: color = color_scheme.get_color(attributes['name']) digraph_lines.append( - '"%s" -> "%s" [label="%s" color=%s fontcolor=%s]\n' % \ + ' "%s" -> "%s" [label="%s" color=%s fontcolor=%s]' % \ (oldstate, attributes['newstate'], '\\n'.join(label), color, color)) - digraph_lines.append('}\n') + digraph_lines.append('}') return digraph_lines def main(filename, show_ops=False, show_perms=False): @@ -75,7 +81,7 @@ digraph_lines = actions2graphviz(actions, show_ops, show_perms) # And output - sys.stdout.write(''.join(digraph_lines)) + sys.stdout.write('\n'.join(digraph_lines)) def usage(output): output.write('workflow_parser [options] configfile.ini\n' diff -Nru trac-0.11.7/debian/changelog trac-0.12.1~ppa2/debian/changelog --- trac-0.11.7/debian/changelog 2010-05-06 03:24:14.000000000 +0100 +++ trac-0.12.1~ppa2/debian/changelog 2010-05-06 03:09:19.000000000 +0100 @@ -1,3 +1,30 @@ +trac (0.12.1~ppa2) lucid; urgency=low + + * Rebuilding on lucid. + + -- Celso Providelo Wed, 05 May 2010 23:09:04 -0300 + +trac (0.12.1~ppa1) hardy; urgency=low + + * Packaging trunk ... + + -- Celso Providelo Tue, 04 May 2010 23:09:27 -0300 + +trac (0.11.7-3) unstable; urgency=low + + * Correced accidently moved DEBHELPER line (Closes: #576988). + Thanks to Marc J. Driftmeyer . + + -- W. Martin Borgert Thu, 08 Apr 2010 19:56:26 +0000 + +trac (0.11.7-2) unstable; urgency=low + + * Removed Luis and Jesus from uploaders. Thanks for your work! + * Create symlink for jquery.js (Closes: #495053). Thanks to + Max V. Stotsky" . + + -- W. Martin Borgert Thu, 08 Apr 2010 08:25:08 +0000 + trac (0.11.7-1) unstable; urgency=low * New upstream release (Closes: #573260). diff -Nru trac-0.11.7/debian/control trac-0.12.1~ppa2/debian/control --- trac-0.11.7/debian/control 2010-05-06 03:24:14.000000000 +0100 +++ trac-0.12.1~ppa2/debian/control 2010-05-05 03:22:03.000000000 +0100 @@ -4,7 +4,7 @@ Build-Depends-Indep: python-setuptools (>= 0.5) Build-Depends: python-genshi (>= 0.5), python-central, python-all-dev (>= 2.5.4), debhelper (>= 7), dpatch Maintainer: Python Applications Packaging Team -Uploaders: Otavio Salvador , Jesus Climent , Luis Matos , W. Martin Borgert +Uploaders: Otavio Salvador , W. Martin Borgert Standards-Version: 3.8.4 Vcs-Svn: svn://svn.debian.org/svn/python-apps/packages/trac/trunk/ Vcs-Browser: http://svn.debian.org/viewsvn/python-apps/packages/trac/trunk/ @@ -13,7 +13,7 @@ Package: trac Architecture: all -Depends: ${python:Depends}, python-setuptools, python (>= 2.5) | python-pysqlite2 (>= 2.3.2) | python-psycopg2 (>= 1.2.1) | python-mysqldb, python-genshi (>= 0.5) +Depends: ${python:Depends}, python-setuptools, python (>= 2.5) | python-pysqlite2 (>= 2.3.2) | python-psycopg2 (>= 1.2.1) | python-mysqldb, python-genshi (>= 0.6) Recommends: apache2 | httpd, python-subversion, libjs-jquery, python-pygments (>= 0.6) | enscript, python-tz Suggests: python-docutils, libapache2-mod-wsgi | libapache2-mod-python, python-textile (>= 2.0), trac-git, trac-spamfilter, trac-bzr (>= 0.2+bzr45), trac-mercurial (>= 0.11.0.4), trac-accountmanager, trac-email2trac, trac-xmlrpc, trac-wysiwyg, trac-mastertickets, trac-customfieldadmin, trac-bitten, trac-authopenid, trac-graphviz, trac-wikirename, trac-wikiprint, trac-ja-resource Conflicts: libapache2-mod-python2.3 (<< 3.2.8-3) diff -Nru trac-0.11.7/debian/patches/00list trac-0.12.1~ppa2/debian/patches/00list --- trac-0.11.7/debian/patches/00list 2010-05-06 03:24:14.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/00list 2010-05-05 03:21:18.000000000 +0100 @@ -1,7 +1,3 @@ -15_remove_jquery_file.dpatch 20_add_interpreter_line.dpatch 30_default_charset_utf8.dpatch -40_timeline_author_filter.dpatch 50_sqlitetopg_script.dpatch -70_cache_control_typo.dpatch -80_correct_plugin_names.dpatch diff -Nru trac-0.11.7/debian/patches/15_remove_jquery_file.dpatch trac-0.12.1~ppa2/debian/patches/15_remove_jquery_file.dpatch --- trac-0.11.7/debian/patches/15_remove_jquery_file.dpatch 2010-05-06 03:24:14.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/15_remove_jquery_file.dpatch 1970-01-01 01:00:00.000000000 +0100 @@ -1,39 +0,0 @@ -#! /bin/sh /usr/share/dpatch/dpatch-run -## 15_remove_jquery_file.dpatch by -## -## All lines beginning with `## DP:' are a description of the patch. -## DP: Removes the jquery.js file - -@DPATCH@ - -diff --git a/Trac.egg-info/SOURCES.txt b/Trac.egg-info/SOURCES.txt -index c2d0840..d0e4746 100644 ---- a/Trac.egg-info/SOURCES.txt -+++ b/Trac.egg-info/SOURCES.txt -@@ -157,7 +157,6 @@ trac/htdocs/js/diff.js - trac/htdocs/js/expand_dir.js - trac/htdocs/js/folding.js - trac/htdocs/js/ie_pre7_hacks.js --trac/htdocs/js/jquery.js - trac/htdocs/js/keyboard_nav.js - trac/htdocs/js/noconflict.js - trac/htdocs/js/query.js - -diff --git a/trac/htdocs/js/jquery.js b/trac/htdocs/js/jquery.js -deleted file mode 100644 -index 95dd013..0000000 ---- a/trac/htdocs/js/jquery.js -+++ /dev/null -@@ -1,11 +0,0 @@ --/* -- * jQuery 1.2.6 - New Wave Javascript -- * -- * Copyright (c) 2008 John Resig (jquery.com) -- * Dual licensed under the MIT (MIT-LICENSE.txt) -- * and GPL (GPL-LICENSE.txt) licenses. -- * -- * $Date: 2008-05-24 14:22:17 -0400 (Sat, 24 May 2008) $ -- * $Rev: 5685 $ -- */ --eval(function(p,a,c,k,e,r){e=function(c){return(c35?String.fromCharCode(c+29):c.toString(36))};if(!''.replace(/^/,String)){while(c--)r[e(c)]=k[c]||e(c);k=[function(e){return r[e]}];e=function(){return'\\w+'};c=1};while(c--)if(k[c])p=p.replace(new RegExp('\\b'+e(c)+'\\b','g'),k[c]);return p}('(H(){J w=1b.4M,3m$=1b.$;J D=1b.4M=1b.$=H(a,b){I 2B D.17.5j(a,b)};J u=/^[^<]*(<(.|\\s)+>)[^>]*$|^#(\\w+)$/,62=/^.[^:#\\[\\.]*$/,12;D.17=D.44={5j:H(d,b){d=d||S;G(d.16){7[0]=d;7.K=1;I 7}G(1j d=="23"){J c=u.2D(d);G(c&&(c[1]||!b)){G(c[1])d=D.4h([c[1]],b);N{J a=S.61(c[3]);G(a){G(a.2v!=c[3])I D().2q(d);I D(a)}d=[]}}N I D(b).2q(d)}N G(D.1D(d))I D(S)[D.17.27?"27":"43"](d);I 7.6Y(D.2d(d))},5w:"1.2.6",8G:H(){I 7.K},K:0,3p:H(a){I a==12?D.2d(7):7[a]},2I:H(b){J a=D(b);a.5n=7;I a},6Y:H(a){7.K=0;2p.44.1p.1w(7,a);I 7},P:H(a,b){I D.P(7,a,b)},5i:H(b){J a=-1;I D.2L(b&&b.5w?b[0]:b,7)},1K:H(c,a,b){J d=c;G(c.1q==56)G(a===12)I 7[0]&&D[b||"1K"](7[0],c);N{d={};d[c]=a}I 7.P(H(i){R(c 1n d)D.1K(b?7.V:7,c,D.1i(7,d[c],b,i,c))})},1g:H(b,a){G((b==\'2h\'||b==\'1Z\')&&3d(a)<0)a=12;I 7.1K(b,a,"2a")},1r:H(b){G(1j b!="49"&&b!=U)I 7.4E().3v((7[0]&&7[0].2z||S).5F(b));J a="";D.P(b||7,H(){D.P(7.3t,H(){G(7.16!=8)a+=7.16!=1?7.76:D.17.1r([7])})});I a},5z:H(b){G(7[0])D(b,7[0].2z).5y().39(7[0]).2l(H(){J a=7;1B(a.1x)a=a.1x;I a}).3v(7);I 7},8Y:H(a){I 7.P(H(){D(7).6Q().5z(a)})},8R:H(a){I 7.P(H(){D(7).5z(a)})},3v:H(){I 7.3W(19,M,Q,H(a){G(7.16==1)7.3U(a)})},6F:H(){I 7.3W(19,M,M,H(a){G(7.16==1)7.39(a,7.1x)})},6E:H(){I 7.3W(19,Q,Q,H(a){7.1d.39(a,7)})},5q:H(){I 7.3W(19,Q,M,H(a){7.1d.39(a,7.2H)})},3l:H(){I 7.5n||D([])},2q:H(b){J c=D.2l(7,H(a){I D.2q(b,a)});I 7.2I(/[^+>] [^+>]/.11(b)||b.1h("..")>-1?D.4r(c):c)},5y:H(e){J f=7.2l(H(){G(D.14.1f&&!D.4n(7)){J a=7.6o(M),5h=S.3h("1v");5h.3U(a);I D.4h([5h.4H])[0]}N I 7.6o(M)});J d=f.2q("*").5c().P(H(){G(7[E]!=12)7[E]=U});G(e===M)7.2q("*").5c().P(H(i){G(7.16==3)I;J c=D.L(7,"3w");R(J a 1n c)R(J b 1n c[a])D.W.1e(d[i],a,c[a][b],c[a][b].L)});I f},1E:H(b){I 7.2I(D.1D(b)&&D.3C(7,H(a,i){I b.1k(a,i)})||D.3g(b,7))},4Y:H(b){G(b.1q==56)G(62.11(b))I 7.2I(D.3g(b,7,M));N b=D.3g(b,7);J a=b.K&&b[b.K-1]!==12&&!b.16;I 7.1E(H(){I a?D.2L(7,b)<0:7!=b})},1e:H(a){I 7.2I(D.4r(D.2R(7.3p(),1j a==\'23\'?D(a):D.2d(a))))},3F:H(a){I!!a&&D.3g(a,7).K>0},7T:H(a){I 7.3F("."+a)},6e:H(b){G(b==12){G(7.K){J c=7[0];G(D.Y(c,"2A")){J e=c.64,63=[],15=c.15,2V=c.O=="2A-2V";G(e<0)I U;R(J i=2V?e:0,2f=2V?e+1:15.K;i<2f;i++){J d=15[i];G(d.2W){b=D.14.1f&&!d.at.2x.an?d.1r:d.2x;G(2V)I b;63.1p(b)}}I 63}N I(7[0].2x||"").1o(/\\r/g,"")}I 12}G(b.1q==4L)b+=\'\';I 7.P(H(){G(7.16!=1)I;G(b.1q==2p&&/5O|5L/.11(7.O))7.4J=(D.2L(7.2x,b)>=0||D.2L(7.34,b)>=0);N G(D.Y(7,"2A")){J a=D.2d(b);D("9R",7).P(H(){7.2W=(D.2L(7.2x,a)>=0||D.2L(7.1r,a)>=0)});G(!a.K)7.64=-1}N 7.2x=b})},2K:H(a){I a==12?(7[0]?7[0].4H:U):7.4E().3v(a)},7b:H(a){I 7.5q(a).21()},79:H(i){I 7.3s(i,i+1)},3s:H(){I 7.2I(2p.44.3s.1w(7,19))},2l:H(b){I 7.2I(D.2l(7,H(a,i){I b.1k(a,i,a)}))},5c:H(){I 7.1e(7.5n)},L:H(d,b){J a=d.1R(".");a[1]=a[1]?"."+a[1]:"";G(b===12){J c=7.5C("9z"+a[1]+"!",[a[0]]);G(c===12&&7.K)c=D.L(7[0],d);I c===12&&a[1]?7.L(a[0]):c}N I 7.1P("9u"+a[1]+"!",[a[0],b]).P(H(){D.L(7,d,b)})},3b:H(a){I 7.P(H(){D.3b(7,a)})},3W:H(g,f,h,d){J e=7.K>1,3x;I 7.P(H(){G(!3x){3x=D.4h(g,7.2z);G(h)3x.9o()}J b=7;G(f&&D.Y(7,"1T")&&D.Y(3x[0],"4F"))b=7.3H("22")[0]||7.3U(7.2z.3h("22"));J c=D([]);D.P(3x,H(){J a=e?D(7).5y(M)[0]:7;G(D.Y(a,"1m"))c=c.1e(a);N{G(a.16==1)c=c.1e(D("1m",a).21());d.1k(b,a)}});c.P(6T)})}};D.17.5j.44=D.17;H 6T(i,a){G(a.4d)D.3Y({1a:a.4d,31:Q,1O:"1m"});N D.5u(a.1r||a.6O||a.4H||"");G(a.1d)a.1d.37(a)}H 1z(){I+2B 8J}D.1l=D.17.1l=H(){J b=19[0]||{},i=1,K=19.K,4x=Q,15;G(b.1q==8I){4x=b;b=19[1]||{};i=2}G(1j b!="49"&&1j b!="H")b={};G(K==i){b=7;--i}R(;i-1}},6q:H(b,c,a){J e={};R(J d 1n c){e[d]=b.V[d];b.V[d]=c[d]}a.1k(b);R(J d 1n c)b.V[d]=e[d]},1g:H(d,e,c){G(e=="2h"||e=="1Z"){J b,3X={30:"5x",5g:"1G",18:"3I"},35=e=="2h"?["5e","6k"]:["5G","6i"];H 5b(){b=e=="2h"?d.8f:d.8c;J a=0,2C=0;D.P(35,H(){a+=3d(D.2a(d,"57"+7,M))||0;2C+=3d(D.2a(d,"2C"+7+"4b",M))||0});b-=29.83(a+2C)}G(D(d).3F(":4j"))5b();N D.6q(d,3X,5b);I 29.2f(0,b)}I D.2a(d,e,c)},2a:H(f,l,k){J e,V=f.V;H 3E(b){G(!D.14.2k)I Q;J a=3P.54(b,U);I!a||a.52("3E")==""}G(l=="1y"&&D.14.1f){e=D.1K(V,"1y");I e==""?"1":e}G(D.14.2G&&l=="18"){J d=V.50;V.50="0 7Y 7W";V.50=d}G(l.1I(/4i/i))l=y;G(!k&&V&&V[l])e=V[l];N G(3P.54){G(l.1I(/4i/i))l="4i";l=l.1o(/([A-Z])/g,"-$1").3y();J c=3P.54(f,U);G(c&&!3E(f))e=c.52(l);N{J g=[],2E=[],a=f,i=0;R(;a&&3E(a);a=a.1d)2E.6h(a);R(;i<2E.K;i++)G(3E(2E[i])){g[i]=2E[i].V.18;2E[i].V.18="3I"}e=l=="18"&&g[2E.K-1]!=U?"2F":(c&&c.52(l))||"";R(i=0;i]*?)\\/>/g,H(b,a,c){I c.1I(/^(aK|4f|7E|aG|4T|7A|aB|3n|az|ay|av)$/i)?b:a+">"});J f=D.3k(d).3y(),1v=h.3h("1v");J e=!f.1h("",""]||!f.1h("",""]||f.1I(/^<(aq|22|am|ak|ai)/)&&[1,"<1T>",""]||!f.1h("<4F")&&[2,"<1T><22>",""]||(!f.1h("<22><4F>",""]||!f.1h("<7E")&&[2,"<1T><22><7q>",""]||D.14.1f&&[1,"1v<1v>",""]||[0,"",""];1v.4H=e[1]+d+e[2];1B(e[0]--)1v=1v.5T;G(D.14.1f){J g=!f.1h("<1T")&&f.1h("<22")<0?1v.1x&&1v.1x.3t:e[1]=="<1T>"&&f.1h("<22")<0?1v.3t:[];R(J j=g.K-1;j>=0;--j)G(D.Y(g[j],"22")&&!g[j].3t.K)g[j].1d.37(g[j]);G(/^\\s/.11(d))1v.39(h.5F(d.1I(/^\\s*/)[0]),1v.1x)}d=D.2d(1v.3t)}G(d.K===0&&(!D.Y(d,"3V")&&!D.Y(d,"2A")))I;G(d[0]==12||D.Y(d,"3V")||d.15)k.1p(d);N k=D.2R(k,d)});I k},1K:H(d,f,c){G(!d||d.16==3||d.16==8)I 12;J e=!D.4n(d),40=c!==12,1f=D.14.1f;f=e&&D.3X[f]||f;G(d.2j){J g=/5Q|4d|V/.11(f);G(f=="2W"&&D.14.2k)d.1d.64;G(f 1n d&&e&&!g){G(40){G(f=="O"&&D.Y(d,"4T")&&d.1d)7p"O a3 a1\'t 9V 9U";d[f]=c}G(D.Y(d,"3V")&&d.7i(f))I d.7i(f).76;I d[f]}G(1f&&e&&f=="V")I D.1K(d.V,"9T",c);G(40)d.9Q(f,""+c);J h=1f&&e&&g?d.4G(f,2):d.4G(f);I h===U?12:h}G(1f&&f=="1y"){G(40){d.6B=1;d.1E=(d.1E||"").1o(/7f\\([^)]*\\)/,"")+(3r(c)+\'\'=="9L"?"":"7f(1y="+c*7a+")")}I d.1E&&d.1E.1h("1y=")>=0?(3d(d.1E.1I(/1y=([^)]*)/)[1])/7a)+\'\':""}f=f.1o(/-([a-z])/9H,H(a,b){I b.2r()});G(40)d[f]=c;I d[f]},3k:H(a){I(a||"").1o(/^\\s+|\\s+$/g,"")},2d:H(b){J a=[];G(b!=U){J i=b.K;G(i==U||b.1R||b.4I||b.1k)a[0]=b;N 1B(i)a[--i]=b[i]}I a},2L:H(b,a){R(J i=0,K=a.K;i*",7).21();1B(7.1x)7.37(7.1x)}},H(a,b){D.17[a]=H(){I 7.P(b,19)}});D.P(["6N","4b"],H(i,c){J b=c.3y();D.17[b]=H(a){I 7[0]==1b?D.14.2G&&S.1c["5t"+c]||D.14.2k&&1b["5s"+c]||S.70=="6Z"&&S.1C["5t"+c]||S.1c["5t"+c]:7[0]==S?29.2f(29.2f(S.1c["4y"+c],S.1C["4y"+c]),29.2f(S.1c["2i"+c],S.1C["2i"+c])):a==12?(7.K?D.1g(7[0],b):U):7.1g(b,a.1q==56?a:a+"2X")}});H 25(a,b){I a[0]&&3r(D.2a(a[0],b,M),10)||0}J C=D.14.2k&&3r(D.14.5B)<8H?"(?:[\\\\w*3m-]|\\\\\\\\.)":"(?:[\\\\w\\8F-\\8E*3m-]|\\\\\\\\.)",6L=2B 4v("^>\\\\s*("+C+"+)"),6J=2B 4v("^("+C+"+)(#)("+C+"+)"),6I=2B 4v("^([#.]?)("+C+"*)");D.1l({6H:{"":H(a,i,m){I m[2]=="*"||D.Y(a,m[2])},"#":H(a,i,m){I a.4G("2v")==m[2]},":":{8D:H(a,i,m){I im[3]-0},3a:H(a,i,m){I m[3]-0==i},79:H(a,i,m){I m[3]-0==i},3o:H(a,i){I i==0},3S:H(a,i,m,r){I i==r.K-1},6D:H(a,i){I i%2==0},6C:H(a,i){I i%2},"3o-4u":H(a){I a.1d.3H("*")[0]==a},"3S-4u":H(a){I D.3a(a.1d.5T,1,"4l")==a},"8z-4u":H(a){I!D.3a(a.1d.5T,2,"4l")},6W:H(a){I a.1x},4E:H(a){I!a.1x},8y:H(a,i,m){I(a.6O||a.8x||D(a).1r()||"").1h(m[3])>=0},4j:H(a){I"1G"!=a.O&&D.1g(a,"18")!="2F"&&D.1g(a,"5g")!="1G"},1G:H(a){I"1G"==a.O||D.1g(a,"18")=="2F"||D.1g(a,"5g")=="1G"},8w:H(a){I!a.3R},3R:H(a){I a.3R},4J:H(a){I a.4J},2W:H(a){I a.2W||D.1K(a,"2W")},1r:H(a){I"1r"==a.O},5O:H(a){I"5O"==a.O},5L:H(a){I"5L"==a.O},5p:H(a){I"5p"==a.O},3Q:H(a){I"3Q"==a.O},5o:H(a){I"5o"==a.O},6A:H(a){I"6A"==a.O},6z:H(a){I"6z"==a.O},2s:H(a){I"2s"==a.O||D.Y(a,"2s")},4T:H(a){I/4T|2A|6y|2s/i.11(a.Y)},3T:H(a,i,m){I D.2q(m[3],a).K},8t:H(a){I/h\\d/i.11(a.Y)},8s:H(a){I D.3C(D.3O,H(b){I a==b.T}).K}}},6x:[/^(\\[) *@?([\\w-]+) *([!*$^~=]*) *(\'?"?)(.*?)\\4 *\\]/,/^(:)([\\w-]+)\\("?\'?(.*?(\\(.*?\\))?[^(]*?)"?\'?\\)/,2B 4v("^([:.#]*)("+C+"+)")],3g:H(a,c,b){J d,1t=[];1B(a&&a!=d){d=a;J f=D.1E(a,c,b);a=f.t.1o(/^\\s*,\\s*/,"");1t=b?c=f.r:D.2R(1t,f.r)}I 1t},2q:H(t,o){G(1j t!="23")I[t];G(o&&o.16!=1&&o.16!=9)I[];o=o||S;J d=[o],2o=[],3S,Y;1B(t&&3S!=t){J r=[];3S=t;t=D.3k(t);J l=Q,3j=6L,m=3j.2D(t);G(m){Y=m[1].2r();R(J i=0;d[i];i++)R(J c=d[i].1x;c;c=c.2H)G(c.16==1&&(Y=="*"||c.Y.2r()==Y))r.1p(c);d=r;t=t.1o(3j,"");G(t.1h(" ")==0)6M;l=M}N{3j=/^([>+~])\\s*(\\w*)/i;G((m=3j.2D(t))!=U){r=[];J k={};Y=m[2].2r();m=m[1];R(J j=0,3i=d.K;j<3i;j++){J n=m=="~"||m=="+"?d[j].2H:d[j].1x;R(;n;n=n.2H)G(n.16==1){J g=D.L(n);G(m=="~"&&k[g])1X;G(!Y||n.Y.2r()==Y){G(m=="~")k[g]=M;r.1p(n)}G(m=="+")1X}}d=r;t=D.3k(t.1o(3j,""));l=M}}G(t&&!l){G(!t.1h(",")){G(o==d[0])d.4s();2o=D.2R(2o,d);r=d=[o];t=" "+t.6v(1,t.K)}N{J h=6J;J m=h.2D(t);G(m){m=[0,m[2],m[3],m[1]]}N{h=6I;m=h.2D(t)}m[2]=m[2].1o(/\\\\/g,"");J f=d[d.K-1];G(m[1]=="#"&&f&&f.61&&!D.4n(f)){J p=f.61(m[2]);G((D.14.1f||D.14.2G)&&p&&1j p.2v=="23"&&p.2v!=m[2])p=D(\'[@2v="\'+m[2]+\'"]\',f)[0];d=r=p&&(!m[3]||D.Y(p,m[3]))?[p]:[]}N{R(J i=0;d[i];i++){J a=m[1]=="#"&&m[3]?m[3]:m[1]!=""||m[0]==""?"*":m[2];G(a=="*"&&d[i].Y.3y()=="49")a="3n";r=D.2R(r,d[i].3H(a))}G(m[1]==".")r=D.5m(r,m[2]);G(m[1]=="#"){J e=[];R(J i=0;r[i];i++)G(r[i].4G("2v")==m[2]){e=[r[i]];1X}r=e}d=r}t=t.1o(h,"")}}G(t){J b=D.1E(t,r);d=r=b.r;t=D.3k(b.t)}}G(t)d=[];G(d&&o==d[0])d.4s();2o=D.2R(2o,d);I 2o},5m:H(r,m,a){m=" "+m+" ";J c=[];R(J i=0;r[i];i++){J b=(" "+r[i].1F+" ").1h(m)>=0;G(!a&&b||a&&!b)c.1p(r[i])}I c},1E:H(t,r,h){J d;1B(t&&t!=d){d=t;J p=D.6x,m;R(J i=0;p[i];i++){m=p[i].2D(t);G(m){t=t.8r(m[0].K);m[2]=m[2].1o(/\\\\/g,"");1X}}G(!m)1X;G(m[1]==":"&&m[2]=="4Y")r=62.11(m[3])?D.1E(m[3],r,M).r:D(r).4Y(m[3]);N G(m[1]==".")r=D.5m(r,m[2],h);N G(m[1]=="["){J g=[],O=m[3];R(J i=0,3i=r.K;i<3i;i++){J a=r[i],z=a[D.3X[m[2]]||m[2]];G(z==U||/5Q|4d|2W/.11(m[2]))z=D.1K(a,m[2])||\'\';G((O==""&&!!z||O=="="&&z==m[5]||O=="!="&&z!=m[5]||O=="^="&&z&&!z.1h(m[5])||O=="$="&&z.6v(z.K-m[5].K)==m[5]||(O=="*="||O=="~=")&&z.1h(m[5])>=0)^h)g.1p(a)}r=g}N G(m[1]==":"&&m[2]=="3a-4u"){J e={},g=[],11=/(-?)(\\d*)n((?:\\+|-)?\\d*)/.2D(m[3]=="6D"&&"2n"||m[3]=="6C"&&"2n+1"||!/\\D/.11(m[3])&&"8q+"+m[3]||m[3]),3o=(11[1]+(11[2]||1))-0,d=11[3]-0;R(J i=0,3i=r.K;i<3i;i++){J j=r[i],1d=j.1d,2v=D.L(1d);G(!e[2v]){J c=1;R(J n=1d.1x;n;n=n.2H)G(n.16==1)n.4q=c++;e[2v]=M}J b=Q;G(3o==0){G(j.4q==d)b=M}N G((j.4q-d)%3o==0&&(j.4q-d)/3o>=0)b=M;G(b^h)g.1p(j)}r=g}N{J f=D.6H[m[1]];G(1j f=="49")f=f[m[2]];G(1j f=="23")f=6u("Q||H(a,i){I "+f+";}");r=D.3C(r,H(a,i){I f(a,i,m,r)},h)}}I{r:r,t:t}},4S:H(b,c){J a=[],1t=b[c];1B(1t&&1t!=S){G(1t.16==1)a.1p(1t);1t=1t[c]}I a},3a:H(a,e,c,b){e=e||1;J d=0;R(;a;a=a[c])G(a.16==1&&++d==e)1X;I a},5v:H(n,a){J r=[];R(;n;n=n.2H){G(n.16==1&&n!=a)r.1p(n)}I r}});D.W={1e:H(f,i,g,e){G(f.16==3||f.16==8)I;G(D.14.1f&&f.4I)f=1b;G(!g.24)g.24=7.24++;G(e!=12){J h=g;g=7.3M(h,H(){I h.1w(7,19)});g.L=e}J j=D.L(f,"3w")||D.L(f,"3w",{}),1H=D.L(f,"1H")||D.L(f,"1H",H(){G(1j D!="12"&&!D.W.5k)I D.W.1H.1w(19.3L.T,19)});1H.T=f;D.P(i.1R(/\\s+/),H(c,b){J a=b.1R(".");b=a[0];g.O=a[1];J d=j[b];G(!d){d=j[b]={};G(!D.W.2t[b]||D.W.2t[b].4p.1k(f)===Q){G(f.3K)f.3K(b,1H,Q);N G(f.6t)f.6t("4o"+b,1H)}}d[g.24]=g;D.W.26[b]=M});f=U},24:1,26:{},21:H(e,h,f){G(e.16==3||e.16==8)I;J i=D.L(e,"3w"),1L,5i;G(i){G(h==12||(1j h=="23"&&h.8p(0)=="."))R(J g 1n i)7.21(e,g+(h||""));N{G(h.O){f=h.2y;h=h.O}D.P(h.1R(/\\s+/),H(b,a){J c=a.1R(".");a=c[0];G(i[a]){G(f)2U i[a][f.24];N R(f 1n i[a])G(!c[1]||i[a][f].O==c[1])2U i[a][f];R(1L 1n i[a])1X;G(!1L){G(!D.W.2t[a]||D.W.2t[a].4A.1k(e)===Q){G(e.6p)e.6p(a,D.L(e,"1H"),Q);N G(e.6n)e.6n("4o"+a,D.L(e,"1H"))}1L=U;2U i[a]}}})}R(1L 1n i)1X;G(!1L){J d=D.L(e,"1H");G(d)d.T=U;D.3b(e,"3w");D.3b(e,"1H")}}},1P:H(h,c,f,g,i){c=D.2d(c);G(h.1h("!")>=0){h=h.3s(0,-1);J a=M}G(!f){G(7.26[h])D("*").1e([1b,S]).1P(h,c)}N{G(f.16==3||f.16==8)I 12;J b,1L,17=D.1D(f[h]||U),W=!c[0]||!c[0].32;G(W){c.6h({O:h,2J:f,32:H(){},3J:H(){},4C:1z()});c[0][E]=M}c[0].O=h;G(a)c[0].6m=M;J d=D.L(f,"1H");G(d)b=d.1w(f,c);G((!17||(D.Y(f,\'a\')&&h=="4V"))&&f["4o"+h]&&f["4o"+h].1w(f,c)===Q)b=Q;G(W)c.4s();G(i&&D.1D(i)){1L=i.1w(f,b==U?c:c.7d(b));G(1L!==12)b=1L}G(17&&g!==Q&&b!==Q&&!(D.Y(f,\'a\')&&h=="4V")){7.5k=M;1U{f[h]()}1V(e){}}7.5k=Q}I b},1H:H(b){J a,1L,38,5f,4m;b=19[0]=D.W.6l(b||1b.W);38=b.O.1R(".");b.O=38[0];38=38[1];5f=!38&&!b.6m;4m=(D.L(7,"3w")||{})[b.O];R(J j 1n 4m){J c=4m[j];G(5f||c.O==38){b.2y=c;b.L=c.L;1L=c.1w(7,19);G(a!==Q)a=1L;G(1L===Q){b.32();b.3J()}}}I a},6l:H(b){G(b[E]==M)I b;J d=b;b={8o:d};J c="8n 8m 8l 8k 2s 8j 47 5d 6j 5E 8i L 8h 8g 4K 2y 5a 59 8e 8b 58 6f 8a 88 4k 87 86 84 6d 2J 4C 6c O 82 81 35".1R(" ");R(J i=c.K;i;i--)b[c[i]]=d[c[i]];b[E]=M;b.32=H(){G(d.32)d.32();d.80=Q};b.3J=H(){G(d.3J)d.3J();d.7Z=M};b.4C=b.4C||1z();G(!b.2J)b.2J=b.6d||S;G(b.2J.16==3)b.2J=b.2J.1d;G(!b.4k&&b.4K)b.4k=b.4K==b.2J?b.6c:b.4K;G(b.58==U&&b.5d!=U){J a=S.1C,1c=S.1c;b.58=b.5d+(a&&a.2e||1c&&1c.2e||0)-(a.6b||0);b.6f=b.6j+(a&&a.2c||1c&&1c.2c||0)-(a.6a||0)}G(!b.35&&((b.47||b.47===0)?b.47:b.5a))b.35=b.47||b.5a;G(!b.59&&b.5E)b.59=b.5E;G(!b.35&&b.2s)b.35=(b.2s&1?1:(b.2s&2?3:(b.2s&4?2:0)));I b},3M:H(a,b){b.24=a.24=a.24||b.24||7.24++;I b},2t:{27:{4p:H(){55();I},4A:H(){I}},3D:{4p:H(){G(D.14.1f)I Q;D(7).2O("53",D.W.2t.3D.2y);I M},4A:H(){G(D.14.1f)I Q;D(7).4e("53",D.W.2t.3D.2y);I M},2y:H(a){G(F(a,7))I M;a.O="3D";I D.W.1H.1w(7,19)}},3N:{4p:H(){G(D.14.1f)I Q;D(7).2O("51",D.W.2t.3N.2y);I M},4A:H(){G(D.14.1f)I Q;D(7).4e("51",D.W.2t.3N.2y);I M},2y:H(a){G(F(a,7))I M;a.O="3N";I D.W.1H.1w(7,19)}}}};D.17.1l({2O:H(c,a,b){I c=="4X"?7.2V(c,a,b):7.P(H(){D.W.1e(7,c,b||a,b&&a)})},2V:H(d,b,c){J e=D.W.3M(c||b,H(a){D(7).4e(a,e);I(c||b).1w(7,19)});I 7.P(H(){D.W.1e(7,d,e,c&&b)})},4e:H(a,b){I 7.P(H(){D.W.21(7,a,b)})},1P:H(c,a,b){I 7.P(H(){D.W.1P(c,a,7,M,b)})},5C:H(c,a,b){I 7[0]&&D.W.1P(c,a,7[0],Q,b)},2m:H(b){J c=19,i=1;1B(i=0){J i=g.3s(e,g.K);g=g.3s(0,e)}c=c||H(){};J f="2P";G(d)G(D.1D(d)){c=d;d=U}N{d=D.3n(d);f="6g"}J h=7;D.3Y({1a:g,O:f,1O:"2K",L:d,1J:H(a,b){G(b=="1W"||b=="7J")h.2K(i?D("<1v/>").3v(a.4U.1o(/<1m(.|\\s)*?\\/1m>/g,"")).2q(i):a.4U);h.P(c,[a.4U,b,a])}});I 7},aL:H(){I D.3n(7.7I())},7I:H(){I 7.2l(H(){I D.Y(7,"3V")?D.2d(7.aH):7}).1E(H(){I 7.34&&!7.3R&&(7.4J||/2A|6y/i.11(7.Y)||/1r|1G|3Q/i.11(7.O))}).2l(H(i,c){J b=D(7).6e();I b==U?U:b.1q==2p?D.2l(b,H(a,i){I{34:c.34,2x:a}}):{34:c.34,2x:b}}).3p()}});D.P("7H,7G,7F,7D,7C,7B".1R(","),H(i,o){D.17[o]=H(f){I 7.2O(o,f)}});J B=1z();D.1l({3p:H(d,b,a,c){G(D.1D(b)){a=b;b=U}I D.3Y({O:"2P",1a:d,L:b,1W:a,1O:c})},aE:H(b,a){I D.3p(b,U,a,"1m")},aD:H(c,b,a){I D.3p(c,b,a,"3z")},aC:H(d,b,a,c){G(D.1D(b)){a=b;b={}}I D.3Y({O:"6g",1a:d,L:b,1W:a,1O:c})},aA:H(a){D.1l(D.60,a)},60:{1a:5Z.5Q,26:M,O:"2P",2T:0,7z:"4R/x-ax-3V-aw",7x:M,31:M,L:U,5Y:U,3Q:U,4Q:{2N:"4R/2N, 1r/2N",2K:"1r/2K",1m:"1r/4t, 4R/4t",3z:"4R/3z, 1r/4t",1r:"1r/as",4w:"*/*"}},4z:{},3Y:H(s){s=D.1l(M,s,D.1l(M,{},D.60,s));J g,2Z=/=\\?(&|$)/g,1u,L,O=s.O.2r();G(s.L&&s.7x&&1j s.L!="23")s.L=D.3n(s.L);G(s.1O=="4P"){G(O=="2P"){G(!s.1a.1I(2Z))s.1a+=(s.1a.1I(/\\?/)?"&":"?")+(s.4P||"7u")+"=?"}N G(!s.L||!s.L.1I(2Z))s.L=(s.L?s.L+"&":"")+(s.4P||"7u")+"=?";s.1O="3z"}G(s.1O=="3z"&&(s.L&&s.L.1I(2Z)||s.1a.1I(2Z))){g="4P"+B++;G(s.L)s.L=(s.L+"").1o(2Z,"="+g+"$1");s.1a=s.1a.1o(2Z,"="+g+"$1");s.1O="1m";1b[g]=H(a){L=a;1W();1J();1b[g]=12;1U{2U 1b[g]}1V(e){}G(i)i.37(h)}}G(s.1O=="1m"&&s.1Y==U)s.1Y=Q;G(s.1Y===Q&&O=="2P"){J j=1z();J k=s.1a.1o(/(\\?|&)3m=.*?(&|$)/,"$ap="+j+"$2");s.1a=k+((k==s.1a)?(s.1a.1I(/\\?/)?"&":"?")+"3m="+j:"")}G(s.L&&O=="2P"){s.1a+=(s.1a.1I(/\\?/)?"&":"?")+s.L;s.L=U}G(s.26&&!D.4O++)D.W.1P("7H");J n=/^(?:\\w+:)?\\/\\/([^\\/?#]+)/;G(s.1O=="1m"&&O=="2P"&&n.11(s.1a)&&n.2D(s.1a)[1]!=5Z.al){J i=S.3H("6w")[0];J h=S.3h("1m");h.4d=s.1a;G(s.7t)h.aj=s.7t;G(!g){J l=Q;h.ah=h.ag=H(){G(!l&&(!7.3f||7.3f=="68"||7.3f=="1J")){l=M;1W();1J();i.37(h)}}}i.3U(h);I 12}J m=Q;J c=1b.7s?2B 7s("ae.ac"):2B 7r();G(s.5Y)c.6R(O,s.1a,s.31,s.5Y,s.3Q);N c.6R(O,s.1a,s.31);1U{G(s.L)c.4B("ab-aa",s.7z);G(s.5S)c.4B("a9-5R-a8",D.4z[s.1a]||"a7, a6 a5 a4 5N:5N:5N a2");c.4B("X-9Z-9Y","7r");c.4B("9W",s.1O&&s.4Q[s.1O]?s.4Q[s.1O]+", */*":s.4Q.4w)}1V(e){}G(s.7m&&s.7m(c,s)===Q){s.26&&D.4O--;c.7l();I Q}G(s.26)D.W.1P("7B",[c,s]);J d=H(a){G(!m&&c&&(c.3f==4||a=="2T")){m=M;G(f){7k(f);f=U}1u=a=="2T"&&"2T"||!D.7j(c)&&"3e"||s.5S&&D.7h(c,s.1a)&&"7J"||"1W";G(1u=="1W"){1U{L=D.6X(c,s.1O,s.9S)}1V(e){1u="5J"}}G(1u=="1W"){J b;1U{b=c.5I("7g-5R")}1V(e){}G(s.5S&&b)D.4z[s.1a]=b;G(!g)1W()}N D.5H(s,c,1u);1J();G(s.31)c=U}};G(s.31){J f=4I(d,13);G(s.2T>0)3B(H(){G(c){c.7l();G(!m)d("2T")}},s.2T)}1U{c.9P(s.L)}1V(e){D.5H(s,c,U,e)}G(!s.31)d();H 1W(){G(s.1W)s.1W(L,1u);G(s.26)D.W.1P("7C",[c,s])}H 1J(){G(s.1J)s.1J(c,1u);G(s.26)D.W.1P("7F",[c,s]);G(s.26&&!--D.4O)D.W.1P("7G")}I c},5H:H(s,a,b,e){G(s.3e)s.3e(a,b,e);G(s.26)D.W.1P("7D",[a,s,e])},4O:0,7j:H(a){1U{I!a.1u&&5Z.9O=="5p:"||(a.1u>=7e&&a.1u<9N)||a.1u==7c||a.1u==9K||D.14.2k&&a.1u==12}1V(e){}I Q},7h:H(a,c){1U{J b=a.5I("7g-5R");I a.1u==7c||b==D.4z[c]||D.14.2k&&a.1u==12}1V(e){}I Q},6X:H(a,c,b){J d=a.5I("9J-O"),2N=c=="2N"||!c&&d&&d.1h("2N")>=0,L=2N?a.9I:a.4U;G(2N&&L.1C.2j=="5J")7p"5J";G(b)L=b(L,c);G(c=="1m")D.5u(L);G(c=="3z")L=6u("("+L+")");I L},3n:H(a){J s=[];G(a.1q==2p||a.5w)D.P(a,H(){s.1p(3u(7.34)+"="+3u(7.2x))});N R(J j 1n a)G(a[j]&&a[j].1q==2p)D.P(a[j],H(){s.1p(3u(j)+"="+3u(7))});N s.1p(3u(j)+"="+3u(D.1D(a[j])?a[j]():a[j]));I s.6s("&").1o(/%20/g,"+")}});D.17.1l({1N:H(c,b){I c?7.2g({1Z:"1N",2h:"1N",1y:"1N"},c,b):7.1E(":1G").P(H(){7.V.18=7.5D||"";G(D.1g(7,"18")=="2F"){J a=D("<"+7.2j+" />").6P("1c");7.V.18=a.1g("18");G(7.V.18=="2F")7.V.18="3I";a.21()}}).3l()},1M:H(b,a){I b?7.2g({1Z:"1M",2h:"1M",1y:"1M"},b,a):7.1E(":4j").P(H(){7.5D=7.5D||D.1g(7,"18");7.V.18="2F"}).3l()},78:D.17.2m,2m:H(a,b){I D.1D(a)&&D.1D(b)?7.78.1w(7,19):a?7.2g({1Z:"2m",2h:"2m",1y:"2m"},a,b):7.P(H(){D(7)[D(7).3F(":1G")?"1N":"1M"]()})},9G:H(b,a){I 7.2g({1Z:"1N"},b,a)},9F:H(b,a){I 7.2g({1Z:"1M"},b,a)},9E:H(b,a){I 7.2g({1Z:"2m"},b,a)},9D:H(b,a){I 7.2g({1y:"1N"},b,a)},9M:H(b,a){I 7.2g({1y:"1M"},b,a)},9C:H(c,a,b){I 7.2g({1y:a},c,b)},2g:H(k,j,i,g){J h=D.77(j,i,g);I 7[h.36===Q?"P":"36"](H(){G(7.16!=1)I Q;J f=D.1l({},h),p,1G=D(7).3F(":1G"),46=7;R(p 1n k){G(k[p]=="1M"&&1G||k[p]=="1N"&&!1G)I f.1J.1k(7);G(p=="1Z"||p=="2h"){f.18=D.1g(7,"18");f.33=7.V.33}}G(f.33!=U)7.V.33="1G";f.45=D.1l({},k);D.P(k,H(c,a){J e=2B D.28(46,f,c);G(/2m|1N|1M/.11(a))e[a=="2m"?1G?"1N":"1M":a](k);N{J b=a.6r().1I(/^([+-]=)?([\\d+-.]+)(.*)$/),2b=e.1t(M)||0;G(b){J d=3d(b[2]),2M=b[3]||"2X";G(2M!="2X"){46.V[c]=(d||1)+2M;2b=((d||1)/e.1t(M))*2b;46.V[c]=2b+2M}G(b[1])d=((b[1]=="-="?-1:1)*d)+2b;e.3G(2b,d,2M)}N e.3G(2b,a,"")}});I M})},36:H(a,b){G(D.1D(a)||(a&&a.1q==2p)){b=a;a="28"}G(!a||(1j a=="23"&&!b))I A(7[0],a);I 7.P(H(){G(b.1q==2p)A(7,a,b);N{A(7,a).1p(b);G(A(7,a).K==1)b.1k(7)}})},9X:H(b,c){J a=D.3O;G(b)7.36([]);7.P(H(){R(J i=a.K-1;i>=0;i--)G(a[i].T==7){G(c)a[i](M);a.7n(i,1)}});G(!c)7.5A();I 7}});J A=H(b,c,a){G(b){c=c||"28";J q=D.L(b,c+"36");G(!q||a)q=D.L(b,c+"36",D.2d(a))}I q};D.17.5A=H(a){a=a||"28";I 7.P(H(){J q=A(7,a);q.4s();G(q.K)q[0].1k(7)})};D.1l({77:H(b,a,c){J d=b&&b.1q==a0?b:{1J:c||!c&&a||D.1D(b)&&b,2u:b,41:c&&a||a&&a.1q!=9t&&a};d.2u=(d.2u&&d.2u.1q==4L?d.2u:D.28.5K[d.2u])||D.28.5K.74;d.5M=d.1J;d.1J=H(){G(d.36!==Q)D(7).5A();G(D.1D(d.5M))d.5M.1k(7)};I d},41:{73:H(p,n,b,a){I b+a*p},5P:H(p,n,b,a){I((-29.9r(p*29.9q)/2)+0.5)*a+b}},3O:[],48:U,28:H(b,c,a){7.15=c;7.T=b;7.1i=a;G(!c.3Z)c.3Z={}}});D.28.44={4D:H(){G(7.15.2Y)7.15.2Y.1k(7.T,7.1z,7);(D.28.2Y[7.1i]||D.28.2Y.4w)(7);G(7.1i=="1Z"||7.1i=="2h")7.T.V.18="3I"},1t:H(a){G(7.T[7.1i]!=U&&7.T.V[7.1i]==U)I 7.T[7.1i];J r=3d(D.1g(7.T,7.1i,a));I r&&r>-9p?r:3d(D.2a(7.T,7.1i))||0},3G:H(c,b,d){7.5V=1z();7.2b=c;7.3l=b;7.2M=d||7.2M||"2X";7.1z=7.2b;7.2S=7.4N=0;7.4D();J e=7;H t(a){I e.2Y(a)}t.T=7.T;D.3O.1p(t);G(D.48==U){D.48=4I(H(){J a=D.3O;R(J i=0;i7.15.2u+7.5V){7.1z=7.3l;7.2S=7.4N=1;7.4D();7.15.45[7.1i]=M;J b=M;R(J i 1n 7.15.45)G(7.15.45[i]!==M)b=Q;G(b){G(7.15.18!=U){7.T.V.33=7.15.33;7.T.V.18=7.15.18;G(D.1g(7.T,"18")=="2F")7.T.V.18="3I"}G(7.15.1M)7.T.V.18="2F";G(7.15.1M||7.15.1N)R(J p 1n 7.15.45)D.1K(7.T.V,p,7.15.3Z[p])}G(b)7.15.1J.1k(7.T);I Q}N{J n=t-7.5V;7.4N=n/7.15.2u;7.2S=D.41[7.15.41||(D.41.5P?"5P":"73")](7.4N,n,0,1,7.15.2u);7.1z=7.2b+((7.3l-7.2b)*7.2S);7.4D()}I M}};D.1l(D.28,{5K:{9l:9j,9i:7e,74:9g},2Y:{2e:H(a){a.T.2e=a.1z},2c:H(a){a.T.2c=a.1z},1y:H(a){D.1K(a.T.V,"1y",a.1z)},4w:H(a){a.T.V[a.1i]=a.1z+a.2M}}});D.17.2i=H(){J b=0,1S=0,T=7[0],3q;G(T)ao(D.14){J d=T.1d,4a=T,1s=T.1s,1Q=T.2z,5U=2k&&3r(5B)<9c&&!/9a/i.11(v),1g=D.2a,3c=1g(T,"30")=="3c";G(T.7y){J c=T.7y();1e(c.1A+29.2f(1Q.1C.2e,1Q.1c.2e),c.1S+29.2f(1Q.1C.2c,1Q.1c.2c));1e(-1Q.1C.6b,-1Q.1C.6a)}N{1e(T.5X,T.5W);1B(1s){1e(1s.5X,1s.5W);G(42&&!/^t(98|d|h)$/i.11(1s.2j)||2k&&!5U)2C(1s);G(!3c&&1g(1s,"30")=="3c")3c=M;4a=/^1c$/i.11(1s.2j)?4a:1s;1s=1s.1s}1B(d&&d.2j&&!/^1c|2K$/i.11(d.2j)){G(!/^96|1T.*$/i.11(1g(d,"18")))1e(-d.2e,-d.2c);G(42&&1g(d,"33")!="4j")2C(d);d=d.1d}G((5U&&(3c||1g(4a,"30")=="5x"))||(42&&1g(4a,"30")!="5x"))1e(-1Q.1c.5X,-1Q.1c.5W);G(3c)1e(29.2f(1Q.1C.2e,1Q.1c.2e),29.2f(1Q.1C.2c,1Q.1c.2c))}3q={1S:1S,1A:b}}H 2C(a){1e(D.2a(a,"6V",M),D.2a(a,"6U",M))}H 1e(l,t){b+=3r(l,10)||0;1S+=3r(t,10)||0}I 3q};D.17.1l({30:H(){J a=0,1S=0,3q;G(7[0]){J b=7.1s(),2i=7.2i(),4c=/^1c|2K$/i.11(b[0].2j)?{1S:0,1A:0}:b.2i();2i.1S-=25(7,\'94\');2i.1A-=25(7,\'aF\');4c.1S+=25(b,\'6U\');4c.1A+=25(b,\'6V\');3q={1S:2i.1S-4c.1S,1A:2i.1A-4c.1A}}I 3q},1s:H(){J a=7[0].1s;1B(a&&(!/^1c|2K$/i.11(a.2j)&&D.1g(a,\'30\')==\'93\'))a=a.1s;I D(a)}});D.P([\'5e\',\'5G\'],H(i,b){J c=\'4y\'+b;D.17[c]=H(a){G(!7[0])I;I a!=12?7.P(H(){7==1b||7==S?1b.92(!i?a:D(1b).2e(),i?a:D(1b).2c()):7[c]=a}):7[0]==1b||7[0]==S?46[i?\'aI\':\'aJ\']||D.71&&S.1C[c]||S.1c[c]:7[0][c]}});D.P(["6N","4b"],H(i,b){J c=i?"5e":"5G",4f=i?"6k":"6i";D.17["5s"+b]=H(){I 7[b.3y()]()+25(7,"57"+c)+25(7,"57"+4f)};D.17["90"+b]=H(a){I 7["5s"+b]()+25(7,"2C"+c+"4b")+25(7,"2C"+4f+"4b")+(a?25(7,"6S"+c)+25(7,"6S"+4f):0)}})})();',62,669,'|||||||this|||||||||||||||||||||||||||||||||||if|function|return|var|length|data|true|else|type|each|false|for|document|elem|null|style|event||nodeName|||test|undefined||browser|options|nodeType|fn|display|arguments|url|window|body|parentNode|add|msie|css|indexOf|prop|typeof|call|extend|script|in|replace|push|constructor|text|offsetParent|cur|status|div|apply|firstChild|opacity|now|left|while|documentElement|isFunction|filter|className|hidden|handle|match|complete|attr|ret|hide|show|dataType|trigger|doc|split|top|table|try|catch|success|break|cache|height||remove|tbody|string|guid|num|global|ready|fx|Math|curCSS|start|scrollTop|makeArray|scrollLeft|max|animate|width|offset|tagName|safari|map|toggle||done|Array|find|toUpperCase|button|special|duration|id|copy|value|handler|ownerDocument|select|new|border|exec|stack|none|opera|nextSibling|pushStack|target|html|inArray|unit|xml|bind|GET|isReady|merge|pos|timeout|delete|one|selected|px|step|jsre|position|async|preventDefault|overflow|name|which|queue|removeChild|namespace|insertBefore|nth|removeData|fixed|parseFloat|error|readyState|multiFilter|createElement|rl|re|trim|end|_|param|first|get|results|parseInt|slice|childNodes|encodeURIComponent|append|events|elems|toLowerCase|json|readyList|setTimeout|grep|mouseenter|color|is|custom|getElementsByTagName|block|stopPropagation|addEventListener|callee|proxy|mouseleave|timers|defaultView|password|disabled|last|has|appendChild|form|domManip|props|ajax|orig|set|easing|mozilla|load|prototype|curAnim|self|charCode|timerId|object|offsetChild|Width|parentOffset|src|unbind|br|currentStyle|clean|float|visible|relatedTarget|previousSibling|handlers|isXMLDoc|on|setup|nodeIndex|unique|shift|javascript|child|RegExp|_default|deep|scroll|lastModified|teardown|setRequestHeader|timeStamp|update|empty|tr|getAttribute|innerHTML|setInterval|checked|fromElement|Number|jQuery|state|active|jsonp|accepts|application|dir|input|responseText|click|styleSheets|unload|not|lastToggle|outline|mouseout|getPropertyValue|mouseover|getComputedStyle|bindReady|String|padding|pageX|metaKey|keyCode|getWH|andSelf|clientX|Left|all|visibility|container|index|init|triggered|removeAttribute|classFilter|prevObject|submit|file|after|windowData|inner|client|globalEval|sibling|jquery|absolute|clone|wrapAll|dequeue|version|triggerHandler|oldblock|ctrlKey|createTextNode|Top|handleError|getResponseHeader|parsererror|speeds|checkbox|old|00|radio|swing|href|Modified|ifModified|lastChild|safari2|startTime|offsetTop|offsetLeft|username|location|ajaxSettings|getElementById|isSimple|values|selectedIndex|runtimeStyle|rsLeft|_load|loaded|DOMContentLoaded|clientTop|clientLeft|toElement|srcElement|val|pageY|POST|unshift|Bottom|clientY|Right|fix|exclusive|detachEvent|cloneNode|removeEventListener|swap|toString|join|attachEvent|eval|substr|head|parse|textarea|reset|image|zoom|odd|even|before|prepend|exclude|expr|quickClass|quickID|uuid|quickChild|continue|Height|textContent|appendTo|contents|open|margin|evalScript|borderTopWidth|borderLeftWidth|parent|httpData|setArray|CSS1Compat|compatMode|boxModel|cssFloat|linear|def|webkit|nodeValue|speed|_toggle|eq|100|replaceWith|304|concat|200|alpha|Last|httpNotModified|getAttributeNode|httpSuccess|clearInterval|abort|beforeSend|splice|styleFloat|throw|colgroup|XMLHttpRequest|ActiveXObject|scriptCharset|callback|fieldset|multiple|processData|getBoundingClientRect|contentType|link|ajaxSend|ajaxSuccess|ajaxError|col|ajaxComplete|ajaxStop|ajaxStart|serializeArray|notmodified|keypress|keydown|change|mouseup|mousedown|dblclick|focus|blur|stylesheet|hasClass|rel|doScroll|black|hover|solid|cancelBubble|returnValue|wheelDelta|view|round|shiftKey|resize|screenY|screenX|relatedNode|mousemove|prevValue|originalTarget|offsetHeight|keyup|newValue|offsetWidth|eventPhase|detail|currentTarget|cancelable|bubbles|attrName|attrChange|altKey|originalEvent|charAt|0n|substring|animated|header|noConflict|line|enabled|innerText|contains|only|weight|font|gt|lt|uFFFF|u0128|size|417|Boolean|Date|toggleClass|removeClass|addClass|removeAttr|replaceAll|insertAfter|prependTo|wrap|contentWindow|contentDocument|iframe|children|siblings|prevAll|wrapInner|nextAll|outer|prev|scrollTo|static|marginTop|next|inline|parents|able|cellSpacing|adobeair|cellspacing|522|maxLength|maxlength|readOnly|400|readonly|fast|600|class|slow|1px|htmlFor|reverse|10000|PI|cos|compatible|Function|setData|ie|ra|it|rv|getData|userAgent|navigator|fadeTo|fadeIn|slideToggle|slideUp|slideDown|ig|responseXML|content|1223|NaN|fadeOut|300|protocol|send|setAttribute|option|dataFilter|cssText|changed|be|Accept|stop|With|Requested|Object|can|GMT|property|1970|Jan|01|Thu|Since|If|Type|Content|XMLHTTP|th|Microsoft|td|onreadystatechange|onload|cap|charset|colg|host|tfoot|specified|with|1_|thead|leg|plain|attributes|opt|embed|urlencoded|www|area|hr|ajaxSetup|meta|post|getJSON|getScript|marginLeft|img|elements|pageYOffset|pageXOffset|abbr|serialize|pixelLeft'.split('|'),0,{})) -\ No newline at end of file diff -Nru trac-0.11.7/debian/patches/.svn/entries trac-0.12.1~ppa2/debian/patches/.svn/entries --- trac-0.11.7/debian/patches/.svn/entries 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/.svn/entries 2010-05-05 03:09:14.000000000 +0100 @@ -0,0 +1,300 @@ +10 + +dir +5190 +svn://svn.debian.org/svn/python-apps/packages/trac/trunk/debian/patches +svn://svn.debian.org/svn/python-apps + + + +2010-03-11T22:35:01.664470Z +4940 +debacle + + + + + + + + + + + + + + +31130ce1-1128-498b-8474-bfd1e18f06ab + +15_remove_jquery_file.dpatch +file + + + + +2010-05-05T00:33:53.000000Z +d08dc41168a5d08898c99cad2756ce7f +2009-09-14T21:12:19.393447Z +3725 +debacle +has-props + + + + + + + + + + + + + + + + + + + + +31865 + +40_timeline_author_filter.dpatch +file + + + + +2010-05-05T00:33:53.000000Z +ac239267ee6eba43e6b6a44537bdbf36 +2009-12-24T11:18:23.571513Z +4356 +debacle +has-props + + + + + + + + + + + + + + + + + + + + +3383 + +20_add_interpreter_line.dpatch +file + + + + +2010-05-05T00:33:53.000000Z +36f0a1e69c720ead7c4406f01e21e6d8 +2009-09-15T09:19:17.276180Z +3736 +debacle +has-props + + + + + + + + + + + + + + + + + + + + +587 + +50_sqlitetopg_script.dpatch +file + + + + +2010-05-05T00:33:53.000000Z +b3c803c0b874862a7167cf8313e2a090 +2009-12-24T11:18:23.571513Z +4356 +debacle +has-props + + + + + + + + + + + + + + + + + + + + +13028 + +70_cache_control_typo.dpatch +file + + + + +2010-05-05T00:33:53.000000Z +dae0358b1926d5e9d935b2be109d1767 +2009-12-24T11:18:23.571513Z +4356 +debacle +has-props + + + + + + + + + + + + + + + + + + + + +1569 + +30_default_charset_utf8.dpatch +file + + + + +2010-05-05T00:33:53.000000Z +388005acf8945d9097c8c08b42411055 +2009-12-24T11:18:23.571513Z +4356 +debacle +has-props + + + + + + + + + + + + + + + + + + + + +828 + +00list +file + + + + +2010-05-05T00:33:53.000000Z +7b46f352774fa21b97376e6260e9e452 +2010-03-11T22:35:01.664470Z +4940 +debacle + + + + + + + + + + + + + + + + + + + + + +212 + +80_correct_plugin_names.dpatch +file + + + + +2010-05-05T00:33:53.000000Z +09fbf7a4c4ee1f4ab85ff4f83e49017a +2010-02-17T07:39:18.697057Z +4794 +debacle +has-props + + + + + + + + + + + + + + + + + + + + +5832 + diff -Nru trac-0.11.7/debian/patches/.svn/prop-base/15_remove_jquery_file.dpatch.svn-base trac-0.12.1~ppa2/debian/patches/.svn/prop-base/15_remove_jquery_file.dpatch.svn-base --- trac-0.11.7/debian/patches/.svn/prop-base/15_remove_jquery_file.dpatch.svn-base 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/.svn/prop-base/15_remove_jquery_file.dpatch.svn-base 2010-05-05 03:09:14.000000000 +0100 @@ -0,0 +1,5 @@ +K 14 +svn:executable +V 1 +* +END diff -Nru trac-0.11.7/debian/patches/.svn/prop-base/20_add_interpreter_line.dpatch.svn-base trac-0.12.1~ppa2/debian/patches/.svn/prop-base/20_add_interpreter_line.dpatch.svn-base --- trac-0.11.7/debian/patches/.svn/prop-base/20_add_interpreter_line.dpatch.svn-base 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/.svn/prop-base/20_add_interpreter_line.dpatch.svn-base 2010-05-05 03:09:14.000000000 +0100 @@ -0,0 +1,5 @@ +K 14 +svn:executable +V 1 +* +END diff -Nru trac-0.11.7/debian/patches/.svn/prop-base/30_default_charset_utf8.dpatch.svn-base trac-0.12.1~ppa2/debian/patches/.svn/prop-base/30_default_charset_utf8.dpatch.svn-base --- trac-0.11.7/debian/patches/.svn/prop-base/30_default_charset_utf8.dpatch.svn-base 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/.svn/prop-base/30_default_charset_utf8.dpatch.svn-base 2010-05-05 03:09:14.000000000 +0100 @@ -0,0 +1,5 @@ +K 14 +svn:executable +V 1 +* +END diff -Nru trac-0.11.7/debian/patches/.svn/prop-base/40_timeline_author_filter.dpatch.svn-base trac-0.12.1~ppa2/debian/patches/.svn/prop-base/40_timeline_author_filter.dpatch.svn-base --- trac-0.11.7/debian/patches/.svn/prop-base/40_timeline_author_filter.dpatch.svn-base 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/.svn/prop-base/40_timeline_author_filter.dpatch.svn-base 2010-05-05 03:09:14.000000000 +0100 @@ -0,0 +1,5 @@ +K 14 +svn:executable +V 1 +* +END diff -Nru trac-0.11.7/debian/patches/.svn/prop-base/50_sqlitetopg_script.dpatch.svn-base trac-0.12.1~ppa2/debian/patches/.svn/prop-base/50_sqlitetopg_script.dpatch.svn-base --- trac-0.11.7/debian/patches/.svn/prop-base/50_sqlitetopg_script.dpatch.svn-base 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/.svn/prop-base/50_sqlitetopg_script.dpatch.svn-base 2010-05-05 03:09:14.000000000 +0100 @@ -0,0 +1,5 @@ +K 14 +svn:executable +V 1 +* +END diff -Nru trac-0.11.7/debian/patches/.svn/prop-base/70_cache_control_typo.dpatch.svn-base trac-0.12.1~ppa2/debian/patches/.svn/prop-base/70_cache_control_typo.dpatch.svn-base --- trac-0.11.7/debian/patches/.svn/prop-base/70_cache_control_typo.dpatch.svn-base 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/.svn/prop-base/70_cache_control_typo.dpatch.svn-base 2010-05-05 03:09:14.000000000 +0100 @@ -0,0 +1,5 @@ +K 14 +svn:executable +V 1 +* +END diff -Nru trac-0.11.7/debian/patches/.svn/prop-base/80_correct_plugin_names.dpatch.svn-base trac-0.12.1~ppa2/debian/patches/.svn/prop-base/80_correct_plugin_names.dpatch.svn-base --- trac-0.11.7/debian/patches/.svn/prop-base/80_correct_plugin_names.dpatch.svn-base 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/.svn/prop-base/80_correct_plugin_names.dpatch.svn-base 2010-05-05 03:09:14.000000000 +0100 @@ -0,0 +1,5 @@ +K 14 +svn:executable +V 1 +* +END diff -Nru trac-0.11.7/debian/patches/.svn/text-base/00list.svn-base trac-0.12.1~ppa2/debian/patches/.svn/text-base/00list.svn-base --- trac-0.11.7/debian/patches/.svn/text-base/00list.svn-base 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/.svn/text-base/00list.svn-base 2010-05-05 03:09:14.000000000 +0100 @@ -0,0 +1,7 @@ +15_remove_jquery_file.dpatch +20_add_interpreter_line.dpatch +30_default_charset_utf8.dpatch +40_timeline_author_filter.dpatch +50_sqlitetopg_script.dpatch +70_cache_control_typo.dpatch +80_correct_plugin_names.dpatch diff -Nru trac-0.11.7/debian/patches/.svn/text-base/15_remove_jquery_file.dpatch.svn-base trac-0.12.1~ppa2/debian/patches/.svn/text-base/15_remove_jquery_file.dpatch.svn-base --- trac-0.11.7/debian/patches/.svn/text-base/15_remove_jquery_file.dpatch.svn-base 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/.svn/text-base/15_remove_jquery_file.dpatch.svn-base 2010-05-05 03:09:14.000000000 +0100 @@ -0,0 +1,39 @@ +#! /bin/sh /usr/share/dpatch/dpatch-run +## 15_remove_jquery_file.dpatch by +## +## All lines beginning with `## DP:' are a description of the patch. +## DP: Removes the jquery.js file + +@DPATCH@ + +diff --git a/Trac.egg-info/SOURCES.txt b/Trac.egg-info/SOURCES.txt +index c2d0840..d0e4746 100644 +--- a/Trac.egg-info/SOURCES.txt ++++ b/Trac.egg-info/SOURCES.txt +@@ -157,7 +157,6 @@ trac/htdocs/js/diff.js + trac/htdocs/js/expand_dir.js + trac/htdocs/js/folding.js + trac/htdocs/js/ie_pre7_hacks.js +-trac/htdocs/js/jquery.js + trac/htdocs/js/keyboard_nav.js + trac/htdocs/js/noconflict.js + trac/htdocs/js/query.js + +diff --git a/trac/htdocs/js/jquery.js b/trac/htdocs/js/jquery.js +deleted file mode 100644 +index 95dd013..0000000 +--- a/trac/htdocs/js/jquery.js ++++ /dev/null +@@ -1,11 +0,0 @@ +-/* +- * jQuery 1.2.6 - New Wave Javascript +- * +- * Copyright (c) 2008 John Resig (jquery.com) +- * Dual licensed under the MIT (MIT-LICENSE.txt) +- * and GPL (GPL-LICENSE.txt) licenses. +- * +- * $Date: 2008-05-24 14:22:17 -0400 (Sat, 24 May 2008) $ +- * $Rev: 5685 $ +- */ +-eval(function(p,a,c,k,e,r){e=function(c){return(c35?String.fromCharCode(c+29):c.toString(36))};if(!''.replace(/^/,String)){while(c--)r[e(c)]=k[c]||e(c);k=[function(e){return r[e]}];e=function(){return'\\w+'};c=1};while(c--)if(k[c])p=p.replace(new RegExp('\\b'+e(c)+'\\b','g'),k[c]);return p}('(H(){J w=1b.4M,3m$=1b.$;J D=1b.4M=1b.$=H(a,b){I 2B D.17.5j(a,b)};J u=/^[^<]*(<(.|\\s)+>)[^>]*$|^#(\\w+)$/,62=/^.[^:#\\[\\.]*$/,12;D.17=D.44={5j:H(d,b){d=d||S;G(d.16){7[0]=d;7.K=1;I 7}G(1j d=="23"){J c=u.2D(d);G(c&&(c[1]||!b)){G(c[1])d=D.4h([c[1]],b);N{J a=S.61(c[3]);G(a){G(a.2v!=c[3])I D().2q(d);I D(a)}d=[]}}N I D(b).2q(d)}N G(D.1D(d))I D(S)[D.17.27?"27":"43"](d);I 7.6Y(D.2d(d))},5w:"1.2.6",8G:H(){I 7.K},K:0,3p:H(a){I a==12?D.2d(7):7[a]},2I:H(b){J a=D(b);a.5n=7;I a},6Y:H(a){7.K=0;2p.44.1p.1w(7,a);I 7},P:H(a,b){I D.P(7,a,b)},5i:H(b){J a=-1;I D.2L(b&&b.5w?b[0]:b,7)},1K:H(c,a,b){J d=c;G(c.1q==56)G(a===12)I 7[0]&&D[b||"1K"](7[0],c);N{d={};d[c]=a}I 7.P(H(i){R(c 1n d)D.1K(b?7.V:7,c,D.1i(7,d[c],b,i,c))})},1g:H(b,a){G((b==\'2h\'||b==\'1Z\')&&3d(a)<0)a=12;I 7.1K(b,a,"2a")},1r:H(b){G(1j b!="49"&&b!=U)I 7.4E().3v((7[0]&&7[0].2z||S).5F(b));J a="";D.P(b||7,H(){D.P(7.3t,H(){G(7.16!=8)a+=7.16!=1?7.76:D.17.1r([7])})});I a},5z:H(b){G(7[0])D(b,7[0].2z).5y().39(7[0]).2l(H(){J a=7;1B(a.1x)a=a.1x;I a}).3v(7);I 7},8Y:H(a){I 7.P(H(){D(7).6Q().5z(a)})},8R:H(a){I 7.P(H(){D(7).5z(a)})},3v:H(){I 7.3W(19,M,Q,H(a){G(7.16==1)7.3U(a)})},6F:H(){I 7.3W(19,M,M,H(a){G(7.16==1)7.39(a,7.1x)})},6E:H(){I 7.3W(19,Q,Q,H(a){7.1d.39(a,7)})},5q:H(){I 7.3W(19,Q,M,H(a){7.1d.39(a,7.2H)})},3l:H(){I 7.5n||D([])},2q:H(b){J c=D.2l(7,H(a){I D.2q(b,a)});I 7.2I(/[^+>] [^+>]/.11(b)||b.1h("..")>-1?D.4r(c):c)},5y:H(e){J f=7.2l(H(){G(D.14.1f&&!D.4n(7)){J a=7.6o(M),5h=S.3h("1v");5h.3U(a);I D.4h([5h.4H])[0]}N I 7.6o(M)});J d=f.2q("*").5c().P(H(){G(7[E]!=12)7[E]=U});G(e===M)7.2q("*").5c().P(H(i){G(7.16==3)I;J c=D.L(7,"3w");R(J a 1n c)R(J b 1n c[a])D.W.1e(d[i],a,c[a][b],c[a][b].L)});I f},1E:H(b){I 7.2I(D.1D(b)&&D.3C(7,H(a,i){I b.1k(a,i)})||D.3g(b,7))},4Y:H(b){G(b.1q==56)G(62.11(b))I 7.2I(D.3g(b,7,M));N b=D.3g(b,7);J a=b.K&&b[b.K-1]!==12&&!b.16;I 7.1E(H(){I a?D.2L(7,b)<0:7!=b})},1e:H(a){I 7.2I(D.4r(D.2R(7.3p(),1j a==\'23\'?D(a):D.2d(a))))},3F:H(a){I!!a&&D.3g(a,7).K>0},7T:H(a){I 7.3F("."+a)},6e:H(b){G(b==12){G(7.K){J c=7[0];G(D.Y(c,"2A")){J e=c.64,63=[],15=c.15,2V=c.O=="2A-2V";G(e<0)I U;R(J i=2V?e:0,2f=2V?e+1:15.K;i<2f;i++){J d=15[i];G(d.2W){b=D.14.1f&&!d.at.2x.an?d.1r:d.2x;G(2V)I b;63.1p(b)}}I 63}N I(7[0].2x||"").1o(/\\r/g,"")}I 12}G(b.1q==4L)b+=\'\';I 7.P(H(){G(7.16!=1)I;G(b.1q==2p&&/5O|5L/.11(7.O))7.4J=(D.2L(7.2x,b)>=0||D.2L(7.34,b)>=0);N G(D.Y(7,"2A")){J a=D.2d(b);D("9R",7).P(H(){7.2W=(D.2L(7.2x,a)>=0||D.2L(7.1r,a)>=0)});G(!a.K)7.64=-1}N 7.2x=b})},2K:H(a){I a==12?(7[0]?7[0].4H:U):7.4E().3v(a)},7b:H(a){I 7.5q(a).21()},79:H(i){I 7.3s(i,i+1)},3s:H(){I 7.2I(2p.44.3s.1w(7,19))},2l:H(b){I 7.2I(D.2l(7,H(a,i){I b.1k(a,i,a)}))},5c:H(){I 7.1e(7.5n)},L:H(d,b){J a=d.1R(".");a[1]=a[1]?"."+a[1]:"";G(b===12){J c=7.5C("9z"+a[1]+"!",[a[0]]);G(c===12&&7.K)c=D.L(7[0],d);I c===12&&a[1]?7.L(a[0]):c}N I 7.1P("9u"+a[1]+"!",[a[0],b]).P(H(){D.L(7,d,b)})},3b:H(a){I 7.P(H(){D.3b(7,a)})},3W:H(g,f,h,d){J e=7.K>1,3x;I 7.P(H(){G(!3x){3x=D.4h(g,7.2z);G(h)3x.9o()}J b=7;G(f&&D.Y(7,"1T")&&D.Y(3x[0],"4F"))b=7.3H("22")[0]||7.3U(7.2z.3h("22"));J c=D([]);D.P(3x,H(){J a=e?D(7).5y(M)[0]:7;G(D.Y(a,"1m"))c=c.1e(a);N{G(a.16==1)c=c.1e(D("1m",a).21());d.1k(b,a)}});c.P(6T)})}};D.17.5j.44=D.17;H 6T(i,a){G(a.4d)D.3Y({1a:a.4d,31:Q,1O:"1m"});N D.5u(a.1r||a.6O||a.4H||"");G(a.1d)a.1d.37(a)}H 1z(){I+2B 8J}D.1l=D.17.1l=H(){J b=19[0]||{},i=1,K=19.K,4x=Q,15;G(b.1q==8I){4x=b;b=19[1]||{};i=2}G(1j b!="49"&&1j b!="H")b={};G(K==i){b=7;--i}R(;i-1}},6q:H(b,c,a){J e={};R(J d 1n c){e[d]=b.V[d];b.V[d]=c[d]}a.1k(b);R(J d 1n c)b.V[d]=e[d]},1g:H(d,e,c){G(e=="2h"||e=="1Z"){J b,3X={30:"5x",5g:"1G",18:"3I"},35=e=="2h"?["5e","6k"]:["5G","6i"];H 5b(){b=e=="2h"?d.8f:d.8c;J a=0,2C=0;D.P(35,H(){a+=3d(D.2a(d,"57"+7,M))||0;2C+=3d(D.2a(d,"2C"+7+"4b",M))||0});b-=29.83(a+2C)}G(D(d).3F(":4j"))5b();N D.6q(d,3X,5b);I 29.2f(0,b)}I D.2a(d,e,c)},2a:H(f,l,k){J e,V=f.V;H 3E(b){G(!D.14.2k)I Q;J a=3P.54(b,U);I!a||a.52("3E")==""}G(l=="1y"&&D.14.1f){e=D.1K(V,"1y");I e==""?"1":e}G(D.14.2G&&l=="18"){J d=V.50;V.50="0 7Y 7W";V.50=d}G(l.1I(/4i/i))l=y;G(!k&&V&&V[l])e=V[l];N G(3P.54){G(l.1I(/4i/i))l="4i";l=l.1o(/([A-Z])/g,"-$1").3y();J c=3P.54(f,U);G(c&&!3E(f))e=c.52(l);N{J g=[],2E=[],a=f,i=0;R(;a&&3E(a);a=a.1d)2E.6h(a);R(;i<2E.K;i++)G(3E(2E[i])){g[i]=2E[i].V.18;2E[i].V.18="3I"}e=l=="18"&&g[2E.K-1]!=U?"2F":(c&&c.52(l))||"";R(i=0;i]*?)\\/>/g,H(b,a,c){I c.1I(/^(aK|4f|7E|aG|4T|7A|aB|3n|az|ay|av)$/i)?b:a+">"});J f=D.3k(d).3y(),1v=h.3h("1v");J e=!f.1h("",""]||!f.1h("",""]||f.1I(/^<(aq|22|am|ak|ai)/)&&[1,"<1T>",""]||!f.1h("<4F")&&[2,"<1T><22>",""]||(!f.1h("<22><4F>",""]||!f.1h("<7E")&&[2,"<1T><22><7q>",""]||D.14.1f&&[1,"1v<1v>",""]||[0,"",""];1v.4H=e[1]+d+e[2];1B(e[0]--)1v=1v.5T;G(D.14.1f){J g=!f.1h("<1T")&&f.1h("<22")<0?1v.1x&&1v.1x.3t:e[1]=="<1T>"&&f.1h("<22")<0?1v.3t:[];R(J j=g.K-1;j>=0;--j)G(D.Y(g[j],"22")&&!g[j].3t.K)g[j].1d.37(g[j]);G(/^\\s/.11(d))1v.39(h.5F(d.1I(/^\\s*/)[0]),1v.1x)}d=D.2d(1v.3t)}G(d.K===0&&(!D.Y(d,"3V")&&!D.Y(d,"2A")))I;G(d[0]==12||D.Y(d,"3V")||d.15)k.1p(d);N k=D.2R(k,d)});I k},1K:H(d,f,c){G(!d||d.16==3||d.16==8)I 12;J e=!D.4n(d),40=c!==12,1f=D.14.1f;f=e&&D.3X[f]||f;G(d.2j){J g=/5Q|4d|V/.11(f);G(f=="2W"&&D.14.2k)d.1d.64;G(f 1n d&&e&&!g){G(40){G(f=="O"&&D.Y(d,"4T")&&d.1d)7p"O a3 a1\'t 9V 9U";d[f]=c}G(D.Y(d,"3V")&&d.7i(f))I d.7i(f).76;I d[f]}G(1f&&e&&f=="V")I D.1K(d.V,"9T",c);G(40)d.9Q(f,""+c);J h=1f&&e&&g?d.4G(f,2):d.4G(f);I h===U?12:h}G(1f&&f=="1y"){G(40){d.6B=1;d.1E=(d.1E||"").1o(/7f\\([^)]*\\)/,"")+(3r(c)+\'\'=="9L"?"":"7f(1y="+c*7a+")")}I d.1E&&d.1E.1h("1y=")>=0?(3d(d.1E.1I(/1y=([^)]*)/)[1])/7a)+\'\':""}f=f.1o(/-([a-z])/9H,H(a,b){I b.2r()});G(40)d[f]=c;I d[f]},3k:H(a){I(a||"").1o(/^\\s+|\\s+$/g,"")},2d:H(b){J a=[];G(b!=U){J i=b.K;G(i==U||b.1R||b.4I||b.1k)a[0]=b;N 1B(i)a[--i]=b[i]}I a},2L:H(b,a){R(J i=0,K=a.K;i*",7).21();1B(7.1x)7.37(7.1x)}},H(a,b){D.17[a]=H(){I 7.P(b,19)}});D.P(["6N","4b"],H(i,c){J b=c.3y();D.17[b]=H(a){I 7[0]==1b?D.14.2G&&S.1c["5t"+c]||D.14.2k&&1b["5s"+c]||S.70=="6Z"&&S.1C["5t"+c]||S.1c["5t"+c]:7[0]==S?29.2f(29.2f(S.1c["4y"+c],S.1C["4y"+c]),29.2f(S.1c["2i"+c],S.1C["2i"+c])):a==12?(7.K?D.1g(7[0],b):U):7.1g(b,a.1q==56?a:a+"2X")}});H 25(a,b){I a[0]&&3r(D.2a(a[0],b,M),10)||0}J C=D.14.2k&&3r(D.14.5B)<8H?"(?:[\\\\w*3m-]|\\\\\\\\.)":"(?:[\\\\w\\8F-\\8E*3m-]|\\\\\\\\.)",6L=2B 4v("^>\\\\s*("+C+"+)"),6J=2B 4v("^("+C+"+)(#)("+C+"+)"),6I=2B 4v("^([#.]?)("+C+"*)");D.1l({6H:{"":H(a,i,m){I m[2]=="*"||D.Y(a,m[2])},"#":H(a,i,m){I a.4G("2v")==m[2]},":":{8D:H(a,i,m){I im[3]-0},3a:H(a,i,m){I m[3]-0==i},79:H(a,i,m){I m[3]-0==i},3o:H(a,i){I i==0},3S:H(a,i,m,r){I i==r.K-1},6D:H(a,i){I i%2==0},6C:H(a,i){I i%2},"3o-4u":H(a){I a.1d.3H("*")[0]==a},"3S-4u":H(a){I D.3a(a.1d.5T,1,"4l")==a},"8z-4u":H(a){I!D.3a(a.1d.5T,2,"4l")},6W:H(a){I a.1x},4E:H(a){I!a.1x},8y:H(a,i,m){I(a.6O||a.8x||D(a).1r()||"").1h(m[3])>=0},4j:H(a){I"1G"!=a.O&&D.1g(a,"18")!="2F"&&D.1g(a,"5g")!="1G"},1G:H(a){I"1G"==a.O||D.1g(a,"18")=="2F"||D.1g(a,"5g")=="1G"},8w:H(a){I!a.3R},3R:H(a){I a.3R},4J:H(a){I a.4J},2W:H(a){I a.2W||D.1K(a,"2W")},1r:H(a){I"1r"==a.O},5O:H(a){I"5O"==a.O},5L:H(a){I"5L"==a.O},5p:H(a){I"5p"==a.O},3Q:H(a){I"3Q"==a.O},5o:H(a){I"5o"==a.O},6A:H(a){I"6A"==a.O},6z:H(a){I"6z"==a.O},2s:H(a){I"2s"==a.O||D.Y(a,"2s")},4T:H(a){I/4T|2A|6y|2s/i.11(a.Y)},3T:H(a,i,m){I D.2q(m[3],a).K},8t:H(a){I/h\\d/i.11(a.Y)},8s:H(a){I D.3C(D.3O,H(b){I a==b.T}).K}}},6x:[/^(\\[) *@?([\\w-]+) *([!*$^~=]*) *(\'?"?)(.*?)\\4 *\\]/,/^(:)([\\w-]+)\\("?\'?(.*?(\\(.*?\\))?[^(]*?)"?\'?\\)/,2B 4v("^([:.#]*)("+C+"+)")],3g:H(a,c,b){J d,1t=[];1B(a&&a!=d){d=a;J f=D.1E(a,c,b);a=f.t.1o(/^\\s*,\\s*/,"");1t=b?c=f.r:D.2R(1t,f.r)}I 1t},2q:H(t,o){G(1j t!="23")I[t];G(o&&o.16!=1&&o.16!=9)I[];o=o||S;J d=[o],2o=[],3S,Y;1B(t&&3S!=t){J r=[];3S=t;t=D.3k(t);J l=Q,3j=6L,m=3j.2D(t);G(m){Y=m[1].2r();R(J i=0;d[i];i++)R(J c=d[i].1x;c;c=c.2H)G(c.16==1&&(Y=="*"||c.Y.2r()==Y))r.1p(c);d=r;t=t.1o(3j,"");G(t.1h(" ")==0)6M;l=M}N{3j=/^([>+~])\\s*(\\w*)/i;G((m=3j.2D(t))!=U){r=[];J k={};Y=m[2].2r();m=m[1];R(J j=0,3i=d.K;j<3i;j++){J n=m=="~"||m=="+"?d[j].2H:d[j].1x;R(;n;n=n.2H)G(n.16==1){J g=D.L(n);G(m=="~"&&k[g])1X;G(!Y||n.Y.2r()==Y){G(m=="~")k[g]=M;r.1p(n)}G(m=="+")1X}}d=r;t=D.3k(t.1o(3j,""));l=M}}G(t&&!l){G(!t.1h(",")){G(o==d[0])d.4s();2o=D.2R(2o,d);r=d=[o];t=" "+t.6v(1,t.K)}N{J h=6J;J m=h.2D(t);G(m){m=[0,m[2],m[3],m[1]]}N{h=6I;m=h.2D(t)}m[2]=m[2].1o(/\\\\/g,"");J f=d[d.K-1];G(m[1]=="#"&&f&&f.61&&!D.4n(f)){J p=f.61(m[2]);G((D.14.1f||D.14.2G)&&p&&1j p.2v=="23"&&p.2v!=m[2])p=D(\'[@2v="\'+m[2]+\'"]\',f)[0];d=r=p&&(!m[3]||D.Y(p,m[3]))?[p]:[]}N{R(J i=0;d[i];i++){J a=m[1]=="#"&&m[3]?m[3]:m[1]!=""||m[0]==""?"*":m[2];G(a=="*"&&d[i].Y.3y()=="49")a="3n";r=D.2R(r,d[i].3H(a))}G(m[1]==".")r=D.5m(r,m[2]);G(m[1]=="#"){J e=[];R(J i=0;r[i];i++)G(r[i].4G("2v")==m[2]){e=[r[i]];1X}r=e}d=r}t=t.1o(h,"")}}G(t){J b=D.1E(t,r);d=r=b.r;t=D.3k(b.t)}}G(t)d=[];G(d&&o==d[0])d.4s();2o=D.2R(2o,d);I 2o},5m:H(r,m,a){m=" "+m+" ";J c=[];R(J i=0;r[i];i++){J b=(" "+r[i].1F+" ").1h(m)>=0;G(!a&&b||a&&!b)c.1p(r[i])}I c},1E:H(t,r,h){J d;1B(t&&t!=d){d=t;J p=D.6x,m;R(J i=0;p[i];i++){m=p[i].2D(t);G(m){t=t.8r(m[0].K);m[2]=m[2].1o(/\\\\/g,"");1X}}G(!m)1X;G(m[1]==":"&&m[2]=="4Y")r=62.11(m[3])?D.1E(m[3],r,M).r:D(r).4Y(m[3]);N G(m[1]==".")r=D.5m(r,m[2],h);N G(m[1]=="["){J g=[],O=m[3];R(J i=0,3i=r.K;i<3i;i++){J a=r[i],z=a[D.3X[m[2]]||m[2]];G(z==U||/5Q|4d|2W/.11(m[2]))z=D.1K(a,m[2])||\'\';G((O==""&&!!z||O=="="&&z==m[5]||O=="!="&&z!=m[5]||O=="^="&&z&&!z.1h(m[5])||O=="$="&&z.6v(z.K-m[5].K)==m[5]||(O=="*="||O=="~=")&&z.1h(m[5])>=0)^h)g.1p(a)}r=g}N G(m[1]==":"&&m[2]=="3a-4u"){J e={},g=[],11=/(-?)(\\d*)n((?:\\+|-)?\\d*)/.2D(m[3]=="6D"&&"2n"||m[3]=="6C"&&"2n+1"||!/\\D/.11(m[3])&&"8q+"+m[3]||m[3]),3o=(11[1]+(11[2]||1))-0,d=11[3]-0;R(J i=0,3i=r.K;i<3i;i++){J j=r[i],1d=j.1d,2v=D.L(1d);G(!e[2v]){J c=1;R(J n=1d.1x;n;n=n.2H)G(n.16==1)n.4q=c++;e[2v]=M}J b=Q;G(3o==0){G(j.4q==d)b=M}N G((j.4q-d)%3o==0&&(j.4q-d)/3o>=0)b=M;G(b^h)g.1p(j)}r=g}N{J f=D.6H[m[1]];G(1j f=="49")f=f[m[2]];G(1j f=="23")f=6u("Q||H(a,i){I "+f+";}");r=D.3C(r,H(a,i){I f(a,i,m,r)},h)}}I{r:r,t:t}},4S:H(b,c){J a=[],1t=b[c];1B(1t&&1t!=S){G(1t.16==1)a.1p(1t);1t=1t[c]}I a},3a:H(a,e,c,b){e=e||1;J d=0;R(;a;a=a[c])G(a.16==1&&++d==e)1X;I a},5v:H(n,a){J r=[];R(;n;n=n.2H){G(n.16==1&&n!=a)r.1p(n)}I r}});D.W={1e:H(f,i,g,e){G(f.16==3||f.16==8)I;G(D.14.1f&&f.4I)f=1b;G(!g.24)g.24=7.24++;G(e!=12){J h=g;g=7.3M(h,H(){I h.1w(7,19)});g.L=e}J j=D.L(f,"3w")||D.L(f,"3w",{}),1H=D.L(f,"1H")||D.L(f,"1H",H(){G(1j D!="12"&&!D.W.5k)I D.W.1H.1w(19.3L.T,19)});1H.T=f;D.P(i.1R(/\\s+/),H(c,b){J a=b.1R(".");b=a[0];g.O=a[1];J d=j[b];G(!d){d=j[b]={};G(!D.W.2t[b]||D.W.2t[b].4p.1k(f)===Q){G(f.3K)f.3K(b,1H,Q);N G(f.6t)f.6t("4o"+b,1H)}}d[g.24]=g;D.W.26[b]=M});f=U},24:1,26:{},21:H(e,h,f){G(e.16==3||e.16==8)I;J i=D.L(e,"3w"),1L,5i;G(i){G(h==12||(1j h=="23"&&h.8p(0)=="."))R(J g 1n i)7.21(e,g+(h||""));N{G(h.O){f=h.2y;h=h.O}D.P(h.1R(/\\s+/),H(b,a){J c=a.1R(".");a=c[0];G(i[a]){G(f)2U i[a][f.24];N R(f 1n i[a])G(!c[1]||i[a][f].O==c[1])2U i[a][f];R(1L 1n i[a])1X;G(!1L){G(!D.W.2t[a]||D.W.2t[a].4A.1k(e)===Q){G(e.6p)e.6p(a,D.L(e,"1H"),Q);N G(e.6n)e.6n("4o"+a,D.L(e,"1H"))}1L=U;2U i[a]}}})}R(1L 1n i)1X;G(!1L){J d=D.L(e,"1H");G(d)d.T=U;D.3b(e,"3w");D.3b(e,"1H")}}},1P:H(h,c,f,g,i){c=D.2d(c);G(h.1h("!")>=0){h=h.3s(0,-1);J a=M}G(!f){G(7.26[h])D("*").1e([1b,S]).1P(h,c)}N{G(f.16==3||f.16==8)I 12;J b,1L,17=D.1D(f[h]||U),W=!c[0]||!c[0].32;G(W){c.6h({O:h,2J:f,32:H(){},3J:H(){},4C:1z()});c[0][E]=M}c[0].O=h;G(a)c[0].6m=M;J d=D.L(f,"1H");G(d)b=d.1w(f,c);G((!17||(D.Y(f,\'a\')&&h=="4V"))&&f["4o"+h]&&f["4o"+h].1w(f,c)===Q)b=Q;G(W)c.4s();G(i&&D.1D(i)){1L=i.1w(f,b==U?c:c.7d(b));G(1L!==12)b=1L}G(17&&g!==Q&&b!==Q&&!(D.Y(f,\'a\')&&h=="4V")){7.5k=M;1U{f[h]()}1V(e){}}7.5k=Q}I b},1H:H(b){J a,1L,38,5f,4m;b=19[0]=D.W.6l(b||1b.W);38=b.O.1R(".");b.O=38[0];38=38[1];5f=!38&&!b.6m;4m=(D.L(7,"3w")||{})[b.O];R(J j 1n 4m){J c=4m[j];G(5f||c.O==38){b.2y=c;b.L=c.L;1L=c.1w(7,19);G(a!==Q)a=1L;G(1L===Q){b.32();b.3J()}}}I a},6l:H(b){G(b[E]==M)I b;J d=b;b={8o:d};J c="8n 8m 8l 8k 2s 8j 47 5d 6j 5E 8i L 8h 8g 4K 2y 5a 59 8e 8b 58 6f 8a 88 4k 87 86 84 6d 2J 4C 6c O 82 81 35".1R(" ");R(J i=c.K;i;i--)b[c[i]]=d[c[i]];b[E]=M;b.32=H(){G(d.32)d.32();d.80=Q};b.3J=H(){G(d.3J)d.3J();d.7Z=M};b.4C=b.4C||1z();G(!b.2J)b.2J=b.6d||S;G(b.2J.16==3)b.2J=b.2J.1d;G(!b.4k&&b.4K)b.4k=b.4K==b.2J?b.6c:b.4K;G(b.58==U&&b.5d!=U){J a=S.1C,1c=S.1c;b.58=b.5d+(a&&a.2e||1c&&1c.2e||0)-(a.6b||0);b.6f=b.6j+(a&&a.2c||1c&&1c.2c||0)-(a.6a||0)}G(!b.35&&((b.47||b.47===0)?b.47:b.5a))b.35=b.47||b.5a;G(!b.59&&b.5E)b.59=b.5E;G(!b.35&&b.2s)b.35=(b.2s&1?1:(b.2s&2?3:(b.2s&4?2:0)));I b},3M:H(a,b){b.24=a.24=a.24||b.24||7.24++;I b},2t:{27:{4p:H(){55();I},4A:H(){I}},3D:{4p:H(){G(D.14.1f)I Q;D(7).2O("53",D.W.2t.3D.2y);I M},4A:H(){G(D.14.1f)I Q;D(7).4e("53",D.W.2t.3D.2y);I M},2y:H(a){G(F(a,7))I M;a.O="3D";I D.W.1H.1w(7,19)}},3N:{4p:H(){G(D.14.1f)I Q;D(7).2O("51",D.W.2t.3N.2y);I M},4A:H(){G(D.14.1f)I Q;D(7).4e("51",D.W.2t.3N.2y);I M},2y:H(a){G(F(a,7))I M;a.O="3N";I D.W.1H.1w(7,19)}}}};D.17.1l({2O:H(c,a,b){I c=="4X"?7.2V(c,a,b):7.P(H(){D.W.1e(7,c,b||a,b&&a)})},2V:H(d,b,c){J e=D.W.3M(c||b,H(a){D(7).4e(a,e);I(c||b).1w(7,19)});I 7.P(H(){D.W.1e(7,d,e,c&&b)})},4e:H(a,b){I 7.P(H(){D.W.21(7,a,b)})},1P:H(c,a,b){I 7.P(H(){D.W.1P(c,a,7,M,b)})},5C:H(c,a,b){I 7[0]&&D.W.1P(c,a,7[0],Q,b)},2m:H(b){J c=19,i=1;1B(i=0){J i=g.3s(e,g.K);g=g.3s(0,e)}c=c||H(){};J f="2P";G(d)G(D.1D(d)){c=d;d=U}N{d=D.3n(d);f="6g"}J h=7;D.3Y({1a:g,O:f,1O:"2K",L:d,1J:H(a,b){G(b=="1W"||b=="7J")h.2K(i?D("<1v/>").3v(a.4U.1o(/<1m(.|\\s)*?\\/1m>/g,"")).2q(i):a.4U);h.P(c,[a.4U,b,a])}});I 7},aL:H(){I D.3n(7.7I())},7I:H(){I 7.2l(H(){I D.Y(7,"3V")?D.2d(7.aH):7}).1E(H(){I 7.34&&!7.3R&&(7.4J||/2A|6y/i.11(7.Y)||/1r|1G|3Q/i.11(7.O))}).2l(H(i,c){J b=D(7).6e();I b==U?U:b.1q==2p?D.2l(b,H(a,i){I{34:c.34,2x:a}}):{34:c.34,2x:b}}).3p()}});D.P("7H,7G,7F,7D,7C,7B".1R(","),H(i,o){D.17[o]=H(f){I 7.2O(o,f)}});J B=1z();D.1l({3p:H(d,b,a,c){G(D.1D(b)){a=b;b=U}I D.3Y({O:"2P",1a:d,L:b,1W:a,1O:c})},aE:H(b,a){I D.3p(b,U,a,"1m")},aD:H(c,b,a){I D.3p(c,b,a,"3z")},aC:H(d,b,a,c){G(D.1D(b)){a=b;b={}}I D.3Y({O:"6g",1a:d,L:b,1W:a,1O:c})},aA:H(a){D.1l(D.60,a)},60:{1a:5Z.5Q,26:M,O:"2P",2T:0,7z:"4R/x-ax-3V-aw",7x:M,31:M,L:U,5Y:U,3Q:U,4Q:{2N:"4R/2N, 1r/2N",2K:"1r/2K",1m:"1r/4t, 4R/4t",3z:"4R/3z, 1r/4t",1r:"1r/as",4w:"*/*"}},4z:{},3Y:H(s){s=D.1l(M,s,D.1l(M,{},D.60,s));J g,2Z=/=\\?(&|$)/g,1u,L,O=s.O.2r();G(s.L&&s.7x&&1j s.L!="23")s.L=D.3n(s.L);G(s.1O=="4P"){G(O=="2P"){G(!s.1a.1I(2Z))s.1a+=(s.1a.1I(/\\?/)?"&":"?")+(s.4P||"7u")+"=?"}N G(!s.L||!s.L.1I(2Z))s.L=(s.L?s.L+"&":"")+(s.4P||"7u")+"=?";s.1O="3z"}G(s.1O=="3z"&&(s.L&&s.L.1I(2Z)||s.1a.1I(2Z))){g="4P"+B++;G(s.L)s.L=(s.L+"").1o(2Z,"="+g+"$1");s.1a=s.1a.1o(2Z,"="+g+"$1");s.1O="1m";1b[g]=H(a){L=a;1W();1J();1b[g]=12;1U{2U 1b[g]}1V(e){}G(i)i.37(h)}}G(s.1O=="1m"&&s.1Y==U)s.1Y=Q;G(s.1Y===Q&&O=="2P"){J j=1z();J k=s.1a.1o(/(\\?|&)3m=.*?(&|$)/,"$ap="+j+"$2");s.1a=k+((k==s.1a)?(s.1a.1I(/\\?/)?"&":"?")+"3m="+j:"")}G(s.L&&O=="2P"){s.1a+=(s.1a.1I(/\\?/)?"&":"?")+s.L;s.L=U}G(s.26&&!D.4O++)D.W.1P("7H");J n=/^(?:\\w+:)?\\/\\/([^\\/?#]+)/;G(s.1O=="1m"&&O=="2P"&&n.11(s.1a)&&n.2D(s.1a)[1]!=5Z.al){J i=S.3H("6w")[0];J h=S.3h("1m");h.4d=s.1a;G(s.7t)h.aj=s.7t;G(!g){J l=Q;h.ah=h.ag=H(){G(!l&&(!7.3f||7.3f=="68"||7.3f=="1J")){l=M;1W();1J();i.37(h)}}}i.3U(h);I 12}J m=Q;J c=1b.7s?2B 7s("ae.ac"):2B 7r();G(s.5Y)c.6R(O,s.1a,s.31,s.5Y,s.3Q);N c.6R(O,s.1a,s.31);1U{G(s.L)c.4B("ab-aa",s.7z);G(s.5S)c.4B("a9-5R-a8",D.4z[s.1a]||"a7, a6 a5 a4 5N:5N:5N a2");c.4B("X-9Z-9Y","7r");c.4B("9W",s.1O&&s.4Q[s.1O]?s.4Q[s.1O]+", */*":s.4Q.4w)}1V(e){}G(s.7m&&s.7m(c,s)===Q){s.26&&D.4O--;c.7l();I Q}G(s.26)D.W.1P("7B",[c,s]);J d=H(a){G(!m&&c&&(c.3f==4||a=="2T")){m=M;G(f){7k(f);f=U}1u=a=="2T"&&"2T"||!D.7j(c)&&"3e"||s.5S&&D.7h(c,s.1a)&&"7J"||"1W";G(1u=="1W"){1U{L=D.6X(c,s.1O,s.9S)}1V(e){1u="5J"}}G(1u=="1W"){J b;1U{b=c.5I("7g-5R")}1V(e){}G(s.5S&&b)D.4z[s.1a]=b;G(!g)1W()}N D.5H(s,c,1u);1J();G(s.31)c=U}};G(s.31){J f=4I(d,13);G(s.2T>0)3B(H(){G(c){c.7l();G(!m)d("2T")}},s.2T)}1U{c.9P(s.L)}1V(e){D.5H(s,c,U,e)}G(!s.31)d();H 1W(){G(s.1W)s.1W(L,1u);G(s.26)D.W.1P("7C",[c,s])}H 1J(){G(s.1J)s.1J(c,1u);G(s.26)D.W.1P("7F",[c,s]);G(s.26&&!--D.4O)D.W.1P("7G")}I c},5H:H(s,a,b,e){G(s.3e)s.3e(a,b,e);G(s.26)D.W.1P("7D",[a,s,e])},4O:0,7j:H(a){1U{I!a.1u&&5Z.9O=="5p:"||(a.1u>=7e&&a.1u<9N)||a.1u==7c||a.1u==9K||D.14.2k&&a.1u==12}1V(e){}I Q},7h:H(a,c){1U{J b=a.5I("7g-5R");I a.1u==7c||b==D.4z[c]||D.14.2k&&a.1u==12}1V(e){}I Q},6X:H(a,c,b){J d=a.5I("9J-O"),2N=c=="2N"||!c&&d&&d.1h("2N")>=0,L=2N?a.9I:a.4U;G(2N&&L.1C.2j=="5J")7p"5J";G(b)L=b(L,c);G(c=="1m")D.5u(L);G(c=="3z")L=6u("("+L+")");I L},3n:H(a){J s=[];G(a.1q==2p||a.5w)D.P(a,H(){s.1p(3u(7.34)+"="+3u(7.2x))});N R(J j 1n a)G(a[j]&&a[j].1q==2p)D.P(a[j],H(){s.1p(3u(j)+"="+3u(7))});N s.1p(3u(j)+"="+3u(D.1D(a[j])?a[j]():a[j]));I s.6s("&").1o(/%20/g,"+")}});D.17.1l({1N:H(c,b){I c?7.2g({1Z:"1N",2h:"1N",1y:"1N"},c,b):7.1E(":1G").P(H(){7.V.18=7.5D||"";G(D.1g(7,"18")=="2F"){J a=D("<"+7.2j+" />").6P("1c");7.V.18=a.1g("18");G(7.V.18=="2F")7.V.18="3I";a.21()}}).3l()},1M:H(b,a){I b?7.2g({1Z:"1M",2h:"1M",1y:"1M"},b,a):7.1E(":4j").P(H(){7.5D=7.5D||D.1g(7,"18");7.V.18="2F"}).3l()},78:D.17.2m,2m:H(a,b){I D.1D(a)&&D.1D(b)?7.78.1w(7,19):a?7.2g({1Z:"2m",2h:"2m",1y:"2m"},a,b):7.P(H(){D(7)[D(7).3F(":1G")?"1N":"1M"]()})},9G:H(b,a){I 7.2g({1Z:"1N"},b,a)},9F:H(b,a){I 7.2g({1Z:"1M"},b,a)},9E:H(b,a){I 7.2g({1Z:"2m"},b,a)},9D:H(b,a){I 7.2g({1y:"1N"},b,a)},9M:H(b,a){I 7.2g({1y:"1M"},b,a)},9C:H(c,a,b){I 7.2g({1y:a},c,b)},2g:H(k,j,i,g){J h=D.77(j,i,g);I 7[h.36===Q?"P":"36"](H(){G(7.16!=1)I Q;J f=D.1l({},h),p,1G=D(7).3F(":1G"),46=7;R(p 1n k){G(k[p]=="1M"&&1G||k[p]=="1N"&&!1G)I f.1J.1k(7);G(p=="1Z"||p=="2h"){f.18=D.1g(7,"18");f.33=7.V.33}}G(f.33!=U)7.V.33="1G";f.45=D.1l({},k);D.P(k,H(c,a){J e=2B D.28(46,f,c);G(/2m|1N|1M/.11(a))e[a=="2m"?1G?"1N":"1M":a](k);N{J b=a.6r().1I(/^([+-]=)?([\\d+-.]+)(.*)$/),2b=e.1t(M)||0;G(b){J d=3d(b[2]),2M=b[3]||"2X";G(2M!="2X"){46.V[c]=(d||1)+2M;2b=((d||1)/e.1t(M))*2b;46.V[c]=2b+2M}G(b[1])d=((b[1]=="-="?-1:1)*d)+2b;e.3G(2b,d,2M)}N e.3G(2b,a,"")}});I M})},36:H(a,b){G(D.1D(a)||(a&&a.1q==2p)){b=a;a="28"}G(!a||(1j a=="23"&&!b))I A(7[0],a);I 7.P(H(){G(b.1q==2p)A(7,a,b);N{A(7,a).1p(b);G(A(7,a).K==1)b.1k(7)}})},9X:H(b,c){J a=D.3O;G(b)7.36([]);7.P(H(){R(J i=a.K-1;i>=0;i--)G(a[i].T==7){G(c)a[i](M);a.7n(i,1)}});G(!c)7.5A();I 7}});J A=H(b,c,a){G(b){c=c||"28";J q=D.L(b,c+"36");G(!q||a)q=D.L(b,c+"36",D.2d(a))}I q};D.17.5A=H(a){a=a||"28";I 7.P(H(){J q=A(7,a);q.4s();G(q.K)q[0].1k(7)})};D.1l({77:H(b,a,c){J d=b&&b.1q==a0?b:{1J:c||!c&&a||D.1D(b)&&b,2u:b,41:c&&a||a&&a.1q!=9t&&a};d.2u=(d.2u&&d.2u.1q==4L?d.2u:D.28.5K[d.2u])||D.28.5K.74;d.5M=d.1J;d.1J=H(){G(d.36!==Q)D(7).5A();G(D.1D(d.5M))d.5M.1k(7)};I d},41:{73:H(p,n,b,a){I b+a*p},5P:H(p,n,b,a){I((-29.9r(p*29.9q)/2)+0.5)*a+b}},3O:[],48:U,28:H(b,c,a){7.15=c;7.T=b;7.1i=a;G(!c.3Z)c.3Z={}}});D.28.44={4D:H(){G(7.15.2Y)7.15.2Y.1k(7.T,7.1z,7);(D.28.2Y[7.1i]||D.28.2Y.4w)(7);G(7.1i=="1Z"||7.1i=="2h")7.T.V.18="3I"},1t:H(a){G(7.T[7.1i]!=U&&7.T.V[7.1i]==U)I 7.T[7.1i];J r=3d(D.1g(7.T,7.1i,a));I r&&r>-9p?r:3d(D.2a(7.T,7.1i))||0},3G:H(c,b,d){7.5V=1z();7.2b=c;7.3l=b;7.2M=d||7.2M||"2X";7.1z=7.2b;7.2S=7.4N=0;7.4D();J e=7;H t(a){I e.2Y(a)}t.T=7.T;D.3O.1p(t);G(D.48==U){D.48=4I(H(){J a=D.3O;R(J i=0;i7.15.2u+7.5V){7.1z=7.3l;7.2S=7.4N=1;7.4D();7.15.45[7.1i]=M;J b=M;R(J i 1n 7.15.45)G(7.15.45[i]!==M)b=Q;G(b){G(7.15.18!=U){7.T.V.33=7.15.33;7.T.V.18=7.15.18;G(D.1g(7.T,"18")=="2F")7.T.V.18="3I"}G(7.15.1M)7.T.V.18="2F";G(7.15.1M||7.15.1N)R(J p 1n 7.15.45)D.1K(7.T.V,p,7.15.3Z[p])}G(b)7.15.1J.1k(7.T);I Q}N{J n=t-7.5V;7.4N=n/7.15.2u;7.2S=D.41[7.15.41||(D.41.5P?"5P":"73")](7.4N,n,0,1,7.15.2u);7.1z=7.2b+((7.3l-7.2b)*7.2S);7.4D()}I M}};D.1l(D.28,{5K:{9l:9j,9i:7e,74:9g},2Y:{2e:H(a){a.T.2e=a.1z},2c:H(a){a.T.2c=a.1z},1y:H(a){D.1K(a.T.V,"1y",a.1z)},4w:H(a){a.T.V[a.1i]=a.1z+a.2M}}});D.17.2i=H(){J b=0,1S=0,T=7[0],3q;G(T)ao(D.14){J d=T.1d,4a=T,1s=T.1s,1Q=T.2z,5U=2k&&3r(5B)<9c&&!/9a/i.11(v),1g=D.2a,3c=1g(T,"30")=="3c";G(T.7y){J c=T.7y();1e(c.1A+29.2f(1Q.1C.2e,1Q.1c.2e),c.1S+29.2f(1Q.1C.2c,1Q.1c.2c));1e(-1Q.1C.6b,-1Q.1C.6a)}N{1e(T.5X,T.5W);1B(1s){1e(1s.5X,1s.5W);G(42&&!/^t(98|d|h)$/i.11(1s.2j)||2k&&!5U)2C(1s);G(!3c&&1g(1s,"30")=="3c")3c=M;4a=/^1c$/i.11(1s.2j)?4a:1s;1s=1s.1s}1B(d&&d.2j&&!/^1c|2K$/i.11(d.2j)){G(!/^96|1T.*$/i.11(1g(d,"18")))1e(-d.2e,-d.2c);G(42&&1g(d,"33")!="4j")2C(d);d=d.1d}G((5U&&(3c||1g(4a,"30")=="5x"))||(42&&1g(4a,"30")!="5x"))1e(-1Q.1c.5X,-1Q.1c.5W);G(3c)1e(29.2f(1Q.1C.2e,1Q.1c.2e),29.2f(1Q.1C.2c,1Q.1c.2c))}3q={1S:1S,1A:b}}H 2C(a){1e(D.2a(a,"6V",M),D.2a(a,"6U",M))}H 1e(l,t){b+=3r(l,10)||0;1S+=3r(t,10)||0}I 3q};D.17.1l({30:H(){J a=0,1S=0,3q;G(7[0]){J b=7.1s(),2i=7.2i(),4c=/^1c|2K$/i.11(b[0].2j)?{1S:0,1A:0}:b.2i();2i.1S-=25(7,\'94\');2i.1A-=25(7,\'aF\');4c.1S+=25(b,\'6U\');4c.1A+=25(b,\'6V\');3q={1S:2i.1S-4c.1S,1A:2i.1A-4c.1A}}I 3q},1s:H(){J a=7[0].1s;1B(a&&(!/^1c|2K$/i.11(a.2j)&&D.1g(a,\'30\')==\'93\'))a=a.1s;I D(a)}});D.P([\'5e\',\'5G\'],H(i,b){J c=\'4y\'+b;D.17[c]=H(a){G(!7[0])I;I a!=12?7.P(H(){7==1b||7==S?1b.92(!i?a:D(1b).2e(),i?a:D(1b).2c()):7[c]=a}):7[0]==1b||7[0]==S?46[i?\'aI\':\'aJ\']||D.71&&S.1C[c]||S.1c[c]:7[0][c]}});D.P(["6N","4b"],H(i,b){J c=i?"5e":"5G",4f=i?"6k":"6i";D.17["5s"+b]=H(){I 7[b.3y()]()+25(7,"57"+c)+25(7,"57"+4f)};D.17["90"+b]=H(a){I 7["5s"+b]()+25(7,"2C"+c+"4b")+25(7,"2C"+4f+"4b")+(a?25(7,"6S"+c)+25(7,"6S"+4f):0)}})})();',62,669,'|||||||this|||||||||||||||||||||||||||||||||||if|function|return|var|length|data|true|else|type|each|false|for|document|elem|null|style|event||nodeName|||test|undefined||browser|options|nodeType|fn|display|arguments|url|window|body|parentNode|add|msie|css|indexOf|prop|typeof|call|extend|script|in|replace|push|constructor|text|offsetParent|cur|status|div|apply|firstChild|opacity|now|left|while|documentElement|isFunction|filter|className|hidden|handle|match|complete|attr|ret|hide|show|dataType|trigger|doc|split|top|table|try|catch|success|break|cache|height||remove|tbody|string|guid|num|global|ready|fx|Math|curCSS|start|scrollTop|makeArray|scrollLeft|max|animate|width|offset|tagName|safari|map|toggle||done|Array|find|toUpperCase|button|special|duration|id|copy|value|handler|ownerDocument|select|new|border|exec|stack|none|opera|nextSibling|pushStack|target|html|inArray|unit|xml|bind|GET|isReady|merge|pos|timeout|delete|one|selected|px|step|jsre|position|async|preventDefault|overflow|name|which|queue|removeChild|namespace|insertBefore|nth|removeData|fixed|parseFloat|error|readyState|multiFilter|createElement|rl|re|trim|end|_|param|first|get|results|parseInt|slice|childNodes|encodeURIComponent|append|events|elems|toLowerCase|json|readyList|setTimeout|grep|mouseenter|color|is|custom|getElementsByTagName|block|stopPropagation|addEventListener|callee|proxy|mouseleave|timers|defaultView|password|disabled|last|has|appendChild|form|domManip|props|ajax|orig|set|easing|mozilla|load|prototype|curAnim|self|charCode|timerId|object|offsetChild|Width|parentOffset|src|unbind|br|currentStyle|clean|float|visible|relatedTarget|previousSibling|handlers|isXMLDoc|on|setup|nodeIndex|unique|shift|javascript|child|RegExp|_default|deep|scroll|lastModified|teardown|setRequestHeader|timeStamp|update|empty|tr|getAttribute|innerHTML|setInterval|checked|fromElement|Number|jQuery|state|active|jsonp|accepts|application|dir|input|responseText|click|styleSheets|unload|not|lastToggle|outline|mouseout|getPropertyValue|mouseover|getComputedStyle|bindReady|String|padding|pageX|metaKey|keyCode|getWH|andSelf|clientX|Left|all|visibility|container|index|init|triggered|removeAttribute|classFilter|prevObject|submit|file|after|windowData|inner|client|globalEval|sibling|jquery|absolute|clone|wrapAll|dequeue|version|triggerHandler|oldblock|ctrlKey|createTextNode|Top|handleError|getResponseHeader|parsererror|speeds|checkbox|old|00|radio|swing|href|Modified|ifModified|lastChild|safari2|startTime|offsetTop|offsetLeft|username|location|ajaxSettings|getElementById|isSimple|values|selectedIndex|runtimeStyle|rsLeft|_load|loaded|DOMContentLoaded|clientTop|clientLeft|toElement|srcElement|val|pageY|POST|unshift|Bottom|clientY|Right|fix|exclusive|detachEvent|cloneNode|removeEventListener|swap|toString|join|attachEvent|eval|substr|head|parse|textarea|reset|image|zoom|odd|even|before|prepend|exclude|expr|quickClass|quickID|uuid|quickChild|continue|Height|textContent|appendTo|contents|open|margin|evalScript|borderTopWidth|borderLeftWidth|parent|httpData|setArray|CSS1Compat|compatMode|boxModel|cssFloat|linear|def|webkit|nodeValue|speed|_toggle|eq|100|replaceWith|304|concat|200|alpha|Last|httpNotModified|getAttributeNode|httpSuccess|clearInterval|abort|beforeSend|splice|styleFloat|throw|colgroup|XMLHttpRequest|ActiveXObject|scriptCharset|callback|fieldset|multiple|processData|getBoundingClientRect|contentType|link|ajaxSend|ajaxSuccess|ajaxError|col|ajaxComplete|ajaxStop|ajaxStart|serializeArray|notmodified|keypress|keydown|change|mouseup|mousedown|dblclick|focus|blur|stylesheet|hasClass|rel|doScroll|black|hover|solid|cancelBubble|returnValue|wheelDelta|view|round|shiftKey|resize|screenY|screenX|relatedNode|mousemove|prevValue|originalTarget|offsetHeight|keyup|newValue|offsetWidth|eventPhase|detail|currentTarget|cancelable|bubbles|attrName|attrChange|altKey|originalEvent|charAt|0n|substring|animated|header|noConflict|line|enabled|innerText|contains|only|weight|font|gt|lt|uFFFF|u0128|size|417|Boolean|Date|toggleClass|removeClass|addClass|removeAttr|replaceAll|insertAfter|prependTo|wrap|contentWindow|contentDocument|iframe|children|siblings|prevAll|wrapInner|nextAll|outer|prev|scrollTo|static|marginTop|next|inline|parents|able|cellSpacing|adobeair|cellspacing|522|maxLength|maxlength|readOnly|400|readonly|fast|600|class|slow|1px|htmlFor|reverse|10000|PI|cos|compatible|Function|setData|ie|ra|it|rv|getData|userAgent|navigator|fadeTo|fadeIn|slideToggle|slideUp|slideDown|ig|responseXML|content|1223|NaN|fadeOut|300|protocol|send|setAttribute|option|dataFilter|cssText|changed|be|Accept|stop|With|Requested|Object|can|GMT|property|1970|Jan|01|Thu|Since|If|Type|Content|XMLHTTP|th|Microsoft|td|onreadystatechange|onload|cap|charset|colg|host|tfoot|specified|with|1_|thead|leg|plain|attributes|opt|embed|urlencoded|www|area|hr|ajaxSetup|meta|post|getJSON|getScript|marginLeft|img|elements|pageYOffset|pageXOffset|abbr|serialize|pixelLeft'.split('|'),0,{})) +\ No newline at end of file diff -Nru trac-0.11.7/debian/patches/.svn/text-base/20_add_interpreter_line.dpatch.svn-base trac-0.12.1~ppa2/debian/patches/.svn/text-base/20_add_interpreter_line.dpatch.svn-base --- trac-0.11.7/debian/patches/.svn/text-base/20_add_interpreter_line.dpatch.svn-base 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/.svn/text-base/20_add_interpreter_line.dpatch.svn-base 2010-05-05 03:09:14.000000000 +0100 @@ -0,0 +1,16 @@ +#! /bin/sh /usr/share/dpatch/dpatch-run +## 20_add_interpreter_line.dpatch by +## +## All lines beginning with `## DP:' are a description of the patch. +## DP: adds the Python interpreter shebang line to modpython_frontend.py + +@DPATCH@ + +diff -ur a/trac/web/modpython_frontend.py b/trac/web/modpython_frontend.py +--- a/trac/web/modpython_frontend.py 2009-02-16 21:15:19.000000000 +0100 ++++ b/trac/web/modpython_frontend.py 2009-09-15 11:02:20.000000000 +0200 +@@ -1,3 +1,4 @@ ++#!/usr/bin/env python + # -*- coding: utf-8 -*- + # + # Copyright (C) 2004-2009 Edgewall Software diff -Nru trac-0.11.7/debian/patches/.svn/text-base/30_default_charset_utf8.dpatch.svn-base trac-0.12.1~ppa2/debian/patches/.svn/text-base/30_default_charset_utf8.dpatch.svn-base --- trac-0.11.7/debian/patches/.svn/text-base/30_default_charset_utf8.dpatch.svn-base 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/.svn/text-base/30_default_charset_utf8.dpatch.svn-base 2010-05-05 03:09:14.000000000 +0100 @@ -0,0 +1,20 @@ +#! /bin/sh /usr/share/dpatch/dpatch-run +## 30_default_charset_utf8.dpatch by +## +## All lines beginning with `## DP:' are a description of the patch. +## DP: Use UTF-8 as default charset + +@DPATCH@ + +diff -uraN trac-0.11.5.orig/trac/mimeview/api.py trac-0.11.5/trac/mimeview/api.py +--- trac-0.11.5.orig/trac/mimeview/api.py 2009-06-30 21:18:58.000000000 +0200 ++++ trac-0.11.5/trac/mimeview/api.py 2009-09-28 22:02:35.000000000 +0200 +@@ -579,7 +579,7 @@ + annotators = ExtensionPoint(IHTMLPreviewAnnotator) + converters = ExtensionPoint(IContentConverter) + +- default_charset = Option('trac', 'default_charset', 'iso-8859-15', ++ default_charset = Option('trac', 'default_charset', 'utf-8', + """Charset to be used when in doubt.""") + + tab_width = IntOption('mimeviewer', 'tab_width', 8, diff -Nru trac-0.11.7/debian/patches/.svn/text-base/40_timeline_author_filter.dpatch.svn-base trac-0.12.1~ppa2/debian/patches/.svn/text-base/40_timeline_author_filter.dpatch.svn-base --- trac-0.11.7/debian/patches/.svn/text-base/40_timeline_author_filter.dpatch.svn-base 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/debian/patches/.svn/text-base/40_timeline_author_filter.dpatch.svn-base 2010-05-05 03:09:14.000000000 +0100 @@ -0,0 +1,68 @@ +#! /bin/sh /usr/share/dpatch/dpatch-run +## 40_timeline_author_filter.dpatch by +## +## All lines beginning with `## DP:' are a description of the patch. +## DP: add author filter to timeline + +@DPATCH@ + +Index: trac/trac/timeline/web_ui.py +=================================================================== +--- trac/trac/timeline/web_ui.py (revision 7937) ++++ trac/trac/timeline/web_ui.py (working copy) +@@ -118,8 +118,12 @@ + daysback = max(0, daysback) + if self.max_daysback >= 0: + daysback = min(self.max_daysback, daysback) ++ author = req.args.get('author', ++ req.session.get('timeline.author', '')) ++ author = author.strip() + + data = {'fromdate': fromdate, 'daysback': daysback, ++ 'author': author, + 'today': format_date(today), + 'yesterday': format_date(today - timedelta(days=1)), + 'precisedate': precisedate, 'precision': precision, +@@ -158,7 +162,9 @@ + try: + for event in provider.get_timeline_events(req, start, stop, + filters): +- events.append(self._event_data(provider, event)) ++ author_index = len(event) < 6 and 2 or 4 # 0.10 events ++ if not author or event[author_index] == author: ++ events.append(self._event_data(provider, event)) + except Exception, e: # cope with a failure of that provider + self._provider_failure(e, req, provider, filters, + [f[0] for f in available_filters]) +@@ -185,6 +191,7 @@ + return 'timeline.rss', data, 'application/rss+xml' + else: + req.session['timeline.daysback'] = daysback ++ req.session['timeline.author'] = author + html_context = Context.from_request(req) + html_context.set_hints(wiki_flavor='oneliner', + shorten_lines=self.abbreviated_messages) +@@ -192,7 +199,8 @@ + + add_stylesheet(req, 'common/css/timeline.css') + rss_href = req.href.timeline([(f, 'on') for f in filters], +- daysback=90, max=50, format='rss') ++ daysback=90, max=50, author=author, ++ format='rss') + add_link(req, 'alternate', rss_href, _('RSS Feed'), + 'application/rss+xml', 'rss') + +Index: trac/trac/timeline/templates/timeline.html +=================================================================== +--- trac/trac/timeline/templates/timeline.html (revision 7937) ++++ trac/trac/timeline/templates/timeline.html (working copy) +@@ -18,7 +18,8 @@ +
+
+
+- and . ++ and
++ +
+
+
- +
diff -Nru trac-0.11.7/trac/admin/templates/admin_components.html trac-0.12.1~ppa2/trac/admin/templates/admin_components.html --- trac-0.11.7/trac/admin/templates/admin_components.html 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/admin/templates/admin_components.html 2010-01-13 21:58:49.000000000 +0000 @@ -3,7 +3,8 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> + xmlns:py="http://genshi.edgewall.org/" + xmlns:i18n="http://genshi.edgewall.org/i18n"> Components @@ -18,9 +19,9 @@ @@ -38,21 +39,21 @@ ${owner_field(component.owner)}
-
- - + +
@@ -66,7 +67,7 @@ ${owner_field()}
- +
@@ -94,8 +95,8 @@
- - + +

You can remove all items from this list to completely hide this diff -Nru trac-0.11.7/trac/admin/templates/admin_enums.html trac-0.12.1~ppa2/trac/admin/templates/admin_enums.html --- trac-0.11.7/trac/admin/templates/admin_enums.html 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/admin/templates/admin_enums.html 2010-03-18 06:13:49.000000000 +0000 @@ -3,6 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> @@ -10,18 +11,18 @@ -

Manage $label_plural

+

Manage $label_plural

- Modify $label_singular + Modify $label_singular
- - + +
@@ -34,7 +35,7 @@
- +
@@ -65,8 +66,8 @@
- - + +

You can remove all items from this list to completely hide this diff -Nru trac-0.11.7/trac/admin/templates/admin_logging.html trac-0.12.1~ppa2/trac/admin/templates/admin_logging.html --- trac-0.11.7/trac/admin/templates/admin_logging.html 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/admin/templates/admin_logging.html 2009-04-13 20:14:45.000000000 +0100 @@ -3,6 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> @@ -44,13 +45,13 @@ -

+

If you specify a relative path, the log file will be stored inside the log directory of the project environment ($log.dir).

- +
diff -Nru trac-0.11.7/trac/admin/templates/admin_milestones.html trac-0.12.1~ppa2/trac/admin/templates/admin_milestones.html --- trac-0.11.7/trac/admin/templates/admin_milestones.html 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/admin/templates/admin_milestones.html 2010-03-07 09:14:01.000000000 +0000 @@ -3,7 +3,8 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> + xmlns:py="http://genshi.edgewall.org/" + xmlns:i18n="http://genshi.edgewall.org/i18n"> Milestones @@ -23,9 +24,9 @@
@@ -37,9 +38,9 @@ @@ -34,20 +58,20 @@

-
-
-

${plugin.name} ${plugin.version}

+
+

${plugin.name} ${plugin.version}

@@ -80,27 +104,64 @@ - + + + + - - - + + + + + +
ComponentEnabled
+ + [+] + [] + + Component + Enabled
- ${component.name}

${component.module}

+
+

+ + [${show_doc and '–' or '+'}] + + ${module_name}.* + — ${module.summary} +

+
${wiki_to_html(context, module.description)}
+
+

+ + [${show_doc and '–' or '+'}] + + ${component_name} + — ${component.summary} +

+
${wiki_to_html(context, component.description)}
+ value="${module_name}.${component_name}" />
-
+
- +
diff -Nru trac-0.11.7/trac/admin/templates/admin_versions.html trac-0.12.1~ppa2/trac/admin/templates/admin_versions.html --- trac-0.11.7/trac/admin/templates/admin_versions.html 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/admin/templates/admin_versions.html 2010-03-07 09:14:01.000000000 +0000 @@ -3,7 +3,8 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> + xmlns:py="http://genshi.edgewall.org/" + xmlns:i18n="http://genshi.edgewall.org/i18n"> Versions @@ -25,24 +26,24 @@
-
- - + +
@@ -57,13 +58,13 @@
- +
@@ -89,8 +90,8 @@
- - + +

You can remove all items from this list to completely hide this diff -Nru trac-0.11.7/trac/admin/templates/deploy_trac.cgi trac-0.12.1~ppa2/trac/admin/templates/deploy_trac.cgi --- trac-0.11.7/trac/admin/templates/deploy_trac.cgi 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/admin/templates/deploy_trac.cgi 2010-01-22 22:14:45.000000000 +0000 @@ -18,9 +18,9 @@ try: import os import pkg_resources - if 'TRAC_ENV' not in os.environ and \ + if 'TRAC_ENV' not in os.environ and \\ 'TRAC_ENV_PARENT_DIR' not in os.environ: - os.environ['TRAC_ENV'] = '${env.path}' + os.environ['TRAC_ENV'] = ${repr(env.path)} if 'PYTHON_EGG_CACHE' not in os.environ: if 'TRAC_ENV' in os.environ: egg_cache = os.path.join(os.environ['TRAC_ENV'], '.egg-cache') diff -Nru trac-0.11.7/trac/admin/templates/deploy_trac.fcgi trac-0.12.1~ppa2/trac/admin/templates/deploy_trac.fcgi --- trac-0.11.7/trac/admin/templates/deploy_trac.fcgi 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/admin/templates/deploy_trac.fcgi 2010-01-22 22:14:45.000000000 +0000 @@ -18,9 +18,9 @@ try: import os import pkg_resources - if 'TRAC_ENV' not in os.environ and \ + if 'TRAC_ENV' not in os.environ and \\ 'TRAC_ENV_PARENT_DIR' not in os.environ: - os.environ['TRAC_ENV'] = '${env.path}' + os.environ['TRAC_ENV'] = ${repr(env.path)} if 'PYTHON_EGG_CACHE' not in os.environ: if 'TRAC_ENV' in os.environ: egg_cache = os.path.join(os.environ['TRAC_ENV'], '.egg-cache') diff -Nru trac-0.11.7/trac/admin/templates/deploy_trac.wsgi trac-0.12.1~ppa2/trac/admin/templates/deploy_trac.wsgi --- trac-0.11.7/trac/admin/templates/deploy_trac.wsgi 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/admin/templates/deploy_trac.wsgi 2010-01-22 22:14:45.000000000 +0000 @@ -17,8 +17,8 @@ import os def application(environ, start_request): - if not 'trac.env_path_parent_dir' in environ: - environ.setdefault('trac.env_path', '${env.path}') + if not 'trac.env_parent_dir' in environ: + environ.setdefault('trac.env_path', ${repr(env.path)}) if 'PYTHON_EGG_CACHE' in environ: os.environ['PYTHON_EGG_CACHE'] = environ['PYTHON_EGG_CACHE'] elif 'trac.env_path' in environ: diff -Nru trac-0.11.7/trac/admin/tests/console.py trac-0.12.1~ppa2/trac/admin/tests/console.py --- trac-0.11.7/trac/admin/tests/console.py 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/admin/tests/console.py 2010-02-24 06:08:39.000000000 +0000 @@ -13,15 +13,11 @@ # # Author: Tim Moloney -import ConfigParser import difflib import os import re -import shlex import sys -import time import unittest -import traceback from StringIO import StringIO from trac.config import Configuration @@ -29,6 +25,7 @@ from trac.admin import console from trac.test import InMemoryDatabase from trac.util.datefmt import get_date_format_hint +from trac.web.tests.session import _prep_session_table STRIP_TRAILING_SPACE = re.compile(r'( +)$', re.MULTILINE) @@ -62,7 +59,7 @@ class InMemoryEnvironment(Environment): """ - A subclass of Environment that keeps its' DB in memory. + A subclass of Environment that keeps its DB in memory. """ def get_db_cnx(self): @@ -94,9 +91,9 @@ .../trac/tests.py. """ - expected_results = load_expected_results(os.path.join(os.path.split(__file__)[0], - 'console-tests.txt'), - '===== (test_[^ ]+) =====') + expected_results = load_expected_results( + os.path.join(os.path.split(__file__)[0], 'console-tests.txt'), + '===== (test_[^ ]+) =====') def setUp(self): self.env = InMemoryEnvironment('', create=True) @@ -111,7 +108,7 @@ def tearDown(self): self.env = None - def _execute(self, cmd, strip_trailing_space=True, expect_exception=False): + def _execute(self, cmd, strip_trailing_space=True): _err = sys.stderr _out = sys.stdout try: @@ -122,8 +119,6 @@ retval = self._admin.onecmd(cmd) except SystemExit, e: pass - sys.stderr = _err - sys.stdout = _out value = out.getvalue() if isinstance(value, str): # reverse what print_listing did value = value.decode('utf-8') @@ -131,15 +126,24 @@ return retval, STRIP_TRAILING_SPACE.sub('', value) else: return retval, value - except Exception, e: + finally: sys.stderr = _err sys.stdout = _out - if expect_exception: - tb = ''.join(traceback.format_exception(*sys.exc_info())) - message = tb.splitlines()[-1] + '\n' - return -1, message - raise + def assertEqual(self, expected_results, output): + if not (isinstance(expected_results, basestring) and \ + isinstance(output, basestring)): + return unittest.TestCase.assertEqual(self, expected_results, output) + # Create a useful delta between the output and the expected output + output_lines = ['%s\n' % x for x in output.split('\n')] + expected_lines = ['%s\n' % x for x in expected_results.split('\n')] + output_diff = ''.join(list( + difflib.unified_diff(expected_lines, output_lines, + 'expected', 'actual') + )) + unittest.TestCase.assertEqual(self, expected_results, output, + "%r != %r\n%s" % + (expected_results, output, output_diff)) # Help test def test_help_ok(self): @@ -156,14 +160,61 @@ expected_results = self.expected_results[test_name] % d rv, output = self._execute('help') self.assertEqual(0, rv) - # Create a useful delta between the output and the expected output - output_lines = ['%s\n' % x for x in output.split('\n')] - expected_lines = ['%s\n' % x for x in expected_results.split('\n')] - output_diff = ''.join(list( - difflib.unified_diff(expected_lines, output_lines) - )) - failure_message = "%r != %r\n" % (output, expected_results) + output_diff - self.assertEqual(expected_results, output, failure_message) + self.assertEqual(expected_results, output) + + # Attachment tests + + def test_attachment_list_empty(self): + """ + Tests the 'attachment list' command in trac-admin, on a wiki page that + doesn't have any attachments. + """ + # FIXME: Additional tests should be written for the other 'attachment' + # commands. This requires being able to control the current + # time, which in turn would require centralizing the time + # provider, for example in the environment object. + test_name = sys._getframe().f_code.co_name + rv, output = self._execute('attachment list wiki:WikiStart') + self.assertEqual(0, rv) + self.assertEqual(self.expected_results[test_name], output) + + # Config tests + + def test_config_get(self): + """ + Tests the 'config get' command in trac-admin. This particular + test gets the project name from the config. + """ + test_name = sys._getframe().f_code.co_name + self.env.config.set('project', 'name', 'Test project') + rv, output = self._execute('config get project name') + self.assertEqual(0, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_config_set(self): + """ + Tests the 'config set' command in trac-admin. This particular + test sets the project name using an option value containing a space. + """ + test_name = sys._getframe().f_code.co_name + rv, output = self._execute('config set project name "Test project"') + self.assertEqual(0, rv) + self.assertEqual(self.expected_results[test_name], output) + self.assertEqual('Test project', + self.env.config.get('project', 'name')) + + def test_config_remove(self): + """ + Tests the 'config remove' command in trac-admin. This particular + test removes the project name from the config, therefore reverting + the option to the default value. + """ + test_name = sys._getframe().f_code.co_name + self.env.config.set('project', 'name', 'Test project') + rv, output = self._execute('config remove project name') + self.assertEqual(0, rv) + self.assertEqual(self.expected_results[test_name], output) + self.assertEqual('My Project', self.env.config.get('project', 'name')) # Permission tests @@ -257,9 +308,8 @@ error message. """ test_name = sys._getframe().f_code.co_name - rv, output = self._execute('component add component1 new_user', - expect_exception=True) - self.assertEqual(-1, rv) + rv, output = self._execute('component add component1 new_user') + self.assertEqual(2, rv) self.assertEqual(self.expected_results[test_name], output) def test_component_rename_ok(self): @@ -289,9 +339,8 @@ test tries to rename a component to a name that already exists. """ test_name = sys._getframe().f_code.co_name - rv, output = self._execute('component rename component1 component2', - expect_exception=True) - self.assertEqual(-1, rv) + rv, output = self._execute('component rename component1 component2') + self.assertEqual(2, rv) self.assertEqual(self.expected_results[test_name], output) def test_component_chown_ok(self): @@ -371,9 +420,8 @@ message. """ test_name = sys._getframe().f_code.co_name - rv, output = self._execute('ticket_type add defect', - expect_exception=True) - self.assertEqual(-1, rv) + rv, output = self._execute('ticket_type add defect') + self.assertEqual(2, rv) self.assertEqual(self.expected_results[test_name], output) def test_ticket_type_change_ok(self): @@ -403,9 +451,8 @@ test tries to change a ticket type to another type that already exists. """ test_name = sys._getframe().f_code.co_name - rv, output = self._execute('ticket_type change defect task', - expect_exception=True) - self.assertEqual(-1, rv) + rv, output = self._execute('ticket_type change defect task') + self.assertEqual(2, rv) self.assertEqual(self.expected_results[test_name], output) def test_ticket_type_remove_ok(self): @@ -504,9 +551,8 @@ error message. """ test_name = sys._getframe().f_code.co_name - rv, output = self._execute('priority add blocker', - expect_exception=True) - self.assertEqual(-1, rv) + rv, output = self._execute('priority add blocker') + self.assertEqual(2, rv) self.assertEqual(self.expected_results[test_name], output) def test_priority_change_ok(self): @@ -536,9 +582,8 @@ test tries to change a priority to a name that already exists. """ test_name = sys._getframe().f_code.co_name - rv, output = self._execute('priority change major minor', - expect_exception=True) - self.assertEqual(-1, rv) + rv, output = self._execute('priority change major minor') + self.assertEqual(2, rv) self.assertEqual(self.expected_results[test_name], output) def test_priority_remove_ok(self): @@ -626,9 +671,8 @@ """ test_name = sys._getframe().f_code.co_name self._execute('severity add blocker') - rv, output = self._execute('severity add blocker', - expect_exception=True) - self.assertEqual(-1, rv) + rv, output = self._execute('severity add blocker') + self.assertEqual(2, rv) self.assertEqual(self.expected_results[test_name], output) def test_severity_change_ok(self): @@ -661,9 +705,8 @@ test_name = sys._getframe().f_code.co_name self._execute('severity add major') self._execute('severity add critical') - rv, output = self._execute('severity change critical major', - expect_exception=True) - self.assertEqual(-1, rv) + rv, output = self._execute('severity change critical major') + self.assertEqual(2, rv) self.assertEqual(self.expected_results[test_name], output) def test_severity_remove_ok(self): @@ -754,9 +797,8 @@ error message. """ test_name = sys._getframe().f_code.co_name - rv, output = self._execute('version add 1.0 "%s"' % self._test_date, - expect_exception=True) - self.assertEqual(-1, rv) + rv, output = self._execute('version add 1.0 "%s"' % self._test_date) + self.assertEqual(2, rv) self.assertEqual(self.expected_results[test_name], output) def test_version_rename_ok(self): @@ -856,7 +898,7 @@ test_name = sys._getframe().f_code.co_name self._execute('milestone add new_milestone "%s"' % self._test_date) rv, output = self._execute('milestone list') - #self.assertEqual(0, rv) + self.assertEqual(0, rv) self.assertEqual(self.expected_results[test_name], output) def test_milestone_add_utf8_ok(self): @@ -879,9 +921,8 @@ """ test_name = sys._getframe().f_code.co_name rv, output = self._execute('milestone add milestone1 "%s"' - % self._test_date, - expect_exception=True) - self.assertEqual(-1, rv) + % self._test_date) + self.assertEqual(2, rv) self.assertEqual(self.expected_results[test_name], output) def test_milestone_rename_ok(self): @@ -994,6 +1035,181 @@ self.assertEqual(0, rv) self.assertEqual(self.expected_results[test_name], output) + def test_session_list_no_sessions(self): + test_name = sys._getframe().f_code.co_name + rv, output = self._execute('session list authenticated') + self.assertEqual(0, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_list_authenticated(self): + test_name = sys._getframe().f_code.co_name + _prep_session_table(self.env.get_db_cnx()) + rv, output = self._execute('session list authenticated') + self.assertEqual(0, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_list_anonymous(self): + test_name = sys._getframe().f_code.co_name + _prep_session_table(self.env.get_db_cnx()) + rv, output = self._execute('session list anonymous') + self.assertEqual(0, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_list_all(self): + test_name = sys._getframe().f_code.co_name + _prep_session_table(self.env.get_db_cnx()) + if self._admin.interactive: + rv, output = self._execute("session list *") + else: + rv, output = self._execute("session list '*'") + self.assertEqual(0, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_list_authenticated_sid(self): + test_name = sys._getframe().f_code.co_name + _prep_session_table(self.env.get_db_cnx()) + rv, output = self._execute('session list name00') + self.assertEqual(0, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_list_anonymous_sid(self): + test_name = sys._getframe().f_code.co_name + _prep_session_table(self.env.get_db_cnx()) + rv, output = self._execute('session list name10') + self.assertEqual(0, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_list_missing_sid(self): + test_name = sys._getframe().f_code.co_name + _prep_session_table(self.env.get_db_cnx()) + rv, output = self._execute('session list thisdoesntexist') + self.assertEqual(0, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_add_missing_sid(self): + test_name = sys._getframe().f_code.co_name + rv, output = self._execute('session add') + self.assertEqual(2, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_add_duplicate_sid(self): + test_name = sys._getframe().f_code.co_name + _prep_session_table(self.env.get_db_cnx()) + rv, output = self._execute('session add name00') + self.assertEqual(2, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_add_sid_all(self): + test_name = sys._getframe().f_code.co_name + rv, output = self._execute('session add john John john@example.org') + self.assertEqual(0, rv) + rv, output = self._execute('session list john') + self.assertEqual(self.expected_results[test_name], output) + + def test_session_add_sid(self): + test_name = sys._getframe().f_code.co_name + rv, output = self._execute('session add john') + self.assertEqual(0, rv) + rv, output = self._execute('session list john') + self.assertEqual(self.expected_results[test_name], output) + + def test_session_add_sid_name(self): + test_name = sys._getframe().f_code.co_name + rv, output = self._execute('session add john John') + self.assertEqual(0, rv) + rv, output = self._execute('session list john') + self.assertEqual(self.expected_results[test_name], output) + + def test_session_set_attr_name(self): + test_name = sys._getframe().f_code.co_name + self._execute('session add john John john@example.org') + rv, output = self._execute('session set name john JOHN') + self.assertEqual(0, rv) + rv, output = self._execute('session list john') + self.assertEqual(self.expected_results[test_name], output) + + def test_session_set_attr_email(self): + test_name = sys._getframe().f_code.co_name + self._execute('session add john John john@example.org') + rv, output = self._execute('session set email john JOHN@EXAMPLE.ORG') + self.assertEqual(0, rv) + rv, output = self._execute('session list john') + self.assertEqual(self.expected_results[test_name], output) + + def test_session_set_attr_missing_attr(self): + test_name = sys._getframe().f_code.co_name + rv, output = self._execute('session set') + self.assertEqual(2, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_set_attr_missing_value(self): + test_name = sys._getframe().f_code.co_name + rv, output = self._execute('session set name john') + self.assertEqual(2, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_set_attr_missing_sid(self): + test_name = sys._getframe().f_code.co_name + rv, output = self._execute('session set name') + self.assertEqual(2, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_set_attr_nonexistent_sid(self): + test_name = sys._getframe().f_code.co_name + rv, output = self._execute('session set name john foo') + self.assertEqual(2, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_delete_sid(self): + test_name = sys._getframe().f_code.co_name + _prep_session_table(self.env.get_db_cnx()) + rv, output = self._execute('session delete name00') + self.assertEqual(0, rv) + rv, output = self._execute('session list nam00') + self.assertEqual(self.expected_results[test_name], output) + + def test_session_delete_missing_params(self): + test_name = sys._getframe().f_code.co_name + rv, output = self._execute('session delete') + self.assertEqual(0, rv) + self.assertEqual(self.expected_results[test_name], output) + + def test_session_delete_anonymous(self): + test_name = sys._getframe().f_code.co_name + _prep_session_table(self.env.get_db_cnx()) + rv, output = self._execute('session delete anonymous') + self.assertEqual(0, rv) + rv, output = self._execute('session list *') + self.assertEqual(self.expected_results[test_name], output) + + def test_session_delete_multiple_sids(self): + test_name = sys._getframe().f_code.co_name + _prep_session_table(self.env.get_db_cnx()) + rv, output = self._execute('session delete name00 name01 name02 ' + 'name03') + self.assertEqual(0, rv) + rv, output = self._execute('session list *') + self.assertEqual(self.expected_results[test_name], output) + + def test_session_delete_all(self): + test_name = sys._getframe().f_code.co_name + _prep_session_table(self.env.get_db_cnx()) + if self._admin.interactive: + rv, output = self._execute("session delete *") + else: + rv, output = self._execute("session delete '*'") + self.assertEqual(0, rv) + rv, output = self._execute('session list *') + self.assertEqual(self.expected_results[test_name], output) + + def test_session_purge_age(self): + test_name = sys._getframe().f_code.co_name + _prep_session_table(self.env.get_db_cnx(), spread_visits=True) + rv, output = self._execute('session purge 20100112') + self.assertEqual(0, rv) + rv, output = self._execute('session list *') + self.assertEqual(self.expected_results[test_name], output) + def suite(): return unittest.makeSuite(TracadminTestCase, 'test') diff -Nru trac-0.11.7/trac/admin/tests/console-tests.txt trac-0.12.1~ppa2/trac/admin/tests/console-tests.txt --- trac-0.11.7/trac/admin/tests/console-tests.txt 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/admin/tests/console-tests.txt 2010-04-23 09:36:58.000000000 +0100 @@ -4,171 +4,91 @@ Usage: trac-admin [command [subcommand] [option ...]] Invoking trac-admin without command starts interactive mode. -help - -- Show documentation - -initenv - -- Create and initialize a new environment interactively - -initenv - -- Create and initialize a new environment from arguments - -hotcopy - -- Make a hot backup copy of an environment - -resync - -- Re-synchronize trac with the repository - -resync - -- Re-synchronize only the given - -upgrade - -- Upgrade database to current version - -deploy - -- Extract static resources from Trac and all plugins. - -permission list [user] - -- List permission rules - -permission add [action] [...] - -- Add a new permission rule - -permission remove [action] [...] - -- Remove permission rule - -wiki list - -- List wiki pages - -wiki remove - -- Remove wiki page - -wiki export [file] - -- Export wiki page to file or stdout - -wiki import [file] - -- Import wiki page from file or stdin - -wiki dump - -- Export all wiki pages to files named by title - -wiki load - -- Import all wiki pages from directory - -wiki upgrade - -- Upgrade default wiki pages to current version - -ticket remove - -- Remove ticket - -ticket_type list - -- Show possible ticket types - -ticket_type add - -- Add a ticket type - -ticket_type change - -- Change a ticket type - -ticket_type remove - -- Remove a ticket type - -ticket_type order up|down - -- Move a ticket type up or down in the list - -priority list - -- Show possible ticket priorities - -priority add - -- Add a priority value option - -priority change - -- Change a priority value - -priority remove - -- Remove priority value - -priority order up|down - -- Move a priority value up or down in the list - -severity list - -- Show possible ticket severities - -severity add - -- Add a severity value option - -severity change - -- Change a severity value - -severity remove - -- Remove severity value - -severity order up|down - -- Move a severity value up or down in the list - -component list - -- Show available components - -component add - -- Add a new component - -component rename - -- Rename a component - -component remove - -- Remove/uninstall component - -component chown - -- Change component ownership - -version list - -- Show versions - -version add [time] - -- Add version - -version rename - -- Rename version - -version time

' % (self.name) @@ -319,14 +351,17 @@ key_str = _to_utf8(key) if self.config.parser.has_option(name_str, key_str): value = self.config.parser.get(name_str, key_str) - elif self.config.parent: - value = self.config.parent[self.name].get(key, default) else: - option = Option.registry.get((self.name, key)) - if option: - value = option.default or _use_default + for parent in self.config.parents: + value = parent[self.name].get(key, _use_default) + if value is not _use_default: + break else: - value = _use_default + if default is not _use_default: + option = Option.registry.get((self.name, key)) + value = option and option.default or _use_default + else: + value = _use_default if value is _use_default: return default if not value: @@ -367,6 +402,24 @@ _('[%(section)s] %(entry)s: expected integer, got %(value)s', section=self.name, entry=key, value=repr(value))) + def getfloat(self, key, default=''): + """Return the value of the specified option as float. + + If the specified option can not be converted to a float, a + `ConfigurationError` exception is raised. + + Valid default input is a string, float or int. Returns a float. + """ + value = self.get(key, default) + if not value: + return 0.0 + try: + return float(value) + except ValueError: + raise ConfigurationError( + _('[%(section)s] %(entry)s: expected float, got %(value)s', + section=self.name, entry=key, value=repr(value))) + def getlist(self, key, default='', sep=',', keep_empty=True): """Return a list of values that have been specified as a single comma-separated option. @@ -389,34 +442,26 @@ return items def getpath(self, key, default=''): - """Return the value of the specified option as a path name, relative to - the location of the configuration file the option is defined in. + """Return the value of the specified option as a path, relative to + the location of this configuration file. - Valid default input is a string. Returns a string with normalised path. + Valid default input is a string. Returns a normalized path. """ - name_str = _to_utf8(self.name) - key_str = _to_utf8(key) - if self.config.parser.has_option(name_str, key_str): - path = to_unicode(self.config.parser.get(name_str, key_str)) - if not path: - return default - if not os.path.isabs(path): - path = os.path.join(os.path.dirname(self.config.filename), - path) - return os.path.normcase(os.path.realpath(path)) - elif self.config.parent: - return self.config.parent[self.name].getpath(key, default) - else: - base = self.config._base_filename or self.config.filename - path_opt = Option.registry.get((self.name, key), None) - path = path_opt and path_opt.default or default - if path and not os.path.isabs(path): - path = os.path.join(os.path.dirname(base), path) - return path - - def options(self): - """Return `(key, value)` tuples for every option in the section.""" - for key in self: + path = self.get(key, default) + if not path: + return default + if not os.path.isabs(path): + path = os.path.join(os.path.dirname(self.config.filename), path) + return os.path.normcase(os.path.realpath(path)) + + def options(self, compmgr=None): + """Return `(key, value)` tuples for every option in the section. + + This includes options that have default values that haven't been + overridden. If `compmgr` is specified, only return default option + values for components that are enabled in the given `ComponentManager`. + """ + for key in self.iterate(compmgr): yield key, self.get(key) def set(self, key, value): @@ -453,8 +498,30 @@ registry = {} accessor = Section.get + @staticmethod + def get_registry(compmgr=None): + """Return the option registry, as a `dict` mapping `(section, key)` + tuples to `Option` objects. + + If `compmgr` is specified, only return options for components that are + enabled in the given `ComponentManager`. + """ + if compmgr is None: + return Option.registry + + from trac.core import ComponentMeta + components = {} + for cls in ComponentMeta._components: + for attr in cls.__dict__.itervalues(): + if isinstance(attr, Option): + components[attr] = cls + + return dict(each for each in Option.registry.items() + if each[1] not in components + or compmgr.is_enabled(components[each[1]])) + def __init__(self, section, name, default=None, doc=''): - """Create the extension point. + """Create the configuration option. @param section: the name of the configuration section this option belongs to @@ -496,9 +563,15 @@ accessor = Section.getint +class FloatOption(Option): + """Descriptor for float configuration options.""" + accessor = Section.getfloat + + class ListOption(Option): """Descriptor for configuration options that contain multiple values - separated by a specific character.""" + separated by a specific character. + """ def __init__(self, section, name, default=None, sep=',', keep_empty=False, doc=''): @@ -509,6 +582,30 @@ def accessor(self, section, name, default): return section.getlist(name, default, self.sep, self.keep_empty) + +class ChoiceOption(Option): + """Descriptor for configuration options providing a choice among a list + of items. + + The default value is the first choice in the list. + """ + + def __init__(self, section, name, choices, doc=''): + Option.__init__(self, section, name, _to_utf8(choices[0]), doc) + self.choices = set(_to_utf8(choice).strip() for choice in choices) + + def accessor(self, section, name, default): + value = section.get(name, default) + if value not in self.choices: + raise ConfigurationError( + _('[%(section)s] %(entry)s: expected one of ' + '(%(choices)s), got %(value)s', + section=section.name, entry=name, value=repr(value), + choices=', '.join('"%s"' % c + for c in sorted(self.choices)))) + return value + + class PathOption(Option): """Descriptor for file system path configuration options.""" accessor = Section.getpath @@ -565,3 +662,43 @@ return cmp(order.index(x), order.index(y)) components.sort(compare) return components + + +class ConfigurationAdmin(Component): + """trac-admin command provider for trac.ini administration.""" + + implements(IAdminCommandProvider) + + # IAdminCommandProvider methods + + def get_admin_commands(self): + yield ('config get', '
- -

There was an internal error in Trac. It is recommended - that you inform your local - Trac - administrator and give him all the information he needs to - reproduce the issue. + +

There was an internal error in Trac. + It is recommended that you notify your local + + Trac administrator with the information needed to + reproduce the issue.

-

To that end, you could ${create_ticket()} a ticket.

+

To that end, you could ${create_ticket()} a ticket.

The action that triggered the error was:

${req.method}: ${req.path_info}
@@ -118,28 +126,36 @@

This is probably a local installation issue. - + You should ${create_ticket()} a ticket at the admin Trac to report the issue. - +

Found a bug in Trac?

If you think this should work and you can reproduce the problem, - you should consider reporting this to the Trac team.

-

Before you do that, though, please first try - searching + you should consider creating a bug report.

+

+ + Note that the ${faulty_plugins[0].name} plugin seems to be involved. + + + Note that the following plugins seem to be involved: + ${', '.join([p.name for p in faulty_plugins])} + + Please report this issue to the plugin maintainer. +

+

Before you do that, though, please first try + searching for similar issues, as it is quite likely that this problem has been reported before. For questions about installation - and configuration of Trac, please try the + and configuration of Trac or its plugins, please try the mailing list - instead of filing a ticket. + instead of creating a ticket.

-
-

Otherwise, please ${create_ticket(True)} a new ticket at - the Trac project site, where you can describe the problem and - explain how to reproduce it.

+ +

Otherwise, please ${create_ticket(tracker)} a new bug report + describing the problem and explain how to reproduce it.

Python Traceback

@@ -148,17 +164,21 @@ -
File "${frame.filename}", line ${frame.lineno + 1}, in ${frame.function}
+                  
File "${frame.filename}", line ${frame.lineno + 1}, in ${frame.function}
   ${frame.line.lstrip()}
 ${traceback}
-

+

System Information:

- - + +
$name:
$name $value
+ +

Enabled Plugins:

+ + + + + + +
+ $plugin.name + ${plugin.version or _('N/A')}$plugin.path
+
diff -Nru trac-0.11.7/trac/templates/history_view.html trac-0.12.1~ppa2/trac/templates/history_view.html --- trac-0.11.7/trac/templates/history_view.html 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/templates/history_view.html 2010-05-01 17:01:31.000000000 +0100 @@ -3,21 +3,23 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> + xmlns:xi="http://www.w3.org/2001/XInclude" + xmlns:i18n="http://genshi.edgewall.org/i18n"> - $title +
-

Change History for ${name_of(resource)}

+

Change History for ${name or name_of(resource)}

- - + + +
@@ -38,17 +40,19 @@ checked="${idx == 0 or None}" /> - +
- $item.version + $item.version ${dateinfo(item.date)}${authorinfo(item.author)}${authorinfo(item.author)} ${wiki_to_oneliner(context(resource), item.comment, shorten=True)}
- +
diff -Nru trac-0.11.7/trac/templates/layout.html trac-0.12.1~ppa2/trac/templates/layout.html --- trac-0.11.7/trac/templates/layout.html 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/templates/layout.html 2010-03-07 09:14:01.000000000 +0000 @@ -10,15 +10,23 @@ <py:if test="title">${title} – </py:if>${project.name or 'Trac'} + + - + + href="${href.search('opensearch')}" + title="${_('Search %(project)s', project=project.name)}"/> + ${Markup('<!--[if lt IE 7]>')} diff -Nru trac-0.11.7/trac/templates/list_of_attachments.html trac-0.12.1~ppa2/trac/templates/list_of_attachments.html --- trac-0.11.7/trac/templates/list_of_attachments.html 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/trac/templates/list_of_attachments.html 2010-03-07 09:14:01.000000000 +0000 @@ -0,0 +1,55 @@ + + + + + $attachment.filename + Download + (${pretty_size(attachment.size)}) - + added by ${authorinfo(attachment.author)} ${dateinfo(attachment.date)} ago. + + + +
+ +

Attachments

+
    + +
  • + ${show_one_attachment(attachment)} + ${wiki_to_oneliner(context, attachment.description)} +
  • +
    +
+
+ +

Attachments

+
+
+ +
${show_one_attachment(attachment)}
+
+ ${wiki_to_oneliner(context, attachment.description)} +
+
+
+ +
+
+
+
+ diff -Nru trac-0.11.7/trac/templates/macros.html trac-0.12.1~ppa2/trac/templates/macros.html --- trac-0.11.7/trac/templates/macros.html 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/templates/macros.html 2010-03-07 09:14:01.000000000 +0000 @@ -1,61 +1,25 @@
+ xmlns:py="http://genshi.edgewall.org/" + xmlns:xi="http://www.w3.org/2001/XInclude" + xmlns:i18n="http://genshi.edgewall.org/i18n" + py:strip=""> + + - - ${cnt == 1 and ('1 '+noun) or '%d %ss' % (cnt, noun)} - - ${ + ${ pretty_size(size) } - - ${ - author and format_author(author) or 'anonymous' - }anonymous - - - - $part.name/ - @ - $rev - -
-
- - - - -
- Show - -
-
- Ignore: -
- - -
-
- - -
-
- - -
-
-
- -
-
- ${preview.rendered} - -

- (The file is empty) -

-

- HTML preview not available, - - - since the file size exceeds $preview.max_file_size bytes. - - - since no preview renderer could handle it. - - - Try downloading the file instead. -

- -

- HTML preview not available. - To view, download the file. -

-

${plural(len(preview.errors), 'issue')} found:

-
- ${renderer.__class__.__name__} -
$err
-
-
-
+
- - - $attachment.filename - Download - (${sizeinfo(attachment.size)}) - added by ${authorinfo(attachment.author)} - ${dateinfo(attachment.date)} ago. - - - - -

Attachments

-
    - -
  • - ${show_one_attachment(attachment)} - ${wiki_to_oneliner(context, attachment.description)} -
  • -
    -
-
- -

Attachments

-
-
- -
${show_one_attachment(attachment)}
-
- ${wiki_to_oneliner(context, attachment.description)} -
-
-
- ${attach_file_form(alist, add_button_title)} -
-
-
-
+ + -
-
- - -
-
+
- - - - -
- - -
-

${percent is None and '%d%%' % stats.done_percent or percent}

-
- -
- ${interval.title.capitalize()} ${stats.unit}s: - ${interval.title.capitalize()} ${stats.unit}s: -
-
- ${interval.count} - ${interval.count} -
-
-
/ Total ${stats.unit}s:
-
${sum([x.count for x in stats.intervals], 0)}
-
-
+ +
diff -Nru trac-0.11.7/trac/templates/macros.rss trac-0.12.1~ppa2/trac/templates/macros.rss --- trac-0.11.7/trac/templates/macros.rss 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/templates/macros.rss 2010-02-24 01:25:29.000000000 +0000 @@ -1,5 +1,6 @@ - - - - - ${format_author(author)} - ${format_author(author)} - - - + diff -Nru trac-0.11.7/trac/templates/preview_file.html trac-0.12.1~ppa2/trac/templates/preview_file.html --- trac-0.11.7/trac/templates/preview_file.html 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/trac/templates/preview_file.html 2010-05-01 17:01:31.000000000 +0100 @@ -0,0 +1,29 @@ + + + ${preview.rendered} + +

+ (The file is empty) +

+

+ + + HTML preview not available, since the file size exceeds $preview.max_file_size bytes. + + + HTML preview not available, since no preview renderer could handle it. + + + Try downloading the file instead. +

+
+ diff -Nru trac-0.11.7/trac/templates/progress_bar.html trac-0.12.1~ppa2/trac/templates/progress_bar.html --- trac-0.11.7/trac/templates/progress_bar.html 1970-01-01 01:00:00.000000000 +0100 +++ trac-0.12.1~ppa2/trac/templates/progress_bar.html 2010-04-20 22:17:52.000000000 +0100 @@ -0,0 +1,53 @@ + + + + + + + +
+ +
+ +

${percent is None and '%d%%' % stats.done_percent or percent}

+ +
+
Number of ${stats.unit}:
+ + + + +
${interval.title}:
+
${interval.count}
+ + + + + +
Total:
+
${stats.count}
+
+ +
+ diff -Nru trac-0.11.7/trac/templates/theme.html trac-0.12.1~ppa2/trac/templates/theme.html --- trac-0.11.7/trac/templates/theme.html 2010-03-09 22:49:38.000000000 +0000 +++ trac-0.12.1~ppa2/trac/templates/theme.html 2010-03-22 21:58:31.000000000 +0000 @@ -22,10 +22,10 @@

${project.name}