# HG changeset patch # User Adam Chlipala # Date 1402412302 14400 # Node ID 2da693675de9624aba76ac1ec97a3e5cec59148b # Parent 924e2ef31f5a66e2e4d8ee04d2044ac793114642 String.trim; add OnChange to more tags diff -r 924e2ef31f5a -r 2da693675de9 lib/ur/basis.urs --- a/lib/ur/basis.urs Mon Jun 09 18:26:03 2014 -0400 +++ b/lib/ur/basis.urs Tue Jun 10 10:58:22 2014 -0400 @@ -946,11 +946,11 @@ val hidden : formTag string [] [Data = data_attr, Id = string, Value = string] val textbox : formTag string [] ([Value = string, Size = int, Placeholder = string, Source = source string, Onchange = transaction unit, Ontext = transaction unit] ++ boxAttrs) -val password : formTag string [] ([Value = string, Size = int, Placeholder = string] ++ boxAttrs) +val password : formTag string [] ([Value = string, Size = int, Placeholder = string, Onchange = transaction unit] ++ boxAttrs) val textarea : formTag string [] ([Rows = int, Cols = int, Onchange = transaction unit, Ontext = transaction unit] ++ boxAttrs) -val checkbox : formTag bool [] ([Checked = bool] ++ boxAttrs) +val checkbox : formTag bool [] ([Checked = bool, Onchange = transaction unit] ++ boxAttrs) type file val fileName : file -> option string @@ -1010,7 +1010,7 @@ Ontext = transaction unit] ++ boxAttrs) [] val button : cformTag ([Value = string] ++ boxAttrs) [] -val ccheckbox : cformTag ([Value = bool, Size = int, Source = source bool] ++ boxAttrs) [] +val ccheckbox : cformTag ([Value = bool, Size = int, Source = source bool, Onchange = transaction unit] ++ boxAttrs) [] con cselect = [Cselect] val cselect : cformTag ([Source = source string, Onchange = transaction unit] ++ boxAttrs) cselect diff -r 924e2ef31f5a -r 2da693675de9 lib/ur/string.ur --- a/lib/ur/string.ur Mon Jun 09 18:26:03 2014 -0400 +++ b/lib/ur/string.ur Tue Jun 10 10:58:22 2014 -0400 @@ -86,3 +86,28 @@ fun isPrefix {Full = f, Prefix = p} = length f >= length p && substring f {Start = 0, Len = length p} = p + +fun trim s = + let + val len = length s + + fun findStart i = + if i < len && Char.isSpace (sub s i) then + findStart (i+1) + else + i + + fun findFinish i = + if i >= 0 && Char.isSpace (sub s i) then + findFinish (i-1) + else + i + + val start = findStart 0 + val finish = findFinish (len - 1) + in + if finish >= start then + substring s {Start = start, Len = finish - start + 1} + else + "" + end diff -r 924e2ef31f5a -r 2da693675de9 lib/ur/string.urs --- a/lib/ur/string.urs Mon Jun 09 18:26:03 2014 -0400 +++ b/lib/ur/string.urs Tue Jun 10 10:58:22 2014 -0400 @@ -33,3 +33,5 @@ val newlines : ctx ::: {Unit} -> [[Body] ~ ctx] => string -> xml ([Body] ++ ctx) [] [] val isPrefix : {Full : t, Prefix : t} -> bool + +val trim : t -> t