/*! \file duckmatic.h
** \brief Template Header
**
-** $Id: duckmatic.h,v 1.1.1.1 2005/01/07 03:34:36 darco Exp $
+** $Id$
**
** \legal
** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
+** Copyright (c) 2007 Chris Moore
**
** This package is free software; you can redistribute it and/or
** modify it under the terms of the GNU General Public License as
/* === M A C R O S ========================================================= */
-#define HASH_MAP_H <ext/hash_map>
-
#ifdef HASH_MAP_H
#include HASH_MAP_H
#ifndef __STRING_HASH__
#define __STRING_HASH__
class StringHash
{
- __gnu_cxx::hash<const char*> hasher_;
+ HASH_MAP_NAMESPACE::hash<const char*> hasher_;
public:
size_t operator()(const synfig::String& x)const
{
public:
#ifdef HASH_MAP_H
-typedef __gnu_cxx::hash_map<synfig::GUID,etl::smart_ptr<synfig::Point>,synfig::GUIDHash> DuckDataMap;
+typedef HASH_MAP_CLASS<synfig::GUID,etl::smart_ptr<synfig::Point>,synfig::GUIDHash> DuckDataMap;
#else
typedef std::map<synfig::GUID,etl::smart_ptr<synfig::Point> > DuckDataMap;
#endif
std::list<etl::handle<Stroke> > stroke_list_;
- std::list<etl::handle<Stroke> > persistant_stroke_list_;
+ std::list<etl::handle<Stroke> > persistent_stroke_list_;
synfig::GUIDSet selected_ducks;
/*! \see grid_snap, show_grid */
synfig::Vector grid_size;
- bool show_persistant_strokes;
+ bool show_persistent_strokes;
bool axis_lock;
synfig::Point snap_point_to_grid(const synfig::Point& x, float radius=0.1)const;
- bool get_show_persistant_strokes()const { return show_persistant_strokes; }
- void set_show_persistant_strokes(bool x);
+ bool get_show_persistent_strokes()const { return show_persistent_strokes; }
+ void set_show_persistent_strokes(bool x);
//! Sets the size of the grid
void set_grid_size(const synfig::Vector &s);
const std::list<etl::handle<Stroke> >& stroke_list()const { return stroke_list_; }
- const std::list<etl::handle<Stroke> >& persistant_stroke_list()const { return persistant_stroke_list_; }
+ const std::list<etl::handle<Stroke> >& persistent_stroke_list()const { return persistent_stroke_list_; }
- std::list<etl::handle<Stroke> >& persistant_stroke_list() { return persistant_stroke_list_; }
+ std::list<etl::handle<Stroke> >& persistent_stroke_list() { return persistent_stroke_list_; }
//! \todo We should modify this to support multiple selections
etl::handle<Duck> get_selected_duck()const;
void select_duck(const etl::handle<Duck> &duck);
+ void toggle_select_ducks_in_box(const synfig::Vector& tl,const synfig::Vector& br);
+
void select_ducks_in_box(const synfig::Vector& tl,const synfig::Vector& br);
void unselect_duck(const etl::handle<Duck> &duck);
void add_stroke(etl::smart_ptr<std::list<synfig::Point> > stroke_point_list, const synfig::Color& color=synfig::Color(0,0,0));
- void add_persistant_stroke(etl::smart_ptr<std::list<synfig::Point> > stroke_point_list, const synfig::Color& color=synfig::Color(0,0,0));
+ void add_persistent_stroke(etl::smart_ptr<std::list<synfig::Point> > stroke_point_list, const synfig::Color& color=synfig::Color(0,0,0));
- void clear_persistant_strokes();
+ void clear_persistent_strokes();
void add_duck(const etl::handle<Duck> &duck);
bool is_valid()const { return (bool)stroke_data; }
sigc::signal<void,float> &signal_user_click(int i=0) { assert(i>=0); assert(i<5); return signal_user_click_[i]; }
-}; // END of struct Duckmatic::Bezier
+}; // END of struct Duckmatic::Stroke
}; // END of namespace studio