Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adds default configuration for PDF generation #264

Merged
merged 9 commits into from
Aug 8, 2024
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 14 additions & 0 deletions .sphinx/_static/custom.css
Original file line number Diff line number Diff line change
Expand Up @@ -376,3 +376,17 @@ p code.literal {
.highlight .o {
color: #BB5400;
}

.rubric > .hclass2 {
SecondSkoll marked this conversation as resolved.
Show resolved Hide resolved
display: block;
font-size: 2em;
border-radius: .5rem;
font-weight: 300;
line-height: 1.25;
margin-top: 1.75rem;
margin-right: -0.5rem;
margin-bottom: 0.5rem;
margin-left: -0.5rem;
padding-left: .5rem;
padding-right: .5rem;
}
Binary file added .sphinx/fonts/Ubuntu-B.ttf
SecondSkoll marked this conversation as resolved.
Show resolved Hide resolved
Binary file not shown.
Binary file added .sphinx/fonts/Ubuntu-R.ttf
Binary file not shown.
Binary file added .sphinx/fonts/Ubuntu-RI.ttf
Binary file not shown.
Binary file added .sphinx/fonts/UbuntuMono-B.ttf
Binary file not shown.
Binary file added .sphinx/fonts/UbuntuMono-R.ttf
Binary file not shown.
Binary file added .sphinx/fonts/UbuntuMono-RI.ttf
Binary file not shown.
96 changes: 96 additions & 0 deletions .sphinx/fonts/ubuntu-font-licence-1.0.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
-------------------------------
UBUNTU FONT LICENCE Version 1.0
-------------------------------

PREAMBLE
This licence allows the licensed fonts to be used, studied, modified and
redistributed freely. The fonts, including any derivative works, can be
bundled, embedded, and redistributed provided the terms of this licence
are met. The fonts and derivatives, however, cannot be released under
any other licence. The requirement for fonts to remain under this
licence does not require any document created using the fonts or their
derivatives to be published under this licence, as long as the primary
purpose of the document is not to be a vehicle for the distribution of
the fonts.

DEFINITIONS
"Font Software" refers to the set of files released by the Copyright
Holder(s) under this licence and clearly marked as such. This may
include source files, build scripts and documentation.

"Original Version" refers to the collection of Font Software components
as received under this licence.

"Modified Version" refers to any derivative made by adding to, deleting,
or substituting -- in part or in whole -- any of the components of the
Original Version, by changing formats or by porting the Font Software to
a new environment.

"Copyright Holder(s)" refers to all individuals and companies who have a
copyright ownership of the Font Software.

"Substantially Changed" refers to Modified Versions which can be easily
identified as dissimilar to the Font Software by users of the Font
Software comparing the Original Version with the Modified Version.

To "Propagate" a work means to do anything with it that, without
permission, would make you directly or secondarily liable for
infringement under applicable copyright law, except executing it on a
computer or modifying a private copy. Propagation includes copying,
distribution (with or without modification and with or without charging
a redistribution fee), making available to the public, and in some
countries other activities as well.

PERMISSION & CONDITIONS
This licence does not grant any rights under trademark law and all such
rights are reserved.

Permission is hereby granted, free of charge, to any person obtaining a
copy of the Font Software, to propagate the Font Software, subject to
the below conditions:

1) Each copy of the Font Software must contain the above copyright
notice and this licence. These can be included either as stand-alone
text files, human-readable headers or in the appropriate machine-
readable metadata fields within text or binary files as long as those
fields can be easily viewed by the user.

2) The font name complies with the following:
(a) The Original Version must retain its name, unmodified.
(b) Modified Versions which are Substantially Changed must be renamed to
avoid use of the name of the Original Version or similar names entirely.
(c) Modified Versions which are not Substantially Changed must be
renamed to both (i) retain the name of the Original Version and (ii) add
additional naming elements to distinguish the Modified Version from the
Original Version. The name of such Modified Versions must be the name of
the Original Version, with "derivative X" where X represents the name of
the new work, appended to that name.

3) The name(s) of the Copyright Holder(s) and any contributor to the
Font Software shall not be used to promote, endorse or advertise any
Modified Version, except (i) as required by this licence, (ii) to
acknowledge the contribution(s) of the Copyright Holder(s) or (iii) with
their explicit written permission.

4) The Font Software, modified or unmodified, in part or in whole, must
be distributed entirely under this licence, and must not be distributed
under any other licence. The requirement for fonts to remain under this
licence does not affect any document created using the Font Software,
except any version of the Font Software extracted from a document
created using the Font Software may only be distributed under this
licence.

TERMINATION
This licence becomes null and void if any of the above conditions are
not met.

DISCLAIMER
THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF
COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM OTHER
DEALINGS IN THE FONT SOFTWARE.
Binary file added .sphinx/images/Canonical-logo-4x.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added .sphinx/images/front-page-light.pdf
Binary file not shown.
Binary file added .sphinx/images/front-page.png
SecondSkoll marked this conversation as resolved.
Show resolved Hide resolved
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added .sphinx/images/normal-page-footer.pdf
Binary file not shown.
119 changes: 119 additions & 0 deletions .sphinx/latex_elements_template.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,119 @@
{
'papersize': 'a4paper',
'pointsize': '11pt',
'fncychap': '',
'preamble': r'''
%\usepackage{charter}
%\usepackage[defaultsans]{lato}
%\usepackage{inconsolata}
\setmainfont[UprightFont = *-R, BoldFont = *-B, ItalicFont=*-RI, Extension = .ttf]{Ubuntu}
\setmonofont[UprightFont = *-R, BoldFont = *-B, ItalicFont=*-RI, Extension = .ttf]{UbuntuMono}
\usepackage[most]{tcolorbox}
\tcbuselibrary{breakable}
\usepackage{lastpage}
\usepackage{tabto}
\usepackage{ifthen}
\usepackage{etoolbox}
\usepackage{fancyhdr}
\usepackage{graphicx}
\usepackage{titlesec}
\usepackage{fontspec}
\usepackage{tikz}
\usepackage{changepage}
\usepackage{array}
\usepackage{tabularx}
\definecolor{yellowgreen}{RGB}{154, 205, 50}
\definecolor{title}{RGB}{76, 17, 48}
\definecolor{subtitle}{RGB}{116, 27, 71}
\definecolor{label}{RGB}{119, 41, 100}
\definecolor{copyright}{RGB}{174, 167, 159}
\makeatletter
\def\tcb@finalize@environment{%
\color{.}% hack for xelatex
\tcb@layer@dec%
}
\makeatother
\newenvironment{sphinxclassprompt}{\color{yellowgreen}\setmonofont[Color = 9ACD32, UprightFont = *-R, Extension = .ttf]{UbuntuMono}}{}
\tcbset{enhanced jigsaw, colback=black, fontupper=\color{white}}
\newtcolorbox{termbox}{use color stack, breakable, colupper=white, halign=flush left}
\newenvironment{sphinxclassterminal}{\setmonofont[Color = white, UprightFont = *-R, Extension = .ttf]{UbuntuMono}\sphinxsetup{VerbatimColor={black}}\begin{termbox}}{\end{termbox}}
\newcommand{\dimtorightedge}{%
\dimexpr\paperwidth-1in-\hoffset-\oddsidemargin\relax}
\newcommand{\dimtotop}{%
\dimexpr\height-1in-\voffset-\topmargin-\headheight-\headsep\relax}
\newtoggle{tpage}
\AtBeginEnvironment{titlepage}{\global\toggletrue{tpage}}
\fancypagestyle{plain}{
\fancyhf{}
\fancyfoot[R]{\thepage\ of \pageref*{LastPage}}
\renewcommand{\headrulewidth}{0pt}
\renewcommand{\footrulewidth}{0pt}
}
\fancypagestyle{normal}{
\fancyhf{}
\fancyfoot[R]{\thepage\ of \pageref*{LastPage}}
\renewcommand{\headrulewidth}{0pt}
\renewcommand{\footrulewidth}{0pt}
}
\fancypagestyle{titlepage}{%
\fancyhf{}
\fancyfoot[L]{\footnotesize \textcolor{copyright}{© 2024 Canonical Ltd. All rights reserved.}}
}
\newcommand\sphinxbackoftitlepage{\thispagestyle{titlepage}}
\titleformat{\chapter}[block]{\Huge \color{title} \bfseries\filright}{\thechapter .}{1.5ex}{}
\titlespacing{\chapter}{0pt}{0pt}{0pt}
\titleformat{\section}[block]{\huge \bfseries\filright}{\thesection .}{1.5ex}{}
\titlespacing{\section}{0pt}{0pt}{0pt}
\titleformat{\subsection}[block]{\Large \bfseries\filright}{\thesubsection .}{1.5ex}{}
\titlespacing{\subsection}{0pt}{0pt}{0pt}
\setcounter{tocdepth}{1}
\renewcommand\pagenumbering[1]{}
''',
'sphinxsetup': 'verbatimwithframe=false, pre_border-radius=0pt, verbatimvisiblespace=\\phantom{}, verbatimcontinued=\\phantom{}',
'extraclassoptions': 'openany,oneside',
'maketitle': r'''
\begin{titlepage}
\begin{flushleft}
\begin{tikzpicture}[remember picture,overlay]
\node[anchor=south east, inner sep=0] at (current page.south east) {
\includegraphics[width=\paperwidth, height=\paperheight]{front-page-light}
};
\end{tikzpicture}
\end{flushleft}

\vspace*{3cm}

\begin{adjustwidth}{8cm}{0pt}
\begin{flushleft}
\huge \textcolor{black}{\textbf{}{\raggedright{$PROJECT}}}
\end{flushleft}
\end{adjustwidth}

\vfill

\begin{adjustwidth}{8cm}{0pt}
\begin{tabularx}{0.5\textwidth}{ l l }
\textcolor{lightgray}{© 2024 Canonical Ltd.} & \hspace{3cm} \\
\textcolor{lightgray}{All rights reserved.} & \hspace{3cm} \\
& \hspace{3cm} \\
& \hspace{3cm} \\

\end{tabularx}
\end{adjustwidth}

\end{titlepage}
\RemoveFromHook{shipout/background}
\AddToHook{shipout/background}{
\begin{tikzpicture}[remember picture,overlay]
\node[anchor=south west, align=left, inner sep=0] at (current page.south west) {
\includegraphics[width=\paperwidth]{normal-page-footer}
};
\end{tikzpicture}
\begin{tikzpicture}[remember picture,overlay]
\node[anchor=north east, opacity=0.5, inner sep=35] at (current page.north east) {
\includegraphics[width=4cm]{Canonical-logo-4x}
};
\end{tikzpicture}
}
''',
}
22 changes: 20 additions & 2 deletions Makefile.sp
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,11 @@ VENV = $(VENVDIR)/bin/activate
TARGET = *
ALLFILES = *.rst **/*.rst
ADDPREREQS ?=
REQPDFPACKS = latexmk fonts-freefont-otf fonts-ibm-plex texlive-latex-recommended texlive-latex-extra texlive-fonts-recommended texlive-font-utils texlive-lang-cjk texlive-xetex plantuml xindy tex-gyre dvipng

.PHONY: sp-full-help sp-woke-install sp-pa11y-install sp-install sp-run sp-html \
sp-epub sp-serve sp-clean sp-clean-doc sp-spelling sp-spellcheck sp-linkcheck sp-woke \
sp-pa11y Makefile.sp sp-vale
sp-pa11y sp-pdf-prep-force sp-pdf-prep sp-pdf Makefile.sp sp-vale

sp-full-help: $(VENVDIR)
@. $(VENV); $(SPHINXBUILD) -M help "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O)
Expand Down Expand Up @@ -114,7 +115,24 @@ sp-vale: sp-install
@echo ""
@. $(VENV); vale --config "$(SPHINXDIR)/vale.ini" --glob='*.{md,txt,rst}' $(TARGET)


sp-pdf-prep: sp-install
@for packageName in $(REQPDFPACKS); do (dpkg-query -W -f='$${Status}' $$packageName 2>/dev/null | \
grep -c "ok installed" >/dev/null && echo "Package $$packageName is installed") || \
(echo "PDF generation requires the installation of the following packages: $(REQPDFPACKS)" && \
echo "" && echo "sudo make pdf-prep-force will install these packages" && echo "" && echo \
SecondSkoll marked this conversation as resolved.
Show resolved Hide resolved
"Please be aware these packages will be installed to your system" && false) ; done

sp-pdf-prep-force:
apt-get update
apt-get upgrade -y
apt-get install --no-install-recommends -y $(REQPDFPACKS) \

sp-pdf: sp-pdf-prep
@. $(VENV); sphinx-build -M latexpdf "$(SOURCEDIR)" "_build" $(SPHINXOPTS)
SecondSkoll marked this conversation as resolved.
Show resolved Hide resolved
@. $(VENV); rm ./_build/latex/front-page-light.pdf || true
@. $(VENV); rm ./_build/latex/normal-page-footer.pdf || true
@. $(VENV); find ./_build/latex -name "*.pdf" -exec mv -t ./ {} +
@. $(VENV); rm -r _build
SecondSkoll marked this conversation as resolved.
Show resolved Hide resolved

# Catch-all target: route all unknown targets to Sphinx using the new
# "make mode" option. $(O) is meant as a shortcut for $(SPHINXOPTS).
Expand Down
29 changes: 29 additions & 0 deletions custom_conf.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import datetime
import ast

# Custom configuration for the Sphinx documentation builder.
# All configuration specific to your project should be done in this file.
Expand Down Expand Up @@ -212,6 +213,32 @@
# that you want to link to:
# manpages_url = "https://manpages.ubuntu.com/manpages/noble/en/man{section}/{page}.{section}.html"

############################################################
SecondSkoll marked this conversation as resolved.
Show resolved Hide resolved
### -- Options for PDF output ------------------------------
############################################################
SecondSkoll marked this conversation as resolved.
Show resolved Hide resolved

latex_additional_files = [
"./.sphinx/fonts/Ubuntu-B.ttf",
"./.sphinx/fonts/Ubuntu-R.ttf",
"./.sphinx/fonts/Ubuntu-RI.ttf",
"./.sphinx/fonts/UbuntuMono-R.ttf",
"./.sphinx/fonts/UbuntuMono-RI.ttf",
"./.sphinx/fonts/UbuntuMono-B.ttf",
"./.sphinx/images/Canonical-logo-4x.png",
"./.sphinx/images/front-page-light.pdf",
"./.sphinx/images/normal-page-footer.pdf",
]

latex_engine = 'xelatex'
latex_show_pagerefs = True
latex_show_urls = 'footnote'

with open(".sphinx/latex_elements_template.txt", "rt") as file:
latex_config = file.read()

latex_elements = ast.literal_eval(latex_config.replace("$PROJECT", project))
SecondSkoll marked this conversation as resolved.
Show resolved Hide resolved


############################################################
### Additional configuration
############################################################
Expand All @@ -222,4 +249,6 @@
rst_prolog = '''
.. role:: center
:class: align-center
.. role:: h2
:class: hclass2
'''
2 changes: 2 additions & 0 deletions doc-cheat-sheet.rst
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,8 @@ Also see the `Sphinx reStructuredText Primer <https://www.sphinx-doc.org/en/mast
H2 heading
----------

.. rubric:: :h2:`H2 heading without TOC entry`

H3 heading
~~~~~~~~~~

Expand Down
2 changes: 2 additions & 0 deletions index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ For quick help on reST or MyST syntax, see the :file:`doc-cheat-sheet.rst.txt` o

More information is available in the `reStructuredText style guide`_.

.. rubric:: :h2:`In this documentation`

.. toctree::
:hidden:
:maxdepth: 2
Expand Down
28 changes: 28 additions & 0 deletions readme.rst
Original file line number Diff line number Diff line change
Expand Up @@ -229,6 +229,34 @@ your doc files were placed (repository root or the ``docs`` directory):
make install
make html

Build a PDF
^^^^^^^^^^^

Build a PDF locally with the following command:

.. code-block:: none

make pdf

PDF generation requires some system files. If these files are not found, a prompt will be presented and the generation will stop.

On Linux, required packages can be installed with:

.. code-block:: none

make pdf-prep-force

.. note::

When generating a PDF, the index page is considered a 'foreword' and will not be labelled with a chapter.

.. important::

When generating a PDF, it is important to not use additional headings before the ``toctree`` on the index page. Documents referenced by the
SecondSkoll marked this conversation as resolved.
Show resolved Hide resolved
``toctree`` will be nested under any provided headings.

A ``rubric`` directive can be combined with the ``h2`` class to provide a heading styled rubric in the HTML output. See the default ``index.rst`` for an example.

Configure the documentation
~~~~~~~~~~~~~~~~~~~~~~~~~~~

Expand Down