Votre IP: 38.107.179.241 
  
 
Google
 
Accueil e-mail Linux
Linux
Perl
Perl
C
Langage C
Dico
Dictionnaire
Biblio liens
Bibliothèque de liens
Index articles
Index articles
 

Date création : 27-03-2008 20:23:44

Linux  Vous êtes dans : GNU/Linux Astuces / Pages man [Section3 - Sous-fonctions]


RTIME

 

Index

  1. NOM
  2. SYNOPSIS
  3. DESCRIPTION
  4. VALEUR RENVOYÉE
  5. ERREURS
  6. EXEMPLE
  7. NOTES
  8. BOGUES
  9. VOIR AUSSI
  10. TRADUCTION

 

NOMIndex

rtime - Lire l'heure sur un serveur distant.  

SYNOPSISIndex


#include <rpc/des_crypt.h>
int rtime(struct sockaddr_in *addrp, struct rpc_timeval *timep, struct rpc_timeval *timeout);
 

DESCRIPTIONIndex

Cette fonction utilise le protocole Time Serveur décrit dans la RFC 868 pour lire l'heure sur une machine distante.
Le protocole Time Serveur donne l'heure en secondes écoulées depuis le 1er janvier 1900 à minuit, et cette fonction soustrait la constante nécessaire pour convertir le résultat en secondes écoulées depuis le 1er janvier 1970 à minuit, début des dates de l'ère Unix (epoch).
Si timeout est non NULL, le port UDP/time (37) est utilisé, sinon le port TCP/time (37) est utilisé.  

VALEUR RENVOYÉEIndex

Si elle réussit, cette fonction renvoie zéro et la valeur 32 bits obtenue est stockée dans timep->tv_sec. En cas d'échec, elle renvoie -1 et errno contient le code d'erreur.  

ERREURSIndex

Toutes les erreurs pour les fonctions sous-jacentes (sendto(), poll(), recvfrom(), connect(), read()) peuvent se produire, avec en outre :
EIO
Le nombre d'octets reçus n'est pas 4.
ETIMEDOUT
Le délai indiqué en second argument a expiré.
 

EXEMPLEIndex

Cet exemple demande que le port 37 soit ouvert et actif. Vérifiez que l'entrée time dans /etc/inetd.conf ne soit pas commentée.
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 ».
#include <stdio.h>
#include <errno.h>
#include <string.h>
#include <time.h>
#include <rpc/auth_des.h>
#include <netdb.h>

int use_tcp = 0;
char *servername = "linux";

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

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

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

  return 0;
}
 

NOTESIndex

Seul IPV4 est supporté.
Certaines versions de in.timed supportent uniquement TCP. Essayez l'exemple précédent avec use_tcp fixé à 1.
La libc5 utilise le prototype
int rtime(struct sockaddr_in *, struct timeval *, struct timeval *);
et requiert <sys/time.h> à la place de <rpc/auth_des.h>.
 

BOGUESIndex

rtime() dans les glibc <= 2.2.5 ne fonctionne pas correctement sur les machines 64 bits.  

VOIR AUSSIIndex

netdate(1), ntpdate(1), rdate(1), inetd(8)  

TRADUCTIONIndex

Cette page de manuel a été traduite et mise à jour par Christophe Blaess <http://www.blaess.fr/christophe/> entre 1996 et 2003, puis par Alain Portal <aportal AT univ-montp2 DOT fr> jusqu'en 2006.
La traduction de cette page de manuel est basée sur les traductions disponibles sur http://manpagesfr.free.fr/, mais est gérée par l'équipe francophone de traduction de Debian au travers de la liste de discussion debian-l10n-french.
Veuillez signaler toute erreur de traduction par un rapport de bogue sur le paquet manpages-fr.
Vous pouvez toujours avoir accès à la version anglaise de ce document en utilisant la commande « man -L C <section> <page_de_man> ».


Création : octobre 2007  © Tous droits réservés 2007 linux-perl-c
Valid HTML 4.01 TransitionalValid CSS