summaryrefslogtreecommitdiffstats
path: root/src/sp-paint-server.cpp
diff options
context:
space:
mode:
authorJon A. Cruz <jon@joncruz.org>2010-07-09 05:02:03 +0000
committerJon A. Cruz <jon@joncruz.org>2010-07-09 05:02:03 +0000
commit50f9aa34d9c9563df9002d8a70ae37a747c8f422 (patch)
treec217dfbf84f501624398df22b279403ec610a508 /src/sp-paint-server.cpp
parent7th update, almost there (diff)
downloadinkscape-50f9aa34d9c9563df9002d8a70ae37a747c8f422.tar.gz
inkscape-50f9aa34d9c9563df9002d8a70ae37a747c8f422.zip
Cleanup of gradient swatch property and collection policy.
(bzr r9602)
Diffstat (limited to 'src/sp-paint-server.cpp')
-rw-r--r--src/sp-paint-server.cpp20
1 files changed, 6 insertions, 14 deletions
diff --git a/src/sp-paint-server.cpp b/src/sp-paint-server.cpp
index 5858f9a0e..4b5366a46 100644
--- a/src/sp-paint-server.cpp
+++ b/src/sp-paint-server.cpp
@@ -21,7 +21,6 @@
#include "xml/node.h"
static void sp_paint_server_class_init(SPPaintServerClass *psc);
-static void sp_paint_server_init(SPPaintServer *ps);
static void sp_paint_server_release(SPObject *object);
@@ -30,7 +29,7 @@ static void sp_painter_stale_fill(SPPainter *painter, NRPixBlock *pb);
static SPObjectClass *parent_class;
static GSList *stale_painters = NULL;
-GType sp_paint_server_get_type (void)
+GType SPPaintServer::getType(void)
{
static GType type = 0;
if (!type) {
@@ -43,7 +42,7 @@ GType sp_paint_server_get_type (void)
NULL, /* class_data */
sizeof(SPPaintServer),
16, /* n_preallocs */
- (GInstanceInitFunc) sp_paint_server_init,
+ (GInstanceInitFunc) SPPaintServer::init,
NULL, /* value_table */
};
type = g_type_register_static(SP_TYPE_OBJECT, "SPPaintServer", &info, (GTypeFlags) 0);
@@ -58,9 +57,10 @@ static void sp_paint_server_class_init(SPPaintServerClass *psc)
parent_class = (SPObjectClass *) g_type_class_ref(SP_TYPE_OBJECT);
}
-static void sp_paint_server_init(SPPaintServer *ps)
+void SPPaintServer::init(SPPaintServer *ps)
{
ps->painters = NULL;
+ ps->swatch = false;
}
static void sp_paint_server_release(SPObject *object)
@@ -157,24 +157,16 @@ static void sp_painter_stale_fill(SPPainter */*painter*/, NRPixBlock *pb)
bool SPPaintServer::isSwatch() const
{
- bool swatch = false;
- if (SP_IS_GRADIENT(this)) {
- SPGradient *grad = SP_GRADIENT(this);
- swatch = grad->hasStops() && repr->attribute("osb:paint");
- }
return swatch;
}
bool SPPaintServer::isSolid() const
{
bool solid = false;
- if (SP_IS_GRADIENT(this)) {
+ if (swatch && SP_IS_GRADIENT(this)) {
SPGradient *grad = SP_GRADIENT(this);
if ( grad->hasStops() && (grad->getStopCount() == 0) ) {
- gchar const * attr = repr->attribute("osb:paint");
- if (attr && !strcmp(attr, "solid")) {
- solid = true;
- }
+ solid = true;
}
}
return solid;