This file is indexed.

/usr/bin/pymvpa2-tutorial is in python-mvpa2 2.2.0-4ubuntu2.

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
#!/usr/bin/python
# emacs: -*- mode: python; py-indent-offset: 4; indent-tabs-mode: nil -*-
# vi: set ft=python sts=4 ts=4 sw=4 et:
### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ##
#
#   See COPYING file distributed along with the PyMVPA package for the
#   copyright and license terms.
#
### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ##
"""Script to start a PyMVPA tutorial session"""

import sys
import os
import shutil
import glob
import getopt
import subprocess
import signal

import mvpa2
from mvpa2.misc.support import SmartVersion

def getandkillopt(opt):
    for i, arg in enumerate(sys.argv[1:]):
        if arg.startswith(opt):
            if opt.endswith('='):
                val = '='.join(sys.argv[i + 1].split('=')[1:])
            else:
                val = True
            del sys.argv[i + 1]
            return val
    return False

def print_help():
    print """
Usage: %s [options] [ipython options]

Wrapper around the IPython executable creating a session directory for working
with the PyMVPA tutorial. The necessary tutorial data is copied (or symlinked,
if possible) into the session directory. If the tutorial shall run in IPython's
notebook the relevant notebook files are copied into the session directory as
well. Any additional options are passed on to IPython. IPython is executed
in the tutorial session directory, and any potential relative path
configurations (such as PYTHONPATH) need to take this into account.

Options:
  --help                print this help and exit
  --version             show program's version number and exit
  --use-qtconsole       start an IPython qtconsole
  --use-notebook        start an IPython notebook server
  --workdir             path to the tutorial session directory.
                        Default: $HOME/pymvpa2_tutorial
  --clean-workdir       delete tutorial session data on exit
  --overwrite-notebook  overwrite existing notebook files in the tutorial
                        session directory
  --tutorial-data-path  path to the tutorial data (need to contain
                        'data' and 'results' directories)
  --tutorial-notebooks-path
                        path to the tutorial notebooks
""" % sys.argv[0]

def get_latest_ipython(ipythons=['ipython01x', 'ipython']):
    """Choose the latest available ipython according to -V
    """
    avail = []
    for ipython in ipythons:
        try:
            p = subprocess.Popen([ipython, '-V'],
                                 stdout=subprocess.PIPE,
                                 stderr=subprocess.PIPE)
            l = p.stdout.read().split('\n')
            l = [x for x in l if len(x)]    # strip empty lines
            if len(l):
                ver = SmartVersion(l[-1])
                avail.append((ver, ipython))
        except OSError:
            pass
    avail = sorted(avail)
    if len(avail):
        return avail[-1]
    else:
        return None, None

def main():
    if getandkillopt('--version'):
        print mvpa2.__version__
        sys.exit(0)
    if getandkillopt('--help'):
        print_help()
        sys.exit(0)

    want_qtconsole = getandkillopt('--use-qtconsole')
    want_notebook = getandkillopt('--use-notebook')
    want_clean = getandkillopt('--clean-workdir')
    want_overwrite_notebooks = getandkillopt('--overwrite-notebooks')
    workdir = getandkillopt('--workdir=')
    if workdir is False:
        # TODO create tmpdir
        workdir=os.path.expanduser('~/pymvpa2_tutorial')
    if not os.path.exists(workdir):
        os.makedirs(workdir)
    tutorial_datadir = getandkillopt('--tutorial-data-path=')
    if tutorial_datadir is False:
        tutorial_datadir = '/usr/share/data/pymvpa2-tutorial'
    notebook_srcdir = getandkillopt('--tutorial-notebooks-path=')
    if notebook_srcdir is False:
        notebook_srcdir = '/usr/share/doc/python-mvpa2/notebooks'
    # assemble session dir
    for dir in ('data', 'results'):
        src = os.path.join(os.path.abspath(tutorial_datadir), dir)
        dst = os.path.join(os.path.abspath(workdir), dir)
        if os.path.lexists(dst):
            print "Use existing tutorial '%s' path at '%s'." \
                  % (dir, dst)
            continue
        if not os.path.exists(src):
            print "Cannot find tutorial data at '%s'" % src
            sys.exit(1)
        if hasattr(os, 'symlink'):
            os.symlink(src, dst)
        else:
            shutil.copytree(src, dst)
    ipy_args = sys.argv[1:]
    ipy_args.append('--quiet')
    if not sum([arg.startswith('--pylab') for arg in ipy_args]):
        # user might want something like --pylab=inline
        ipy_args.append('--pylab')
    if want_notebook:
        ipy_args.insert(0, 'notebook')
    elif want_qtconsole:
        ipy_args.insert(0, 'qtconsole')

    if want_notebook:
        notebook_dstdir = workdir
        ipy_args.append('--notebook-dir=%s' % notebook_dstdir)
        if not os.path.exists(notebook_dstdir):
            os.makedirs(notebook_dstdir)
        notebook_files = glob.glob(os.path.join(notebook_srcdir, '*.ipynb'))
        if not len(notebook_files):
            print "Beware: no notebooks found under %s" % notebook_srcdir
        for nb in notebook_files:
            nb_dst_filepath = os.path.join(notebook_dstdir, os.path.basename(nb))
            if not os.path.exists(nb_dst_filepath) or want_overwrite_notebooks:
                shutil.copyfile(nb, nb_dst_filepath)
            else:
                print "Keep existing notebook at '%s'" % nb_dst_filepath

    ipython_ver, ipython = get_latest_ipython()
    if ipython_ver is None:
        raise SystemExit("No reasonably versioned IPython was found")
    if ipython_ver < '0.12' and want_notebook:
        raise SystemExit(
            "ERROR: no notebook facilities are available in IPython prior " \
            "version 0.12. Detected version of IPython on the system %s " \
            "by %s" % (ipython_ver.vstring, ipython))
    try:
        ipy = subprocess.Popen([ipython] + ipy_args, cwd=workdir)
        ipy.wait()
    except KeyboardInterrupt:
        ipy.terminate()
    if want_clean:
        shutil.rmtree(workdir)

if __name__ == '__main__':
    main()