Move GetsOrCreateAsarArchive to asar_util.h

This commit is contained in:
Cheng Zhao 2015-02-12 17:23:49 +08:00
parent 64622ceae3
commit 3b3a025ed4
7 changed files with 66 additions and 25 deletions

View file

@ -216,6 +216,8 @@
'atom/common/api/object_life_monitor.h', 'atom/common/api/object_life_monitor.h',
'atom/common/asar/archive.cc', 'atom/common/asar/archive.cc',
'atom/common/asar/archive.h', 'atom/common/asar/archive.h',
'atom/common/asar/asar_util.cc',
'atom/common/asar/asar_util.h',
'atom/common/asar/scoped_temporary_file.cc', 'atom/common/asar/scoped_temporary_file.cc',
'atom/common/asar/scoped_temporary_file.h', 'atom/common/asar/scoped_temporary_file.h',
'atom/common/common_message_generator.cc', 'atom/common/common_message_generator.cc',

View file

@ -6,6 +6,7 @@
#include "atom/browser/net/asar/url_request_asar_job.h" #include "atom/browser/net/asar/url_request_asar_job.h"
#include "atom/common/asar/archive.h" #include "atom/common/asar/archive.h"
#include "atom/common/asar/asar_util.h"
#include "net/base/filename_util.h" #include "net/base/filename_util.h"
#include "net/base/net_errors.h" #include "net/base/net_errors.h"
#include "net/url_request/url_request_error_job.h" #include "net/url_request/url_request_error_job.h"
@ -49,19 +50,6 @@ AsarProtocolHandler::AsarProtocolHandler(
AsarProtocolHandler::~AsarProtocolHandler() { AsarProtocolHandler::~AsarProtocolHandler() {
} }
Archive* AsarProtocolHandler::GetOrCreateAsarArchive(
const base::FilePath& path) const {
if (!archives_.contains(path)) {
scoped_ptr<Archive> archive(new Archive(path));
if (!archive->Init())
return nullptr;
archives_.set(path, archive.Pass());
}
return archives_.get(path);
}
net::URLRequestJob* AsarProtocolHandler::MaybeCreateJob( net::URLRequestJob* AsarProtocolHandler::MaybeCreateJob(
net::URLRequest* request, net::URLRequest* request,
net::NetworkDelegate* network_delegate) const { net::NetworkDelegate* network_delegate) const {
@ -75,7 +63,7 @@ net::URLRequestJob* AsarProtocolHandler::MaybeCreateJob(
return new net::URLRequestFileJob(request, network_delegate, full_path, return new net::URLRequestFileJob(request, network_delegate, full_path,
file_task_runner_); file_task_runner_);
Archive* archive = GetOrCreateAsarArchive(asar_path); std::shared_ptr<Archive> archive = GetOrCreateAsarArchive(asar_path);
if (!archive) if (!archive)
return new net::URLRequestErrorJob(request, network_delegate, return new net::URLRequestErrorJob(request, network_delegate,
net::ERR_FILE_NOT_FOUND); net::ERR_FILE_NOT_FOUND);

View file

@ -5,8 +5,6 @@
#ifndef ATOM_BROWSER_NET_ASAR_ASAR_PROTOCOL_HANDLER_H_ #ifndef ATOM_BROWSER_NET_ASAR_ASAR_PROTOCOL_HANDLER_H_
#define ATOM_BROWSER_NET_ASAR_ASAR_PROTOCOL_HANDLER_H_ #define ATOM_BROWSER_NET_ASAR_ASAR_PROTOCOL_HANDLER_H_
#include "base/containers/scoped_ptr_hash_map.h"
#include "base/files/file_path.h"
#include "base/memory/ref_counted.h" #include "base/memory/ref_counted.h"
#include "net/url_request/url_request_job_factory.h" #include "net/url_request/url_request_job_factory.h"
@ -16,16 +14,12 @@ class TaskRunner;
namespace asar { namespace asar {
class Archive;
class AsarProtocolHandler : public net::URLRequestJobFactory::ProtocolHandler { class AsarProtocolHandler : public net::URLRequestJobFactory::ProtocolHandler {
public: public:
explicit AsarProtocolHandler( explicit AsarProtocolHandler(
const scoped_refptr<base::TaskRunner>& file_task_runner); const scoped_refptr<base::TaskRunner>& file_task_runner);
virtual ~AsarProtocolHandler(); virtual ~AsarProtocolHandler();
Archive* GetOrCreateAsarArchive(const base::FilePath& path) const;
// net::URLRequestJobFactory::ProtocolHandler: // net::URLRequestJobFactory::ProtocolHandler:
net::URLRequestJob* MaybeCreateJob( net::URLRequestJob* MaybeCreateJob(
net::URLRequest* request, net::URLRequest* request,
@ -35,8 +29,6 @@ class AsarProtocolHandler : public net::URLRequestJobFactory::ProtocolHandler {
private: private:
const scoped_refptr<base::TaskRunner> file_task_runner_; const scoped_refptr<base::TaskRunner> file_task_runner_;
mutable base::ScopedPtrHashMap<base::FilePath, Archive> archives_;
DISALLOW_COPY_AND_ASSIGN(AsarProtocolHandler); DISALLOW_COPY_AND_ASSIGN(AsarProtocolHandler);
}; };

View file

@ -17,7 +17,7 @@ namespace asar {
URLRequestAsarJob::URLRequestAsarJob( URLRequestAsarJob::URLRequestAsarJob(
net::URLRequest* request, net::URLRequest* request,
net::NetworkDelegate* network_delegate, net::NetworkDelegate* network_delegate,
Archive* archive, std::shared_ptr<Archive> archive,
const base::FilePath& file_path, const base::FilePath& file_path,
const scoped_refptr<base::TaskRunner>& file_task_runner) const scoped_refptr<base::TaskRunner>& file_task_runner)
: net::URLRequestJob(request, network_delegate), : net::URLRequestJob(request, network_delegate),

View file

@ -5,6 +5,7 @@
#ifndef ATOM_BROWSER_NET_ASAR_URL_REQUEST_ASAR_JOB_H_ #ifndef ATOM_BROWSER_NET_ASAR_URL_REQUEST_ASAR_JOB_H_
#define ATOM_BROWSER_NET_ASAR_URL_REQUEST_ASAR_JOB_H_ #define ATOM_BROWSER_NET_ASAR_URL_REQUEST_ASAR_JOB_H_
#include <memory>
#include <string> #include <string>
#include "atom/common/asar/archive.h" #include "atom/common/asar/archive.h"
@ -27,7 +28,7 @@ class URLRequestAsarJob : public net::URLRequestJob {
public: public:
URLRequestAsarJob(net::URLRequest* request, URLRequestAsarJob(net::URLRequest* request,
net::NetworkDelegate* network_delegate, net::NetworkDelegate* network_delegate,
Archive* archive, std::shared_ptr<Archive> archive,
const base::FilePath& file_path, const base::FilePath& file_path,
const scoped_refptr<base::TaskRunner>& file_task_runner); const scoped_refptr<base::TaskRunner>& file_task_runner);
@ -53,7 +54,7 @@ class URLRequestAsarJob : public net::URLRequestJob {
// Callback after data is asynchronously read from the file into |buf|. // Callback after data is asynchronously read from the file into |buf|.
void DidRead(scoped_refptr<net::IOBuffer> buf, int result); void DidRead(scoped_refptr<net::IOBuffer> buf, int result);
Archive* archive_; std::shared_ptr<Archive> archive_;
Archive::FileInfo file_info_; Archive::FileInfo file_info_;
base::FilePath file_path_; base::FilePath file_path_;

View file

@ -0,0 +1,35 @@
// Copyright (c) 2015 GitHub, Inc.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#include "atom/common/asar/asar_util.h"
#include <map>
#include "atom/common/asar/archive.h"
#include "base/files/file_path.h"
#include "base/lazy_instance.h"
#include "base/stl_util.h"
namespace asar {
typedef std::map<base::FilePath, std::shared_ptr<Archive>> ArchiveMap;
namespace {
static base::LazyInstance<ArchiveMap> g_archive_map = LAZY_INSTANCE_INITIALIZER;
} // namespace
std::shared_ptr<Archive> GetOrCreateAsarArchive(const base::FilePath& path) {
ArchiveMap& archive_map = *g_archive_map.Pointer();
if (!ContainsKey(archive_map, path)) {
std::shared_ptr<Archive> archive(new Archive(path));
if (!archive->Init())
return nullptr;
archive_map[path] = archive;
}
return archive_map[path];
}
} // namespace asar

View file

@ -0,0 +1,23 @@
// Copyright (c) 2015 GitHub, Inc.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#ifndef ATOM_COMMON_ASAR_ASAR_UTIL_H_
#define ATOM_COMMON_ASAR_ASAR_UTIL_H_
#include <memory>
namespace base {
class FilePath;
}
namespace asar {
class Archive;
// Gets or creates a new Archive from the path.
std::shared_ptr<Archive> GetOrCreateAsarArchive(const base::FilePath& path);
} // namespace asar
#endif // ATOM_COMMON_ASAR_ASAR_UTIL_H_