summaryrefslogtreecommitdiffstats
path: root/meta/recipes-extended/texinfo-dummy-native/texinfo-dummy/template.py
blob: e369f74455f6936792b02310e5518e9b0f69d758 (plain)
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
#! /usr/bin/env python3

# template.py (and other filenames)
# By Max Eliaser (max.eliaser@intel.com)

# Copyright (c) 2014 Intel Corp.

# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:

# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.

# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
# THE SOFTWARE.

# This program acts like a dummy version of the texinfo utilities, creating
# the right output files but leaving them blank. It will parse out the name
# of the executable from argv[0] and emulate the corresponding program, so
# multiple copies of this script will exist under different names.

import sys, os

olong = "--output="
Elong = "--macro-expand="


this_binary = sys.argv[0].split ("/")[-1]

# To be outputted if functionality that hasn't been stubbed yet is invoked.
stub_msg = """
This stand-in version of %s is not yet fully capable of emulating the real
version from the GNU texinfo suite. If you see this message, file a bug report
with details on the recipe that failed.
""" % this_binary

# Autotools setups query the version, so this is actually necessary. Some of
# them (lookin' at you, glibc) actually look for the substring "GNU texinfo,"
# so we put that substring in there without actually telling a lie.
version_str = """ %s (fake texinfo, emulating GNU texinfo) 5.2
 
Super amazing version which is totally not fake in any way whatsoever.
Copyright (C) 2014 Intel Corp. Distributed under the terms of the MIT
license.
""" % this_binary

simple_binaries = "pod2texi texi2dvi pdftexi2dvi texindex texi2pdf \
                   txixml2texi install-info ginstall-info \
                   update-info-dir".split ()

# These utilities use a slightly different set of options and flags.
complex_binaries = "makeinfo texi2any".split ()

valid_binaries = simple_binaries + complex_binaries

# For generating blank output files.
def touch_file (path):
    f = open (path, "w")
    f.close ()

assert this_binary in valid_binaries, \
       this_binary + " is not one of " + ', '.join (valid_binaries)

if "--version" in sys.argv:
    print(version_str)
    sys.exit (0)

# For debugging
log_interceptions = False
if log_interceptions:
    f = open ("/tmp/intercepted_" + this_binary, "a")
    f.write (' '.join ([this_binary] + sys.argv[1:]) + '\n')
    f.close ()

# Look through the options and flags, and if necessary, touch any output
# files.
arg_idx = 1
while arg_idx < len (sys.argv):
    arg = sys.argv [arg_idx]
    
    if arg == "--":
        break
    
    # Something like -I . can result in a need for this (specifically the .)
    elif len (arg) < 2:
        pass
    
    # Check if -o or --output is specified. These can be used at most once.
    elif arg[0] == '-' and arg[1] != '-' and arg[len (arg) - 1] == 'o':
        touch_file (sys.argv[arg_idx + 1])
        sys.exit (0)
    elif arg.startswith (olong):
        touch_file (arg.split ("=")[1])
        sys.exit (0)
    
    # Check for functionality that isn't implemented yet.
    else:
        assert arg[0] != '-' or arg[1] == '-' or 'E' not in arg or \
               this_binary in simple_binaries, \
               "-E option not yet supported" + stub_msg
        
        assert not arg.startswith (Elong), \
               Elong[:-1] + " option not yet supported" + stub_msg
    
    arg_idx += 1

# The -o/--output option overrides the default. For makeinfo and texi2any,
# that default is to look for a @setfilename command in the input file.
# Otherwise, printing nothing to stdout and then exiting should suffice.
assert this_binary in simple_binaries, \
       "Don't know how to get default output file name from input file!" + \
       stub_msg