summaryrefslogtreecommitdiffstats
path: root/kpovmodeler/pmsplinememento.cpp
blob: 99568e7427104ca8773b04c58ed269772238ec7b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/*
**************************************************************************
                                 description
                             --------------------
    copyright            : (C) 2002 by Andreas Zehender
    email                : zehender@kde.org
**************************************************************************

**************************************************************************
*                                                                        *
*  This program is free software; you can redistribute it and/or modify  *
*  it under the terms of the GNU General Public License as published by  *
*  the Free Software Foundation; either version 2 of the License, or     *
*  (at your option) any later version.                                   *
*                                                                        *
**************************************************************************/

#include "pmsplinememento.h"
#include "pmdebug.h"

PMSplineMemento::PMSplineMemento( PMObject* originator )
      : PMMemento( originator )
{
   m_bSplinePointsSaved = false;
}

PMSplineMemento::~PMSplineMemento( )
{
}

void PMSplineMemento::setSplinePoints( const TQValueList<PMVector>& v )
{
   if( !m_bSplinePointsSaved )
   {
      // Direct assignment does not work with TQt 2.3.x
      // The list will be changed later in a graphical
      // change because TQValueList::detach( ) is called
      // too late!
      // Copy the list by hand.

      TQValueList<PMVector>::ConstIterator it = v.begin( );
      for( ; it != v.end( ); ++it )
         m_splinePoints.append( *it );

      m_bSplinePointsSaved = true;
      addChange( PMCData );
   }
}

TQValueList<PMVector> PMSplineMemento::splinePoints( ) const
{
   if( !m_bSplinePointsSaved )
      kdError( PMArea ) << "Spline points not saved in PMSplineMemento::splinePoints\n";
   
   return m_splinePoints;
}