.\" Copyright 1993 David Metcalfe (david@prism.demon.co.uk) .\" .\" Permission is granted to make and distribute verbatim copies of this .\" manual provided the copyright notice and this permission notice are .\" preserved on all copies. .\" .\" Permission is granted to copy and distribute modified versions of this .\" manual under the conditions for verbatim copying, provided that the .\" entire resulting derived work is distributed under the terms of a .\" permission notice identical to this one .\" .\" Since the Linux kernel and libraries are constantly changing, this .\" manual page may be incorrect or out-of-date. The author(s) assume no .\" responsibility for errors or omissions, or for damages resulting from .\" the use of the information contained herein. The author(s) may not .\" have taken the same level of care in the production of this manual, .\" which is licensed free of charge, as they might when working .\" professionally. .\" .\" Formatted or processed versions of this manual, if unaccompanied by .\" the source, must acknowledge the copyright and authors of this work. .\" .\" References consulted: .\" Linux libc source code .\" Lewine's _POSIX Programmer's Guide_ (O'Reilly & Associates, 1991) .\" 386BSD man pages .\" Modified Sat Jul 24 19:49:27 1993 by Rik Faith (faith@cs.unc.edu) .\" Modified Fri Apr 26 12:38:55 MET DST 1996 by Martin Schulze (joey@linux.de) .\" Modified 2001-11-13, aeb .\" Modified 2001-12-13, joey, aeb .\" .\" Traducido al castellano (con permiso) por: .\" Sebastian Desimone (chipy@argenet.com.ar) (desimone@fasta.edu.ar) .\" Translation fixed on Thu Apr 23 16:27:38 CEST 1998 by .\" Gerardo Aburruzaga García .\" Translation revised on Sun Apr 4 1999 by Juan Piernas .\" Traducción revisada por Miguel Pérez Ibars el 14-febrero-2005 .\" .TH CTIME 3 "13 diciembre 2001" "" "Manual del Programador de Linux" .SH NOMBRE asctime, ctime, gmtime, localtime, mktime \- transforman fechas y horas binarias a ASCII .SH SINOPSIS .nf .B #include .sp .BI "char *asctime(const struct tm *" tm ); .br .BI "char *asctime_r(const struct tm *" tm ", char *" buf ); .sp .BI "char *ctime(const time_t *" timep ); .br .BI "char *ctime_r(const time_t *" timep ", char *" buf ); .sp .BI "struct tm *gmtime(const time_t *" timep ); .br .BI "struct tm *gmtime_r(const time_t *" timep ", struct tm *" result ); .sp .BI "struct tm *localtime(const time_t *" timep ); .br .BI "struct tm *localtime_r(const time_t *" timep ", struct tm *" result ); .sp .BI "time_t mktime(struct tm *" tm ); .fi .SH DESCRIPCIÓN La funciones \fBctime()\fP, \fBgmtime()\fP y \fBlocaltime()\fP toman todas un argumento de tipo \fItime_t\fP que representa el tiempo de calendario. Al ser interpretado como un valor de tiempo absoluto, representa el número de segundos transcurridos desde las 00:00:00 del 1 de Enero de 1970, en Tiempo Universal Coordinado, Coordinated Universal Time (UTC). .PP Las funciones \fBasctime()\fP y \fBmktime()\fP toman un argumento que representa el tiempo descompuesto, que es una representación separada en año, mes, día, etc. .PP El tiempo descompuesto se guarda en una estructura \fItm\fP, que se define en \fI\fP como sigue: .sp .RS .nf .ne 11 .ta 8n 16n 32n struct tm { int tm_sec; /* segundos */ int tm_min; /* minutos */ int tm_hour; /* horas */ int tm_mday; /* día del mes */ int tm_mon; /* mes */ int tm_year; /* año */ int tm_wday; /* día de la semana */ int tm_yday; /* día del año */ int tm_isdst; /* cambio horario verano/invierno */ }; .ta .fi .RE .PP Los miembros de la estructura \fItm\fP son: .TP .I tm_sec El número de segundos, normalmente en el rango de 0 a 59, pero puede llegar a 61 para permitir segundos bisiestos. .TP .I tm_min El número de minutos, en el rango de 0 a 59. .TP .I tm_hour El número de horas pasada la medianoche, en el rango de 0 a 23. .TP .I tm_mday El día del mes, en el rango de 1 a 31. .TP .I tm_mon El número de meses desde Enero, en el rango de 0 a 11. .TP .I tm_year El número de años desde 1900. .TP .I tm_wday El número de dias desde el Domingo, en el rango de 0 a 6. .TP .I tm_yday El número de dias desde el 1 de Enero en el rango de 0 a 365. .TP .I tm_isdst Un indicador que dice si existe cambio horario entre verano e invierno para el tiempo descrito. El valor es positivo si existe este cambio, cero si no lo hay, y negativo si la información no está disponible. .PP La llamada .BI ctime( t ) es equivalente a .BI asctime(localtime( t )) \fR. Convierte el tiempo de calendario \fItimep\fP a una cadena de la forma .sp .RS "Wed Jun 30 21:49:08 1993\\n" .RE .sp Las abreviaturas para los dias de la semana son `Sun', `Mon', `Tue', `Wed', `Thu', `Fri', y `Sat'. Las abreviaturas para los meses son `Jan', `Feb', `Mar', `Apr', `May', `Jun', `Jul', `Aug', `Sep', `Oct', `Nov', y `Dec'. El valor devuelto apunta a una cadena reservada estáticamente que puede ser sobreescrita por posteriores llamadas a cualquiera de las funciones de fecha u hora. La función también pone en la variable externa \fItzname\fP (véase .BR tzset (3)) información acerca del huso horario. La versión reentrante \fBctime_r()\fP hace lo mismo, pero almacena la cadena en un buffer suministrado por el usuario de longitud mínima 26. No necesita modificar \fItzname\fP. .PP La función \fBgmtime()\fP convierte el tiempo de calendario \fItimep\fP a una representación descompuesta del tiempo, expresado en Tiempo Universal Coordinado (UTC). Puede devolver NULL cuando el año no cabe en una variable entera. El valor devuelto apunta a una estructura reservada estáticamente que puede ser sobreescrita por llamadas posteriores a cualquiera de las funciones de fecha y tiempo. La función \fBgmtime_r()\fP hace lo mismo, pero almacena los datos en una estructura suministrada por el usuario. .PP La función \fBlocaltime()\fP convierte el tiempo de calendario \fItimep\fP a una representación descompuesta, expresada relativa a la zona horaria especificada por el usuario. La función actúa como si hubiera llamado a .BR tzset (3) y pone en la variable externa \fItzname\fP información acerca de la zona horaria en curso, en \fItimezone\fP la diferencia entre el Tiempo Universal Coordinado (UTC) y la hora local normal en segundos, y en \fIdaylight\fP un valor distinto de cero si las reglas del cambio horario de verano/invierno se aplican durante alguna parte del año. El valor devuelto apunta a una estructura reservada estáticamente que puede ser sobreescrita por llamadas posteriores a cualquiera de las funciones de fecha y tiempo. La función \fBlocaltime_r()\fP hace lo mismo, pero almacena los datos en una estructura suministrada por el usuario. .PP La función \fBasctime()\fP convierte el tiempo descompuesto \fItm\fP a una cadena con el mismo formato que \fBctime()\fP. El valor devuelto apunta a una cadena reservada estáticamente que puede ser sobreescrita por posteriores llamadas a cualquiera de las funciones de fecha u hora. La función \fBasctime_r()\fP hace lo mismo, pero almacena la cadena en un buffer suministrado por el usuario de longitud mínima 26. .PP La función \fBmktime()\fP convierte un tiempo descompuesto a una representación tiempo de calendario. La función hace caso omiso de los contenidos específícos en los miembros de la estructura \fItm_wday\fP y \fItm_yday\fP y los recalcula a partir de otra información existente en la estructura del tiempo descompuesto. Si los miembros de la estructura están fuera de sus intervalos permitidos, serán normalizados (del tal manera que, por ejemplo, el 40 de octubre se cambiará al 9 de noviembre). Al llamar a \fBmktime()\fP también se pone un valor en la variable externa \fItzname\fP con información acerca de la zona horaria. Si el tiempo descompuesto especificado no puede representarse como tiempo de calendario (segundos desde la `Época'), \fBmktime()\fP devuelve el valor (time_t)(\-1) y no altera los miembros \fItm_wday\fP ni \fItm_yday\fP de la estructura del tiempo descompuesto. .SH "VALOR DEVUELTO" Cada una de estas funciones devuelve el valor descrito, o NULL (\-1 en el caso de \fBmktime()\fP) en caso de error. .SH OBSERVACIONES Las cuatro funciones .BR acstime() , .BR ctime() , .B gmtime() y .B localtime() devuelven un puntero a datos estáticos y por tanto no son seguras para trabajar con hilos. Las versiones hilo-seguro .BR acstime_r() , .BR ctime_r() , .B gmtime_r() y .BR localtime_r() están especificadas por SUSv2, y están disponibles desde la versión 5.2.5 de libc. .LP La versión glibc de la estructura tm contiene campos adicionales .sp .RS .nf long tm_gmtoff; /* Segundos al este de UTC */ const char *tm_tm_zone; /* Abreviación del huso horario */ .fi .RE .sp definidos cuando se pone _BSD_SOURCE antes de incluir .IR . Esta es una extensión BSD, presente en 4.3BSD-Reno. .SH "CONFORME A" SVID 3, POSIX, BSD 4.3, ISO 9899 .SH "VÉASE TAMBIÉN" .BR date (1), .BR gettimeofday (2), .BR newctime (3), .BR time (2), .BR utime (2), .BR clock (3), .BR difftime (3), .BR strftime (3), .BR strptime (3), .BR tzset (3)