Skip to content

Commit

Permalink
Merge pull request SFML#431 from Kratos714/master
Browse files Browse the repository at this point in the history
Fixed some minor memory issues
  • Loading branch information
LaurentGomila committed Jul 19, 2013
2 parents b3357ee + 5a42c91 commit 7cd545b
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 13 deletions.
3 changes: 3 additions & 0 deletions src/SFML/Audio/SoundFile.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,7 @@ bool SoundFile::openRead(const std::string& filename)

// Open the sound file
SF_INFO fileInfo;
fileInfo.format = 0;
m_file = sf_open(filename.c_str(), SFM_READ, &fileInfo);
if (!m_file)
{
Expand Down Expand Up @@ -132,6 +133,7 @@ bool SoundFile::openRead(const void* data, std::size_t sizeInBytes)

// Open the sound file
SF_INFO fileInfo;
fileInfo.format = 0;
m_file = sf_open_virtual(&io, SFM_READ, &fileInfo, &m_memory);
if (!m_file)
{
Expand Down Expand Up @@ -169,6 +171,7 @@ bool SoundFile::openRead(InputStream& stream)

// Open the sound file
SF_INFO fileInfo;
fileInfo.format = 0;
m_file = sf_open_virtual(&io, SFM_READ, &fileInfo, &m_stream);
if (!m_file)
{
Expand Down
24 changes: 11 additions & 13 deletions src/SFML/Window/Linux/WindowImplX11.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -60,21 +60,18 @@ namespace
}

// Find the name of the current executable
const char* findExecutableName()
void findExecutableName(char* buffer, std::size_t bufferSize)
{
char buffer[512];
std::size_t length = readlink("/proc/self/exe", buffer, sizeof(buffer));
if ((length > 0) && (length < sizeof(buffer)))
//Default fallback name
const char* executableName = "sfml";
std::size_t length = readlink("/proc/self/exe", buffer, bufferSize);
if ((length > 0) && (length < bufferSize))
{
// Remove the path to keep the executable name only
buffer[length] = '\0';
return basename(buffer);
}
else
{
// Fallback name
return "sfml";
executableName = basename(buffer);
}
std::memmove(buffer, executableName, std::strlen(executableName) + 1);
}
}

Expand Down Expand Up @@ -249,10 +246,11 @@ m_previousSize(-1, -1)
}

// Set the window's WM class (this can be used by window managers)
const char* windowClass = findExecutableName();
char windowClass[512];
findExecutableName(windowClass, sizeof(windowClass));
XClassHint* classHint = XAllocClassHint();
classHint->res_name = const_cast<char*>(windowClass);
classHint->res_class = const_cast<char*>(windowClass);
classHint->res_name = windowClass;
classHint->res_class = windowClass;
XSetClassHint(m_display, m_window, classHint);
XFree(classHint);

Expand Down

0 comments on commit 7cd545b

Please sign in to comment.