Skip to content

Releases: cppalliance/mrdocs

v0.0.3

02 Jan 14:26
Compare
Choose a tag to compare

🚀 Features

New features and additions

🐛 Fixes

Bug fixes and error corrections

  • Map translation units to global namespaces. 266f49c
  • Friends use type declarator. 96c42d5
  • Do not omit frame pointer in tests. 723f34f
  • Infinite recursion when identifying SFINAE types. 5750b79
  • Missing template parameters in asciidoc templates. a962db0
  • Lazy object construct when atomic shared pointers are unsupported. efe0620
  • Handlebars unit tests are unrelated to is_multipage. 9ef4c38
  • Support SFINAE detection for compound types. cc08383
  • Deduplicate inherited members. 91c6871
  • HTML anchors are unescaped. 9312ffb
  • Overload set overview is unescaped. 826295c
  • Multipage section levels. 36a9eb8
  • Uniform signature code blocks. 833dee2
  • No relative asciidoc links.3 8693504
  • Adoc multipage wrapper includes relfileprefix. bcd8372
  • Tables have no enumerator anchors. 0e36580
  • Use arguments to \par if available. 03d1a75
  • Path: Scoped temp directories use llvm's remove_directories. 691ce1d
  • Handlebars:
    • Helper calls report errors. 29f4d4f
    • "or" helper returns first truthy value. f9e7af4
  • HandlebarsGenerator:
  • Generator: Propagate createDirectory error. ece7e7d

⚡️ Performance

Performance optimizations and enhancements

  • OverlayObjectImpl: Fold empty overlays. 184448a
  • Builder:
    • Render templates directly to ostream. 3d38f59
    • Load template layouts at construction. 9543810

♻️ Refactor

Code refactoring and restructuring

  • Unify traverse functions. 938b673
  • InfoTypeFor trait. f225a4f
  • Info parent is not always namespace. 7d8de21
  • Corpus qualified name returns void. f92f1f2
  • Referenced-declarations default is never. 9edf3ab
  • Drop bitcode support. e6205d5
  • Options are quoted in messages. eaff684
  • Split error message from source location in reports. (fix #672) 446a41d (thanks @akrzemi1)
  • Version command includes build. f600633
  • Compilation database ensures target. 9871794
  • Compilation database ensures std. (fix #694) b5a36db
  • Remove unused mergeInfos. c072007
  • Remove BitField/BitFlag. c56dcae
  • Temp directories use output path. 1aca304
  • Info nodes configuration file. 9daf71f
  • Lazy object mapping traits. (fix #696) 9d30ea1
  • Public settings initialize relativeto.4 59b3012
  • Unify dom lazy array classes.5 e919a61
  • Dom::Value tag_invoke. 2663199
  • Dom::LazyObject tag_invoke. de7f589
  • Custom ValueFrom for Info types. 4393f22
  • Synchronize HTML templates. 0823b48
  • Simplify handlebars generators.6 (Generator: main reason the HTML Generator is always behind the Adoc Generator: simple features were not duplicated in the HTML generator. This even justified #656, where we would temporarily remove the HTML generator., fix #656) e6ee971
  • Deduction guides for CTAD warnings. efccb11
  • Remove unused alias. df43d87
  • Generator reports time. e24492d
  • Single page references are fragments. 1d253d7
  • No intermediary buffers for wrapper template. 5bc9f53
  • Time report supports minutes. 5cd44bd
  • Modular ASTVisitor. dee9fdf
  • Platform: Support arm64. d92de4e
  • generate-config-info: Normalization via visitor. a1fb8ec
  • TestArgs: Reuse public config args. 3a22947
  • test: Remove unused lambda capture. 70bff87
  • LazyObject:
  • DomCorpus: Inline operators. 8d2948a
  • Template: Remove unused parameter. 6639b8d
  • Generator: Build member function. eb464a3
  • HandlebarsGenerator:
    • ToString customization is virtual function. 7d7f949
    • Simplify build function.7 5209438
    • Remove unused options. 5f9e5a1
    • Do not require symbol as hash parameter. fc43804
    • Single page HTML includes reference title. 75fdb49
  • Handlebars: Distinguish ostream types. 1efcc2e
  • Builder: Is_multipage does not require helper. 713b573
  • Error: Error propagation uses Expected. 0b4d669
  • Radix: No redundant static. fb7d6b9

📖 Documentation

Documentation updates and improvements

🎨 Style

Code style and formatting changes

  • Scope: Standardize indentation. 0b9f944
  • Requires clauses on their own line. c6cc73c
  • Declarators render unnamed symbols. 9ddac83

📦️ Build

Build system and configuration changes

🧪 Tests

Test cases and testing-related changes

🚦 Continuous Integration

Changes related to continuous integration

🏗️ Chores

Routine tasks, maintenance, and housekeeping

  1. Like the asciidoc option, this option can be used to generate pages without the surrounding tags to include them in other documentation pages, like the mrdocs website.

  2. Some applications might need custom escape functions either because the output format is not HTML or because the application requires more strict HTML escaping.

  3. See https://gitlab.com/antora/antora/-/issues/428.

  4. This fixes a warning when using initialization with designators.

  5. The DomCorpus uses multiple classes that represented lazy arrays. This commit simplifies the dom by unifying all of these array implementations.

  6. Apart from the DocVisitor, the Adoc and HTML generators are nearly 100% duplicated code.This commit unifies the standard code to remove duplicated code, simplify maintenance, and ensure that both generators always have access to the same features.In passing, many missing features in the HTML generator are now available.

  7. Unify code duplicated between build and buildOne.

  8. The Cmake example for header-only libraries compiles by replacing OUTPUT_FILE with TMP_CPP_FILE.

  9. Generate yaml schema as part of the custom target.

  10. The previously hard-coded paths only work on ubuntu. On windows and macOS, these paths don't exist, don't have the necessary permissions, or are ignored by ssh.

v0.0.2

10 Jul 22:00
Compare
Choose a tag to compare

🚀 Features

New features and additions

  • ✨ Config YAML as dom::Object. 0faf7a9
  • 💫 Represent possibly-qualified names with NameInfo. aa4e6ff
  • 🌟 Replace (Builtin/Tag/Specialization)TypeInfo with NamedTypeInfo. c19a4d4
  • ✨ Support @throw/@throws/@exception. 0f25c6a
  • 💫 Extract and render initializers for variables and fields. 42cc6ec
  • 🌟 Detect compiler default include paths. 0720a15
  • ✨ Automatic generation of compile_commands.json. 70a9347
  • 💫 Deducing this. 67fa963
  • 🌟 Input filters. 5f2e60e
  • ✨ Extra javadoc and HTML tags. 75611fc
  • 💫 Support multi-node HTML tags. 541cf5b
  • 🌟 Adoc template "See also" section. 9c20b9d
  • ✨ Support using directives, using declarations and namespace aliases. 753823e
  • 💫 Support variadic functions and variadic function types. d456f87
  • 🌟 Better support for explicit-specifiers. 7ebe30a
  • ✨ Support @pre and @post. 5fee793
  • 💫 Annotate constructors and destructors in adoc member lists. 590b317
  • 🌟 Configurable see-below and implementation-defined namespaces. c476746
  • ✨ Support @n command. 0d821e2
  • 💫 Add 'select' handlebars helper. 8c20d25
  • 🌟 Render explicit-specifier in asciidoc output. 3122db0
  • ✨ Allow multiple implementation-defined and see-below namespaces. 2753767
  • 💫 Warnings for duplicates. (closes #266, #350) a691052
  • 🌟 Detect types implementing SFINAE idiom. bb7d201

🐛 Fixes

Bug fixes and error corrections

  • Use book doctype when generating demos. 34cfbd7
  • Only delete Boost.URL demos on push. 1833247
  • Case label skips variable with non-vacuous initialization. badb9d9
  • Visitor with rvalue arguments. 8dbacbf
  • Do not link to external/system headers. 4542bf0
  • LookupCallback has virtual destructor. c5dc7ae
  • Sanitize references. 1de3dff
  • Bug reporters refer to Mrdocs repo. 06dd4c0
  • Track whether base-specifiers were a pack expansion. 34204a0
  • Propagate current dependency mode when extracting typedefs as a dependency. 7820d6a
  • Dependency extraction for templates. a28f265
  • Atomic shared_ptr checks. 4805772
  • Expected does not support class template argument deduction. da44b16
  • StringRef::equals replaced with operator==.1 8a3c4e3
  • No extra ';'s. d7f3b6d
  • Version string final line break. 52d63cd
  • Remove newline from namespace alias signature template. 995c8ac
  • Typo for ternary operator in CI. 895cc6e
  • HTML matches Asciidoc templates. 561f213
  • Xml schema. 028b98e
  • Escape names of overload set members. 161b6f4
  • Test bug report messages refer to mrdocs. ab29a11
  • Source-root is always normalized. e96bd59
  • ToolArgs initialization is ordered. 0dd9414
  • Merging of parameter names. f19eb95
  • Global namespace is always created. 81318c8
  • Identification of duplicate @returns (#638). 057778c

♻️ Refactor

Code refactoring and restructuring

  • East-const in adoc generation. de4f5c6
  • Remove convertToNoexceptKind. 49414e4
  • Remove cmake temp files. 59681e8
  • Modular cmake functions. f53685e
  • IsCXXSrcFile accepts C files. 14e3a33
  • Command database filters fsanitize. b18ec64
  • Cmake config uses temporary directory. 9bfb5f4
  • Cmake help can use OS defaults. dd10896
  • Bash argument parser. bb927a6
  • Format ASTVisitor. be25522
  • Report bitcode failures. 1be3e83
  • References to excluded symbols are not an error. a567f80
  • Invalid commands emit error messages. d5e8f64
  • Don't represent using-directives as Info. c4441d4
  • Info tables. (fix #549, #553) 3456ba5
  • Config tables. 340b978
  • Character set is base36. (closes #376) 71ab1e6
  • East-const declarations. 6c684c6

📖 Documentation

Documentation updates and improvements

  • Corpus javadocs. 01403d6
  • CMakeUserPresets.json.example includes warnings. c438bd9
  • Expand build utilities javadoc. 91d6742
  • Support asciidoctor tabs. 4043ad3
  • Install instructions use official dependency releases. 0fa17a9
  • Demo page. d37df4c
  • README.adoc refers to Mr. Docs. 4d6e040
  • Banner refers to Mr. Docs. 17503d8
  • README uses consistent capitalization. 45e1095
  • Index.adoc uses consistent capitalization. dd28523
  • Source code callouts. 49fc14b
  • UI header and footer are clean. 359d017
  • Simplified home page. 83ff42c
  • Demos page has direct links. 0d52577
  • Install page releases extension. d04e10f
  • Complete usage examples. 6e1ee8a
  • Commands page include examples. 678b724
  • Complete config file reference. (fix #525) a3fd0ce (thanks @anarthal)
  • Design notes includes rationale and philosophy. (fix #154, #615) 608a925
  • Complete contributor guide. 42d32a4
  • README.adoc refers to documentation. bd4cbad
  • contribute: All directories are at section level 4. d70ae7e

📦️ Build

Build system and configuration changes

  • Default preset enables tests. b615e97
  • Duktape CMake scripts. 586ce9b
  • Capitalized duktape package has precedence. 05938ab

🧪 Tests

Test cases and testing-related changes

🚦 Continuous Integration

Changes related to continuous integration

  • Update cpp-actions to v1.6.2. 9c0071a
  • Update cpp-actions to v1.8.2. 61ede2b
  • Demos use original mrdocs.yml. 588b598
  • Build and cache LLVM from source.2 (fix #548) 03b55df
  • Scp command uses StrictHostKeyChecking=no option. 313abfb
  • Use official dependency releases. 0771bdc
  • Use official libxml2 release.3 ab43756
  • Update LLVM to 5b959310. 62793c4
  • Demo comparison artifact. be9a55a
  • Gcc uses -static. (fix #547) b0021e5
  • Gcc uses default container. 95a39a4
  • Artifact names include ref_name in master and develop. 09a43d4
  • Website demos disable StrictHostKeyChecking. 2637ae4
  • Template consistency checks. 380eb00
  • Secure known_hosts permissions with chmod 600. ce04a1b
  • Demo variants via command line. 0ea641b
  • HTML demos are restored. 4552d29
  • Split test targets. 3fa59db
  • Build-type is RelWithDebInfo. 619d216
  • LLVM install falls back to binaries. 76ff85d
  • Demos command is single-line. 7f12879
  • Actions/checkout v4. 691d8a6
  • compare_templates: No empty warnings. b8deda9

🏗️ Chores

Routine tasks, maintenance, and housekeeping

💬 Other

Other changes not covered by specific categories

  • Revert "docs: valid section anchors".4 afc59d5
  • Revert "docs: qualified typedefs".5 e88ce51
  • Revert "refactor: east-const in adoc generation".6 cd00fe6
  • Cmake refactor fallback --system-information. 062b399
  • Code simplification. 2bc1e13
  • Do not call cmake --system-information on CI. 741198c
  • Update .github/workflows/ci.yml. 3d3f398 47a3031 e3a0bff
  • Fallback in case of parse fail. 113ecbc
  1. StringRef::equals has been deprecated.

  2. Generalizes the build process for any LLVM version and any set of configuration options. To make it faster, the set of targets is reduced to only what we need for MrDocs. When we change the LLVM parameters, the first run will take slightly longer in CI and subsequent runs will reuse the cached binaries. This means we no longer need to host the binaries on mrdocs.com and update them manually, making the process of updating the LLVM version much simpler and cheaper since github will be hosting the binaries. It also allows us to explore other static ways to build LLVM in CI, which is required to create executables that are not associated with a specific ubuntu version.

  3. This extends the same logic of other dependencies and avoids bugs in the vcpkg port.

  4. This reverts commit 6053bf8.

  5. This reverts commit 3ad5066.

  6. This reverts commit de4f5c6.

develop

24 Oct 14:38
Compare
Choose a tag to compare

🚀 Features

New features and additions

  • ✨ Virtual and deleted function suffixes. d104e7c
  • 💫 Support inline styled text. 741047c
  • 🌟 Support throw symbols. dd76a20
  • ✨ Javadoc ref can resolve to alternative URLs. eb311c6
  • 💫 Render scoped enums. d02a0c0
  • 🌟 Enum constant briefs are unescaped. 3723bbb

🐛 Fixes

Bug fixes and error corrections

  • Tagfiles skip symbols with no anchors. 78a28c3
  • Populating Record maintains base classes. 56f175a
  • Namespace aliases support prefix. 499c541
  • ToolArgs include no default strings. 97facef
  • CommandLineSink paths should not be resolved. b3ed6d7
  • Param default does not include equal sign. bc61d75
  • -std command considers implied source language. 74d2407

🎨 Style

Code style and formatting changes

  • Adoc anchors have no prefix. c43082a
  • Adoc headers include new line. 351658e
  • No empty column templates. b305f67

🚦 Continuous Integration

Changes related to continuous integration

Parent release: v0.0.3 54e75a7

v0.0.1

01 Dec 23:12
Compare
Choose a tag to compare

Changelog

🚀 Features

New features and additions

  • ✨ RangeFor. c916310
  • 💫 Formatter. 21988cf
  • 🌟 Handlebars API. 7a218f4
  • ✨ Add Path APIs. 66aedd6
  • 💫 JavaScript api. e12c78d
  • 🌟 Addons directory. 9582ac1
  • ✨ String support algorithms. ae14717
  • 💫 Doc::Heading. 9094337
  • 🌟 More doc node types. 6806796
  • ✨ Add MRDOX_GENERATE_REFERENCE cmake option. 6e67eb4
  • 💫 Error refactoring. 1982508
  • 🌟 Stack trace on exception. fcb2d60
  • ✨ Links in doc. 0578675
  • 💫 Dom. ec7344e
  • 🌟 Adoc support for templates. (close #328) 1a89402
  • ✨ Interface for records. 1138867
  • 💫 Enum dom and adoc work. 2b90a02
  • 🌟 Dom is lazy. a2613b8
  • ✨ Better Expected. 5b2fa54
  • 💫 SharedPtr. e2d0f73
  • 🌟 Lua integration. 940033e
  • ✨ Recursive TypeInfo structure. (closes #209, closes #343) af254c3
  • 💫 New Dom. 8ccb12a
  • 🌟 Add IsMutable for FieldInfo. (closes #177) 9798204
  • ✨ Add support for bitfields. (closes #212) 8c82517
  • 💫 Add ConstexprKind and isConstinit to VariableInfo. (closes #325, closes #205) a864552
  • 🌟 Add isThreadLocal to VariableInfo. b1a5896
  • ✨ Add isInline and isAnonymous to NamespaceInfo. (closes #199) c85c48e
  • 💫 DomCorpus. 345358d
  • 🌟 Classify functions by kind. 5aa45a6
  • ✨ Info name improvements. (closes #352) a3389a2
  • 💫 Diagnostics. 668e4e9
  • 🌟 Array::emplace_back. e92e988
  • ✨ Dom::String. (fix #361, fix #372) 735ef37
  • 💫 Use std::unordered_set<std::unique_ptr> during AST traversal. 8a376f2
  • 🌟 Tests have configs. c59ef02
  • ✨ C++ Handlebars library. 81a5b88
  • 💫 Improved reporting with levels. 9a64659
  • 🌟 --report switch. 843f5a2
  • ✨ Info reporting in test runner. caf0347
  • 💫 Improved declaration resolution. e4947d8
  • 🌟 TArg stores types. c0fd3fc
  • ✨ Improved clang and llvm natvis. cb7d069
  • 💫 HTML generator. a57def6
  • 🌟 Add Info::Implicit flag. 2a21b06
  • ✨ Dom::Function and major refactor. a45679c
  • 💫 Duktape uses native dom. a3d6bbd
  • 🌟 Whitespace control specs. 7e5250e
  • ✨ Partials specs. 5a0409a
  • 💫 Block specs. 95210f8
  • 🌟 Subexpression specs. f3e6861
  • ✨ Builtin specs. 7510558
  • 💫 Private data specs. c1223af
  • 🌟 Helpers specs. 8f674d5
  • ✨ Track-ids specs. 517d4d4
  • 💫 Strict specs. deaa47c
  • 🌟 Util specs. d10a921
  • ✨ Mustache specs. f63df18
  • 💫 Safe names. 3aecfc0
  • 🌟 Support dom::Function. 93a1bf9
  • ✨ Handlebars error handling. 2e554c8
  • 💫 Symbol filtering. 090db2a
  • 🌟 Dependency extraction improvements. c3a18a5
  • ✨ ExtractOptions. 7a1e1dd
  • 💫 Minimal safenames. 7360cd4
  • 🌟 Support basic filtering of inaccessible members. 66ba585
  • ✨ Add find/index_of container helpers. c6ccde2
  • 💫 Find helper supports strings, arrays, and objects. 60d79ff
  • 🌟 Symbol name lookup. 9141ad1
  • ✨ Add EnumeratorInfo and FriendInfo. 22ac9ec
  • 💫 Overload sets. bbc08f1
  • 🌟 C++/JS proxy functions.[^1] 58e4cec
  • ✨ Configurable extraction of inaccessible bases. a77752e
  • 💫 C++/JS proxy objects. 339f7da
  • 🌟 Tranches & overload sets for namespaces. a7a7330
  • ✨ C++/JS proxy arrays. 5230768
  • 💫 Complete JavaScript helpers support.[^2] 1a1b510
  • 🌟 Template context includes config. 186db21
  • ✨ BaseURL config option. 86609ec

🐛 Fixes

Bug fixes and error corrections

  • Linux build. fab205d
  • Added addons folder copy. ea602c2
  • Runtime errors. (close #284, close #285) 90668f3
  • Fix Source/Error.hpp include. 8bf0395
  • Missing Field in visit. 4c2f8c5
  • Missing info kind tags. be131f1
  • Mrdox.cmake. 03bcc0a
  • Add CMakePresets.json to gitignore. 8a0bb97
  • Add back brief-1.cpp. 9fe16c8
  • Invert Value::getBool. bb6a6d3
  • Constexpr. 181ac6b
  • CI warnings. 5c7120b
  • Don't lookup bases that use SymbolID::zero. bf5ffde
  • Source_location. 262846a
  • Expressions of different signedness are casted. 66b3d3b
  • No reference temporaries. 353fe98
  • Lua ignored warnings include GCC. 828560c
  • Change FieldFlags::isNodiscard to FieldFlags::isMaybeUnused. db42b86
  • DomCorpus warning. 4db0c96
  • Hack to make test pass regardless of line endings. 45d69f7
  • Invalid assert in parseJavadoc. 09854bc
  • Doc::Overview. f8e72bb
  • Concurrency is a command line argument. (fix #392) 3e5f660
  • Fixup clang natvis. fda33b1
  • Inverse blocks with no helpers expand expressions. 68491d0
  • Single-thread pool. a55a87c
  • Info::Namespace uses SymbolID::zero for global namespace. cbc7d55
  • Handle substituted template parameter types. d2990a8
  • Fallback to TemplateName::print for qualified template names. 80f9eae
  • Multipage links work in adoc. 9914bbb
  • Make_format_args requires lvalue references. 53273a0
  • Asciidoc demos. fa02ec5
  • Safename disambiguation. a2e033b
  • Workaround for msvc 14.5 bug. 0448745
  • Global namespace safename. 2bd8576
  • Remove expression trim.[^3] bf64028
  • [object Object] shown in adoc output. bb41cf0
  • Create generator output directory if it doesn't exist. 581bc90
  • Adoc shows declarations and definitions. bb96013
  • Qualified lookup for transparent contexts. 2b5c5c8
  • Compute pseudo-access for friends. 3401014
  • GetInstantiatedFrom returns templated declaration for templates. 1579d95
  • Use string_view data. 71dd9f5
  • Tranche partial requires no whitespace. 7d689c9
  • Report handlebars errors from Builder. cf2d10a
  • AccessKind::None is zero. 633a686

♻️ Refactor

Code refactoring and restructuring

  • Move source files to src. 04f75dd
  • MrDox uses C++ handlebars.[^4] 63ac382
  • Store dom::String as a single pointer. (closes #413) ba19bdf
  • Project name is mrdocs. (🚨 BREAKING) 12c027f
  • Rename format option to generate and move it to the config. bfe1ae3
  • Promote adoc section levels. a7afbe1
  • Group namespace members by kind. 76998f4
  • Invert source and synopsis. 7c1f0ea
  • Namespace members are sorted. d788ed8
  • Source partial refers to headers. 6e00120
  • Replicate function and record sections. a0c9d1d
  • Tool uses Expected. 3e1c279
  • Template headers link to repo. 866f727

📖 Documentation

Documentation updates and improvements

  • Antora setup. 744eaee
  • SafeString javadoc. (fix #388) 2f9fe70
  • Installation instructions are relative to enclosing directory. 3491224
  • Antora playbooks refer to mrdocs repo.[^5] 4e59401
  • LLVM version is 29b20829.[^6] (fix #462) 6c6d641
  • JavaScript.hpp javadoc. da84105
  • JavaScript capitalization is consistent. ef24d66

📦️ Build

Build system and configuration changes

🧪 Tests

Test cases and testing-related changes

  • Integrate handlebars and boost.url test suite.[^10] (fix #390, #384) e14fe08
  • Handlebars basic spec. 74fd1f3
  • Improve decomposer integral comparison operators. 831a691
  • Clang::mrdox::dom unit tests. cc9e397
  • JavaScript unit tests.[^11] d5b7b3d

🚦 Continuous Integration

Changes related to continuous integration

🏗️ Chores

Routine tasks, maintenance, and housekeeping

  • Tidy up include guard names. 1c398cb
  • Error is in Support. f3a848e
  • Refactor error handling and reporting. b81ac4a
  • Config has workingDir. f3694e3
  • Absolute compilation database. d226f3a
  • Add Execution. 21b6df1
  • Add parallelFor. 8460e1f
  • ParallelFor tidy. 028a460
  • Path public API work. 8c5c0fc
  • Use new path routines. 5ccf929
  • Fix absolute path algorithms. 9c0f220
  • ThreadPool. e396dbf
  • Only 1 each of msvc, clang, gcc CI targets. bdc9864
  • Refactor thread facilities. 9121bef
  • Config uses ThreadPool. c740a9a
  • Tidy up config construction. 993bfa1
  • NamespaceInfo member refs are just symbol IDs. 3205784
  • RecordInfo member refs are just symbol IDs. 1b6bb13
  • Executor group. 5915bef
  • No source files in source/. d1a37ee
  • Refactor thread support sources. f19a27a
  • Tidy up command line arguments. 5c90ac2
  • Support fixes. 8ce8894
  • Add traverse and visit. 85b20d4
  • JS array objects. 9dcc342
  • Refactor Javadoc. 6600fe7
  • Reverse compare direction in diffs for failed tests. d9ad26f
  • Rename VarInfo to VariableInfo. 711baf4
  • Rename SymbolInfo to SourceInfo, move Location into Source.hpp. 77729b0
  • Debug and error streams are unbuffered. 5b92bfb
  • Remove llvm/clang includes from public headers. 0264f5e
  • Remove debug_outs. a31ae91
  • Relative paths during visit. 971dcd1
  • Corpus visit fix. 0e960f2
  • Better bitcoding for doc nodes. 87d0752
  • Asserts for ExecutorGroup. 68ccbfe
  • Fix data race in executor group. d49dcb1
  • Define FMT_CONSTEVAL. e89a07a
  • Error is an exception. 5d78642
  • Refactor ExecutorGroup. 65b5279
  • ExecutorGroup returns errors. a09e7af
  • ThreadPool returns errors. b7e2443
  • Visitor helpers are not anonymous. e4ab713
  • Add OptionalLocation. (fix #316) 23b8911
  • Normalize outputPath. 6c436c2
  • Dom work. 395be0f
  • Source symbols are exported. f7aaad9
  • Adoc multipage visitor. 118c1b7
  • Tidy up Pointer. 1d4a429
  • Empty dom Array, Object. ef5af06
  • Dom and asciidoc work. 75cd2dd
  • Generate symbol IDs for type by looking through pointers/references etc. 072f43c
  • BaseInfo stores type using TypeInfo. c2abb69
  • Move TagTypeKind conversion to ASTVisitorHelpers. 7246747
  • Add toString for InfoKind and RecordKeyKind. e0a82fb
  • Dom::create spelling. 2e4b285...
Read more

master

01 Dec 19:58
Compare
Choose a tag to compare

🚀 Features

New features and additions

  • undefined:
  • Handlebars:
    • 💫 Support recursive partial blocks. () 6f5bf3d
    • 🌟 Block whitespace control. () 3b12ca3
    • ✨ Value constructor helpers. () 739b8fb
    • 💫 Custom escape functions.2 () 59fe95d
    • 🌟 Options data provide root context. () e545dfe
    • ✨ Concat helper variadic arguments. () b11bdd6
  • HandlebarsGenerator:
    • 💫 Common helper templates. () 3cce490
    • 🌟 Overloads partial. () bca5a46
    • ✨ Unify signature helpers. () e33b47d
    • 💫 Unify symbol partials. () 2da68d8
  • 🌟 Builder: Relativize helper. () 80b1116
  • ✨ templates: Common signature entry partial. () 3f0ddbd
  • 💫 Config: Paths relative to secondary options. () 4bbf7ec

🐛 Fixes

Bug fixes and error corrections

  • undefined:
    • Infinite recursion when identifying SFINAE types. () 5750b79
    • Missing template parameters in asciidoc templates. () a962db0
    • Lazy object construct when atomic shared pointers are unsupported. () efe0620
    • Handlebars unit tests are unrelated to is_multipage. () 9ef4c38
    • Support SFINAE detection for compound types. () cc08383
    • Deduplicate inherited members. () 91c6871
    • HTML anchors are unescaped. () 9312ffb
    • Overload set overview is unescaped. () 826295c
    • Multipage section levels. () 36a9eb8
    • Uniform signature code blocks. () 833dee2
    • No relative asciidoc links.3 () 8693504
    • Adoc multipage wrapper includes relfileprefix. () bcd8372
    • Tables have no enumerator anchors. () 0e36580
    • Use arguments to \par if available. () 03d1a75
  • Path: Scoped temp directories use llvm's remove_directories. () 691ce1d
  • Handlebars:
    • Helper calls report errors. () 29f4d4f
    • "or" helper returns first truthy value. () f9e7af4
  • HandlebarsGenerator:
  • Generator: Propagate createDirectory error. () ece7e7d

⚡️ Performance

Performance optimizations and enhancements

  • OverlayObjectImpl: Fold empty overlays. () 184448a
  • Builder:
    • Render templates directly to ostream. () 3d38f59
    • Load template layouts at construction. () 9543810

♻️ Refactor

Code refactoring and restructuring

  • undefined:
    • Drop bitcode support. () e6205d5
    • Options are quoted in messages. () eaff684
    • Split error message from source location in reports. (fix #672) 446a41d
    • Version command includes build. () f600633
    • Compilation database ensures target. () 9871794
    • Compilation database ensures std. (fix #694) b5a36db
    • Remove unused mergeInfos. () c072007
    • Remove BitField/BitFlag. () c56dcae
    • Temp directories use output path. () 1aca304
    • Info nodes configuration file. () 9daf71f
    • Lazy object mapping traits. (fix #696) 9d30ea1
    • Public settings initialize relativeto.4 () 59b3012
    • Unify dom lazy array classes.5 () e919a61
    • Dom::Value tag_invoke. () 2663199
    • Dom::LazyObject tag_invoke. () de7f589
    • Custom ValueFrom for Info types. () 4393f22
    • Synchronize HTML templates. () 0823b48
    • Simplify handlebars generators.6 (Generator: main reason the HTML Generator is always behind the Adoc Generator: simple features were not duplicated in the HTML generator. This even justified #656, where we would temporarily remove the HTML generator., fix #656) e6ee971
    • Deduction guides for CTAD warnings. () efccb11
    • Remove unused alias. () df43d87
    • Generator reports time. () e24492d
    • Single page references are fragments. () 1d253d7
    • No intermediary buffers for wrapper template. () 5bc9f53
    • Time report supports minutes. () 5cd44bd
    • Modular ASTVisitor. () dee9fdf
  • Platform: Support arm64. () d92de4e
  • generate-config-info: Normalization via visitor. () a1fb8ec
  • TestArgs: Reuse public config args. () 3a22947
  • test: Remove unused lambda capture. () 70bff87
  • LazyObject:
    • Header macros belong in LIB. () 3ebf66d
    • Initialize result. () 17a7212
  • DomCorpus: Inline operators. () 8d2948a
  • Template: Remove unused parameter. () 6639b8d
  • Generator: Build member function. () eb464a3
  • HandlebarsGenerator:
    • ToString customization is virtual function. () 7d7f949
    • Simplify build function.7 () 5209438
    • Remove unused options. () 5f9e5a1
    • Do not require symbol as hash parameter. () fc43804
    • Single page HTML includes reference title. () 75fdb49
  • Handlebars: Distinguish ostream types. () 1efcc2e
  • Builder: Is_multipage does not require helper. () 713b573
  • Error: Error propagation uses Expected. () 0b4d669
  • Radix: No redundant static. () fb7d6b9

📖 Documentation

Documentation updates and improvements

  • usage:
    • Cmake example uses TMP_CPP_FILE.8 () d8b7fcf
    • Include MrDocs workflow. () 0e08458
  • undefined:
    • Website build scripts set cxx_std_23. () a8707b0
    • Libc++ compiler requirements. () 9648483
    • Releases extension allows CI authentication and retries. () 55214d7
    • Generator DOM reference. () f551db3
    • Generator layout entry points. () e052cb7
    • Website panels use embedded HTML. () 12ceade
  • LazyObject: Update documentation. () c521719
  • Scope: Include lookups in documentation. () b078bea
  • generators:
  • contribute: Workflow is partial. () 555e2c4
  • demos: Enable HTML demos. () d38d3e1

🎨 Style

Code style and formatting changes

  • Scope: Standardize indentation. () 0b9f944

📦️ Build

Build system and configuration changes

  • undefined: Generate yaml schema.[^9] () 5bc071e

🧪 Tests

Test cases and testing-related changes

  • undefined:
  • TestRunner: Check Expected values. () 46a3152

🚦 Continuous Integration

Changes related to continuous integration

  • llvm-matrix: Filter uses Node.js 20. () f3b33a4
  • llvm-releases:
    • Handle empty llvm releases matrix. () 5982cc7
    • Ssh uses relative user paths.[^10] () a820ad7
  • releases:
  • undefined:
    • Enable macos. (fix #558) 390159e
    • Fix package asset uploads. () d1c3566
    • Demos artifact path is relative. () 62736e4
    • Coverage workflow. () 1259131
    • Check config schema is up to date. () cb18b87
    • Remove info node support warnings. () 62f361f
    • Enable html demos. () c46c4a9
    • Containers install git. () 43e5f25
    • Clang 18 uses ubuntu:24.04. () b3ac35d
    • Fix file count report. () c376277
    • Export SSH_AUTH_SOCK. () 3470b10

🏗️ Chores

Routine tasks, maintenance, and housekeeping

  • undefined:

💬 Other

Other changes not covered by specific categories

  • null:
    • Unify traverse functions.[^11] () 938b673
    • InfoTypeFor trait.[^12] () f225a4f
    • Support file inputs.[^13] () 75b1bc5
    • Map translation units to global namespaces.[^14] () 266f49c
    • Info parent is not always namespace.[^15] () 7d8de21
    • Corpus qualified name returns void.[^16] () f92f1f2
    • Referenced-declarations default is never.[^17] () 9edf3ab
    • Corpus ordered traverse.[^18] () ed78539
    • Info ExtractionMode.[^19] () f0adca7
    • Info Attribute lists.[^20] () d92629d
    • Template pre/post conditions are unordered lists.[^21] () 0e3c9a8
    • Template param direction.[^22] () 963a387
    • Requires clauses on their own line.[^23] () c6cc73c
    • Declarators render unnamed symbols.[^24] () 9ddac83
    • Friends use type declarator.[^25] () 96c42d5
    • Tranches include namespace aliases.[^26] () 9662f27
    • Support glob patterns.[^27] () 1b67a84
    • Do not omit frame pointer in tests.[^28] () 723f34f
    • Support doxygen-like filters.[^29] () 6841950
  1. Like the asciidoc option, this option can be used to generate pages without the surrounding tags to include them in other documentation pages, like the mrdocs website.

  2. Some applications might need custom escape functions either because the output format is not HTML or because the application requires more strict HTML escaping.

  3. See https://gitlab.com/antora/antora/-/issues/428.

  4. This fixes a warning when using initialization with designators.

  5. The DomCorpus uses multiple classes that represented lazy arrays. This commit simplifies the dom by unifying all of these array implementations.

  6. Apart from the DocVisitor, the Adoc and HTML generators are nearly 100% duplicated code.This commit unifies the standard code to remove duplicated code, simplify maintenance, and ensure that both generators always have access to the same features.In passing, many missing features in the HTML generator are now available.

  7. Unify code duplicated between build and buildOne.

  8. The Cmake example for hea...

Read more

llvm-package

04 May 15:47
Compare
Choose a tag to compare

This release includes the LLVM packages used by MrDox in CI.

Other packages are available from https://mrdox.com/llvm+clang/