summaryrefslogtreecommitdiff
path: root/CCache/ccache.c
diff options
context:
space:
mode:
authorWilliam S Fulton <wsf@fultondesigns.co.uk>2009-01-07 02:26:34 +0000
committerWilliam S Fulton <wsf@fultondesigns.co.uk>2009-01-07 02:26:34 +0000
commit7c81201d28a0c4a52f0fb1523e172fedf63f953b (patch)
treea1cf6e4adb7068b2b8fdd1b3db6e56a621dbd6e5 /CCache/ccache.c
parente65ea565300a9c1f6f73fe1c16a9e084d7cce560 (diff)
downloadswig-7c81201d28a0c4a52f0fb1523e172fedf63f953b.tar.gz
Fix lack of error logging in some situations and fix failure to work on windows when swig is a pure Win32 (non-cygwin) compile
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@11034 626c5289-ae23-0410-ae9c-e8d60b6d4f22
Diffstat (limited to 'CCache/ccache.c')
-rw-r--r--CCache/ccache.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/CCache/ccache.c b/CCache/ccache.c
index e35778147..0de4e4136 100644
--- a/CCache/ccache.c
+++ b/CCache/ccache.c
@@ -329,6 +329,9 @@ static void to_cache(ARGS *args)
while (fgets(out_filename, FILENAME_MAX, file)) {
char *linefeed = strchr(out_filename, '\n');
if (linefeed) {
+ char *potential_cr = linefeed - 1;
+ if (potential_cr >= out_filename && *potential_cr == '\r')
+ *potential_cr = 0;
*linefeed = 0;
if (cached_files_count == 0) {
@@ -337,8 +340,7 @@ static void to_cache(ARGS *args)
sprintf(out_filename_cache, "%s.%d", hashname, cached_files_count);
}
- if (stat(out_filename, &st1) != 0 ||
- commit_to_cache(out_filename, out_filename_cache, hardlink) != 0) {
+ if (commit_to_cache(out_filename, out_filename_cache, hardlink) != 0) {
fclose(file);
unlink(tmp_outfiles);
failed();
@@ -374,8 +376,7 @@ static void to_cache(ARGS *args)
failed();
}
} else {
- if (stat(output_file, &st1) != 0 ||
- commit_to_cache(output_file, hashname, hardlink) != 0) {
+ if (commit_to_cache(output_file, hashname, hardlink) != 0) {
failed();
}
to_cache_stats_helper(&st1, hashname, 0, &files_size, &cached_files_count);
@@ -670,6 +671,9 @@ static void from_cache(int first)
while (fgets(out_filename, FILENAME_MAX, file)) {
char *linefeed = strchr(out_filename, '\n');
if (linefeed) {
+ char *potential_cr = linefeed - 1;
+ if (potential_cr >= out_filename && *potential_cr == '\r')
+ *potential_cr = 0;
*linefeed = 0;
if (retrieved_files_count == 0) {