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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
|
/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: paralleltimecontainer.cxx,v $
*
* $Revision: 1.5 $
*
* last change: $Author: obo $ $Date: 2005-10-11 08:44:01 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
************************************************************************/
#include <canvas/debug.hxx>
#include <canvas/verbosetrace.hxx>
#include <paralleltimecontainer.hxx>
#include <tools.hxx>
#include <nodetools.hxx>
#ifndef BOOST_BIND_HPP_INCLUDED
#include <boost/bind.hpp>
#endif
#ifndef BOOST_MEM_FN_HPP_INCLUDED
#include <boost/mem_fn.hpp>
#endif
#include <algorithm>
using namespace ::com::sun::star;
namespace presentation
{
namespace internal
{
ParallelTimeContainer::ParallelTimeContainer( const uno::Reference< animations::XAnimationNode >& xNode,
const BaseContainerNodeSharedPtr& rParent,
const NodeContext& rContext ) :
BaseContainerNode( xNode, rParent, rContext )
{
}
bool ParallelTimeContainer::activate()
{
if( getState() == ACTIVE )
return true; // avoid duplicate event generation
if( !BaseContainerNode::activate() )
return false;
// resolve all children, only return true, if _all_
// children were resolvable.
return ::std::count_if( getChildren().begin(),
getChildren().end(),
::boost::mem_fn(&AnimationNode::resolve) )
== static_cast<VectorOfNodes::difference_type>(getChildren().size());
}
void ParallelTimeContainer::notifyDeactivating( const AnimationNodeSharedPtr& rNotifier )
{
// early exit on invalid nodes
if( getState() == INVALID )
return;
// if we don't have indefinite duration, ignore this message
if( !isDurationInfinite() )
return;
// find given notifier in child vector
const VectorOfNodes::const_iterator aBegin( getChildren().begin() );
const VectorOfNodes::const_iterator aEnd( getChildren().end() );
VectorOfNodes::const_iterator aIter;
if( (aIter=::std::find( aBegin,
aEnd,
rNotifier )) == aEnd )
{
OSL_ENSURE( false,
"ParallelTimeContainer::notifyDeactivating(): unknown notifier" );
return;
}
const ::std::size_t nIndex( ::std::distance(aBegin, aIter) );
// prevent duplicate increments (for children that notify
// more than once)
if( getFinishedStates()[ nIndex ] == false )
++getFinishedCount();
getFinishedStates()[ nIndex ] = true;
// all children finished?
if( getFinishedCount() == getChildren().size() )
{
// yep. deactivate this node, too
deactivate();
}
}
#if defined(VERBOSE) && defined(DBG_UTIL)
const char* ParallelTimeContainer::getDescription() const
{
return "ParallelTimeContainer";
}
#endif
}
}
|