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 107 108 109
|
/*
* Copyright (C) 2012-2013 Team XBMC
* http://xbmc.org
*
* 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, 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 XBMC; see the file COPYING. If not, see
* <http://www.gnu.org/licenses/>.
*
*/
#include "ImageFile.h"
#include "URL.h"
#include "TextureCache.h"
using namespace XFILE;
CImageFile::CImageFile(void)
{
}
CImageFile::~CImageFile(void)
{
Close();
}
bool CImageFile::Open(const CURL& url)
{
std::string file = url.Get();
bool needsRecaching = false;
std::string cachedFile = CTextureCache::GetInstance().CheckCachedImage(file, false, needsRecaching);
if (cachedFile.empty())
{ // not in the cache, so cache it
cachedFile = CTextureCache::GetInstance().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 = CTextureCache::GetInstance().CheckCachedImage(url.Get(), false, needsRecaching);
if (!cachedFile.empty())
return CFile::Exists(cachedFile, false);
// 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 = CTextureCache::GetInstance().CheckCachedImage(url.Get(), false, 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();
}
|