4. Créer une distribution source¶
Comme montré dans le chapitre Un exemple simple, vous pouvez utiliser la commande sdist pour créer une distribution source. Dans le cas le plus simple,
python setup.py sdist
(en supposant que vous n’avez spécifié aucune option pour la commande sdist dans le script de préparation ou le fichier de configuration), sdist crée une archive au format par défaut pour la plateforme utilisée. Le format par défaut est un fichier tar compressé (.tar.gz
) sur Unix et un fichier ZIP sur Windows.
You can specify as many formats as you like using the --formats
option, for example:
python setup.py sdist --formats=gztar,zip
pour créer un fichier tarball compressé et un fichier ZIP. Les formats disponibles actuellement sont :
Format |
Description |
Notes |
---|---|---|
|
Fichier zip ( |
(1), (3) |
|
Fichier tar compressé par gzip ( |
(2) |
|
Fichier tar compressé par bzip2 ( |
|
|
Fichier tar compressé par compress ( |
(4) |
|
fichier tar ( |
Notes :
Par défaut sur Windows
Par défaut sur Unix
nécessite soit un utilitaire zip extérieur ou le module
zipfile
(inclut dans la bibliothèque standard depuis Python 1.6)requires the compress program.
When using any tar
format (gztar
, bztar
, ztar
or
tar
) under Unix, you can specify the owner
and group
names
that will be set for each member of the archive.
Par exemple, si vous voulez que tous les fichiers de l’archive soient détenu par root :
python setup.py sdist --owner=root --group=root
4.1. Spécifier les fichiers à distribuer¶
Si vous ne fournissez pas une liste explicite de fichiers (ou les instructions pour la générer), la commande sdist en met par défaut le minimum dans la distribution source :
tous les fichiers source Python sous-entendus par les options
py_modules
etpackages
tous les fichiers source C mentionnés dans les arguments
ext_modules
oulibraries
scripts identifiés par l’argument
scripts
. Voir Installing Scripts.tout ce qui ressemble à un script de test
test/test*.py
(pour l’instant, Distutils ne fait rien avec ces scripts de test, si ce n’est les inclure dans les distributions sources, mais dans le futur un standard sera implémenté pour tester les distributions de module Python)README.txt
(ouREADME
),setup.py
(ou peut importe la manière dont vous avez appelé votre script d’installation) etsetup.cfg
tous les fichiers associés aux méta-données
package_data
. Voir Installing Package Data.tous les fichiers associés aux méta-données
data_files
. Voir Installing Additional Files.
Parfois ce fonctionnement suffit, mais généralement vous voudrez spécifier des fichiers supplémentaires à distribuer. La façon classique de le faire est d’écrire un manifeste modèle, appelé MANIFEST.in
par défaut. Ce manifeste modèle est juste une liste d’instructions pour générer votre fichier manifeste final, MANIFEST
, qui est la liste exacte des fichiers à inclure dans votre distribution source. La commande sdist traite ce modèle et génère un manifeste à partir de ces instructions et de ce qu’elle trouve dans le système de fichiers.
Si vous préférez créer votre propre fichier manifeste, le format est simple : un nom de fichier par ligne, uniquement des fichiers normaux (ou leur lien symbolique). Si vous fournissez votre propre MANIFEST
, vous devez tout spécifier : les groupes de fichiers par défaut décrits au-dessus ne sont pas inclus automatiquement dans ce cas.
Modifié dans la version 2.7: Un MANIFEST
existant généré automatiquement sera régénéré sans que sdist ne compare son heure de modification à MANIFEST.in
ou setup.py
.
Modifié dans la version 2.7.1: Les fichiers MANIFEST
commencent par un commentaire indiquant qu’ils sont générés. Les fichiers sans ce commentaire ne sont pas réécrits ou supprimés.
Modifié dans la version 2.7.3: sdist will read a MANIFEST
file if no MANIFEST.in
exists, like it did before 2.7.
See The MANIFEST.in template section for a syntax reference.
4.3. The MANIFEST.in template¶
A MANIFEST.in
file can be added in a project to define the list of
files to include in the distribution built by the sdist command.
When sdist is run, it will look for the MANIFEST.in
file
and interpret it to generate the MANIFEST
file that contains the
list of files that will be included in the package.
This mechanism can be used when the default list of files is not enough. (See Spécifier les fichiers à distribuer).
4.3.1. Principle¶
The manifest template has one command per line, where each command specifies a set of files to include or exclude from the source distribution. For an example, let’s look at the Distutils” own manifest template:
include *.txt
recursive-include examples *.txt *.py
prune examples/sample?/build
The meanings should be fairly clear: include all files in the distribution root
matching *.txt
, all files anywhere under the examples
directory
matching *.txt
or *.py
, and exclude all directories matching
examples/sample?/build
. All of this is done after the standard
include set, so you can exclude files from the standard set with explicit
instructions in the manifest template. (Or, you can use the
--no-defaults
option to disable the standard set entirely.)
L’ordre des commandes dans le modèle manifeste compte : nous avons, à la base, la liste de fichiers par défaut telle que décrite plus haut. Ensuite, chaque commande du modèle ajoute ou supprime des fichiers de cette liste. Une fois que le traitement du manifeste modèle est fini, nous enlevons les fichiers qui ne doivent pas être inclus dans la distribution source :
tous les fichiers dans l’arborescence de build de Distutils (par défaut
build/
)tous les fichiers dans les dossiers nommés
RCS
,CVS
,.svn
,.hg
,.git
,.bzr
ou_darcs
Maintenant nous avons notre liste complète de fichiers ; elle est désormais écrite dans le manifeste pour une utilisation future et sera utilisée pour construire la ou les archive(s) de notre distribution source.
You can disable the default set of included files with the
--no-defaults
option, and you can disable the standard exclude set
with --no-prune
.
Voici le manifeste modèle de Distutils, suivons comment la commande sdist construit la liste des fichiers à inclure dans la distribution source de Distutils.
inclure tous les fichiers source Python dans les sous-dossiers
distutils
etdistutils/command
(parce que des paquets correspondant à ces deux dossiers ont été mentionnés dans l’argumentpackages
du script d’installation — voir le chapitre Writing the Setup Script)inclure
README.txt
,setup.py
etsetup.cfg
(fichiers standards)inclure
test/test*.py
(fichiers standard)inclure
*.txt
à la racine de la distribution (ceci trouveREADME.txt
une seconde fois, mais les redondances sont supprimées plus tard)inclure tout fichier de la forme
*.txt
ou*.py
dans la sous-arborescence deexamples
,exclure tous les fichiers dans les sous-arborescences dont les dossiers racines sont de la forme
examples/sample?/build
— Ceci peut exclure des fichiers inclus dans les étapes précédentes, il est donc important que la commandeprune
dans le manifeste modèle vienne après la commanderecursive-include
exclure l’arborescence de
build
ainsi que les dossiersRCS
,CVS
,.svn
,.hg
,.git
,.bzr
et_darcs
Comme dans le script de préparation, les chemins des fichiers et des dossiers dans le manifeste modèle doivent toujours être séparés par des barres obliques (slash en anglais) ; Distutils s’occupe de les convertir à la représentation standard de votre plateforme. De cette manière, le manifeste modèle est portable sur tout système d’exploitation.
4.3.2. Commands¶
Les commandes du modèle manifeste sont :
Commande |
Description |
---|---|
include pat1 pat2 ... |
Inclut tous les fichiers ressemblant aux modèles listés |
exclude pat1 pat2 ... |
exclut tous les fichiers ressemblant aux modèles listés |
recursive-include dir pat1 pat2 ... |
inclut récursivement tous les fichiers sous dir ressemblant aux modèles listés |
recursive-exclude dir pat1 pat2 ... |
exclut tous les fichiers sous dir ressemblant aux modèles listés |
global-include pat1 pat2 ... |
Inclut tous les fichiers dans l’arborescence ressemblant aux modèles listés |
global-exclude pat1 pat2 ... |
exclut tous les fichiers dans l’arborescence ressemblant aux modèles listés |
prune dir |
exclut tous les fichiers dans dir |
graft dir |
inclut tous les fichiers dans dir |
Les modèles sont de style Unix glob : *
correspond à n’importe quelle chaîne de caractères d’un nom de fichier valide, ?
correspond à un seul caractère d’un nom de fichier valide et [range]
correspond à n’importe quel caractère dans la range (e.g., a-z
, a-zA-Z
, a-f0-9_.
). La définition de « caractère de nom de fichier valide » est spécifique à chaque plateforme: sur Unix il s’agir de n’importe quel caractère à part le slash; sur Windows il s’agir de n’importe quel caractère a part l’anti-slash et les deux points.