touch man page on Gentoo

Man page or keyword search:  
man Server   6889 pages
apropos Keyword Search (all sections)
Output format
Gentoo logo
[printable version]

TOUCH(1P)		   POSIX Programmer's Manual		     TOUCH(1P)

PROLOG
       This  manual  page is part of the POSIX Programmer's Manual.  The Linux
       implementation of this interface may differ (consult the	 corresponding
       Linux  manual page for details of Linux behavior), or the interface may
       not be implemented on Linux.

NAME
       touch — change file access and modification times

SYNOPSIS
       touch [−acm] [−r ref_file|−t time|−d date_time] file...

DESCRIPTION
       The touch utility shall change the last data  modification  timestamps,
       the last data access timestamps, or both.

       The time used can be specified by the −t time option-argument, the cor‐
       responding time fields of  the  file  referenced	 by  the  −r  ref_file
       option-argument,	 or  the −d date_time option-argument, as specified in
       the following sections. If none of these are specified, touch shall use
       the current time.

       For  each  file	operand, touch shall perform actions equivalent to the
       following  functions  defined  in  the  System  Interfaces  volume   of
       POSIX.1‐2008:

	1. If file does not exist:

	    a. The creat() function is called with the following arguments:

	       --  The file operand is used as the path argument.

	       --  The	value of the bitwise-inclusive OR of S_IRUSR, S_IWUSR,
		   S_IRGRP, S_IWGRP, S_IROTH, and S_IWOTH is used as the  mode
		   argument.

	    b. The futimens() function is called with the following arguments:

	       --  The file descriptor opened in step 1a.

	       --  The access time and the modification time, set as described
		   in the OPTIONS section, are used as the  first  and	second
		   elements of the times array argument, respectively.

	2. If file exists, the utimensat() function is called with the follow‐
	   ing arguments:

	    a. The AT_FDCWD special value is used as the fd argument.

	    b. The file operand is used as the path argument.

	    c. The access time and the modification time, set as described  in
	       the  OPTIONS section, are used as the first and second elements
	       of the times array argument, respectively.

	    d. The flag argument is set to zero.

OPTIONS
       The touch utility shall conform	to  the	 Base  Definitions  volume  of
       POSIX.1‐2008, Section 12.2, Utility Syntax Guidelines.

       The following options shall be supported:

       −a	 Change	 the access time of file.  Do not change the modifica‐
		 tion time unless −m is also specified.

       −c	 Do not create a specified file if it does not exist.  Do  not
		 write any diagnostic messages concerning this condition.

       −d date_time
		 Use  the specified date_time instead of the current time. The
		 option-argument shall be a string of the form:

		     YYYY−MM−DDThh:mm:SS[.frac][tz]

		 or:

		     YYYY−MM−DDThh:mm:SS[,frac][tz]

		 where:

		  *  YYYY are at least four decimal digits giving the year.

		  *  MM, DD, hh, mm, and SS are as with −t time.

		  *  T is the time designator, and can be replaced by a single
		     <space>.

		  *  [.frac] and [,frac] are either empty, or a <period> ('.')
		     or a <comma> (',') respectively, followed by one or  more
		     decimal digits, specifying a fractional second.

		  *  [tz]  is either empty, signifying local time, or the let‐
		     ter 'Z', signifying UTC. If [tz] is empty, the  resulting
		     time shall be affected by the value of the TZ environment
		     variable.

		 If the resulting time precedes the  Epoch,  the  behavior  is
		 implementation-defined.  If the time cannot be represented as
		 the file's timestamp, touch shall exit	 immediately  with  an
		 error status.

       −m	 Change	 the  modification  time  of  file.  Do not change the
		 access time unless −a is also specified.

       −r ref_file
		 Use the corresponding time of the file named by the  pathname
		 ref_file instead of the current time.

       −t time	 Use  the  specified  time  instead  of	 the current time. The
		 option-argument shall be a decimal number of the form:

		     [[CC]YY]MMDDhhmm[.SS]

		 where each two digits represents the following:

		 MM	 The month of the year [01,12].

		 DD	 The day of the month [01,31].

		 hh	 The hour of the day [00,23].

		 mm	 The minute of the hour [00,59].

		 CC	 The first two digits of the year (the century).

		 YY	 The second two digits of the year.

		 SS	 The second of the minute [00,60].

		 Both CC and YY shall be optional. If neither  is  given,  the
		 current  year shall be assumed. If YY is specified, but CC is
		 not, CC shall be derived as follows:

				   ┌──────────┬─────────────┐
				   │If YY is: │ CC becomes: │
				   ├──────────┼─────────────┤
				   │ [69,99]  │	    19	    │
				   │ [00,68]  │	    20	    │
				   └──────────┴─────────────┘
		 Note:	   It is expected that in a  future  version  of  this
			   standard   the  default  century  inferred  from  a
			   2-digit year will change. (This would apply to  all
			   commands accepting a 2-digit year as input.)

		 The  resulting	 time shall be affected by the value of the TZ
		 environment variable. If the resulting	 time  value  precedes
		 the  Epoch,  the  behavior  is implementation-defined. If the
		 time is out of range for the file's  timestamp,  touch	 shall
		 exit  immediately  with  an  error status. The range of valid
		 times past the Epoch is implementation-defined, but it	 shall
		 extend	 to  at	 least the time 0 hours, 0 minutes, 0 seconds,
		 January 1, 2038, Coordinated Universal Time. Some implementa‐
		 tions	may  not be able to represent dates beyond January 18,
		 2038, because they use signed int as a time holder.

		 The range for SS is [00,60] rather than  [00,59]  because  of
		 leap  seconds.	 If  SS	 is  60,  and  the  resulting time, as
		 affected by the TZ environment variable, does not refer to  a
		 leap  second,	the resulting time shall be one second after a
		 time where SS is 59. If SS  is	 not  given  a	value,	it  is
		 assumed to be zero.

       If  neither the −a nor −m options were specified, touch shall behave as
       if both the −a and −m options were specified.

OPERANDS
       The following operands shall be supported:

       file	 A pathname of a file whose times shall be modified.

STDIN
       Not used.

INPUT FILES
       None.

ENVIRONMENT VARIABLES
       The following environment  variables  shall  affect  the	 execution  of
       touch:

       LANG	 Provide  a  default  value for the internationalization vari‐
		 ables that are unset or null. (See the Base Definitions  vol‐
		 ume  of POSIX.1‐2008, Section 8.2, Internationalization Vari‐
		 ables for the precedence  of  internationalization  variables
		 used to determine the values of locale categories.)

       LC_ALL	 If  set  to  a non-empty string value, override the values of
		 all the other internationalization variables.

       LC_CTYPE	 Determine the locale for the interpretation of	 sequences  of
		 bytes of text data as characters (for example, single-byte as
		 opposed to multi-byte characters in arguments).

       LC_MESSAGES
		 Determine the locale that should be used to affect the format
		 and  contents	of  diagnostic	messages  written  to standard
		 error.

       NLSPATH	 Determine the location of message catalogs for the processing
		 of LC_MESSAGES.

       TZ	 Determine  the	 timezone to be used for interpreting the time
		 option-argument. If TZ	 is  unset  or	null,  an  unspecified
		 default timezone shall be used.

ASYNCHRONOUS EVENTS
       Default.

STDOUT
       Not used.

STDERR
       The standard error shall be used only for diagnostic messages.

OUTPUT FILES
       None.

EXTENDED DESCRIPTION
       None.

EXIT STATUS
       The following exit values shall be returned:

	0    The  utility executed successfully and all requested changes were
	     made.

       >0    An error occurred.

CONSEQUENCES OF ERRORS
       Default.

       The following sections are informative.

APPLICATION USAGE
       The interpretation of time is taken to be seconds since the Epoch  (see
       the  Base  Definitions  volume  of  POSIX.1‐2008, Section 4.15, Seconds
       Since the Epoch).  It should be noted that  implementations  conforming
       to  the	System Interfaces volume of POSIX.1‐2008 do not take leap sec‐
       onds into account when computing seconds since the Epoch. When SS=60 is
       used,  the  resulting  time  always  refers to 1 plus seconds since the
       Epoch for a time when SS=59.

       Although the −t time option-argument  specifies	values	in  1969,  the
       access  time  and modification time fields are defined in terms of sec‐
       onds since the Epoch (00:00:00  on  1  January  1970  UTC).  Therefore,
       depending  on  the  value  of TZ when touch is run, there is never more
       than a few valid hours in 1969 and there need not be any valid times in
       1969.

       One ambiguous situation occurs if −t time is not specified, −r ref_file
       is not specified, and the first operand is an eight or ten-digit	 deci‐
       mal number. A portable script can avoid this problem by using:

	   touch −− file

       or:

	   touch ./file

       in this case.

       If  the T time designator is replaced by a <space> for the −d date_time
       option-argument, the <space> must be quoted to prevent the  shell  from
       splitting the argument.

EXAMPLES
       Create  or  update  a  file called dwc; the resulting file has both the
       last data modification and last data access timestamps set to  November
       12, 2007 at 10:15:30 local time:

	   touch −d 2007-11-12T10:15:30 dwc

       Create  or  update  a file called nick; the resulting file has both the
       last data modification and last data access timestamps set to  November
       12, 2007 at 10:15:30 UTC:

	   touch −d 2007-11-12T10:15:30Z nick

       Create  or  update  a  file called gwc; the resulting file has both the
       last data modification and last data access timestamps set to  November
       12,  2007  at 10:15:30 local time with a fractional second timestamp of
       .002 seconds:

	   touch −d 2007-11-12T10:15:30,002 gwc

       Create or update a file called ajosey; the resulting file has both  the
       last  data modification and last data access timestamps set to November
       12, 2007 at 10:15:30 UTC with a fractional  second  timestamp  of  .002
       seconds:

	   touch −d "2007-11-12 10:15:30.002Z" ajosey

       Create  or  update a file called cathy; the resulting file has both the
       last data modification and last data access timestamps set to  November
       12, 2007 at 10:15:00 local time:

	   touch −t 200711121015 cathy

       Create or update a file called drepper; the resulting file has both the
       last data modification and last data access timestamps set to  November
       12, 2007 at 10:15:30 local time:

	   touch −t 200711121015.30 drepper

       Create  or  update  a file called ebb9; the resulting file has both the
       last data modification and last data access timestamps set to  November
       12, 2007 at 10:15:30 local time:

	   touch −t 0711121015.30 ebb9

       Create  or update a file called eggert; the resulting file has the last
       data access timestamp set to the corresponding time of the  file	 named
       mark  instead  of  the  current time. If the file exists, the last data
       modification time is not changed:

	   touch −a −r mark eggert

RATIONALE
       The functionality of touch is described almost entirely through	refer‐
       ences  to functions in the System Interfaces volume of POSIX.1‐2008. In
       this way, there is no duplication of  effort  required  for  describing
       such side-effects as the relationship of user IDs to the user database,
       permissions, and so on.

       There are some significant differences between  the  touch  utility  in
       this volume of POSIX.1‐2008 and those in System V and BSD systems. They
       are upwards-compatible for historical applications from both  implemen‐
       tations:

	1. In  System V, an ambiguity exists when a pathname that is a decimal
	   number leads the operands; it is treated as a time value.  In  BSD,
	   no  time value is allowed; files may only be touched to the current
	   time. The −t time construct solves these problems for  future  con‐
	   forming  applications  (note	 that  the −t option is not historical
	   practice).

	2. The inclusion of the century digits, CC, is also new. Note  that  a
	   ten-digit  time  value is treated as if YY, and not CC, were speci‐
	   fied. The caveat about the range of dates following the  Epoch  was
	   included  as	 recognition that some implementations are not able to
	   represent dates beyond 18 January 2038 because they use signed  int
	   as a time holder.

       The  −r	option was added because several comments requested this capa‐
       bility.	This option was named −f in an early proposal, but was changed
       because	the  −f option is used in the BSD version of touch with a dif‐
       ferent meaning.

       At least one historical implementation of touch	incremented  the  exit
       code  if	 −c  was  specified and the file did not exist. This volume of
       POSIX.1‐2008 requires exit status zero if no errors occur.

       In previous version of the standard, if at least two operands are spec‐
       ified,  and the first operand is an eight or ten-digit decimal integer,
       the first operand was assumed to be a date_time operand. This usage was
       removed	in this version of the standard since it had been marked obso‐
       lescent previously.

       The −d date_time format is an ISO 8601:2004 standard complete represen‐
       tation  of date and time extended format with an optional decimal point
       or <comma> followed by a string of digits following the seconds portion
       to  specify  fractions  of  a  second. It is not necessary to recognize
       "[+/-]hh:mm" and "[+/-]hh" to specify timezones other than  local  time
       and  UTC.  The T time designator in the ISO 8601:2004 standard extended
       format may be replaced by <space>.

FUTURE DIRECTIONS
       None.

SEE ALSO
       date

       The Base Definitions volume  of	POSIX.1‐2008,  Section	4.15,  Seconds
       Since  the Epoch, Chapter 8, Environment Variables, Section 12.2, Util‐
       ity Syntax Guidelines, <sys_stat.h>

       The System Interfaces  volume  of  POSIX.1‐2008,	 creat(),  futimens(),
       time(), utime()

COPYRIGHT
       Portions	 of  this text are reprinted and reproduced in electronic form
       from IEEE Std 1003.1, 2013 Edition, Standard for Information Technology
       --  Portable  Operating	System	Interface (POSIX), The Open Group Base
       Specifications Issue 7, Copyright (C) 2013 by the Institute of Electri‐
       cal  and	 Electronics  Engineers,  Inc  and  The	 Open Group.  (This is
       POSIX.1-2008 with the 2013 Technical Corrigendum	 1  applied.)  In  the
       event of any discrepancy between this version and the original IEEE and
       The Open Group Standard, the original IEEE and The Open Group  Standard
       is  the	referee document. The original Standard can be obtained online
       at http://www.unix.org/online.html .

       Any typographical or formatting errors that appear  in  this  page  are
       most likely to have been introduced during the conversion of the source
       files to man page format. To report such errors,	 see  https://www.ker‐
       nel.org/doc/man-pages/reporting_bugs.html .

IEEE/The Open Group		     2013			     TOUCH(1P)
[top]

List of man pages available for Gentoo

Copyright (c) for man pages and the logo by the respective OS vendor.

For those who want to learn more, the polarhome community provides shell access and support.

[legal] [privacy] [GNU] [policy] [cookies] [netiquette] [sponsors] [FAQ]
Tweet
Polarhome, production since 1999.
Member of Polarhome portal.
Based on Fawad Halim's script.
....................................................................
Vote for polarhome
Free Shell Accounts :: the biggest list on the net