From cf9c58bb0bbf80fb0f192e7c145ff851d4ca9050 Mon Sep 17 00:00:00 2001 From: fluxgen Date: Sat, 19 May 2007 11:18:44 +0000 Subject: added title test for _NET_WM_NAME and WM_NAME memory leaks --- src/tests/Makefile | 3 ++ src/tests/titletest.cc | 120 +++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 123 insertions(+) create mode 100644 src/tests/titletest.cc diff --git a/src/tests/Makefile b/src/tests/Makefile index e39ab0b..74fd97b 100644 --- a/src/tests/Makefile +++ b/src/tests/Makefile @@ -24,6 +24,9 @@ testKeys: testKeys.o testResource: Resourcetest.o Resource.o ${CXX} ${LIBS} ${XLIBS} Resourcetest.o Resource.o -o testResource +testTitle: titletest.cc + ${CXX} ${CXXFLAGS} ${LIBS} ${XLIBS} titletest.cc ../FbTk/libFbTk.a -o testTitle + signaltest: ${COMPILE} ../FbTk/SignalHandler.o signaltest.cc -o signaltest diff --git a/src/tests/titletest.cc b/src/tests/titletest.cc new file mode 100644 index 0000000..a473d06 --- /dev/null +++ b/src/tests/titletest.cc @@ -0,0 +1,120 @@ +// titletest.cc for fbtk test suite +// Copyright (c) 2007 Henrik Kinnunen (fluxgen at fluxbox dot org) +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and associated documentation files (the "Software"), +// to deal in the Software without restriction, including without limitation +// the rights to use, copy, modify, merge, publish, distribute, sublicense, +// and/or sell copies of the Software, and to permit persons to whom the +// Software is furnished to do so, subject to the following conditions: +// +// The above copyright notice and this permission notice shall be included in +// all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER +// DEALINGS IN THE SOFTWARE. + +// $Id$ + +#include "App.hh" +#include "FbWindow.hh" +#include "Font.hh" +#include "EventHandler.hh" +#include "EventManager.hh" +#include "Timer.hh" +#include "SimpleCommand.hh" +#include "stringstream.hh" +#include "GContext.hh" +#include "Color.hh" + +#include +#include + +#include +#include +using namespace std; + +class App:public FbTk::App, public FbTk::EventHandler { +public: + App(const char *displayname): + FbTk::App(displayname), + m_win(DefaultScreen(display()), + 0, 0, 640, 100, KeyPressMask | ExposureMask | + ButtonPressMask | ButtonReleaseMask | ButtonMotionMask), + m_tick( 0 ) { + + m_win.show(); + m_win.setBackgroundColor(FbTk::Color("white", m_win.screenNumber())); + FbTk::EventManager::instance()->add(*this, m_win); + FbTk::RefCount cmd(new FbTk::SimpleCommand + (*this, + &App::updateTitle)); + timeval t; + t.tv_sec = 0; + t.tv_usec = 150000; + m_timer.setTimeout(t); + m_timer.setCommand(cmd); + m_timer.fireOnce(false); + m_timer.start(); + + updateTitle(); + m_win.clear(); + srand( time( 0 ) ); + } + + ~App() { + } + void eventLoop() { + XEvent ev; + while (!done()) { + if (XPending(display())) { + XNextEvent(display(), &ev); + FbTk::EventManager::instance()->handleEvent(ev); + } else { + FbTk::Timer::updateTimers(ConnectionNumber(display())); + } + } + } + + void updateTitle() { + FbTk_ostringstream str; + ++m_tick; + for (int i = 0, n = rand( ) % 10; i < max( 1, n ); ++i) { + str << " Tick #" << m_tick; + } + + m_win.setName( str.str().c_str() ); + // set _NET_WM_NAME + Atom net_wm_name = XInternAtom(display(), "_NET_WM_NAME", False); + Atom utf8_string = XInternAtom(display(), "UTF8_STRING", False); + XChangeProperty(display(), m_win.window(), + net_wm_name, utf8_string, 8, + PropModeReplace, + (unsigned char*)str.str().c_str(), str.str().size() ); + } + + +private: + FbTk::FbWindow m_win; + FbTk::Timer m_timer; + unsigned int m_tick; +}; + +int main(int argc, char **argv) { + string displayname(""); + for (int a=1; a