Skip to content

Defines a framework and format for metadata-rich, automation-friendly style guides and glossaries.

Notifications You must be signed in to change notification settings

DocOps/openstyles

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 

Repository files navigation

Open Styles: A linter-friendly style-guide sourcing system

Table of Contents

Open Styles is a framework for creating and publishing style guides and glossaries of all kinds, including:

design style guides

For branding, user interfaces, publishing templates, etc.

content style guides

For sentence style, proper terminology, grammar, graphics guidance, and other writing rules.

source-code style guides

For programming languages and markup formats, from Java and C++ to HTML and AsciiDoc — rules for formatting the source itself.

single-sourced glossaries

More than just term-and-definition, the framework enables extensive metadata, ideal for publishing tailored-but-single-sourced glossaries across multiple products or projects.

With Open Styles, you can create these or related kinds of canonical references for your whole organization, and even your customer users. Use AsciiDoc or Markdown to format reference content and contextualize with topical content in an article or wiki format.

Create and organize rules in flat-file data sources (YAML), publish them in reader-friendly formats (HTML portal, PDF manual), then use linters like Vale to enforce those rules in your output.

OpenSGY (“Open Siggy”) is a YAML-based markup format for term- and rule-defining objects. These terms and rules obey an internal logic can be combined and reshaped for rendering into references.

The Open Styles framework includes basic back-end (Jekyll) and front-end (jQuery) tooling to render your data for reference display and interactivity. If you extend it to incorporate other converters or front-end components, please consider contributing back to this project.

The flagship project of Open Styles, and currently the only known implementation, is the FreeStyles Technical Documentation Writer’s Reference. Use that project as a guide or customize it for your own purposes.

Project Scope

The aim of the Open Styles project is to empower authors, reviewers, and automation routines with everything needed to ensure quality plaintext source matter, be it programming code or textual content.

  1. A standardized data object suitable for conveying:

    • word meaning/usage descriptions rich in metadata (terms)

    • text/code style preferences as actionable instructions (rules)

  2. A system of cascading (inheritable and overwritable) definitions enabling:

    • downstream subscriptions customizable down to the term/rule level

    • straightforward forking/syncing

  3. Exemplary parser implementations:

    • Jekyll/Liquid-based parser of rule/term objects into content objects & pages

    • JavaScript implementation identifies glossary terms

    • Converter for Vale linter styles and vocabularies

    • [Your implementation here?]

Project Status

At this point, the project is just a draft schema model looking for honest feedback and some collaborators. The initial exemplary tooling will be done in Ruby, though because the common data format is YAML, generators should be readily reproducible in other languages, for non-Ruby static-site generators and so forth.

If you would like to participate in evaluating the source format or any eventual tooling around this project, please leave a message here for this project.

If you are more interested in helping to build the flagship publication for Open Styles, check out Free Styles and consider joining the contributor team there.

About

Defines a framework and format for metadata-rich, automation-friendly style guides and glossaries.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published