Parent: [f396ad] (diff)

Child: [9dbf56] (diff)

Download this file

ohplaylist.hxx    104 lines (87 with data), 4.3 kB

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
/* Copyright (C) 2014 J.F.Dockes
* This program 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.
*
* This program 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 more 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 _OHPLAYLIST_H_X_INCLUDED_
#define _OHPLAYLIST_H_X_INCLUDED_
#include <string> // for string
#include <unordered_map> // for unordered_map
#include <vector> // for vector
#include "libupnpp/device/device.hxx" // for UpnpService
#include "libupnpp/soaphelp.hxx" // for SoapIncoming, SoapOutgoing
#include "mpdcli.hxx"
class UpMpd;
using namespace UPnPP;
class OHPlaylist : public UPnPProvider::UpnpService {
public:
OHPlaylist(UpMpd *dev, unsigned int cachesavesleep);
virtual bool getEventData(bool all, std::vector<std::string>& names,
std::vector<std::string>& values);
bool cacheFind(const std::string& uri, std:: string& meta);
// Internal non-soap versions of some of the interface for use by
// e.g. ohreceiver
bool insertUri(int afterid, const std::string& uri,
const std::string& metadata, int *newid = 0);
bool ireadList(const std::vector<int>&, std::vector<UpSong>&);
bool iidArray(std::string& idarray, int *token);
bool urlMap(std::unordered_map<int, std::string>& umap);
int iStop();
void refreshState();
// Source active ?
void setActive(bool onoff);
private:
int play(const SoapIncoming& sc, SoapOutgoing& data);
int pause(const SoapIncoming& sc, SoapOutgoing& data);
int stop(const SoapIncoming& sc, SoapOutgoing& data);
int next(const SoapIncoming& sc, SoapOutgoing& data);
int previous(const SoapIncoming& sc, SoapOutgoing& data);
int setRepeat(const SoapIncoming& sc, SoapOutgoing& data);
int repeat(const SoapIncoming& sc, SoapOutgoing& data);
int setShuffle(const SoapIncoming& sc, SoapOutgoing& data);
int shuffle(const SoapIncoming& sc, SoapOutgoing& data);
int seekSecondAbsolute(const SoapIncoming& sc, SoapOutgoing& data);
int seekSecondRelative(const SoapIncoming& sc, SoapOutgoing& data);
int seekId(const SoapIncoming& sc, SoapOutgoing& data);
int seekIndex(const SoapIncoming& sc, SoapOutgoing& data);
int transportState(const SoapIncoming& sc, SoapOutgoing& data);
int id(const SoapIncoming& sc, SoapOutgoing& data);
int ohread(const SoapIncoming& sc, SoapOutgoing& data);
int readList(const SoapIncoming& sc, SoapOutgoing& data);
int insert(const SoapIncoming& sc, SoapOutgoing& data);
int deleteId(const SoapIncoming& sc, SoapOutgoing& data);
int deleteAll(const SoapIncoming& sc, SoapOutgoing& data);
int tracksMax(const SoapIncoming& sc, SoapOutgoing& data);
int idArray(const SoapIncoming& sc, SoapOutgoing& data);
int idArrayChanged(const SoapIncoming& sc, SoapOutgoing& data);
int protocolInfo(const SoapIncoming& sc, SoapOutgoing& data);
bool makeIdArray(std::string&);
bool makestate(std::unordered_map<std::string, std::string> &st);
void maybeWakeUp(bool ok);
// State variable storage
std::unordered_map<std::string, std::string> m_state;
UpMpd *m_dev;
bool m_active;
MpdState m_mpdsavedstate;
// Storage for song metadata, indexed by URL. This used to be
// indexed by song id, but this does not survive MPD restarts.
// The data is the DIDL XML string.
std::unordered_map<std::string, std::string> m_metacache;
bool m_cachedirty;
// Avoid re-reading the whole MPD queue every time by using the
// queue version.
int m_mpdqvers;
std::string m_idArrayCached;
};
#endif /* _OHPLAYLIST_H_X_INCLUDED_ */