-
Notifications
You must be signed in to change notification settings - Fork 14
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: first working version for DocumenterCitations (#139)
* feat: first working version for DocumenterCitations - fix also the ordered list printing * MAST -> MarkdownAST * Copy files from DocumenterCitations over to the DV docs to serve as a test * add dep * delete file that we want to copy? * Update src/vitepress_config.jl * Bump version * Add `refs.bib` back, comment the copying code out --------- Co-authored-by: Anshul Singhvi <[email protected]>
- Loading branch information
1 parent
f275608
commit 1860fc2
Showing
8 changed files
with
1,142 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,7 @@ | ||
name = "DocumenterVitepress" | ||
uuid = "4710194d-e776-4893-9690-8d956a29c365" | ||
authors = ["Lazaro Alonso <[email protected]>", "Anshul Singhvi <[email protected]>"] | ||
version = "0.0.20" | ||
version = "0.0.21" | ||
|
||
[deps] | ||
ANSIColoredPrinters = "a4c015fc-c6ff-483c-b24f-f7ea428134e9" | ||
|
@@ -14,9 +14,16 @@ NodeJS_20_jll = "c7aee132-11e1-519c-8219-0a43005e73c2" | |
REPL = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb" | ||
|
||
[compat] | ||
julia = "1.6" | ||
ANSIColoredPrinters = "0.0.1" | ||
Documenter = "1" | ||
DocStringExtensions = "0.9" | ||
Documenter = "1" | ||
DocumenterCitations = "1" | ||
IOCapture = "0.2" | ||
NodeJS_20_jll = "20" | ||
julia = "1.6" | ||
|
||
[weakdeps] | ||
DocumenterCitations = "daee34ce-89f3-4625-b898-19384cb65244" | ||
|
||
[extensions] | ||
DocumenterVitepressDocumenterCitationsExt = "DocumenterCitations" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,4 @@ | ||
[deps] | ||
Documenter = "e30172f5-a6a5-5a46-863b-614d45cd2de4" | ||
DocumenterVitepress = "4710194d-e776-4893-9690-8d956a29c365" | ||
DocumenterCitations = "daee34ce-89f3-4625-b898-19384cb65244" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,197 @@ | ||
# DocumenterCitations.jl integration | ||
|
||
This page shows the DocumenterCitations.jl integration and what it looks like. You can use DocumenterCitations in DocumenterVitepress in the same way that you use them in Documenter! | ||
|
||
This page's source was taken from the DocumenterCitations docs and rendered via DocumenterVitepress. | ||
|
||
# [Citation Style Gallery](@id gallery) | ||
|
||
The citation style is determined when instantiating the `CitationBibliography`, via the `style` argument. | ||
|
||
The built-in styles are: | ||
|
||
* `style=:numeric` (default): [numeric style](@ref numeric_style) | ||
* `style=:authoryear`: [author-year style](@ref author_year_style) | ||
* `style=:alpha`: [alphabetic style](@ref alphabetic_style) | ||
|
||
## [Numeric style](@id numeric_style) | ||
|
||
This is the default style (`style=:numeric`) used throughout the other pages of this documentation, cf. the Syntax examples. | ||
|
||
* `[GoerzQ2022](@cite)` renders as "[GoerzQ2022](@cite)" | ||
* `[FuerstNJP2014,SolaAAMOP2018](@cite)` renders as "[FuerstNJP2014,SolaAAMOP2018](@cite)" | ||
* `[GoerzQ2022](@citet)` renders as "[GoerzQ2022](@citet)" | ||
* `[GoerzQ2022](@citep)` renders as "[GoerzQ2022](@citep)" — `@citep` is the same as `@cite` for this style | ||
* `[GoerzQ2022; Eq. (1)](@cite)` renders as "[GoerzQ2022; Eq. (1)](@cite)" | ||
* `[GoerzQ2022; Eq. (1)](@citet)` renders as "[GoerzQ2022; Eq. (1)](@citet)" | ||
* `[GoerzQ2022](@citet*)` renders as "[GoerzQ2022](@citet*)" | ||
* `[GoerzQ2022; Eq. (1)](@citet*)` renders as "[GoerzQ2022; Eq. (1)](@citet*)" | ||
* `[WinckelIP2008](@citet)` renders as "[WinckelIP2008](@citet)" | ||
* `[WinckelIP2008](@Citet)` renders as "[WinckelIP2008](@Citet)" | ||
* `[BrumerShapiro2003, BrifNJP2010, Shapiro2012, KochJPCM2016; and references therein](@cite)` renders as "[BrumerShapiro2003, BrifNJP2010, Shapiro2012, KochJPCM2016; and references therein](@cite)" | ||
* `[BrumerShapiro2003, BrifNJP2010, Shapiro2012, KochJPCM2016; and references therein](@Citet)` renders as "[BrumerShapiro2003, BrifNJP2010, Shapiro2012, KochJPCM2016; and references therein](@Citet)" | ||
* `[arbitrary text](@cite GoerzQ2022)` renders as "[arbitrary text](@cite GoerzQ2022)" | ||
|
||
**References:** | ||
|
||
```@bibliography | ||
Pages = [@__FILE__] | ||
Style = :numeric | ||
Canonical = false | ||
``` | ||
|
||
## [Author-year style](@id author_year_style) | ||
|
||
The author-year style (`style=:authoryear`) formats citations with the author name and publication year. This is the citation style used, e.g., in [Rev. Mod. Phys.](https://journals.aps.org/rmp/) (`rmp` option in [REVTeX](https://www.ctan.org/tex-archive/macros/latex/contrib/revtex/auguide)). The bibliography is sorted alphabetically by author name. The default `@cite` command is parenthetical (`@cite` and `@citep` are equivalent) which is different from the `authoryear` style in [natbib](https://mirrors.rit.edu/CTAN/macros/latex/contrib/natbib/natnotes.pdf). | ||
|
||
* `[GoerzQ2022](@cite)` renders as "[GoerzQ2022](@cite%authoryear%)" | ||
* `[FuerstNJP2014,SolaAAMOP2018](@cite)` renders as "[FuerstNJP2014,SolaAAMOP2018](@cite%authoryear%)" | ||
* `[GoerzQ2022](@citet)` renders as "[GoerzQ2022](@citet%authoryear%)" | ||
* `[GoerzQ2022](@citep)` renders as "[GoerzQ2022](@citep%authoryear%)" — `@citep` is the same as `@cite` for this style | ||
* `[GoerzQ2022; Eq. (1)](@cite)` renders as "[GoerzQ2022; Eq. (1)](@cite%authoryear%)" | ||
* `[GoerzQ2022; Eq. (1)](@citet)` renders as "[GoerzQ2022; Eq. (1)](@citet%authoryear%)" | ||
* `[GoerzQ2022](@cite*)` renders as "[GoerzQ2022](@cite*%authoryear%)" | ||
* `[GoerzQ2022](@citet*)` renders as "[GoerzQ2022](@citet*%authoryear%)" | ||
* `[GoerzQ2022; Eq. (1)](@cite*)` renders as "[GoerzQ2022; Eq. (1)](@cite*%authoryear%)" | ||
* `[GoerzQ2022; Eq. (1)](@citet*)` renders as "[GoerzQ2022; Eq. (1)](@citet*%authoryear%)" | ||
* `[WinckelIP2008](@citet)` renders as "[WinckelIP2008](@citet%authoryear%)" | ||
* `[WinckelIP2008](@Citet)` renders as "[WinckelIP2008](@Citet%authoryear%)" | ||
* `[BrumerShapiro2003, BrifNJP2010, Shapiro2012, KochJPCM2016; and references therein](@cite)` renders as "[BrumerShapiro2003, BrifNJP2010, Shapiro2012, KochJPCM2016; and references therein](@cite%authoryear%)" | ||
* `[BrumerShapiro2003, BrifNJP2010, Shapiro2012, KochJPCM2016; and references therein](@Citet)` renders as "[BrumerShapiro2003, BrifNJP2010, Shapiro2012, KochJPCM2016; and references therein](@Citet%authoryear%)" | ||
* `[arbitrary text](@cite GoerzQ2022)` renders as "[arbitrary text](@cite GoerzQ2022)" | ||
|
||
**References:** | ||
|
||
```@bibliography | ||
Pages = [@__FILE__] | ||
Style = :authoryear | ||
Canonical = false | ||
``` | ||
|
||
## [Alphabetic style](@id alphabetic_style) | ||
|
||
The `style=:alpha` formats citations and references like `:numeric`, except that it uses labels derived from the author names and publication year and sorts the references alphabetically. | ||
|
||
* `[GoerzQ2022](@cite)` renders as "[GoerzQ2022](@cite%alpha%)" | ||
* `[FuerstNJP2014,SolaAAMOP2018](@cite)` renders as "[FuerstNJP2014,SolaAAMOP2018](@cite%alpha%)" | ||
* `[GoerzQ2022](@citet)` renders as "[GoerzQ2022](@citet%alpha%)" | ||
* `[GoerzQ2022](@citep)` renders as "[GoerzQ2022](@citep%alpha%)" — `@citep` is the same as `@cite` for this style | ||
* `[GoerzQ2022; Eq. (1)](@cite)` renders as "[GoerzQ2022; Eq. (1)](@cite%alpha%)" | ||
* `[GoerzQ2022; Eq. (1)](@citet)` renders as "[GoerzQ2022; Eq. (1)](@citet%alpha%)" | ||
* `[GoerzQ2022](@citet*)` renders as "[GoerzQ2022](@citet*%alpha%)" | ||
* `[GoerzQ2022; Eq. (1)](@citet*)` renders as "[GoerzQ2022; Eq. (1)](@citet*%alpha%)" | ||
* `[WinckelIP2008](@citet)` renders as "[WinckelIP2008](@citet%alpha%)" | ||
* `[WinckelIP2008](@Citet)` renders as "[WinckelIP2008](@Citet%alpha%)" | ||
* `[BrumerShapiro2003, BrifNJP2010, Shapiro2012, KochJPCM2016; and references therein](@cite)` renders as "[BrumerShapiro2003, BrifNJP2010, Shapiro2012, KochJPCM2016; and references therein](@cite%alpha%)". Note that unlike for `style=:numeric`, the citations are not compressed. | ||
* `[BrumerShapiro2003, BrifNJP2010, Shapiro2012, KochJPCM2016; and references therein](@Citet)` renders as "[BrumerShapiro2003, BrifNJP2010, Shapiro2012, KochJPCM2016; and references therein](@Citet%alpha%)" | ||
* `[arbitrary text](@cite GoerzQ2022)` renders as "[arbitrary text](@cite GoerzQ2022)" | ||
|
||
**References:** | ||
|
||
```@bibliography | ||
Pages = [@__FILE__] | ||
Style = :alpha | ||
Canonical = false | ||
SolaAAMOP2018 | ||
``` | ||
|
||
```@raw latex | ||
Compared to the HTML version of the documentation, the hanging indent in the above list of references is too small for the longer labels of the \texttt{:alpha} style. This can be remedied by adjusting the \texttt{dl\_hangindent} and \texttt{dl\_labelwidth} parameters with \hyperlinkref{sec:customizing_latex_output}{\texttt{DocumenterCitations.set\_latex\_options}}. | ||
``` | ||
|
||
Note that the `:alpha` style is able to automatically disambiguate labels: | ||
|
||
```@bibliography | ||
Pages = [] | ||
Style = :alpha | ||
Canonical = false | ||
GraceJMO2007 | ||
GraceJPB2007 | ||
``` | ||
|
||
This works because the `DocumenterCitations` plugin automatically upgrades `style=:alpha` to the internal | ||
|
||
``` | ||
DocumenterCitations.AlphaStyle | ||
``` | ||
|
||
|
||
## [Custom styles](@id custom_styles) | ||
|
||
In the following, we show two examples for user-defined styles. See the notes on customization on how to generally define a custom style. | ||
|
||
### Custom style: enumerated author-year | ||
|
||
In this example, the `:authoryear` style is used, but the references are shown in an enumerated list. | ||
|
||
~~~@eval | ||
# custom styles are included in docs/make.jl, which is how we get around | ||
# world-age issues. | ||
using Markdown | ||
custom_style = joinpath(@__DIR__, "..", "custom_styles", "enumauthoryear.jl") | ||
if isfile(custom_style) | ||
Markdown.parse(""" | ||
```julia | ||
$(read(custom_style, String)) | ||
``` | ||
""") | ||
end | ||
~~~ | ||
|
||
The important part of the definition is in the last line, indicating that the References should be shown as an enumeration (ordered list, `<ol>`, in HTML), see below. Meanwhile, citations render exactly as with `style=:authoryear`: | ||
|
||
* `[GoerzQ2022](@cite)` renders as "[GoerzQ2022](@cite%enumauthoryear%)" | ||
* `[FuerstNJP2014,SolaAAMOP2018](@cite)` renders as "[FuerstNJP2014,SolaAAMOP2018](@cite%enumauthoryear%)" | ||
* `[WinckelIP2008](@Citet)` renders as "[WinckelIP2008](@Citet%enumauthoryear%)" | ||
|
||
**References:** | ||
|
||
```@bibliography | ||
Pages = [@__FILE__] | ||
Style = :enumauthoryear | ||
Canonical = false | ||
``` | ||
|
||
### Custom style: Citation-key labels | ||
|
||
In this less trivial example, a style similar to `:alpha` is used, using the citation keys in the `.bib` file as labels. This would be somewhat more appropriate with citation keys that are shorter that the ones used here (keys similar to those automatically generated with the `:alpha` style). | ||
|
||
~~~@eval | ||
# custom styles are included in docs/make.jl, which is how we get around | ||
# world-age issues. | ||
using Markdown | ||
custom_style = joinpath(@__DIR__, "..", "custom_styles", "keylabels.jl") | ||
if isfile(custom_style) | ||
Markdown.parse(""" | ||
```julia | ||
$(read(custom_style, String)) | ||
``` | ||
""") | ||
end | ||
~~~ | ||
|
||
* `[GoerzQ2022](@cite)` renders as "[GoerzQ2022](@cite%keylabels%)" | ||
* `[FuerstNJP2014,SolaAAMOP2018](@cite)` renders as "[FuerstNJP2014,SolaAAMOP2018](@cite%keylabels%)" | ||
* `[GoerzQ2022](@citet)` renders as "[GoerzQ2022](@citet%keylabels%)" | ||
* `[GoerzQ2022](@citep)` renders as "[GoerzQ2022](@citep%keylabels%)" — `@citep` is the same as `@cite` for this style | ||
* `[GoerzQ2022; Eq. (1)](@cite)` renders as "[GoerzQ2022; Eq. (1)](@cite%keylabels%)" | ||
* `[GoerzQ2022; Eq. (1)](@citet)` renders as "[GoerzQ2022; Eq. (1)](@citet%keylabels%)" | ||
* `[GoerzQ2022](@citet*)` renders as "[GoerzQ2022](@citet*%keylabels%)" | ||
* `[GoerzQ2022; Eq. (1)](@citet*)` renders as "[GoerzQ2022; Eq. (1)](@citet*%keylabels%)" | ||
* `[WinckelIP2008](@citet)` renders as "[WinckelIP2008](@citet%keylabels%)" | ||
* `[WinckelIP2008](@Citet)` renders as "[WinckelIP2008](@Citet%keylabels%)" | ||
* `[arbitrary text](@cite GoerzQ2022)` renders as "[arbitrary text](@cite GoerzQ2022)" | ||
|
||
**References:** | ||
|
||
```@bibliography | ||
Pages = [@__FILE__] | ||
Style = :keylabels | ||
Canonical = false | ||
``` | ||
|
||
```@raw latex | ||
As with the \texttt{:alpha} style, for \LaTeX{} output, the \texttt{dl\_hangindent} and \texttt{dl\_labelwidth} parameters should be adjusted with \hyperlinkref{sec:customizing_latex_output}{\texttt{DocumenterCitations.set\_latex\_options}} to obtain a more suitable hanging indent that matches the HTML version of this documentation. | ||
``` |
Oops, something went wrong.
1860fc2
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@JuliaRegistrator register
1860fc2
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Registration pull request created: JuliaRegistries/General/107159
Tip: Release Notes
Did you know you can add release notes too? Just add markdown formatted text underneath the comment after the text
"Release notes:" and it will be added to the registry PR, and if TagBot is installed it will also be added to the
release that TagBot creates. i.e.
To add them here just re-invoke and the PR will be updated.
Tagging
After the above pull request is merged, it is recommended that a tag is created on this repository for the registered package version.
This will be done automatically if the Julia TagBot GitHub Action is installed, or can be done manually through the github interface, or via: