caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
* [Caml-list] Hashtbl.keys
@ 2003-02-18 18:03 Oliver Bandel
  2003-02-18 18:13 ` Hal Daume III
  2003-02-20  9:43 ` Xavier Leroy
  0 siblings, 2 replies; 36+ messages in thread
From: Oliver Bandel @ 2003-02-18 18:03 UTC (permalink / raw)
  To: caml-list

Hello,

the Hastbl-module is a fine thing. To have functions like
Hastbl.find_all is convenient for a lot of problems, which would
be not so easy to solve, when only hastbl.find would be in
that library.

Well... and Hashtbl.iter seems to work on *all* antries in the
*whole* hash-table, that is: A Hastbl.find_all  for each of the
keys in that table.
At least it is, how I understand the decription in the manual.

Well, but Hashtbl.iter is used for unit-functions.
But I need bool-functions, and maybe other tyopes
too.

So, if I want to apply a function with return-type different then
unit, I have to use a second Hash-table to remember, which
keys I have inside my main hastbl (using hashtbl.replace).

Or I may have to use Hastbl.replace instead of Hastbl.add
in my main Hashtbl, where my new data-entry is a list of
the old entry with the new entry appended.

But that all would be easier, if there would be a function
Hashtbl.keys, which give back all keys of a hashtbl.


So, Hashtbl.keys would have the following type:

('a, 'b) t -> key 'a list


With that function, I could use things like

##################################################
let myhash = Hashtbl.create 100000;;

Hashtbl.add myhash "k1" "hellO";;
Hashtbl.add myhash "k2" "xxx";;
Hashtbl.add myhash "k3" "iuzwiuezriuw";;

Hashtbl.add myhash "k1" "la la la";;
Hashtbl.add myhash "k1" "shoo bi doo";;

Hashtbl.find_all (Hashtbl.keys myhash) 

(*
   But the later function could also be named
   Hashtbl.values
   and this one may makes sense in the Hashtbl-module
   too, but a Hashtbl.keys would be much more necessary!

   let all_values_of_a_hash hash = Hashtbl.find_all(Hashtbl.keys hash)

   But I think, the implementation could be more efficient, when
   doing the latter function directly in the underwood of the
   Hashtbl-module itself.

*)
##################################################


Wouldn't it a good idea to add such a
function "get all keys of a hashtable"
into the hashtbl-module? (And a "get all values..." to?)

Would that be hard work, or can it be added easily?


What workaround makes sense until such a funtion will
be available?
Should I use a second hash to save all keys
of the main-hash?
Or what is a good way to solve this problem?


Ciao,
   Oliver


P.S.: For a possible Ocaml-advocacy discussion I want to drop
      that note here:

      I can't believe that programming such problems in perl
      should be easier than in Ocaml... in perl there is a function
      "keys" as well as a function "values" for working on hash-tables.


-------------------
To unsubscribe, mail caml-list-request@inria.fr Archives: http://caml.inria.fr
Bug reports: http://caml.inria.fr/bin/caml-bugs FAQ: http://caml.inria.fr/FAQ/
Beginner's list: http://groups.yahoo.com/group/ocaml_beginners


^ permalink raw reply	[flat|nested] 36+ messages in thread

end of thread, other threads:[~2003-02-26 13:17 UTC | newest]

Thread overview: 36+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2003-02-18 18:03 [Caml-list] Hashtbl.keys Oliver Bandel
2003-02-18 18:13 ` Hal Daume III
2003-02-20  9:43 ` Xavier Leroy
2003-02-20 16:54   ` [Caml-list] OCaml standard library improvement Stefano Zacchiroli
2003-02-21 13:47     ` Nicolas George
2003-02-22 14:09       ` Stefano Zacchiroli
2003-02-23 18:33         ` Alessandro Baretta
2003-02-21 13:53     ` fva
2003-02-21 16:18       ` Amit Dubey
2003-02-21 17:10         ` Brian Hurt
2003-02-21 17:23           ` Nicolas George
2003-02-21 18:01             ` Brian Hurt
2003-02-21 18:57               ` Chris Hecker
2003-02-21 19:28                 ` Brian Hurt
2003-02-22 15:52             ` John Max Skaller
2003-02-21 17:32         ` Maxence Guesdon
2003-02-24  1:21       ` Nicolas Cannasse
2003-02-24  1:45         ` Chris Hecker
2003-02-24  2:46           ` Brian Hurt
2003-02-24  7:42             ` Stefano Zacchiroli
2003-02-24 10:18             ` fva
2003-02-24 11:03             ` Amit Dubey
2003-02-24 12:56               ` John Max Skaller
2003-02-24 13:06                 ` Lauri Alanko
2003-02-24 13:08                 ` Sven Luther
2003-02-24 14:05                   ` [Caml-list] Library Discussion Followups Amit Dubey
2003-02-25  5:49                   ` [Caml-list] OCaml standard library improvement John Max Skaller
2003-02-25  8:29                     ` Xavier Leroy
2003-02-24 16:50                 ` Benjamin C. Pierce
2003-02-24 17:28                   ` brogoff
2003-02-25 18:08                   ` Diego Olivier Fernandez Pons
2003-02-26  7:47                     ` Jean-Christophe Filliatre
2003-02-25 10:47     ` [Caml-list] OCaml standard library _improvement_ NOT a new library! Stefano Zacchiroli
2003-02-25 21:43       ` Alessandro Baretta
2003-02-26  9:42         ` Stefano Zacchiroli
2003-02-21  6:40   ` [Caml-list] Hashtbl.keys Alex Cowie

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).