"""FAQ Wizard customization module. | |
Edit this file to customize the FAQ Wizard. For normal purposes, you | |
should only have to change the FAQ section titles and the small group | |
of parameters below it. | |
""" | |
# Titles of FAQ sections | |
SECTION_TITLES = { | |
# SectionNumber : SectionTitle; need at least one entry | |
1: "General information and availability", | |
} | |
# Parameters you definitely want to change | |
SHORTNAME = "Generic" # FAQ name with "FAQ" omitted | |
PASSWORD = "" # Password for editing | |
OWNERNAME = "FAQ owner" # Name for feedback | |
OWNEREMAIL = "nobody@anywhere.org" # Email for feedback | |
HOMEURL = "http://www.python.org" # Related home page | |
HOMENAME = "Python home" # Name of related home page | |
RCSBINDIR = "/usr/local/bin/" # Directory containing RCS commands | |
# (must end in a slash) | |
# Parameters you can normally leave alone | |
MAXHITS = 10 # Max #hits to be shown directly | |
COOKIE_LIFETIME = 28*24*3600 # Cookie expiration in seconds | |
# (28*24*3600 = 28 days = 4 weeks) | |
PROCESS_PREFORMAT = 1 # toggle whether preformatted text | |
# will replace urls and emails with | |
# HTML links | |
# Markers appended to title to indicate recently change | |
# (may contain HTML, e.g. <IMG>); and corresponding | |
MARK_VERY_RECENT = " **" # Changed very recently | |
MARK_RECENT = " *" # Changed recently | |
DT_VERY_RECENT = 24*3600 # 24 hours | |
DT_RECENT = 7*24*3600 # 7 days | |
EXPLAIN_MARKS = """ | |
<P>(Entries marked with ** were changed within the last 24 hours; | |
entries marked with * were changed within the last 7 days.) | |
<P> | |
""" | |
# Version -- don't change unless you edit faqwiz.py | |
WIZVERSION = "1.0.4" # FAQ Wizard version | |
import os, sys | |
if os.name in ['nt',]: | |
# On NT we'll probably be running python from a batch file, | |
# so sys.argv[0] is not helpful | |
FAQCGI = 'faq.bat' # Relative URL of the FAQ cgi script | |
# LOGNAME is not typically set on NT | |
os.environ[ 'LOGNAME' ] = "FAQWizard" | |
else: | |
# This parameter is normally overwritten with a dynamic value | |
FAQCGI = 'faqw.py' # Relative URL of the FAQ cgi script | |
FAQCGI = os.path.basename(sys.argv[0]) or FAQCGI | |
del os, sys | |
# Perl (re module) style regular expression to recognize FAQ entry | |
# files: group(1) should be the section number, group(2) should be the | |
# question number. Both should be fixed width so simple-minded | |
# sorting yields the right order. | |
OKFILENAME = r"^faq(\d\d)\.(\d\d\d)\.htp$" | |
# Format to construct a FAQ entry file name | |
NEWFILENAME = "faq%02d.%03d.htp" | |
# Load local customizations on top of the previous parameters | |
try: | |
from faqcust import * | |
except ImportError: | |
pass | |
# Calculated parameter names | |
COOKIE_NAME = SHORTNAME + "-FAQ-Wizard" # Name used for Netscape cookie | |
FAQNAME = SHORTNAME + " FAQ" # Name of the FAQ | |
# ---------------------------------------------------------------------- | |
# Anything below this point normally needn't be changed; you would | |
# change this if you were to create e.g. a French translation or if | |
# you just aren't happy with the text generated by the FAQ Wizard. | |
# Most strings here are subject to substitution (string%dictionary) | |
# RCS commands | |
import os | |
if os.name in ['nt', ]: | |
SH_RLOG = RCSBINDIR + "rlog %(file)s < NUL" | |
SH_RLOG_H = RCSBINDIR + "rlog -h %(file)s < NUL" | |
SH_RDIFF = RCSBINDIR + "rcsdiff -r%(prev)s -r%(rev)s %(file)s < NUL" | |
SH_REVISION = RCSBINDIR + "co -p%(rev)s %(file)s < NUL" | |
### Have to use co -l, or the file is not marked rw on NT | |
SH_LOCK = RCSBINDIR + "co -l %(file)s < NUL" | |
SH_CHECKIN = RCSBINDIR + "ci -u %(file)s < %(tfn)s" | |
else: | |
SH_RLOG = RCSBINDIR + "rlog %(file)s </dev/null 2>&1" | |
SH_RLOG_H = RCSBINDIR + "rlog -h %(file)s </dev/null 2>&1" | |
SH_RDIFF = RCSBINDIR + "rcsdiff -r%(prev)s -r%(rev)s %(file)s </dev/null 2>&1" | |
SH_REVISION = RCSBINDIR + "co -p%(rev)s %(file)s </dev/null 2>&1" | |
SH_LOCK = RCSBINDIR + "rcs -l %(file)s </dev/null 2>&1" | |
SH_CHECKIN = RCSBINDIR + "ci -u %(file)s <%(tfn)s 2>&1" | |
del os | |
# Titles for various output pages (not subject to substitution) | |
T_HOME = FAQNAME + " Wizard " + WIZVERSION | |
T_ERROR = "Sorry, an error occurred" | |
T_ROULETTE = FAQNAME + " Roulette" | |
T_ALL = "The Whole " + FAQNAME | |
T_INDEX = FAQNAME + " Index" | |
T_SEARCH = FAQNAME + " Search Results" | |
T_RECENT = "What's New in the " + FAQNAME | |
T_SHOW = FAQNAME + " Entry" | |
T_LOG = "RCS log for %s entry" % FAQNAME | |
T_REVISION = "RCS revision for %s entry" % FAQNAME | |
T_DIFF = "RCS diff for %s entry" % FAQNAME | |
T_ADD = "Add an entry to the " + FAQNAME | |
T_DELETE = "Deleting an entry from the " + FAQNAME | |
T_EDIT = FAQNAME + " Edit Wizard" | |
T_REVIEW = T_EDIT + " - Review Changes" | |
T_COMMITTED = T_EDIT + " - Changes Committed" | |
T_COMMITFAILED = T_EDIT + " - Commit Failed" | |
T_CANTCOMMIT = T_EDIT + " - Commit Rejected" | |
T_HELP = T_EDIT + " - Help" | |
# Generic prologue and epilogue | |
PROLOGUE = ''' | |
<HTML> | |
<HEAD> | |
<TITLE>%(title)s</TITLE> | |
</HEAD> | |
<BODY | |
BGCOLOR="#FFFFFF" | |
TEXT="#000000" | |
LINK="#AA0000" | |
VLINK="#906A6A"> | |
<H1>%(title)s</H1> | |
''' | |
EPILOGUE = ''' | |
<HR> | |
<A HREF="%(HOMEURL)s">%(HOMENAME)s</A> / | |
<A HREF="%(FAQCGI)s?req=home">%(FAQNAME)s Wizard %(WIZVERSION)s</A> / | |
Feedback to <A HREF="mailto:%(OWNEREMAIL)s">%(OWNERNAME)s</A> | |
</BODY> | |
</HTML> | |
''' | |
# Home page | |
HOME = """ | |
<H2>Search the %(FAQNAME)s:</H2> | |
<BLOCKQUOTE> | |
<FORM ACTION="%(FAQCGI)s"> | |
<INPUT TYPE=text NAME=query> | |
<INPUT TYPE=submit VALUE="Search"><BR> | |
<INPUT TYPE=radio NAME=querytype VALUE=simple CHECKED> | |
Simple string | |
/ | |
<INPUT TYPE=radio NAME=querytype VALUE=regex> | |
Regular expression | |
/<BR> | |
<INPUT TYPE=radio NAME=querytype VALUE=anykeywords> | |
Keywords (any) | |
/ | |
<INPUT TYPE=radio NAME=querytype VALUE=allkeywords> | |
Keywords (all) | |
<BR> | |
<INPUT TYPE=radio NAME=casefold VALUE=yes CHECKED> | |
Fold case | |
/ | |
<INPUT TYPE=radio NAME=casefold VALUE=no> | |
Case sensitive | |
<BR> | |
<INPUT TYPE=hidden NAME=req VALUE=search> | |
</FORM> | |
</BLOCKQUOTE> | |
<HR> | |
<H2>Other forms of %(FAQNAME)s access:</H2> | |
<UL> | |
<LI><A HREF="%(FAQCGI)s?req=index">FAQ index</A> | |
<LI><A HREF="%(FAQCGI)s?req=all">The whole FAQ</A> | |
<LI><A HREF="%(FAQCGI)s?req=recent">What's new in the FAQ?</A> | |
<LI><A HREF="%(FAQCGI)s?req=roulette">FAQ roulette</A> | |
<LI><A HREF="%(FAQCGI)s?req=add">Add a FAQ entry</A> | |
<LI><A HREF="%(FAQCGI)s?req=delete">Delete a FAQ entry</A> | |
</UL> | |
""" | |
# Index formatting | |
INDEX_SECTION = """ | |
<P> | |
<HR> | |
<H2>%(sec)s. %(title)s</H2> | |
<UL> | |
""" | |
INDEX_ADDSECTION = """ | |
<P> | |
<LI><A HREF="%(FAQCGI)s?req=new&section=%(sec)s">Add new entry</A> | |
(at this point) | |
""" | |
INDEX_ENDSECTION = """ | |
</UL> | |
""" | |
INDEX_ENTRY = """\ | |
<LI><A HREF="%(FAQCGI)s?req=show&file=%(file)s">%(title)s</A> | |
""" | |
LOCAL_ENTRY = """\ | |
<LI><A HREF="#%(sec)s.%(num)s">%(title)s</A> | |
""" | |
# Entry formatting | |
ENTRY_HEADER1 = """ | |
<HR> | |
<H2><A NAME="%(sec)s.%(num)s">%(title)s</A>\ | |
""" | |
ENTRY_HEADER2 = """\ | |
</H2> | |
""" | |
ENTRY_FOOTER = """ | |
<A HREF="%(FAQCGI)s?req=edit&file=%(file)s">Edit this entry</A> / | |
<A HREF="%(FAQCGI)s?req=log&file=%(file)s">Log info</A> | |
""" | |
ENTRY_LOGINFO = """ | |
/ Last changed on %(last_changed_date)s by | |
<A HREF="mailto:%(last_changed_email)s">%(last_changed_author)s</A> | |
""" | |
# Search | |
NO_HITS = """ | |
No hits. | |
""" | |
ONE_HIT = """ | |
Your search matched the following entry: | |
""" | |
FEW_HITS = """ | |
Your search matched the following %(count)s entries: | |
""" | |
MANY_HITS = """ | |
Your search matched more than %(MAXHITS)s entries. | |
The %(count)s matching entries are presented here ordered by section: | |
""" | |
# RCS log and diff | |
LOG = """ | |
Click on a revision line to see the diff between that revision and the | |
previous one. | |
""" | |
REVISIONLINK = """\ | |
<A HREF="%(FAQCGI)s?req=revision&file=%(file)s&rev=%(rev)s" | |
>%(line)s</A>\ | |
""" | |
DIFFLINK = """\ | |
(<A HREF="%(FAQCGI)s?req=diff&file=%(file)s&\ | |
prev=%(prev)s&rev=%(rev)s" | |
>diff -r%(prev)s -r%(rev)s</A>)\ | |
""" | |
# Recently changed entries | |
NO_RECENT = """ | |
<HR> | |
No %(FAQNAME)s entries were changed in the last %(period)s. | |
""" | |
VIEW_MENU = """ | |
<HR> | |
View entries changed in the last... | |
<UL> | |
<LI><A HREF="%(FAQCGI)s?req=recent&days=1">24 hours</A> | |
<LI><A HREF="%(FAQCGI)s?req=recent&days=2">2 days</A> | |
<LI><A HREF="%(FAQCGI)s?req=recent&days=3">3 days</A> | |
<LI><A HREF="%(FAQCGI)s?req=recent&days=7">week</A> | |
<LI><A HREF="%(FAQCGI)s?req=recent&days=28">4 weeks</A> | |
<LI><A HREF="%(FAQCGI)s?req=recent&days=365250">millennium</A> | |
</UL> | |
""" | |
ONE_RECENT = VIEW_MENU + """ | |
The following %(FAQNAME)s entry was changed in the last %(period)s: | |
""" | |
SOME_RECENT = VIEW_MENU + """ | |
The following %(count)s %(FAQNAME)s entries were changed | |
in the last %(period)s, most recently changed shown first: | |
""" | |
TAIL_RECENT = VIEW_MENU | |
# Last changed banner on "all" (strftime format) | |
LAST_CHANGED = "Last changed on %c %Z" | |
# "Compat" command prologue (this has no <BODY> tag) | |
COMPAT = """ | |
<H1>The whole %(FAQNAME)s</H1> | |
See also the <A HREF="%(FAQCGI)s?req=home">%(FAQNAME)s Wizard</A>. | |
<P> | |
""" | |
# Editing | |
EDITHEAD = """ | |
<A HREF="%(FAQCGI)s?req=help">Click for Help</A> | |
""" | |
REVIEWHEAD = EDITHEAD | |
EDITFORM1 = """ | |
<FORM ACTION="%(FAQCGI)s" METHOD=POST> | |
<INPUT TYPE=hidden NAME=req VALUE=review> | |
<INPUT TYPE=hidden NAME=file VALUE=%(file)s> | |
<INPUT TYPE=hidden NAME=editversion VALUE=%(editversion)s> | |
<HR> | |
""" | |
EDITFORM2 = """ | |
Title: <INPUT TYPE=text SIZE=70 NAME=title VALUE="%(title)s"><BR> | |
<TEXTAREA COLS=72 ROWS=20 NAME=body>%(body)s | |
</TEXTAREA><BR> | |
Log message (reason for the change):<BR> | |
<TEXTAREA COLS=72 ROWS=5 NAME=log>%(log)s | |
</TEXTAREA><BR> | |
Please provide the following information for logging purposes: | |
<TABLE FRAME=none COLS=2> | |
<TR> | |
<TD>Name: | |
<TD><INPUT TYPE=text SIZE=40 NAME=author VALUE="%(author)s"> | |
<TR> | |
<TD>Email: | |
<TD><INPUT TYPE=text SIZE=40 NAME=email VALUE="%(email)s"> | |
<TR> | |
<TD>Password: | |
<TD><INPUT TYPE=password SIZE=20 NAME=password VALUE="%(password)s"> | |
</TABLE> | |
<INPUT TYPE=submit NAME=review VALUE="Preview Edit"> | |
Click this button to preview your changes. | |
""" | |
EDITFORM3 = """ | |
</FORM> | |
""" | |
COMMIT = """ | |
<INPUT TYPE=submit NAME=commit VALUE="Commit"> | |
Click this button to commit your changes. | |
<HR> | |
""" | |
NOCOMMIT_HEAD = """ | |
To commit your changes, please correct the following errors in the | |
form below and click the Preview Edit button. | |
<UL> | |
""" | |
NOCOMMIT_TAIL = """ | |
</UL> | |
<HR> | |
""" | |
CANTCOMMIT_HEAD = """ | |
Some required information is missing: | |
<UL> | |
""" | |
NEED_PASSWD = "<LI>You must provide the correct password.\n" | |
NEED_AUTHOR = "<LI>You must enter your name.\n" | |
NEED_EMAIL = "<LI>You must enter your email address.\n" | |
NEED_LOG = "<LI>You must enter a log message.\n" | |
CANTCOMMIT_TAIL = """ | |
</UL> | |
Please use your browser's Back command to correct the form and commit | |
again. | |
""" | |
NEWCONFLICT = """ | |
<P> | |
You are creating a new entry, but the entry number specified is not | |
correct. | |
<P> | |
The two most common causes of this problem are: | |
<UL> | |
<LI>After creating the entry yourself, you went back in your browser, | |
edited the entry some more, and clicked Commit again. | |
<LI>Someone else started creating a new entry in the same section and | |
committed before you did. | |
</UL> | |
(It is also possible that the last entry in the section was physically | |
deleted, but this should not happen except through manual intervention | |
by the FAQ maintainer.) | |
<P> | |
<A HREF="%(FAQCGI)s?req=new&section=%(sec)s">Click here to try | |
again.</A> | |
<P> | |
""" | |
VERSIONCONFLICT = """ | |
<P> | |
You edited version %(editversion)s but the current version is %(version)s. | |
<P> | |
The two most common causes of this problem are: | |
<UL> | |
<LI>After committing a change, you went back in your browser, | |
edited the entry some more, and clicked Commit again. | |
<LI>Someone else started editing the same entry and committed | |
before you did. | |
</UL> | |
<P> | |
<A HREF="%(FAQCGI)s?req=show&file=%(file)s">Click here to reload | |
the entry and try again.</A> | |
<P> | |
""" | |
CANTWRITE = """ | |
Can't write file %(file)s (%(why)s). | |
""" | |
FILEHEADER = """\ | |
Title: %(title)s | |
Last-Changed-Date: %(date)s | |
Last-Changed-Author: %(author)s | |
Last-Changed-Email: %(email)s | |
Last-Changed-Remote-Host: %(REMOTE_HOST)s | |
Last-Changed-Remote-Address: %(REMOTE_ADDR)s | |
""" | |
LOGHEADER = """\ | |
Last-Changed-Date: %(date)s | |
Last-Changed-Author: %(author)s | |
Last-Changed-Email: %(email)s | |
Last-Changed-Remote-Host: %(REMOTE_HOST)s | |
Last-Changed-Remote-Address: %(REMOTE_ADDR)s | |
%(log)s | |
""" | |
COMMITTED = """ | |
Your changes have been committed. | |
""" | |
COMMITFAILED = """ | |
Exit status %(sts)s. | |
""" | |
# Add/Delete | |
ADD_HEAD = """ | |
At the moment, new entries can only be added at the end of a section. | |
This is because the entry numbers are also their | |
unique identifiers -- it's a bad idea to renumber entries. | |
<P> | |
Click on the section to which you want to add a new entry: | |
<UL> | |
""" | |
ADD_SECTION = """\ | |
<LI><A HREF="%(FAQCGI)s?req=new&section=%(section)s">%(section)s. %(title)s</A> | |
""" | |
ADD_TAIL = """ | |
</UL> | |
""" | |
ROULETTE = """ | |
<P>Hit your browser's Reload button to play again.<P> | |
""" | |
DELETE = """ | |
At the moment, there's no direct way to delete entries. | |
This is because the entry numbers are also their | |
unique identifiers -- it's a bad idea to renumber entries. | |
<P> | |
If you really think an entry needs to be deleted, | |
change the title to "(deleted)" and make the body | |
empty (keep the entry number in the title though). | |
""" | |
# Help file for the FAQ Edit Wizard | |
HELP = """ | |
Using the %(FAQNAME)s Edit Wizard speaks mostly for itself. Here are | |
some answers to questions you are likely to ask: | |
<P><HR> | |
<H2>I can review an entry but I can't commit it.</H2> | |
The commit button only appears if the following conditions are met: | |
<UL> | |
<LI>The Name field is not empty. | |
<LI>The Email field contains at least an @ character. | |
<LI>The Log message box is not empty. | |
<LI>The Password field contains the proper password. | |
</UL> | |
<P><HR> | |
<H2>What is the password?</H2> | |
At the moment, only PSA members will be told the password. This is a | |
good time to join the PSA! See <A | |
HREF="http://www.python.org/psa/">the PSA home page</A>. | |
<P><HR> | |
<H2>Can I use HTML in the FAQ entry?</H2> | |
Yes, if you include it in <HTML&rt; and </HTML> tags. | |
<P> | |
Also, if you include a URL or an email address in the text it will | |
automatigally become an anchor of the right type. Also, *word* | |
is made italic (but only for single alphabetic words). | |
<P><HR> | |
<H2>How do I delineate paragraphs?</H2> | |
Use blank lines to separate paragraphs. | |
<P><HR> | |
<H2>How do I enter example text?</H2> | |
Any line that begins with a space or tab is assumed to be part of | |
literal text. Blocks of literal text delineated by blank lines are | |
placed inside <PRE>...</PRE>. | |
""" | |
# Load local customizations again, in case they set some other variables | |
try: | |
from faqcust import * | |
except ImportError: | |
pass |