Separated PortQueue and PortMessage into separate files.

Added read methods to PortMessage


git-svn-id: file:///srv/svn/repos/haiku/trunk/current@3594 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
DarkWyrm 2003-06-22 17:17:40 +00:00
parent aa1480c7be
commit 21099b6971
5 changed files with 316 additions and 123 deletions

View File

@ -0,0 +1,67 @@
//------------------------------------------------------------------------------
// Copyright (c) 2001-2002, OpenBeOS
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
//
// File Name: PortMessage.h
// Author: DarkWyrm <bpmagic@columbus.rr.com>
// Description: Package class for port messaging-based data
//
//------------------------------------------------------------------------------
#ifndef PORTMESSAGE_H_
#define PORTMESSAGE_H_
#include <OS.h>
class PortMessage
{
public:
PortMessage(const int32 &code, const void *buffer, const ssize_t &buffersize,
const bool &copy);
PortMessage(void);
~PortMessage(void);
status_t ReadFromPort(const port_id &port, const bigtime_t &timeout=B_INFINITE_TIMEOUT);
status_t WriteToPort(const port_id &port);
void SetCode(const int32 &code);
void SetBuffer(const void *buffer, const ssize_t &size, const bool &copy=false);
int32 Code(void) { return _code; }
void *Buffer(void) { return _buffer; }
ssize_t BufferSize(void) { return _buffersize; }
status_t Read(BPoint *data);
status_t Read(BRect *data);
status_t Read(float *data);
status_t Read(int *data);
status_t Read(long *data);
status_t Read(double *data);
status_t Read(void *data, ssize_t size);
void Rewind(void);
private:
int32 _code;
uint8 *_buffer;
ssize_t _buffersize;
uint8 *_index;
};
#endif

View File

@ -30,29 +30,7 @@
#include <OS.h>
#include <queue>
class PortMessage
{
public:
PortMessage(const int32 &code, const void *buffer, const ssize_t &buffersize,
const bool &copy);
PortMessage(void);
~PortMessage(void);
status_t ReadFromPort(const port_id &port, const bigtime_t &timeout=B_INFINITE_TIMEOUT);
status_t WriteToPort(const port_id &port);
void SetCode(const int32 &code);
void SetBuffer(const void *buffer, const ssize_t &size, const bool &copy=false);
int32 Code(void) { return _code; }
void *Buffer(void) { return _buffer; }
ssize_t BufferSize(void) { return _buffersize; }
private:
int32 _code;
void *_buffer;
ssize_t _buffersize;
};
class PortMessage;
class PortQueue
{

View File

@ -0,0 +1,246 @@
//------------------------------------------------------------------------------
// Copyright (c) 2001-2002, OpenBeOS
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
//
// File Name: PortMessage.cpp
// Author: DarkWyrm <bpmagic@columbus.rr.com>
// Description: Package class for port messaging-based data
//
//------------------------------------------------------------------------------
#include <Point.h>
#include <Rect.h>
#include "PortMessage.h"
PortMessage::PortMessage(const int32 &code, const void *buffer, const ssize_t &buffersize,
const bool &copy)
{
_code=code;
SetBuffer(buffer,buffersize,copy);
}
PortMessage::PortMessage(void)
{
_code=0;
_buffer=NULL;
_buffersize=0;
}
PortMessage::~PortMessage(void)
{
if(_buffersize>0 && _buffer!=NULL)
delete _buffer;
}
status_t PortMessage::ReadFromPort(const port_id &port, const bigtime_t &timeout=B_INFINITE_TIMEOUT)
{
if(_buffersize>0 && _buffer!=NULL)
delete _buffer;
_buffer=NULL;
_buffersize=0;
if(timeout==B_INFINITE_TIMEOUT)
{
_buffersize=port_buffer_size(port);
if(_buffersize==B_BAD_PORT_ID)
return (status_t)_buffersize;
if(_buffersize>0)
_buffer=new uint8[_buffersize];
read_port(port, &_code, _buffer, _buffersize);
}
else
{
_buffersize=port_buffer_size_etc(port,B_TIMEOUT, timeout);
if(_buffersize==B_TIMED_OUT || _buffersize==B_BAD_PORT_ID ||
_buffersize==B_WOULD_BLOCK)
return (status_t)_buffersize;
if(_buffersize>0)
_buffer=new uint8[_buffersize];
read_port(port, &_code, _buffer, _buffersize);
}
return B_OK;
}
status_t PortMessage::WriteToPort(const port_id &port)
{
// Check port validity
port_info pi;
if(get_port_info(port,&pi)!=B_OK)
return B_BAD_VALUE;
write_port(port,_code, _buffer, _buffersize);
if(_buffer && _buffersize>0)
{
delete _buffer;
_buffersize=0;
_buffer=NULL;
}
return B_OK;
}
void PortMessage::SetCode(const int32 &code)
{
_code=code;
}
void PortMessage::SetBuffer(const void *buffer, const ssize_t &size, const bool &copy)
{
if(_buffersize>0 && _buffer!=NULL)
delete _buffer;
_buffer=NULL;
_buffersize=0;
if(!buffer || size<1)
return;
if(copy)
{
_buffersize=size;
_buffer=new uint8[_buffersize];
memcpy(_buffer,buffer,_buffersize);
}
else
{
_buffersize=size;
_buffer=(uint8 *)buffer;
}
}
status_t PortMessage::Read(BPoint *data)
{
if(!data)
return B_BAD_VALUE;
if( !_buffer ||
_buffersize<sizeof(BPoint) ||
((_index+sizeof(BPoint))>(_buffer+_buffersize)) )
return B_NO_MEMORY;
*data=*((BPoint*)_index);
_index+=sizeof(BPoint);
return B_OK;
}
status_t PortMessage::Read(BRect *data)
{
if(!data)
return B_BAD_VALUE;
if( !_buffer ||
_buffersize<sizeof(BRect) ||
((_index+sizeof(BRect))>(_buffer+_buffersize)) )
return B_NO_MEMORY;
*data=*((BRect*)_index);
_index+=sizeof(BRect);
return B_OK;
}
status_t PortMessage::Read(float *data)
{
if(!data)
return B_BAD_VALUE;
if( !_buffer ||
_buffersize<sizeof(float) ||
((_index+sizeof(float))>(_buffer+_buffersize)) )
return B_NO_MEMORY;
*data=*((float*)_index);
_index+=sizeof(float);
return B_OK;
}
status_t PortMessage::Read(int *data)
{
if(!data)
return B_BAD_VALUE;
if( !_buffer ||
_buffersize<sizeof(int) ||
((_index+sizeof(int))>(_buffer+_buffersize)) )
return B_NO_MEMORY;
*data=*((int*)_index);
_index+=sizeof(int);
return B_OK;
}
status_t PortMessage::Read(long *data)
{
if(!data)
return B_BAD_VALUE;
if( !_buffer ||
_buffersize<sizeof(long) ||
((_index+sizeof(long))>(_buffer+_buffersize)) )
return B_NO_MEMORY;
*data=*((long*)_index);
_index+=sizeof(long);
return B_OK;
}
status_t PortMessage::Read(double *data)
{
if(!data)
return B_BAD_VALUE;
if( !_buffer ||
_buffersize<sizeof(double) ||
((_index+sizeof(double))>(_buffer+_buffersize)) )
return B_NO_MEMORY;
*data=*((double*)_index);
_index+=sizeof(double);
return B_OK;
}
status_t PortMessage::Read(void *data, ssize_t size)
{
if(!data || size<1)
return B_BAD_VALUE;
if( !_buffer ||
_buffersize<size ||
((_index+size)>(_buffer+_buffersize)) )
return B_NO_MEMORY;
memcpy(data,_index,size);
_index+=size;
return B_OK;
}
void PortMessage::Rewind(void)
{
_index=_buffer;
}

View File

@ -25,106 +25,7 @@
//
//------------------------------------------------------------------------------
#include "PortQueue.h"
PortMessage::PortMessage(const int32 &code, const void *buffer, const ssize_t &buffersize,
const bool &copy)
{
_code=code;
SetBuffer(buffer,buffersize,copy);
}
PortMessage::PortMessage(void)
{
_code=0;
_buffer=NULL;
_buffersize=0;
}
PortMessage::~PortMessage(void)
{
if(_buffersize>0 && _buffer!=NULL)
delete _buffer;
}
status_t PortMessage::ReadFromPort(const port_id &port, const bigtime_t &timeout=B_INFINITE_TIMEOUT)
{
if(_buffersize>0 && _buffer!=NULL)
delete _buffer;
_buffer=NULL;
_buffersize=0;
if(timeout==B_INFINITE_TIMEOUT)
{
_buffersize=port_buffer_size(port);
if(_buffersize==B_BAD_PORT_ID)
return (status_t)_buffersize;
if(_buffersize>0)
_buffer=new char[_buffersize];
read_port(port, &_code, _buffer, _buffersize);
}
else
{
_buffersize=port_buffer_size_etc(port,B_TIMEOUT, timeout);
if(_buffersize==B_TIMED_OUT || _buffersize==B_BAD_PORT_ID ||
_buffersize==B_WOULD_BLOCK)
return (status_t)_buffersize;
if(_buffersize>0)
_buffer=new char[_buffersize];
read_port(port, &_code, _buffer, _buffersize);
}
return B_OK;
}
status_t PortMessage::WriteToPort(const port_id &port)
{
// Check port validity
port_info pi;
if(get_port_info(port,&pi)!=B_OK)
return B_BAD_VALUE;
write_port(port,_code, _buffer, _buffersize);
if(_buffer && _buffersize>0)
{
delete _buffer;
_buffersize=0;
_buffer=NULL;
}
return B_OK;
}
void PortMessage::SetCode(const int32 &code)
{
_code=code;
}
void PortMessage::SetBuffer(const void *buffer, const ssize_t &size, const bool &copy)
{
if(_buffersize>0 && _buffer!=NULL)
delete _buffer;
_buffer=NULL;
_buffersize=0;
if(!buffer || size<1)
return;
if(copy)
{
_buffersize=size;
_buffer=new char[_buffersize];
memcpy(_buffer,buffer,_buffersize);
}
else
{
_buffersize=size;
_buffer=(void *)buffer;
}
}
#include "PortMessage.h"
PortQueue::PortQueue(const port_id &port)
{

View File

@ -21,6 +21,7 @@ APP_KIT_SOURCE =
MessageUtils.cpp
PropertyInfo.cpp
PortLink.cpp
PortMessage.cpp
PortQueue.cpp
RegistrarDefs.cpp
RegistrarThread.cpp