/*
 * 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/McUDP.cc,v 1.5 2002/12/02 12:31:30 akisada Exp $
 */
#include "McUDP.h"
#include "MmHeader.h"
#include "MmChecksum.h"
#include "ItPosition.h"
#include "WObject.h"
#include "RObject.h"
#include "PControl.h"
#include "PvObject.h"
#include "PvOctets.h"

//////////////////////////////////////////////////////////////////////////////
#define SUPER	McUpper
McUpp_UDP* McUpp_UDP::instance_=0;
McTopHdr_UDP* McUpp_UDP::tophdr_=0;
McUpp_UDP::McUpp_UDP(CSTR key):SUPER(key) {instance_=this;}
McUpp_UDP::~McUpp_UDP(){if(instance_==this)instance_=0;}

// COMPOSE/REVERSE
uint32_t McUpp_UDP::length_for_reverse(
		RControl& c,ItPosition& at,OCTBUF& buf) const{
	uint32_t length = tophdr_->Layerlength_for_reverse(c,at,buf);
	return length;}

RObject* McUpp_UDP::reverse(RControl& c,
		RObject* r_parent,ItPosition& at,OCTBUF& buf)const{
	RObject* r_self = SUPER::reverse(c,r_parent,at,buf);
	if(!c.error()){
		Con_IPinfo* info = c.IPinfo();
		if(info)info->reverse_postUppChecksum(c,r_self);}
	return r_self;}
bool McUpp_UDP::generate(WControl& c,WObject* w_self,OCTBUF& buf) const {
	bool rtn = SUPER::generate(c,w_self,buf);
	if(!c.error()){
		Con_IPinfo* info = c.IPinfo();
		if(info)info->generate_postUppChecksum(c,buf,w_self);}
	return rtn;}
#undef SUPER

//----------------------------------------------------------------------------
#define SUPER	McHeader
McTopHdr_UDP::McTopHdr_UDP(CSTR key):SUPER(key), SrcPort_meta_(0), DstPort_meta_(0), Layerlength_meta_(0) {
	PrtObjs_ = new PrtObjs();
}

McTopHdr_UDP::~McTopHdr_UDP(){}

// COMPOSE/REVERSE
uint32_t McTopHdr_UDP::Layerlength_for_reverse(
			RControl& c,ItPosition& at,OCTBUF& buf) const{
	if(!Layerlength_meta_)return SUPER::Layerlength_for_reverse(c,at,buf);
	uint32_t valulen	= Layerlength_meta_->value(at,buf);
	uint32_t Layerlength	= valulen;
	return Layerlength;}

bool McTopHdr_UDP::HCGENE(Length)(
			WControl& cntr,WObject* wmem,OCTBUF& buf) const{
	WObject* wc		= wmem->parent();	//TopHdr_UDP
	WObject* upper		= wc->parent();		//Upper_UDP
	uint32_t reallen	= upper->size().bytes();
	uint32_t valulen	= reallen;
	PvNumber def(valulen);
	return def.generate(cntr,wmem,buf);}

RObject *McTopHdr_UDP::reverse(RControl &c, RObject *r_parent, ItPosition &at, OCTBUF &buf) const {
	RObject *r_self = SUPER::reverse(c, r_parent, at, buf);

	if(r_self) {
		upperProto_set_Object(r_self);
	}

	return(r_self);
}

void McTopHdr_UDP::upperProto_set_Object(RObject *r_self) const {
	if((!r_self) || (!SrcPort_meta_) || (!DstPort_meta_) || (!PrtObjs_)) {
		return;
	}

        RObject *src = (RObject *)r_self->corresponding(SrcPort_meta_);
        RObject *dst = (RObject *)r_self->corresponding(DstPort_meta_);

	if(src){
		set_srcobj(src);
	}

	if(dst) {
		set_dstobj(dst);
	}

	return;
}

bool McTopHdr_UDP::HCGENE(SourcePort)(WControl &cntr, WObject *wmem, OCTBUF &buf) const {
	int32_t val = get_next_protocolPort(wmem);

	if(val == -1) {
		return(false);
	}

	PvNumber def(val);
	return(def.generate(cntr, wmem, buf));
}

PObject *McTopHdr_UDP::HCEVAL(SourcePort)(WObject *wmem) const {
	int32_t val = get_next_protocolPort(wmem);

	return(new PvNumber(val));
}

bool McTopHdr_UDP::HCGENE(DestinationPort)(WControl &cntr, WObject *wmem, OCTBUF &buf) const {
	int32_t val = get_next_protocolPort(wmem);

	if(val == -1) {
		return(false);
	}

	PvNumber def(val);
	return(def.generate(cntr, wmem, buf));
}

PObject *McTopHdr_UDP::HCEVAL(DestinationPort)(WObject *wmem) const {
	int32_t val = get_next_protocolPort(wmem);

	return(new PvNumber(val));
}
#undef SUPER


syntax highlighted by Code2HTML, v. 0.9.1