The Citation.cff is a fantastic format that combines human-readable and machine-readable metadata about its repository. It provides linking systems with important metadata about the presented project and gives people the ability to reference the project, among other things. However, for a wide range of users, the YAML file format can seem intimidating, whereas a clean website is generally more readable. This project aims to automate the conversion of cff files, so that maintaining the cff file pays off for developers in terms of the project's presentation, thereby ensuring that the website representation is retained.
cff2pages is envisioned as a Python package, designed to automate the extraction of metadata from your project's Citation.cff file, and swiftly generate a sleek, static HTML page. This versatile page can serve as a vivid representation of your project on Github/Gitlab Pages.
usage: cff2pages [-h] [-i [INPUT]] [-o [OUTPUT]]
Converts citation information in Citation File Format into HTML or Markdown
options:
-h, --help show this help message and exit
-i [INPUT], --input [INPUT]
path to the input CFF file. Default: ./CITATION.cff
-o [OUTPUT], --output [OUTPUT]
path to the output file. Default: public/citation.html
cd project_folder
pip install cff2pages
cff2pages
By default, output will be written to public/citation.html
.
stages:
- Pages
pages:
stage: Pages
image: python:3.11
script:
- python -m pip install cff2pages
- cff2pages -o public/index.html
artifacts:
paths:
- public
deploy:
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Set up Python 3.11
uses: actions/setup-python@v3
with:
python-version: 3.11
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install cff2pages
cff2pages -o public/index.html
- name: Setup Pages
uses: actions/configure-pages@v3
- name: Upload artifact
uses: actions/upload-pages-artifact@v2
with:
path: './public'
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v2