X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=scripts%2Fedit.ml;h=bf7b482a75a30b13f6cf5c70eae9ba1823b6e3f5;hb=35f3941cfe3d70d720604da0b2c8850ef704a92d;hp=47ab1fcea63d12e0d3fb6ccf4b6bbb1591358e8b;hpb=11b93485a29771f4d826c50d9efc6d3607dfa50f;p=cocanwiki.git diff --git a/scripts/edit.ml b/scripts/edit.ml index 47ab1fc..bf7b482 100644 --- a/scripts/edit.ml +++ b/scripts/edit.ml @@ -1,7 +1,7 @@ (* COCANWIKI - a wiki written in Objective CAML. * Written by Richard W.M. Jones . * Copyright (C) 2004 Merjis Ltd. - * $Id: edit.ml,v 1.8 2004/09/09 12:21:22 rich Exp $ + * $Id: edit.ml,v 1.9 2004/09/20 10:56:47 rich Exp $ * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -118,12 +118,16 @@ let run r (q : cgi) (dbh : Dbi.connection) hostid { hostname = hostname } _ = "(ie. not to a page which is itself a redirect).") ); - (* All sections have sectionnames? *) - List.iter (function (sectionnames, _, _) - when string_is_whitespace sectionnames -> - add_error ("Every section must have a title."); - | _ -> ()) - model.contents; + (* All sections after the first one have sectionnames? The first + * section ONLY is allowed to have an empty title. + *) + if model.contents <> [] then + List.iter (function (sectionnames, _, _) + when string_is_whitespace sectionnames -> + add_error + ("Every section except the first must have a title."); + | _ -> ()) + (List.tl model.contents); get_errors () in @@ -247,7 +251,8 @@ let run r (q : cgi) (dbh : Dbi.connection) hostid { hostname = hostname } _ = | _ -> assert false in (* Get the sections. *) - let sth = dbh#prepare_cached "select sectionname, content, + let sth = dbh#prepare_cached "select coalesce (sectionname, ''), + content, coalesce (divname, '') from contents where pageid = ? @@ -429,9 +434,12 @@ let run r (q : cgi) (dbh : Dbi.connection) hostid { hostname = hostname } _ = let divname = if string_is_whitespace divname then `Null else `String divname in + let sectionname = + if string_is_whitespace sectionname then `Null + else `String sectionname in incr ordering; let ordering = !ordering in sth#execute [`Int pageid; `Int ordering; - `String sectionname; divname; + sectionname; divname; `String content]) model.contents;