From baa6a4a42ffead3ed8db11fd84d69706e98b2df7 Mon Sep 17 00:00:00 2001 From: fluxgen Date: Fri, 2 Jan 2004 21:59:52 +0000 Subject: fixed checking in ThemeItem int --- src/FbTk/ThemeItems.hh | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/src/FbTk/ThemeItems.hh b/src/FbTk/ThemeItems.hh index d652c52..4d4d081 100644 --- a/src/FbTk/ThemeItems.hh +++ b/src/FbTk/ThemeItems.hh @@ -19,7 +19,7 @@ // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER // DEALINGS IN THE SOFTWARE. -// $Id: ThemeItems.hh,v 1.3 2003/11/28 23:02:05 fluxgen Exp $ +// $Id: ThemeItems.hh,v 1.4 2004/01/02 21:59:52 fluxgen Exp $ /// @file implements common theme items @@ -64,9 +64,13 @@ void FbTk::ThemeItem::setDefaultValue() { template <> void FbTk::ThemeItem::setFromString(const char *str) { - if (str == 0) + if (str == 0) { + setDefaultValue(); return; - sscanf(str, "%d", &m_value); + } + + if (sscanf(str, "%d", &m_value) < 1) + setDefaultValue(); } template <> @@ -124,16 +128,21 @@ void ThemeItem::load() { StringUtil::removeFirstWhitespace(pixmap_name); StringUtil::removeTrailingWhitespace(pixmap_name); - + if (pixmap_name.empty()) { + m_value.pixmap() = 0; + return; + } std::auto_ptr pm(Image::load(pixmap_name, m_tm.screenNum())); if (pm.get() == 0) { - if (FbTk::ThemeManager::instance().verbose()) + if (FbTk::ThemeManager::instance().verbose()) { cerr<<"Resource("<pixmap().release(); + } template <> -- cgit v0.11.2