fixed: gcc8 compile issues
[opensg.git] / Source / Contrib / ComplexSceneManager / Helper / OSGCSMLogger.cpp
blob6e3bfd373b00dc35d1dddac88159f488d426dccd
1 /*---------------------------------------------------------------------------*\
2 * OpenSG *
3 * *
4 * *
5 * Copyright (C) 2000-2006 by the OpenSG Forum *
6 * *
7 * www.opensg.org *
8 * *
9 * contact: dirk@opensg.org, gerrit.voss@vossg.org, jbehr@zgdv.de *
10 * *
11 \*---------------------------------------------------------------------------*/
12 /*---------------------------------------------------------------------------*\
13 * License *
14 * *
15 * This library is free software; you can redistribute it and/or modify it *
16 * under the terms of the GNU Library General Public License as published *
17 * by the Free Software Foundation, version 2. *
18 * *
19 * This library is distributed in the hope that it will be useful, but *
20 * WITHOUT ANY WARRANTY; without even the implied warranty of *
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
22 * Library General Public License for more details. *
23 * *
24 * You should have received a copy of the GNU Library General Public *
25 * License along with this library; if not, write to the Free Software *
26 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. *
27 * *
28 \*---------------------------------------------------------------------------*/
29 /*---------------------------------------------------------------------------*\
30 * Changes *
31 * *
32 * *
33 * *
34 * *
35 * *
36 * *
37 \*---------------------------------------------------------------------------*/
39 //---------------------------------------------------------------------------
40 // Includes
41 //---------------------------------------------------------------------------
43 #include <cstdlib>
44 #include <cstdio>
46 #include "OSGConfig.h"
48 #include "OSGCSMLogger.h"
49 #include "OSGNameAttachment.h"
51 OSG_BEGIN_NAMESPACE
53 // Documentation for this class is emitted in the
54 // OSGCSMLoggerBase.cpp file.
55 // To modify it, please change the .fcd file (OSGCSMLogger.fcd) and
56 // regenerate the base file.
58 /***************************************************************************\
59 * Class variables *
60 \***************************************************************************/
62 /***************************************************************************\
63 * Class methods *
64 \***************************************************************************/
66 void CSMLogger::initMethod(InitPhase ePhase)
68 Inherited::initMethod(ePhase);
70 if(ePhase == TypeObject::SystemPost)
75 /***************************************************************************\
76 * Instance methods *
77 \***************************************************************************/
79 /*-------------------------------------------------------------------------*\
80 - private -
81 \*-------------------------------------------------------------------------*/
83 /*----------------------- constructors & destructors ----------------------*/
85 CSMLogger::CSMLogger(void) :
86 Inherited()
90 CSMLogger::CSMLogger(const CSMLogger &source) :
91 Inherited(source)
95 CSMLogger::~CSMLogger(void)
99 /*----------------------------- class specific ----------------------------*/
101 void CSMLogger::changed(ConstFieldMaskArg whichField,
102 UInt32 origin,
103 BitVector details)
105 Inherited::changed(whichField, origin, details);
107 if(0x0000 != (whichField & (ContainersFieldMask | FieldsFieldMask)))
112 void CSMLogger::dump( UInt32 ,
113 const BitVector ) const
115 SLOG << "Dump CSMLogger NI" << std::endl;
118 void CSMLogger::postOSGLoading(FileContextAttachment * const pContext)
120 MFContainersType::const_iterator cIt = _mfContainers.begin();
121 MFContainersType::const_iterator cEnd = _mfContainers.end ();
123 MFString ::const_iterator fIt = _mfFields.begin ();
124 MFString ::const_iterator fEnd = _mfFields.end ();
126 for(; cIt != cEnd && fIt != fEnd; ++cIt, ++fIt)
128 fprintf(stderr, "log : %p (%s).%s\n",
129 static_cast<void *>(*cIt),
130 (*cIt) != NULL ? (*cIt)->getType().getCName() : "---",
131 fIt->c_str() );
133 const FieldDescriptionBase *pDesc =
134 (*cIt)->getFieldDescription(fIt->c_str());
136 if(pDesc != NULL)
138 ChangedFunctor logCB =
139 boost::bind(&CSMLogger::doLog,
140 this,
141 _1,
142 _2,
144 pDesc->getFieldId(),
145 pDesc->getFieldMask());
147 (*cIt)->addChangedFunctor(logCB, "");
152 void CSMLogger::doLog(FieldContainer *pContainer,
153 BitVector bvFlags ,
154 UInt32 origin ,
155 UInt32 uiRefFieldId,
156 BitVector uiRefFieldMask)
158 if(0x0000 != (bvFlags & uiRefFieldMask) && _sfEnabled.getValue() == true)
160 GetFieldHandlePtr pFH = pContainer->getField(uiRefFieldId);
162 if(pFH && pFH->isValid() == true)
164 static CErrOutStream cerrStream;
166 const FieldDescriptionBase *pDesc =
167 pContainer->getFieldDescription(uiRefFieldId);
169 AttachmentContainer *pAtt =
170 dynamic_cast<AttachmentContainer *>(pContainer);
172 if(pAtt != NULL)
174 const Char8 *szName = getName(pAtt);
176 if(szName != NULL)
178 cerrStream << "[" << szName << "]:";
182 cerrStream << pContainer->getType().getName()
183 << "."
184 << pDesc->getName()
185 << " : ";
187 pFH->pushValueToStream(cerrStream);
189 cerrStream << std::endl;
194 OSG_END_NAMESPACE