1 /*---------------------------------------------------------------------------*\
5 * Copyright (C) 2000-2006 by the OpenSG Forum *
9 * contact: dirk@opensg.org, gerrit.voss@vossg.org, jbehr@zgdv.de *
11 \*---------------------------------------------------------------------------*/
12 /*---------------------------------------------------------------------------*\
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. *
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. *
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. *
28 \*---------------------------------------------------------------------------*/
29 /*---------------------------------------------------------------------------*\
37 \*---------------------------------------------------------------------------*/
39 //---------------------------------------------------------------------------
41 //---------------------------------------------------------------------------
46 #include "OSGConfig.h"
48 #include "OSGCSMLogger.h"
49 #include "OSGNameAttachment.h"
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 /***************************************************************************\
60 \***************************************************************************/
62 /***************************************************************************\
64 \***************************************************************************/
66 void CSMLogger::initMethod(InitPhase ePhase
)
68 Inherited::initMethod(ePhase
);
70 if(ePhase
== TypeObject::SystemPost
)
75 /***************************************************************************\
77 \***************************************************************************/
79 /*-------------------------------------------------------------------------*\
81 \*-------------------------------------------------------------------------*/
83 /*----------------------- constructors & destructors ----------------------*/
85 CSMLogger::CSMLogger(void) :
90 CSMLogger::CSMLogger(const CSMLogger
&source
) :
95 CSMLogger::~CSMLogger(void)
99 /*----------------------------- class specific ----------------------------*/
101 void CSMLogger::changed(ConstFieldMaskArg whichField
,
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() : "---",
133 const FieldDescriptionBase
*pDesc
=
134 (*cIt
)->getFieldDescription(fIt
->c_str());
138 ChangedFunctor logCB
=
139 boost::bind(&CSMLogger::doLog
,
145 pDesc
->getFieldMask());
147 (*cIt
)->addChangedFunctor(logCB
, "");
152 void CSMLogger::doLog(FieldContainer
*pContainer
,
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
);
174 const Char8
*szName
= getName(pAtt
);
178 cerrStream
<< "[" << szName
<< "]:";
182 cerrStream
<< pContainer
->getType().getName()
187 pFH
->pushValueToStream(cerrStream
);
189 cerrStream
<< std::endl
;