From 158b515e21f0f0154041cd5985ec38fe37c0e875 Mon Sep 17 00:00:00 2001
From: rathnor <rathnor>
Date: Thu, 2 Oct 2003 16:14:41 +0000
Subject: address some memory issues shown up with valgrind

---
 ChangeLog                 |  4 ++++
 src/FbTk/EventManager.cc  | 21 ++++++++++-----------
 src/FbTk/TextureRender.cc |  8 ++++----
 src/Gnome.cc              |  4 ++--
 src/Screen.cc             |  7 +++++--
 src/WinClient.cc          |  5 +++--
 src/Window.cc             |  7 ++++++-
 src/Xutil.cc              |  6 +++++-
 src/main.cc               |  4 ++--
 9 files changed, 41 insertions(+), 25 deletions(-)

diff --git a/ChangeLog b/ChangeLog
index cacb377..62647f4 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,6 +1,10 @@
 (Format: Year/Month/Day)
 Changes for 0.9.6:
 *03/10/02:
+  * Fix couple of memory leaks and uninitialised uses shown up with 
+    valgrind (Simon)
+    EventManager.cc TextureRender.cc Gnome.cc Screen.cc Window.cc 
+    WinClient.cc Xutil.cc main.cc
   * Make grips children of handle (Simon)
     - Fixes parentrelative grip texture
     FbWinFrame.hh/cc
diff --git a/src/FbTk/EventManager.cc b/src/FbTk/EventManager.cc
index eadc701..ff01794 100644
--- a/src/FbTk/EventManager.cc
+++ b/src/FbTk/EventManager.cc
@@ -19,7 +19,7 @@
 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 // DEALINGS IN THE SOFTWARE.
 
-// $Id: EventManager.cc,v 1.8 2003/08/27 00:21:54 fluxgen Exp $
+// $Id: EventManager.cc,v 1.9 2003/10/02 16:14:41 rathnor Exp $
 
 #include "EventManager.hh"
 #include "FbWindow.hh"
@@ -114,19 +114,18 @@ void EventManager::dispatch(Window win, XEvent &ev, bool parent) {
     Window root, parent_win, *children = 0;
     unsigned int num_children;
     if (XQueryTree(FbTk::App::instance()->display(), win, 
-                   &root, &parent_win, &children, &num_children) != 0 && 
-        parent_win != 0 &&
-        parent_win != root) {
-
-        if (children != 0)
+                   &root, &parent_win, &children, &num_children) != 0) {
+        if (children != 0) 
             XFree(children);
 
-        if (m_parent[parent_win] == 0)
-            return;
-
-        // dispatch event to parent
-        dispatch(parent_win, ev, true);
+        if (parent_win != 0 &&
+            parent_win != root) {
+            if (m_parent[parent_win] == 0)
+                return;
 
+            // dispatch event to parent
+            dispatch(parent_win, ev, true);
+        }
     }
 
 }
diff --git a/src/FbTk/TextureRender.cc b/src/FbTk/TextureRender.cc
index 40a7e72..f1f1103 100644
--- a/src/FbTk/TextureRender.cc
+++ b/src/FbTk/TextureRender.cc
@@ -22,7 +22,7 @@
 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 // DEALINGS IN THE SOFTWARE.
 
-// $Id: TextureRender.cc,v 1.4 2003/08/12 11:44:41 fluxgen Exp $
+// $Id: TextureRender.cc,v 1.5 2003/10/02 16:14:41 rathnor Exp $
 
 #include "TextureRender.hh"
 
@@ -57,7 +57,7 @@ TextureRender::TextureRender(ImageControl &imgctrl,
         height = 3200;
     }
 
-    red = new (nothrow) unsigned char[width * height];
+    red = new unsigned char[width * height];
     if (red == 0) {
         char sbuf[128];
         sprintf(sbuf, "%d", width*height);
@@ -65,14 +65,14 @@ TextureRender::TextureRender(ImageControl &imgctrl,
     }
 
 
-    green = new (nothrow)  unsigned char[width * height];
+    green = new unsigned char[width * height];
     if (green == 0) {
         char sbuf[128];
         sprintf(sbuf, "%d", width*height);
         throw string("TextureRender::TextureRender(): Out of memory while allocating green buffer. size " + string(sbuf));
     }
 
-    blue = new (nothrow) unsigned char[width * height];
+    blue = new unsigned char[width * height];
     if (blue == 0) {
         char sbuf[128];
         sprintf(sbuf, "%d", width*height);
diff --git a/src/Gnome.cc b/src/Gnome.cc
index 2059839..86f7f75 100644
--- a/src/Gnome.cc
+++ b/src/Gnome.cc
@@ -19,7 +19,7 @@
 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 // DEALINGS IN THE SOFTWARE.
 
-// $Id: Gnome.cc,v 1.31 2003/07/28 15:06:33 rathnor Exp $
+// $Id: Gnome.cc,v 1.32 2003/10/02 16:14:41 rathnor Exp $
 
 #include "Gnome.hh"
 
@@ -147,7 +147,7 @@ void Gnome::updateClientList(BScreen &screen) {
             num += (*win_it)->numClients();
     }
 	
-    Window *wl = new (nothrow) Window[num];
+    Window *wl = new Window[num];
     if (wl == 0) {
         cerr<<"Fatal: Out of memory, can't allocate ("<<num*sizeof (Window)<<") for gnome client list"<<endl;
         return;
diff --git a/src/Screen.cc b/src/Screen.cc
index f2466e3..487f0c0 100644
--- a/src/Screen.cc
+++ b/src/Screen.cc
@@ -22,7 +22,7 @@
 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 // DEALINGS IN THE SOFTWARE.
 
-// $Id: Screen.cc,v 1.235 2003/09/29 12:53:58 rathnor Exp $
+// $Id: Screen.cc,v 1.236 2003/10/02 16:14:41 rathnor Exp $
 
 
 #include "Screen.hh"
@@ -731,7 +731,10 @@ void BScreen::removeWindow(FluxboxWindow *win) {
 
 void BScreen::removeClient(WinClient &client) {
 
-    WinClient *cyc = *cycling_window;
+    WinClient *cyc = 0;
+    if (cycling_window != focused_list.end())
+        cyc = *cycling_window;
+
     WinClient *focused = Fluxbox::instance()->getFocusedWindow();
     focused_list.remove(&client);
     if (cyc == &client) {
diff --git a/src/WinClient.cc b/src/WinClient.cc
index e032304..dadabe3 100644
--- a/src/WinClient.cc
+++ b/src/WinClient.cc
@@ -19,7 +19,7 @@
 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 // DEALINGS IN THE SOFTWARE.
 
-// $Id: WinClient.cc,v 1.28 2003/09/29 14:58:15 rathnor Exp $
+// $Id: WinClient.cc,v 1.29 2003/10/02 16:14:41 rathnor Exp $
 
 #include "WinClient.hh"
 
@@ -61,7 +61,8 @@ WinClient::WinClient(Window win, BScreen &screen, FluxboxWindow *fbwin):FbTk::Fb
                      m_blackbox_hint(0),
                      m_mwm_hint(0),
                      m_focus_mode(F_PASSIVE),
-                     m_diesig(*this), m_screen(screen) {
+                     m_diesig(*this), m_screen(screen), 
+                     m_strut(0) {
     updateBlackboxHints();
     updateMWMHints();
     updateWMHints();
diff --git a/src/Window.cc b/src/Window.cc
index 8609861..47fe00c 100644
--- a/src/Window.cc
+++ b/src/Window.cc
@@ -22,7 +22,7 @@
 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 // DEALINGS IN THE SOFTWARE.
 
-// $Id: Window.cc,v 1.237 2003/09/29 15:00:06 rathnor Exp $
+// $Id: Window.cc,v 1.238 2003/10/02 16:14:41 rathnor Exp $
 
 #include "Window.hh"
 
@@ -1126,6 +1126,11 @@ void FluxboxWindow::moveResize(int new_x, int new_y,
     }
 
     shape();
+
+    if (!moving) {
+        m_last_resize_x = new_x;
+        m_last_resize_y = new_y;
+    }
 }	
 
 // returns whether the focus was "set" to this window
diff --git a/src/Xutil.cc b/src/Xutil.cc
index 5203469..671c52e 100644
--- a/src/Xutil.cc
+++ b/src/Xutil.cc
@@ -20,7 +20,7 @@
 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 // DEALINGS IN THE SOFTWARE.
 
-// $Id: Xutil.cc,v 1.1 2003/06/22 12:23:57 fluxgen Exp $
+// $Id: Xutil.cc,v 1.2 2003/10/02 16:14:41 rathnor Exp $
 
 #include "Xutil.hh"
 
@@ -41,6 +41,7 @@ std::string getWMName(Window window) {
     Display *display = FbTk::App::instance()->display();
 
     XTextProperty text_prop;
+    text_prop.value = 0;
     char **list;
     int num;
     I18n *i18n = I18n::instance();
@@ -62,6 +63,9 @@ std::string getWMName(Window window) {
 					
             } else				
                 name = text_prop.value ? (char *)text_prop.value : "";
+
+            XFree(text_prop.value);
+
         } else { // default name
             name = i18n->getMessage(FBNLS::WindowSet, FBNLS::WindowUnnamed,
                                     "Unnamed");
diff --git a/src/main.cc b/src/main.cc
index c3bc73a..9a91e35 100644
--- a/src/main.cc
+++ b/src/main.cc
@@ -20,7 +20,7 @@
 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 // DEALINGS IN THE SOFTWARE.
 
-// $Id: main.cc,v 1.23 2003/08/28 23:18:37 fluxgen Exp $
+// $Id: main.cc,v 1.24 2003/10/02 16:14:41 rathnor Exp $
 
 #include "fluxbox.hh"
 #include "I18n.hh"
@@ -135,7 +135,7 @@ void showInfo(ostream &ostr) {
 
 int main(int argc, char **argv) {
 	
-    std::string session_display;
+    std::string session_display = "";
     std::string rc_file;
     std::string log_filename;
 
-- 
cgit v0.11.2