summaryrefslogtreecommitdiff
path: root/dmake/make.c
diff options
context:
space:
mode:
authorIvo Hinkelmann <ihi@openoffice.org>2007-10-15 14:40:19 +0000
committerIvo Hinkelmann <ihi@openoffice.org>2007-10-15 14:40:19 +0000
commit8c8f0e51a845dc62fd5e9740aadb69d1b0aaea80 (patch)
treecb5bbd3ff682cf8d513c9a28e2598694ddad0228 /dmake/make.c
parent551eb4d6c3e45ace719aea770e0078885dd553dd (diff)
INTEGRATION: CWS dmake411 (1.9.4); FILE MERGED
2007/09/19 00:34:31 vq 1.9.4.15: #i81252# Add a new SHELLCMDQUOTE control macro. 2007/09/14 03:40:58 vq 1.9.4.14: #i81296# Clear flags indicating that targets that infered makefiles (and their prerequisites) were previously build. 2007/09/08 18:20:35 vq 1.9.4.13: #i10000# Add some output for .INCLUDE operations when the -vf verbose flag is given. 2007/09/02 10:44:26 vq 1.9.4.12: #i67911# Wait with the deletion of temporary files until the target is completely made. 2007/08/25 19:34:32 vq 1.9.4.11: #i64572# If a target without recipes has an existing file use its time stamp only if the time is newer than the one of the its newest prerequisite. 2007/08/21 15:09:25 vq 1.9.4.10: #i64572# To keep the dependency chains intact targets without recipes inherit the time of their newest prerequisite. (Additional patches are needed as currently the F_RULES flag is not always set correctly.) 2007/08/18 22:23:40 vq 1.9.4.9: #i64572# Make dmake warn if the time stamp of a target is not updated after making the target. This warning can be silenced using the .SILENT attribute. 2007/08/18 03:21:48 vq 1.9.4.8: #i10000# Remove unused variable. 2007/08/18 03:16:50 vq 1.9.4.7: #i10000# Add some comments. 2007/08/15 21:25:21 vq 1.9.4.6: #i80687# Fix building of inferred phony prerequisites. 2007/08/14 17:55:49 vq 1.9.4.5: #i64572# Revert previous patch. 2007/08/13 15:33:17 vq 1.9.4.4: #i64572# Make dmake warn if the time stamp of a target is not updated after making the target. 2007/08/05 18:55:42 vq 1.9.4.3: #i70168# Clear F_MARK flag after dynamic prerequisite expansion is done. 2007/08/04 18:42:31 vq 1.9.4.2: #i80352# Fix .PRECIOUS attribute. 2007/07/12 22:59:49 vq 1.9.4.1: #i69462# Do not assume that non-existing prerequisites for %-targets have the same time stamp as the parent target. Testcase added.
Diffstat (limited to 'dmake/make.c')
-rw-r--r--dmake/make.c146
1 files changed, 88 insertions, 58 deletions
diff --git a/dmake/make.c b/dmake/make.c
index 22d79f3c424d..0329d7e6e46a 100644
--- a/dmake/make.c
+++ b/dmake/make.c
@@ -1,6 +1,6 @@
/* $RCSfile: make.c,v $
--- $Revision: 1.10 $
--- last change: $Author: vg $ $Date: 2007-09-20 14:33:30 $
+-- $Revision: 1.11 $
+-- last change: $Author: ihi $ $Date: 2007-10-15 15:40:19 $
--
-- SYNOPSIS
-- Perform the update of all outdated targets.
@@ -259,7 +259,9 @@ Make_targets()/*
PUBLIC int
Make( cp, setdirroot )/*
-======================== Make a specified target */
+========================
+ Make target cp. Make() is also called on prerequisites that have no rule
+ associated (F_TARGET is not set) to verify that they exist. */
CELLPTR cp;
CELLPTR setdirroot;
{
@@ -277,8 +279,7 @@ CELLPTR setdirroot;
int push = 0;
int made = F_MADE;
int ignore;
- time_t otime = (time_t) 1L;
- time_t ttime = (time_t) 1L;
+ time_t otime = (time_t) 1L; /* Hold time of newest prerequisite. */
int mark_made = FALSE;
#if defined(__CYGWIN__)
@@ -372,8 +373,6 @@ CELLPTR setdirroot;
DB_PRINT( "mem", ("%s:-A mem %ld", cp->CE_NAME, (long) coreleft()) );
/* If we have not yet statted the target then do so. */
if( !(cp->ce_flag & F_STAT) && !(cp->ce_attr&A_PHONY) ) {
- time_t itime = cp->ce_time;
-
if (cp->ce_parent && (cp->ce_parent->ce_flag & F_MULTI)) {
/* Inherit the stat info from the F_MULTI parent. */
cp->ce_time = cp->ce_parent->ce_time;
@@ -387,11 +386,7 @@ CELLPTR setdirroot;
/* Check if target already exists. */
Stat_target( tcp, 1, FALSE );
- if( tcp->ce_time == (time_t)0L ) {
- if( tcp->ce_flag & F_INFER )
- tcp->ce_time = itime;
- }
- else {
+ if( tcp->ce_time != (time_t)0L ) {
/* File exists so don't remove it later. */
tcp->ce_attr |= A_PRECIOUS;
}
@@ -406,6 +401,7 @@ CELLPTR setdirroot;
DB_PRINT( "make", ("(%s, %ld, 0x%08x, 0x%04x)", cp->CE_NAME,
cp->ce_time, cp->ce_attr, cp->ce_flag) );
+ /* Handle targets without rule and without existing file. */
if( !(cp->ce_flag & F_TARGET) && (cp->ce_time == (time_t) 0L) ) {
if( Makemkf ) {
rval = -1;
@@ -492,19 +488,29 @@ CELLPTR setdirroot;
next = dp->cl_next;
tcp = dp->cl_prq;
+ if( Verbose & V_MAKE )
+ printf("Checking prerequisite [%s]\n", tcp->CE_NAME);
+
seq = (((cp->ce_attr | Glob_attr) & A_SEQ) != 0);
+ /* This checks if this prerequisite is still in the making, if yes
+ * come back later. */
if( tcp->ce_flag & F_VISITED ) {
+ /* Check if this currently or fully made target has the same
+ * .SETDIR setting. If yes, continue if it was made or come
+ * back later otherwise. */
if( _explode_graph(tcp, dp, setdirroot) == 0 ) {
/* didn't blow it up so see if we need to wait for it. */
if( tcp->ce_flag & F_MADE ) {
- if( tcp->ce_time > ttime ) ttime = tcp->ce_time;
+ /* Target was made. */
continue;
}
else
+ /* Target is still in the making ... */
goto stop_making_it;
}
else
+ /* Use the new prerequisite with the new .SETDIR value. */
tcp = dp->cl_prq;
}
@@ -555,20 +561,15 @@ CELLPTR setdirroot;
}
/* Clear F_MARK flag that could have been set by _expand_dynamic_prq(). */
- tcp->ce_attr &= ~(F_MARK);
+ tcp->ce_flag &= ~(F_MARK);
if( cp->ce_attr & A_LIBRARY ) {
tcp->ce_attr |= A_LIBRARYM;
tcp->ce_lib = cp->ce_fname;
}
- if( (tcp->ce_flag & (F_INFER|F_STAT))==F_INFER && cp->ce_time >= ttime )
- tcp->ce_time = cp->ce_time;
-
- /* Propagate the parent's F_REMOVE and F_INFER flags to the children.
- * Make certain to do this AFTER propagating the time, since the
- * time propagation test above uses the F_INFER flag to decide if
- * it should do so. */
+ /* Propagate the parent's F_REMOVE and F_INFER flags to the
+ * prerequisites. */
tcp->ce_flag |= cp->ce_flag & (F_REMOVE|F_INFER);
/* Propagate parents A_ROOT attribute to a child if the parent is a
@@ -586,8 +587,6 @@ CELLPTR setdirroot;
if( rval == -1 || (seq && (rval==1)) )
goto stop_making_it;
- if( tcp->ce_time > ttime ) ttime = tcp->ce_time;
-
/* If tcp is ready, set made = F_MADE. */
made &= tcp->ce_flag & F_MADE;
}
@@ -618,6 +617,8 @@ CELLPTR setdirroot;
if( mtime < tcp->ce_time ) tcp->ce_time = cp->ce_time+1L;
}
+ /* Set otime to the newest time stamp of all prereqs or 1 if there
+ * are no prerequisites. */
if( tcp->ce_time > otime ) otime = tcp->ce_time;
list_add(&all_list, name);
@@ -631,6 +632,8 @@ CELLPTR setdirroot;
}
}
+ /* All prerequisites are made, now make the current target. */
+
/* Restore UseWinpath and $@ if needed, see above for an explanation. */
if (m_at->ht_value == NIL(char)) {
/* This check effectively tests if Make() was run before because
@@ -721,6 +724,22 @@ CELLPTR setdirroot;
printf( "%s: Updating [%s], (%ld > %ld)\n", Pname,
cp->CE_NAME, otime, cp->ce_time );
+ /* In order to check if a targets time stamp was properly updated
+ * after the target was made and to keep the dependency chain valid
+ * for targets without recipes we store the minimum required file
+ * time. If the target time stamp is older than the newest
+ * prerequisite use that time, otherwise the current time. (This
+ * avoids the call to Do_time() for every target, still checks
+ * if the target time is new enough for the given prerequisite and
+ * mintime is also the newest time of the given prerequisites and
+ * can be used for targets without recipes.)
+ * We reuse the ce_time member to store this minimum time until
+ * the target is finished by Update_time_stamp(). This function
+ * checks if the file time was updated properly and warns if it was
+ * not. (While making a target this value does not change.) */
+ cp->ce_time = ( cp->ce_time < otime ? otime : Do_time() );
+ DB_PRINT( "make", ("Set ce_time (mintime) to: %ld", cp->ce_time) );
+
if( Touch ) {
name = cp->ce_fname;
lib = cp->ce_lib;
@@ -781,6 +800,8 @@ CELLPTR setdirroot;
m_q->ht_value = name;
rval = Exec_commands( cp );
+ /* Thanks to Wait_for_completion = TRUE we are allowed
+ * to remove the temp files here. */
Unlink_temp_files(cp);
}
while( *(name = Get_token( &tk, "", FALSE )) != '\0' );
@@ -809,13 +830,22 @@ CELLPTR setdirroot;
}
}
else {
+ if( Verbose & V_MAKE )
+ printf( "%s: Up to date [%s], prq time = %ld , target time = %ld)\n", Pname,
+ cp->CE_NAME, otime, cp->ce_time );
mark_made = TRUE;
}
- /* Make sure everyone gets remade if Force is set */
+ /* If mark_made == TRUE the target is up-to-date otherwise it is
+ * currently in the making. */
+
+ /* Update all targets in .UPDATEALL rule / only target cp. */
for(dp=CeMeToo(cp); dp; dp=dp->cl_next) {
tcp=dp->cl_prq;
+ /* Set the time stamp of those prerequisites without rule to the current
+ * time if Force is TRUE to make sure that targets depending on those
+ * prerequisites get remade. */
if( !(tcp->ce_flag & F_TARGET) && Force ) tcp->ce_time = Do_time();
if( mark_made ) {
tcp->ce_flag |= F_MADE;
@@ -826,6 +856,7 @@ CELLPTR setdirroot;
}
}
+ /* Note that the target is in the making. */
tcp->ce_flag |= F_VISITED;
/* Note: If the prerequisite was made using a .SETDIR= attribute
@@ -1373,7 +1404,7 @@ CELLPTR cp;
/* Print command and remove continuation sequence from cmnd. */
Print_cmnd(cmnd, !(do_it && (l_attr & A_SILENT)), 0);
}
- rval=Do_cmnd(cmnd,FALSE,do_it,cp,l_attr,
+ rval=Do_cmnd(&cmnd,FALSE,do_it,cp,l_attr,
rp->st_next == NIL(STRING) );
}
@@ -1397,7 +1428,7 @@ CELLPTR cp;
chmod(groupfile,0700);
#endif
}
- rval = Do_cmnd(groupfile, TRUE, do_it, cp, attr | A_SHELL, TRUE);
+ rval = Do_cmnd(&groupfile, TRUE, do_it, cp, attr | A_SHELL, TRUE);
}
_recipes[ RP_RECIPE ] = orp;
@@ -1615,39 +1646,7 @@ int map;
if( Trace ) return;
-#ifdef __EMX__
- // YD libc06 response files requires one argument per line
- // write each argument on a new line
- {
- char* quote;
- int quote_flag = 0;
- char* tok = strtok( cmnd, " \t\n\r");
- while( tok) {
- if (strlen(tok)>0) {
- fputs(tok, tmpfile);
- // check for a single quote ": if found, do not write newline until next quote
- // but add a white space.
- // double quotes in token doesn't need special handling.
- quote = strchr( tok, '\"');
- if (quote) {
- // check if single
- if (!strchr( quote+1, '\"'))
- quote_flag = 1 - quote_flag;
- }
- if (quote_flag == 0)
- fputc('\n', tmpfile);
- else
- fputc(' ', tmpfile);
- }
- tok = strtok( NULL, " \t\n\r");
- }
- // remove newline, otherwise we get two of them!
- newline = 0;
- }
-#else
fputs(cmnd, tmpfile);
-#endif
-
if( newline ) fputc('\n', tmpfile);
fflush(tmpfile);
@@ -1727,3 +1726,34 @@ char *str;
DB_RETURN( string );
}
+
+
+void
+Unmake( cp )/*
+==============
+ Remove flags indicating that a target was previously made. This
+ is used for infered makefiles. */
+CELLPTR cp;
+{
+ LINKPTR dp, ep;
+ CELLPTR tcp, pcp;
+
+ DB_ENTER( "Unmake" );
+
+ for(dp=CeMeToo(cp); dp; dp=dp->cl_next) {
+ tcp = dp->cl_prq;
+
+ /* Unmake the prerequisites. */
+ for( ep = tcp->ce_prq; ep != NIL(LINK); ep = ep->cl_next ) {
+ pcp = ep->cl_prq;
+
+ Unmake(pcp);
+ }
+ DB_PRINT( "unmake", ("Unmake [%s]", tcp->CE_NAME) );
+
+ tcp->ce_flag &= ~(F_MADE|F_VISITED|F_STAT);
+ tcp->ce_time = (time_t)0L;
+ }
+
+ DB_VOID_RETURN;
+}