From 66afb1e517325abe97e6ac62640ccd1c224172aa Mon Sep 17 00:00:00 2001
From: akir <akir>
Date: Thu, 21 Oct 2004 16:46:50 +0000
Subject: moved ThemeItems.hh -> ThemeItems.cc

---
 src/FbTk/ThemeItems.hh | 230 -------------------------------------------------
 1 file changed, 230 deletions(-)
 delete mode 100644 src/FbTk/ThemeItems.hh

diff --git a/src/FbTk/ThemeItems.hh b/src/FbTk/ThemeItems.hh
deleted file mode 100644
index 60efe2f..0000000
--- a/src/FbTk/ThemeItems.hh
+++ /dev/null
@@ -1,230 +0,0 @@
-// ThemeItems.cc for FbTk - Fluxbox ToolKit
-// Copyright (c) 2002 - 2003 Henrik Kinnunen (fluxgen at users.sourceforge.net)
-//
-// 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: ThemeItems.hh,v 1.9 2004/10/21 10:29:49 akir Exp $
-
-/// @file implements common theme items
-
-#ifndef THEMEITEMS_HH
-#define THEMEITEMS_HH
-
-#include "Theme.hh"
-#include "Color.hh"
-#include "Texture.hh"
-#include "Font.hh"
-#include "PixmapWithMask.hh"
-#include "Image.hh"
-#include "StringUtil.hh"
-
-#include <string>
-#ifdef HAVE_CSTDIO
-  #include <cstdio>
-#else
-  #include <stdio.h>
-#endif
-#include <iostream>
-namespace FbTk {
-
-using namespace std;
-
-// create default handlers for Color, Font, Texture, int and string
-template <>
-void FbTk::ThemeItem<std::string>::load(const std::string *name, const std::string *altname) { }
-
-template <>
-void FbTk::ThemeItem<std::string>::setDefaultValue() {
-    *(*this) = "";
-}
-
-template <>
-void FbTk::ThemeItem<std::string>::setFromString(const char *str) {
-    *(*this) = (str ? str : "");
-}
-
-template <>
-void FbTk::ThemeItem<int>::load(const std::string *name, const std::string *altname) { }
-
-template<>
-void FbTk::ThemeItem<int>::setDefaultValue() {
-    *(*this) = 0;
-}
-
-template <>
-void FbTk::ThemeItem<int>::setFromString(const char *str) {
-    if (str == 0) {
-        setDefaultValue();
-        return;
-    }
-
-    if (sscanf(str, "%d", &m_value) < 1)
-        setDefaultValue();
-}
-
-template <>
-void ThemeItem<FbTk::Font>::setDefaultValue() {
-    if (!m_value.load("fixed")) {
-        cerr<<"FbTk::ThemeItem<FbTk::Font>: Warning! Failed to load default value 'fixed'"<<endl;
-    }
-}
-
-template <>
-void ThemeItem<FbTk::Font>::setFromString(const char *str) {
-
-    if (str == 0 || m_value.load(str) == false) {
-        if (FbTk::ThemeManager::instance().verbose()) {
-            cerr<<"FbTk::Theme: Error loading font "<<
-                ((m_value.isAntialias() || m_value.utf8()) ? "(" : "")<<
-
-                (m_value.isAntialias() ? "antialias" : "")<<
-                (m_value.utf8() ? " utf8" : "")<<
-
-                ((m_value.isAntialias() || m_value.utf8()) ? ") " : "")<<
-                "for \""<<name()<<"\" or \""<<altName()<<"\": "<<str<<endl;
-
-            cerr<<"FbTk::Theme: Setting default value"<<endl;
-        }
-        setDefaultValue();
-    }
-
-}
-
-// do nothing
-template <>
-void ThemeItem<FbTk::Font>::load(const std::string *name, const std::string *altname) {
-}
-
-
-template <>
-void ThemeItem<FbTk::Texture>::load(const std::string *o_name, const std::string *o_altname) {
-    const std::string &m_name = (o_name==0)?name():*o_name;
-    const std::string &m_altname = (o_altname==0)?altName():*o_altname;
-
-    string color_name(ThemeManager::instance().
-                      resourceValue(m_name+".color", m_altname+".Color"));
-    string colorto_name(ThemeManager::instance().
-                        resourceValue(m_name+".colorTo", m_altname+".ColorTo"));
-    string pixmap_name(ThemeManager::instance().
-                       resourceValue(m_name+".pixmap", m_altname+".Pixmap"));
-
-
-    // set default value if we failed to load color
-    if (!m_value.color().setFromString(color_name.c_str(),
-                                       m_tm.screenNum()))
-        m_value.color().setFromString("darkgray", m_tm.screenNum());
-
-    if (!m_value.colorTo().setFromString(colorto_name.c_str(),
-                                         m_tm.screenNum()))
-        m_value.colorTo().setFromString("white", m_tm.screenNum());
-
-
-    if ((m_value.type() & FbTk::Texture::SOLID) != 0 && (m_value.type() & FbTk::Texture::FLAT) == 0)
-        m_value.calcHiLoColors(m_tm.screenNum());
-
-    StringUtil::removeFirstWhitespace(pixmap_name);
-    StringUtil::removeTrailingWhitespace(pixmap_name);
-    if (pixmap_name.empty()) {
-        m_value.pixmap() = 0;
-        return;
-    }
-
-    std::auto_ptr<FbTk::PixmapWithMask> pm(FbTk::Image::load(pixmap_name,
-                                                             m_tm.screenNum()));
-    if (pm.get() == 0) {
-        if (FbTk::ThemeManager::instance().verbose()) {
-            cerr<<"Resource("<<m_name+".pixmap"
-                <<"): Failed to load image: "<<pixmap_name<<endl;
-        }
-        m_value.pixmap() = 0;
-    } else
-        m_value.pixmap() = pm->pixmap().release();
-
-}
-
-template <>
-void ThemeItem<FbTk::Texture>::setDefaultValue() {
-    m_value.setType(FbTk::Texture::FLAT | FbTk::Texture::SOLID);
-    load(); // one might forget to add line something:  so we try to load something.*:  too
-}
-
-template <>
-void ThemeItem<FbTk::Texture>::setFromString(const char *str) {
-    m_value.setFromString(str);
-    if (m_value.type() == 0) // failed to set value
-        setDefaultValue();
-}
-
-
-
-// not used
-template <>
-void FbTk::ThemeItem<PixmapWithMask>::load(const std::string *name, const std::string *altname) { }
-
-template <>
-void FbTk::ThemeItem<PixmapWithMask>::
-setDefaultValue() {
-    // create empty pixmap
-    (*this)->pixmap() = 0;
-    (*this)->mask() = 0;
-}
-
-template <>
-void FbTk::ThemeItem<PixmapWithMask>::
-setFromString(const char *str) {
-    if (str == 0)
-        setDefaultValue();
-    else {
-        std::string filename(str);
-
-        StringUtil::removeFirstWhitespace(filename);
-        StringUtil::removeTrailingWhitespace(filename);
-
-        std::auto_ptr<FbTk::PixmapWithMask> pm(Image::load(filename, m_tm.screenNum()));
-        if (pm.get() == 0)
-            setDefaultValue();
-        else {
-            (*this)->pixmap() = pm->pixmap().release();
-            (*this)->mask() = pm->mask().release();
-        }
-    }
-}
-
-
-template <>
-void ThemeItem<FbTk::Color>::setDefaultValue() {
-    m_value.setFromString("white", m_tm.screenNum());
-}
-
-template <>
-void ThemeItem<FbTk::Color>::setFromString(const char *str) {
-    if (!m_value.setFromString(str, m_tm.screenNum())) {
-        if (FbTk::ThemeManager::instance().verbose())
-            cerr<<"FbTk::Theme: Error loading color value for \""<<name()<<"\" or \""<<altName()<<"\"."<<endl;
-        setDefaultValue();
-    }
-}
-
-// does nothing
-template <>
-void ThemeItem<FbTk::Color>::load(const std::string *name, const std::string *altname) { }
-
-} // end namespace FbTk
-
-#endif // THEMEITEMS_HH
-- 
cgit v0.11.2