--- parser3/src/classes/hash.C 2001/09/06 08:25:08 1.15 +++ parser3/src/classes/hash.C 2001/09/18 16:05:42 1.17 @@ -4,10 +4,8 @@ Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com) Author: Alexander Petrosyan (http://design.ru/paf) - - $Id: hash.C,v 1.15 2001/09/06 08:25:08 parser Exp $ */ -static const char *RCSId="$Id: hash.C,v 1.15 2001/09/06 08:25:08 parser Exp $"; +static const char *RCSId="$Id: hash.C,v 1.17 2001/09/18 16:05:42 parser Exp $"; #include "classes.h" #include "pa_request.h" @@ -15,6 +13,7 @@ static const char *RCSId="$Id: hash.C,v #include "pa_vvoid.h" #include "pa_sql_connection.h" #include "pa_vtable.h" +#include "pa_vint.h" // defines @@ -159,6 +158,14 @@ static void _keys(Request& r, const Stri r.write_no_lang(result); } +static void _count(Request& r, const String& method_name, MethodParams *) { + Pool& pool=r.pool(); + + Value& value=*new(pool) VInt(pool, static_cast(r.self)->hash().size()); + value.set_name(method_name); + r.write_no_lang(value); +} + // constructor MHash::MHash(Pool& apool) : Methoded(apool) { @@ -169,6 +176,9 @@ MHash::MHash(Pool& apool) : Methoded(apo // ^hash._keys[] add_native_method("_keys", Method::CT_DYNAMIC, _keys, 0, 0); + + // ^hash._count[] + add_native_method("_count", Method::CT_DYNAMIC, _count, 0, 0); } // global variable