⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rtpsimple.cxx

📁 RTP协议
💻 CXX
字号:
/* ==================================================================== * The Vovida Software License, Version 1.0  *  * Copyright (c) 2000 Vovida Networks, Inc.  All rights reserved. *  * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: *  * 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. The names "VOCAL", "Vovida Open Communication Application Library", *    and "Vovida Open Communication Application Library (VOCAL)" must *    not be used to endorse or promote products derived from this *    software without prior written permission. For written *    permission, please contact vocal@vovida.org. * * 4. Products derived from this software may not be called "VOCAL", nor *    may "VOCAL" appear in their name, without prior written *    permission of Vovida Networks, Inc. *  * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND * NON-INFRINGEMENT ARE DISCLAIMED.  IN NO EVENT SHALL VOVIDA * NETWORKS, INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT DAMAGES * IN EXCESS OF $1,000, NOR FOR ANY 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. *  * ==================================================================== *  * This software consists of voluntary contributions made by Vovida * Networks, Inc. and many individuals on behalf of Vovida Networks, * Inc.  For more information on Vovida Networks, Inc., please see * <http://www.vovida.org/>. * */static const char* const rtpSimple_cxx_Version =    "$Id: rtpSimple.cxx,v 1.10 2001/06/29 21:02:42 bko Exp $";#include <unistd.h>#include <fstream>#include "rtpTypes.h"#include "Rtp.hxx"#include "Rtcp.hxx"#include "RtpSession.hxx"#ifdef __vxworks#include "VThread.hxx"#endif#include <sys/types.h>#include <sys/stat.h>#include <fcntl.h>#include <errno.h>#include <deque>#include "SessionData.hxx"#include "support.hxx"class MultiSession{    public:        MultiSession();        void processControl();        void periodicProcess();        int setFds(fd_set* fdSet);        void processFds(fd_set* fdSet);    private:        deque < SessionData* > sessionList;        string cmdBuf;};MultiSession::MultiSession(){    SessionData* session;    session = new SessionData;    sessionList.push_back(session);}bool cmd_verify(const split_t& command_list,                const char* cmd_name,                unsigned int args){    if (command_list.size() == args)    {        if ((command_list[0] == cmd_name))        {            return true;        }    }    return false;}void MultiSession::processControl(){    cout << "got bytes" << endl;    // this should do something    char buf[1024];    int bytesRead = read(0, buf, 1023);    buf[bytesRead] = '\0';    cmdBuf += buf;    // chomp out to the \n    SessionData* session = sessionList.front();    while (1)    {        string::size_type pos = cmdBuf.find("\n");        if (pos != string::npos)        {            // this is a command            string cmd;            cmd = cmdBuf.substr(0, pos);            split_t myCmd = split(cmd, " ");            if (cmd_verify(myCmd, "n", 4))            {                cout << "new handle" << endl;                session->newStack(myCmd[1], myCmd[2], myCmd[3]);            }            if (myCmd[0] == "v")            {                // voice mail mode:                // play first filename (greeting)                // play second filename (beep)                // record third filename                split_t::iterator i = myCmd.begin();                i++;                while (i != myCmd.end())                {                    session->addQueue(*i);                    i++;                }                session->shouldUseQueue(true);            }            if (cmd_verify(myCmd, "r", 2))            {                session->setRecordFile(myCmd[1]);            }            if (cmd_verify(myCmd, "sr", 1))            {                session->stopRecord();            }            if (cmd_verify(myCmd, "p", 2))            {                // play file                session->setPlayFile(myCmd[1]);            }            if (cmd_verify(myCmd, "d", 1))            {                // delete stack                session->closeStack();            }            if (cmd_verify(myCmd, "s", 2))            {                session->setPktSize(atoi(myCmd[1].c_str()));            }            if (myCmd[0] == "q")            {                session->closeStack();                exit(0);            }            if ((pos + 1) < cmdBuf.length())            {                cmdBuf                = cmdBuf.substr(pos + 1,                                cmdBuf.length() - (pos + 1));            }            else            {                cmdBuf = "";            }        }        else        {            // no more cmd -- skip            break;        }    }}void MultiSession::periodicProcess(){    SessionData* session = sessionList.front();    session->periodicProcess();}int MultiSession::setFds(fd_set* fdSet){    int maxFd = 0;    FD_SET(0, fdSet);   // stdin -- needed for stuff    SessionData* session = sessionList.front();    int sessionFd = session->getFd();    if (sessionFd >= 0)    {        FD_SET(sessionFd, fdSet);        maxFd = sessionFd;    }    return maxFd;}void MultiSession::processFds(fd_set* fdSet){    if (FD_ISSET(0, fdSet))    {        processControl();    }    SessionData* session = sessionList.front();    int sessionFd = session->getFd();    if (sessionFd >= 0)    {        // handle selects        if (FD_ISSET(sessionFd, fdSet))        {            session->receivePacket();        }    }}void mainAudioLoop(){    MultiSession mySession;    // in the audio stack, handle appropriate stuff    while (1)    {        fd_set readfds;        struct timeval tv;        int retval;        int maxFd = 0;        // reset file descriptor        FD_ZERO(&readfds);        maxFd = mySession.setFds(&readfds);        maxFd++;        tv.tv_sec = 0;        tv.tv_usec = 1000;        retval = select(maxFd, &readfds, 0, 0, &tv);        if (retval < 0)        {            cout << "select() returned with an error\n";            return ;        }        if (retval > 0)        {            mySession.processFds(&readfds);        }        // check for too much time elapsing -- do I need to send a packet?        mySession.periodicProcess();    }}int main (int argc, char *argv[]){    mainAudioLoop();    //    stack.transmitRTCPBYE();    //    RtpTransmitter* tran = stack.getRtpTran();    return 0;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -