annotate bits/RequestOrResponse.h @ 73:7bfc07576830

Ensure id is passed through properly in convert and in server
author Chris Cannam <c.cannam@qmul.ac.uk>
date Mon, 10 Oct 2016 15:03:47 +0100
parents 815e94fedc1c
children
rev   line source
c@31 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
c@31 2
c@31 3 /*
c@31 4 Vampipe
c@31 5
c@31 6 Centre for Digital Music, Queen Mary, University of London.
c@31 7 Copyright 2006-2016 Chris Cannam and QMUL.
c@31 8
c@31 9 Permission is hereby granted, free of charge, to any person
c@31 10 obtaining a copy of this software and associated documentation
c@31 11 files (the "Software"), to deal in the Software without
c@31 12 restriction, including without limitation the rights to use, copy,
c@31 13 modify, merge, publish, distribute, sublicense, and/or sell copies
c@31 14 of the Software, and to permit persons to whom the Software is
c@31 15 furnished to do so, subject to the following conditions:
c@31 16
c@31 17 The above copyright notice and this permission notice shall be
c@31 18 included in all copies or substantial portions of the Software.
c@31 19
c@31 20 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
c@31 21 EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
c@31 22 MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
c@31 23 NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
c@31 24 ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
c@31 25 CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
c@31 26 WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
c@31 27
c@31 28 Except as contained in this notice, the names of the Centre for
c@31 29 Digital Music; Queen Mary, University of London; and Chris Cannam
c@31 30 shall not be used in advertising or otherwise to promote the sale,
c@31 31 use or other dealings in this Software without prior written
c@31 32 authorization.
c@31 33 */
c@31 34
c@31 35 #ifndef VAMPIPE_REQUEST_OR_RESPONSE_H
c@31 36 #define VAMPIPE_REQUEST_OR_RESPONSE_H
c@31 37
c@31 38 #include "RequestResponseType.h"
c@31 39
c@31 40 #include <vamp-hostsdk/PluginStaticData.h>
c@31 41 #include <vamp-hostsdk/RequestResponse.h>
c@31 42
c@31 43 #include <string>
c@31 44 #include <vector>
c@31 45
c@31 46 namespace vampipe {
c@31 47
c@31 48 class RequestOrResponse
c@31 49 {
c@31 50 public:
c@31 51 enum Direction {
c@31 52 Request, Response
c@31 53 };
c@73 54
c@73 55 struct RpcId {
c@73 56 enum { Absent, Number, Tag } type;
c@73 57 int number;
c@73 58 std::string tag;
c@73 59 };
c@31 60
c@31 61 RequestOrResponse() : // nothing by default
c@31 62 direction(Request),
c@31 63 type(RRType::NotValid),
c@73 64 success(false),
c@73 65 id({ RpcId::Absent, 0, "" })
c@73 66 { }
c@31 67
c@31 68 Direction direction;
c@31 69 RRType type;
c@31 70 bool success;
c@31 71 std::string errorText;
c@73 72 RpcId id;
c@31 73
c@56 74 Vamp::HostExt::ListResponse listResponse;
c@31 75 Vamp::HostExt::LoadRequest loadRequest;
c@31 76 Vamp::HostExt::LoadResponse loadResponse;
c@31 77 Vamp::HostExt::ConfigurationRequest configurationRequest;
c@31 78 Vamp::HostExt::ConfigurationResponse configurationResponse;
c@31 79 Vamp::HostExt::ProcessRequest processRequest;
c@31 80 Vamp::HostExt::ProcessResponse processResponse;
c@55 81 Vamp::HostExt::FinishRequest finishRequest;
c@31 82 Vamp::HostExt::ProcessResponse finishResponse;
c@31 83 };
c@31 84
c@31 85 }
c@31 86
c@31 87 #endif