An extension to Python-Markdown which adds support for shorthand links to GitHub users, repositories, issues and commits.
To install the extension run the following command:
pip install mdx-gh-links
To use the extension simply include its name in the list of extensions passed to Python-Markdown.
import markdown
markdown.markdown(src, extensions=['mdx_gh_links'])
To set configuration options, you may pass them to Markdown's exension_configs
keyword...
markdown.markdown(
src,
extensions=['mdx_gh_links'],
extension_configs={
'mdx_gh_links': {'user': 'foo', 'repo': 'bar'}
}
)
... or you may import and pass the configs directly to an instance of the
mdx_gh_links.GithubLinks
class...
from mdx_gh_links import GithubLinks
markdown.markdown(src, extensions=[GithubLinks(user='foo', repo='bar')])
The following configuration options are available:
A GitHub user name or organization. If no user or organization is specified in a GitHub link, then the value of this option will be used.
A GitHub repository. If no repository is specified in a GitHub link, then the value of this option will be used.
The domain of the host server for the repository. Defaults to
https://github.com
, but may be set to the root of a GitHub Enterprise Server.
This extension implements shorthand to specify links to GitHub in various ways.
All links in the generated HTML are assigned a gh-link
class as well as a class
unique to that type of link. See each type for the specific class assigned.
Link directly to a GitHub user, organization or repository. Note that no verification is made that an actual user, organization or repository exists. As the syntax does not differentiate between users and organizations, all organizations are assumed to be users. However, this assumption is only reflected in the title of a link.
Mentions use the format @{user}
to link to a user or organization and
@{user}/{repo}
to link to a repository. The defaults defined in the
configuration options are ignored by mentions. A mention may be escaped by
adding a backslash immediately before the at sign (@
).
All mentions are assigned the gh-mention
class.
The following table provides some examples:
shorthand | href | rendered result |
---|---|---|
@foo |
https://github.com/foo |
@foo |
@foo/bar |
https://github.com/foo/bar |
@foo/bar |
\@foo |
@foo | |
\@foo/bar |
@foo/bar |
Link directly to a GitHub issue or pull request (PR). Note that no verification is made that an actual issue or PR exists. As the syntax does not differentiate between Issues and PRs, all URLs point to "issues". Fortunately, GitHub will properly redirect an issue URL to a PR URL if appropriate.
Issue links use the format #{num}
or {user}/{repo}#{num}
. {num}
is the
number assigned to the issue or PR. {user}
and {repo}
will use the
defaults defined in the configuration options if not provided. An issue link may
be escaped by adding a backslash immediately before the hash mark (#
).
All issue links are assigned the gh-issue
class.
The following table provides various examples (with the defaults set as
user='user', repo='repo'
):
shorthand | href | rendered result |
---|---|---|
#123 |
https://github.com/user/repo/issues/123 |
#123 |
foo/bar#123 |
https://github.com/foo/bar/issues/123 |
foo/bar#123 |
\#123 |
#123 | |
foo/bar\#123 |
foo/bar#123 |
Link directly to a GitHub Commit. Note that no verification is made that an actual commit exists.
Commit links consist of a complete 40 character SHA hash and may optionally be
prefaced by {user}@
or {user/repo}@
. {user}
and {repo}
will use the
defaults defined in the configuration options if not provided. To avoid a 40
character hash from being linked, wrap it in a code span.
All commit links are assigned the gh-commit
class.
The following table provides various examples (with the defaults set as
user='user', repo='repo'
):
shorthand | href | rendered result |
---|---|---|
72df691791fb36f00cf5363fefe757c8d3042656 |
https://github.com/user/repo/commit/72df691791fb36f00cf5363fefe757c8d3042656 |
72df691 |
foo@72df691791fb36f00cf5363fefe757c8d3042656 |
https://github.com/foo/repo/commit/72df691791fb36f00cf5363fefe757c8d3042656 |
foo@72df691 |
foo/bar@72df691791fb36f00cf5363fefe757c8d3042656 |
https://github.com/foo/bar/commit/72df691791fb36f00cf5363fefe757c8d3042656 |
foo/bar@72df691 |
`72df691791fb36f00cf5363fefe757c8d3042656` |
72df691791fb36f00cf5363fefe757c8d3042656 |
The Python-Markdown Github-Links Extension is licensed under the BSD License as
defined in LICENSE
.
Add domain
configuration option in order to support GitHub Enterprise Servers.
Include README in release.
Update dependencies.
Ignore mentions/issues/commits within Markdown links.
The initial release.