summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorpixel <pixel>2008-01-21 17:19:07 +0000
committerpixel <pixel>2008-01-21 17:19:07 +0000
commita8f2f2297f4bd240b9b6284dc69ee586aa9fb49b (patch)
tree7f0393984e79e042d9bde05f65e144c9c07db0f6
parent3d363ac042ecba8fe9c7091a2a9158dda7ccc0f8 (diff)
Adding the possibility to count the number of handles.
-rw-r--r--include/Handle.h5
-rw-r--r--lib/Handle.cc11
-rw-r--r--lib/LuaHandle.cc13
3 files changed, 26 insertions, 3 deletions
diff --git a/include/Handle.h b/include/Handle.h
index 3dbecae..3ef9408 100644
--- a/include/Handle.h
+++ b/include/Handle.h
@@ -17,7 +17,7 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
-/* $Id: Handle.h,v 1.37 2007-05-30 11:57:08 pixel Exp $ */
+/* $Id: Handle.h,v 1.38 2008-01-21 17:19:07 pixel Exp $ */
#ifndef __HANDLE_H__
#define __HANDLE_H__
@@ -65,6 +65,8 @@ class Handle : public Base {
void * mmap(off_t = 0, size_t = -1) throw (GeneralException);
void munmap() throw (GeneralException);
+
+ static int GetNbHandles();
protected:
Handle(int h);
int GetHandle() const;
@@ -87,6 +89,7 @@ class Handle : public Base {
bool mapped;
size_t maplength;
void * mappedarea;
+ static int nb_handles;
};
Handle & operator<<(Handle &, const String &);
diff --git a/lib/Handle.cc b/lib/Handle.cc
index 685c4a4..7313d92 100644
--- a/lib/Handle.cc
+++ b/lib/Handle.cc
@@ -17,7 +17,7 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
-/* $Id: Handle.cc,v 1.80 2007-05-30 11:57:09 pixel Exp $ */
+/* $Id: Handle.cc,v 1.81 2008-01-21 17:19:07 pixel Exp $ */
#include <stdio.h>
#include <string.h>
@@ -62,6 +62,8 @@ enum {
INFLATE
};
+int Handle::nb_handles = 0;
+
Handle::Handle(const Handle & nh) : itell(0), hFile(0), h(nh.h >= 0 ? nh.ndup() : nh.h), closed(nh.closed), nonblock(nh.closed), zfile(0), z(0), hMapObject(0), mapped(0)
{
#ifdef DEBUG
@@ -70,6 +72,7 @@ Handle::Handle(const Handle & nh) : itell(0), hFile(0), h(nh.h >= 0 ? nh.ndup()
if ((h >= 0) && (nh.z)) {
SetZ(nh.z);
}
+ nb_handles++;
}
Handle::~Handle() {
@@ -77,6 +80,7 @@ Handle::~Handle() {
printm(M_INFO, String(_("Destroying handle ")) + h + "\n");
#endif
close();
+ nb_handles--;
}
Handle::Handle(int nh) : itell(0), h(nh), closed(false), nonblock(false), zfile(0), z(0), hMapObject(0), mapped(0)
@@ -84,6 +88,7 @@ Handle::Handle(int nh) : itell(0), h(nh), closed(false), nonblock(false), zfile(
#ifdef DEBUG
printm(M_INFO, String(_("Initialising handle ")) + h + "\n");
#endif
+ nb_handles++;
}
int Handle::GetHandle() {
@@ -691,3 +696,7 @@ int Handle::ndup() const throw (GeneralException) {
int Handle::nclose() throw (GeneralException) {
return ::close(h);
}
+
+int Handle::GetNbHandles() {
+ return nb_handles;
+}
diff --git a/lib/LuaHandle.cc b/lib/LuaHandle.cc
index 587dabd..a1e5ccb 100644
--- a/lib/LuaHandle.cc
+++ b/lib/LuaHandle.cc
@@ -17,7 +17,7 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
-/* $Id: LuaHandle.cc,v 1.22 2007-05-30 11:57:10 pixel Exp $ */
+/* $Id: LuaHandle.cc,v 1.23 2008-01-21 17:19:07 pixel Exp $ */
#include "LuaHandle.h"
@@ -63,6 +63,7 @@ class sLuaHandle : public Base {
static int bseek(lua_State * L);
static int btell(lua_State * L);
static int exists(lua_State * L);
+ static int get_nb_handles(lua_State * L);
private:
static int read(lua_State * L, int);
static int write(lua_State * L, int);
@@ -480,6 +481,14 @@ int sLuaHandle::setz(lua_State * __L) {
return 0;
}
+int sLuaHandle::get_nb_handles(lua_State * __L) {
+ Lua * L = Lua::find(__L);
+
+ L->push((lua_Number) Handle::GetNbHandles());
+
+ return 1;
+}
+
int sLuaHandle::seek(lua_State * __L) {
Lua * L = Lua::find(__L);
int n = L->gettop();
@@ -691,4 +700,6 @@ void LuaHandle::pushconstruct(Lua * L) {
L->push("SEEK_END");
L->push((lua_Number) SEEK_END);
L->settable(LUA_GLOBALSINDEX);
+
+ L->declarefunc("get_nb_handles", sLuaHandle::get_nb_handles);
}