From ebb302498593f15330affa732c5206e31d882d8f Mon Sep 17 00:00:00 2001 From: Marc Coquand Date: Wed, 15 May 2024 15:25:36 -0500 Subject: Rename screen -> Prompt --- lib/input_screen.ml | 38 -------------------------------------- 1 file changed, 38 deletions(-) delete mode 100644 lib/input_screen.ml (limited to 'lib/input_screen.ml') diff --git a/lib/input_screen.ml b/lib/input_screen.ml deleted file mode 100644 index 45979aa..0000000 --- a/lib/input_screen.ml +++ /dev/null @@ -1,38 +0,0 @@ -module Grep = Grep -module Common = Common -open Notty - -type state = - { user_input : string - ; on_enter : string -> unit - ; on_cancel : unit -> unit - ; prompt : string - ; screen : I.t - } - -let rec render t ({ user_input; on_enter; on_cancel; screen; prompt } as state) = - let _, size_y = Common.Term.size t in - Common.Term.cursor t (Some (String.length user_input + String.length prompt, size_y)); - let img = - let open I in - I.strf "%s%s" prompt user_input |> I.pad ~l:0 ~t:(size_y - 1) screen - in - Common.Term.image t img; - match Common.Term.event t with - | `End | `Key (`ASCII 'G', [ `Ctrl ]) | `Key (`ASCII 'C', [ `Ctrl ]) -> on_cancel () - | `Key (`Enter, []) -> on_enter user_input - | `Key (`Backspace, []) -> - if String.equal "" user_input - then on_cancel () - else ( - let state = - { state with - user_input = String.sub user_input 0 (max (String.length user_input - 1) 0) - } - in - render t state) - | `Resize _ -> render t state - | `Key (`ASCII c, []) -> - let state = { state with user_input = user_input ^ String.make 1 c } in - render t state - | _ -> render t state -- cgit v1.2.3