36.1. "posix" — Les appels système POSIX les plus courants
**********************************************************

Ce module permet d’accéder aux fonctionnalités du système
d’exploitation normalisés par le Standard C et le Standard POSIX (une
interface Unix habilement déguisée).

**Ne pas importer ce module directement.**  À la place, importer le
module "os", qui fournit une version *portable* de cette interface.
Sous Unix, le module "os" fournit un sur-ensemble de l’interface
"posix".  Sous les systèmes d’exploitation non Unix le module "posix"
n’est pas disponible, mais un sous ensemble est toujours disponible
via l’interface "os". Une fois que "os" est importé, il n’y a aucune
perte de performance à l’utiliser à la place de "posix".  De plus,
"os" fournit des fonctionnalités supplémentaires, telles que l’appel
automatique de "putenv()" lorsqu’une entrée dans "os.environ" est
modifiée.

Les erreurs sont signalées comme des exceptions; les exceptions
habituelles sont données pour les erreurs de type, tandis que les
erreurs signalées par les appels système lèvent une erreur "OSError".


36.1.1. Prise en charge de gros fichiers
========================================

Several operating systems (including AIX, HP-UX, Irix and Solaris)
provide support for files that are larger than 2 GB from a C
programming model where "int" and "long" are 32-bit values. This is
typically accomplished by defining the relevant size and offset types
as 64-bit values. Such files are sometimes referred to as *large
files*.

Large file support is enabled in Python when the size of an "off_t" is
larger than a "long" and the "long long" type is available and is at
least as large as an "off_t". Python longs are then used to represent
file sizes, offsets and other values that can exceed the range of a
Python int. It may be necessary to configure and compile Python with
certain compiler flags to enable this mode. For example, it is enabled
by default with recent versions of Irix, but with Solaris 2.6 and 2.7
you need to do something like:

   CFLAGS="`getconf LFS_CFLAGS`" OPT="-g -O2 $CFLAGS" \
           ./configure

Sur les systèmes Linux capable de supporter les fichiers volumineux,
cela pourrait fonctionner:

   CFLAGS='-D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64' OPT="-g -O2 $CFLAGS" \
           ./configure


36.1.2. Contenu du Module
=========================

En plus des nombreuses fonctions décrites dans la documentation du
module "os", "posix" possède les éléments suivants:

posix.environ

   A dictionary representing the string environment at the time the
   interpreter was started.  For example, "environ['HOME']" is the
   pathname of your home directory, equivalent to "getenv("HOME")" in
   C.

   Modifier ce dictionnaire n’affecte pas les variables
   d’environnements fournis par "execv()", "popen()" ou "system()"; Si
   vous avez besoin de changer l’environnement, passer le paramètre
   "environ" à "execve()" ou ajouter les assignations de variables et
   les *export* à la commande à exécuter via "system()" ou "popen()".

   Note: The "os" module provides an alternate implementation of
     "environ" which updates the environment on modification.  Note
     also that updating "os.environ" will render this dictionary
     obsolete.  Use of the "os" module version of this is recommended
     over direct access to the "posix" module.
