ENH: Changing shared library versioned file names on OSX to conform to that platform's convention.

This commit is contained in:
Brad King 2006-06-05 13:45:43 -04:00
parent 7ebe4702db
commit 932e3524fc
3 changed files with 46 additions and 10 deletions

View File

@ -775,15 +775,10 @@ bool cmFileCommand::HandleInstallCommand(
std::string libname = toFile; std::string libname = toFile;
std::string soname = toFile; std::string soname = toFile;
std::string soname_nopath = fromName; std::string soname_nopath = fromName;
soname += "."; this->ComputeVersionedName(soname, lib_soversion);
soname += lib_soversion; this->ComputeVersionedName(soname_nopath, lib_soversion);
soname_nopath += "."; this->ComputeVersionedName(fromName, lib_version);
soname_nopath += lib_soversion; this->ComputeVersionedName(toFile, lib_version);
fromName += ".";
fromName += lib_version;
toFile += ".";
toFile += lib_version;
cmSystemTools::RemoveFile(soname.c_str()); cmSystemTools::RemoveFile(soname.c_str());
cmSystemTools::RemoveFile(libname.c_str()); cmSystemTools::RemoveFile(libname.c_str());
@ -945,6 +940,26 @@ bool cmFileCommand::HandleInstallCommand(
return true; return true;
} }
//----------------------------------------------------------------------------
void cmFileCommand::ComputeVersionedName(std::string& name,
const char* version)
{
#if defined(__APPLE__)
std::string ext;
kwsys_stl::string::size_type dot_pos = name.rfind(".");
if(dot_pos != name.npos)
{
ext = name.substr(dot_pos, name.npos);
name = name.substr(0, dot_pos);
}
#endif
name += ".";
name += version;
#if defined(__APPLE__)
name += ext;
#endif
}
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
bool cmFileCommand::HandleRelativePathCommand( bool cmFileCommand::HandleRelativePathCommand(
std::vector<std::string> const& args) std::vector<std::string> const& args)

View File

@ -125,6 +125,7 @@ protected:
bool HandleRelativePathCommand(std::vector<std::string> const& args); bool HandleRelativePathCommand(std::vector<std::string> const& args);
bool HandleCMakePathCommand(std::vector<std::string> const& args, bool HandleCMakePathCommand(std::vector<std::string> const& args,
bool nativePath); bool nativePath);
void ComputeVersionedName(std::string& name, const char* version);
}; };

View File

@ -1321,19 +1321,36 @@ void cmTarget::GetLibraryNamesInternal(std::string& name,
soversion = version; soversion = version;
} }
// Get the components of the library name.
std::string prefix;
std::string base;
std::string suffix;
this->GetFullNameInternal(type, config, false, prefix, base, suffix);
// The library name. // The library name.
name = this->GetFullNameInternal(type, config, false); name = prefix+base+suffix;
// The library's soname. // The library's soname.
#if defined(__APPLE__)
soName = prefix+base;
#else
soName = name; soName = name;
#endif
if(soversion) if(soversion)
{ {
soName += "."; soName += ".";
soName += soversion; soName += soversion;
} }
#if defined(__APPLE__)
soName += suffix;
#endif
// The library's real name on disk. // The library's real name on disk.
#if defined(__APPLE__)
realName = prefix+base;
#else
realName = name; realName = name;
#endif
if(version) if(version)
{ {
realName += "."; realName += ".";
@ -1344,6 +1361,9 @@ void cmTarget::GetLibraryNamesInternal(std::string& name,
realName += "."; realName += ".";
realName += soversion; realName += soversion;
} }
#if defined(__APPLE__)
realName += suffix;
#endif
// The import library name. // The import library name.
if(type == cmTarget::SHARED_LIBRARY) if(type == cmTarget::SHARED_LIBRARY)