本文整理汇总了C++中Packet函数的典型用法代码示例。如果您正苦于以下问题:C++ Packet函数的具体用法?C++ Packet怎么用?C++ Packet使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了Packet函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: Packet
void QuestsPacket::questFinish(Player* player, vector <Player*> players,short questid, int npcid, short nextquest, __int64 time){
Packet packet = Packet();
packet.addHeader(0x32);
packet.addByte(1);
packet.addShort(questid);
packet.addByte(2);
packet.addInt64(time);
packet.packetSend(player);
packet = Packet();
packet.addHeader(0x6D);
packet.addByte(6);
packet.addShort(questid);
packet.addInt(npcid);
packet.addShort(nextquest);
packet.packetSend(player);
packet = Packet();
packet.addHeader(0x68);
packet.addByte(9);
packet.packetSend(player);
packet = Packet();
packet.addHeader(0x86);
packet.addInt(player->getPlayerid());
packet.addByte(9);
packet.sendTo(player, players, 0);
}
示例2: firm_str
bool YModem::SendFile(const std::string &path, YModem::SPort &out) {
if (path.size() == 0 ||
not out.is_open())
return false;
std::fstream firm_str(path.c_str());
if (not firm_str.is_open())
return false;
firm_str.seekg(0, firm_str.end);
const size_t kFileSize = firm_str.tellg();
firm_str.seekg(0, firm_str.beg);
// ожидание запроса
WaitForResponse(out, Packet::kRequest);
Packet::Sequence seq(&out);
// инициализация соединения
char buf[24];
snprintf(buf, 24, "%u", (unsigned)kFileSize);
const std::string kMsgs[] = {path, buf};
SendInitialPkt(seq, kMsgs, 2);
if (not IsResponse(out, Packet::kRequest)) {
firm_str.close();
return false;
}
// передача файла
Array frame(NewFrame());
size_t was_send = 0;
size_t last_percent = 0;
do {
firm_str.sync();
firm_str.read((char*)frame.get(), kFrameSize);
const size_t kWasRead = firm_str.gcount();
if (kWasRead != kFrameSize) {
memset(frame.get() + kWasRead, 0, kFrameSize - kWasRead);
}
seq.Send(Packet(Packet::kSTX, frame.get(), kFrameSize));
was_send += kWasRead;
if (not IsResponse(out, Packet::kACK)) {
std::cout << "\t ! Ошибка передачи данных" << std::endl;
break;
}
const size_t kPercent = was_send * 100 / kFileSize;
if (kPercent > last_percent) {
ShowPercentage("\t * Прогресс", kPercent);
last_percent = kPercent;
}
} while (was_send < kFileSize);
std::cout << std::endl;
seq.Send(Packet(Packet::kEOT));
IsResponse(out, Packet::kACK);
seq.Send(Packet(Packet::kEOT));
IsResponse(out, Packet::kACK);
IsResponse(out, Packet::kRequest);
SendClosingPkt(seq);
firm_str.close();
return true;
}
示例3: pcap_open_offline
/**
* @todo Add command-line parameters for IPv4 network address and mask so we
* can remove broadcast and multicast hosts from the result
*/
void IPForensics::load_hosts(std::string filename) {
// open the filename
char error[PCAP_ERRBUF_SIZE] {};
pcap_t* pcap = pcap_open_offline(filename.c_str(), error);
if (pcap == NULL) {
throw std::runtime_error(error);
}
// exit if the data link is not Ethernet
if (pcap_datalink(pcap) != DLT_EN10MB) {
pcap_close(pcap);
throw std::runtime_error("Link-layer type not IEEE 802.3 Ethernet");
}
// read the packets from the file
const unsigned char * packet = NULL;
struct pcap_pkthdr header;
// if packet_count_ is set, read specified number of packets only
if (packet_count_ > 0) {
for (int i = 0; i < packet_count_; ++i) {
packet = pcap_next(pcap, &header);
if (packet != NULL) {
packets_.push_back(Packet(packet));
}
}
} else {
// if packet_count_ is not set, read all packets
packet = pcap_next(pcap, &header);
while (packet != NULL) {
packets_.push_back(Packet(packet));
packet = pcap_next(pcap, &header);
}
}
// close the packet capture
pcap_close(pcap);
// extract hosts from packets
for (Packet p : packets_) {
// add the source host
std::set<Host>::iterator it = hosts_.find(static_cast<Host>(p.mac_src()));
if (it == hosts_.end()) {
add_host(p.mac_src(), p.ipv4_src(), p.ipv6_src());
} else {
update_host(it, p.ipv4_src(), p.ipv6_src());
}
// add the destination host
it = hosts_.find(static_cast<Host>(p.mac_dst()));
if (it == hosts_.end()) {
add_host(p.mac_dst(), p.ipv4_dst(), p.ipv6_dst());
} else {
update_host(it, p.ipv4_dst(), p.ipv6_dst());
}
}
// remove meaningless hosts
clean_hosts(nullptr, nullptr);
}
示例4: qDebug
void AVDemuxThread::seekInternal(qint64 pos)
{
if (audio_thread) {
audio_thread->setDemuxEnded(false);
audio_thread->packetQueue()->clear();
}
if (video_thread) {
video_thread->setDemuxEnded(false);
video_thread->packetQueue()->clear();
}
qDebug("seek to %lld ms (%f%%)", pos, double(pos)/double(demuxer->duration())*100.0);
demuxer->seek(pos);
// TODO: why queue may not empty?
if (audio_thread) {
audio_thread->packetQueue()->clear();
audio_thread->packetQueue()->put(Packet());
}
if (video_thread) {
video_thread->packetQueue()->clear();
// TODO: the first frame (key frame) will not be decoded correctly if flush() is called.
video_thread->packetQueue()->put(Packet());
}
//if (subtitle_thread) {
// subtitle_thread->packetQueue()->clear();
// subtitle_thread->packetQueue()->put(Packet());
//}
#if RESUME_ONCE_ON_SEEK
class PauseTask : public QRunnable {
public:
PauseTask(AVDemuxThread *dt, bool p)
: pause(p)
, demux_thread(dt)
{}
void run() {
if (pause && !demux_thread->isPaused()) // what if user resume?
demux_thread->pauseInternal(true);
if (!pause && demux_thread->isPaused())
demux_thread->pauseInternal(false);
}
private:
bool pause;
AVDemuxThread *demux_thread;
};
pause_tasks.clear();
if (isPaused()) {
pause_tasks.enqueue(new PauseTask(this, false));
pause_tasks.enqueue(new PauseTask(this, true));
} else {
pause_tasks.enqueue(new PauseTask(this, true));
}
#endif
}
示例5: main
int main( int argc, char **argv )
{
co::init( argc, argv );
{
Reader readers[ N_READER ];
for( size_t i = 0; i < N_READER; ++i )
readers[i].start();
co::CommandCache cache;
co::LocalNodePtr node = new co::LocalNode;
size_t nOps = 0;
co::base::Clock clock;
while( clock.getTime64() < RUNTIME )
{
co::Command& command = cache.alloc( node, node, sizeof( Packet ));
Packet* packet = command.get< Packet >();
*packet = Packet();
readers[0].dispatchCommand( command );
for( size_t i = 1; i < N_READER; ++i )
{
co::Command& clone = cache.clone( command );
readers[i].dispatchCommand( clone );
}
++nOps;
}
const uint64_t time = clock.getTime64();
nOps *= N_READER;
std::cout << nOps << " operations, " << nOps / time << " ops/ms"
<< std::endl;
for( size_t i = 0; i < N_READER; ++i )
{
co::Command& command = cache.alloc( node, node, sizeof( Packet ));
Packet* packet = command.get< Packet >();
*packet = Packet();
packet->command = 1;
readers[i].dispatchCommand( command );
readers[i].join();
}
}
TEST( co::exit( ));
return EXIT_SUCCESS;
}
示例6: Packet
Packet
Packet::make_new(size_t cxt, int ingress_port, packet_id_t id,
copy_id_t copy_id, int ingress_length,
PacketBuffer &&buffer, PHVSourceIface *phv_source) {
return Packet(cxt, ingress_port, id, copy_id, ingress_length,
std::move(buffer), phv_source);
}
示例7: while
void Receiver::enterRVIMode(){
int flag;
int tCount = 0 ;
pSerial_->sendPacket(Packet(RVI));
while(true){
try{
flag = pSerial_->getPacket().flags();
if (flag == ACK1){
break;
}
}catch(int i){
ENSURE_EXCEPTION(i, TIMEOUT_EXCEPTION);
throw GOTO_RESET_EXCEPTION;
}
}
while(!(pBuffer_->safe())){
pSerial_->sendPacket((pBuffer_->peek()));
pBuffer_->pop();
}
if(pBuffer_->safe()){
throw GOTO_IDLE_EXCEPTION;
}
}
示例8: AckPackets
void CRemoteConnection::ProcessRawPacket(const unsigned char* data, const unsigned length)
{
lastReceiveTime=static_cast<float>(SDL_GetTicks())/1000.0f;
const unsigned hsize = 9;
int packetNum=*(int*)data;
int ack=*(int*)(data+4);
unsigned char nak = *(unsigned char*)(data+8);
AckPackets(ack);
if (nak > 0) // we have lost $nak packets
{
int nak_abs = nak + firstUnacked - 1;
if (nak_abs!=lastNak || lastNakTime < lastReceiveTime-0.1f)
{
// resend all packets from firstUnacked till nak_abs
lastNak=nak_abs;
lastNakTime=lastReceiveTime;
for(int b=firstUnacked;b<=nak_abs;++b){
SendRawPacket(unackedPackets[b-firstUnacked]->data,unackedPackets[b-firstUnacked]->length,b);
++resentPackets;
}
}
}
if(!active || lastInOrder>=packetNum || waitingPackets.find(packetNum)!=waitingPackets.end())
return;
Packet* p=SAFE_NEW Packet(data+hsize,length-hsize);
waitingPackets[packetNum]=p;
dataRecv += length;
recvOverhead += hsize;
}
示例9: Packet
Packet PacketPool::allocate(int size)
{
if (size <= 0)
return Packet();
Packet ret(m_pages[m_alloc_page].get(), m_alloc_ptr, size);
// Advance the allocation location
m_alloc_ptr += size;
// If there is not enough room in the current page
if (m_alloc_ptr >= m_page_size - m_packet_size) {
// Try to find an empty one
unsigned int i;
for (i = 0; i < m_pages.size(); i++) {
if (*reinterpret_cast<unsigned int*>(m_pages[i].get()) == 0) {
break;
}
}
m_alloc_page = i;
m_alloc_ptr = PAGE_HEADER_SIZE;
// If the page doesn't exist create it
if (i == m_pages.size()) {
add_page();
}
}
return ret;
}
示例10: Packet
Packet Packet::fromAVPacket(const AVPacket *avpkt, double time_base)
{
Packet pkt;
if (fromAVPacket(&pkt, avpkt, time_base))
return pkt;
return Packet();
}
示例11: log_func
void Conn::onRead(const boost::system::error_code& error, std::shared_ptr< boost::asio::streambuf > rd_buf) {
if( unlikely(error) ) {
log_func("[iproto_conn] %s:%u read error: %s", ep.address().to_string().c_str(), ep.port(), error.message().c_str() );
dismissCallbacks(CB_ERR);
if( error != boost::asio::error::operation_aborted ) {
reconnect();
}
return;
}
if( unlikely(!rd_buf) )
rd_buf.reset(new boost::asio::streambuf);
if( LOG_DEBUG )
log_func("[iproto_conn] %s:%u onRead rd_buf->size=%zu", ep.address().to_string().c_str(), ep.port(), rd_buf->size());
while( rd_buf->size() >= sizeof(Header) ) {
const PacketPtr *buf = boost::asio::buffer_cast< const PacketPtr * >( rd_buf->data() );
if( LOG_DEBUG )
log_func("[iproto_conn] %s:%u onRead buffer iproto packet hdr: len=%u sync=%u msg=%u", ep.address().to_string().c_str(), ep.port(),
buf->hdr.len, buf->hdr.sync, buf->hdr.msg);
size_t want_read = sizeof(Header)+buf->hdr.len;
if( want_read <= rd_buf->size() ) {
invokeCallback(buf->hdr.sync, RequestResult(CB_OK, Packet(buf)) );
rd_buf->consume( sizeof(Header) + buf->hdr.len );
}else{
size_t rd = want_read - rd_buf->size();
if( LOG_DEBUG )
log_func("[iproto_conn] %s:%u onRead want_read=%zu", ep.address().to_string().c_str(), ep.port(), rd);
boost::asio::async_read(sock, *rd_buf, boost::asio::transfer_at_least(rd),
boost::bind(&Conn::onRead, shared_from_this(), boost::asio::placeholders::error, rd_buf) );
return;
}
}
if( likely(sock.is_open()) )
boost::asio::async_read(sock, *rd_buf, boost::asio::transfer_at_least(sizeof(Header)-rd_buf->size()),
boost::bind(&Conn::onRead, shared_from_this(), boost::asio::placeholders::error, rd_buf) );
}
示例12: Packet
void DropsPacket::removeDrop(vector <Player*> players, Drop* drop){
Packet packet = Packet();
packet.addHeader(0xBA);
packet.addByte(0);
packet.addInt(drop->getObjID());
packet.sendTo(NULL, players, 1);
}
示例13: while
bool CDSMSplitterFilter::DemuxLoop()
{
HRESULT hr = S_OK;
while (SUCCEEDED(hr) && !CheckRequest(nullptr) && m_pFile->GetRemaining()) {
dsmp_t type;
UINT64 len;
if (!m_pFile->Sync(type, len)) {
continue;
}
__int64 pos = m_pFile->GetPos();
if (type == DSMP_SAMPLE) {
CAutoPtr<Packet> p(DEBUG_NEW Packet());
if (m_pFile->Read(len, p)) {
if (p->rtStart != Packet::INVALID_TIME) {
p->rtStart -= m_pFile->m_rtFirst;
p->rtStop -= m_pFile->m_rtFirst;
}
hr = DeliverPacket(p);
}
}
m_pFile->Seek(pos + len);
}
return true;
}
示例14: sendPacket
//
// bool sendMsg(msg, toID, fromID, type)
// Last modified: 07Sep2006
//
// Attempts to send a packet to its destination
// based upon the given parameters, returning
// true if successful, false otherwise.
//
// Returns: true if successful, false otherwise
// Parameters:
// msg in/out the message being sent
// toID in the ID of the cell receiving the packet
// fromID in the ID of the cell sending the packet
// type in the type of message being sent
//
bool Environment::sendMsg(const Message &msg,
const GLint toID,
const GLint fromID,
const GLint type)
{
return sendPacket(Packet(msg, toID, fromID, type));
} // sendMsg(const Message &, const GLint, const GLint, const GLint)
示例15: Packet
bool KOSocket::DecryptPacket(uint8 *in_stream, Packet & pkt)
{
uint8* final_packet = nullptr;
if (isCryptoEnabled())
{
// Invalid packet (all encrypted packets need a CRC32 checksum!)
if (m_remaining < 4
// Invalid checksum
|| m_crypto.JvDecryptionWithCRC32(m_remaining, in_stream, in_stream) < 0
// Invalid sequence ID
|| ++m_sequence != *(uint32 *)(in_stream))
return false;
m_remaining -= 8; // remove the sequence ID & CRC checksum
final_packet = &in_stream[4];
}
else
{
final_packet = in_stream; // for simplicity :P
}
m_remaining--;
pkt = Packet(final_packet[0], (size_t)m_remaining);
if (m_remaining > 0)
{
pkt.resize(m_remaining);
memcpy((void*)pkt.contents(), &final_packet[1], m_remaining);
}
return true;
}