1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980# 1 "Camomile/public/locale.ml"(* Copyright (C) 2003, 2011 Yamagata Yoriyuki *)(* This library is free software; you can redistribute it and/or *)(* modify it under the terms of the GNU Lesser General Public License *)(* as published by the Free Software Foundation; either version 2 of *)(* the License, or (at your option) any later version. *)(* As a special exception to the GNU Library General Public License, you *)(* may link, statically or dynamically, a "work that uses this library" *)(* with a publicly distributed version of this library to produce an *)(* executable file containing portions of this library, and distribute *)(* that executable file under terms of your choice, without any of the *)(* additional requirements listed in clause 6 of the GNU Library General *)(* Public License. By "a publicly distributed version of this library", *)(* we mean either the unmodified Library as distributed by the authors, *)(* or a modified version of this library that is distributed under the *)(* conditions defined in clause 3 of the GNU Library General Public *)(* License. This exception does not however invalidate any other reasons *)(* why the executable file might be covered by the GNU Library General *)(* Public License . *)(* This library is distributed in the hope that it will be useful, *)(* but WITHOUT ANY WARRANTY; without even the implied warranty of *)(* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *)(* Lesser General Public License for more details. *)(* You should have received a copy of the GNU Lesser General Public *)(* License along with this library; if not, write to the Free Software *)(* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 *)(* USA *)(* You can contact the authour by sending email to *)(* yoriyuki.y@gmail.com *)typet=stringletrecparse_locale_auxis=leti'=tryString.index_fromsi'_'withNot_found->String.lengthsinString.subsi(i'-i)::ifi'>=String.lengthsthen[]elseifi'=String.lengths-1then[""]elseparse_locale_aux(i'+1)sletparse_locale=parse_locale_aux0letreccut_last=function[]->assertfalse|[_]->[]|x::rest->x::cut_lastrestletreadrootsuffixreaderlocale=letlocale_path=parse_localelocaleinletrecsearchlocale_path=letbasename=iflocale_path=[]then"root"elseString.concat"_"locale_pathintryDatabase.readrootsuffixreaderbasenamewithNot_found->iflocale_path=[]thenraiseNot_foundelsesearch(cut_lastlocale_path)insearchlocale_pathletreclist_containl1l2=matchl1,l2with[],_->true|_,[]->false|x1::rest1,x2::rest2->ifx1=x2thenlist_containrest1rest2elsefalseletcontainloc1loc2=letl1=parse_localeloc1inletl2=parse_localeloc2inlist_containl1l2