aboutsummaryrefslogtreecommitdiff
path: root/dep/ACE_wrappers/ace/Filecache.cpp
diff options
context:
space:
mode:
authormaximius <none@none>2009-10-17 15:35:07 -0700
committermaximius <none@none>2009-10-17 15:35:07 -0700
commit26b5e033ffde3d161382fc9addbfa99738379641 (patch)
treea344f369ca32945f787a02dee35c3dbe342bed7e /dep/ACE_wrappers/ace/Filecache.cpp
parentf21f47005dcb6b76e1abc9f35fbcd03eed191bff (diff)
*Massive cleanup (\n\n -> \n, *\n -> \n, cleanup for(...) to for (...), and some other cleanups by hand)
*Fix a possible crash in Spell::DoAllEffectOnTarget --HG-- branch : trunk
Diffstat (limited to 'dep/ACE_wrappers/ace/Filecache.cpp')
-rw-r--r--dep/ACE_wrappers/ace/Filecache.cpp113
1 files changed, 0 insertions, 113 deletions
diff --git a/dep/ACE_wrappers/ace/Filecache.cpp b/dep/ACE_wrappers/ace/Filecache.cpp
index cfb70f94f68..df1fe934c7d 100644
--- a/dep/ACE_wrappers/ace/Filecache.cpp
+++ b/dep/ACE_wrappers/ace/Filecache.cpp
@@ -1,5 +1,4 @@
// $Id: Filecache.cpp 80826 2008-03-04 14:51:23Z wotte $
-
#include "ace/Filecache.h"
#include "ace/Object_Manager.h"
#include "ace/Log_Msg.h"
@@ -10,11 +9,9 @@
#include "ace/OS_NS_unistd.h"
#include "ace/OS_NS_fcntl.h"
#include "ace/Truncate.h"
-
ACE_RCSID (ace,
Filecache,
"$Id: Filecache.cpp 80826 2008-03-04 14:51:23Z wotte $")
-
#if defined (ACE_WIN32)
// Specifies no sharing flags.
#define R_MASK ACE_DEFAULT_OPEN_PERMS
@@ -23,7 +20,6 @@ ACE_RCSID (ace,
#define R_MASK S_IRUSR|S_IRGRP|S_IROTH
#define W_MASK S_IRUSR|S_IRGRP|S_IROTH|S_IWUSR|S_IWGRP|S_IWOTH
#endif /* ACE_WIN32 */
-
#if defined (ACE_WIN32)
// See if you can get rid of some of these.
#define READ_FLAGS (FILE_FLAG_SEQUENTIAL_SCAN | \
@@ -42,25 +38,20 @@ ACE_RCSID (ace,
#define WRITE_FLAGS (O_RDWR | O_CREAT | O_TRUNC)
// static const int WCOPY_FLAGS = O_RDWR | O_CREAT | O_TRUNC;
#endif /* ACE_WIN32 */
-
ACE_BEGIN_VERSIONED_NAMESPACE_DECL
-
// static data members
ACE_Filecache *ACE_Filecache::cvf_ = 0;
-
void
ACE_Filecache_Handle::init (void)
{
this->file_ = 0;
this->handle_ = ACE_INVALID_HANDLE;
}
-
ACE_Filecache_Handle::ACE_Filecache_Handle (void)
: file_ (0), handle_ (0), mapit_ (0)
{
this->init ();
}
-
ACE_Filecache_Handle::ACE_Filecache_Handle (const ACE_TCHAR *filename,
ACE_Filecache_Flag mapit)
: file_ (0), handle_ (0), mapit_ (mapit)
@@ -68,19 +59,16 @@ ACE_Filecache_Handle::ACE_Filecache_Handle (const ACE_TCHAR *filename,
this->init ();
// Fetch the file from the Virtual_Filesystem let the
// Virtual_Filesystem do the work of cache coherency.
-
// Filecache will also do the acquire, since it holds the lock at
// that time.
this->file_ = ACE_Filecache::instance ()->fetch (filename, mapit);
}
-
ACE_Filecache_Handle::ACE_Filecache_Handle (const ACE_TCHAR *filename,
int size,
ACE_Filecache_Flag mapit)
: file_ (0), handle_ (0), mapit_ (mapit)
{
this->init ();
-
if (size == 0)
ACE_Filecache::instance ()->remove (filename);
else
@@ -88,28 +76,23 @@ ACE_Filecache_Handle::ACE_Filecache_Handle (const ACE_TCHAR *filename,
// Since this is being opened for a write, simply create a new
// ACE_Filecache_Object now, and let the destructor add it into CVF
// later
-
// Filecache will also do the acquire, since it holds the lock at
// that time.
this->file_ = ACE_Filecache::instance ()->create (filename, size);
}
}
-
ACE_Filecache_Handle::~ACE_Filecache_Handle (void)
{
if (this->handle_ != ACE_INVALID_HANDLE)
// this was dup ()'d
ACE_OS::close (this->handle_);
-
ACE_Filecache::instance ()->finish (this->file_);
}
-
void *
ACE_Filecache_Handle::address (void) const
{
return this->file_ == 0 ? 0 : this->file_->address ();
}
-
ACE_HANDLE
ACE_Filecache_Handle::handle (void) const
{
@@ -121,7 +104,6 @@ ACE_Filecache_Handle::handle (void) const
}
return this->handle_;
}
-
int
ACE_Filecache_Handle::error (void) const
{
@@ -130,7 +112,6 @@ ACE_Filecache_Handle::error (void) const
else
return this->file_->error ();
}
-
ACE_OFF_T
ACE_Filecache_Handle::size (void) const
{
@@ -139,16 +120,13 @@ ACE_Filecache_Handle::size (void) const
else
return this->file_->size ();
}
-
// ------------------
// ACE_Filecache_Hash
// ------------------
-
#define ACE_Filecache_Hash \
ACE_Hash_Map_Manager_Ex<const ACE_TCHAR *, ACE_Filecache_Object *, ACE_Hash<const ACE_TCHAR *>, ACE_Equal_To<const ACE_TCHAR *>, ACE_Null_Mutex>
#define ACE_Filecache_Hash_Entry \
ACE_Hash_Map_Entry<const ACE_TCHAR *, ACE_Filecache_Object *>
-
template <>
ACE_Filecache_Hash_Entry::ACE_Hash_Map_Entry (
const ACE_TCHAR *const &ext_id,
@@ -163,7 +141,6 @@ ACE_Filecache_Hash_Entry::ACE_Hash_Map_Entry (
prev_ (prev)
{
}
-
template <>
ACE_Filecache_Hash_Entry::ACE_Hash_Map_Entry (ACE_Filecache_Hash_Entry *next,
ACE_Filecache_Hash_Entry *prev)
@@ -172,23 +149,19 @@ ACE_Filecache_Hash_Entry::ACE_Hash_Map_Entry (ACE_Filecache_Hash_Entry *next,
prev_ (prev)
{
}
-
template <>
ACE_Filecache_Hash_Entry::~ACE_Hash_Map_Entry (void)
{
ACE_OS::free ((void *) ext_id_);
}
-
// We need these template specializations since KEY is defined as a
// ACE_TCHAR*, which doesn't have a hash() or equal() method defined on it.
-
template <>
unsigned long
ACE_Filecache_Hash::hash (const ACE_TCHAR *const &ext_id)
{
return ACE::hash_pjw (ext_id);
}
-
template <>
int
ACE_Filecache_Hash::equal (const ACE_TCHAR *const &id1,
@@ -196,15 +169,12 @@ ACE_Filecache_Hash::equal (const ACE_TCHAR *const &id1,
{
return ACE_OS::strcmp (id1, id2) == 0;
}
-
#undef ACE_Filecache_Hash
#undef ACE_Filecache_Hash_Entry
-
// -------------
// ACE_Filecache
// -------------
-
ACE_Filecache *
ACE_Filecache::instance (void)
{
@@ -215,7 +185,6 @@ ACE_Filecache::instance (void)
*ACE_Managed_Object<ACE_SYNCH_RW_MUTEX>::get_preallocated_object
(ACE_Object_Manager::ACE_FILECACHE_LOCK);
ACE_GUARD_RETURN (ACE_SYNCH_RW_MUTEX, ace_mon, lock, 0);
-
// @@ James, please check each of the ACE_NEW_RETURN calls to
// make sure that it is safe to return if allocation fails.
if (ACE_Filecache::cvf_ == 0)
@@ -223,35 +192,28 @@ ACE_Filecache::instance (void)
ACE_Filecache,
0);
}
-
return ACE_Filecache::cvf_;
}
-
ACE_Filecache::ACE_Filecache (void)
: size_ (ACE_DEFAULT_VIRTUAL_FILESYSTEM_TABLE_SIZE),
hash_ (size_)
{
}
-
ACE_Filecache::~ACE_Filecache (void)
{
}
-
ACE_Filecache_Object *
ACE_Filecache::insert_i (const ACE_TCHAR *filename,
ACE_SYNCH_RW_MUTEX &filelock,
int mapit)
{
ACE_Filecache_Object *handle = 0;
-
if (this->hash_.find (filename, handle) == -1)
{
ACE_NEW_RETURN (handle,
ACE_Filecache_Object (filename, filelock, 0, mapit),
0);
-
// ACE_DEBUG ((LM_DEBUG, ACE_TEXT (" (%t) CVF: creating %s\n"), filename));
-
if (this->hash_.bind (filename, handle) == -1)
{
delete handle;
@@ -260,20 +222,16 @@ ACE_Filecache::insert_i (const ACE_TCHAR *filename,
}
else
handle = 0;
-
return handle;
}
-
ACE_Filecache_Object *
ACE_Filecache::remove_i (const ACE_TCHAR *filename)
{
ACE_Filecache_Object *handle = 0;
-
// Disassociate file from the cache.
if (this->hash_.unbind (filename, handle) == 0)
{
handle->stale_ = 1;
-
// Try a lock. If it succeeds, we can delete it now.
// Otherwise, it will clean itself up later.
if (handle->lock_.tryacquire_write () == 0)
@@ -284,74 +242,58 @@ ACE_Filecache::remove_i (const ACE_TCHAR *filename)
}
else
handle = 0;
-
return handle;
}
-
ACE_Filecache_Object *
ACE_Filecache::update_i (const ACE_TCHAR *filename,
ACE_SYNCH_RW_MUTEX &filelock,
int mapit)
{
ACE_Filecache_Object *handle = 0;
-
handle = this->remove_i (filename);
handle = this->insert_i (filename, filelock, mapit);
-
return handle;
}
-
int
ACE_Filecache::find (const ACE_TCHAR *filename)
{
return this->hash_.find (filename);
}
-
ACE_Filecache_Object *
ACE_Filecache::remove (const ACE_TCHAR *filename)
{
ACE_Filecache_Object *handle = 0;
-
ACE_OFF_T loc = ACE::hash_pjw (filename) % this->size_;
ACE_SYNCH_RW_MUTEX &hashlock = this->hash_lock_[loc];
// ACE_SYNCH_RW_MUTEX &filelock = this->file_lock_[loc];
-
if (this->hash_.find (filename, handle) != -1)
{
ACE_WRITE_GUARD_RETURN (ACE_SYNCH_RW_MUTEX,
ace_mon,
hashlock,
0);
-
return this->remove_i (filename);
}
-
return 0;
}
-
ACE_Filecache_Object *
ACE_Filecache::fetch (const ACE_TCHAR *filename, int mapit)
{
ACE_Filecache_Object *handle = 0;
-
ACE_OFF_T loc = ACE::hash_pjw (filename) % this->size_;
ACE_SYNCH_RW_MUTEX &hashlock = this->hash_lock_[loc];
ACE_SYNCH_RW_MUTEX &filelock = this->file_lock_[loc];
-
filelock.acquire_read ();
-
if (this->hash_.find (filename, handle) == -1)
{
ACE_WRITE_GUARD_RETURN (ACE_SYNCH_RW_MUTEX,
ace_mon,
hashlock,
0);
-
// Second check in the method call
handle = this->insert_i (filename, filelock, mapit);
-
if (handle == 0)
filelock.release ();
}
@@ -365,45 +307,35 @@ ACE_Filecache::fetch (const ACE_TCHAR *filename, int mapit)
ace_mon,
hashlock,
0);
-
// Second check in the method call
handle = this->update_i (filename, filelock, mapit);
-
if (handle == 0)
filelock.release ();
}
}
// ACE_DEBUG ((LM_DEBUG, ACE_TEXT (" (%t) CVF: found %s\n"), filename));
}
-
return handle;
}
-
ACE_Filecache_Object *
ACE_Filecache::create (const ACE_TCHAR *filename, int size)
{
ACE_Filecache_Object *handle = 0;
-
ACE_OFF_T loc = ACE::hash_pjw (filename) % this->size_;
ACE_SYNCH_RW_MUTEX &filelock = this->file_lock_[loc];
-
ACE_NEW_RETURN (handle,
ACE_Filecache_Object (filename, size, filelock),
0);
handle->acquire ();
-
return handle;
}
-
ACE_Filecache_Object *
ACE_Filecache::finish (ACE_Filecache_Object *&file)
{
if (file == 0)
return file;
-
ACE_OFF_T loc = ACE::hash_pjw (file->filename_) % this->size_;
ACE_SYNCH_RW_MUTEX &hashlock = this->hash_lock_[loc];
-
if (file != 0)
switch (file->action_)
{
@@ -413,13 +345,10 @@ ACE_Filecache::finish (ACE_Filecache_Object *&file)
ace_mon,
hashlock,
0);
-
file->release ();
-
this->remove_i (file->filename_);
#if 0
int result = this->hash_.bind (file->filename (), file);
-
if (result == 0)
file->acquire ();
#else
@@ -436,11 +365,9 @@ ACE_Filecache::finish (ACE_Filecache_Object *&file)
}
#endif
}
-
break;
default:
file->release ();
-
// Last one using a stale file is resposible for deleting it.
if (file->stale_)
{
@@ -452,13 +379,10 @@ ACE_Filecache::finish (ACE_Filecache_Object *&file)
file = 0;
}
}
-
break;
}
-
return file;
}
-
void
ACE_Filecache_Object::init (void)
{
@@ -467,10 +391,8 @@ ACE_Filecache_Object::init (void)
this->error_ = ACE_SUCCESS;
this->tempname_ = 0;
this->size_ = 0;
-
ACE_OS::memset (&(this->stat_), 0, sizeof (this->stat_));
}
-
ACE_Filecache_Object::ACE_Filecache_Object (void)
: tempname_ (0),
mmap_ (),
@@ -486,7 +408,6 @@ ACE_Filecache_Object::ACE_Filecache_Object (void)
{
this->init ();
}
-
ACE_Filecache_Object::ACE_Filecache_Object (const ACE_TCHAR *filename,
ACE_SYNCH_RW_MUTEX &lock,
LPSECURITY_ATTRIBUTES sa,
@@ -504,29 +425,24 @@ ACE_Filecache_Object::ACE_Filecache_Object (const ACE_TCHAR *filename,
lock_ (lock)
{
this->init ();
-
// ASSERT strlen(filename) < sizeof (this->filename_)
ACE_OS::strcpy (this->filename_, filename);
this->action_ = ACE_Filecache_Object::ACE_READING;
// place ourselves into the READING state
-
// Can we access the file?
if (ACE_OS::access (this->filename_, R_OK) == -1)
{
this->error_i (ACE_Filecache_Object::ACE_ACCESS_FAILED);
return;
}
-
// Can we stat the file?
if (ACE_OS::stat (this->filename_, &this->stat_) == -1)
{
this->error_i (ACE_Filecache_Object::ACE_STAT_FAILED);
return;
}
-
this->size_ = ACE_Utils::truncate_cast<ACE_OFF_T> (this->stat_.st_size);
this->tempname_ = this->filename_;
-
// Can we open the file?
this->handle_ = ACE_OS::open (this->tempname_,
READ_FLAGS, R_MASK, this->sa_);
@@ -536,7 +452,6 @@ ACE_Filecache_Object::ACE_Filecache_Object (const ACE_TCHAR *filename,
ACE_TEXT ("ACE_Filecache_Object::ctor: open"));
return;
}
-
if (mapit)
{
// Can we map the file?
@@ -550,11 +465,9 @@ ACE_Filecache_Object::ACE_Filecache_Object (const ACE_TCHAR *filename,
return;
}
}
-
// Ok, finished!
this->action_ = ACE_Filecache_Object::ACE_READING;
}
-
ACE_Filecache_Object::ACE_Filecache_Object (const ACE_TCHAR *filename,
ACE_OFF_T size,
ACE_SYNCH_RW_MUTEX &lock,
@@ -564,11 +477,9 @@ ACE_Filecache_Object::ACE_Filecache_Object (const ACE_TCHAR *filename,
lock_ (lock)
{
this->init ();
-
this->size_ = size;
ACE_OS::strcpy (this->filename_, filename);
this->action_ = ACE_Filecache_Object::ACE_WRITING;
-
// Can we access the file?
if (ACE_OS::access (this->filename_, R_OK|W_OK) == -1
// Does it exist?
@@ -578,9 +489,7 @@ ACE_Filecache_Object::ACE_Filecache_Object (const ACE_TCHAR *filename,
this->error_i (ACE_Filecache_Object::ACE_ACCESS_FAILED);
return;
}
-
this->tempname_ = this->filename_;
-
// Can we open the file?
this->handle_ = ACE_OS::open (this->tempname_, WRITE_FLAGS, W_MASK, this->sa_);
if (this->handle_ == ACE_INVALID_HANDLE)
@@ -589,7 +498,6 @@ ACE_Filecache_Object::ACE_Filecache_Object (const ACE_TCHAR *filename,
ACE_TEXT ("ACE_Filecache_Object::acquire: open"));
return;
}
-
// Can we write?
if (ACE_OS::pwrite (this->handle_, "", 1, this->size_ - 1) != 1)
{
@@ -598,7 +506,6 @@ ACE_Filecache_Object::ACE_Filecache_Object (const ACE_TCHAR *filename,
ACE_OS::close (this->handle_);
return;
}
-
// Can we map?
if (this->mmap_.map (this->handle_, this->size_, PROT_RDWR, MAP_SHARED,
0, 0, this->sa_) != 0)
@@ -607,10 +514,8 @@ ACE_Filecache_Object::ACE_Filecache_Object (const ACE_TCHAR *filename,
ACE_TEXT ("ACE_Filecache_Object::acquire: map"));
ACE_OS::close (this->handle_);
}
-
// Ok, done!
}
-
ACE_Filecache_Object::~ACE_Filecache_Object (void)
{
if (this->error_ == ACE_SUCCESS)
@@ -619,23 +524,19 @@ ACE_Filecache_Object::~ACE_Filecache_Object (void)
ACE_OS::close (this->handle_);
this->handle_ = ACE_INVALID_HANDLE;
}
-
this->lock_.release ();
}
-
int
ACE_Filecache_Object::acquire (void)
{
return this->lock_.tryacquire_read ();
}
-
int
ACE_Filecache_Object::release (void)
{
if (this->action_ == ACE_WRITING)
{
// We are safe since only one thread has a writable Filecache_Object
-
#if 0
ACE_HANDLE original = ACE_OS::open (this->filename_, WRITE_FLAGS, W_MASK,
this->sa_);
@@ -651,11 +552,9 @@ ACE_Filecache_Object::release (void)
else if (ACE_OS::stat (this->filename_, &this->stat_) == -1)
this->error_ = ACE_Filecache_Object::ACE_STAT_FAILED;
#endif
-
this->mmap_.unmap ();
ACE_OS::close (this->handle_);
this->handle_ = ACE_INVALID_HANDLE;
-
#if 0
// Leave the file in an acquirable state.
this->handle_ = ACE_OS::open (this->tempname_, READ_FLAGS, R_MASK);
@@ -676,21 +575,17 @@ ACE_Filecache_Object::release (void)
ACE_OS::close (this->handle_);
this->handle_ = ACE_INVALID_HANDLE;
}
-
this->action_ = ACE_Filecache_Object::ACE_READING;
#endif
}
-
return this->lock_.release ();
}
-
int
ACE_Filecache_Object::error (void) const
{
// The existence of the object means a read lock is being held.
return this->error_;
}
-
int
ACE_Filecache_Object::error_i (int error_value, const ACE_TCHAR *s)
{
@@ -699,42 +594,36 @@ ACE_Filecache_Object::error_i (int error_value, const ACE_TCHAR *s)
this->error_ = error_value;
return error_value;
}
-
const ACE_TCHAR *
ACE_Filecache_Object::filename (void) const
{
// The existence of the object means a read lock is being held.
return this->filename_;
}
-
ACE_OFF_T
ACE_Filecache_Object::size (void) const
{
// The existence of the object means a read lock is being held.
return this->size_;
}
-
ACE_HANDLE
ACE_Filecache_Object::handle (void) const
{
// The existence of the object means a read lock is being held.
return this->handle_;
}
-
void *
ACE_Filecache_Object::address (void) const
{
// The existence of the object means a read lock is being held.
return this->mmap_.addr ();
}
-
int
ACE_Filecache_Object::update (void) const
{
// The existence of the object means a read lock is being held.
int result;
ACE_stat statbuf;
-
if (ACE_OS::stat (this->filename_, &statbuf) == -1)
result = 1;
else
@@ -747,9 +636,7 @@ ACE_Filecache_Object::update (void) const
#else
result = ACE_OS::difftime (this->stat_.st_mtime, statbuf.st_mtime) < 0;
#endif /* ACE_HAS_WINCE */
-
return result;
}
-
ACE_END_VERSIONED_NAMESPACE_DECL