.\" -*- coding: UTF-8 -*-
'\" t
.\" Copyright 2003 walter harms (walter.harms@informatik.uni-oldenburg.de)
.\"
.\" SPDX-License-Identifier: GPL-1.0-or-later
.\"
.\" Modified 2003-04-04 Walter Harms
.\" <walter.harms@informatik.uni-oldenburg.de>
.\"
.\" Slightly polished, aeb, 2003-04-06
.\"
.\"*******************************************************************
.\"
.\" This file was generated with po4a. Translate the source file.
.\"
.\"*******************************************************************
.TH rtime 3 "15 décembre 2022" "Pages du manuel de Linux 6.03" 
.SH NOM
rtime \- Lire l'heure sur un serveur distant
.SH BIBLIOTHÈQUE
Bibliothèque C standard (\fIlibc\fP, \fI\-lc\fP)
.SH SYNOPSIS
.nf
\fB#include <rpc/auth_des.h>\fP
.PP
\fBint rtime(struct sockaddr_in *\fP\fIaddrp\fP\fB, struct rpc_timeval *\fP\fItimep\fP\fB,\fP
\fB          struct rpc_timeval *\fP\fItimeout\fP\fB);\fP
.fi
.SH DESCRIPTION
Cette fonction utilise le protocole Time Serveur décrit dans la RFC\ 868
pour lire l'heure sur une machine distante.
.PP
Le protocole Time Serveur donne l'heure en secondes écoulées depuis le
1er\ janvier 1900 à 00:00:00 UTC, et cette fonction soustrait la constante
nécessaire pour convertir le résultat en secondes écoulées depuis l'époque,
1er\ janvier 1970 à\ 00:00:00 (UTC).
.PP
Si \fItimeout\fP est non NULL, le port UDP/time (37) est utilisé, sinon le port
TCP/time (37) est utilisé.
.SH "VALEUR RENVOYÉE"
On success, 0 is returned, and the obtained 32\-bit time value is stored in
\fItimep\->tv_sec\fP.  In case of error \-1 is returned, and \fIerrno\fP is set
to indicate the error.
.SH ERREURS
Toutes les erreurs pour les fonctions sous\-jacentes (\fBsendto\fP(2),
\fBpoll\fP(2), \fBrecvfrom\fP(2), \fBconnect\fP(2), \fBread\fP(2)) peuvent se produire,
avec en outre\ :
.TP 
\fBEIO\fP
Le nombre d'octets reçus n'est pas 4.
.TP 
\fBETIMEDOUT\fP
Le délai indiqué en second argument a expiré.
.SH ATTRIBUTS
Pour une explication des termes utilisés dans cette section, consulter
\fBattributes\fP(7).
.ad l
.nh
.TS
allbox;
lbx lb lb
l l l.
Interface	Attribut	Valeur
T{
\fBrtime\fP()
T}	Sécurité des threads	MT\-Safe
.TE
.hy
.ad
.sp 1
.SH NOTES
Seul IPv4 est supporté.
.PP
.\" .PP
.\" Libc5 uses the prototype
.\" .PP
.\" .nf
.\"    int rtime(struct sockaddr_in *, struct timeval *, struct timeval *);
.\" .fi
.\" .PP
.\" and requires
.\" .I <sys/time.h>
.\" instead of
.\" .IR <rpc/auth_des.h> .
Certaines versions de \fIin.timed\fP supportent uniquement TCP. Essayez le
programme d'exemple avec \fIuse_tcp\fP définie à 1.
.SH BOGUES
\fBrtime\fP() dans la glibc 2.2.5 et les précédentes ne fonctionne pas
correctement sur les machines 64\ bits.
.SH EXEMPLES
Cet exemple demande que le port 37 soit ouvert et actif. Vérifiez que
l'entrée time dans \fI/etc/inetd.conf\fP ne soit pas commentée.
.PP
Le programme se connecte sur un hôte nommé «\ linux\ ». Utiliser «\ localhost\ » ne fonctionne pas. Le résultat est l'heure locale de
l'ordinateur «\ linux\ ».
.PP
.\" SRC BEGIN (rtime.c)
.EX
#include <errno.h>
#include <netdb.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>

#include <rpc/auth_des.h>

static int use_tcp = 0;
static const char servername[] = "linux";

int
main(void)
{
    int                 ret;
    time_t              t;
    struct hostent      *hent;
    struct rpc_timeval  time1 = {0, 0};
    struct rpc_timeval  timeout = {1, 0};
    struct sockaddr_in  name;

    memset(&name, 0, sizeof(name));
    sethostent(1);
    hent = gethostbyname(servername);
    memcpy(&name.sin_addr, hent\->h_addr, hent\->h_length);

    ret = rtime(&name, &time1, use_tcp ? NULL : &timeout);
    if (ret < 0)
        perror("rtime error");
    else {
        t = time1.tv_sec;
        printf("%s\en", ctime(&t));
    }

    exit(EXIT_SUCCESS);
}
.EE
.\" SRC END
.SH "VOIR AUSSI"
.\" .BR netdate (1),
.\" .BR rdate (1),
\fBntpdate\fP(1), \fBinetd\fP(8)
.PP
.SH TRADUCTION
La traduction française de cette page de manuel a été créée par
Christophe Blaess <https://www.blaess.fr/christophe/>,
Stéphan Rafin <stephan.rafin@laposte.net>,
Thierry Vignaud <tvignaud@mandriva.com>,
François Micaux,
Alain Portal <aportal@univ-montp2.fr>,
Jean-Philippe Guérard <fevrier@tigreraye.org>,
Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>,
Julien Cristau <jcristau@debian.org>,
Thomas Huriaux <thomas.huriaux@gmail.com>,
Nicolas François <nicolas.francois@centraliens.net>,
Florentin Duneau <fduneau@gmail.com>,
Simon Paillard <simon.paillard@resel.enst-bretagne.fr>,
Denis Barbier <barbier@debian.org>
et
David Prévot <david@tilapin.org>
.
.PP
Cette traduction est une documentation libre ; veuillez vous reporter à la
.UR https://www.gnu.org/licenses/gpl-3.0.html
GNU General Public License version 3
.UE
concernant les conditions de copie et 
de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.
.PP
Si vous découvrez un bogue dans la traduction de cette page de manuel, 
veuillez envoyer un message à
.MT debian-l10n-french@lists.debian.org
.ME .