1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889# 1 "Camomile/public/uText.ml"(** An implementation of Unicode string. *)(* Copyright (C) 2002, 2003 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 *)includeArraytypemutability=[`Mutable|`Immutable]type'atext=UChar.tarraytypeutext=[`Imutable]texttypet=utexttypeustring=[`Mutable]textletutext_of_ustring=Array.copyletustring_of_utext=Array.copytypeindex=intletlooksi=getsiletnth_i=iletfirst_=0letlasts=Array.lengths-1letout_of_rangesi=i<0||i>=Array.lengthsletnext_i=i+1letprev_i=i-1letmove_in=i+nletcompare_index_(i:int)(j:int)=i-jletmakeleninit=Array.makeleninitletinit_ustring=initletof_strings=init(String.lengths)(funi->UChar.of_chars.[i])letreccompare_auxit1t2=ifi>=lengtht1thenifi>=lengtht2then0else~-1elseifi>=lengtht2then1elsematchUChar.compare(gett1i)(gett2i)with0->compare_aux(i+1)t1t2|sgn->sgnletcomparet1t2=compare_aux0t1t2moduleBuf=structincludeXArraytypebuf=UChar.txarrayletcreatebufsize=XArray.make~bufsize0(UChar.chr_of_uint0)letcontents=array_ofletcontents_string=array_ofletadd_char=add_elementletadd_string=add_arrayletadd_buffer=add_xarrayend