Remove dev and pydev directories which have been accidentially migrated from svn
This commit is contained in:
parent
0df30bf88b
commit
a5e6ac2fc4
@ -1,62 +0,0 @@
|
||||
##############################################################################
|
||||
#
|
||||
# Copyright (c) 2006 Zope Corporation and Contributors.
|
||||
# All Rights Reserved.
|
||||
#
|
||||
# This software is subject to the provisions of the Zope Public License,
|
||||
# Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution.
|
||||
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
|
||||
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
|
||||
# FOR A PARTICULAR PURPOSE.
|
||||
#
|
||||
##############################################################################
|
||||
"""Bootstrap a buildout-based project
|
||||
|
||||
Simply run this script in a directory containing a buildout.cfg.
|
||||
The script accepts buildout command-line options, so you can
|
||||
use the -c option to specify an alternate configuration file.
|
||||
|
||||
$Id: bootstrap.py 85041 2008-03-31 15:57:30Z andreasjung $
|
||||
"""
|
||||
|
||||
import os, shutil, sys, tempfile, urllib2
|
||||
|
||||
tmpeggs = tempfile.mkdtemp()
|
||||
|
||||
try:
|
||||
import pkg_resources
|
||||
except ImportError:
|
||||
ez = {}
|
||||
exec urllib2.urlopen('http://peak.telecommunity.com/dist/ez_setup.py'
|
||||
).read() in ez
|
||||
ez['use_setuptools'](to_dir=tmpeggs, download_delay=0)
|
||||
|
||||
import pkg_resources
|
||||
|
||||
if sys.platform == 'win32':
|
||||
def quote(c):
|
||||
if ' ' in c:
|
||||
return '"%s"' % c # work around spawn lamosity on windows
|
||||
else:
|
||||
return c
|
||||
else:
|
||||
def quote (c):
|
||||
return c
|
||||
|
||||
cmd = 'from setuptools.command.easy_install import main; main()'
|
||||
ws = pkg_resources.working_set
|
||||
assert os.spawnle(
|
||||
os.P_WAIT, sys.executable, quote (sys.executable),
|
||||
'-c', quote (cmd), '-mqNxd', quote (tmpeggs), 'zc.buildout',
|
||||
dict(os.environ,
|
||||
PYTHONPATH=
|
||||
ws.find(pkg_resources.Requirement.parse('setuptools')).location
|
||||
),
|
||||
) == 0
|
||||
|
||||
ws.add_entry(tmpeggs)
|
||||
ws.require('zc.buildout')
|
||||
import zc.buildout.buildout
|
||||
zc.buildout.buildout.main(sys.argv[1:] + ['bootstrap'])
|
||||
shutil.rmtree(tmpeggs)
|
@ -1,81 +0,0 @@
|
||||
[buildout]
|
||||
extensions = mr.developer buildout.dumppickedversions
|
||||
unzip = true
|
||||
parts = instance omelette zopepy test roadrunner
|
||||
extends =
|
||||
http://dist.plone.org/release/3.3.4/versions.cfg
|
||||
http://good-py.appspot.com/release/plone.app.discussion/1.0b4
|
||||
versions = versions
|
||||
sources = sources
|
||||
|
||||
develop =
|
||||
src/discussion.examplecontent
|
||||
src/plone.formwidget.captcha
|
||||
src/plone.formwidget.recaptcha
|
||||
src/collective.autoresizetextarea
|
||||
|
||||
auto-checkout =
|
||||
plone.app.discussion
|
||||
plone.formwidget.captcha
|
||||
plone.formwidget.recaptcha
|
||||
collective.autoresizetextarea
|
||||
|
||||
[zope2]
|
||||
recipe = plone.recipe.zope2install
|
||||
fake-zope-eggs = true
|
||||
additional-fake-eggs = ZODB3
|
||||
url = ${versions:zope2-url}
|
||||
|
||||
[instance]
|
||||
recipe = plone.recipe.zope2instance
|
||||
zope2-location = ${zope2:location}
|
||||
user = admin:admin
|
||||
http-address = 8080
|
||||
debug-mode = on
|
||||
verbose-security = on
|
||||
eggs =
|
||||
Plone
|
||||
plone.reload
|
||||
Products.PdbDebugMode
|
||||
plone.app.discussion
|
||||
plone.formwidget.captcha
|
||||
plone.formwidget.recaptcha
|
||||
collective.autoresizetextarea
|
||||
collective.autopermission
|
||||
|
||||
zcml =
|
||||
discussion.examplecontent
|
||||
plone.formwidget.captcha
|
||||
plone.formwidget.recaptcha
|
||||
collective.autoresizetextarea
|
||||
plone.reload
|
||||
|
||||
[omelette]
|
||||
recipe = collective.recipe.omelette
|
||||
eggs = ${instance:eggs}
|
||||
packages = ${zope2:location}/lib/python ./
|
||||
|
||||
[zopepy]
|
||||
recipe = zc.recipe.egg
|
||||
eggs = ${instance:eggs}
|
||||
interpreter = zopepy
|
||||
extra-paths = ${zope2:location}/lib/python
|
||||
scripts = zopepy
|
||||
|
||||
[test]
|
||||
recipe = collective.xmltestreport
|
||||
eggs = plone.app.discussion
|
||||
# other eggs in this list not shown
|
||||
extra-paths = ${zope2:location}/lib/python
|
||||
defaults = ['--exit-with-status', '--auto-color', '--auto-progress']
|
||||
|
||||
[roadrunner]
|
||||
recipe = roadrunner:plone
|
||||
zope2-instance = instance
|
||||
packages-under-test = plone.app.discussion
|
||||
|
||||
[sources]
|
||||
plone.app.discussion = svn https://svn.plone.org/svn/plone/plone.app.discussion/trunk
|
||||
plone.formwidget.captcha = svn https://svn.plone.org/svn/plone/plone.formwidget.captcha/trunk
|
||||
plone.formwidget.recaptcha = svn https://svn.plone.org/svn/plone/plone.formwidget.recaptcha/trunk
|
||||
collective.autoresizetextarea = svn https://svn.plone.org/svn/collective/collective.autoresizetextarea/trunk
|
@ -1,4 +0,0 @@
|
||||
Introduction
|
||||
============
|
||||
|
||||
|
@ -1,6 +0,0 @@
|
||||
# See http://peak.telecommunity.com/DevCenter/setuptools#namespace-packages
|
||||
try:
|
||||
__import__('pkg_resources').declare_namespace(__name__)
|
||||
except ImportError:
|
||||
from pkgutil import extend_path
|
||||
__path__ = extend_path(__path__, __name__)
|
@ -1,38 +0,0 @@
|
||||
import transaction
|
||||
from Products.CMFCore.utils import getToolByName
|
||||
|
||||
PRODUCT_DEPENDENCIES = ('plone.app.discussion',)
|
||||
|
||||
EXTENSION_PROFILES = ('discussion.examplecontent:default',)
|
||||
|
||||
def install(self, reinstall=False):
|
||||
"""Install a set of products (which themselves may either use Install.py
|
||||
or GenericSetup extension profiles for their configuration) and then
|
||||
install a set of extension profiles.
|
||||
|
||||
One of the extension profiles we install is that of this product. This
|
||||
works because an Install.py installation script (such as this one) takes
|
||||
precedence over extension profiles for the same product in
|
||||
portal_quickinstaller.
|
||||
|
||||
We do this because it is not possible to install other products during
|
||||
the execution of an extension profile (i.e. we cannot do this during
|
||||
the importVarious step for this profile).
|
||||
"""
|
||||
|
||||
portal_quickinstaller = getToolByName(self, 'portal_quickinstaller')
|
||||
portal_setup = getToolByName(self, 'portal_setup')
|
||||
|
||||
for product in PRODUCT_DEPENDENCIES:
|
||||
if reinstall and portal_quickinstaller.isProductInstalled(product):
|
||||
portal_quickinstaller.reinstallProducts([product])
|
||||
transaction.savepoint()
|
||||
elif not portal_quickinstaller.isProductInstalled(product):
|
||||
portal_quickinstaller.installProduct(product)
|
||||
transaction.savepoint()
|
||||
|
||||
for extension_id in EXTENSION_PROFILES:
|
||||
portal_setup.runAllImportStepsFromProfile('profile-%s' % extension_id, purge_old=False)
|
||||
product_name = extension_id.split(':')[0]
|
||||
portal_quickinstaller.notifyInstalled(product_name)
|
||||
transaction.savepoint()
|
@ -1,3 +0,0 @@
|
||||
|
||||
def initialize(context):
|
||||
"""Initializer called when used as a Zope 2 product."""
|
@ -1,17 +0,0 @@
|
||||
<configure
|
||||
xmlns="http://namespaces.zope.org/zope"
|
||||
xmlns:five="http://namespaces.zope.org/five"
|
||||
xmlns:genericsetup="http://namespaces.zope.org/genericsetup"
|
||||
i18n_domain="discussion.examplecontent">
|
||||
|
||||
<five:registerPackage package="." initialize=".initialize" />
|
||||
|
||||
<genericsetup:registerProfile
|
||||
name="default"
|
||||
title="Plone Discussion Example Content"
|
||||
directory="profiles/default"
|
||||
description="Example content to test and develop plone.app.discussion"
|
||||
provides="Products.GenericSetup.interfaces.EXTENSION"
|
||||
/>
|
||||
|
||||
</configure>
|
@ -1,7 +0,0 @@
|
||||
<?xml version="1.0"?>
|
||||
<import-steps>
|
||||
<import-step id="discussion-examplecontent-various" version="20090525-01"
|
||||
handler="discussion.examplecontent.setuphandlers.importVarious"
|
||||
title="Example content to test and develop plone.app.discussion">
|
||||
plone.app.discussion example content </import-step>
|
||||
</import-steps>
|
@ -1,138 +0,0 @@
|
||||
from zope.component import createObject
|
||||
|
||||
from Products.CMFCore.utils import getToolByName
|
||||
from Products.CMFEditions.setuphandlers import DEFAULT_POLICIES
|
||||
|
||||
from Products.CMFPlone.utils import _createObjectByType
|
||||
|
||||
from plone.app.discussion.interfaces import IConversation, IReplies
|
||||
|
||||
def addUser(portal, id, fullname, password, email, roles):
|
||||
status=""
|
||||
props = {"username": id,
|
||||
"fullname": fullname,
|
||||
"password": password,
|
||||
"email": email}
|
||||
# add a new member to the Portal
|
||||
try:
|
||||
portal.portal_registration.addMember(id, password, roles,domains="",
|
||||
properties=props)
|
||||
status+="The user "+fullname+" was successfully added.\n"
|
||||
except:
|
||||
status+="The user "+fullname+" was not added.\n"
|
||||
portal.plone_log(status)
|
||||
|
||||
def addComments(portal):
|
||||
|
||||
# Create document
|
||||
_createObjectByType('Document', portal, id='doc1', title='Document 1')
|
||||
portal.plone_log("Document 1 created")
|
||||
|
||||
doc1 = portal.get('doc1', None)
|
||||
|
||||
# Create a conversation. In this case we doesn't assign it to an
|
||||
# object, as we just want to check the Conversation object API.
|
||||
conversation = IConversation(doc1)
|
||||
|
||||
# Pretend that we have traversed to the comment by aq wrapping it.
|
||||
conversation = conversation.__of__(doc1)
|
||||
|
||||
replies = IReplies(conversation)
|
||||
|
||||
# Create a nested comment structure:
|
||||
#
|
||||
# Conversation
|
||||
# +- Comment 1
|
||||
# +- Comment 1_1
|
||||
# | +- Comment 1_1_1
|
||||
# +- Comment 1_2
|
||||
# +- Comment 2
|
||||
# +- Comment 2_1
|
||||
# +- Comment 3
|
||||
# +- Comment 4
|
||||
|
||||
# Create all comments
|
||||
comment1 = createObject('plone.Comment')
|
||||
comment1.title = 'Comment 1'
|
||||
comment1.text = 'Comment text'
|
||||
comment1.Creator = 'Jim'
|
||||
|
||||
comment1_1 = createObject('plone.Comment')
|
||||
comment1_1.title = 'Re: Comment 1'
|
||||
comment1_1.text = 'Comment text'
|
||||
comment1_1.Creator = 'Emma'
|
||||
|
||||
comment1_1_1 = createObject('plone.Comment')
|
||||
comment1_1_1.title = 'Re: Re: Comment 1'
|
||||
comment1_1_1.text = 'Comment text'
|
||||
comment1_1_1.Creator = 'Lukas'
|
||||
|
||||
comment1_2 = createObject('plone.Comment')
|
||||
comment1_2.title = 'Re: Comment 1 (2)'
|
||||
comment1_2.text = 'Comment text'
|
||||
comment1_2.Creator = 'Jim'
|
||||
|
||||
comment2 = createObject('plone.Comment')
|
||||
comment2.title = 'Comment 2'
|
||||
comment2.text = 'Comment text'
|
||||
comment2.Creator = 'Lukas'
|
||||
|
||||
comment2_1 = createObject('plone.Comment')
|
||||
comment2_1.title = 'Re: Comment 2'
|
||||
comment2_1.text = 'Comment text'
|
||||
comment2_1.Creator = 'Emma'
|
||||
|
||||
comment3 = createObject('plone.Comment')
|
||||
comment3.title = 'Comment 3'
|
||||
comment3.text = 'Comment text'
|
||||
comment3.Creator = 'Lukas'
|
||||
|
||||
comment4 = createObject('plone.Comment')
|
||||
comment4.title = 'Comment 4'
|
||||
comment4.text = 'Comment text'
|
||||
comment4.Creator = 'Emma'
|
||||
|
||||
# Create the nested comment structure
|
||||
new_id_1 = conversation.addComment(comment1)
|
||||
new_id_2 = conversation.addComment(comment2)
|
||||
new_id_3 = conversation.addComment(comment3)
|
||||
new_id_4 = conversation.addComment(comment4)
|
||||
|
||||
comment1_1.in_reply_to = new_id_1
|
||||
new_id_1_1 = conversation.addComment(comment1_1)
|
||||
|
||||
comment1_1_1.in_reply_to = new_id_1_1
|
||||
new_id_1_1_1 = conversation.addComment(comment1_1_1)
|
||||
|
||||
comment1_2.in_reply_to = new_id_1
|
||||
new_id_1_2 = conversation.addComment(comment1_2)
|
||||
|
||||
comment2_1.in_reply_to = new_id_2
|
||||
new_id_2_1 = conversation.addComment(comment2_1)
|
||||
|
||||
# Add a comment. Note: in real life, we always create comments via the factory
|
||||
# to allow different factories to be swapped in
|
||||
|
||||
portal.plone_log("")
|
||||
|
||||
def importVarious(context):
|
||||
"""Miscellanous steps import handle
|
||||
"""
|
||||
|
||||
# Ordinarily, GenericSetup handlers check for the existence of XML files.
|
||||
# Here, we are not parsing an XML file, but we use this text file as a
|
||||
# flag to check that we actually meant for this import step to be run.
|
||||
# The file is found in profiles/default.
|
||||
|
||||
if context.readDataFile('discussion.examplecontent_various.txt') is None:
|
||||
return
|
||||
|
||||
portal = context.getSite()
|
||||
|
||||
addUser(portal, id="jim", fullname="Jim Knopf", password="lummerland",
|
||||
email="jim@lummerland.com", roles = ("Member",))
|
||||
addUser(portal, id="lukas", fullname="Lukas", password="lummerland",
|
||||
email="lukas@lummerland.com", roles = ("Member",))
|
||||
addUser(portal, id="emma", fullname="Emma", password="lummerland",
|
||||
email="emma@lummerland.com", roles = ("Member",))
|
||||
addComments(portal)
|
@ -1,53 +0,0 @@
|
||||
import unittest
|
||||
|
||||
from zope.testing import doctestunit
|
||||
from zope.component import testing
|
||||
from Testing import ZopeTestCase as ztc
|
||||
|
||||
from Products.Five import zcml
|
||||
from Products.Five import fiveconfigure
|
||||
from Products.PloneTestCase import PloneTestCase as ptc
|
||||
from Products.PloneTestCase.layer import PloneSite
|
||||
ptc.setupPloneSite()
|
||||
|
||||
import discussion.examplecontent
|
||||
|
||||
class TestCase(ptc.PloneTestCase):
|
||||
class layer(PloneSite):
|
||||
@classmethod
|
||||
def setUp(cls):
|
||||
fiveconfigure.debug_mode = True
|
||||
ztc.installPackage(discussion.examplecontent)
|
||||
fiveconfigure.debug_mode = False
|
||||
|
||||
@classmethod
|
||||
def tearDown(cls):
|
||||
pass
|
||||
|
||||
|
||||
def test_suite():
|
||||
return unittest.TestSuite([
|
||||
|
||||
# Unit tests
|
||||
#doctestunit.DocFileSuite(
|
||||
# 'README.txt', package='discussion.examplecontent',
|
||||
# setUp=testing.setUp, tearDown=testing.tearDown),
|
||||
|
||||
#doctestunit.DocTestSuite(
|
||||
# module='discussion.examplecontent.mymodule',
|
||||
# setUp=testing.setUp, tearDown=testing.tearDown),
|
||||
|
||||
|
||||
# Integration tests that use PloneTestCase
|
||||
#ztc.ZopeDocFileSuite(
|
||||
# 'README.txt', package='discussion.examplecontent',
|
||||
# test_class=TestCase),
|
||||
|
||||
#ztc.FunctionalDocFileSuite(
|
||||
# 'browser.txt', package='discussion.examplecontent',
|
||||
# test_class=TestCase),
|
||||
|
||||
])
|
||||
|
||||
if __name__ == '__main__':
|
||||
unittest.main(defaultTest='test_suite')
|
@ -1,8 +0,0 @@
|
||||
Changelog
|
||||
=========
|
||||
|
||||
1.0 - Unreleased
|
||||
----------------
|
||||
|
||||
* Initial release
|
||||
|
@ -1,52 +0,0 @@
|
||||
discussion.examplecontent Installation
|
||||
--------------------------------------
|
||||
|
||||
To install discussion.examplecontent into the global Python environment (or a workingenv),
|
||||
using a traditional Zope 2 instance, you can do this:
|
||||
|
||||
* When you're reading this you have probably already run
|
||||
``easy_install discussion.examplecontent``. Find out how to install setuptools
|
||||
(and EasyInstall) here:
|
||||
http://peak.telecommunity.com/DevCenter/EasyInstall
|
||||
|
||||
* If you are using Zope 2.9 (not 2.10), get `pythonproducts`_ and install it
|
||||
via::
|
||||
|
||||
python setup.py install --home /path/to/instance
|
||||
|
||||
into your Zope instance.
|
||||
|
||||
* Create a file called ``discussion.examplecontent-configure.zcml`` in the
|
||||
``/path/to/instance/etc/package-includes`` directory. The file
|
||||
should only contain this::
|
||||
|
||||
<include package="discussion.examplecontent" />
|
||||
|
||||
.. _pythonproducts: http://plone.org/products/pythonproducts
|
||||
|
||||
|
||||
Alternatively, if you are using zc.buildout and the plone.recipe.zope2instance
|
||||
recipe to manage your project, you can do this:
|
||||
|
||||
* Add ``discussion.examplecontent`` to the list of eggs to install, e.g.:
|
||||
|
||||
[buildout]
|
||||
...
|
||||
eggs =
|
||||
...
|
||||
discussion.examplecontent
|
||||
|
||||
* Tell the plone.recipe.zope2instance recipe to install a ZCML slug:
|
||||
|
||||
[instance]
|
||||
recipe = plone.recipe.zope2instance
|
||||
...
|
||||
zcml =
|
||||
discussion.examplecontent
|
||||
|
||||
* Re-run buildout, e.g. with:
|
||||
|
||||
$ ./bin/buildout
|
||||
|
||||
You can skip the ZCML slug if you are going to explicitly include the package
|
||||
from another package's configure.zcml file.
|
@ -1,222 +0,0 @@
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||
|
||||
0. This License applies to any program or other work which contains
|
||||
a notice placed by the copyright holder saying it may be distributed
|
||||
under the terms of this General Public License. The "Program", below,
|
||||
refers to any such program or work, and a "work based on the Program"
|
||||
means either the Program or any derivative work under copyright law:
|
||||
that is to say, a work containing the Program or a portion of it,
|
||||
either verbatim or with modifications and/or translated into another
|
||||
language. (Hereinafter, translation is included without limitation in
|
||||
the term "modification".) Each licensee is addressed as "you".
|
||||
|
||||
Activities other than copying, distribution and modification are not
|
||||
covered by this License; they are outside its scope. The act of
|
||||
running the Program is not restricted, and the output from the Program
|
||||
is covered only if its contents constitute a work based on the
|
||||
Program (independent of having been made by running the Program).
|
||||
Whether that is true depends on what the Program does.
|
||||
|
||||
1. You may copy and distribute verbatim copies of the Program's
|
||||
source code as you receive it, in any medium, provided that you
|
||||
conspicuously and appropriately publish on each copy an appropriate
|
||||
copyright notice and disclaimer of warranty; keep intact all the
|
||||
notices that refer to this License and to the absence of any warranty;
|
||||
and give any other recipients of the Program a copy of this License
|
||||
along with the Program.
|
||||
|
||||
You may charge a fee for the physical act of transferring a copy, and
|
||||
you may at your option offer warranty protection in exchange for a fee.
|
||||
|
||||
2. You may modify your copy or copies of the Program or any portion
|
||||
of it, thus forming a work based on the Program, and copy and
|
||||
distribute such modifications or work under the terms of Section 1
|
||||
above, provided that you also meet all of these conditions:
|
||||
|
||||
a) You must cause the modified files to carry prominent notices
|
||||
stating that you changed the files and the date of any change.
|
||||
|
||||
b) You must cause any work that you distribute or publish, that in
|
||||
whole or in part contains or is derived from the Program or any
|
||||
part thereof, to be licensed as a whole at no charge to all third
|
||||
parties under the terms of this License.
|
||||
|
||||
c) If the modified program normally reads commands interactively
|
||||
when run, you must cause it, when started running for such
|
||||
interactive use in the most ordinary way, to print or display an
|
||||
announcement including an appropriate copyright notice and a
|
||||
notice that there is no warranty (or else, saying that you provide
|
||||
a warranty) and that users may redistribute the program under
|
||||
these conditions, and telling the user how to view a copy of this
|
||||
License. (Exception: if the Program itself is interactive but
|
||||
does not normally print such an announcement, your work based on
|
||||
the Program is not required to print an announcement.)
|
||||
|
||||
These requirements apply to the modified work as a whole. If
|
||||
identifiable sections of that work are not derived from the Program,
|
||||
and can be reasonably considered independent and separate works in
|
||||
themselves, then this License, and its terms, do not apply to those
|
||||
sections when you distribute them as separate works. But when you
|
||||
distribute the same sections as part of a whole which is a work based
|
||||
on the Program, the distribution of the whole must be on the terms of
|
||||
this License, whose permissions for other licensees extend to the
|
||||
entire whole, and thus to each and every part regardless of who wrote it.
|
||||
|
||||
Thus, it is not the intent of this section to claim rights or contest
|
||||
your rights to work written entirely by you; rather, the intent is to
|
||||
exercise the right to control the distribution of derivative or
|
||||
collective works based on the Program.
|
||||
|
||||
In addition, mere aggregation of another work not based on the Program
|
||||
with the Program (or with a work based on the Program) on a volume of
|
||||
a storage or distribution medium does not bring the other work under
|
||||
the scope of this License.
|
||||
|
||||
3. You may copy and distribute the Program (or a work based on it,
|
||||
under Section 2) in object code or executable form under the terms of
|
||||
Sections 1 and 2 above provided that you also do one of the following:
|
||||
|
||||
a) Accompany it with the complete corresponding machine-readable
|
||||
source code, which must be distributed under the terms of Sections
|
||||
1 and 2 above on a medium customarily used for software interchange; or,
|
||||
|
||||
b) Accompany it with a written offer, valid for at least three
|
||||
years, to give any third party, for a charge no more than your
|
||||
cost of physically performing source distribution, a complete
|
||||
machine-readable copy of the corresponding source code, to be
|
||||
distributed under the terms of Sections 1 and 2 above on a medium
|
||||
customarily used for software interchange; or,
|
||||
|
||||
c) Accompany it with the information you received as to the offer
|
||||
to distribute corresponding source code. (This alternative is
|
||||
allowed only for noncommercial distribution and only if you
|
||||
received the program in object code or executable form with such
|
||||
an offer, in accord with Subsection b above.)
|
||||
|
||||
The source code for a work means the preferred form of the work for
|
||||
making modifications to it. For an executable work, complete source
|
||||
code means all the source code for all modules it contains, plus any
|
||||
associated interface definition files, plus the scripts used to
|
||||
control compilation and installation of the executable. However, as a
|
||||
special exception, the source code distributed need not include
|
||||
anything that is normally distributed (in either source or binary
|
||||
form) with the major components (compiler, kernel, and so on) of the
|
||||
operating system on which the executable runs, unless that component
|
||||
itself accompanies the executable.
|
||||
|
||||
If distribution of executable or object code is made by offering
|
||||
access to copy from a designated place, then offering equivalent
|
||||
access to copy the source code from the same place counts as
|
||||
distribution of the source code, even though third parties are not
|
||||
compelled to copy the source along with the object code.
|
||||
|
||||
4. You may not copy, modify, sublicense, or distribute the Program
|
||||
except as expressly provided under this License. Any attempt
|
||||
otherwise to copy, modify, sublicense or distribute the Program is
|
||||
void, and will automatically terminate your rights under this License.
|
||||
However, parties who have received copies, or rights, from you under
|
||||
this License will not have their licenses terminated so long as such
|
||||
parties remain in full compliance.
|
||||
|
||||
5. You are not required to accept this License, since you have not
|
||||
signed it. However, nothing else grants you permission to modify or
|
||||
distribute the Program or its derivative works. These actions are
|
||||
prohibited by law if you do not accept this License. Therefore, by
|
||||
modifying or distributing the Program (or any work based on the
|
||||
Program), you indicate your acceptance of this License to do so, and
|
||||
all its terms and conditions for copying, distributing or modifying
|
||||
the Program or works based on it.
|
||||
|
||||
6. Each time you redistribute the Program (or any work based on the
|
||||
Program), the recipient automatically receives a license from the
|
||||
original licensor to copy, distribute or modify the Program subject to
|
||||
these terms and conditions. You may not impose any further
|
||||
restrictions on the recipients' exercise of the rights granted herein.
|
||||
You are not responsible for enforcing compliance by third parties to
|
||||
this License.
|
||||
|
||||
7. If, as a consequence of a court judgment or allegation of patent
|
||||
infringement or for any other reason (not limited to patent issues),
|
||||
conditions are imposed on you (whether by court order, agreement or
|
||||
otherwise) that contradict the conditions of this License, they do not
|
||||
excuse you from the conditions of this License. If you cannot
|
||||
distribute so as to satisfy simultaneously your obligations under this
|
||||
License and any other pertinent obligations, then as a consequence you
|
||||
may not distribute the Program at all. For example, if a patent
|
||||
license would not permit royalty-free redistribution of the Program by
|
||||
all those who receive copies directly or indirectly through you, then
|
||||
the only way you could satisfy both it and this License would be to
|
||||
refrain entirely from distribution of the Program.
|
||||
|
||||
If any portion of this section is held invalid or unenforceable under
|
||||
any particular circumstance, the balance of the section is intended to
|
||||
apply and the section as a whole is intended to apply in other
|
||||
circumstances.
|
||||
|
||||
It is not the purpose of this section to induce you to infringe any
|
||||
patents or other property right claims or to contest validity of any
|
||||
such claims; this section has the sole purpose of protecting the
|
||||
integrity of the free software distribution system, which is
|
||||
implemented by public license practices. Many people have made
|
||||
generous contributions to the wide range of software distributed
|
||||
through that system in reliance on consistent application of that
|
||||
system; it is up to the author/donor to decide if he or she is willing
|
||||
to distribute software through any other system and a licensee cannot
|
||||
impose that choice.
|
||||
|
||||
This section is intended to make thoroughly clear what is believed to
|
||||
be a consequence of the rest of this License.
|
||||
|
||||
8. If the distribution and/or use of the Program is restricted in
|
||||
certain countries either by patents or by copyrighted interfaces, the
|
||||
original copyright holder who places the Program under this License
|
||||
may add an explicit geographical distribution limitation excluding
|
||||
those countries, so that distribution is permitted only in or among
|
||||
countries not thus excluded. In such case, this License incorporates
|
||||
the limitation as if written in the body of this License.
|
||||
|
||||
9. The Free Software Foundation may publish revised and/or new versions
|
||||
of the General Public License from time to time. Such new versions will
|
||||
be similar in spirit to the present version, but may differ in detail to
|
||||
address new problems or concerns.
|
||||
|
||||
Each version is given a distinguishing version number. If the Program
|
||||
specifies a version number of this License which applies to it and "any
|
||||
later version", you have the option of following the terms and conditions
|
||||
either of that version or of any later version published by the Free
|
||||
Software Foundation. If the Program does not specify a version number of
|
||||
this License, you may choose any version ever published by the Free Software
|
||||
Foundation.
|
||||
|
||||
10. If you wish to incorporate parts of the Program into other free
|
||||
programs whose distribution conditions are different, write to the author
|
||||
to ask for permission. For software which is copyrighted by the Free
|
||||
Software Foundation, write to the Free Software Foundation; we sometimes
|
||||
make exceptions for this. Our decision will be guided by the two goals
|
||||
of preserving the free status of all derivatives of our free software and
|
||||
of promoting the sharing and reuse of software generally.
|
||||
|
||||
NO WARRANTY
|
||||
|
||||
11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
|
||||
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
|
||||
OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
|
||||
PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
|
||||
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
|
||||
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
|
||||
PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
|
||||
REPAIR OR CORRECTION.
|
||||
|
||||
12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
|
||||
REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
|
||||
INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
|
||||
OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
|
||||
TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
|
||||
YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
|
||||
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
||||
POSSIBILITY OF SUCH DAMAGES.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
@ -1,16 +0,0 @@
|
||||
discussion.examplecontent is copyright Timo Stollenwerk
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation; either version 2 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program; if not, write to the Free Software
|
||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
MA 02111-1307 USA.
|
@ -1,7 +0,0 @@
|
||||
[zopeskel]
|
||||
template = plone
|
||||
|
||||
[egg_info]
|
||||
tag_build = dev
|
||||
tag_svn_revision = true
|
||||
|
@ -1,40 +0,0 @@
|
||||
from setuptools import setup, find_packages
|
||||
import os
|
||||
|
||||
version = '1.0'
|
||||
|
||||
setup(name='discussion.examplecontent',
|
||||
version=version,
|
||||
description="Example content for testing and developing plone.app.discussion",
|
||||
long_description=open("README.txt").read() + "\n" +
|
||||
open(os.path.join("docs", "HISTORY.txt")).read(),
|
||||
# Get more strings from http://www.python.org/pypi?%3Aaction=list_classifiers
|
||||
classifiers=[
|
||||
"Framework :: Plone",
|
||||
"Programming Language :: Python",
|
||||
"Topic :: Software Development :: Libraries :: Python Modules",
|
||||
],
|
||||
keywords='',
|
||||
author='Timo Stollenwerk',
|
||||
author_email='timo@zmag.de',
|
||||
url='http://svn.plone.org/svn/plone/plone.example',
|
||||
license='GPL',
|
||||
packages=find_packages(exclude=['ez_setup']),
|
||||
namespace_packages=['discussion'],
|
||||
include_package_data=True,
|
||||
zip_safe=False,
|
||||
install_requires=[
|
||||
'setuptools',
|
||||
# -*- Extra requirements: -*-
|
||||
],
|
||||
entry_points="""
|
||||
# -*- Entry points: -*-
|
||||
|
||||
[distutils.setup_keywords]
|
||||
paster_plugins = setuptools.dist:assert_string_list
|
||||
|
||||
[egg_info.writers]
|
||||
paster_plugins.txt = setuptools.command.egg_info:write_arg
|
||||
""",
|
||||
paster_plugins = ["ZopeSkel"],
|
||||
)
|
@ -1,12 +0,0 @@
|
||||
===================================================
|
||||
PyDev Development Buildout for plone.app.discussion
|
||||
===================================================
|
||||
|
||||
This is the development buildout for plone.app.discussion. This
|
||||
buildout is for development with the PyDev Eclipse plugin.
|
||||
You have to manually link plone.app.discussion (checked out
|
||||
seperately) into the src directory of this buildout to make it
|
||||
work::
|
||||
|
||||
$ cd pydev-plone4-buildout/src
|
||||
$ ln -s ../../plone.app.discussion
|
@ -1,121 +0,0 @@
|
||||
##############################################################################
|
||||
#
|
||||
# Copyright (c) 2006 Zope Corporation and Contributors.
|
||||
# All Rights Reserved.
|
||||
#
|
||||
# This software is subject to the provisions of the Zope Public License,
|
||||
# Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution.
|
||||
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
|
||||
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
|
||||
# FOR A PARTICULAR PURPOSE.
|
||||
#
|
||||
##############################################################################
|
||||
"""Bootstrap a buildout-based project
|
||||
|
||||
Simply run this script in a directory containing a buildout.cfg.
|
||||
The script accepts buildout command-line options, so you can
|
||||
use the -c option to specify an alternate configuration file.
|
||||
"""
|
||||
|
||||
import os, shutil, sys, tempfile, urllib2
|
||||
from optparse import OptionParser
|
||||
|
||||
tmpeggs = tempfile.mkdtemp()
|
||||
|
||||
is_jython = sys.platform.startswith('java')
|
||||
|
||||
# parsing arguments
|
||||
parser = OptionParser()
|
||||
parser.add_option("-v", "--version", dest="version",
|
||||
help="use a specific zc.buildout version")
|
||||
parser.add_option("-d", "--distribute",
|
||||
action="store_true", dest="distribute", default=False,
|
||||
help="Use Disribute rather than Setuptools.")
|
||||
|
||||
parser.add_option("-c", None, action="store", dest="config_file",
|
||||
help=("Specify the path to the buildout configuration "
|
||||
"file to be used."))
|
||||
|
||||
options, args = parser.parse_args()
|
||||
|
||||
# if -c was provided, we push it back into args for buildout' main function
|
||||
if options.config_file is not None:
|
||||
args += ['-c', options.config_file]
|
||||
|
||||
if options.version is not None:
|
||||
VERSION = '==%s' % options.version
|
||||
else:
|
||||
VERSION = ''
|
||||
|
||||
# We decided to always use distribute, make sure this is the default for us
|
||||
# USE_DISTRIBUTE = options.distribute
|
||||
USE_DISTRIBUTE = True
|
||||
args = args + ['bootstrap']
|
||||
|
||||
to_reload = False
|
||||
try:
|
||||
import pkg_resources
|
||||
if not hasattr(pkg_resources, '_distribute'):
|
||||
to_reload = True
|
||||
raise ImportError
|
||||
except ImportError:
|
||||
ez = {}
|
||||
if USE_DISTRIBUTE:
|
||||
exec urllib2.urlopen('http://python-distribute.org/distribute_setup.py'
|
||||
).read() in ez
|
||||
ez['use_setuptools'](to_dir=tmpeggs, download_delay=0, no_fake=True)
|
||||
else:
|
||||
exec urllib2.urlopen('http://peak.telecommunity.com/dist/ez_setup.py'
|
||||
).read() in ez
|
||||
ez['use_setuptools'](to_dir=tmpeggs, download_delay=0)
|
||||
|
||||
if to_reload:
|
||||
reload(pkg_resources)
|
||||
else:
|
||||
import pkg_resources
|
||||
|
||||
if sys.platform == 'win32':
|
||||
def quote(c):
|
||||
if ' ' in c:
|
||||
return '"%s"' % c # work around spawn lamosity on windows
|
||||
else:
|
||||
return c
|
||||
else:
|
||||
def quote (c):
|
||||
return c
|
||||
|
||||
cmd = 'from setuptools.command.easy_install import main; main()'
|
||||
ws = pkg_resources.working_set
|
||||
|
||||
if USE_DISTRIBUTE:
|
||||
requirement = 'distribute'
|
||||
else:
|
||||
requirement = 'setuptools'
|
||||
|
||||
if is_jython:
|
||||
import subprocess
|
||||
|
||||
assert subprocess.Popen([sys.executable] + ['-c', quote(cmd), '-mqNxd',
|
||||
quote(tmpeggs), 'zc.buildout' + VERSION],
|
||||
env=dict(os.environ,
|
||||
PYTHONPATH=
|
||||
ws.find(pkg_resources.Requirement.parse(requirement)).location
|
||||
),
|
||||
).wait() == 0
|
||||
|
||||
else:
|
||||
assert os.spawnle(
|
||||
os.P_WAIT, sys.executable, quote (sys.executable),
|
||||
'-c', quote (cmd), '-mqNxd', quote (tmpeggs), 'zc.buildout' + VERSION,
|
||||
dict(os.environ,
|
||||
PYTHONPATH=
|
||||
ws.find(pkg_resources.Requirement.parse(requirement)).location
|
||||
),
|
||||
) == 0
|
||||
|
||||
ws.add_entry(tmpeggs)
|
||||
ws.require('zc.buildout' + VERSION)
|
||||
import zc.buildout.buildout
|
||||
zc.buildout.buildout.main(args)
|
||||
shutil.rmtree(tmpeggs)
|
@ -1,124 +0,0 @@
|
||||
[buildout]
|
||||
parts =
|
||||
productdistros
|
||||
instance
|
||||
zopepy
|
||||
omelette
|
||||
test
|
||||
coverage-test
|
||||
coverage-report
|
||||
|
||||
extensions =
|
||||
buildout.dumppickedversions
|
||||
buildout.eggtractor
|
||||
|
||||
dump-picked-versions-file = versions.cfg
|
||||
overwrite-picked-versions-file = True
|
||||
|
||||
tractor-src-directory = src
|
||||
packages-under-test = plone.app.discussion
|
||||
|
||||
# Change the number here to change the version of Plone being used
|
||||
extends =
|
||||
http://download.zope.org/Zope2/index/2.12.1/versions.cfg
|
||||
http://dist.plone.org/release/4.0a4/versions.cfg
|
||||
versions = versions
|
||||
|
||||
# Add additional egg download sources here. dist.plone.org contains archives
|
||||
# of Plone packages.
|
||||
find-links =
|
||||
http://dist.plone.org/release/4.0a4
|
||||
http://dist.plone.org/thirdparty
|
||||
|
||||
# Add additional eggs here
|
||||
eggs =
|
||||
collective.autoresizetextarea
|
||||
plone.formwidget.captcha
|
||||
plone.formwidget.recaptcha
|
||||
Products.PdbDebugMode
|
||||
plone.reload
|
||||
ipdb
|
||||
|
||||
# Reference any eggs you are developing here, one per line
|
||||
# e.g.: develop = src/my.package
|
||||
develop =
|
||||
|
||||
[versions]
|
||||
plone.theme = 1.2
|
||||
zope.schema = 3.6.0
|
||||
|
||||
# Use this section to download additional old-style products.
|
||||
# List any number of URLs for product tarballs under URLs (separate
|
||||
# with whitespace, or break over several lines, with subsequent lines
|
||||
# indented). If any archives contain several products inside a top-level
|
||||
# directory, list the archive file name (i.e. the last part of the URL,
|
||||
# normally with a .tar.gz suffix or similar) under 'nested-packages'.
|
||||
# If any archives extract to a product directory with a version suffix, list
|
||||
# the archive name under 'version-suffix-packages'.
|
||||
[productdistros]
|
||||
# For more information on this step and configuration options see:
|
||||
# http://pypi.python.org/pypi/plone.recipe.distros
|
||||
recipe = plone.recipe.distros
|
||||
urls =
|
||||
nested-packages =
|
||||
version-suffix-packages =
|
||||
|
||||
[instance]
|
||||
# For more information on this step and configuration options see:
|
||||
# http://pypi.python.org/pypi/plone.recipe.zope2instance
|
||||
recipe = plone.recipe.zope2instance
|
||||
user = admin:admin
|
||||
http-address = 8080
|
||||
#debug-mode = on
|
||||
#verbose-security = on
|
||||
blob-storage = var/blobstorage
|
||||
# If you want Zope to know about any additional eggs, list them here.
|
||||
# This should include any development eggs you listed in develop-eggs above,
|
||||
# e.g. eggs = Plone my.package
|
||||
eggs =
|
||||
Zope2
|
||||
Plone
|
||||
${buildout:eggs}
|
||||
|
||||
# If you want to register ZCML slugs for any packages, list them here.
|
||||
# e.g. zcml = my.package my.other.package
|
||||
zcml =
|
||||
collective.autoresizetextarea
|
||||
plone.formwidget.captcha
|
||||
plone.formwidget.recaptcha
|
||||
|
||||
products =
|
||||
${buildout:directory}/products
|
||||
${productdistros:location}
|
||||
|
||||
[zopepy]
|
||||
# For more information on this step and configuration options see:
|
||||
# http://pypi.python.org/pypi/zc.recipe.egg
|
||||
recipe = zc.recipe.egg
|
||||
eggs = ${instance:eggs}
|
||||
interpreter = zopepy
|
||||
scripts = zopepy
|
||||
|
||||
[omelette]
|
||||
recipe = collective.recipe.omelette
|
||||
eggs = ${instance:eggs}
|
||||
products = ${instance:products}
|
||||
packages = ${instance:location}/lib/python ./
|
||||
|
||||
[test]
|
||||
recipe = zc.recipe.testrunner
|
||||
eggs =
|
||||
plone.app.discussion
|
||||
defaults = ['-v', '--exit-with-status', '--auto-color', '--auto-progress']
|
||||
|
||||
[coverage-test]
|
||||
recipe = zc.recipe.testrunner
|
||||
eggs = ${test:eggs}
|
||||
defaults = ['--coverage', '../../coverage', '-v', '--auto-progress']
|
||||
|
||||
[coverage-report]
|
||||
recipe = zc.recipe.egg
|
||||
eggs = z3c.coverage
|
||||
scripts = coverage=coverage-report
|
||||
arguments = ('coverage', 'report')
|
||||
|
@ -1 +0,0 @@
|
||||
Old-style Zope products you are developing can be added here
|
@ -1 +0,0 @@
|
||||
Packages in eggs that you develop should go in this directory
|
@ -1,47 +0,0 @@
|
||||
[versions]
|
||||
Products.PDBDebugMode = 1.1
|
||||
collective.autoresizetextarea = 1.0a1
|
||||
collective.recipe.omelette = 0.9
|
||||
collective.z3cform.datetimewidget = 0.1a9
|
||||
ipdb = 0.1dev-r1716
|
||||
plone.autoform = 1.0b2
|
||||
plone.formwidget.captcha = 1.0a1
|
||||
plone.formwidget.recaptcha = 1.0b1
|
||||
plone.recipe.distros = 1.5
|
||||
plone.supermodel = 1.0b4
|
||||
recaptcha-client = 1.0.5
|
||||
z3c.coverage = 1.1.3
|
||||
|
||||
#Required by:
|
||||
#plone.app.discussion 1.0b1
|
||||
collective.autopermission = 1.0b1
|
||||
|
||||
#Required by:
|
||||
#ipdb 0.1dev-r1716
|
||||
ipython = 0.10
|
||||
|
||||
#Required by:
|
||||
#plone.app.discussion 1.0b1
|
||||
#plone.formwidget.recaptcha 1.0b1
|
||||
plone.app.registry = 1.0b1
|
||||
|
||||
#Required by:
|
||||
#plone.app.discussion 1.0b1
|
||||
#plone.formwidget.recaptcha 1.0b1
|
||||
plone.registry = 1.0b1
|
||||
|
||||
#Required by:
|
||||
#plone.formwidget.captcha 1.0a1
|
||||
skimpyGimpy = 1.4
|
||||
|
||||
#Required by:
|
||||
#plone.z3cform 0.5.5
|
||||
z3c.batching = 1.1.0
|
||||
|
||||
#Required by:
|
||||
#plone.z3cform 0.5.5
|
||||
z3c.form = 2.2.0
|
||||
|
||||
#Required by:
|
||||
#plone.app.z3cform 0.4.6
|
||||
z3c.formwidget.query = 0.5
|
Loading…
Reference in New Issue
Block a user