Skip to content

Commit

Permalink
Fix multithreading issues
Browse files Browse the repository at this point in the history
  • Loading branch information
a1rwulf committed Dec 21, 2017
1 parent 53f94ec commit ec3974e
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 0 deletions.
10 changes: 10 additions & 0 deletions src/PVRIptvData.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -573,11 +573,13 @@ bool PVRIptvData::LoadGenres(void)

int PVRIptvData::GetChannelsAmount(void)
{
P8PLATFORM::CLockObject lock(m_mutex);
return m_channels.size();
}

PVR_ERROR PVRIptvData::GetChannels(ADDON_HANDLE handle, bool bRadio)
{
P8PLATFORM::CLockObject lock(m_mutex);
for (unsigned int iChannelPtr = 0; iChannelPtr < m_channels.size(); iChannelPtr++)
{
PVRIptvChannel &channel = m_channels.at(iChannelPtr);
Expand All @@ -603,6 +605,7 @@ PVR_ERROR PVRIptvData::GetChannels(ADDON_HANDLE handle, bool bRadio)

bool PVRIptvData::GetChannel(const PVR_CHANNEL &channel, PVRIptvChannel &myChannel)
{
P8PLATFORM::CLockObject lock(m_mutex);
for (unsigned int iChannelPtr = 0; iChannelPtr < m_channels.size(); iChannelPtr++)
{
PVRIptvChannel &thisChannel = m_channels.at(iChannelPtr);
Expand All @@ -625,11 +628,13 @@ bool PVRIptvData::GetChannel(const PVR_CHANNEL &channel, PVRIptvChannel &myChann

int PVRIptvData::GetChannelGroupsAmount(void)
{
P8PLATFORM::CLockObject lock(m_mutex);
return m_groups.size();
}

PVR_ERROR PVRIptvData::GetChannelGroups(ADDON_HANDLE handle, bool bRadio)
{
P8PLATFORM::CLockObject lock(m_mutex);
std::vector<PVRIptvChannelGroup>::iterator it;
for (it = m_groups.begin(); it != m_groups.end(); ++it)
{
Expand All @@ -651,6 +656,7 @@ PVR_ERROR PVRIptvData::GetChannelGroups(ADDON_HANDLE handle, bool bRadio)

PVR_ERROR PVRIptvData::GetChannelGroupMembers(ADDON_HANDLE handle, const PVR_CHANNEL_GROUP &group)
{
P8PLATFORM::CLockObject lock(m_mutex);
PVRIptvChannelGroup *myGroup;
if ((myGroup = FindGroup(group.strGroupName)) != NULL)
{
Expand All @@ -677,6 +683,7 @@ PVR_ERROR PVRIptvData::GetChannelGroupMembers(ADDON_HANDLE handle, const PVR_CHA

PVR_ERROR PVRIptvData::GetEPGForChannel(ADDON_HANDLE handle, const PVR_CHANNEL &channel, time_t iStart, time_t iEnd)
{
P8PLATFORM::CLockObject lock(m_mutex);
std::vector<PVRIptvChannel>::iterator myChannel;
for (myChannel = m_channels.begin(); myChannel < m_channels.end(); ++myChannel)
{
Expand Down Expand Up @@ -1058,6 +1065,7 @@ void PVRIptvData::ApplyChannelsLogosFromEPG()

void PVRIptvData::ReaplyChannelsLogos(const char * strNewPath)
{
P8PLATFORM::CLockObject lock(m_mutex);
if (strlen(strNewPath) > 0)
{
m_strLogoPath = strNewPath;
Expand All @@ -1070,6 +1078,7 @@ void PVRIptvData::ReaplyChannelsLogos(const char * strNewPath)

void PVRIptvData::ReloadEPG(const char * strNewPath)
{
P8PLATFORM::CLockObject lock(m_mutex);
if (strNewPath != m_strXMLTVUrl)
{
m_strXMLTVUrl = strNewPath;
Expand All @@ -1088,6 +1097,7 @@ void PVRIptvData::ReloadEPG(const char * strNewPath)

void PVRIptvData::ReloadPlayList(const char * strNewPath)
{
P8PLATFORM::CLockObject lock(m_mutex);
if (strNewPath != m_strM3uUrl)
{
m_strM3uUrl = strNewPath;
Expand Down
1 change: 1 addition & 0 deletions src/PVRIptvData.h
Original file line number Diff line number Diff line change
Expand Up @@ -132,4 +132,5 @@ class PVRIptvData : public P8PLATFORM::CThread
std::vector<PVRIptvChannel> m_channels;
std::vector<PVRIptvEpgChannel> m_epg;
std::vector<PVRIptvEpgGenre> m_genres;
P8PLATFORM::CMutex m_mutex;
};

0 comments on commit ec3974e

Please sign in to comment.