Apply patches from j@oil21.org, Ben Finney, Jelmer Vernooij.
authorChris Ball <cjb@laptop.org>
Fri, 16 May 2008 19:20:54 +0000 (15:20 -0400)
committerChris Ball <cjb@laptop.org>
Fri, 16 May 2008 19:20:54 +0000 (15:20 -0400)
15 files changed:
1  2  3  4 
.be/bugs/00f26f04-9202-4288-8744-b29abc2342d6/comments/4be73baf-e46b-4acb-a58e-4719e57c550b/body
.be/bugs/00f26f04-9202-4288-8744-b29abc2342d6/comments/4be73baf-e46b-4acb-a58e-4719e57c550b/values
.be/bugs/00f26f04-9202-4288-8744-b29abc2342d6/values
.be/bugs/b187fbce-fb10-4819-ace2-c8b0b4a45c57/comments/e757d2ae-085a-4539-99be-096386de5352/body
.be/bugs/b187fbce-fb10-4819-ace2-c8b0b4a45c57/comments/e757d2ae-085a-4539-99be-096386de5352/values
.be/bugs/b187fbce-fb10-4819-ace2-c8b0b4a45c57/values
.bzrignore
Bugs-Everywhere-Web/beweb/config/app.cfg
Bugs-Everywhere-Web/beweb/controllers.py
Bugs-Everywhere-Web/beweb/templates/about.kid
Bugs-Everywhere-Web/libbe
Makefile
doc/be.1.sgml
doc/module.mk
setup.py

index 0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000..ff42ab3c896b6e7922f7f752e9031a245eb73b4e
new file mode 100644 (file)
--- /dev/null
--- /dev/null
--- /dev/null
--- /dev/null
@@@@@ -1,0 -1,0 -1,0 -1,0 +1,8 @@@@@
++++The FSF offices are no longer at Temple Place, and there is a revised
++++text of the GPLv2 giving the correct address and other textual
++++clean-ups. 
++++
++++The COPYING file should be updated to the new GPLv2 text, and the
++++copyright notices throughout the working tree should be updated for
++++the new boilerplate how-to-use-the-GPL text. 
++++
index 0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000..a68a21d2206679d9bfc9a8dbf0442afa55370500
new file mode 100644 (file)
--- /dev/null
--- /dev/null
--- /dev/null
--- /dev/null
@@@@@ -1,0 -1,0 -1,0 -1,0 +1,21 @@@@@
++++
++++
++++
++++Content-type=text/plain
++++
++++
++++
++++
++++
++++
++++Date=Fri, 18 Apr 2008 11:21:03 +0000
++++
++++
++++
++++
++++
++++
++++From=benf
++++
++++
++++
index 0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000..05961db0645330f000c3b9aba4a15d9d3e2eae15
new file mode 100644 (file)
--- /dev/null
--- /dev/null
--- /dev/null
--- /dev/null
@@@@@ -1,0 -1,0 -1,0 -1,0 +1,42 @@@@@
++++
++++
++++
++++assigned=Ben Finney <ben+python@benfinney.id.au>
++++
++++
++++
++++
++++
++++
++++creator=benf
++++
++++
++++
++++
++++
++++
++++severity=minor
++++
++++
++++
++++
++++
++++
++++status=closed
++++
++++
++++
++++
++++
++++
++++summary=Address is outdated for FSF offices
++++
++++
++++
++++
++++
++++
++++time=Fri, 18 Apr 2008 11:18:58 +0000
++++
++++
++++
index 0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000..0dedcdd10a20c1741cc38342b3dbaf896b9bdb41
new file mode 100644 (file)
--- /dev/null
--- /dev/null
--- /dev/null
--- /dev/null
@@@@@ -1,0 -1,0 -1,0 -1,0 +1,3 @@@@@
++++The 'be' command should have a Unix manpage, describing it like any
++++other command on the system. 
++++
index 0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000..b7b289e18f11620ca0988edf5b46d2585fc5b29c
new file mode 100644 (file)
--- /dev/null
--- /dev/null
--- /dev/null
--- /dev/null
@@@@@ -1,0 -1,0 -1,0 -1,0 +1,21 @@@@@
++++
++++
++++
++++Content-type=text/plain
++++
++++
++++
++++
++++
++++
++++Date=Mon, 21 Apr 2008 03:24:11 +0000
++++
++++
++++
++++
++++
++++
++++From=benf
++++
++++
++++
index 0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000..ff8a30af5966522399433047854cc827f22e1320
new file mode 100644 (file)
--- /dev/null
--- /dev/null
--- /dev/null
--- /dev/null
@@@@@ -1,0 -1,0 -1,0 -1,0 +1,42 @@@@@
++++
++++
++++
++++assigned=benf
++++
++++
++++
++++
++++
++++
++++creator=benf
++++
++++
++++
++++
++++
++++
++++severity=minor
++++
++++
++++
++++
++++
++++
++++status=closed
++++
++++
++++
++++
++++
++++
++++summary=Manual page for 'be' command
++++
++++
++++
++++
++++
++++
++++time=Mon, 21 Apr 2008 03:21:35 +0000
++++
++++
++++
diff --cc .bzrignore
index a0515507a21e876835d6e19fb1a34c233cfbf5e8,a0515507a21e876835d6e19fb1a34c233cfbf5e8,a0515507a21e876835d6e19fb1a34c233cfbf5e8,a0515507a21e876835d6e19fb1a34c233cfbf5e8..c0fddb17ad19a21fb587757dda6784eb3ea40b18
@@@@@ -8,3 -8,3 -8,3 -8,3 +8,4 @@@@@ fte.ds
    *~
    ./.shelf
    Bugs-Everywhere-Web/devdata.sqlite
++++./doc/*.1
index d37cf67019708e7c9fbb950d0608cb741e26f5da,d37cf67019708e7c9fbb950d0608cb741e26f5da,d37cf67019708e7c9fbb950d0608cb741e26f5da,d37cf67019708e7c9fbb950d0608cb741e26f5da..15555b7a7c3ad109d430ac054246cb47dc50ee4c
    # Set to True if the scheduler should be started
    # tg.scheduler = False
    
++++# IDENTITY
++++# General configuration of the TurboGears Identity management module
++++# --------
++++
++++# Switch to turn on or off the Identity management module
++++identity.on=True
++++
++++# [REQUIRED] URL to which CherryPy will internally redirect when an access
++++# control check fails. If Identity management is turned on, a value for this
++++# option must be specified.
++++identity.failure_url="/login"
++++
++++# identity.provider='sqlobject'
++++
++++# The names of the fields on the login form containing the visitor's user ID
++++# and password. In addition, the submit button is specified simply so its
++++# existence may be stripped out prior to passing the form data to the target
++++# controller.
++++# identity.form.user_name="user_name"
++++# identity.form.password="password"
++++# identity.form.submit="login"
++++
++++# What sources should the identity provider consider when determining the
++++# identity associated with a request? Comma separated list of identity sources.
++++# Valid sources: form, visit, http_auth
++++# identity.source="form,http_auth,visit"
++++
++++# SqlObjectIdentityProvider
++++# Configuration options for the default IdentityProvider
++++# -------------------------
++++
++++# The classes you wish to use for your Identity model. Remember to not use reserved
++++# SQL keywords for class names (at least unless you specify a different table
++++# name using sqlmeta).
++++identity.soprovider.model.user="stfa.model.User"
++++identity.soprovider.model.group="stfa.model.Group"
++++identity.soprovider.model.permission="stfa.model.Permission"
++++
++++# The password encryption algorithm used when comparing passwords against what's
++++# stored in the database. Valid values are 'md5' or 'sha1'. If you do not
++++# specify an encryption algorithm, passwords are expected to be clear text.
++++# The SqlObjectProvider *will* encrypt passwords supplied as part of your login
++++# form.  If you set the password through the password property, like:
++++# my_user.password = 'secret'
++++# the password will be encrypted in the database, provided identity is up and
++++# running, or you have loaded the configuration specifying what encryption to
++++# use (in situations where identity may not yet be running, like tests).
++++
++++# identity.soprovider.encryption_algorithm=None
++++
    [/static]
    static_filter.on = True
    static_filter.dir = "%(top_level_dir)s/static"
index 358e74ad220107c3d22c0d67433e207cc4d4f277,358e74ad220107c3d22c0d67433e207cc4d4f277,358e74ad220107c3d22c0d67433e207cc4d4f277,358e74ad220107c3d22c0d67433e207cc4d4f277..8def76c8fb770870f6f89b6cba3fd6b4ac2f4693
@@@@@ -26,6 -26,6 -26,6 -26,6 +26,7 @@@@@ def comment_url(project, bug, comment, 
                              (project, bug, comment), kwargs)
    
    class Comment(PrestHandler):
++++    @identity.require( identity.has_permission("editbugs"))
        @provide_action("action", "New comment")
        def new_comment(self, comment_data, comment, *args, **kwargs):
            bug_tree = project_tree(comment_data['project'])
            raise cherrypy.HTTPRedirect(comment_url(comment=comment.uuid, 
                                        **comment_data))
    
++++    @identity.require( identity.has_permission("editbugs"))
        @provide_action("action", "Reply")
        def reply_comment(self, comment_data, comment, *args, **kwargs):
            bug_tree = project_tree(comment_data['project'])
index 45d00937b70a4054e9f46ee8ae70889485889039,45d00937b70a4054e9f46ee8ae70889485889039,45d00937b70a4054e9f46ee8ae70889485889039,45d00937b70a4054e9f46ee8ae70889485889039..fa3548af280e9a7e47a52ae088ea3d4b407522bb
    
    <body>
    <h1>About Bugs Everywhere</h1>
----<p>Bug Everywhere was designed by Aaron Bentley and implemented by Aaron
----    Bentley and Oleg Romanyshyn.
++++<p>Bugs Everywhere is a "distributed bugtracker", designed to complement distributed revision control systems.
    </p>
    <p>
----    Development is sponsored by 
----    <a href="http://panoramicfeedback.com/">Panoramic Feedback</a>.
++++Bugs Everywhere was conceived and written by developers at <a href="http://panoramicfeedback.com/">Panoramic Feedback</a>, primarily Aaron Bentley. <a href="http://panoramicfeedback.com/">Panoramic Feedback</a> is no longer developing BE, and the current maintainer is <a href="http://bugseverywhere.org/be/show/ChrisBall">Chris Ball</a>.
    </p>
    <p>
----    Bugs Everywhere <a href="http://panoramicfeedback.com/opensource">web site</a>
++++    Bugs Everywhere <a href="http://bugseverywhere.org/">web site</a>
    </p>
    <a href="/">Project List</a>
    </body>
index 6081eee6219546ac41f63b619a5508189ac32bd5,6081eee6219546ac41f63b619a5508189ac32bd5,6081eee6219546ac41f63b619a5508189ac32bd5,6081eee6219546ac41f63b619a5508189ac32bd5..4e5e17e1906da5af676d1f5073a784a1daa591e8
@@@@@ -1,1 -1,1 -1,1 -1,1 +1,1 @@@@@
----../libbe/
++++../libbe
diff --cc Makefile
index 0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,c1e6571ee202a6001e4bd9339957c30e610c4ea9..47fbbfdcdd4b6b38f47855f839522602ac8938bb
mode 000000,000000,000000,100644..100644
--- /dev/null
--- /dev/null
--- /dev/null
+++ b/Makefile
@@@@@ -1,0 -1,0 -1,0 -1,27 +1,47 @@@@@
   -# -*- makefile; coding: utf-8 -*-
+++ #! /usr/bin/make -f
   -# No warranty expressed or implied. See the file LICENSE for details.
++++# :vim: filetype=make : -*- makefile; coding: utf-8; -*-
+++ 
+++ # Makefile
+++ # Part of Bugs Everywhere, a distributed bug tracking system.
+++ #
+++ # Copyright © 2008 Ben Finney <ben+python@benfinney.id.au>
+++ # This is free software; you may copy, modify and/or distribute this work
+++ # under the terms of the GNU General Public License, version 2 or later.
++++# No warranty expressed or implied. See the file COPYING for details.
+++ 
+++ # Makefile for Bugs Everywhere project
+++ 
+++ SHELL = /bin/bash
+++ PATH = /usr/bin:/bin
+++ 
++++# Directories with semantic meaning
++++DOC_DIR := doc
++++
+++ # Variables that will be extended by module include files
+++ GENERATED_FILES :=
+++ CODE_MODULES :=
+++ CODE_PROGRAMS :=
+++ 
++++# List of modules (directories) that comprise our 'make' project
++++MODULES += ${DOC_DIR}
++++
+++ RM = rm
+++ 
++++\f
++++.PHONY: all
++++all: build
++++
++++# Include the make data for each module
++++include $(patsubst %,%/module.mk,${MODULES})
++++
++++\f
++++.PHONY: build
++++build:
++++
++++.PHONY: install
++++install:
++++
+++ \f
+++ .PHONY: clean
+++ clean:
+++     $(RM) -rf ${GENERATED_FILES}
diff --cc doc/be.1.sgml
index 0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000..5e6efc3c84aa5d5629795143439ab8e376df42a4
new file mode 100644 (file)
--- /dev/null
--- /dev/null
--- /dev/null
--- /dev/null
@@@@@ -1,0 -1,0 -1,0 -1,0 +1,247 @@@@@
++++<!doctype refentry PUBLIC "-//OASIS//DTD DocBook V4.1//EN" [
++++
++++<!-- Process this file with docbook-to-man to generate an nroff manual
++++     page: `docbook-to-man manpage.sgml > manpage.1'.  You may view
++++     the manual page with: `docbook-to-man manpage.sgml | nroff -man |
++++     less'.  A typical entry in a Makefile or Makefile.am is:
++++
++++be.1: be.1.sgml
++++    docbook-to-man $< > $@
++++
++++    The docbook-to-man binary is found in the docbook-to-man package.
++++    Please remember that if you create the nroff version in one of the
++++    debian/rules file targets (such as build), you will need to include
++++    docbook-to-man in your Build-Depends control field.
++++
++++  -->
++++
++++  <!ENTITY dhfirstname "<firstname>Ben</firstname>">
++++  <!ENTITY dhsurname   "<surname>Finney</surname>">
++++  <!-- Please adjust the date whenever revising the manpage. -->
++++  <!ENTITY dhdate      "<date>2008-04-21</date>">
++++  <!-- SECTION should be 1-8, maybe w/ subsection other parameters are
++++       allowed: see man(7), man(1). -->
++++  <!ENTITY dhsection   "<manvolnum>1</manvolnum>">
++++  <!ENTITY dhemail     "<email>ben+debian@benfinney.id.au</email>">
++++  <!ENTITY dhusername  "Ben Finney">
++++  <!ENTITY dhucpackage "<refentrytitle>BUGS-EVERYWHERE</refentrytitle>">
++++  <!ENTITY dhpackage   "bugs-everywhere">
++++  <!ENTITY pkgfullname "Bugs Everywhere">
++++  <!ENTITY uccmdname   "<refentrytitle>BE</refentrytitle>">
++++  <!ENTITY cmdname     "be">
++++
++++  <!ENTITY debian      "<productname>Debian</productname>">
++++  <!ENTITY gnu         "<acronym>GNU</acronym>">
++++  <!ENTITY gpl         "&gnu; <acronym>GPL</acronym>">
++++]>
++++
++++<refentry>
++++  <refentryinfo>
++++    <address>
++++      &dhemail;
++++    </address>
++++    <author>
++++      &dhfirstname;
++++      &dhsurname;
++++    </author>
++++    <copyright>
++++      <year>2008</year>
++++      <holder>&dhusername;</holder>
++++    </copyright>
++++    &dhdate;
++++  </refentryinfo>
++++  <refmeta>
++++    &uccmdname;
++++
++++    &dhsection;
++++  </refmeta>
++++  <refnamediv>
++++    <refname>&cmdname;</refname>
++++
++++    <refpurpose>distributed bug tracker</refpurpose>
++++  </refnamediv>
++++  <refsynopsisdiv>
++++    <cmdsynopsis>
++++      <command>&cmdname;</command>
++++      <arg><replaceable>command</replaceable></arg>
++++      <arg><replaceable>command_options ...</replaceable></arg>
++++      <arg><replaceable>command_args ...</replaceable></arg>
++++    </cmdsynopsis>
++++    <cmdsynopsis>
++++      <command>&cmdname; help</command>
++++    </cmdsynopsis>
++++    <cmdsynopsis>
++++      <command>&cmdname; help</command>
++++      <arg><replaceable>command</replaceable></arg>
++++    </cmdsynopsis>
++++  </refsynopsisdiv>
++++  <refsect1>
++++    <title>DESCRIPTION</title>
++++
++++    <para>This manual page documents briefly the
++++      <command>&cmdname;</command> command, part of the
++++      &pkgfullname; package.</para>
++++
++++    <para><command>&cmdname;</command> allows commandline interaction
++++      with the &pkgfullname; database in a project tree.</para>
++++
++++  </refsect1>
++++  <refsect1>
++++    <title>COMMANDS</title>
++++
++++    <variablelist>
++++      <varlistentry>
++++        <term><command>assign</command>
++++        </term>
++++        <listitem>
++++          <para>Assign an individual or group to fix a bug
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>close</command>
++++        </term>
++++        <listitem>
++++          <para>Close a bug
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>comment</command>
++++        </term>
++++        <listitem>
++++          <para>Add a comment to a bug
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>diff</command>
++++        </term>
++++        <listitem>
++++          <para>Compare bug reports with older tree
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>help</command>
++++        </term>
++++        <listitem>
++++          <para>Print help for given subcommand
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>inprogress</command>
++++        </term>
++++        <listitem>
++++          <para>Bug fixing in progress
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>list</command>
++++        </term>
++++        <listitem>
++++          <para>List bugs
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>new</command>
++++        </term>
++++        <listitem>
++++          <para>Create a new bug
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>open</command>
++++        </term>
++++        <listitem>
++++          <para>Re-open a bug
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>set</command>
++++        </term>
++++        <listitem>
++++          <para>Change tree settings
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>set-root</command>
++++        </term>
++++        <listitem>
++++          <para>Assign the root directory for bug tracking
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>severity</command>
++++        </term>
++++        <listitem>
++++          <para>Show or change a bug's severity level
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>show</command>
++++        </term>
++++        <listitem>
++++          <para>Show a particular bug
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>target</command>
++++        </term>
++++        <listitem>
++++          <para>Show or change a bug's target for fixing
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++      <varlistentry>
++++        <term><command>upgrade</command>
++++        </term>
++++        <listitem>
++++          <para>Upgrade the bugs to the latest format
++++          </para>
++++        </listitem>
++++      </varlistentry>
++++    </variablelist>
++++  </refsect1>
++++  <refsect1>
++++    <title>AUTHOR</title>
++++
++++    <para>This manual page was written by &dhusername; <&dhemail;> for
++++      the &debian; system (but may be used by others). Permission is
++++      granted to copy, distribute and/or modify this document under
++++      the terms of the &gnu; General Public License, Version 2 or any
++++      later version published by the Free Software Foundation.
++++    </para>
++++    <para>
++++      On Debian systems, the complete text of the GNU General Public
++++      License can be found in /usr/share/common-licenses/GPL.
++++    </para>
++++
++++  </refsect1>
++++</refentry>
++++
++++<!-- Keep this comment at the end of the file
++++Local variables:
++++mode: sgml
++++sgml-omittag:t
++++sgml-shorttag:t
++++sgml-minimize-attributes:nil
++++sgml-always-quote-attributes:t
++++sgml-indent-step:2
++++sgml-indent-data:t
++++sgml-parent-document:nil
++++sgml-default-dtd-file:nil
++++sgml-exposed-tags:nil
++++sgml-local-catalogs:nil
++++sgml-local-ecat-files:nil
++++End:
++++-->
diff --cc doc/module.mk
index 0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000,0000000000000000000000000000000000000000..1b365c84d8a6c44cb33f3abde96f05834f085df0
new file mode 100644 (file)
--- /dev/null
--- /dev/null
--- /dev/null
--- /dev/null
@@@@@ -1,0 -1,0 -1,0 -1,0 +1,31 @@@@@
++++# :vim: filetype=make : -*- makefile; coding: utf-8; -*-
++++
++++# doc/module.mk
++++# Part of Bugs Everywhere, a distributed bug tracking system.
++++#
++++# Copyright © 2008 Ben Finney <ben+python@benfinney.id.au>
++++# This is free software; you may copy, modify and/or distribute this work
++++# under the terms of the GNU General Public License, version 2 or later.
++++# No warranty expressed or implied. See the file COPYING for details.
++++
++++# Makefile module for documentation
++++
++++MODULE_DIR := doc
++++
++++MANPAGES = be.1
++++manpage_files = $(patsubst %,${MODULE_DIR}/%,${MANPAGES})
++++
++++GENERATED_FILES += ${manpage_files}
++++
++++\f
++++.PHONY: doc
++++doc: man
++++
++++build: doc
++++
++++\f
++++.PHONY: man
++++man: ${manpage_files}
++++
++++%.1: %.1.sgml
++++    docbook-to-man $< > $@
diff --cc setup.py
index 7c4c98a0e208ce80272bd2dca203a92861bfef55,7c4c98a0e208ce80272bd2dca203a92861bfef55,7c4c98a0e208ce80272bd2dca203a92861bfef55,7c4c98a0e208ce80272bd2dca203a92861bfef55..b909f3f75b37aab355c788aeb5c0f70b63f1a3e4
mode 100644,100644,100755,100644..100755
+++ b/setup.py
@@@@@ -9,4 -9,4 -9,4 -9,4 +9,7 @@@@@ setup
        url='http://panoramicfeedback.com/opensource/',
        packages=['becommands', 'libbe'],
        scripts=['be'],
++++    data_files=[
++++        ('share/man/man1', ['doc/be.1']),
++++        ]
        )