/edk2/AppPkg/Applications/Python/Python-2.7.2/Tools/faqwiz/faqconf.py
Python | 577 lines | 543 code | 4 blank | 30 comment | 0 complexity | 9435497732119a930505160874966d66 MD5 | raw file
- """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