File: doxycommentview.py

package info (click to toggle)
doxygen 1.15.0%2Bds1-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 25,384 kB
  • sloc: cpp: 223,248; lex: 45,536; python: 32,394; ansic: 26,761; xml: 16,962; javascript: 8,627; yacc: 582; f90: 455; php: 427; perl: 384; makefile: 201; sh: 24; objc: 14; cs: 5; java: 1
file content (75 lines) | stat: -rw-r--r-- 2,997 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
#!/usr/bin/env python3
#
# python3 helper script to start a web server that can do life rendering of doxygen comments.
#
# Copyright (C) 1997-2024 by Dimitri van Heesch.
#
# Permission to use, copy, modify, and distribute this software and its
# documentation under the terms of the GNU General Public License is hereby
# granted. No representations are made about the suitability of this software
# for any purpose. It is provided "as is" without express or implied warranty.
# See the GNU General Public License for more details.
#
# Documents produced by Doxygen are derivative works derived from the
# input used in their production; they are not affected by this license.
#

import http.server
import socketserver
import json
import subprocess
import argparse
import signal
import threading
import html

def main():
    # Set up argument parser
    parser = argparse.ArgumentParser(description="Runs the doxygen comment viewer HTTP server.")
    parser.add_argument('--port', type=int, default=8000, help='Port number to run the server on')
    parser.add_argument('--doxygen', type=str, default='doxygen', help='Path to doxygen executable')
    parser.add_argument('--doxyfile', type=str, default='Doxyfile', help='Path to Doxyfile to use')
    args = parser.parse_args()

    PORT = args.port
    DOXYGEN = args.doxygen
    DOXYFILE = args.doxyfile
    VERSION_STR = subprocess.run([DOXYGEN, '-v'], capture_output=True, text=True, encoding="utf-8").stdout

    class RequestHandler(http.server.SimpleHTTPRequestHandler):
        def do_POST(self):
            if self.path == '/process':
                content_length = int(self.headers['Content-Length'])
                post_data = self.rfile.read(content_length)
                data = json.loads(post_data)
                input_text = data['input']

                # Run doxygen in single comment mode, reading from stdin and writing to stdout and stderr
                result = subprocess.run([DOXYGEN, '-c', '-', DOXYFILE], \
                                        input=input_text, capture_output=True, text=True, encoding="utf-8")

                # Prepare the response
                response = json.dumps({
                  'html_output': result.stdout,
                  'error_output': "<b>Doxygen version "+html.escape(VERSION_STR)+"</b><pre>"+html.escape(result.stderr)+"</pre>"
                })

                # Send the result to the requesting HTML page
                self.send_response(200)
                self.send_header('Content-type', 'text/html')
                self.end_headers()
                self.wfile.write(response.encode())

    httpd = socketserver.TCPServer(("", PORT), RequestHandler)

    def signal_handler(sig, frame):
        print('Shutting down the web server...')
        threading.Thread(target=httpd.shutdown).start()

    signal.signal(signal.SIGINT, signal_handler)

    print("Running web server on port", PORT)
    httpd.serve_forever()

if __name__ == '__main__':
    main()