VirtualBox

source: vbox/trunk/doc/manual/add_file_to_id_only_references.py@ 107404

Last change on this file since 107404 was 107404, checked in by vboxsync, 4 weeks ago

Docs: bugref:10705. bugref:10829. Build fix.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.8 KB
Line 
1#!/usr/bin/env python3
2__copyright__ = \
3"""
4Copyright (C) 2023-2024 Oracle and/or its affiliates.
5
6This file is part of VirtualBox base platform packages, as
7available from https://www.virtualbox.org.
8
9This program is free software; you can redistribute it and/or
10modify it under the terms of the GNU General Public License
11as published by the Free Software Foundation, in version 3 of the
12License.
13
14This program is distributed in the hope that it will be useful, but
15WITHOUT ANY WARRANTY; without even the implied warranty of
16MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17General Public License for more details.
18
19You should have received a copy of the GNU General Public License
20along with this program; if not, see <https://www.gnu.org/licenses>.
21
22SPDX-License-Identifier: GPL-3.0-only
23"""
24
25# Standard python imports.
26import glob;
27import os;
28import re;
29import sys;
30
31
32g_oReHref = re.compile(r'\bhref=("[^">#./]+"|\'[^\'>#./]+\')');
33
34def modifyDitaFile(dIdToFile, sContent):
35 """
36 Modifies the href attributes in this file.
37 """
38 current_file_is_refentry = False
39 if any(current_file_name.lower() in s.lower() for s in refentry_files):
40 current_file_is_refentry = True
41 sModified = '';
42 offPrev = 0;
43 for oMatch in g_oReHref.finditer(sContent):
44 sId = oMatch.group(1)[1:-1];
45 if sId in dIdToFile:
46 reference_is_refentry = False
47 if any(os.path.splitext(dIdToFile[sId])[0].lower() in s.lower() for s in refentry_files):
48 reference_is_refentry = True
49 if current_file_is_refentry and not reference_is_refentry:
50 sModified += sContent[offPrev : oMatch.start(1)] + '"../topics/' + dIdToFile[sId] + '#' + sId + '"';
51 else:
52 sModified += sContent[offPrev : oMatch.start(1)] + '"' + dIdToFile[sId] + '#' + sId + '"';
53 offPrev = oMatch.end(1);
54 if offPrev < len(sContent):
55 sModified += sContent[offPrev:];
56 return sModified;
57
58def info(sMessage):
59 """ Info message. """
60 print('add_file_to_id_only_references.py: info: %s' % sMessage);
61 return 1;
62
63def error(sMessage):
64 """ Reports an error. """
65 print('add_file_to_id_only_references.py: error: %s' % sMessage, file = sys.stderr);
66 return 1;
67
68def syntax(sMessage):
69 """ Reports a syntax error. """
70 print('add_file_to_id_only_references.py: syntax error: %s' % sMessage, file = sys.stderr);
71 return 2;
72
73def usage():
74 """ Reports usage. """
75 print('usage: add_file_to_id_only_references.py [--verbose|--quiet] --mapping-file <map.db> file1.dita [file2.dita [...]]');
76 return 0;
77
78def main(asArgs):
79 dIdToFile = None;
80 fEndOfArgs = False;
81 fVerbose = False;
82 iArg = 1;
83 while iArg < len(asArgs):
84 sArg = asArgs[iArg];
85 if sArg[0] == '-' and not fEndOfArgs:
86 # Options.
87 if sArg == '--':
88 fEndOfArgs = True;
89 elif sArg in ('--help', '-h', '-?'):
90 return usage();
91 elif sArg in ('--version', '-V' ):
92 print(__version__[__version__.find(':') + 2:-2]);
93 elif sArg in ('--quiet', '-q' ):
94 fVerbose = False;
95 elif sArg in ('--verbose', '-v' ):
96 fVerbose = True;
97 elif sArg in ('--refentry_file_list', '-f' ):
98 iArg += 1;
99 if iArg >= len(asArgs):
100 return syntax('Expected a list of refentry files following "--refentry_file_list"!');
101 global refentry_files
102 refentry_files = asArgs[iArg].split(' ')
103 elif sArg in ('--mapping-file', '-m'):
104 iArg += 1;
105 if iArg >= len(asArgs):
106 return syntax('Expected filename following "--mapping-file"!');
107 # Load the database file.
108 sArg = asArgs[iArg];
109 try:
110 with open(sArg, 'r', encoding = 'utf-8') as oFile:
111 dIdToFile = {};
112 for sLine in oFile:
113 sId, sFile = sLine.split('=');
114 dIdToFile[sId.strip()] = sFile.strip();
115 except Exception as oXcpt: # pylint: disable=broad-exception-caught
116 return error('Failed to open and parse "%s": %s' % (sArg, oXcpt,));
117 if fVerbose:
118 info('Loaded %s IDs from "%s"' % (len(dIdToFile), sArg));
119 else:
120 return syntax('Unknown option: %s' % (sArg,));
121 else:
122 # File to modify.
123 if dIdToFile is None:
124 return syntax('A mapping database must be given before any other files!');
125
126 try:
127 with open(sArg, 'r', encoding = 'utf-8') as oFile:
128 sContent = oFile.read();
129 except Exception as oXcpt: # pylint: disable=broad-exception-caught
130 return error('Failed to open and read "%s": %s' % (sArg, oXcpt,));
131 global current_file_name
132 current_file_name = os.path.splitext(os.path.basename(sArg))[0]
133 prefix = "flat-"
134 if current_file_name.startswith(prefix):
135 current_file_name = current_file_name[len(prefix):]
136 sModified = modifyDitaFile(dIdToFile, sContent);
137 if sModified != sContent:
138 if fVerbose:
139 info('Writing out modified "%s"...' % (sArg,));
140 try:
141 with open(sArg, 'w', encoding = 'utf-8') as oFile:
142 oFile.write(sModified);
143 except Exception as oXcpt: # pylint: disable=broad-exception-caught
144 return error('Failed to open and write back "%s": %s' % (sArg, oXcpt,));
145 elif fVerbose:
146 info('No changes to "%s"...' % (sArg,));
147
148 iArg += 1;
149 return 0;
150
151if __name__ == "__main__":
152 main(sys.argv)
153
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette