Skip to main content

A typesetting system for quick and easy technical documentation.

Project description

TEchX

TEchX is a lightweight typesetting system designed for creating easy and smooth technical documentation. It supports a custom .techx file format, allowing you to easily define sections like titles, authors, API references, and changelogs. TEchX can render these files into both HTML and PDF formats which can be displayed for documentation.

Features

  • Custom Typesetting Language: Use .techx files with a simple syntax to define your documentation structure.

  • HTML Output: Generate clean and responsive HTML documentation from your .techx files.

  • PDF Output: Convert .techx files into polished PDF documents, suitable for printing and sharing.

Installation

You can install TEchX via pip.

Using PIP :

pip  install  techx

Also run pip install requirements.txt to install some dependencies.

Manual Installation

Clone the repository and install it locally:

git  clone  https://github.com/yourusername/TEchX.git
cd  TEchX
pip  install  .

Usage

Once installed, you can use the techx command-line tool to generate HTML and PDF documentation.

Utilities

Generate HTML TechDoc

techx tech_doc.techx --output-html tech_doc.html

This command converts tech_doc.techx into tech_doc.html.

Generate PDF TechDoc

techx tech_doc.techx --output-pdf tech_doc.pdf

This command converts tech_doc.techx into tech_doc.pdf.

TEchX syntax:

TEchX provides a very easy and simple syntax to produce technical documentation for small scale projects and also individual files.

Techdoc uses a simple and intuitive syntax to define sections, code snippets, API references, and changelogs within .techx files. All commands begin with a ~ symbol, and the escape character is also ~. Below is a breakdown of the available commands and their usage.

1. Document Metadata

  • ~title{}: Specifies the title of the document.

    ~title{Project Documentation}
    
  • ~author{}: Specifies the author’s name.

    ~author{John Doe}
    
  • ~date{}: Specifies the date of the document. This is an optional parameter. If left empty, it automatically fetches the date from the system.

    ~date{15 Oct 2005}
    

2. Sections

  • ~section{}: Defines a new section in the document. The section title is provided within the curly braces.

    ~section{Introduction}
    This is the introduction section.
    

3. Code Snippets

  • ~code{language : code}: Embeds a code snippet in the document. The language specifies the programming language for syntax highlighting, and the code is the actual code snippet.

    ~code{bash : npm install myproject}
    

    Multiline code snippets are also supported:

    ~code{javascript : 
    const myProject = require('myproject');
    myProject.doSomething();
    }
    

4. API References

  • ~api{}: Defines an API reference entry. The command is followed by the API method or function name, and a description is provided in the text.

    ~api{API_Reference}
    Description: Executes the main function of the project.
    Parameters: none
    Returns: void
    

5. Changelog

  • ~changelog{}: Defines a changelog section. The changes are listed within the curly braces, with each change prefixed by a hyphen.

    ~changelog{
    - v1.0.0: Initial release
    - v1.1.0: Added new feature
    }
    

6. Text Content

  • Plain Text: Any text outside of a command is treated as plain text and will be rendered directly.

    This is a regular paragraph of text.
    

7. Escape Characters

  • Escape ~: If you need to use the ~ character literally in your text, escape it by doubling the ~. Escaped tilde: '~~'

Contributing

Currently, the project is in a nascent stage with more updates and development yet to come. Any new feature ideas and/or bugs can be reported in an issue or by opening a pull request in this repository! All contributions are most welcome!

License

This project is an open source tool licensed under the MIT License.


Project details


Release history Release notifications | RSS feed

This version

0.1

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

techx-0.1.tar.gz (8.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

techx-0.1-py3-none-any.whl (8.1 kB view details)

Uploaded Python 3

File details

Details for the file techx-0.1.tar.gz.

File metadata

  • Download URL: techx-0.1.tar.gz
  • Upload date:
  • Size: 8.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for techx-0.1.tar.gz
Algorithm Hash digest
SHA256 236ce876e7467eba6f48e70f9bbccfc1daf0bfe1feee1003328e224bb25ed96d
MD5 cb63d2a620478944c41f1a7f82104144
BLAKE2b-256 7660f890cc71e513715933b5f6ff1398f279bc5ca918b3a4548611af376dcc67

See more details on using hashes here.

File details

Details for the file techx-0.1-py3-none-any.whl.

File metadata

  • Download URL: techx-0.1-py3-none-any.whl
  • Upload date:
  • Size: 8.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for techx-0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a1da9fa0506bfbbafb3f1b84cf570a5d033b2d569168beeb0316ed88ee17aea7
MD5 22bd0663cf685ef49adbaf4005382eeb
BLAKE2b-256 f082fe698237932e56a380266b47b3cbcd2380a96e24f5187420f7924466348b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page