/*
 * Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005 Yokogawa Electric Corporation,
 * YDC Corporation, IPA (Information-technology Promotion Agency, Japan).
 * All rights reserved.
 * 
 * Redistribution and use of this software in source and binary forms, with 
 * or without modification, are permitted provided that the following 
 * conditions and disclaimer are agreed and accepted by the user:
 * 
 * 1. Redistributions of source code must retain the above copyright 
 * notice, this list of conditions and the following disclaimer.
 * 
 * 2. Redistributions in binary form must reproduce the above copyright 
 * notice, this list of conditions and the following disclaimer in the 
 * documentation and/or other materials provided with the distribution.
 * 
 * 3. Neither the names of the copyrighters, the name of the project which 
 * is related to this software (hereinafter referred to as "project") nor 
 * the names of the contributors may be used to endorse or promote products 
 * derived from this software without specific prior written permission.
 * 
 * 4. No merchantable use may be permitted without prior written 
 * notification to the copyrighters. However, using this software for the 
 * purpose of testing or evaluating any products including merchantable 
 * products may be permitted without any notification to the copyrighters.
 * 
 * 
 * 
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHTERS, THE PROJECT AND 
 * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING 
 * BUT NOT LIMITED THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 
 * FOR A PARTICULAR PURPOSE, ARE DISCLAIMED.  IN NO EVENT SHALL THE 
 * COPYRIGHTERS, THE PROJECT OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 
 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 
 * CONTRACT,STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF 
 * THE POSSIBILITY OF SUCH DAMAGE.
 *
 * $TAHI: v6eval/lib/Pz/PrItem.cc,v 1.3 2003/12/04 04:59:47 akisada Exp $
 */
#include "PrItem.h"
//#include <stdio.h>

//////////////////////////////////////////////////////////////////////////////
// printer items
//////////////////////////////////////////////////////////////////////////////

//---------------------------------------------------------------------------
#define CLASS "PrItem"

bool PrItem::check_remainLength(const ItP& reqlen,
			const ItP& at,const PvOctets& buf)const{
	uint32_t l= buf.length();
	ItP len(l,0);
	len-=at; len-=reqlen;
	if(len.bytes()>=0)return true;//printable enough length
	//
	fprintf(stderr,
		"err:unable print %s size(%d,%d) ,remain at(%d,%d)/size(%d)\n",
		name_,reqlen.bytes(),reqlen.bits(),at.bytes(),at.bits(),l);
	return false;}

void PrItem::print_tag(uint32_t t)const{
	printf("log:");
	for(uint32_t i=0;i<t;i++) {printf("| ");}
	printf("%-30s",name_);}

bool PrItem::print(uint32_t,ItP&,const PvOctets&)const{return true;}

#undef CLASS

//---------------------------------------------------------------------------
#define CLASS "PrUint"

uint32_t PrUint::get_value(const ItP& at,const PvOctets& buf)const{
	uint32_t value = buf.decodeUint(at,width_);//decode hostorder
	return value;}

bool PrUint::print(uint32_t t,ItP& at,const PvOctets& buf)const{
	if(!check_remainLength(ItP(0,width_),at,buf))return false;
	print_tag(t);
	uint32_t value = get_value(at,buf);
	printf(" = %u\n",value);
	step(at); //forward Itp& at
	return true;}

#undef CLASS

//---------------------------------------------------------------------------
#define CLASS "PrData"

bool PrData::print(uint32_t t,ItP& at,const PvOctets& buf)const{
	if(!check_remainLength(ItP(0),at,buf))return false;
	print_tag(t);
	int32_t length = buf.remainLength(at.bytes());
	PvOctets value(length,(OCTSTR)buf.string(at.bytes()));
	printf(" = "); value.log(t); printf("\n");
	at.addBytes(length); //forward Itp& at
	return true;}

#undef CLASS

//////////////////////////////////////////////////////////////////////////////
// Abstruct printer compound & PrNeedless
//////////////////////////////////////////////////////////////////////////////

//---------------------------------------------------------------------------
#define CLASS "PrCompound"

uint32_t PrCompound::length_for_pr(const ItP&,const PvOctets&)const{
	return 0;}

bool PrCompound::print_head(uint32_t t,uint32_t length)const{
	print_tag(t); printf("(length:%d)",length); printf("\n");
	return true;}
bool PrCompound::print_body(uint32_t,ItP&,const PvOctets&)const{
	return true;}

bool PrCompound::print(uint32_t t,ItP& at,const PvOctets& buf)const{
	uint32_t length = length_for_pr(at,buf);
	if(!check_remainLength(ItP(length),at,buf))return false;
	ItP bodyat;
	PvOctets bodybuf(length,(OCTSTR)buf.string(at.bytes()));
	bool rtn = true;
	if(rtn)rtn = print_head(t,length);
	if(rtn)rtn = print_body(t+1,bodyat,bodybuf);
	if(bodybuf.remainLength(bodyat.bytes())>0){//remain Needless
		print_remain_Needless(t+1,bodyat,bodybuf);}
	at.addBytes(length);
	return rtn;}

bool PrCompound::print_remain_more0(uint32_t t,
		ItP& at,const PvOctets& buf)const{
	bool rtn= true;
	int32_t remain = 0;
	while(rtn && (remain=buf.remainLength(at.bytes()))>0){
		rtn = print(t,at,buf);}
	return rtn;}

bool PrCompound::print_remain_Needless(uint32_t t,ItP& at,const PvOctets& buf){
	const PrNeedless tmp;
	return tmp.print(t,at,buf);}

#undef CLASS



syntax highlighted by Code2HTML, v. 0.9.1