]> git.vomp.tv Git - vompclient.git/blob - vdrcommand.h
Change mutex locking in setvolume and mute
[vompclient.git] / vdrcommand.h
1 /*
2     Copyright 2004-2005 Chris Tallon, Andreas Vogel
3
4     This file is part of VOMP.
5
6     VOMP is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     VOMP is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with VOMP; if not, write to the Free Software
18     Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
19 */
20
21 #ifndef VDRCOMMAND_H
22 #define VDRCOMMAND_H
23
24 #include "defines.h"
25 #include "serialize.h"
26 #include "media.h"
27
28 /**
29   * data holder for VDR commands
30   * it's only important to add serializable objects
31   * in the same order on both sides
32   */
33
34 //until we really have response - commands we simply take
35 //the request+this flag for responses
36 //not really necessary but for checks it's better to have a command ID at least in some responses
37 const static ULONG VDR_RESPONSE_FLAG =0x1000000;
38
39 //as this header is only included by vdr.cc the constants are this way private
40 //but can easily be used on the server side as well
41
42 const static ULONG VDR_LOGIN               = 1;
43 const static ULONG VDR_GETRECORDINGLIST    = 2;
44 const static ULONG VDR_DELETERECORDING     = 3;
45 const static ULONG VDR_GETCHANNELLIST      = 5;
46 const static ULONG VDR_STREAMCHANNEL       = 6;
47 const static ULONG VDR_GETBLOCK            = 7;
48 const static ULONG VDR_STOPSTREAMING       = 8;
49 const static ULONG VDR_STREAMRECORDING     = 9;
50 const static ULONG VDR_GETCHANNELSCHEDULE  = 10;
51 const static ULONG VDR_CONFIGSAVE          = 11;
52 const static ULONG VDR_CONFIGLOAD          = 12;
53 const static ULONG VDR_RESCANRECORDING     = 13;  // FIXME obselete
54 const static ULONG VDR_GETTIMERS           = 14;
55 const static ULONG VDR_SETTIMER            = 15;
56 const static ULONG VDR_POSFROMFRAME        = 16;
57 const static ULONG VDR_FRAMEFROMPOS        = 17;
58 const static ULONG VDR_MOVERECORDING       = 18;
59 const static ULONG VDR_GETNEXTIFRAME       = 19;
60 const static ULONG VDR_GETRECINFO          = 20;
61 const static ULONG VDR_GETMARKS            = 21;
62 const static ULONG VDR_GETCHANNELPIDS      = 22;
63 const static ULONG VDR_DELETETIMER         = 23;
64 const static ULONG VDR_GETLANGUAGELIST     = 33;
65 const static ULONG VDR_GETLANGUAGECONTENT  = 34;
66 const static ULONG VDR_SETCHARSET          = 37;
67 const static ULONG VDR_GETMEDIALIST        = 30;
68 const static ULONG VDR_OPENMEDIA           = 31;
69 const static ULONG VDR_GETMEDIABLOCK       = 32;
70 const static ULONG VDR_GETMEDIAINFO        = 35;
71 const static ULONG VDR_CLOSECHANNEL        = 36;
72
73 class VDR_Command : public SerializableList {
74   public:
75     VDR_Command(const ULONG cmd) {
76       command=cmd;
77       addParam(&command);
78     }
79     virtual ~VDR_Command(){}
80     ULONG command;
81 };
82
83 class VDR_GetMediaListRequest : public VDR_Command {
84   public:
85     VDR_GetMediaListRequest(MediaURI *root) :VDR_Command(VDR_GETMEDIALIST) {
86       addParam(root);
87     }
88 };
89
90 class VDR_GetMediaListResponse : public VDR_Command {
91   public:
92     VDR_GetMediaListResponse(ULONG *flags,MediaList *m) : VDR_Command(VDR_GETMEDIALIST|VDR_RESPONSE_FLAG){
93       addParam(flags);
94       addParam(m);
95     }
96 };
97
98 class VDR_OpenMediumRequest : public VDR_Command {
99   public:
100     VDR_OpenMediumRequest(ULONG *channel,MediaURI *u,ULONG *xsize, ULONG *ysize) :
101       VDR_Command(VDR_OPENMEDIA) {
102         addParam(channel);
103         addParam(u);
104         addParam(xsize);
105         addParam(ysize);
106       }
107 };
108 class VDR_OpenMediumResponse : public VDR_Command {
109   public:
110     VDR_OpenMediumResponse(ULONG *flags,ULLONG *size) :
111       VDR_Command(VDR_OPENMEDIA|VDR_RESPONSE_FLAG) {
112         addParam(flags);
113         addParam(size);
114       }
115 };
116 class VDR_GetMediaBlockRequest : public VDR_Command {
117   public:
118     VDR_GetMediaBlockRequest(ULONG * channel, ULLONG *pos, ULONG *max):
119       VDR_Command(VDR_GETMEDIABLOCK) {
120         addParam(channel);
121         addParam(pos);
122         addParam(max);
123       }
124 };
125
126 //no response class for GetMediaBlock
127
128
129 class VDR_CloseMediaChannelRequest : public VDR_Command {
130   public:
131     VDR_CloseMediaChannelRequest(ULONG * channel):
132       VDR_Command(VDR_CLOSECHANNEL) {
133         addParam(channel);
134       }
135 };
136
137 class VDR_CloseMediaChannelResponse : public VDR_Command {
138   public:
139     VDR_CloseMediaChannelResponse(ULONG * flags):
140       VDR_Command(VDR_CLOSECHANNEL|VDR_RESPONSE_FLAG) {
141         addParam(flags);
142       }
143 };
144
145 class VDR_GetMediaInfoRequest : public VDR_Command {
146   public:
147     VDR_GetMediaInfoRequest(ULONG * channel):
148       VDR_Command(VDR_GETMEDIAINFO) {
149         addParam(channel);
150       }
151 };
152 class VDR_GetMediaInfoResponse : public VDR_Command {
153   public:
154     VDR_GetMediaInfoResponse(ULONG * flags,MediaInfo *info):
155       VDR_Command(VDR_GETMEDIAINFO|VDR_RESPONSE_FLAG) {
156         addParam(flags);
157         addParam(info);
158       }
159 };
160
161
162
163
164 #endif