This file is indexed.

/usr/share/sagemath/bin/sage-sws2rst is in sagemath-common 8.1-7ubuntu1.

This file is owned by root:root, with mode 0o755.

The actual contents of the file can be viewed below.

  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
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
#!/usr/bin/env python
# -*- coding: utf-8 -*-
r"""
sage-sws2rst
============

Translate a Sage worksheet file (.sws) into an rst file. The result is
saved in the current working directory.

Usage::

    sage --sws2rst [-h] <source sws file>

Print the help message::

    sage --sws2rst -h

EXAMPLES::

    sage --sws2rst file.sws

AUTHORS:

- Pablo Angulo (January 2011): Initial version
- Karl-Dieter Crisman (June 2012): Documentation
  and minor refinements
- Karl-Dieter Crisman (November 2014): Correct use of temporary files,
  see :trac:`17308`.
"""

#*****************************************************************************
#       Copyright (C) 2011 Pablo Angulo
#       Copyright (C) 2012-2014 Karl-Dieter Crisman
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 2 of the License, or
# (at your option) any later version.
#                  http://www.gnu.org/licenses/
#*****************************************************************************

import sys
import tarfile
import os
import shutil
import codecs
import tempfile
from sagenb.misc.worksheet2rst import worksheet2rst

from optparse import OptionParser


def process_sws(sws_file):
    """
    Process the ``.sws`` file ``sws_file`` and create an ``.rst`` file
    (and possible media files) in the current working directory.
    """
    base_name = os.path.basename(os.path.splitext(sws_file)[0])
    base_name = base_name.replace(' ','_')

    tempdir = tempfile.mkdtemp()
    try:
        with tarfile.open(sws_file, mode='r:bz2') as sws_file:
            sws_file.extractall(tempdir)
        worksheet_dir = os.path.join(tempdir, 'sage_worksheet')
        if not os.path.isdir(worksheet_dir):
            raise RuntimeError("Worksheeet file %r does not contain a 'sage_worksheet' directory" % sws_file)
        process_worksheet(worksheet_dir, base_name)
    finally:
        shutil.rmtree(tempdir)

def process_worksheet(worksheet_dir, base_name):
    """
    Process the extracted worksheet directory ``worksheet_dir`` and
    create the ``.rst`` and media files with base name ``base_name``.

    Files are moved from ``worksheet_dir``, so make sure these are
    temporary files!
    """
    #Images
    images_dir = base_name + '_media'
    try:
        os.mkdir(images_dir)
    except OSError:
        if not os.path.isdir(images_dir):
            raise

    #"data" dir
    data_path = os.path.join(worksheet_dir, 'data')
    if os.path.isdir(data_path):
        for image in os.listdir(data_path):
            shutil.move(os.path.join(data_path, image), os.path.join(images_dir, image.replace(' ','_')))

    #cells
    cells_path = os.path.join(worksheet_dir, 'cells')
    if os.path.isdir(cells_path):
        for cell in os.listdir(cells_path):
            cell_path = os.path.join(cells_path, cell)
            for image in os.listdir(cell_path):
                if os.path.isfile(os.path.join(cell_path, image)):
                    shutil.move(os.path.join(cell_path, image),
                                 os.path.join(images_dir, 'cell_%s_%s'%(cell,image)))
                # could be Jmol image directory - code for future
                #elif os.path.isdir(os.path.join(cell_path, image)):
                #    if image == '.jmol_images':
                #        for jmolimg in os.listdir(os.path.join(cell_path, image)):
                #            shutil.move(os.path.join(cell_path, image, jmolimg),
                #                     os.path.join(images_dir, 'cell_%s_%s'%(cell,jmolimg)))

    #read html file, parse it, write rst file
    html_file = os.path.join(worksheet_dir, 'worksheet.html')
    with codecs.open(html_file, mode='r', encoding='utf-8') as f:
        html_text = f.read()

    rst_text = worksheet2rst(html_text, images_dir=images_dir)
    rst_file = base_name + '.rst'

    with codecs.open(rst_file, mode='w', encoding='utf-8') as out_file:
        out_file.write(rst_text)

    print("File at", rst_file)
    print("Image directory at", images_dir)


# Set the parser
usage = r"""

    sage --sws2rst [options]  <source sws file> ...

Translate a Sage worksheet file (.sws) into an reStructuredText
(.rst) file.  At least one sws file argument is required; all sws
files will be parsed and translated.  Spaces in the names of the
worksheet will be converted to underscores. The resulting files will
be stored in the current working directory.

Examples:

    sage --sws2rst file.sws
    sage --sws2rst file1.sws file2.sws file3.sws
    sage --sws2rst -h # this help message prints
    sage --sws2rst --sphinxify # information about how to use
                               # Sphinx to compile your rst file
"""

sphinxify_text = r"""

Once you have made your rst file, what can you do with it?

If this is a file which is likely to become part of the Sage
standard documentation, you will want to edit the appropriate
file in $SAGE_ROOT/src/doc to include your file, or
simply include your file as appropriate.

However, you may simply want to make great-looking documentation
for some other purpose out of your worksheet.  The following
steps are one way to do so.

 - Assume that the generated .rst file is ``My_Project.rst``.
 - Make a folder somewhere convenient to compile in, say, ``MyProject``.
 - Then move your .rst file into that folder, and cd into it.
 - Now the key is to use Sage's shell to run Sphinx on it! Run ``sage --sh``.
 - Then type ``sphinx-quickstart`` and follow the instructions in the
   Sphinx tutorial [1]_. You will probably want to choose to render math
   with MathJax [2]_, but you can accept the defaults for the other options.
 - Finally, edit ``index.rst`` by adding ``My_Project`` in the table of
   contents, as detailed in the Sphinx tutorial [3]_.
 - If you now type ``make html`` you should get a beautiful-looking web page
   in ``_build/html``. If you did not have a header at the top of your worksheet,
   you may get an error, but you can ignore this.

REFERENCES:

.. [1] First Steps with Sphinx,
   http://sphinx.pocoo.org/tutorial.html
.. [2] MathJax,
   http://www.mathjax.org/
.. [3] Defining Document Structure, First Steps with Sphinx,
   http://sphinx.pocoo.org/tutorial.html#defining-document-structure"""

parser = OptionParser(usage=usage)
parser.add_option("--sphinxify",
                  action="store_true", dest="sphinxify",
                  help="Print information about how to use Sphinx to compile your rst file, then exit.")
(options, args) = parser.parse_args()

# Parse option
if options.sphinxify:
    print(sphinxify_text)
    sys.exit(0)

# Parse arguments
if len(args) < 1:
    parser.print_usage()
    sys.exit(1)

for file_name in args:
    print("Processing", file_name)
    process_sws(file_name)