Browse Source

Merge pull request #393 from dpogue/nix-fix

*nix fixes
Michael Hansen 11 years ago
parent
commit
50d16c3d1f
  1. 2
      Sources/Plasma/Apps/plPythonPack/main.cpp
  2. 7
      Sources/Plasma/CoreLib/hsThread_Unix.cpp
  3. 31
      Sources/Plasma/CoreLib/plFileSystem.cpp
  4. 6
      Sources/Plasma/CoreLib/plFileSystem.h

2
Sources/Plasma/Apps/plPythonPack/main.cpp

@ -75,7 +75,7 @@ void WritePythonFile(const plFileName &fileName, const plFileName &path, hsStrea
{ {
hsUNIXStream pyStream, glueStream; hsUNIXStream pyStream, glueStream;
plFileName filePath; plFileName filePath;
size_t filestart = fileName.AsString().FindLast('.'); ssize_t filestart = fileName.AsString().FindLast('.');
if (filestart >= 0) if (filestart >= 0)
filePath = fileName.AsString().Substr(filestart+1); filePath = fileName.AsString().Substr(filestart+1);
else else

7
Sources/Plasma/CoreLib/hsThread_Unix.cpp

@ -284,6 +284,7 @@ hsSemaphore::hsSemaphore(int initialValue, const char* name)
} else { } else {
/* Anonymous semaphore shared between threads */ /* Anonymous semaphore shared between threads */
int shared = 0; // 1 if sharing between processes int shared = 0; // 1 if sharing between processes
fPSema = new sem_t;
int status = sem_init(fPSema, shared, initialValue); int status = sem_init(fPSema, shared, initialValue);
hsThrowIfOSErr(status); hsThrowIfOSErr(status);
} }
@ -307,6 +308,7 @@ hsSemaphore::~hsSemaphore()
} else { } else {
status = sem_destroy(fPSema); status = sem_destroy(fPSema);
} }
delete fPSema;
hsThrowIfOSErr(status); hsThrowIfOSErr(status);
#else #else
int status = ::pthread_cond_destroy(&fPCond); int status = ::pthread_cond_destroy(&fPCond);
@ -321,7 +323,10 @@ bool hsSemaphore::TryWait()
{ {
#ifdef USE_SEMA #ifdef USE_SEMA
int status = ::sem_trywait(fPSema); int status = ::sem_trywait(fPSema);
return status != EAGAIN; if (status != 0) {
return errno != EAGAIN;
}
return true;
#else #else
int status = ::pthread_mutex_trylock(&fPMutex); int status = ::pthread_mutex_trylock(&fPMutex);
hsThrowIfOSErr(status); hsThrowIfOSErr(status);

31
Sources/Plasma/CoreLib/plFileSystem.cpp

@ -540,37 +540,6 @@ plFileName plFileSystem::GetCurrentAppPath()
#endif #endif
} }
plFileName plFileSystem::GetTempFilename(const char *prefix, const plFileName &path)
{
#if HS_BUILD_FOR_WIN32
// GetTempFileName() never uses more than 3 chars for the prefix
wchar_t wprefix[4];
for (size_t i=0; i<4; ++i)
wprefix[i] = prefix[i];
wprefix[3] = 0;
wchar_t temp[MAX_PATH];
if (GetTempFileNameW(path.AsString().ToWchar(), wprefix, 0, temp))
return plString::FromWchar(temp);
return "";
#else
plFileName tmpdir = path;
if (!tmpdir.IsValid())
tmpdir = "/tmp";
// "/tmp/prefixXXXXXX"
size_t temp_len = tmpdir.GetSize() + strlen(prefix) + 7;
char *temp = new char[temp_len + 1];
snprintf(temp, temp_len + 1, "%s/%sXXXXXX", tmpdir.AsString().c_str(), prefix);
mktemp(temp);
plFileName result = temp;
delete [] temp;
return result;
#endif
}
plString plFileSystem::ConvertFileSize(uint64_t size) plString plFileSystem::ConvertFileSize(uint64_t size)
{ {
const char* labels[] = { "KiB", "MiB", "GiB", "TiB", "PiB", "EiB" }; const char* labels[] = { "KiB", "MiB", "GiB", "TiB", "PiB", "EiB" };

6
Sources/Plasma/CoreLib/plFileSystem.h

@ -333,12 +333,6 @@ namespace plFileSystem
/** Get the full path and filename of the current process. */ /** Get the full path and filename of the current process. */
plFileName GetCurrentAppPath(); plFileName GetCurrentAppPath();
/** Create a temporary filename. If path is specified, the returned
* filename will be relative to the supplied path -- otherwise, the
* system temp path is used.
*/
plFileName GetTempFilename(const char *prefix = "tmp", const plFileName &path = "");
/** Convert a file size from bytes to a human readable size. */ /** Convert a file size from bytes to a human readable size. */
plString ConvertFileSize(uint64_t size); plString ConvertFileSize(uint64_t size);
} }

Loading…
Cancel
Save