Skip to content

Commit

Permalink
Cleaning up schema
Browse files Browse the repository at this point in the history
  • Loading branch information
giovannipizzi committed Feb 14, 2024
1 parent db30bf0 commit 8baa5c5
Show file tree
Hide file tree
Showing 8 changed files with 42 additions and 92 deletions.
42 changes: 19 additions & 23 deletions codes.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -2,21 +2,21 @@
YAMBO:
categories:
- ab-initio_engines
git_url: https://github.com/yambo-code/yambo.git
metadata:
description: |
A FORTRAN/C code for Many-Body calculations in solid state and molecular physics.
documentation_url: https://www.yambo-code.eu/wiki/index.php/Main_Page
title: Yambo
logo: 
sourcecode_url: https://github.com/yambo-code/yambo.git
logo: https://fresh.yambo-code.eu/wp-content/uploads/2023/02/yambo_logo_overlay.svg

Quantum ESPRESSO:
categories:
- ab-initio_engines
git_url: https://gitlab.com/QEF/q-e
metadata:
description: |
Quantum ESPRESSO is an integrated suite of open-source computer codes for quantum simulations of materials using state-of-the art electronic-structure techniques, based on density-functional theory, density-functional perturbation theory, and many-body perturbation theory, within the plane-wave pseudo-potential and projector-augmented-wave approaches
sourcecode_url: https://gitlab.com/QEF/q-e
documentation_url: https://www.quantum-espresso.org/documentation/
title: Quantum ESPRESSO
logo: https://www.quantum-espresso.org/wp-content/uploads/2022/03/quantum_ogo_ok.png
Expand All @@ -25,32 +25,31 @@ ABINIT:
categories:
- ab-initio_engines
- dmft
git_url: https://github.com/abinit/abinit
metadata:
description: |
ABINIT is a software suite to calculate the optical, mechanical, vibrational, and other observable properties of materials. Starting from the quantum equations of density functional theory, you can build up to advanced applications with perturbation theories based on DFT, and many-body Green's functions (GW and DMFT).
documentation_url: https://www.abinit.org
sourcecode_url: https://github.com/abinit/abinit
homepage_url: https://www.abinit.org
title: ABINIT
logo: https://www.abinit.org/themes/abinit/logo-abinit-2015.svg

WIEN2k:
categories:
- ab-initio_engines
hosted_on: http://susi.theochem.tuwien.ac.at
metadata:
description: |
ABINIT is a software suite to calculate the optical, mechanical, vibrational, and other observable properties of materials. Starting from the quantum equations of density functional theory, you can build up to advanced applications with perturbation theories based on DFT, and many-body Green's functions (GW and DMFT).
documentation_url: http://susi.theochem.tuwien.ac.at
homepage_url: http://susi.theochem.tuwien.ac.at
title: WIEN2k
logo: http://susi.theochem.tuwien.ac.at/img/wien2k_logo_3.gif

VASP:
categories:
- ab-initio_engines
hosted_on: https://www.vasp.at
metadata:
description: |
The Vienna Ab initio Simulation Package (VASP) is a computer program for atomic scale materials modelling, e.g. electronic structure calculations and quantum-mechanical molecular dynamics, from first principles.
homepage_url: https://www.vasp.at
documentation_url: https://www.vasp.at/wiki/index.php/LWANNIER90
title: VASP
logo: https://www.vasp.at/wiki/images/vasp_logo_alpha.png
Expand All @@ -59,35 +58,33 @@ pythtb:
categories:
- tb
- berry
hosted_on: https://pypi.org/project/pythtb/
metadata:
description: |
Simple solver for tight binding models for use in condensed matter physics and materials science.
documentation_url: https://www.physics.rutgers.edu/pythtb/index.html
interface_docs_url: https://www.physics.rutgers.edu/pythtb/usage.html#pythtb.w90
sourcecode_url: https://pypi.org/project/pythtb/
documentation_url: https://www.physics.rutgers.edu/pythtb/usage.html#pythtb.w90
title: PythTB
logo: https://www.physics.rutgers.edu/pythtb/_images/graphene.png

tbmodels:
categories:
- tb
- berry
git_url: https://github.com/Z2PackDev/TBmodels
metadata:
description: |
Bmodels is a Python package for evaluating tight-binding models. It features methods for reading and writing tight-binding models to various formats, and evaluating the Hamiltonian and eigenvalues of the system. It is considerably faster than comparable packages, enabling it to handle first-principles derived tight-binding models.
documentation_url: https://tbmodels.greschd.ch/en/latest/tutorial.html
interface_docs_url: https://tbmodels.greschd.ch/en/latest/tutorial.html#id3
sourcecode_url: https://github.com/Z2PackDev/TBmodels
documentation_url: https://tbmodels.greschd.ch/en/latest/tutorial.html#id3
title: TBmodels
logo: https://tbmodels.greschd.ch/en/latest/_images/tbmodels_logo.jpg

z2pack:
categories:
- berry
git_url: https://github.com/Z2PackDev/Z2Pack
metadata:
description: |
Z2Pack automates the calculation of topological numbers of band-structures. It works with first-principles calculations (z2pack.fp), tight-binding models (z2pack.tb) and explicit Hamiltonian matrices (z2pack.hm).
sourcecode_url: https://github.com/Z2PackDev/Z2Pack
documentation_url: https://z2pack.greschd.ch/
title: Z2Pack
logo: https://z2pack.greschd.ch/en/latest/_static/z2_logo_150.png
Expand All @@ -96,10 +93,10 @@ wanniertools:
categories:
- tb
- berry
git_url: https://github.com/quanshengwu/wannier_tools
metadata:
description: |
An open-source software package for novel topological materials.
sourcecode_url: https://github.com/quanshengwu/wannier_tools
documentation_url: http://www.wanniertools.com/#
title: WannierTools
logo: https://github.com/quanshengwu/wannier_tools/raw/master/wt-logo.jpg
Expand All @@ -108,23 +105,23 @@ wannierberri:
categories:
- tb
- berry
git_url: https://github.com/wannier-berri/wannier-berri
metadata:
description: |
A code to calculate different properties by means of Wannier interpolation: Berry curvature, orbital moment and derived properties.
documentation_url: https://wannier-berri.org
interface_docs_url: https://docs.wannier-berri.org/en/master/docs/system.html#id3
sourcecode_url: https://github.com/wannier-berri/wannier-berri
homepage_url: https://wannier-berri.org
documentation_url: https://docs.wannier-berri.org/en/master/docs/system.html#id3
title: Wannier Berri
logo: https://docs.wannier-berri.org/en/master/_static/Book.png

strawberrypy:
categories:
- tb
- berry
git_url: https://github.com/strawberrypy-developers/strawberrypy
metadata:
description: |
StraWBerryPy (Single-poinT and local invaRiAnts for Wannier Berriologies in Python) is a Python package to calculate topological invariants and quantum-geometrical quantities in non-crystalline topological insulators.
sourcecode_url: https://github.com/strawberrypy-developers/strawberrypy
documentation_url: https://strawberrypy.readthedocs.io/en/latest/
title: StraWBerryPy
logo: https://strawberrypy.readthedocs.io/en/latest/_static/logo.png
Expand All @@ -133,12 +130,11 @@ linres:
categories:
- tb
- berry
hosted_on: https://bitbucket.org/zeleznyj/wannier-linear-response/src/master/
metadata:
description: |
Code for calculating linear response properties based on tight-binding Hamiltonians. It is mainly used with tight-binding Hamiltonians obtained from wannier90 or from the FPLO DFT code but any tight-binding can be used. A python program for generating sd models that is also interfaced to the linear response code is also included. The code utilizes Kubo formula with constant Gamma approximation to calculate conductivity and the anomalous Hall effect, spin Hall effect and the current induced spin-polarization, which gives rise to the spin-orbit torque. Other response quantities can be easily implemented.
sourcecode_url: https://bitbucket.org/zeleznyj/wannier-linear-response/src/master/
homepage_url: https://bitbucket.org/zeleznyj/wannier-linear-response/wiki/Home
documentation_url: https://bitbucket.org/zeleznyj/wannier-linear-response/wiki/Home
title: linres
logo: None


2 changes: 1 addition & 1 deletion schemas/codes.schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
"type": "object",
"additionalProperties": false,
"properties": {
"git_url": {
"sourcecode_url": {
"type": "string",
"format": "uri",
"qt-uri-protocols": [
Expand Down
2 changes: 1 addition & 1 deletion schemas/codes_meta.schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@
"type": "object",
"additionalProperties": false,
"properties": {
"git_url": {
"sourcecode_url": {
"type": "string",
"format": "uri",
"qt-uri-protocols": [
Expand Down
4 changes: 2 additions & 2 deletions schemas/metadata.schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
"type": "object",
"additionalProperties": false,
"properties": {
"codename": {
"title": {
"type": "string"
},
"description": {
Expand All @@ -24,7 +24,7 @@
"type": "string",
"format": "uri"
},
"interface_docs_url": {
"documentation_url": {
"type": "string",
"format": "uri"
},
Expand Down
14 changes: 0 additions & 14 deletions src/code_registry/metadata.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,24 +23,10 @@ def complete_metadata(code_name, metadata, git_url):
def fetch_code_data(code_data, code_name):
"""Fetch additional data for the given code data."""

# Get Git URL, fail build if git_url is not found or wrong
git_url = code_data.get("git_url", "")
hosted_on = util.get_hosted_on(git_url) if git_url else None

# Check if categories are specified, warn if not
if "categories" not in code_data:
logger.info(" >> WARNING: No categories specified.")

code_data["metadata"] = complete_metadata(code_name, code_data["metadata"], git_url)
if git_url:
code_data["gitinfo"] = util.get_git_branches(git_url)
if hosted_on:
code_data["hosted_on"] = hosted_on

# Get logo URL, if it has been specified
if "logo" in code_data["metadata"]:
code_data["logo"] = code_data["metadata"]["logo"]

return code_data


Expand Down
21 changes: 4 additions & 17 deletions src/code_registry/util.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,30 +17,17 @@ def get_html_code_fname(code_name):
return f"{simple_string}.html"


def get_hosted_on(url):
netloc = urlparse(url).netloc

# Remove port (if any)
netloc = netloc.partition(":")[0]

# Remove subdomains (this only works for domain suffixes of length 1!)
# TODO: fix it for domains like yyy.co.uk
netloc = ".".join(netloc.split(".")[-2:])

return netloc


def get_git_branches(git_url):
t, p = get_transport_and_path_from_url(git_url)
def get_git_branches(sourcecode_url):
t, p = get_transport_and_path_from_url(sourcecode_url)
branches = t.get_refs(p)
res = {}
for key, value in branches.items():
res[key.decode("utf-8")] = value.decode("utf-8")
return res


def get_git_author(git_url):
return urlparse(git_url).path.split("/")[1]
def get_git_author(sourcecode_url):
return urlparse(sourcecode_url).path.split("/")[1]


def load_json(path: Path) -> dict:
Expand Down
20 changes: 2 additions & 18 deletions src/mod/templates/main_index.html
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,9 @@ <h1>
<div class="submenu-entry">
<div class="submenu-img">
<a href="{{ code.subpage }}">
{% if code.logo %}
{% if code.metadata.logo %}
<!-- img with error handler for dead links (fallback to ecosystem logo) -->
<img src="{{ code.logo }}" alt="{{ code.metadata.title }}"
<img src="{{ code.metadata.logo }}" alt="{{ code.metadata.title }}"
onerror="this.src='static/img/ecosystem-logo.png';this.onerror='';">
{% else %}
<img src="static/img/ecosystem-logo.png" alt="{{ code.metadata.title }}">
Expand All @@ -48,25 +48,9 @@ <h2><a href="{{ code.subpage }}">{{ code.metadata.title }}</a>
{% endif %}
</p>

{% if code.summaryinfo %}
<p class="summaryinfo">
{% for summaryinfoelem in code.summaryinfo %}
<span class="badge">
<span class="badge-left {{summaryinfoelem.colorclass}}">{{summaryinfoelem.text}}</span>
<span class="badge-right">{{summaryinfoelem.count}}</span>
</span>
{% endfor %}
</p>
{% endif %}
<p class='details'><a href="{{ code.subpage }}">Show details</a></p>
</div>
</div>

{#
{% if not loop.last %}
<hr>
{% endif %}
#}
{% endfor %}
</div>

Expand Down
29 changes: 13 additions & 16 deletions src/mod/templates/singlepage.html
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,8 @@

<div class="submenu-entry">
<div class="submenu-img">
{% if logo %}
<img src="{{ logo }}" alt="{{ metadata.title }}">
{% if metadata.logo %}
<img src="{{ metadata.logo }}" alt="{{ metadata.title }}">
{% else %}
<img src="../static/img/ecosystem-logo.png" alt="{{ metadata.title }}">
{% endif %}
Expand All @@ -33,34 +33,31 @@ <h1>{{ metadata.title }}</h1>
</div>

<h2>General information</h2>
{% if metadata.git_url %}
<div>
{% if metadata.homepage_url %}
<p>
<strong>Code homepage</strong>: <a href="{{ metadata.homepage_url }}" target="_blank">{{ metadata.homepage_url }}</a>
<p>
<strong>Source code</strong>: <a href="{{ git_url }}" target="_blank">Go to the code source code</a>
</p>
</div>
{% endif %}

{% if metadata.external_url %}
{% if metadata.documentation_url %}
<p>
<strong>Code homepage</strong>: <a href="{{ metadata.external_url }}" target="_blank">Go to code homepage</a>
<strong>Full documentation</strong>: <a href="{{ metadata.documentation_url }}" target="_blank">{{ metadata.documentation_url }}</a>
<p>
{% endif %}

{% if metadata.documentation_url %}
<p>
<strong>Documentation</strong>: <a href="{{ metadata.documentation_url }}" target="_blank">Go to code documentation</a>
{% if metadata.sourcecode_url %}
<div>
<p>
<strong>Source code</strong>: <a href="{{ metadata.sourcecode_url }}" target="_blank">{{ metadata.sourcecode_url }}</a>
</p>
</div>
{% endif %}

<h2>
Detailed information
</h2>
{% if metadata %}
{% if metadata.description %}
<div id='description'>
<p>
{% if hosted_on %} <strong>Source code:</strong> <a href="{{ git_url }}">{{ hosted_on }}</a>{% endif %}
</p>
<p>
<strong>Short description</strong>: {{ metadata.description }}
</p>
Expand Down

0 comments on commit 8baa5c5

Please sign in to comment.