summaryrefslogtreecommitdiffstats
path: root/otherlibs/labltk/browser/jg_box.ml
diff options
context:
space:
mode:
authorJacques Garrigue <garrigue at math.nagoya-u.ac.jp>1999-11-16 10:22:42 +0000
committerJacques Garrigue <garrigue at math.nagoya-u.ac.jp>1999-11-16 10:22:42 +0000
commitdf8e31a8ae8fda0499f209ebd6efadbe544d4549 (patch)
tree6ad5d6bd60a5126b08d77b8c6c60671cba022ab1 /otherlibs/labltk/browser/jg_box.ml
parentfce433fa4ddf1ce57a29a00cf7d6c6c62ba85bff (diff)
This commit was generated by cvs2svn to compensate for changes in r2531,
which included commits to RCS files with non-trunk default branches. git-svn-id: http://caml.inria.fr/svn/ocaml/trunk@2532 f963ae5c-01c2-4b8c-9fe0-0dff7051ff02
Diffstat (limited to 'otherlibs/labltk/browser/jg_box.ml')
-rw-r--r--otherlibs/labltk/browser/jg_box.ml57
1 files changed, 57 insertions, 0 deletions
diff --git a/otherlibs/labltk/browser/jg_box.ml b/otherlibs/labltk/browser/jg_box.ml
new file mode 100644
index 000000000..f71bd0e7f
--- /dev/null
+++ b/otherlibs/labltk/browser/jg_box.ml
@@ -0,0 +1,57 @@
+(* $Id$ *)
+
+open Tk
+
+let add_scrollbar lb =
+ let sb =
+ Scrollbar.create parent:(Winfo.parent lb) command:(Listbox.yview lb) () in
+ Listbox.configure lb yscrollcommand:(Scrollbar.set sb); sb
+
+let create_with_scrollbar :parent ?:selectmode () =
+ let frame = Frame.create :parent () in
+ let lb = Listbox.create parent:frame ?:selectmode () in
+ frame, lb, add_scrollbar lb
+
+(* from frx_listbox,adapted *)
+
+let recenter lb :index =
+ Listbox.selection_clear lb first:(`Num 0) last:`End;
+ (* Activate it, to keep consistent with Up/Down.
+ You have to be in Extended or Browse mode *)
+ Listbox.activate lb :index;
+ Listbox.selection_anchor lb :index;
+ Listbox.yview_index lb :index
+
+class timed ?:wait ?:nocase get_texts = object
+ val get_texts = get_texts
+ inherit Jg_completion.timed [] ?:wait ?:nocase as super
+ method reset =
+ texts <- get_texts ();
+ super#reset
+end
+
+let add_completion ?:action ?:wait ?:nocase lb =
+ let comp =
+ new timed ?:wait ?:nocase
+ (fun () -> Listbox.get_range lb first:(`Num 0) last:`End) in
+
+ Jg_bind.enter_focus lb;
+
+ bind lb events:[[], `KeyPress]
+ action:(`Set([`Char], fun ev ->
+ (* consider only keys producing characters. The callback is called
+ even if you press Shift. *)
+ if ev.ev_Char <> "" then
+ recenter lb index:(`Num (comp#add ev.ev_Char))));
+
+ begin match action with
+ Some action ->
+ bind lb events:[[], `KeyPressDetail "Return"]
+ action:(`Set ([], fun _ -> action `Active));
+ bind lb events:[[`Double], `ButtonPressDetail 1]
+ action:(`Setbreakable ([`MouseY], fun ev ->
+ action (Listbox.nearest lb y:ev.ev_MouseY); break ()))
+ | None -> ()
+ end;
+
+ recenter lb index:(`Num 0) (* so that first item is active *)