django-markup


Namedjango-markup JSON
Version 1.9.1 PyPI version JSON
download
home_pagehttps://github.com/bartTC/django-markup/
SummaryA generic Django application to convert text with specific markup to html.
upload_time2024-11-19 08:41:23
maintainerNone
docs_urlhttps://pythonhosted.org/django-markup/
authorMartin Mahner
requires_python<4.0,>=3.8
licenseMIT
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <a href="https://pypi.org/project/django-markup/"><img src="https://img.shields.io/pypi/v/django-markup.svg" alt=""/></a> <a href="https://github.com/bartTC/django-markup/actions"><img src="https://github.com/bartTC/django-markup/actions/workflows/push.yml/badge.svg?branch=main" alt=""/></a>

📖 Full documentation on https://django-markup.readthedocs.io/en/latest/

# django-markup

This app is a generic way to provide filters that convert text into html.

## Compatibility Matrix:

| Py/Dj     | 3.8 | 3.9 | 3.10 | 3.11 | 3.12 |
|-----------|-----|-----|------|------|------|
| 3.2 (LTS) | ✓   | ✓   | ✓    | ✓    | ✓    |
| 4.0       | ✓   | ✓   | ✓    | ✓    | ✓    |
| 4.1       | ✓   | ✓   | ✓    | ✓    | ✓    |
| 4.2 (LTS) | ✓   | ✓   | ✓    | ✓    | ✓    |
| 5.0       | —   | —   | ✓    | ✓    | ✓    |
| 5.1       | —   | —   | ✓    | ✓    | ✓    |

## Quickstart

Download and install the package from the python package index (pypi):

Note that `django-markup` ships with some filters ready to use, but the more
complex packages such as Markdown or ReStructuredText are not part of the code.
Please refer the docs which packages are used for the built-in filter.

An alternative is to install django-markup with all filter dependencies
right away. Do so with:

    $ pip install django-markup[all_filter_dependencies]

Then add it to the ``INSTALLED_APPS`` list:

    INSTALLED_APPS = (
        ...
        'django_markup',
    )

Use it in the template:

    {% load markup_tags %}
    {{ the_text|apply_markup:"markdown" }}

Or in Python code:

    from django_markup.markup import formatter
    formatter('Some *Markdown* text.', filter_name='markdown')

# Testsuite

To run the testsuite install the project with pipenv and run it:

    % pipenv install --dev
    $ pipenv run test

You can also test against a variation of Django and Python versions
using tox:

    $ tox


# Changelog

## v1.9.1 (2024-11-19):

- Drop support for Python <= 3.8.
- Drop support for Django <= 4.1.
- Added support for Python 3.13.

## v1.9 (2024-08-11):

- Minor Type Annotation fixes.
- Switch from pipenv to Poetry.
- Added support for Django 5.1.

## v1.8.1 (2023-10-07):

- Remove all annotations for "Self". It would require an additional dependency for
  installations on Python <3.11 and that's not worth it.

## v1.8 (2023-10-07):

- Drop support for Python <3.8.
- Added support for Python 3.12 and Django 5.0.
- Type Annotations.

## v1.7.2 (2023-05-01):

- Fixed a setup.cfg bug that defined the minimal Django version to be v3.7 which does
  not exist. The correct version is 3.2.

## v1.7.1 (2023-04-25):

- Fixed Python classifiers in setup.cfg.

## v1.7 (2023-04-25):

- Django 4.2 compatibility and tests.
- Python 3.11 compatibility and tests.

## v1.6 (2022-08-14):

- Dropped support for Django <3.2 and Python <3.7.
- Django 3.2 (LTS) compatibility and tests.
- Django 4.0 compatibility and tests.
- Django 4.1 compatibility and tests.
- Python 3.9 compatibility and tests.
- Python 3.10 compatibility and tests.


## v1.5 (2020-06-12):

- Dropped support for Django <=1.11 and Python <=3.5.
- Python 3.8 compatibility and tests.
- Django 3.0 compatibility and tests.
- bleach-whitelist dependency is no longer necessary as tags are now shipped
  with the built-in markdown filter.
- Uses pytest for testing.

## v1.4 (2019-03-15):

- Markdown's safe_mode was deprecated and no longer functional, it's behavior
  was replaced with [bleach].
- Pipfile support for local development and general code cleanup.

[bleach]: https://github.com/mozilla/bleach

## v1.3 (2018-09-07):

- Python 3.6 and 3.7 compatibility and tests.
- Django 2.0 and 2.1 compatibility and tests.
- The package setup script now provides the ability to install all filter
  dependencies automatically. See the installation Readme for details.

## v1.2 (2017-03-18):

- Django 1.10 compatibility and tests.
- Updated all filter dependencies. most notably SmartyPants to v2.0
  which changed it's API, so your project dependencies need to update it
  as well.

## v1.1 (2016-05-02):

- The Markdown filter has the ``safe_mode`` option enabled by default.
- The RestructuredText filter has the file and raw content inclusion
  disabled by default.

## v1.0 (2016-01-02):

- Removed some 5 year old dust
- Django 1.8+ compatible
- Tests

Backwards incompatible changes:

- Removed Pygments highlighting in the Markdown and RestructuredText filter.
- Removed CreoleParser library in favor of a pypi package.
- Removed Lightbox filter.
- The RestructuredText filter now renders level 1 and 2 headers.
  See Github [Issue 14] for details and a backwards compatible workaround.

## v0.4 (2011-06-01):

- Added a widont filter
- MarkupField is South compatible.
- Tested with Django 1.3

## v0.3 (2009-07-29):

django-markup now ships with a builtin creole parser. Advantage is, that
the recently used Creoleparser library needs the Genshi lib, which needs
a c-compiler and so on. The builtin creole parser is a pure python library
without any dependencies and follows the wikicreole.org specifications.
django-markup uses the [WikiCreole library].

[WikiCreole library]: http://devel.sheep.art.pl/creole/
[Issue 14]: https://github.com/bartTC/django-markup/issues/14

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/bartTC/django-markup/",
    "name": "django-markup",
    "maintainer": null,
    "docs_url": "https://pythonhosted.org/django-markup/",
    "requires_python": "<4.0,>=3.8",
    "maintainer_email": null,
    "keywords": null,
    "author": "Martin Mahner",
    "author_email": "martin@mahner.org",
    "download_url": "https://files.pythonhosted.org/packages/de/8c/eeaf4d2be2ac9e04915bf735f42a7b78936557fb9dad7dbb770a12a6039e/django_markup-1.9.1.tar.gz",
    "platform": null,
    "description": "<a href=\"https://pypi.org/project/django-markup/\"><img src=\"https://img.shields.io/pypi/v/django-markup.svg\" alt=\"\"/></a> <a href=\"https://github.com/bartTC/django-markup/actions\"><img src=\"https://github.com/bartTC/django-markup/actions/workflows/push.yml/badge.svg?branch=main\" alt=\"\"/></a>\n\n\ud83d\udcd6 Full documentation on https://django-markup.readthedocs.io/en/latest/\n\n# django-markup\n\nThis app is a generic way to provide filters that convert text into html.\n\n## Compatibility Matrix:\n\n| Py/Dj     | 3.8 | 3.9 | 3.10 | 3.11 | 3.12 |\n|-----------|-----|-----|------|------|------|\n| 3.2 (LTS) | \u2713   | \u2713   | \u2713    | \u2713    | \u2713    |\n| 4.0       | \u2713   | \u2713   | \u2713    | \u2713    | \u2713    |\n| 4.1       | \u2713   | \u2713   | \u2713    | \u2713    | \u2713    |\n| 4.2 (LTS) | \u2713   | \u2713   | \u2713    | \u2713    | \u2713    |\n| 5.0       | \u2014   | \u2014   | \u2713    | \u2713    | \u2713    |\n| 5.1       | \u2014   | \u2014   | \u2713    | \u2713    | \u2713    |\n\n## Quickstart\n\nDownload and install the package from the python package index (pypi):\n\nNote that `django-markup` ships with some filters ready to use, but the more\ncomplex packages such as Markdown or ReStructuredText are not part of the code.\nPlease refer the docs which packages are used for the built-in filter.\n\nAn alternative is to install django-markup with all filter dependencies\nright away. Do so with:\n\n    $ pip install django-markup[all_filter_dependencies]\n\nThen add it to the ``INSTALLED_APPS`` list:\n\n    INSTALLED_APPS = (\n        ...\n        'django_markup',\n    )\n\nUse it in the template:\n\n    {% load markup_tags %}\n    {{ the_text|apply_markup:\"markdown\" }}\n\nOr in Python code:\n\n    from django_markup.markup import formatter\n    formatter('Some *Markdown* text.', filter_name='markdown')\n\n# Testsuite\n\nTo run the testsuite install the project with pipenv and run it:\n\n    % pipenv install --dev\n    $ pipenv run test\n\nYou can also test against a variation of Django and Python versions\nusing tox:\n\n    $ tox\n\n\n# Changelog\n\n## v1.9.1 (2024-11-19):\n\n- Drop support for Python <= 3.8.\n- Drop support for Django <= 4.1.\n- Added support for Python 3.13.\n\n## v1.9 (2024-08-11):\n\n- Minor Type Annotation fixes.\n- Switch from pipenv to Poetry.\n- Added support for Django 5.1.\n\n## v1.8.1 (2023-10-07):\n\n- Remove all annotations for \"Self\". It would require an additional dependency for\n  installations on Python <3.11 and that's not worth it.\n\n## v1.8 (2023-10-07):\n\n- Drop support for Python <3.8.\n- Added support for Python 3.12 and Django 5.0.\n- Type Annotations.\n\n## v1.7.2 (2023-05-01):\n\n- Fixed a setup.cfg bug that defined the minimal Django version to be v3.7 which does\n  not exist. The correct version is 3.2.\n\n## v1.7.1 (2023-04-25):\n\n- Fixed Python classifiers in setup.cfg.\n\n## v1.7 (2023-04-25):\n\n- Django 4.2 compatibility and tests.\n- Python 3.11 compatibility and tests.\n\n## v1.6 (2022-08-14):\n\n- Dropped support for Django <3.2 and Python <3.7.\n- Django 3.2 (LTS) compatibility and tests.\n- Django 4.0 compatibility and tests.\n- Django 4.1 compatibility and tests.\n- Python 3.9 compatibility and tests.\n- Python 3.10 compatibility and tests.\n\n\n## v1.5 (2020-06-12):\n\n- Dropped support for Django <=1.11 and Python <=3.5.\n- Python 3.8 compatibility and tests.\n- Django 3.0 compatibility and tests.\n- bleach-whitelist dependency is no longer necessary as tags are now shipped\n  with the built-in markdown filter.\n- Uses pytest for testing.\n\n## v1.4 (2019-03-15):\n\n- Markdown's safe_mode was deprecated and no longer functional, it's behavior\n  was replaced with [bleach].\n- Pipfile support for local development and general code cleanup.\n\n[bleach]: https://github.com/mozilla/bleach\n\n## v1.3 (2018-09-07):\n\n- Python 3.6 and 3.7 compatibility and tests.\n- Django 2.0 and 2.1 compatibility and tests.\n- The package setup script now provides the ability to install all filter\n  dependencies automatically. See the installation Readme for details.\n\n## v1.2 (2017-03-18):\n\n- Django 1.10 compatibility and tests.\n- Updated all filter dependencies. most notably SmartyPants to v2.0\n  which changed it's API, so your project dependencies need to update it\n  as well.\n\n## v1.1 (2016-05-02):\n\n- The Markdown filter has the ``safe_mode`` option enabled by default.\n- The RestructuredText filter has the file and raw content inclusion\n  disabled by default.\n\n## v1.0 (2016-01-02):\n\n- Removed some 5 year old dust\n- Django 1.8+ compatible\n- Tests\n\nBackwards incompatible changes:\n\n- Removed Pygments highlighting in the Markdown and RestructuredText filter.\n- Removed CreoleParser library in favor of a pypi package.\n- Removed Lightbox filter.\n- The RestructuredText filter now renders level 1 and 2 headers.\n  See Github [Issue 14] for details and a backwards compatible workaround.\n\n## v0.4 (2011-06-01):\n\n- Added a widont filter\n- MarkupField is South compatible.\n- Tested with Django 1.3\n\n## v0.3 (2009-07-29):\n\ndjango-markup now ships with a builtin creole parser. Advantage is, that\nthe recently used Creoleparser library needs the Genshi lib, which needs\na c-compiler and so on. The builtin creole parser is a pure python library\nwithout any dependencies and follows the wikicreole.org specifications.\ndjango-markup uses the [WikiCreole library].\n\n[WikiCreole library]: http://devel.sheep.art.pl/creole/\n[Issue 14]: https://github.com/bartTC/django-markup/issues/14\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "A generic Django application to convert text with specific markup to html.",
    "version": "1.9.1",
    "project_urls": {
        "Homepage": "https://github.com/bartTC/django-markup/"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "1d226eb9f9f4245399cdf120d016fc67fac1b932fc87e2bcc2bcc6df35c2fe5f",
                "md5": "624ebb15d911fdb68c6fa41120cd3723",
                "sha256": "8311138cbf9bfe75560736d0b9424c4ab2a84b944222d095b7080ee1d7c8287a"
            },
            "downloads": -1,
            "filename": "django_markup-1.9.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "624ebb15d911fdb68c6fa41120cd3723",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4.0,>=3.8",
            "size": 18799,
            "upload_time": "2024-11-19T08:41:21",
            "upload_time_iso_8601": "2024-11-19T08:41:21.850766Z",
            "url": "https://files.pythonhosted.org/packages/1d/22/6eb9f9f4245399cdf120d016fc67fac1b932fc87e2bcc2bcc6df35c2fe5f/django_markup-1.9.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "de8ceeaf4d2be2ac9e04915bf735f42a7b78936557fb9dad7dbb770a12a6039e",
                "md5": "b3506dedf843978d0071192614764b9c",
                "sha256": "8262ce3a9ed909d58321d24aef1291586fb09a046fc4b3389e2be4305ecda909"
            },
            "downloads": -1,
            "filename": "django_markup-1.9.1.tar.gz",
            "has_sig": false,
            "md5_digest": "b3506dedf843978d0071192614764b9c",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<4.0,>=3.8",
            "size": 14185,
            "upload_time": "2024-11-19T08:41:23",
            "upload_time_iso_8601": "2024-11-19T08:41:23.336538Z",
            "url": "https://files.pythonhosted.org/packages/de/8c/eeaf4d2be2ac9e04915bf735f42a7b78936557fb9dad7dbb770a12a6039e/django_markup-1.9.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-11-19 08:41:23",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "bartTC",
    "github_project": "django-markup",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "tox": true,
    "lcname": "django-markup"
}
        
Elapsed time: 0.34461s