File: index.rst

package info (click to toggle)
python-cogapp 3.4.1-1
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 332 kB
  • sloc: python: 3,081; makefile: 55
file content (132 lines) | stat: -rw-r--r-- 4,431 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
===
Cog
===

..
    <history>
    <!-- Actually created 20040208, but not posted until the 10th. -->
    <what when='20040210T200100'>Created.</what>
    <what when='20040321T000000'>Version 1.1.</what>
    <what when='20040515T204000'>Minor edits for clarity.</what>
    <what when='20040605T140000'>Updated to cog 1.11, added a See Also section, and fixed a sample.</what>
    <what when='20040621T221600'>Updated to cog 1.12.</what>
    <what when='20041229T203300'>Updated to cog 1.2.</what>
    <what when='20041230T172100'>Updated to cog 1.3.</what>
    <what when='20050225T191900'>Updated to cog 1.4.</what>
    <what when='20050517T063000'>Added links to other Cog implementations.</what>
    <what when='20050828T125100'>Added links to 2.0 beta 2.</what>
    <what when='20051006T220000'>Updating for 2.0.</what>
    <what when='20060205T090500'>Added PCG.</what>
    <what when='20060214T195400'>Added an explicit mention of the license: MIT.</what>
    <what when='20060810T081800'>Added links to 3rd-party packages.</what>
    <what when='20070720T080700'>Clarified -D value types, and fixed a 3rd-party link.</what>
    <what when='20080318T081200'>Tried to explain better about indentation, and fixed an incorrect parameter name.</what>
    <what when='20080521T085800'>Added -U switch from Alexander Belchenko.</what>
    <what when='20080524T092000'>Fixed the russian pointer to be to a current document.</what>
    <what when='20090625T202912'>Removed handyxml, files are now at pypi.</what>
    <what when='20120205T141000'>Python 3 is supported!</what>
    <what when='20120227T192300'>Polish up Cog 2.3</what>
    <what when='20150111T203100'>Version 2.4</what>
    <what when='20190402T063800'>Version 3.0.0</what>
    <what when='20211107T112100'>Version 3.2.0</what>
    <what when='20211119T104100'>Version 3.3.0</what>
    </history>

Cog is a file generation tool.  It lets you use pieces of Python code
as generators in your source files to generate whatever text you need.

This page describes version 3.4.1, released March 7, 2024.


What does it do?
================

Cog transforms files in a very simple way: it finds chunks of Python code
embedded in them, executes the Python code, and inserts its output back into
the original file.  The file can contain whatever text you like around the
Python code.  It will usually be source code.

For example, if you run this file through cog:

.. code-block:: cpp

    // This is my C++ file.
    ...
    /*[[[cog
    import cog
    fnames = ['DoSomething', 'DoAnotherThing', 'DoLastThing']
    for fn in fnames:
        cog.outl("void %s();" % fn)
    ]]]*/
    //[[[end]]]
    ...

it will come out like this:

.. code-block:: cpp

    // This is my C++ file.
    ...
    /*[[[cog
    import cog
    fnames = ['DoSomething', 'DoAnotherThing', 'DoLastThing']
    for fn in fnames:
        cog.outl("void %s();" % fn)
    ]]]*/
    void DoSomething();
    void DoAnotherThing();
    void DoLastThing();
    //[[[end]]]
    ...

Lines with triple square brackets are marker lines.  The lines between
``[[[cog`` and ``]]]`` are the generator Python code.  The lines between
``]]]`` and ``[[[end]]]`` are the output from the generator.

Output is written with `cog.outl()`, or if you use the ``-P`` option,
normal `print()` calls.

When cog runs, it discards the last generated Python output, executes the
generator Python code, and writes its generated output into the file.  All text
lines outside of the special markers are passed through unchanged.

The cog marker lines can contain any text in addition to the triple square
bracket tokens.  This makes it possible to hide the generator Python code from
the source file.  In the sample above, the entire chunk of Python code is a C++
comment, so the Python code can be left in place while the file is treated as
C++ code.


Installation
============

Cog requires Python 3.7 or higher.

Cog is installed in the usual way, except the installation name is "cogapp",
not "cog":

.. code-block:: bash

    $ python3 -m pip install cogapp

You should now have a "cog" command you can run.

See the :ref:`changelog <changes>` for the history of changes.

Cog is distributed under the `MIT license`_.  Use it to spread goodness through
the world.

.. _MIT License: http://www.opensource.org/licenses/mit-license.php


More
====

.. toctree::
   :maxdepth: 1

   changes
   design
   source
   module
   running