62 lines
1.7 KiB
C++
62 lines
1.7 KiB
C++
/* This file is part of Om. Copyright (C) 2006 Dave Robillard.
|
|
*
|
|
* Om is free software; you can redistribute it and/or modify it under the
|
|
* terms of the GNU General Public License as published by the Free Software
|
|
* Foundation; either version 2 of the License, or (at your option) any later
|
|
* version.
|
|
*
|
|
* Om is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*/
|
|
|
|
#ifndef OSCRESPONDER_H
|
|
#define OSCRESPONDER_H
|
|
|
|
#include <inttypes.h>
|
|
#include <memory>
|
|
#include <lo/lo.h>
|
|
#include "Responder.h"
|
|
|
|
namespace Om {
|
|
|
|
|
|
/** Responder for (liblo) OSC clients.
|
|
*
|
|
* OSC Clients use request IDs to be able to associate replies with sent
|
|
* events. If the ID is -1, a response will not be sent (and the overhead
|
|
* of searching for the client's record will be skipped). Any other integer
|
|
* is a valid response ID and will be responded to.
|
|
*
|
|
* Creation of the lo_address is deferred until needed to avoid bogging down
|
|
* the receiving thread as much as possible.
|
|
*/
|
|
class OSCResponder : public Responder
|
|
{
|
|
public:
|
|
OSCResponder(int32_t id, char* url);
|
|
~OSCResponder();
|
|
|
|
CountedPtr<Shared::ClientInterface> find_client();
|
|
|
|
void respond_ok();
|
|
void respond_error(const string& msg);
|
|
|
|
const char* url() const { return _url; }
|
|
|
|
private:
|
|
int32_t _id;
|
|
char* const _url;
|
|
lo_address _addr;
|
|
};
|
|
|
|
|
|
} // namespace Om
|
|
|
|
#endif // OSCRESPONDER_H
|
|
|