changeset 33:b01f1bb3ad57

More work on documentation.
author Brian Neal <bgneal@gmail.com>
date Fri, 01 Jun 2012 23:10:17 -0500 (2012-06-02)
parents 5c33e81fbc7d
children 4a9c4d3ced13
files enigma/docs/source/conf.py enigma/docs/source/index.rst enigma/docs/source/keyfile.rst enigma/docs/source/library.rst enigma/docs/source/pyenigma.rst enigma/machine.py
diffstat 6 files changed, 103 insertions(+), 7 deletions(-) [+]
line wrap: on
line diff
--- a/enigma/docs/source/conf.py	Thu May 31 20:55:23 2012 -0500
+++ b/enigma/docs/source/conf.py	Fri Jun 01 23:10:17 2012 -0500
@@ -242,3 +242,9 @@
 
 # How to display URL addresses: 'footnote', 'no', or 'inline'.
 #texinfo_show_urls = 'footnote'
+
+
+# -- Py-Enigma customizations --------------------------------------------------
+
+autoclass_content = 'both'
+
--- a/enigma/docs/source/index.rst	Thu May 31 20:55:23 2012 -0500
+++ b/enigma/docs/source/index.rst	Fri Jun 01 23:10:17 2012 -0500
@@ -13,7 +13,12 @@
 :License: MIT License (see LICENSE.txt)
 :Support: https://bitbucket.org/bgneal/enigma/issues
 
-Contents:
+Py-Enigma is a historically accurate `Enigma machine
+<http://en.wikipedia.org/wiki/Enigma_machine>`_ simulation library written in
+Python. Py-Enigma includes a simple command-line application to allow for quick
+experimenting and scripting.
+
+Documentation contents:
 
 .. toctree::
    :maxdepth: 2
@@ -21,6 +26,7 @@
    overview
    library
    pyenigma
+   keyfile
 
 Indices and tables
 ==================
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/enigma/docs/source/keyfile.rst	Fri Jun 01 23:10:17 2012 -0500
@@ -0,0 +1,2 @@
+Key file format
+===============
--- a/enigma/docs/source/library.rst	Thu May 31 20:55:23 2012 -0500
+++ b/enigma/docs/source/library.rst	Fri Jun 01 23:10:17 2012 -0500
@@ -1,8 +1,88 @@
 Library Documentation
 =====================
 
+The Py-Enigma simulation is made up of several Python classes as described
+below.
+
 EnigmaMachine Class Reference
 -----------------------------
 
-.. autoclass:: enigma.machine.EnigmaMachine
-   :members:
+The top-level ``EnigmaMachine`` class represents an assembled Enigma machine.
+The ``EnigmaMachine`` class resides in the ``enigma.machine`` module.
+
+.. class:: enigma.machine.EnigmaMachine(rotors, reflector, plugboard)
+
+   Top-level class that represents Enigma machines.
+
+   :param rotors: A list containing 3 or 4 (for the Kriegsmarine M4 version)
+      :class:`Rotor <enigma.rotors.rotor.Rotor>` objects. The order of the
+      list is important. The first rotor is the left-most rotor, and the last
+      rotor is the right-most (from the operator's perspective sitting at the
+      machine).
+   :param reflector: A :class:`Rotor <enigma.rotors.rotor.Rotor>` object that
+      represents the reflector (*UKW*).
+   :param plugboard: A :class:`Plugboard <enigma.plugboard.Plugboard>` object
+      that represents the state of the plugboard (*Steckerbrett*).
+
+   .. classmethod:: from_key_sheet([rotors='I II III'[, ring_settings=None[, \
+            reflector='B'[, plugboard_settings=None]]]])
+
+      Convenience function to build an EnigmaMachine from the data as you
+      might find it on a monthly key sheet (code book).
+
+      :param rotors: Either a list of strings naming the rotors from left to
+         right or a single string: e.g. ``["I", "III", "IV"]`` or ``"I III IV"``.
+      :param ring_settings: Either a list/tuple of integers, a string, or ``None``
+         to represent the ring settings to be applied to the rotors in the
+         rotors list (see below).
+      :param reflector: A string that names the reflector to use.
+      :param plugboard_settings: A string of plugboard settings as you might
+         find on a key sheet (see below).
+       
+      The ``ring_settings`` parameter can accept either:
+
+      * A list/tuple of integers with values between 0-25.
+      * A string; either space separated letters or numbers, e.g.
+        ``'B U L'`` or ``'1 20 11'``.
+      * ``None`` means all ring settings are 0.
+
+      The ``plugboard_settings`` parameter can accept either:
+
+      * A string of space separated letter pairs; e.g. ``'PO ML IU KJ NH YT GB VF RE DC'``.
+      * A string of slash separated number pairs; e.g. ``'18/26 17/4 21/6 3/16 19/14 22/7 8/1 12/25 5/9 10/15'``.
+      * A value of ``None`` means no plugboard connections are made.
+
+   .. classmethod:: from_key_file(fp[, day=None])
+
+      Convenience function to build an EnigmaMachine by reading key parameters
+      from a file.
+
+      :param fp: A file-like object that contains daily key settings, one day's
+         settings per line.
+      :param day: The line in the file labeled with the day number (1-31) will
+         be used for the settings. If day is ``None``, the day number will be
+         determined from today's date. 
+
+      For more information on the file format, see :doc:`Key File Format <keyfile>`.
+
+   .. method:: set_display(val)
+
+      Sets the simulated rotor operator windows to *val*. This establishes a new
+      starting position for a subsequent encrypt or decrypt operation. See also
+      :meth:`get_display`.
+
+      :param val: Must be a string or iterable containing uppercase letter values, one
+         for each window from left to right. For example, a valid value for a 3 rotor
+         machine would be ``'ABC'``.
+
+   .. method:: get_display(val)
+
+      This method returns the current position of the rotors as a string. See
+      also :meth:`set_display`.
+
+      :returns: a string of uppercase letters, one for each rotor
+      :rtype: string
+
+.. class:: enigma.rotors.rotor.Rotor(x, y)
+
+   Rotor class
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/enigma/docs/source/pyenigma.rst	Fri Jun 01 23:10:17 2012 -0500
@@ -0,0 +1,2 @@
+pyenigma command-line application
+=================================
--- a/enigma/machine.py	Thu May 31 20:55:23 2012 -0500
+++ b/enigma/machine.py	Fri Jun 01 23:10:17 2012 -0500
@@ -73,8 +73,8 @@
 
         reflector: a string that names the reflector to use
 
-        plugboard: a string of plugboard settings as you might find on a key
-        sheet; e.g. 
+        plugboard_settings: a string of plugboard settings as you might find
+        on a key sheet; e.g. 
             'PO ML IU KJ NH YT GB VF RE DC' 
         or
             '18/26 17/4 21/6 3/16 19/14 22/7 8/1 12/25 5/9 10/15'
@@ -131,8 +131,8 @@
     def set_display(self, val):
         """Sets the rotor operator windows to 'val'.
 
-        'val' must be a string or iterable containing 3 values, one for each
-        window from left to right.
+        'val' must be a string or iterable containing values for each window
+        from left to right.
 
         """
         if len(val) != self.rotor_count: