(root)/
tar-1.35/
gnu/
time-internal.h
       1  /* Time internal interface
       2  
       3     Copyright 2015-2023 Free Software Foundation, Inc.
       4  
       5     This file is free software: you can redistribute it and/or modify
       6     it under the terms of the GNU Lesser General Public License as
       7     published by the Free Software Foundation, either version 3 of the
       8     License, or (at your option) any later version.
       9  
      10     This file is distributed in the hope that it will be useful,
      11     but WITHOUT ANY WARRANTY; without even the implied warranty of
      12     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
      13     GNU Lesser General Public License for more details.
      14  
      15     You should have received a copy of the GNU Lesser General Public License
      16     along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
      17  
      18  /* Written by Paul Eggert.  */
      19  
      20  /* A time zone rule.  */
      21  struct tm_zone
      22  {
      23    /* More abbreviations, should they be needed.  Their TZ_IS_SET
      24       members are zero.  */
      25    struct tm_zone *next;
      26  
      27  #if HAVE_TZNAME && !HAVE_STRUCT_TM_TM_ZONE
      28    /* Copies of recent strings taken from tzname[0] and tzname[1].
      29       The copies are in ABBRS, so that they survive tzset.  Null if unknown.  */
      30    char *tzname_copy[2];
      31  #endif
      32  
      33    /* If nonzero, the rule represents the TZ environment variable set
      34       to the first "abbreviation" (this may be the empty string).
      35       Otherwise, it represents an unset TZ.  */
      36    char tz_is_set;
      37  
      38    /* A sequence of null-terminated strings packed next to each other.
      39       The strings are followed by an extra null byte.  If TZ_IS_SET,
      40       there must be at least one string and the first string (which is
      41       actually a TZ environment value) may be empty.  Otherwise all
      42       strings must be nonempty.
      43  
      44       Abbreviations are stored here because otherwise the values of
      45       tm_zone and/or tzname would be dead after changing TZ and calling
      46       tzset.  Abbreviations never move once allocated, and are live
      47       until tzfree is called.  */
      48    char abbrs[FLEXIBLE_ARRAY_MEMBER];
      49  };