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
104
105
106
|
/*
* Copyright (C) 2012-2018 Team Kodi
* This file is part of Kodi - https://kodi.tv
*
* SPDX-License-Identifier: GPL-2.0-or-later
* See LICENSES/README.md for more information.
*/
#include "ImageFile.h"
#include "ServiceBroker.h"
#include "TextureCache.h"
#include "URL.h"
using namespace XFILE;
CImageFile::CImageFile(void) = default;
CImageFile::~CImageFile(void)
{
Close();
}
bool CImageFile::Open(const CURL& url)
{
std::string file = url.Get();
bool needsRecaching = false;
std::string cachedFile =
CServiceBroker::GetTextureCache()->CheckCachedImage(file, needsRecaching);
if (cachedFile.empty())
{ // not in the cache, so cache it
cachedFile = CServiceBroker::GetTextureCache()->CacheImage(file);
}
if (!cachedFile.empty())
{ // in the cache, return what we have
if (m_file.Open(cachedFile))
return true;
}
return false;
}
bool CImageFile::Exists(const CURL& url)
{
bool needsRecaching = false;
std::string cachedFile =
CServiceBroker::GetTextureCache()->CheckCachedImage(url.Get(), needsRecaching);
if (!cachedFile.empty())
{
if (CFile::Exists(cachedFile, false))
return true;
else
// Remove from cache so it gets cached again on next Open()
CServiceBroker::GetTextureCache()->ClearCachedImage(url.Get());
}
// need to check if the original can be cached on demand and that the file exists
if (!CTextureCache::CanCacheImageURL(url))
return false;
return CFile::Exists(url.GetHostName());
}
int CImageFile::Stat(const CURL& url, struct __stat64* buffer)
{
bool needsRecaching = false;
std::string cachedFile =
CServiceBroker::GetTextureCache()->CheckCachedImage(url.Get(), needsRecaching);
if (!cachedFile.empty())
return CFile::Stat(cachedFile, buffer);
/*
Doesn't exist in the cache yet. We have 3 options here:
1. Cache the file and do the Stat() on the cached file.
2. Do the Stat() on the original file.
3. Return -1;
Only 1 will return valid results, at the cost of being time consuming. ATM we do 3 under
the theory that the only user of this is the webinterface currently, where Stat() is not
required.
*/
return -1;
}
ssize_t CImageFile::Read(void* lpBuf, size_t uiBufSize)
{
return m_file.Read(lpBuf, uiBufSize);
}
int64_t CImageFile::Seek(int64_t iFilePosition, int iWhence /*=SEEK_SET*/)
{
return m_file.Seek(iFilePosition, iWhence);
}
void CImageFile::Close()
{
m_file.Close();
}
int64_t CImageFile::GetPosition()
{
return m_file.GetPosition();
}
int64_t CImageFile::GetLength()
{
return m_file.GetLength();
}
|