ladish/grauph/src/libs/engine/OSCResponder.h

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