verboseclcmntracer.cc

00001 /*
00002  * Copyright (c) 2007 Regents of the SIGNET lab, University of Padova.
00003  * All rights reserved.
00004  *
00005  * Redistribution and use in source and binary forms, with or without
00006  * modification, are permitted provided that the following conditions
00007  * are met:
00008  * 1. Redistributions of source code must retain the above copyright
00009  *    notice, this list of conditions and the following disclaimer.
00010  * 2. Redistributions in binary form must reproduce the above copyright
00011  *    notice, this list of conditions and the following disclaimer in the
00012  *    documentation and/or other materials provided with the distribution.
00013  * 3. Neither the name of the University of Padova (SIGNET lab) nor the 
00014  *    names of its contributors may be used to endorse or promote products 
00015  *    derived from this software without specific prior written permission.
00016  *
00017  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
00018  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 
00019  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
00020  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR 
00021  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 
00022  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 
00023  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 
00024  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
00025  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 
00026  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 
00027  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00028  */
00029 
00030 #include "verboseclcmntracer.h"
00031 #include <clsap.h>
00032 
00033 
00034 VerboseClCmnTracer::VerboseClCmnTracer()
00035   : ClMessageTracer(0)
00036 {
00037 }
00038 
00039 void VerboseClCmnTracer::format(ClMessage *m, ConnectorTrace *sap)
00040 {
00041   char* dir;
00042   switch (m->direction())
00043     {
00044     case TONODECORE:
00045       dir = "ToNC  ";
00046       break;
00047     case TOMODULE:
00048       dir = "ToMod ";
00049       break;
00050     case UP:
00051       dir = "Up    ";
00052       break;
00053     case DOWN:
00054       dir = "Down  ";
00055       break;
00056     }
00057         
00058         
00059   writeTrace(sap, " %s %s src: %2d  dst: %2d  uid: %2d  ",
00060              dir,
00061              (m->getDestType() == UNICAST) ? "UNICAST " : "BROADCAST",
00062              m->getSource(),
00063              m->getDest(),
00064              m->uid()
00065              );
00066 }
00067 
00068 
00069 extern "C" int Verboseclcmntracer_Init()
00070 {
00071         /*
00072         Put here all the commands which must be execute when the library is loaded (i.e. TCL script execution)
00073         Remember to ruturn 0 if all is OK, otherwise return 1
00074         */
00075         ConnectorTrace::addCommonTracer(new VerboseClCmnTracer);
00076         return 0;
00077 }
00078 
00079 extern "C" int  Cygverboseclcmntracer_Init()
00080 {
00081   return Verboseclcmntracer_Init();
00082 }
00083 
00084 

Generated on Wed Nov 26 15:47:27 2008 for NS-MIRACLE library by  doxygen 1.5.2