diff options
author | Andy Cedilnik <andy.cedilnik@kitware.com> | 2004-07-02 15:51:30 (GMT) |
---|---|---|
committer | Andy Cedilnik <andy.cedilnik@kitware.com> | 2004-07-02 15:51:30 (GMT) |
commit | 04a8572b9985a7c7c3eec95e52bc1ce144f39c8f (patch) | |
tree | ae0fdece007f851e0c90736fb39351412c854ac2 /Source/cmFileCommand.cxx | |
parent | 9d61ea38ddc8cbc657e1f847e940aa3602d1b811 (diff) | |
download | CMake-04a8572b9985a7c7c3eec95e52bc1ce144f39c8f.zip CMake-04a8572b9985a7c7c3eec95e52bc1ce144f39c8f.tar.gz CMake-04a8572b9985a7c7c3eec95e52bc1ce144f39c8f.tar.bz2 |
BUG: If the destination is the same as source, do not copy file. Fixes Bug #956 - make install broken
Diffstat (limited to 'Source/cmFileCommand.cxx')
-rw-r--r-- | Source/cmFileCommand.cxx | 73 |
1 files changed, 38 insertions, 35 deletions
diff --git a/Source/cmFileCommand.cxx b/Source/cmFileCommand.cxx index 471b92a..a1d85b2 100644 --- a/Source/cmFileCommand.cxx +++ b/Source/cmFileCommand.cxx @@ -549,51 +549,54 @@ bool cmFileCommand::HandleInstallCommand( break; } - if ( cmSystemTools::FileExists(ctarget.c_str()) ) + if ( !cmSystemTools::SameFile(ctarget.c_str(), destfile.c_str()) ) { - cmSystemTools::RemoveFile(destfile.c_str()); - if ( !cmSystemTools::CopyFileAlways(ctarget.c_str(), - destination.c_str()) ) + if ( cmSystemTools::FileExists(ctarget.c_str()) ) { - std::string errstring = "cannot copy file: " + ctarget + - " to directory : " + destination + "."; - this->SetError(errstring.c_str()); - return false; - } - switch( itype ) - { - case cmTarget::MODULE_LIBRARY: - case cmTarget::SHARED_LIBRARY: - case cmTarget::EXECUTABLE: - case cmTarget::INSTALL_PROGRAMS: + cmSystemTools::RemoveFile(destfile.c_str()); + if ( !cmSystemTools::CopyFileAlways(ctarget.c_str(), + destination.c_str()) ) + { + std::string errstring = "cannot copy file: " + ctarget + + " to directory : " + destination + "."; + this->SetError(errstring.c_str()); + return false; + } + switch( itype ) + { + case cmTarget::MODULE_LIBRARY: + case cmTarget::SHARED_LIBRARY: + case cmTarget::EXECUTABLE: + case cmTarget::INSTALL_PROGRAMS: - if ( !cmSystemTools::SetPermissions(destfile.c_str(), + if ( !cmSystemTools::SetPermissions(destfile.c_str(), #if defined( _MSC_VER ) || defined( __MINGW32__ ) - S_IREAD | S_IWRITE | S_IEXEC + S_IREAD | S_IWRITE | S_IEXEC #elif defined( __BORLANDC__ ) - S_IRUSR | S_IWUSR | S_IXUSR + S_IRUSR | S_IWUSR | S_IXUSR #else - S_IRUSR | S_IWUSR | S_IXUSR | - S_IRGRP | S_IXGRP | - S_IROTH | S_IXOTH + S_IRUSR | S_IWUSR | S_IXUSR | + S_IRGRP | S_IXGRP | + S_IROTH | S_IXOTH #endif - ) ) - { - cmOStringStream err; - err << "Problem setting permissions on file: " << destfile.c_str(); - perror(err.str().c_str()); + ) ) + { + cmOStringStream err; + err << "Problem setting permissions on file: " << destfile.c_str(); + perror(err.str().c_str()); + } } + smanifest_files += ";" + destfile; } - smanifest_files += ";" + destfile; - } - else - { - if ( !optional ) + else { - std::string errstring = "cannot find file: " + - ctarget + " to install."; - this->SetError(errstring.c_str()); - return false; + if ( !optional ) + { + std::string errstring = "cannot find file: " + + ctarget + " to install."; + this->SetError(errstring.c_str()); + return false; + } } } } |