2020-03-10 19:10:54 +01:00
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
"""
|
|
|
|
|
pygments.lexers.c_cpp
|
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
|
|
Lexers for C/C++ languages.
|
|
|
|
|
|
|
|
|
|
:copyright: Copyright 2006-2019 by the Pygments team, see AUTHORS.
|
|
|
|
|
:license: BSD, see LICENSE for details.
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
import re
|
2021-09-17 20:42:51 +02:00
|
|
|
|
import sphinx_rtd_theme
|
2020-03-10 19:10:54 +01:00
|
|
|
|
|
2022-05-12 13:58:32 +02:00
|
|
|
|
from pygments.lexer import (
|
|
|
|
|
RegexLexer,
|
|
|
|
|
include,
|
|
|
|
|
bygroups,
|
|
|
|
|
using,
|
|
|
|
|
this,
|
|
|
|
|
inherit,
|
|
|
|
|
default,
|
|
|
|
|
words,
|
|
|
|
|
)
|
2020-03-10 19:10:54 +01:00
|
|
|
|
from pygments.util import get_bool_opt
|
2022-05-12 13:58:32 +02:00
|
|
|
|
from pygments.token import (
|
|
|
|
|
Text,
|
|
|
|
|
Comment,
|
|
|
|
|
Operator,
|
|
|
|
|
Keyword,
|
|
|
|
|
Name,
|
|
|
|
|
String,
|
|
|
|
|
Number,
|
|
|
|
|
Punctuation,
|
|
|
|
|
Error,
|
|
|
|
|
)
|
2020-03-10 19:10:54 +01:00
|
|
|
|
from sphinx.highlighting import lexers
|
|
|
|
|
|
2022-05-12 13:58:32 +02:00
|
|
|
|
|
2020-03-10 19:10:54 +01:00
|
|
|
|
class MyCFamilyLexer(RegexLexer):
|
|
|
|
|
#: optional Comment or Whitespace
|
2022-05-12 13:58:32 +02:00
|
|
|
|
_ws = r"(?:\s|//.*?\n|/[*].*?[*]/)+"
|
2020-03-10 19:10:54 +01:00
|
|
|
|
|
|
|
|
|
# The trailing ?, rather than *, avoids a geometric performance drop here.
|
|
|
|
|
#: only one /* */ style comment
|
2022-05-12 13:58:32 +02:00
|
|
|
|
_ws1 = r"\s*(?:/[*].*?[*]/\s*)?"
|
2020-03-10 19:10:54 +01:00
|
|
|
|
|
|
|
|
|
tokens = {
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"whitespace": [
|
2020-03-10 19:10:54 +01:00
|
|
|
|
# preprocessor directives: without whitespace
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(r"^#if\s+0", Comment.Preproc, "if0"),
|
|
|
|
|
("^#", Comment.Preproc, "macro"),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
# or with whitespace
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(
|
|
|
|
|
"^(" + _ws1 + r")(#if\s+0)",
|
|
|
|
|
bygroups(using(this), Comment.Preproc),
|
|
|
|
|
"if0",
|
|
|
|
|
),
|
|
|
|
|
("^(" + _ws1 + ")(#)", bygroups(using(this), Comment.Preproc), "macro"),
|
|
|
|
|
(r"\n", Text),
|
|
|
|
|
(r"\s+", Text),
|
|
|
|
|
(r"\\\n", Text), # line continuation
|
|
|
|
|
(r"//(\n|[\w\W]*?[^\\]\n)", Comment.Single),
|
|
|
|
|
(r"/(\\\n)?[*][\w\W]*?[*](\\\n)?/", Comment.Multiline),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
# Open until EOF, so no ending delimeter
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(r"/(\\\n)?[*][\w\W]*", Comment.Multiline),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
],
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"statements": [
|
|
|
|
|
(r'(L?)(")', bygroups(String.Affix, String), "string"),
|
|
|
|
|
(
|
|
|
|
|
r"(L?)(')(\\.|\\[0-7]{1,3}|\\x[a-fA-F0-9]{1,2}|[^\\\'\n])(')",
|
|
|
|
|
bygroups(String.Affix, String.Char, String.Char, String.Char),
|
|
|
|
|
),
|
|
|
|
|
(r"\*/", Error),
|
|
|
|
|
(r"[~!%^&*+=|?:<>/-]", Operator),
|
|
|
|
|
(r"[()\[\],.]", Punctuation),
|
|
|
|
|
(
|
|
|
|
|
words(
|
|
|
|
|
(
|
|
|
|
|
"asm",
|
|
|
|
|
"auto",
|
|
|
|
|
"break",
|
|
|
|
|
"case",
|
|
|
|
|
"const",
|
|
|
|
|
"continue",
|
|
|
|
|
"default",
|
|
|
|
|
"do",
|
|
|
|
|
"else",
|
|
|
|
|
"enum",
|
|
|
|
|
"extern",
|
|
|
|
|
"for",
|
|
|
|
|
"goto",
|
|
|
|
|
"if",
|
|
|
|
|
"register",
|
|
|
|
|
"restricted",
|
|
|
|
|
"return",
|
|
|
|
|
"sizeof",
|
|
|
|
|
"static",
|
|
|
|
|
"struct",
|
|
|
|
|
"switch",
|
|
|
|
|
"typedef",
|
|
|
|
|
"union",
|
|
|
|
|
"volatile",
|
|
|
|
|
"while",
|
|
|
|
|
),
|
|
|
|
|
suffix=r"\b",
|
|
|
|
|
),
|
|
|
|
|
Keyword,
|
|
|
|
|
),
|
|
|
|
|
(
|
|
|
|
|
r"(bool|int|long|float|short|double|char|unsigned|signed|void)\b",
|
|
|
|
|
Keyword.Type,
|
|
|
|
|
),
|
|
|
|
|
(
|
|
|
|
|
words(
|
|
|
|
|
(
|
|
|
|
|
"inline",
|
|
|
|
|
"_inline",
|
|
|
|
|
"__inline",
|
|
|
|
|
"naked",
|
|
|
|
|
"restrict",
|
|
|
|
|
"thread",
|
|
|
|
|
"typename",
|
|
|
|
|
),
|
|
|
|
|
suffix=r"\b",
|
|
|
|
|
),
|
|
|
|
|
Keyword.Reserved,
|
|
|
|
|
),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
# Vector intrinsics
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(r"(__m(128i|128d|128|64))\b", Keyword.Reserved),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
# Microsoft-isms
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(
|
|
|
|
|
words(
|
|
|
|
|
(
|
|
|
|
|
"asm",
|
|
|
|
|
"int8",
|
|
|
|
|
"based",
|
|
|
|
|
"except",
|
|
|
|
|
"int16",
|
|
|
|
|
"stdcall",
|
|
|
|
|
"cdecl",
|
|
|
|
|
"fastcall",
|
|
|
|
|
"int32",
|
|
|
|
|
"declspec",
|
|
|
|
|
"finally",
|
|
|
|
|
"int64",
|
|
|
|
|
"try",
|
|
|
|
|
"leave",
|
|
|
|
|
"wchar_t",
|
|
|
|
|
"w64",
|
|
|
|
|
"unaligned",
|
|
|
|
|
"raise",
|
|
|
|
|
"noop",
|
|
|
|
|
"identifier",
|
|
|
|
|
"forceinline",
|
|
|
|
|
"assume",
|
|
|
|
|
),
|
|
|
|
|
prefix=r"__",
|
|
|
|
|
suffix=r"\b",
|
|
|
|
|
),
|
|
|
|
|
Keyword.Reserved,
|
|
|
|
|
),
|
|
|
|
|
(r"(true|false|NULL)\b", Name.Builtin),
|
|
|
|
|
(r"([a-zA-Z_]\w*)(\s*)(:)(?!:)", bygroups(Name.Label, Text, Punctuation)),
|
|
|
|
|
(r"[a-zA-Z_]\w*", Name),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
],
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"root": [
|
|
|
|
|
include("whitespace"),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
# functions
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(
|
|
|
|
|
r"((?:[\w*\s])+?(?:\s|[*]))" # return arguments
|
|
|
|
|
r"([a-zA-Z_]\w*)" # method name
|
|
|
|
|
r"(\s*\([^;]*?\))" # signature
|
|
|
|
|
r"([^;{]*)(\{)",
|
|
|
|
|
bygroups(
|
|
|
|
|
using(this), Name.Function, using(this), using(this), Punctuation
|
|
|
|
|
),
|
|
|
|
|
"function",
|
|
|
|
|
),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
# function declarations
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(
|
|
|
|
|
r"((?:[\w*\s])+?(?:\s|[*]))" # return arguments
|
|
|
|
|
r"([a-zA-Z_]\w*)" # method name
|
|
|
|
|
r"(\s*\([^;]*?\))" # signature
|
|
|
|
|
r"([^;]*)(;)",
|
|
|
|
|
bygroups(
|
|
|
|
|
using(this), Name.Function, using(this), using(this), Punctuation
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
default("statement"),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
],
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"statement": [
|
|
|
|
|
include("whitespace"),
|
|
|
|
|
include("statements"),
|
|
|
|
|
("[{}]", Punctuation),
|
|
|
|
|
(";", Punctuation, "#pop"),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
],
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"function": [
|
|
|
|
|
include("whitespace"),
|
|
|
|
|
include("statements"),
|
|
|
|
|
(";", Punctuation),
|
|
|
|
|
(r"\{", Punctuation, "#push"),
|
|
|
|
|
(r"\}", Punctuation, "#pop"),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
],
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"string": [
|
|
|
|
|
(r'"', String, "#pop"),
|
|
|
|
|
(
|
|
|
|
|
r'\\([\\abfnrtv"\']|x[a-fA-F0-9]{2,4}|'
|
|
|
|
|
r"u[a-fA-F0-9]{4}|U[a-fA-F0-9]{8}|[0-7]{1,3})",
|
|
|
|
|
String.Escape,
|
|
|
|
|
),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
(r'[^\\"\n]+', String), # all other characters
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(r"\\\n", String), # line continuation
|
|
|
|
|
(r"\\", String), # stray backslash
|
|
|
|
|
],
|
|
|
|
|
"macro": [
|
|
|
|
|
(
|
|
|
|
|
r"(include)(" + _ws1 + r")([^\n]+)",
|
|
|
|
|
bygroups(Comment.Preproc, Text, Comment.PreprocFile),
|
|
|
|
|
),
|
|
|
|
|
(r"[^/\n]+", Comment.Preproc),
|
|
|
|
|
(r"/[*](.|\n)*?[*]/", Comment.Multiline),
|
|
|
|
|
(r"//.*?\n", Comment.Single, "#pop"),
|
|
|
|
|
(r"/", Comment.Preproc),
|
|
|
|
|
(r"(?<=\\)\n", Comment.Preproc),
|
|
|
|
|
(r"\n", Comment.Preproc, "#pop"),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
],
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"if0": [
|
|
|
|
|
(r"^\s*#if.*?(?<!\\)\n", Comment.Preproc, "#push"),
|
|
|
|
|
(r"^\s*#el(?:se|if).*\n", Comment.Preproc, "#pop"),
|
|
|
|
|
(r"^\s*#endif.*?(?<!\\)\n", Comment.Preproc, "#pop"),
|
|
|
|
|
(r".*?\n", Comment),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
],
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
stdlib_types = {
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"size_t",
|
|
|
|
|
"ssize_t",
|
|
|
|
|
"off_t",
|
|
|
|
|
"wchar_t",
|
|
|
|
|
"ptrdiff_t",
|
|
|
|
|
"sig_atomic_t",
|
|
|
|
|
"fpos_t",
|
|
|
|
|
"clock_t",
|
|
|
|
|
"time_t",
|
|
|
|
|
"va_list",
|
|
|
|
|
"jmp_buf",
|
|
|
|
|
"FILE",
|
|
|
|
|
"DIR",
|
|
|
|
|
"div_t",
|
|
|
|
|
"ldiv_t",
|
|
|
|
|
"mbstate_t",
|
|
|
|
|
"wctrans_t",
|
|
|
|
|
"wint_t",
|
|
|
|
|
"wctype_t",
|
|
|
|
|
}
|
2020-03-10 19:10:54 +01:00
|
|
|
|
c99_types = {
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"_Bool",
|
|
|
|
|
"_Complex",
|
|
|
|
|
"int8_t",
|
|
|
|
|
"int16_t",
|
|
|
|
|
"int32_t",
|
|
|
|
|
"int64_t",
|
|
|
|
|
"uint8_t",
|
|
|
|
|
"uint16_t",
|
|
|
|
|
"uint32_t",
|
|
|
|
|
"uint64_t",
|
|
|
|
|
"int_least8_t",
|
|
|
|
|
"int_least16_t",
|
|
|
|
|
"int_least32_t",
|
|
|
|
|
"int_least64_t",
|
|
|
|
|
"uint_least8_t",
|
|
|
|
|
"uint_least16_t",
|
|
|
|
|
"uint_least32_t",
|
|
|
|
|
"uint_least64_t",
|
|
|
|
|
"int_fast8_t",
|
|
|
|
|
"int_fast16_t",
|
|
|
|
|
"int_fast32_t",
|
|
|
|
|
"int_fast64_t",
|
|
|
|
|
"uint_fast8_t",
|
|
|
|
|
"uint_fast16_t",
|
|
|
|
|
"uint_fast32_t",
|
|
|
|
|
"uint_fast64_t",
|
|
|
|
|
"intptr_t",
|
|
|
|
|
"uintptr_t",
|
|
|
|
|
"intmax_t",
|
|
|
|
|
"uintmax_t",
|
|
|
|
|
}
|
2020-03-10 19:10:54 +01:00
|
|
|
|
linux_types = {
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"clockid_t",
|
|
|
|
|
"cpu_set_t",
|
|
|
|
|
"cpumask_t",
|
|
|
|
|
"dev_t",
|
|
|
|
|
"gid_t",
|
|
|
|
|
"id_t",
|
|
|
|
|
"ino_t",
|
|
|
|
|
"key_t",
|
|
|
|
|
"mode_t",
|
|
|
|
|
"nfds_t",
|
|
|
|
|
"pid_t",
|
|
|
|
|
"rlim_t",
|
|
|
|
|
"sig_t",
|
|
|
|
|
"sighandler_t",
|
|
|
|
|
"siginfo_t",
|
|
|
|
|
"sigset_t",
|
|
|
|
|
"sigval_t",
|
|
|
|
|
"socklen_t",
|
|
|
|
|
"timer_t",
|
|
|
|
|
"uid_t",
|
|
|
|
|
}
|
2020-03-10 19:10:54 +01:00
|
|
|
|
|
|
|
|
|
def __init__(self, **options):
|
2022-05-12 13:58:32 +02:00
|
|
|
|
self.stdlibhighlighting = get_bool_opt(options, "stdlibhighlighting", True)
|
|
|
|
|
self.c99highlighting = get_bool_opt(options, "c99highlighting", True)
|
|
|
|
|
self.platformhighlighting = get_bool_opt(options, "platformhighlighting", True)
|
2020-03-10 19:10:54 +01:00
|
|
|
|
RegexLexer.__init__(self, **options)
|
|
|
|
|
|
|
|
|
|
def get_tokens_unprocessed(self, text):
|
2022-05-12 13:58:32 +02:00
|
|
|
|
for index, token, value in RegexLexer.get_tokens_unprocessed(self, text):
|
2020-03-10 19:10:54 +01:00
|
|
|
|
if token is Name:
|
|
|
|
|
if self.stdlibhighlighting and value in self.stdlib_types:
|
|
|
|
|
token = Keyword.Type
|
|
|
|
|
elif self.c99highlighting and value in self.c99_types:
|
|
|
|
|
token = Keyword.Type
|
|
|
|
|
elif self.platformhighlighting and value in self.linux_types:
|
|
|
|
|
token = Keyword.Type
|
|
|
|
|
yield index, token, value
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class MyCppLexer(MyCFamilyLexer):
|
|
|
|
|
"""
|
|
|
|
|
For C++ source code with preprocessor directives.
|
|
|
|
|
"""
|
2022-05-12 13:58:32 +02:00
|
|
|
|
|
|
|
|
|
name = "My C++"
|
|
|
|
|
aliases = ["cpp", "c++"]
|
|
|
|
|
filenames = [
|
|
|
|
|
"*.cpp",
|
|
|
|
|
"*.hpp",
|
|
|
|
|
"*.c++",
|
|
|
|
|
"*.h++",
|
|
|
|
|
"*.cc",
|
|
|
|
|
"*.hh",
|
|
|
|
|
"*.cxx",
|
|
|
|
|
"*.hxx",
|
|
|
|
|
"*.C",
|
|
|
|
|
"*.H",
|
|
|
|
|
"*.cp",
|
|
|
|
|
"*.CPP",
|
|
|
|
|
]
|
|
|
|
|
mimetypes = ["text/x-c++hdr", "text/x-c++src"]
|
2020-03-10 19:10:54 +01:00
|
|
|
|
priority = 0.1
|
|
|
|
|
|
|
|
|
|
tokens = {
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"statements": [
|
|
|
|
|
(
|
|
|
|
|
words(
|
|
|
|
|
(
|
|
|
|
|
"catch",
|
|
|
|
|
"const_cast",
|
|
|
|
|
"delete",
|
|
|
|
|
"dynamic_cast",
|
|
|
|
|
"explicit",
|
|
|
|
|
"export",
|
|
|
|
|
"friend",
|
|
|
|
|
"mutable",
|
|
|
|
|
"namespace",
|
|
|
|
|
"new",
|
|
|
|
|
"operator",
|
|
|
|
|
"private",
|
|
|
|
|
"protected",
|
|
|
|
|
"public",
|
|
|
|
|
"reinterpret_cast",
|
|
|
|
|
"restrict",
|
|
|
|
|
"static_cast",
|
|
|
|
|
"template",
|
|
|
|
|
"this",
|
|
|
|
|
"throw",
|
|
|
|
|
"throws",
|
|
|
|
|
"try",
|
|
|
|
|
"typeid",
|
|
|
|
|
"typename",
|
|
|
|
|
"using",
|
|
|
|
|
"virtual",
|
|
|
|
|
"constexpr",
|
|
|
|
|
"nullptr",
|
|
|
|
|
"decltype",
|
|
|
|
|
"thread_local",
|
|
|
|
|
"alignas",
|
|
|
|
|
"alignof",
|
|
|
|
|
"static_assert",
|
|
|
|
|
"noexcept",
|
|
|
|
|
"override",
|
|
|
|
|
"final",
|
|
|
|
|
"constinit",
|
|
|
|
|
"consteval",
|
|
|
|
|
"constinit",
|
|
|
|
|
"concept",
|
|
|
|
|
"co_await",
|
|
|
|
|
"co_return",
|
|
|
|
|
"co_yield",
|
|
|
|
|
"requires",
|
|
|
|
|
"import",
|
|
|
|
|
"module",
|
|
|
|
|
),
|
|
|
|
|
suffix=r"\b",
|
|
|
|
|
),
|
|
|
|
|
Keyword,
|
|
|
|
|
),
|
|
|
|
|
(r"char(16_t|32_t|8_t)\b", Keyword.Type),
|
|
|
|
|
(r"(class)(\s+)", bygroups(Keyword, Text), "classname"),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
# C++11 raw strings
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(
|
|
|
|
|
r'(R)(")([^\\()\s]{,16})(\()((?:.|\n)*?)(\)\3)(")',
|
|
|
|
|
bygroups(
|
|
|
|
|
String.Affix,
|
|
|
|
|
String,
|
|
|
|
|
String.Delimiter,
|
|
|
|
|
String.Delimiter,
|
|
|
|
|
String,
|
|
|
|
|
String.Delimiter,
|
|
|
|
|
String,
|
|
|
|
|
),
|
|
|
|
|
),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
# C++11 UTF-8/16/32 strings
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(r'(u8|u|U)(")', bygroups(String.Affix, String), "string"),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
# C++14 number separators
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(
|
|
|
|
|
r"(\d[\d\']*\.[\d\']*|\.\d[\d\']*|\d[\d\']*)[eE][+-]?\d[\d\']*[LlUu]*",
|
|
|
|
|
Number.Float,
|
|
|
|
|
),
|
|
|
|
|
(r"(\d[\d\']*\.[\d\']*|\.\d[\d\']*|\d[\d\']*[fF])[fF]?", Number.Float),
|
|
|
|
|
(r"0x[0-9a-fA-F\']+[LlUu]*", Number.Hex),
|
|
|
|
|
(r"0[0-7\']+[LlUu]*", Number.Oct),
|
|
|
|
|
(r"\d[\d\']*[LlUu]*", Number.Integer),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
inherit,
|
|
|
|
|
],
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"root": [
|
2020-03-10 19:10:54 +01:00
|
|
|
|
inherit,
|
|
|
|
|
# C++ Microsoft-isms
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(
|
|
|
|
|
words(
|
|
|
|
|
(
|
|
|
|
|
"virtual_inheritance",
|
|
|
|
|
"uuidof",
|
|
|
|
|
"super",
|
|
|
|
|
"single_inheritance",
|
|
|
|
|
"multiple_inheritance",
|
|
|
|
|
"interface",
|
|
|
|
|
"event",
|
|
|
|
|
),
|
|
|
|
|
prefix=r"__",
|
|
|
|
|
suffix=r"\b",
|
|
|
|
|
),
|
|
|
|
|
Keyword.Reserved,
|
|
|
|
|
),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
# Offload C++ extensions, http://offload.codeplay.com/
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(r"__(offload|blockingoffload|outer)\b", Keyword.Pseudo),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
],
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"classname": [
|
|
|
|
|
(r"[a-zA-Z_]\w*", Name.Class, "#pop"),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
# template specification
|
2022-05-12 13:58:32 +02:00
|
|
|
|
(r"\s*(?=>)", Text, "#pop"),
|
2020-03-10 19:10:54 +01:00
|
|
|
|
],
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
def analyse_text(text):
|
2022-05-12 13:58:32 +02:00
|
|
|
|
if re.search("#include <[a-z_]+>", text):
|
2020-03-10 19:10:54 +01:00
|
|
|
|
return 0.2
|
2022-05-12 13:58:32 +02:00
|
|
|
|
if re.search("using namespace ", text):
|
2020-03-10 19:10:54 +01:00
|
|
|
|
return 0.4
|
|
|
|
|
|
2022-05-12 13:58:32 +02:00
|
|
|
|
|
|
|
|
|
lexers["cpp"] = MyCppLexer(startinline=True)
|
2020-03-10 19:10:54 +01:00
|
|
|
|
|
|
|
|
|
# TODO Remove the above when Pygments release with fixes is available
|
|
|
|
|
|
|
|
|
|
|
2020-03-09 18:55:41 +01:00
|
|
|
|
# Configuration file for the Sphinx documentation builder.
|
|
|
|
|
#
|
|
|
|
|
# This file only contains a selection of the most common options.
|
|
|
|
|
# For a full list see the documentation:
|
|
|
|
|
# https://www.sphinx-doc.org/en/master/usage/configuration.html
|
|
|
|
|
|
|
|
|
|
import subprocess, os, re
|
|
|
|
|
|
2022-05-12 13:58:32 +02:00
|
|
|
|
|
2020-03-09 18:55:41 +01:00
|
|
|
|
def get_version():
|
|
|
|
|
try:
|
2022-05-12 13:58:32 +02:00
|
|
|
|
with open("../src/CMakeLists.txt", "r") as file:
|
2020-03-09 18:55:41 +01:00
|
|
|
|
content = file.read()
|
2022-05-12 13:58:32 +02:00
|
|
|
|
version = re.search(
|
|
|
|
|
r"project\([^\)]+VERSION (\d+\.\d+\.\d+)[^\)]*\)", content
|
|
|
|
|
).group(1)
|
2020-03-09 18:55:41 +01:00
|
|
|
|
return version.strip()
|
|
|
|
|
except Exception:
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# -- Project information -----------------------------------------------------
|
|
|
|
|
|
2022-05-12 13:58:32 +02:00
|
|
|
|
project = "mp-units"
|
|
|
|
|
copyright = "2018-present, Mateusz Pusz"
|
|
|
|
|
author = "Mateusz Pusz"
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# The major project version, used as the replacement for |version|.
|
|
|
|
|
version = get_version()
|
|
|
|
|
|
|
|
|
|
# The full project version, used as the replacement for |release| and
|
|
|
|
|
# e.g. in the HTML templates.
|
|
|
|
|
release = get_version()
|
|
|
|
|
|
|
|
|
|
# Add any Sphinx extension module names here, as strings. They can be
|
|
|
|
|
# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom
|
|
|
|
|
# ones.
|
|
|
|
|
extensions = [
|
2022-05-12 13:58:32 +02:00
|
|
|
|
"sphinx.ext.autosectionlabel",
|
|
|
|
|
"sphinx.ext.githubpages",
|
|
|
|
|
"sphinx.ext.graphviz",
|
|
|
|
|
"sphinx_rtd_theme",
|
|
|
|
|
"recommonmark",
|
|
|
|
|
"breathe",
|
2020-03-09 18:55:41 +01:00
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
# Add any paths that contain templates here, relative to this directory.
|
2022-05-12 13:58:32 +02:00
|
|
|
|
templates_path = ["_templates"]
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# List of patterns, relative to source directory, that match files and
|
|
|
|
|
# directories to ignore when looking for source files.
|
|
|
|
|
# This pattern also affects html_static_path and html_extra_path.
|
2022-05-12 13:58:32 +02:00
|
|
|
|
exclude_patterns = ["_build", "Thumbs.db", ".DS_Store"]
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# If true, Sphinx will warn about all references where the target cannot
|
|
|
|
|
# be found. Default is False.
|
|
|
|
|
nitpicky = True
|
|
|
|
|
|
|
|
|
|
# A list of (type, target) tuples (by default empty) that should be ignored
|
|
|
|
|
# when generating warnings in “nitpicky mode”. Note that type should include
|
|
|
|
|
# the domain name if present. Example entries would be ('py:func', 'int')
|
|
|
|
|
# or ('envvar', 'LD_LIBRARY_PATH').
|
|
|
|
|
nitpick_ignore = []
|
|
|
|
|
|
2021-02-16 16:19:57 +01:00
|
|
|
|
# True to prefix each section label with the name of the document it is in,
|
|
|
|
|
# followed by a colon. Useful for avoiding ambiguity when the same section
|
|
|
|
|
# heading appears in different documents.
|
|
|
|
|
autosectionlabel_prefix_document = True
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# -- C++ configuration ---------------------------------------------------
|
|
|
|
|
|
|
|
|
|
# The name of the default domain. Can also be None to disable a default
|
|
|
|
|
# domain. The default is 'py'.
|
2022-05-12 13:58:32 +02:00
|
|
|
|
primary_domain = "cpp"
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# The reST default role (used for this markup: `text`) to use for all documents.
|
2022-05-12 13:58:32 +02:00
|
|
|
|
default_role = "cpp:any"
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# The default language to highlight source code in. The default is 'python3'.
|
|
|
|
|
# The value should be a valid Pygments lexer name (https://pygments.org/docs/lexers).
|
2022-05-12 13:58:32 +02:00
|
|
|
|
highlight_language = "cpp"
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# The style name to use for Pygments highlighting of source code. If not set,
|
|
|
|
|
# either the theme’s default style or 'sphinx' is selected for HTML output.
|
2022-05-12 13:58:32 +02:00
|
|
|
|
pygments_style = "default"
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# A list of prefixes that will be ignored when sorting C++ objects in the global
|
|
|
|
|
# index. For example ['awesome_lib::'].
|
2022-05-12 13:58:32 +02:00
|
|
|
|
cpp_index_common_prefix = ["units::"]
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# -- Options for HTML output -------------------------------------------------
|
|
|
|
|
|
|
|
|
|
# The theme to use for HTML and HTML Help pages. See the documentation for
|
|
|
|
|
# a list of builtin themes.
|
2022-05-12 13:58:32 +02:00
|
|
|
|
html_theme = "sphinx_rtd_theme"
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
2020-03-10 13:33:33 +01:00
|
|
|
|
# A dictionary of options that influence the look and feel of the selected theme.
|
|
|
|
|
# These are theme-specific.
|
|
|
|
|
html_theme_options = {
|
2020-05-08 22:56:37 +02:00
|
|
|
|
# WARNING: unsupported theme option 'github_url' given
|
|
|
|
|
# 'github_url': 'https://github.com/mpusz/units'
|
2020-03-10 13:33:33 +01:00
|
|
|
|
}
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# Add any paths that contain custom static files (such as style sheets) here,
|
|
|
|
|
# relative to this directory. They are copied after the builtin static files,
|
|
|
|
|
# so a file named "default.css" will overwrite the builtin "default.css".
|
2022-05-12 13:58:32 +02:00
|
|
|
|
html_static_path = ["_static"]
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# If given, this must be the name of an image file (path relative to the
|
|
|
|
|
# configuration directory) that is the logo of the docs. It is placed at the
|
|
|
|
|
# top of the sidebar; its width should therefore not exceed 200 pixels.
|
|
|
|
|
# Default: None.
|
2022-03-18 14:34:59 +01:00
|
|
|
|
# html_logo =
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# These paths are either relative to html_static_path or fully qualified
|
|
|
|
|
# paths (eg. https://...)
|
2022-05-12 13:58:32 +02:00
|
|
|
|
html_css_files = ["css/custom.css"]
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# -- Breathe configuration ---------------------------------------------------
|
|
|
|
|
|
2022-05-12 13:58:32 +02:00
|
|
|
|
|
2020-03-09 19:56:12 +01:00
|
|
|
|
def configureDoxyfile(input_dir, output_dir):
|
2022-05-12 13:58:32 +02:00
|
|
|
|
with open("Doxyfile.in", "r") as file:
|
2020-03-09 19:56:12 +01:00
|
|
|
|
filedata = file.read()
|
2022-03-18 14:34:59 +01:00
|
|
|
|
|
2022-05-12 13:58:32 +02:00
|
|
|
|
filedata = filedata.replace("@DOXYGEN_INPUT_DIR@", input_dir)
|
|
|
|
|
filedata = filedata.replace("@DOXYGEN_OUTPUT_DIR@", output_dir)
|
2022-03-18 14:34:59 +01:00
|
|
|
|
|
2022-05-12 13:58:32 +02:00
|
|
|
|
with open("Doxyfile", "w") as file:
|
2020-03-09 19:56:12 +01:00
|
|
|
|
file.write(filedata)
|
|
|
|
|
|
2022-05-12 13:58:32 +02:00
|
|
|
|
|
2020-03-09 18:55:41 +01:00
|
|
|
|
# Check if we're running on Read the Docs' servers
|
2022-05-12 13:58:32 +02:00
|
|
|
|
read_the_docs_build = os.environ.get("READTHEDOCS", None) == "True"
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# This should be a dictionary in which the keys are project names and the values
|
|
|
|
|
# are paths to the folder containing the doxygen output for that project.
|
|
|
|
|
breathe_projects = {}
|
|
|
|
|
if read_the_docs_build:
|
2022-05-12 13:58:32 +02:00
|
|
|
|
input_dir = "../src"
|
|
|
|
|
output_dir = "build"
|
2020-03-09 18:55:41 +01:00
|
|
|
|
configureDoxyfile(input_dir, output_dir)
|
2022-05-12 13:58:32 +02:00
|
|
|
|
subprocess.call("doxygen", shell=True)
|
|
|
|
|
breathe_projects["mp-units"] = output_dir + "/xml"
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# This should match one of the keys in the breathe_projects dictionary and
|
|
|
|
|
# indicates which project should be used when the project is not specified on
|
|
|
|
|
# the directive.
|
2022-05-12 13:58:32 +02:00
|
|
|
|
breathe_default_project = "mp-units"
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# Allows you to specify domains for particular files according to their extension.
|
2022-05-12 13:58:32 +02:00
|
|
|
|
breathe_domain_by_extension = {"h": "cpp"}
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
|
|
# Provides the directive flags that should be applied to all directives which
|
|
|
|
|
# take :members:, :private-members: and :undoc-members: options. By default,
|
|
|
|
|
# this is set to an empty list, which means no members are displayed.
|
2022-05-12 13:58:32 +02:00
|
|
|
|
breathe_default_members = ("members",)
|