Skip to content

Commit

Permalink
Merge pull request #269 from lsst/tickets/DM-46066
Browse files Browse the repository at this point in the history
 ASCOM latex as a paper style
  • Loading branch information
womullan authored Sep 6, 2024
2 parents d48f146 + 1bfdfe2 commit d45b6eb
Show file tree
Hide file tree
Showing 44 changed files with 14,256 additions and 8 deletions.
1 change: 1 addition & 0 deletions SConstruct
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ SConscript(
"project_templates/technote_aastex/SConscript",
"project_templates/technote_adasstex/SConscript",
"project_templates/technote_spietex/SConscript",
"project_templates/technote_ascomtex/SConscript",
"project_templates/test_report/SConscript",
"project_templates/latex_lsstdoc/SConscript",
"project_templates/fastapi_safir_app/SConscript",
Expand Down
5 changes: 5 additions & 0 deletions project_templates/technote_ascomtex/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
# Change log

## 2024-08-30

Creation
184 changes: 184 additions & 0 deletions project_templates/technote_ascomtex/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,184 @@
# technote_ascomtex

**LSST technical note repository, formatted as an Astronomy & Computing paper preprint.**

This template generates a new paper repository based on [Elsevier cas Tex](https://mirrors.ctan.org/macros/latex/contrib/elsarticle.zip).
This template also uses bib and author metadata from [lsst-texmf](https://lsst-texmf.lsst.io).
See [Technotes for stand-alone technical documentation in the Developer Guide](https://developer.lsst.io/project-docs/technotes.html).

## Template variables

### cookiecutter.org

The organization responsible for the document.

### cookiecutter.series

The identifier of the technote series which will be used to name the repo
Choose the series that fits the document's purpose or aligns with the organization creating the document.
For now to make this simpler we assume Papers are DMTN or PSTN.

- `DMTN` for Data Management technical notes.
- `PSTN` for Project Science Team technical notes.
- `TSTN` for Telescope and Site Team technical notes.

### cookiecutter.serial_number

The serial number. Use three digits padded with zeros.
If you are creating a technical note manually with this template, see the [Create a technote](https://developer.lsst.io/project-docs/technotes.html#create-a-technote) instructions for how to determine the serial number.

### cookiecutter.github_org

The GitHub organization where this technote resides.
Choose a GitHub organization that matches the [series](#cookiecutter_series):

- `lsst-dm` for the DMTN series.
- `lsst-pst` for the PSTN series.
- `lsst-ts` for the TSTN series.

### cookiecutter.title

The title of the technote.

### cookiecutter.author_id

The ID of the first author.
Author IDs may be found in the [https://github.com/lsst/lsst-texmf/blob/main/etc/authordb.yaml](authorsdb.yaml) file in lsst-texmf - this YAML database contains all LSST authors.
Additional authors can be added later in the `authors.yaml` file.
The file `authors.tex` is generated from the list of author codes in `authors.yaml`.

### cookiecutter.abstract

A short description of the technote's content and purpose.
This description is used in the repository's README and the abstract in the document itself.

### cookiecutter.copyright_year

The year of the initial copyright claim.
Cookiecutter will automatically populate the current year.

### cookiecutter.copyright_holder

The initial copyright holder.
See [Copyrights for LSST DM work and the COPYRIGHT file](https://developer.lsst.io/legal/copyright-overview.html) for more information.

## Examples

### testn-000/

The [testn-000](testn-000) directory is an example of a LaTeX-formatted technote.

## Files

## .github/workflows/ci.yaml

Example: [.github/workflows/ci.yaml](testn-000/.github/workflows/ci.yaml).

The GitHub Actions workflow file.
You shouldn't have to modify this file unless you have a novel preprocessing build step (see below).

**Tip:** GitHub Actions provides a flexible Python environment.
It's likely easier to run preprocessing scripts directly from the GitHub actions environment, rather than within the lsst-texmf Docker container:

- Install additional Python dependencies in the `Python install` step.
- Add additional bash commands for preprocessing steps to run before the `docker run` step.
- Structure your `Makefile` so that files built in advance in the GitHub actions environment are automatically used as-is by the `docker run` command.

For more information about using the CI environment, see the [GitHub actions workflow documentation](https://help.github.com/en/actions/reference/workflow-syntax-for-github-actions).

## .gitignore

Example: [.gitignore](testn-000/.gitignore).

The gitignore file ignores the built PDF product (which is persisted on LSST the Docs), as well as intermediate LaTeX build files (including `meta.tex`).
The `acronyms.tex` file is not ignored so that `make acronyms.tex` does not need to be run for every document build.

## acronyms.tex

Example: [acronyms.tex](testn-000/acronyms.tex).

This file is generated and updated by the `make acronyms.tex` command.

## authors.tex

Example: [authors.tex](testn-000/authors.tex).

The file `authors.tex` is generated from the list of author codes in `authors.yaml`.
This file is normally generated through the regular `make` command, but can also be regenerated individually by running `make authors.tex`.

### COPYRIGHT

Example: [COPYRIGHT](testn-000/COPYRIGHT).

Record copyright claims in this file, one line per institution.
See the [copyright](../copyright) template and [Copyrights for LSST DM work and the COPYRIGHT file](https://developer.lsst.io/legal/copyright-overview.html).

### LICENSE

Example: [LICENSE](testn-000/LICENSE).

Generally speaking, LSST documentation is licensed under CC-BY 4.0.
See [Licensing LSST DM source code and content](https://developer.lsst.io/legal/licensing-overview.html) in the Developer Guide for more information.

### local.bib

Example: [local.bib](testn-000/local.bib).

Add BibTeX citations to this file that aren't already available in [lsst-texmf](https://lsst-texmf.lsst.io) (the [lsstbib/](#testn-000/local_bib).
See the [Updating bibliographies](https://lsst-texmf.lsst.io/developer.html#updating-bibliographies) documentation in lsst-texmf for how to migrate local bibliography data upstream into [lsst-texmf](https://lsst-texmf.lsst.io).

### Makefile

Example: [Makefile](testn-000/Makefile).

The built-in targets are:

- `make`: compiles the PDF document by running `xelatex` and `bibtex` iteratively.
This command is used by the CI environment that pushes the PDF to LSST the Docs (lsst.io).
See the [.github/workflows/ci.yaml](#githubworkflowsciyaml) file.
- `make acronyms.tex`: regenerates the [acronyms.tex](#acronymstex) file.
- `make authors.tex`: regenerates the [authors.tex](#authorstex) file.

Add additional make targets to do preprocessing steps (such as running a Python script to generate tables or figures).

### myacronyms.txt

Example: [Makefile](testn-000/Makefile).

List acronyms in this file that are not found in lsst-texmf's [lsstacronyms.txt](https://github.com/lsst/lsst-texmf/blob/main/etc/lsstacronyms.txt) or [glossary.txt](https://github.com/lsst/lsst-texmf/blob/main/etc/glossary.txt), or that have multiple definitions (put the one you want in the local `myacronyms.txt` file).

The format for each line of this file is:

```
ACRONYM:Definition
```

For example:

```
MIA:Missing In Action
```

### README.rst

Example: [README.rst](testn-000/README.rst).

The README advertises the technote to GitHub visitors and provides instructions for authors.

You can update the abstract in the README and add author instructions as necessary.

### skipacronyms.txt

Example: [skipacronyms.txt](testn-000/skipacronyms.txt).

This file contains a list acronyms that should be ignored by `generateAcronyms.py` (the script behind `make acronyms.txt`).
If your document contains acronym-like strings that aren't acronyms, you can add them to `skipacronyms.txt`.

### {{cookiecutter.series.upper()}}-{{cookiecutter.serial_number}}.tex

Example: [TESTN-000.tex](testn-000/TESTN-000.tex)

This file contains the content of the technote itself.
Either write directly in this file, or use the `\input` command to include content from other files.

For more information about writing a LaTeX document with the `elsarticle` class file, see the [Elsvier Author Guide](https://www.elsevier.com/latex).
9 changes: 9 additions & 0 deletions project_templates/technote_ascomtex/SConscript
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
from templatekit.builder import cookiecutter_project_builder

# Run cookiecutter to generate the 'TESTN-000' report
env = Environment(BUILDERS={'Cookiecutter': cookiecutter_project_builder})
env.Cookiecutter(AlwaysBuild(Dir('TESTN-000')),
'cookiecutter.json',
cookiecutter_context={'series': 'TESTN',
'github_org': 'lsst-dm',
'author_id': 'omullanew'})
52 changes: 52 additions & 0 deletions project_templates/technote_ascomtex/cookiecutter.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
{
"org": [
"DM",
"OPS",
"PST",
"SE"
],
"series": [
"DMTN",
"PSTN",
"RTN",
"SITCOMTN",
"SMTN",
"TSTN",
"TESTN"
],
"serial_number": "000",
"github_org": [
"lsst",
"lsst-dm",
"lsst-pst",
"lsst-sims",
"lsst-sitcom",
"lsst-sqre-testing"

],
"title": "Document Title",
"author_id": "ID from lsst-texmf/etc/authorsdb.yaml",
"abstract": "Abstract text.",
"copyright_year": "{% now 'utc', '%Y' %}",
"copyright_holder": [
"Association of Universities for Research in Astronomy, Inc. (AURA)",
"Brookhaven Science Associates, LLC",
"California Institute of Technology",
"Fermi Research Alliance, LLC",
"The Board of Trustees of the Leland Stanford Junior University, through SLAC National Accelerator Laboratory",
"The Trustees of Princeton University",
"University of Illinois Board of Trustees",
"University of Washington"
],
"_copy_without_render": [
"*.bib",
"*acron*",
"els*.*",
"els*.bst",
".gitignore",
"body.tex"
],
"_extensions": [
"jinja2_time.TimeExtension"
]
}
61 changes: 61 additions & 0 deletions project_templates/technote_ascomtex/templatekit.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
name: "Technote (ASCOM LaTeX)"
group: "Documents"
dialog_title: "Create a paper"
dialog_fields:
- key: "title"
label: "Paper title"
placeholder: ""
hint: "Don't include the document's handle."
component: "textarea"
- key: "abstract"
label: "Abstract or description"
hint: "You can use LaTeX here."
component: "textarea"
placeholder: ""
- key: "author_id"
label: "First author's ID"
hint: "ID is a key from lsst-texmf's authors.yaml (http://ls.st/uyr)"
component: "text"
placeholder: ""
- label: "Series"
component: "select"
preset_options:
- label: "DMTN"
value: "DMTN"
presets:
series: "DMTN"
github_org: "lsst-dm"
org: "DM"
- label: "PSTN"
value: "PSTN"
presets:
series: "PSTN"
github_org: "lsst-pst"
org: "PST"
- label: "RTN"
value: "RTN"
presets:
series: "RTN"
github_org: "lsst"
org: "OPS"
- label: "SMTN"
value: "smtn"
presets:
series: "SMTN"
github_org: "lsst-sims"
org: "SE"
- label: "TSTN"
value: "tstn"
presets:
series: "TSTN"
github_org: "lsst-tstn"
org: "DM"
- label: "Test"
value: "test"
presets:
series: "TESTN"
github_org: "lsst-sqre-testing"
org: "DM"
- label: "Initial copyright holder"
key: "copyright_holder"
component: "select"
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
name: CI

"on": [push, pull_request]

jobs:
build:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0 # full history for metadata
submodules: true

- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: "3.10"

- name: Python install
run: |
python -m pip install --upgrade pip
python -m pip install "lander<2.0.0"
python -m pip install pyyaml
- name: Compile author list
run: |
make authors.tex
- name: Login to Docker Hub
uses: docker/login-action@v1
with:
username: sqrereadonly
password: ${{ secrets.DOCKERHUB_SQREREADONLY_TOKEN }}

- name: TeX build
run: |
docker run --rm -v `pwd`:/workspace -w /workspace lsstsqre/lsst-texmf:latest sh -c 'make'
- name: Landing page upload
if: ${{ github.event_name == 'push' }}
env:
LTD_PASSWORD: ${{ secrets.LTD_PASSWORD }}
LTD_USERNAME: ${{ secrets.LTD_USERNAME }}
run: |
lander --upload --pdf TESTN-000.pdf --ltd-product testn-000 --title "Document Title" --handle "TESTN-000" --lsstdoc "TESTN-000.tex"
11 changes: 11 additions & 0 deletions project_templates/technote_ascomtex/testn-000/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
*.aux
*.bbl
*.blg
*.fdb_latexmk
*.fls
*.log
*.out
*.xdv
*.dvi
*.pdf
authors.tex
1 change: 1 addition & 0 deletions project_templates/technote_ascomtex/testn-000/COPYRIGHT
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Copyright 2024 Association of Universities for Research in Astronomy, Inc. (AURA)
Loading

0 comments on commit d45b6eb

Please sign in to comment.