diff options
| author | Ulrich Sibiller <uli42@gmx.de> | 2017-12-07 22:35:59 +0100 | 
|---|---|---|
| committer | Mihai Moldovan <ionic@ionic.de> | 2017-12-09 13:15:35 +0100 | 
| commit | 4dbee3a3f13657577f283bca22b281d7273c19e5 (patch) | |
| tree | 638d62dce7a3e1f4245cb53212e3e422f310be99 /nxcomp/src/ChannelEndPoint.cpp | |
| parent | 2814677a7e2b259669708c89ed55b55dc1c46f9c (diff) | |
| download | nx-libs-4dbee3a3f13657577f283bca22b281d7273c19e5.tar.gz nx-libs-4dbee3a3f13657577f283bca22b281d7273c19e5.tar.bz2 nx-libs-4dbee3a3f13657577f283bca22b281d7273c19e5.zip | |
nxcomp: use new macro SAFE_FREE(ptr)
Should be used instead of free() calls and will clear the pointer after
calling free(). This can prevent double-free or use-after-free errors.
Diffstat (limited to 'nxcomp/src/ChannelEndPoint.cpp')
| -rw-r--r-- | nxcomp/src/ChannelEndPoint.cpp | 30 | 
1 files changed, 14 insertions, 16 deletions
| diff --git a/nxcomp/src/ChannelEndPoint.cpp b/nxcomp/src/ChannelEndPoint.cpp index 843bf2b35..fb8549f6a 100644 --- a/nxcomp/src/ChannelEndPoint.cpp +++ b/nxcomp/src/ChannelEndPoint.cpp @@ -37,6 +37,8 @@  #include "NXalert.h" +#include "Misc.h" +  ChannelEndPoint::ChannelEndPoint(const char *spec)    : defaultTCPPort_(0), defaultTCPInterface_(0),      defaultUnixPath_(NULL), spec_(NULL) { @@ -54,17 +56,14 @@ ChannelEndPoint::~ChannelEndPoint()      if(S_ISSOCK(st.st_mode))        unlink(unixPath);    } -  free(unixPath); -  unixPath = NULL; -  free(defaultUnixPath_); -  defaultUnixPath_ = NULL; -  free(spec_); -  spec_ = NULL; +  SAFE_FREE(unixPath); +  SAFE_FREE(defaultUnixPath_); +  SAFE_FREE(spec_);  }  void  ChannelEndPoint::setSpec(const char *spec) { -  free(spec_); +  SAFE_FREE(spec_);    if (spec && strlen(spec))    { @@ -99,8 +98,7 @@ ChannelEndPoint::setSpec(const char *hostName, long port) {    isUnix_ = false;    isTCP_ = false; -  free(spec_); -  spec_ = NULL; +  SAFE_FREE(spec_);    if (hostName && strlen(hostName) && port >= 1)    { @@ -145,9 +143,9 @@ ChannelEndPoint::getSpec(char **socketUri) const {        *socketUri = strdup(newSocketUri);    } -  free(newSocketUri); -  free(unixPath); -  free(hostName); +  SAFE_FREE(newSocketUri); +  SAFE_FREE(unixPath); +  SAFE_FREE(hostName);    if (NULL != *socketUri)      return true; @@ -168,7 +166,7 @@ ChannelEndPoint::setDefaultTCPInterface(int publicInterface) {  void  ChannelEndPoint::setDefaultUnixPath(char *path) { -  free(defaultUnixPath_); +  SAFE_FREE(defaultUnixPath_);    if (path && strlen(path))      defaultUnixPath_ = strdup(path); @@ -337,10 +335,10 @@ ChannelEndPoint &ChannelEndPoint::operator=(const ChannelEndPoint &other) {    defaultTCPInterface_ = other.defaultTCPInterface_;    old = defaultUnixPath_;    defaultUnixPath_ = (other.defaultUnixPath_ ? strdup(other.defaultUnixPath_) : NULL); -  free(old); +  SAFE_FREE(old);    old = spec_;    spec_ = (other.spec_ ? strdup(other.spec_) : NULL); -  free(old); +  SAFE_FREE(old);    isUnix_ = getUnixPath();    isTCP_ = getTCPHostAndPort();    return *this; @@ -352,7 +350,7 @@ std::ostream& operator<<(std::ostream& os, const ChannelEndPoint& endPoint) {      if (endPoint.getSpec(&endPointSpec))      {        os << endPointSpec; -      free(endPointSpec); +      SAFE_FREE(endPointSpec);      }      else        os << "(invalid)"; | 
