Download Latest Version tcl-9.0.2-installer-2.0.4-x64.msi (37.4 MB)
Email in envelope

Get an email when there's a new version of magicsplat

Home / ruff
Name Modified Size InfoDownloads / Week
Parent folder
README.md 2025-08-30 4.8 kB
ruff-2.6.0.tgz 2025-08-30 99.2 kB
ruff-2.6.0.zip 2025-08-30 109.2 kB
ruff-2.5.0.tgz 2024-12-01 94.2 kB
ruff-2.5.0.zip 2024-12-01 108.7 kB
ruff-2.4.2.tgz 2024-10-04 92.9 kB
ruff-2.4.2.zip 2024-10-04 107.4 kB
ruff-2.3.0.tgz 2022-06-05 91.0 kB
ruff-2.3.0.zip 2022-06-05 105.2 kB
ruff-2.2.0.tgz 2022-03-21 90.2 kB
ruff-2.2.0.zip 2022-03-21 104.7 kB
ruff-2.1.2.tgz 2022-03-09 81.3 kB
ruff-2.1.2.zip 2022-03-09 96.4 kB
ruff-2.1.1.tgz 2022-02-21 81.3 kB
ruff-2.1.1.zip 2022-02-21 94.9 kB
ruff-2.0.tgz 2021-12-11 79.7 kB
ruff-2.0.zip 2021-12-11 93.5 kB
ruff-1.2.1.tgz 2021-09-28 80.8 kB
ruff-1.2.1.zip 2021-09-28 93.3 kB
ruff-1.2.0.tgz 2021-04-21 79.9 kB
ruff-1.2.0.zip 2021-04-21 92.7 kB
ruff-1.1.0.tgz 2021-01-28 75.6 kB
ruff-1.1.0.zip 2021-01-28 88.7 kB
ruff-1.0.5.zip 2021-01-15 84.7 kB
ruff-1.0.5.tgz 2021-01-15 72.1 kB
ruff-1.0.4.tgz 2020-05-14 70.6 kB
ruff-1.0.4.zip 2020-05-14 83.8 kB
ruff-1.0b3.tgz 2019-09-28 65.7 kB
ruff-1.0b3.zip 2019-09-28 78.5 kB
ruff-1.0b2.tgz 2019-09-22 65.5 kB
ruff-1.0b2.zip 2019-09-22 78.2 kB
ruff-1.0b1.zip 2019-09-22 77.3 kB
ruff-1.0b1.tgz 2019-09-14 64.7 kB
Totals: 33 Items   2.8 MB 17

Ruff! documentation generator

Ruff! (Runtime function formatter) is a documentation generation system for programs written in the Tcl programming language. Ruff! uses runtime introspection in conjunction with comment analysis to generate reference documentation for Tcl programs with minimal effort on the programmer's part.

Why Ruff!

Ruff! produces documentation that not only requires less duplication of effort from the programmer, but is also more complete, more accurate and more maintainable.

  • Comments in source code do not have to be reproduced for documentation purposes.

  • Ruff! requires minimal markup in the comments making it lightweight as well as reducing clutter.

  • Supports inline formatting using Markdown syntax.

  • Embedded diagrams in multiple formats

  • Program elements like command arguments, defaults and class relationships like inheritance are automatically derived.

  • Maintenance is less of a burden as documentation is automatically updated with source modification such as changes to defaults, addition of mix-ins etc.

On the output side,

  • Ruff! supports multiple formats (currently HTML, Markdown and nroff).

  • Generated documentation can optionally be split across multiple pages.

  • Hyperlinks between program elements, and optionally source code, make navigation easy and efficient.

  • A table of contents and optional searchable index permits quick location of command and class documentation.

  • Class relationships are extracted and the full API for a class, with inherited and mixed-in methods, is flattened and summarized.

  • HTML output supports user-selectable themes.

See https://ruff.magicsplat.com for features and reference documentation.

For additional examples of Ruff! generated documentation, see

iocp, cffi, CAWT, SpiceGenTcl, apave, baltip, hl-tcl, tcl-promise, tomato, obex, Woof! and tcl-vix.

Release notes for 2.6

  • Added #ruff includeformatters|excludeformatters directives to include or exclude content for specific formatters (thanks to George Yashin).

Release notes for 2.5

  • Better documentation of TclOO properties to include custom setter/getter descriptions
  • Bug fixes in nroff output.

Release notes for 2.4

  • Support for TclOO properties in Tcl 9
  • Support for language specifier in fenced blocks

Release notes for 2.3

  • Collapsible details section for procedure description option when -compact 1 is specified. Note generated output with -compact 1 has changed.
  • Bug fix. Ensure diagrams fit in page width
  • Bug fix. Index page tooltip synopsis visibility in dark themes.

Release notes for 2.2

  • Support for embedded text formatted diagrams (ditaa, PlantUML etc.)
  • Alignment and linkable numbered captions for fenced blocks and diagrams.
  • Fixed minor display artifacts.

Release notes for 2.1

This release mainly has cosmetic changes in presentation.

  • Ensemble command includes table to subcommands.
  • Show command synopsis in navigation pane tooltip.
  • Tweaks to themes and navigation.
  • Bug fix: broken link to index page.

Release notes for 2.0

  • Added Nroff formatter for Unix manpages.
  • Added themes with end-user selection.
  • Added end-user control for positioning navigation pane.
  • Classes defined with metaclasses are recognized.
  • Proc and method synopsis overrides, for example to distinguish invocation options.
  • Web assets are linked by default (option -linkassets) instead of being embedded.
  • Incompatibility: Generated HTML and CSS templates have changed and require modern browsers (no Internet Explorer support).
  • Incompatibility: The -stylesheets option is not supported.
  • Incompatibility: The -navigation option only takes scrolled sticky as valid values.
  • Incompatibility: The -output option is not supported. Use -outfile and -outdir instead.
  • Incompatibility: Output file names use hyphen as a separator instead of underscore.
  • Bug fixes

NOTE 2.0 HAS SEVERAL INCOMPATIBILITIES VIS-A-VIS 1.x IN OPTIONS AND GENERATED OUTPUT FORMAT. See above Release notes for 2.0.

Source: README.md, updated 2025-08-30