Skip to main content

Asennettavan pakettiversion haku git-leimojen mukaan

Project description

git-versiointi

Työkalupaketti pakettiversion ja -historian sekä vaadittavien riippuvuuksien automaattiseen määrittämiseen.

Asennus

Asennusta järjestelmään ei tarvita työasemalla eikä palvelimella.

Työkalut otetaan sen sijaan käyttöön kunkin halutun pip-asennettavan git-projektin osalta muokkaamalla vastaavaa setup.py-tiedostoa seuraavasti:

import setuptools

setuptools._install_setup_requires({'setup_requires': ['git-versiointi']})
from versiointi import asennustiedot

setuptools.setup(
  ...
  # version=...             <-- POISTA TÄMÄ
  # install_requires=...    <-- POISTA TÄMÄ
  ...
  **asennustiedot(__file__)
)

Kun pakettia asennetaan joko työasemalla (python setup.py develop) tai palvelimella (pip install ...), tekee järjestelmä setup.py-tiedoston suorittamisen yhteydessä automaattisesti seuraavaa:

  • asentaa git-versiointi-paketin, ellei sitä löydy jo valmiiksi järjestelmästä
  • suorittaa normaalin asennuksen muodostaen versionumeron yms. tiedot automaattisesti (ks. kuvaus jäljempänä)
  • poistaa asennuksen ajaksi asennetun git-versiointi-paketin

Versionumeron tutkiminen

Git-versiointia käyttävän paketin versionumero voidaan poimia komentoriviltä seuraavasti:

python <paketti>/setup.py --version

Toimintaperiaate

Skripti palauttaa setup()-kutsua varten seuraavat parametrit:

  • version: versionumero
  • historia: JSON-data, joka sisältää projektin git-versiohistorian
  • install_requires: asennuksen vaatimat riippuvuudet

Versionumeron muodostus

Versio- ja aliversionumero muodostetaan paketin sisältämän git-tietovaraston sisältämien tietojen mukaan. Tietovarastosta etsitään versionumerolta näyttäviä leimoja: tyyppiä ^v[0-9].

Mikäli tiettyyn git-muutokseen osoittaa suoraan jokin leima, puhutaan (kokonaisesta) versiosta; muutoin kyseessä on aliversio. Mikäli leima on tyyppiä [a-z][0-9]*$, puhutaan kehitysversiosta; muutoin kyseessä on julkaisuversio.

Kokonaisen version numero poimitaan versionumerojärjestyksessä (PEP 440) suurimman, suoraan kyseiseen muutokseen osoittavan git-leiman mukaisesti. Ensisijaisesti haetaan julkaisu- ja toissijaisesti kehitysversiota. Näin löydetty suora versioleima annetaan parametrinä leima.

Aliversion numero lasketaan lähimmän, versionumerojärjestyksessä suurimman julkaisu- tai kehitysversion sekä tämän päälle lasketun git-muutoshistorian pituuden mukaan. Nämä tiedot annetaan parametreinä leima ja etaisyys.

Oletuksena versio- ja aliversionumero lasketaan näiden tietojen mukaan seuraavasti:

  • kokonaiseen versioon liittyvän leima sellaisenaan
  • jos lähin, viimeisin leima kuvaa kehitysversiota (esim. v1.2.3a1, v1.2.3.dev3), muodostetaan aliversio lisäämällä etäisyys leiman loppunumeroon, esim. etäisyys 3 -> v1.2.3a4, v1.2.3.dev6
  • muussa tapauksessa aliversion etäisyys lisätään alanumerona leiman kuvaaman versionumero perään, esim. v1.2 + etäisyys 3 (kolme muutosta) --> versionumero v1.2.3

Versionumeroidan määritys voidaan räätälöidä seuraavilla tavoilla:

  • antamalla asennustiedot()-funktiokutsulle nimettyinä parametreinä versio- ja/tai aliversio-funktio, joka saa nimetyt parametrit leima ja etaisyys ja jonka tulee palauttaa versionumero merkkijonona
  • antamalla asennustiedot()-funktiokutsulle vastaavat parametrit merkkijonoina. Tällöin merkkijonoihin interpoloidaan edellä mainitut parametrit str.format-kutsun avulla.
  • määrittämällä em. interpoloitavat merkkijonot paketin setup.cfg-tiedostossa [versiointi]-osion sisällä.

Huom. nämä räätälöinnit eivät vaikuta edellä kuvattuun kehitysversioiden numerointiin.

Kaikki oletusarvoiset tai räätälöidyn logiikan mukaan muodostetut versionumerot normalisoidaan lopuksi PEP 440:n mukaisesti.

Historiatiedot

setup()-kutsulle annettu historia-parametri kirjoitetaan asennetun paketin metatietoihin (EGG-INFO) tiedostoon historia.json.

Tämä on toteutettu git-versiointi-paketin omissa asennustiedoissa seuraavasti:

  • entry_points[distutils.setup_keywords]: määrittää uuden setup()-parametrin historia
  • entry_points[egg_info.writers]: määrittää kirjoituskomennon tiedostolle historia.json

Asennusvaatimukset

Riippuvuudet haetaan requirements.txt-tiedostosta seuraavasti:

  • normaalit Pypi-paketit sellaisenaan (esim. numpy>=1.7)
  • git-paketteihin lisätään paketin nimi alkuun
    • esim. paketti @ git+https://github.com/x/paketti.git

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

git-versiointi-1.1.2.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

git_versiointi-1.1.2-py3-none-any.whl (8.4 kB view details)

Uploaded Python 3

File details

Details for the file git-versiointi-1.1.2.tar.gz.

File metadata

  • Download URL: git-versiointi-1.1.2.tar.gz
  • Upload date:
  • Size: 7.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.3

File hashes

Hashes for git-versiointi-1.1.2.tar.gz
Algorithm Hash digest
SHA256 8a024c671e7b8aabf31b495dd09b5e0cf922748148a7085e35ee05cecb8e259e
MD5 6d05893e2aaa43945fd07b6e9578fb15
BLAKE2b-256 70aae7c8513498e73d6e4db653dee1d8355114130708c6da812a9872963a7059

See more details on using hashes here.

File details

Details for the file git_versiointi-1.1.2-py3-none-any.whl.

File metadata

  • Download URL: git_versiointi-1.1.2-py3-none-any.whl
  • Upload date:
  • Size: 8.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.3

File hashes

Hashes for git_versiointi-1.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 0de229475de8a23c1b467d5ffabf86db2a15ab6573a20cd35429238553f6f85d
MD5 183336804862fe0c82ad74487b106a3f
BLAKE2b-256 1464b0f415605abbd346e644f7aaaeec1084ae809f9b07fa078d0163132e5a9d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page