summaryrefslogtreecommitdiff
path: root/etc/BABYL
diff options
context:
space:
mode:
Diffstat (limited to 'etc/BABYL')
-rw-r--r--etc/BABYL176
1 files changed, 176 insertions, 0 deletions
diff --git a/etc/BABYL b/etc/BABYL
new file mode 100644
index 00000000000..987d1283aba
--- /dev/null
+++ b/etc/BABYL
@@ -0,0 +1,176 @@
+Format of Version 5 Babyl Files:
+
+Warning:
+
+ This was written Tuesday, 12 April 1983 (by Eugene Ciccarelli),
+based on looking at a particular Babyl file and recalling various
+issues. Therefore it is not guaranteed to be complete, but it is a
+start, and I will try to point the reader to various Babyl functions
+that will serve to clarify certain format questions.
+
+ Also note that this file will not contain control-characters,
+but instead have two-character sequences starting with Uparrow.
+Unless otherwise stated, an Uparrow <character> is to be read as
+Control-<character>, e.g. ^L is a Control-L.
+
+Versions:
+
+ First, note that each Babyl file contains in its BABYL OPTIONS
+section the version for the Babyl file format. In principle, the
+format can be changed in any way as long as we increment the format
+version number; then programs can support both old and new formats.
+
+ In practice, version 5 is the only format version used, and the
+previous versions have been obsolete for so long that Emacs does not
+support them.
+
+
+Overall Babyl File Structure:
+
+ A Babyl file consists of a BABYL OPTIONS section followed by
+0 or more message sections. The BABYL OPTIONS section starts
+with the line "BABYL OPTIONS:". Message sections start with
+Control-Underscore Control-L Newline. Each section ends
+with a Control-Underscore. (That is also the first character
+of the starter for the next section, if any.) Thus, a three
+message Babyl file looks like:
+
+BABYL OPTIONS:
+...the stuff within the Babyl Options section...
+^_^L
+...the stuff within the 1st message section...
+^_^L
+...the stuff within the 2nd message section...
+^_^L
+...the stuff within the last message section...
+^_
+
+ Babyl is tolerant about some whitespace at the end of the
+file -- the file may end with the final ^_ or it may have some
+whitespace, e.g. a newline, after it.
+
+
+The BABYL OPTIONS Section:
+
+ Each Babyl option is specified on one line (thus restricting
+string values these options can currently have). Values are
+either numbers or strings. The format is name, colon, and the
+value, with whitespace after the colon ignored, e.g.:
+
+Mail: ~/special-inbox
+
+ Unrecognized options are ignored.
+
+ Here are those options and the kind of values currently expected:
+
+ MAIL Filename, the input mail file for this
+ Babyl file. You may also use several file names
+ separated by commas.
+ Version Number. This should always be 5.
+ Labels String, list of labels, separated by commas.
+
+
+Message Sections:
+
+ A message section contains one message and information
+associated with it. The first line is the "status line", which
+contains a bit (0 or 1 character) saying whether the message has
+been reformed yet, and a list of the labels attached to this
+message. Certain labels, called basic labels, are built into
+Babyl in a fundamental way, and are separated in the status line
+for convenience of operation. For example, consider the status
+line:
+
+1, answered,, zval, bug,
+
+ The 1 means this message has been reformed. This message is
+labeled "answered", "zval", and "bug". The first, "answered", is
+a basic label, and the other two are user labels. The basic
+labels come before the double-comma in the line. Each label is
+preceded by ", " and followed by ",". (The last basic label is
+in fact followed by ",,".) If this message had no labels at all,
+it would look like:
+
+1,,
+
+ Or, if it had two basic labels, "answered" and "deleted", it
+would look like:
+
+1, answered, deleted,, zval, bug,
+
+ The & Label Babyl Message knows which are the basic labels.
+Currently they are: deleted, unseen, recent, and answered.
+
+ After the status line comes the original header if any.
+Following that is the EOOH line, which contains exactly the
+characters "*** EOOH ***" (which stands for "end of original
+header"). Note that the original header, if a network format
+header, includes the trailing newline. And finally, following the
+EOOH line is the visible message, header and text. For example,
+here is a complete message section, starting with the message
+starter, and ending with the terminator:
+
+^_^L
+1,, wordab, eccmacs,
+Date: 11 May 1982 21:40-EDT
+From: Eugene C. Ciccarelli <ECC at MIT-AI>
+Subject: notes
+To: ECC at MIT-AI
+
+*** EOOH ***
+Date: Tuesday, 11 May 1982 21:40-EDT
+From: Eugene C. Ciccarelli <ECC>
+To: ECC
+Re: notes
+
+Remember to pickup check at cashier's office, and deposit it
+soon. Pay rent.
+^_
+
+;;; Babyl File BNF:
+
+;;; Overall Babyl file structure:
+
+
+Babyl-File ::= Babyl-Options-Section (Message-Section)*
+
+
+;;; Babyl Options section:
+
+
+Babyl-Options-Section
+ ::= "BABYL OPTIONS:" newline (Babyl-Option)* Terminator
+
+Babyl-Option ::= Option-Name ":" Horiz-Whitespace BOptValue newline
+
+BOptValue ::= Number | 1-Line-String
+
+
+
+;;; Message section:
+
+
+Message-Section ::= Message-Starter Status-Line Orig-Header
+ EOOH-Line Message Terminator
+
+Message-Starter ::= "^L" newline
+
+Status-Line ::= Bit-Char "," (Basic-Label)* "," (User-Label)* newline
+
+Basic-Label ::= Space BLabel-Name ","
+
+User-Label ::= Space ULabel-Name ","
+
+EOOH-Line ::= "*** EOOH ***" newline
+
+Message ::= Visible-Header Message-Text
+
+
+;;; Utilities:
+
+Terminator ::= "^_"
+
+Horiz-Whitespace
+ ::= (Space | Tab)*
+
+Bit-Char ::= "0" | "1"