VirtualBox

source: kBuild/trunk/src/kmk/filedef.h@ 2657

Last change on this file since 2657 was 2594, checked in by bird, 13 years ago

Fixed the broken $(deps*).

  • Property svn:eol-style set to native
File size: 10.5 KB
Line 
1/* Definition of target file data structures for GNU Make.
2Copyright (C) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997,
31998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009,
42010 Free Software Foundation, Inc.
5This file is part of GNU Make.
6
7GNU Make is free software; you can redistribute it and/or modify it under the
8terms of the GNU General Public License as published by the Free Software
9Foundation; either version 3 of the License, or (at your option) any later
10version.
11
12GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY
13WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
14A PARTICULAR PURPOSE. See the GNU General Public License for more details.
15
16You should have received a copy of the GNU General Public License along with
17this program. If not, see <http://www.gnu.org/licenses/>. */
18
19
20/* Structure that represents the info on one file
21 that the makefile says how to make.
22 All of these are chained together through `next'. */
23
24#include "hash.h"
25
26struct file
27 {
28 const char *name;
29 const char *hname; /* Hashed filename */
30 const char *vpath; /* VPATH/vpath pathname */
31 struct dep *deps; /* all dependencies, including duplicates */
32#ifdef CONFIG_WITH_LAZY_DEPS_VARS
33 struct dep *deps_no_dupes; /* dependencies without duplicates, created on
34 demaned by func_deps. */
35#endif
36 struct commands *cmds; /* Commands to execute for this target. */
37 int command_flags; /* Flags OR'd in for cmds; see commands.h. */
38 const char *stem; /* Implicit stem, if an implicit
39 rule has been used */
40 struct dep *also_make; /* Targets that are made by making this. */
41 FILE_TIMESTAMP last_mtime; /* File's modtime, if already known. */
42 FILE_TIMESTAMP mtime_before_update; /* File's modtime before any updating
43 has been performed. */
44 struct file *prev; /* Previous entry for same file name;
45 used when there are multiple double-colon
46 entries for the same file. */
47 struct file *last; /* Last entry for the same file name. */
48
49 /* File that this file was renamed to. After any time that a
50 file could be renamed, call `check_renamed' (below). */
51 struct file *renamed;
52
53 /* List of variable sets used for this file. */
54 struct variable_set_list *variables;
55
56 /* Pattern-specific variable reference for this target, or null if there
57 isn't one. Also see the pat_searched flag, below. */
58 struct variable_set_list *pat_variables;
59
60 /* Immediate dependent that caused this target to be remade,
61 or nil if there isn't one. */
62 struct file *parent;
63
64 /* For a double-colon entry, this is the first double-colon entry for
65 the same file. Otherwise this is null. */
66 struct file *double_colon;
67
68#ifdef CONFIG_WITH_EXPLICIT_MULTITARGET
69 /* For a target of an explicit multi target rule, this points to the
70 primary target. Otherwise this is null. */
71 struct file *multi_head;
72 /* Pointer to next target of an explicit multi target rule. */
73 struct file *multi_next;
74#endif
75
76 short int update_status; /* Status of the last attempt to update,
77 or -1 if none has been made. */
78
79 enum cmd_state /* State of the commands. */
80 { /* Note: It is important that cs_not_started be zero. */
81 cs_not_started, /* Not yet started. */
82 cs_deps_running, /* Dep commands running. */
83 cs_running, /* Commands running. */
84 cs_finished /* Commands finished. */
85 } command_state ENUM_BITFIELD (2);
86
87 unsigned int precious:1; /* Non-0 means don't delete file on quit */
88 unsigned int low_resolution_time:1; /* Nonzero if this file's time stamp
89 has only one-second resolution. */
90 unsigned int tried_implicit:1; /* Nonzero if have searched
91 for implicit rule for making
92 this file; don't search again. */
93 unsigned int updating:1; /* Nonzero while updating deps of this file */
94 unsigned int updated:1; /* Nonzero if this file has been remade. */
95 unsigned int is_target:1; /* Nonzero if file is described as target. */
96 unsigned int cmd_target:1; /* Nonzero if file was given on cmd line. */
97 unsigned int phony:1; /* Nonzero if this is a phony file
98 i.e., a prerequisite of .PHONY. */
99 unsigned int intermediate:1;/* Nonzero if this is an intermediate file. */
100 unsigned int secondary:1; /* Nonzero means remove_intermediates should
101 not delete it. */
102 unsigned int dontcare:1; /* Nonzero if no complaint is to be made if
103 this target cannot be remade. */
104 unsigned int ignore_vpath:1;/* Nonzero if we threw out VPATH name. */
105 unsigned int pat_searched:1;/* Nonzero if we already searched for
106 pattern-specific variables. */
107 unsigned int considered:1; /* equal to 'considered' if file has been
108 considered on current scan of goal chain */
109 unsigned int no_diag:1; /* True if the file failed to update and no
110 diagnostics has been issued (dontcare). */
111
112#ifdef CONFIG_WITH_EXPLICIT_MULTITARGET
113 unsigned int multi_maybe:1; /* Nonzero if this file isn't always updated
114 by the explicit multi target rule. */
115#endif
116#ifdef CONFIG_WITH_2ND_TARGET_EXPANSION
117 unsigned int need_2nd_target_expansion:1; /* Nonzero if this file needs
118 second expansion of its name. Whether it
119 can receive this is decided at parse time,
120 and the expanding done in snap_deps. */
121#endif
122 };
123
124
125extern struct file *suffix_file, *default_file;
126
127
128struct file *lookup_file (const char *name);
129#ifdef CONFIG_WITH_STRCACHE2
130struct file *lookup_file_cached (const char *name);
131#endif
132struct file *enter_file (const char *name);
133struct dep *split_prereqs (char *prereqstr);
134struct dep *enter_prereqs (struct dep *prereqs, const char *stem);
135void remove_intermediates (int sig);
136void snap_deps (void);
137void rename_file (struct file *file, const char *name);
138void rehash_file (struct file *file, const char *name);
139void set_command_state (struct file *file, enum cmd_state state);
140void notice_finished_file (struct file *file);
141void init_hash_files (void);
142char *build_target_list (char *old_list);
143void print_prereqs (const struct dep *deps);
144void print_file_data_base (void);
145
146#if FILE_TIMESTAMP_HI_RES
147# define FILE_TIMESTAMP_STAT_MODTIME(fname, st) \
148 file_timestamp_cons (fname, (st).st_mtime, (st).st_mtim.ST_MTIM_NSEC)
149#else
150# define FILE_TIMESTAMP_STAT_MODTIME(fname, st) \
151 file_timestamp_cons (fname, (st).st_mtime, 0)
152#endif
153
154/* If FILE_TIMESTAMP is 64 bits (or more), use nanosecond resolution.
155 (Multiply by 2**30 instead of by 10**9 to save time at the cost of
156 slightly decreasing the number of available timestamps.) With
157 64-bit FILE_TIMESTAMP, this stops working on 2514-05-30 01:53:04
158 UTC, but by then uintmax_t should be larger than 64 bits. */
159#define FILE_TIMESTAMPS_PER_S (FILE_TIMESTAMP_HI_RES ? 1000000000 : 1)
160#define FILE_TIMESTAMP_LO_BITS (FILE_TIMESTAMP_HI_RES ? 30 : 0)
161
162#define FILE_TIMESTAMP_S(ts) (((ts) - ORDINARY_MTIME_MIN) \
163 >> FILE_TIMESTAMP_LO_BITS)
164#define FILE_TIMESTAMP_NS(ts) ((int) (((ts) - ORDINARY_MTIME_MIN) \
165 & ((1 << FILE_TIMESTAMP_LO_BITS) - 1)))
166
167/* Upper bound on length of string "YYYY-MM-DD HH:MM:SS.NNNNNNNNN"
168 representing a file timestamp. The upper bound is not necessarily 19,
169 since the year might be less than -999 or greater than 9999.
170
171 Subtract one for the sign bit if in case file timestamps can be negative;
172 subtract FLOOR_LOG2_SECONDS_PER_YEAR to yield an upper bound on how many
173 file timestamp bits might affect the year;
174 302 / 1000 is log10 (2) rounded up;
175 add one for integer division truncation;
176 add one more for a minus sign if file timestamps can be negative;
177 add 4 to allow for any 4-digit epoch year (e.g. 1970);
178 add 25 to allow for "-MM-DD HH:MM:SS.NNNNNNNNN". */
179#define FLOOR_LOG2_SECONDS_PER_YEAR 24
180#define FILE_TIMESTAMP_PRINT_LEN_BOUND \
181 (((sizeof (FILE_TIMESTAMP) * CHAR_BIT - 1 - FLOOR_LOG2_SECONDS_PER_YEAR) \
182 * 302 / 1000) \
183 + 1 + 1 + 4 + 25)
184
185FILE_TIMESTAMP file_timestamp_cons (char const *, time_t, int);
186FILE_TIMESTAMP file_timestamp_now (int *);
187void file_timestamp_sprintf (char *p, FILE_TIMESTAMP ts);
188
189/* Return the mtime of file F (a struct file *), caching it.
190 The value is NONEXISTENT_MTIME if the file does not exist. */
191#define file_mtime(f) file_mtime_1 ((f), 1)
192/* Return the mtime of file F (a struct file *), caching it.
193 Don't search using vpath for the file--if it doesn't actually exist,
194 we don't find it.
195 The value is NONEXISTENT_MTIME if the file does not exist. */
196#define file_mtime_no_search(f) file_mtime_1 ((f), 0)
197FILE_TIMESTAMP f_mtime (struct file *file, int search);
198#define file_mtime_1(f, v) \
199 ((f)->last_mtime == UNKNOWN_MTIME ? f_mtime ((f), v) : (f)->last_mtime)
200
201/* Special timestamp values. */
202
203/* The file's timestamp is not yet known. */
204#define UNKNOWN_MTIME 0
205
206/* The file does not exist. */
207#define NONEXISTENT_MTIME 1
208
209/* The file does not exist, and we assume that it is older than any
210 actual file. */
211#define OLD_MTIME 2
212
213/* The smallest and largest ordinary timestamps. */
214#define ORDINARY_MTIME_MIN (OLD_MTIME + 1)
215#if FILE_TIMESTAMP_HI_RES == 0 /* bird: shut up annoying warnings!
216 ASSUMES: unsigned FILE_TIMESTAMP ++. */
217# define ORDINARY_MTIME_MAX ( ~ (FILE_TIMESTAMP) 0 )
218#else
219#define ORDINARY_MTIME_MAX ((FILE_TIMESTAMP_S (NEW_MTIME) \
220 << FILE_TIMESTAMP_LO_BITS) \
221 + ORDINARY_MTIME_MIN + FILE_TIMESTAMPS_PER_S - 1)
222#endif
223
224/* Modtime value to use for `infinitely new'. We used to get the current time
225 from the system and use that whenever we wanted `new'. But that causes
226 trouble when the machine running make and the machine holding a file have
227 different ideas about what time it is; and can also lose for `force'
228 targets, which need to be considered newer than anything that depends on
229 them, even if said dependents' modtimes are in the future. */
230#if 1 /* bird: ASSUME the type is unsigned and the wrath of a pedantic gcc. */
231# define NEW_MTIME ( ~ (FILE_TIMESTAMP) 0 )
232#else
233#define NEW_MTIME INTEGER_TYPE_MAXIMUM (FILE_TIMESTAMP)
234#endif
235
236#define check_renamed(file) \
237 while ((file)->renamed != 0) (file) = (file)->renamed /* No ; here. */
238
239/* Have we snapped deps yet? */
240extern int snapped_deps;
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette