]> git.saurik.com Git - wxWidgets.git/commitdiff
files of wxMac moved into carbon subdirs
authorStefan Csomor <csomor@advancedconcepts.ch>
Fri, 26 Mar 2004 20:46:31 +0000 (20:46 +0000)
committerStefan Csomor <csomor@advancedconcepts.ch>
Fri, 26 Mar 2004 20:46:31 +0000 (20:46 +0000)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@26374 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

26 files changed:
src/mac/macsock/sock_PPC.lib [deleted file]
src/mac/morefile/DirectoryCopy.c [deleted file]
src/mac/morefile/DirectoryCopy.h [deleted file]
src/mac/morefile/FSpCompat.c [deleted file]
src/mac/morefile/FSpCompat.h [deleted file]
src/mac/morefile/FileCopy.c [deleted file]
src/mac/morefile/FileCopy.h [deleted file]
src/mac/morefile/FullPath.c [deleted file]
src/mac/morefile/FullPath.h [deleted file]
src/mac/morefile/IterateDirectory.c [deleted file]
src/mac/morefile/IterateDirectory.h [deleted file]
src/mac/morefile/MoreDesktopMgr.c [deleted file]
src/mac/morefile/MoreDesktopMgr.h [deleted file]
src/mac/morefile/MoreFiles.c [deleted file]
src/mac/morefile/MoreFiles.h [deleted file]
src/mac/morefile/MoreFilesExtras.c [deleted file]
src/mac/morefile/MoreFilesExtras.h [deleted file]
src/mac/morefile/Optimization.h [deleted file]
src/mac/morefile/OptimizationEnd.h [deleted file]
src/mac/morefile/Search.c [deleted file]
src/mac/morefile/Search.h [deleted file]
src/mac/morefilex/MoreFilesX.c [deleted file]
src/mac/morefilex/MoreFilesX.cpp [deleted file]
src/mac/morefilex/MoreFilesX.h [deleted file]
src/mac/morefilex/MoreFilesXReadMe.txt [deleted file]
src/wxWindows.pbproj/project.pbxproj

diff --git a/src/mac/macsock/sock_PPC.lib b/src/mac/macsock/sock_PPC.lib
deleted file mode 100644 (file)
index a85c82a..0000000
+++ /dev/null
@@ -1 +0,0 @@
-(This file must be converted with BinHex 4.0)\r:!!"08%a'3eG*43!!!!-3A!!!!4ijQ8eA6d*38%-J!*!(!3!![XJ!!#4S!!!!#V#\rXlYd!!!$N!!!!mJ!!!e`!!#2bXQAFf3!!!5B!!!%f!!!R8!!!Y4ka,F84!!!"E!!\r!!AJ!!0a`!!!B@,*Pi@S!!!'U!!!"YJ!!p-J!!&Q!XQ-ZeJ!!!HJ!!!(e!!&15!!\r!GFk[r%YD!!!#+!!!!M3!!F3B!!!RbUj'*kS!!!*Q!!!#G!!"kq3!!"b+XQAX)3!\r!!UJ!!!+c!!))F!!!CV#`V2#X!!!#j!!!!Zm!!QmJ!!"!3,#pbM)!!!-J!!!$+`!\r#Vf!!!'$m4e9658*eCQCPFLjMF!"%CACPE'p`E@9ZG$T%CA0VG'p`)%C[E'4PFMT\r$9dG98dNkFh*M1NG98dP#G@CQCA)ZBh!!4e96584TFh"KG'0S,Q0`!%4PGQ9XEh"\rYC@jd1N4PFfYdEh!J4QpXC'9b1N0A4e9656TcFQ-k4e96584TFh"KG'0S,Q0`!%G\r98dP(E'pL,Q0`!%4PGQ9XEh"YC@jd1N4PFfYdEh!J4QpXC'9b1N0A4e9656TcFQ-\rk4e9658GXEf)ZBh!!4e9658P1493ZBh!!4'9fC@a[F'ePER3k4'9cDh4[F#"'Efa\rNCA)k3eG(990*1R0bBcT(990*58j&9#jMF!"(990*6Q9d4%)ZBh!!4'9fC@a[F'e\rPER3k4'9cDh4[F#"'EfaNCA)k3eG(990*1R0bBcT(990*6Q9d4%)ZBh!!4e9658j\reE'`ZBh!!4'9fC@a[F'ePER3k4'9cDh4[F#"'EfaNCA)k3eG(990*1R0bBcT(990\r*6R9XE#jMF!"(990*8fpMDf9d,Q0`!%4PGQ9XEh"YC@jd1N4PFfYdEh!J4QpXC'9\rb1N0A4e9656TcFQ-k4e96590[BfYPG#jMF!"(990*9%03,Q0`!%4PGQ9XEh"YC@j\rd1N4PFfYdEh!J4QpXC'9b1N0A4e9656TcFQ-k4e96594$8#jMF!"(990*9843,Q0\r`!%4PGQ9XEh"YC@jd1N4PFfYdEh!J4QpXC'9b1N0A4e9656TcFQ-k4e96599%8#j\rMF!"(990*4P0`,Q0`!%4PGQ9XEh"YC@jd1N4PFfYdEh!J4QpXC'9b1N0A4e9656T\rcFQ-k4e9658C6F#jMF!"36eG5!*!'&5!!!"hd!!!!EJ!!&B`!!!KS!!!*m!#3"J'\rc!!!!$!#33%9R!!"&D3#3"3&&DJ!%!!!!!J!!!(3!!!!J!!!$Zh`)!UDrBIrXN!!\r"!!L8)Iq`1i-!!$ZN!!!la3!!1qB!!(`Hq%"!J3!i1(`!!$LG!!!i[!!!10m!!%J\r!!!%lB`!!1(`!!$LG!!!i[J!!10d!!%J!!!&mBpS85!!!#(aqq&#!!3"B1#%!8(`\r)!kDlBIrX6S!!)%9e!*!&!J!!!$K&G3#3"3)!!!"34@i-"!!!!!F!!!!-J!#3#i!\r!!(3S!!!!4AF!N!8#!*!%4@X!"!!!!!J!!!#-!!!!I!!!"@am#!+QNq(rr*2"rrL\r3!!%!#*3Krm!li`!!1m3!!&5$"$j)!!!"B!!!!*!!I`!!J(m!!&I!"$jm!`)8N!!\rI!!5!(`!!N!!I!!L!(`!!N!!I!!bch`!31!!!!,!I!")i!!!!X"m!&$J!!!#B(`!\r@1!!!!*!!(`!B1(m!!)!"!%Ji)3"!I!J$TS2Krrb$`Iri6S!!)%9e!*!&#3!!!#"\r&EJ`%!!!!&`!!!!b!!*!,J!!!M"!!!!"&G`#3"3J!N!4&D`!%!!!!'!!!!'`!!!#\rd!!!'FR`)!UD6iIrmN!!"!!L8)Ir!I(mEHE#"!&j"JJ!m1!!!!CJI!"D!(`!!+!!\r!!%'#!"#!I`!!5!!!!@!!!!#S!3"H,!!!!%#"!"!iI`!!5!!!!@!!!!!iI`!!J!%\r!5$JK!%"m#!1QJq(rr%k!!#"&G3#3"4N!!!!d4A8!N!8D!!!!6%9Z$!3!!!!E!!!\r!$)!!N!Z!!!"X#!!!!%9h!*!&'!#3"%9V!!3!!!!F!!!")!!!!1B!!!DqI!J#TT2\rKrrb6`IriNk(rp*1"rr#3!!%!#*3Krl!li`!!1i3!!$J!!!'B!`!@S!-!%LJ!!!"\r!JJ!FJ"m!!*!!(`!-J"m!!*!!(`!)1!!!!,!I!"5!I`!-J"m!"(r$!&#$[`!-9m-\r%2U!I!""m!`"!3B!!$+2I!"")!!"-9m-%2U!I!""m!!j`I!-!!%#!!$KA``3qJ"`\r!!(`$!!"!J!!SXpm!&)!I!!#3!"m!$+"r!"5J(`!3I!-!8,!I!"#Mh`!3Jlm!$)"\rm!!"A`!3qI!-!!%#"!!aA`!3qN!!F!!!i!!!!Q"m!&S!I!"JS!!!!3B)!&)"r!"b\r"R`!B5!!!!@!!!!!iI3!!J!%!@$JK!&"m#!1QJq(rr)2"rrL$SIrdJi(rm%k!!#"\r&G3#3"4d!!!$d4@i-"!!!!#%!!!!-J!#3#i!!!5!J!!!!4AF!N!8F!*!%4@X!"!!\r!!#)!!!#i!!!"HJ!!#-Ym#!+QNq(rr*2"rrL6SIrdNi(rm*!!!3!)P#(rX$[M!!!\rlK!!!1!!!!CJ$!"DJJ`!8J'-!#)!I!!4m!`"3Im3!8)1r!!KA``3qS"m!%R`$!%"\r!J3!)Spm!%S"m!!"A`!3qI!-!!%#"!!aA`!3qN!!F!!!i!!!!Q"m!&S!I!"JS!!!\r!3B)!&)"r!"b"R`!B5!!!!@!!!!!iI3!!J!%!@$JK!&"m#!1QJq(rr)2"rrL$SIr\rdJi(rm%k!!#"&G3#3"4d!!!#-4@i-"!!!!#-!!!!-J!#3#i!!!,JJ!!!!4AF!N!8\rL!*!%4@X!"!!!!#3!!!#F!!!"lJ!!#J&m#!+QNq(rr*2"rrL3!!%!#*3Krm!li`!\r!1m3!!$J!!!'B!`!@S!-!%R`!mK5`!`!5S!-!%(`H!&#`!`!3J!-!$(`!mK53!!-\r!$)"M!!b!(`!%I!-!3%##!!b!(`!!N!!I!!`i!!!!Q"m!&S!I!"JS!!!!3B)!&)"\rr!"b"R`!B5!!!!@!!!!#!!3")1#%!3(`)!kD$iIrmJm(rq%k!!#"&G3#3"4d!!!"\rm4@i-"!!!!#8!!!!-J!#3#i!!!*`3!!!!4AF!N!8N!*!%4@X!"!!!!#B!!!$B!!!\r#0J!!#YCm#!+QNq(rr*2"rrL3!!%!#*3Krm!li`!!1m3!!$J!!!'B!`!@S!-!%(`\r!mK5`!`!3S!-!%R`H!&#`!`!5J!-!#(`!mK53!!-!#)#$!!LJB`!8J"m!"(`$!&"\rm"!"!3))!')!I!!#3!"m!#$J!!!#`(`!85!!!,+!I!")S!!!!3))!)+!I!""m!2!\r!3))!&)!I!!#3!"m!#)!I!!#3!"m!$$J!!!#B(`!@J"m!'#J!!!""JJ!8J(m!()'\rI!"K)!!!"B!!!!)!"!%Ji)3"!I!J$TS2Krrb$`Iri6S!!)%9e!*!&(3!!!,K&EJ`\r%!!!!*`!!!!b!!*!,J!!!f"!!!!"&G`#3"5B!N!4&D`!%!!!!+!!!!*3!!!+1!!!\r-1A`)!UDrBIrXN!!"!!L8)IqJ1q-!!$Z%!!!lC3!!Jm8!!%J!!$`iI`!!1)%!1%J\r!!!%iR!!!J+%!1%J!!!&J!!!!1(m!!)#"!$K)!!!"J!%!1(qF!K5!!3!iIm$`8*2\r"!$JX(J!!3B)!%+!I!")S!!!!3),rY)!E!!"m(J"3N!!E!!#!!3"S1#%!B(`)!kD\rlBIrX6S!!)%9e!*!&)J!!!#a&G3#3"5N!!!!i4A8!N!8Q!!!!5%9Z$!3!!!!Y!!!\r!$)!!N!Z!!!#8+!!!!%9h!*!&+!#3"%9V!!3!!!!Z!!!!R!!!!bi!!!fdI!J#TVp\rKrqb3!!%!#*3Krk!li`!!1i3!!$YP!!#$a3!!5!!!4$Kr!!!iJ3!i5!!!!6ZM!!!\riI!!!1*d!!)#K!$K)!!!"B!!!!$Kr!!#!J3!i5!!!!B!"!$KrR!)8J!%!1(r!m&#\r6`3!i,"i!!%'#!"#J(`!3+!!!!%##rkb!'`!!I"i!8*!!'`!!J!%!D$JK!'"m#!1\rQZf(rl%k!!#"&G3#3"4`!!!!X4A8!N!8T!!!!3%9e!*!&*!!!!&"&EJ`%!!!!,`!\r!!!b!!*!,J!!!R#J!!!"&G`#3"5i!N!4&D`!%!!!!-!!!!4!!!!21!!!2Jh`)!UD\r6iIrmNm(rq*1Krr53!!%!#*3Krl!li`!!1m3!!$ZP!!#!!J!!N!!$!"56``!3Nk-\r!$)!$!!`X!!!"3)!!)$J!!!#3!"m!"$J!!!#3!"m!#$J!!!#3!"m!!%J!!*L!(`!\r-,!!!!8##!##!(J!!N!!I!!5!(J!%N!!I!!Ji!!!!N!!I!!")!!"`1!!!!*!!(`!\r)5!!!')"r!!L!(J!%I!-#&*!!(`!)1pi!##`G!!!l[Irr3),rj)"r!!K)!!!"B!!\r!!*!!I`!!J"m!!#J!!!""JJ!JJ(m!!%J!!!&J!!!!J(m!!)!$!!#3!"m!"%J!!!`\ri!!!!N!!I!!3iI`!!J!%!@$JK!&"m#!1QJq(rr)2"rrL$SIrd6S!!)%9d!`#3"$%\r!!!!N4A8!N!8b!!!!Y%9e!*!&-`!!!0"&EJ`%!!!!2J!!!!b!!*!,J!!"%"J!!!"\r&G`#3"6!!N!4&D`!%!!!!2`!!!'`!!!4F!!!44(`)!UD6iIrmN!!"!!L8)Ir!I(m\rEHE#"!&j"JJ!mJ!)!!*!!(`!8J"m!!#J!!!""JJ!3J(m!!%J!!!&J!!!!U!%!AL`\r!!!"!J3!31(m!!%J!!!&J!!!!1(m!!)!"!%Ji)3"!I!J$TS2Krra1J!!J4A3$!*!\r%-3!!!"a&G3#3"8!!!!!d4A8!N!8D!!!!6%9Z$!3!!!""!!!!$)!!N!Z!!!"X#!!\r!!%9h!*!&2`#3"%9V!!3!!!"#!!!!5!!!")B!!"'*I!J#TT2Krrb3!!%!#*3Krm!\rli`!!N!#"!&b3!+%!B)#"!&b!S3"J5!!!!B!#!!#3!"m!&$Kr!!#!!3")1#%!3(`\r)!kD$iIrm6S!!)%9e!*!&-!!!!#4&G!-!N!4$!!!!+%9Z$!3!!!"'!!!!$)!!N!Z\r!!!")#!!!!%9h!*!&3J#3"%9V!!3!!!"(!!!"#!!!"-3!!"(KI!J#TT2Krrb6`Ir\riNk(rp*!!!3!)P#(rX(ar'hQ`J3"Z3B)!b)!#!!#3!"m!&)!I!!`X!!!"3)%!N!#\r!(`!%+!!!!%'#!)5$[`!%5!!!A)#I!!L!I`!3J!-!"(`%!!"!J!!-Jpm!#%J!!!b\r!I`!3Jm-!")"r!"#!B`!!1*d!!$Lq!!")!!!"B!!!!(qpmK5!(`!)I"i!8*!!(`!\r)J(m!%$J$!!L3!"m!%)"r!!`i!rrrN!!I!!`X!`!!3B)!%)!I!!JX!!!!3),rM$K\rr!!!iJ!!!5!!!!DJ"!'iX!!!!3)%!%$Kr!!")!!!"B!!!!$Kr!!#!!3"B1#%!8(`\r)!kD$iIrmJm(rq)1Krr41J!!J4A3$!*!%3`!!!#4&G3#3"8J!!!#!4A8!N!8r!!!\r!c%9e!*!&'J!!!1"&EJ`%!!!!5`!!!!b!!*!,J!!"#"J!!!"&G`#3"8F!N!4&D`!\r%!!!!6!!!!+!!!!8U!!!5dA`)!UD6iIrmNm(rq*1Krr56JIr`N!!"!!L8)Iq`1i-\r!!$[N!!!lT3!!5!!!!B!#!!#3!"`!&#`G!!&!J3"%J"`!"#J!!!""JJ!iJp`!"%J\r!!#3iIJ!!J*m!!)#r!!4)!!!"B!!!!)!I!!4rhJ)81rm!##`G!!!l[Irr3),rf$K\rm!!#!!3"B1#%!8(`)!kD$iIrmJm(rq)1Krr5$JIr`6S!!)%9e!*!&-!!!!#K&G!-\r!N!40!!!!,%9e!*!&5!!!!&a&EJd#!!!!6`!!!"D!!*!()!!!B!"J!!S!!)D!!"`\r!N!T&GJUF!!!!8!!!!"*&EJ`%!!!!83!!!!b!!*!1S!#3"%9h!*!&6!#3"%9h$3#\r3"%m!!!!)4@X!"!!!!&)!!!"J!!!&RJ!!%m*m#!+QNq(rr*!!!3!)P#(r`(ar'hQ\r`J3"H3B)!-)!#!!#3!"m!&$Kr!!!iJ!!!5!!!!DJ"!&iX!!!!3)%!%$Kr!!")!!!\r"B!!!!$Kr!!#!!3")1#%!3(`)!kD$iIrm6S!!)%9d!`#3"%d!!!!F4A8!N!8r!!!\r!,%9e!*!&'J!!!%"&EJ`%!!!!8`!!!!b!!*!,J!!!B!J!!!"&G`#3"9)!N!4&D`!\r%!!!!9!!!!$`!!!A!!!!6hC2Krr`li!!!5!!!&)J$!!!lr`!"I!6jVMKM!!')!`!\r!I!!(G8'#!!`X(`$r3B$ri*[N!!#$iIrm6S!!)%9Z"3%!!!"A!!!!#Irrrr-!!"2\rG4f&dD'9bCA)!!"334@i&!3!!!&J!!!!+rrrrmJ!!%pe6Bf&dG%GKG'J!!!"&EJ8\r%!!!!@3!!!!Mrrrra!!!6h3#3#%9f"3#3"&J!N!4&EJ8%!!!!@J!!!!crrrr`!!!\r6h3#3$%9f"3#3"&N!N!4&EJ8%!!!!@`!!!!Mrrrr[!!!6h3#3#%9f"3#3"&F!N!4\r&GJ8!N!4D!!!!"%9["33!!!"0!!!!$2rrrqi!!"2G!*!-4AB&!*!%@`#3"%9f#J#\r3"&`!!!!)4@i&!3!!!&d!!!!+rrrrl3!!%pe6Bf&dG'9bCA)!&""&EJ8%!!!!AJ!\r!!!crrrrX!!!6h3#3$%9f"3#3"&N!N!4&EJ8%!!!!A`!!!!MrrrrV!!!6h3#3#%9\rf"3#3"&d!N!4&GJ8!N!4H!!!!"%9["33!!!"$!!!!$2rrrqS!!"2G!*!-4AB&!*!\r%A`#3"%9f#J#3"'!!!!!)4@m&"!!!!$%!!!!-rrrrk3!!%pd!N!a&GJ8!N!4C!*!\r%4AB+!*!%8!!!!!K&E`S%!!!!B3!!!!L!!*!24AB!N!98!*!%4AB2!*!%BJ!!!!4\r&E`S%!!!!A!!!!!L!!*!24AB!N!95!*!%4AB2!*!%BJ!!!!4&E`S%!!!!B`!!!!L\r!!*!24AB!N!9-!*!%4AB2!*!%BJ!!!!4&E`S%!!!!B!!!!!L!!*!24AB!N!9(!*!\r%4AB2!*!%BJ!!!!4&E`S%!!!!C!!!!!L!!*!24AB!N!9#!*!%4AB2!*!%BJ!!!!4\r&E`S%!!!!8!!!!!L!!*!24AB!N!8r!*!%4AB2!*!%BJ!!!!4&E`S%!!!!C3!!!!L\r!!*!24AB!N!8`!*!%4AB2!*!%BJ!!!!4&E`S%!!!!CJ!!!!L!!*!24AB!N!8Z!*!\r%4AB2!*!%BJ!!!!4&E`S%!!!!C`!!!!L!!*!24AB!N!8S!*!%4AB2!*!%BJ!!!!4\r&E`S%!!!!D!!!!!L!!*!24AB!N!8Q!*!%4AB2!*!%BJ!!!!4&E`S%!!!!D3!!!!L\r!!*!24AB!N!8N!*!%4AB2!*!%BJ!!!!4&E`S%!!!!DJ!!!!L!!*!24AB!N!8L!*!\r%4AB2!*!%BJ!!!!4&E`S%!!!!D`!!!!L!!*!24AB!N!8F!*!%4AB2!*!%BJ!!!!4\r&E`S%!!!!E!!!!!L!!*!24AB!N!8B!*!%4AB2!*!%BJ!!!!4&E`S%!!!!E3!!!!L\r!!*!24AB!N!8)!*!%4AB2!*!%BJ!!!!4&E`-%!!!!63!!!!5!!*!,4AB&!*!%63#\r3"%9[!`3!!!"$!!!!")!!N!Y&GJ8!N!4$!*!%4@m$"!!!!$%!!!!%J!#3#d9f"3#\r3"$%!N!4&E`m%!!!!BJ#3")!!N!G&D!!!8eP05!!!"Ki!!!!A!!!!#!#3%3%!N!B\r$p3!!!#J!!!3*!!!!A!!!"&RrN!3!!!4T!!3!!!!$!!!!CJ%!N!3F!!!!"!!!!'B\r"!*!%(3!!!!8!!!"Q!3#3""i!!!!'!!!!CJ%!N!3I!!%!N!B&N`!!!#!!!!@@rj!\r%!!!'E`!#!!!!#[q3"!%!N!3I!!!!&J!!!!S"!*!%(J!"!*!'"S`!!!!F!!!'M`!\r!!$!!!!DRrj!%!!!'Z`!"!!!!#[q3"!%!N!3I!!%!N!B'i`!!!$J!!!FY!!!!8!!\r!"fJ!!!"`!!!(ZJ!!!(J!!!I2!!!!R!!!"rd!!!$!!!!)A`!!!0!!!!Kc!!!!f!!\r!#+i!!!$m!!!)[2q3"!!!#-J!"!!!!!VrN!3"!*!%(`!!!"lrrrrm!3#3""`!!!!\rI!!!!CJ#3"4d!!!!J!!!!#J#3"4i!!3#3"JM`!!!!9!!!#B3!!!"B!!!*P3!!!'J\r!!!QT!!!!F!!!#H3!!!#8!!!*m[q3"!!!#Ii!"!!!!!VrN!3"!*!%(`!!!"lrrrr\rm!3#3""`!!!!I!!!!CJ#3"4d!!!!J!!!!#J#3"4i!N!J+*3!!!&J!!!UK!!!!B!!\r!#XJ!!!#%!!!+drq3"!!!#Y-!!J!!!!VrN!3"!*!%(`!!!"i!!!!$!3#3""i!N!J\r+r!!!!'!!!!Z"!!!!G!!!#kN!!!#-!!!,l3!!!*`!!!`V!!!!`!!!$$ErN!3!!!`\rf!!)!!!!+rj!%!3#3""m!!!!H!!!!!`%!N!3H!*!)$'B!!!!N!!!0"3!!!$J!!!d\rG!!!!3!!!$6N!!!"-!!!063!!!&`!!!eE!!!!G!!!$@!!!!#!!!!0XIq3"!!!$E%\r!"J!!!!VrN!3"!*!%(`!!!!B!!!"Q!3#3""`!!!!Hrrrrr!%!N!3E!!!!+J!!!'B\r!N!8G!!!!+`!!!!-!N!8H!!!!,!!!!!-!!`!!!$J!N!J0i`!!!#3!!!k%!!!!3!!\r!$T`!!!")!!!1ZJ!!!&3!!!l2!!!!C!!!$Yi!!!"m!!!1i`!!!)J!!!mirj!%!!!\r21!!'!!!!#[q3"!%!N!3I!!!!"3!!!'B"!*!%(!!!!"lrrrrm!3#3""X!!!!U!!!\r!CJ#3"4d!!!!V!!!!!`#3"4i!!!!X!!!!!`!$!!!!1!!"!*!'$lS!!!"!!!!2k`!\r!!&`!!"!F!!!!D!!!%$%!!!#%!!!3LJ!!!*!!!!!3U3!!!,!!!"$*!!!!c!!!%2S\r!!!$B!!!4$3!!!1J!!"%b!!!!m!!!%8(rN!3!!"&"!!-!!!!+rrrrq`%!N!3I!!!\r!22rrrrN"!*!%(J!!!$d!!!!$!3#3""d!!3#3"K&F!!!!-!!!%@lrN!3!!"''!!%\r!!!!+rrrrq`%!N!3I!!%!N!B4a2q3"!!!%Gi!!`!!!!Vrrrrh!3#3""m!!!!mrrr\rrq3%$!!!!A!!!!$B!!!!$!3-!!!"J!!%!N!B4q3!!!$J!!")*!!!!4!!!%LB!!!"\r-!!!5A3!!!(!!!"+#!!!!T!!!%XcrN!3!!",1!!-!!!!+rrrrp`%!N!3I!!!!53!\r!!'B!N!8G!!!!5J!!!!-!N!8H!!%!N!B6#J!!!$`!!"-P!!!!5!!!%d)!!!"3!!!\r6F`!!!(!!!"1p!!!!I!!!%lrrN!3!!"1r!!3!!!!+rrrrp3%!N!3F!!!!22rrrrN\r"!*!%(`!!!$B!!!!$!3#3""d!!!"*!!!!CJ#3"4i!!3#3"K2Brj!%!!!6fJ!"!!!\r!#[rrrr8"!*!%(`#3#"33!!!!"!!!&"m!!!!-!!!8@!!!!$!!!"4G!!!!0!!!&'c\rrN!3!!"4X!!-!!!"9!!!!CJ%!N!3$!!!!9J!!!'X"!*!%"!!!!"i!!!!$!*!&(`!\r!rrrrr3!"!!!!DJ!#rrrrrJ!!!!X!!!!J!!S!!!!-!!!!CJ#3"`d!!!"Q!!!!"!!\r!!!i!!!"Q!!!!#!!!!!m!!!"Q!!!!$!!!!"!!!!!+!!!!%!!!!"%!!!!+!!!!%J!\r!!")!!!!+!!!!&!!!!"-!!!!'!!!!&J!!!"6rrrrp!!!!'!!!!"8!!!"N!!!!(!!\r!rj!%!!(rrrrq!!$rrrrm!!%!!!!$!!,rrrri!!!!1!!!!!J!!J!!!$N!!!"Q!*!\r(1J!!!!-!!!!%!!$rrrrj!!(rrrri!!,rrrrk!!!!0!!!!"J!"J!!!$8!!!"R!*!\r(+J!!!'3!!!!%!!!!(J!!!!-!!!!)!!!!0J!!!!-!!!!-!!!!0rrrrrN!!!!3!!!\r!1`!!!'3!!!!8!!$rrrrl!!(rrrrk!!,rrrrf!!!!4!!!!"J!!3!!!%Arrrrk!*!\r'rrrrp`!"rrrrpJ!#rrrrp!!!!%i!!!!B!!%!!!"&rrrrqJ#3"[rrrr8!!Irrrr3\r!!Irrrr-!!!!*!!!!!3!!!!F!!Irrrr)!!!!+!!!!!3!!!!F!![rrrr(rN!3!!!!\r)!!!!![rrrr$rN!3!!!!-!!!!![rrrqrrN!3!!!!)!!!!![rrrqlrN!3!!!!-!!!\r!!Irrrqd!!!!+!!!!!3!!!!F!![rrrqcrN!3!!!!-!!!!![rrrq[rN!3!!!!)!!!\r!![rrrqVrN!3!!!!-!!!!![rrrqRrN!3!!!!-!!!%U%G98dN!"'`Z8QPZCd4TFh4\rIAdC3Be"M8'03B`!&QA0dBA*d!!1RC@jN!!3cCR*[E3!#rA4[!!5F3$Fd13!'9#j\rIAf0dAema-&*TEQG#G@CQCA*'9A-!"p8Z6Q9h8(4b!!4EG'KTF`!#K&*TEQG#G@C\rQCA)!"J0LG@CQCA)!"NePEQ4LG@B!"d"MEfjcG@eP!!F`F(*[C(9MC3!%kQCbC@8\r!"GCfB@aTC!!&T(0`BA*P!!5VE'pMD`!(('4PCR"bEf-!!cTKFQF!"U"LG@CcDAS\r!",4!0c8a!!A%,PpIC(4IAc%`8QPZCd*eCQCPFNCf!!-),N4TFh"[Ff93G()!!Nm\rZAepNE&pI4P"f!!5l3$Fe1!!#Abj3FQpNG@0PFPpI-6"5D@jR3R9QCQ9b4P*X!!1\r8,PpIF(4bAfGXG@8!!maXC@i!!qPbCA-!"R"cG(*PB@X!"2C!0cFc!!)5,N0[ER0\reE@9bAema-&*TEQG#G@CQCA*'8Q`!""9!0cJb!!(L,PCKE'PNBA4PAema-&*TEQG\r#G@CQCA*'E!!%(%!h1$N!!e8Z5@jfB@aTC'&dC9pI-6"5D@jR3R9QCQ9b4Q`!"$G\r!1$!`!!--,N0[ER0eE@9IAc%`8QPZCd*eCQCPFNC3Be*X!!)[,N*XEf0V6@pfC3!\r$RQ*eCJ!%XA*PFh3!"&p`BA*d!!3r3$J`1!!$D#j3FQpNG@0PAema-&*TEQG#G@C\rQCA*'8'05E!!%A8!i-6B!!m!ZAepMG&pI190MBA4d4f&dD%C33c9TEhCPBfN!!,0\rIAhCdAemj8f0KG(4(BA4S!!+(,NjPGdKKEQ4XC3!'L#j)6'pMD`!"aP0MBA4d4f&\rdD!!((A0MFQ&dBfJ!"39MEh9ZG!!#R'P[!!8cD@pfC@-!!(*TEhCIBQ&cC3!($'P\r[GPpXC@i!"r0IAhC`G()N!!-*D@pf!!22Bfjd!!5C3$Jc-J!$R#jIAf4dAemj8f0\rKG(4(BA4S4RB!"X-Z4'PcF'pcC8KKEQ4XC3!%Rd!i-cJ!!i-ZAepMG&pI190MBA4\rdCA*PFNC33c9TEhCPBfN!!%jIAhCdAemj8f0KG(4PFQ9b!!&"8f0KG(4PFQ9b!!)\rq*&0MBA4d4f&dD!!%Yd!i0$!!!bdZAepNG&pI190MBA4dCA*PFNCf!!GP,QePE@0\r`H3!%df*`G()!"#pcC@0d!!6D3$Je-`!#hLjIAf0dAemi4f&dD'9bCA*'8%-eD@p\rfC@0T!!GTAepfG&pI1%GKG'KPFQ9b!!"-4f&dD'9bCA)!"2T!1$Bc!!*lAepNG&p\rI190MBA4d4f&dD%Cf!!6l3$Jf0!!#0LjIAf4dAemi4f&dD'9bCA*'GJ!%rd!i0MJ\r!"#%Z3fp`H8-b8&0dFPpI4P"$Be"9B`!%Af0cG()!"!C`Fh4b!!3G3$Jh0J!%(d!\ri0cJ!!P0IAe*89%PIAcP6Bf&dG%GKG'J!""j!1$Fh!!'MAep59&4*Aemi4f&dD'9\rbCA)!!DjIAf4dAemi4f&dD'9bCA*'GJ!%)%!i0cN!"$K!1$J`!!*ZAep59&4*Aem\rj8f0KG(4PFQ9b!!)-AepNG&pI190MBA4dCA*PFNCf!!0Q3fp`H8-b8&0dFPpI4P"\r$Be"9B`!$IP423`!")&pIBh4IAcK(BA4SCA*PFNC33c9TEhCPBfN!!PpIAf0dAem\rj8f0KG(4PFQ9b4P"$0@P[GQ9MD3!#N9pIBh4IAcP6Bf&dG%GKG'K'8%-eD@pfC@0\rT!!,48(*[C(9MC9pI-6"5D@jR3R9QCQ9b4P"M8Q`!!QT$EfjcG@ePAema-&*TEQG\r#G@CQCA*'8'05E!!#ZNPZGQ&XD@4KG'9IAc%`8QPZCd*eCQCPFNCX!!#&9Q&XD@4\rKG'9IAc%`8QPZCd*eCQCPFNCX!!(l3fpZFh9YCA*IAc%`8QPZCd*eCQCPFNC5E!!\r"I&"bEf4eBf9bAema-&*TEQG#G@CQCA*'8Q`!"1aIAf4dAema-&*TEQG#G@CQCA*\r'GJ!&%&pIBh4IAc%`8QPZCd*eCQCPFNC9F`!!45K36eG5!*!'Df`!!*@B!!!#E!!\r!DpJ!!#R!!!!`D!!!!Ed!!!@a!!!!R!#33%9R!!"&D3#3"3&&E`8%!!!!(3!!!!6\rrrrrf!!!$&!#3"%9f#J#3""i!N!4&E`8%!!!!(`!!!!6rrrrf!!!$33#3"%9f#J#\r3"#!!N!4&E`8%!!!!)J!!!!3!!!!$!!!$Q!!!!!&&EK!%!!!!*3!!!!3!!!!$!!!\r$q[q3"%9V!!3!!!!f!!!!'!!!!#!!!!LY,!-!!%'#!!b!JJ!!N!"N!!!iB2rr6S!\r!)%9d!`#3"$F!!!!)4@X!"!!!!$N!!!!B!!!!8J!!#4-X!`!!3B)!$)##!!#3!'3\r!!$KJ!!"1J!!J4A3$!*!%0`!!!!K&EK!"!!!!2!!!!!,rrrrd!!!+%MS!!!"&D`!\r%!!!!23!!!qJ!!!#%!!!+%R`)!UDr)IrNN!!"!!L8)IqJ1m-!!)0#!!")!!!"B!!\r!!$XM!!#)'J!!+!!!!%##!"#!BJ!!Xb-!!%J!!"5!BJ!!U'-!!%J!!!&J!!!!2'"\r(9ML!+!!iBlG*5!!!!@!!!!"mI"Yj3B)!&$Km!!")!!!"B!!!!%J!!!JiB!!!1f-\r!!#`E!!4"J!!BJ(`!!)!$!!#3!"i!!#J!!!"!JJ!32'"846KM@&53!(i!!#`E!!K\r"J!!BJ(`!!)!$!!53!"i!"#J!!!"!JJ!32'"08$KM8b#3!(i!"#`E!!P!J!!31!!\r!!CJH!!K)!!!3J(`!!)J$!!LB(J!),"X!$N#!!"3mB$!a1'-`-T!!IJ!35!!!%)"\rm!!#!!`!+N!!H!"!X'`!+3)!!3$J!!!#B(J!*1!!!!*JH!!Si!!!!Q"i!#cJ!!!#\rB(J!-1!!!!*JH!!di!!!!Q"i!$MJ!!!#B(J!25!!"5)"m!!#)!`!*9!-'-$J!!!"\rmB`"3-!2rrh`!'4#B(J!*J(`!!)J$!!P8!`Cb1!!!!(aM!&!`!rrrI!!C%*JH!!S\riJ!!!J"i!%$aJ-$%iBc8`I!!B3%'!!#b!(J!32'!`-6KM1$"m!"K!3B%!')"m!!#\r)!`!*9!!(18'#!!JiJ!!"Q*i!#cL!!!#!(J!32'!`-6KM1$&m!"K!3B!!')"m!!#\r)!`!*9!!(18'#!!JiJ!!"Q*i!$cL!!!#!(J!32'!`-6KM0c4m!"K!3B!!')"m!!#\r)!`!*9!!(Hd'#!!JiJ!!"Q*i!$$L!!!#!(J!32'!`-6KM0c4m!"K!3B!!')"m!!#\r)!`!*9!!([8'#!!JiJ!!"Q*i!$6L!!!#!(J!32'!`-6KM0c4m!"K!3B!!')"m!!#\r)!`!*9!!(rd'#!!JiJ!!"Q*i!$S!H!"!mB$!a1'-b-(`!'%""J!!-,"X!%%#!!"!\ri!!!!X"i!&%J!!"#!I!!!U!-!$V!H!"5S(J!8,!!!!%##!"!i!!!!N!!H!"C)!!#\rNU"i!&"aJ!!a)!!!"B!!!!*!!IJ!@+!-!!%'#!)JiI!!!5!!!!@!!!!#!IJ!@J*`\r!!$L%!"#S(J!8(+!!$%J!!!&J!!!!1k!!!%J!!%`li!!!5!!!1)"q!"BF(3!-I!$\rk&(`$!+jm!!Gd,!!!)%##!"JiJ!!!J(i!&K`G!!am!2S8I)-"VM[r!!%X(`!%3B$\rrb$Zp!!'S(J!8I"d!!%'!rl#)'J!!+!!!!%##!#Ji!!!"Q"S!!)JH!!NS!!!!3))\r!)$KL!!")!!!"B!!!!%J!!"!iH3!!5!!!!@!!!!!iI!!!5!!!!@!!!!!iIJ!!J!%\r!D$JK!'"m#!1QZb(rj%k!!#"&G!-!N!3k!!!!&%9e!*!&2J!!!"K&G!-!N!3l!!!\r!-%9d!`#3"$X!!!!m4A8!N!8r!!!!4%9e!*!&3!!!!&K&G3#3"8%!!!"X4A8!N!9\r#!!!#m%9e!*!&3`!!!`K&G3#3"83!!!-N4A-3!*!%2!!!!kK&G3#3"88!!!1X4A8\r!N!8r!!!$[%9e!*!&4J!!!mK&EJ`%!!!!6`!!!!b!!*!,J!!$k$J!!!"&G`#3"6d\r!N!4&D`!%!!!!8!!!!A`!!!(m!!!4eR`)!UD6iIrmNm(rq*1Krr56JIr`N!!"!!L\r8)IqJ1m-!!$ZN!!#!BJ!!J!-!!#J!!!""JJ!J1(d!!)##!!#"K!!!5!!!!@!!!!"\r8B!Br3))"%+Kp!!#!R3!#1,d!"MM"!%")!!!"B!!!!(aJ"c9!JJ$`1(d!"ML!!#j\r)!!!"B!!!!(am'hP"JJ#N1"d!"RaJi&#)(3!'I!-!8#`!!!4"J3#-1'%!1$LF!!%\ri(3!'I+$J8)JG!!CmT3"35!!!!@!!!!!li!!!5!!!@)"q!"BF(`!-I'-#&$L"!$J\riS!!%5!!!!@!!!!!X!`!!3))!-)#H!"BFI`!-1!-!"(`%!#k3!!%!3)#H!"BFI`!\r-1!-!#(`%!#k3!!%!4%J!!$!lr`!"U"i!&(`I!!""J2qNJ"i!!*!!!3"!J"i!"*!\r!!3"%S!%!5&3!"Lb`!3")U(d!!)#G!!)i[3!'1-%!3%J!!!&J!!!!J!%!D$JK!'"\rm#!1QJq(rr)2"rrL$SIrdJi(rm%k!!#"&G!-!N!3K!!!!*%9d!`#3"#%!!!!i4A8\r!N!94!!!!3%9e!*!&8J!!!'"&G3#3"9-!!!"i4A8!N!98!!!!Z%9e!*!&93!!!0a\r&G3#3"9B!!!&84@i-"!!!!'N!!!!-J!#3#i!!!A`J!!!!4AF!N!93!*!%4@X!"!!\r!!'S!!!"B!!!#[!!!&6Gm#!+QN!!"!!L8)Ir!N!"K!&K)!!!"B!!!!)#$!!#!BJ!\r!1!-!bR`%!%""JJ!8J')!!$KM!-T)!!!"B!!!!$J!!!'!B3"BQ!-!$)!"!%Ji)3"\r!I!J$TNk!!#"&G3#3"@X!!!!34A3$!*!%E!!!!"a&G!-!N!4X!!!!,%9e!*!&E3!\r!!$4&EJ`%!!!!EJ!!!!b!!*!,J!!!@!#3"%9h!*!&DJ#3"%9U!!3!!!"[!!!!"!!\r!![i!!"D96S!!)%9V!!3!!!"`!!!!3!!!!a)!!"JcI!J#TT2Krrb3!!%!#*3Krm!\rli`!!L!-"!#J!!!""JJ!31!!!!*JI!3")!!!"J!%!5$JK!%"m#!1QJq(rr%k!!#"\r&G3#3"@m!!!!S4@i-"!!!!(%!!!!-J!#3#i!!!%!)!!!!4AF!N!9`!*!%4@X!"!!\r!!()!!!!)!!!$6!!!'2diB!"!6S!!)%9V!!3!!!"c!!!!k!!!!f!!!"NVI!J#TT2\rKrrb6`IriNk(rp*!!!3!)P#(rX*!!B3"SN!#"!'b3!+%!F)"L!!")!!!"J'%!D%J\r!!!&J!!!!I(iEH8'#!(!iIJ!!J)%!E)#K!(#"RJ!!JB`!$%J!!!&J!!!!I(mEH8'\r#!%b!BJ!!1*m!!$LJ!!")!!!"B!!!!$ZM!!!X(Irr3B)!$$Kp!!")!!"%,"m!!%'\r#!"`iI`!!1)!!!B'I!!+"M!"J5!!!!@!!!!#!BJ!!J!-!!#`!!!"!JJ!31'!!$%J\r!!!&)!!!)1'$rri!"!&Ji)3"3I!J$TS2Krrb$`IriJk(rp%k!!#"&G!-!N!3@!!!\r!*%9e!*!&F!!!!#K&G3#3"A3!!!!`4A8!N!94!!!!9%9d!`#3""B!!!"N4A8!N!9\re!!!!F%9e!*!&83!!!+4&G!-!N!3h!!!!V%9e!*!&0J!!!-"&EJ`%!!!!I3!!!!b\r!!*!,J!!!k"J!!!"&G`#3"A-!N!4&D`!%!!!!IJ!!!83!!!33!!!DNA`)!UD6iIr\rmNm(rq*1Krr53!!%!#*3Krl#3!'%!D*!!J3"XN!#K!(!laJ!!Jq)!!$Kr!!")!!!\r"J'%!D%J!!!&J!!!!I(dEH8'#!-3iI3!!J)%!E)#K!(!i`3!iJCd!!)'-!"")!!!\r"B!!!!#`$!!"!JJ#F1(m!!)#"!$JiS!!!5!!!!@!!!!#3!(i!!#`$rrp"JJ!m1(m\r!!)#"!$`iS!!!5!!!!@!!!!#3!(i!"#`$rrp"JJ!-1'!!!%J!!(3iI`!!J*i!!%J\r!!!&J!!!!J'%!1#`$!!""JJ!B1)!!!B'$!!+"M!"J5!!!!@!!!!#!B3!m,!-!!%'\r#!"JiJ!!"JB-!!S'-!'")!!!"B!!!!)"L!!#!!`!!,!!!!%##!"!iB!!-5!!!!8J\r!!!JiB2rrJ!%!@$JK!&"m#!1QJq(rr)2"rrL$SIrd6S!!)%9d!`#3""B!!!!S4A8\r!N!9`!!!!-%9e!*!&G!!!!$K&G3#3"9%!!!"J4A8!N!9e!!!!I%9e!*!&G3!!!*a\r&G3#3"Am!!!$!4A8!N!94!!!!i%9e!*!&83!!!3"&G!-!N!3h!!!"#%9e!*!&0J!\r!!4a&EJ`%!!!!J3!!!!b!!*!,J!!"4"J!!!"&G`#3"Ai!N!4&D`!%!!!!JJ!!!(J\r!!!6B!!!FVh`)!UD6iIrmN!!"!!L8)Ir!1q-!!%J!!!&J!!!!1'!!!6L!!!%iS!!\r!10m!!%J!!!%X!`!!3B)!$$KJrrp)!!!SJ(m!!$L!!!&)!!!"B!!!!)"r!!3iJ!!\r!5!!!!@!!!!!iB!!!J!%!5$JK!%"m#!1QJq(rr%k!!#"&G3#3"B-!!!!84A8!N!9\rq!!!!,%9e!*!&K!!!!%K&G3#3"B3!!!"B4@i-"!!!!)8!!!!-J!#3#i!!!(J)!!!\r!4AF!N!@#!*!%4@X!"!!!!)B!!!#)!!!&)J!!(90m#!+QNq(rr*!!!3!)P#(r`*!\r!B3"BN!#"!&b3!+%!B*!!`3"NN!$K!'L4!3"XN5%!F)"K!&K)!!!"B!!!!(ar'hP\r"JJ!d1(m!!)#"!&b!S3"JJ-%!C)$K!'L"!3"XJ5%!F)'I!!#"M!!85!!!!@!!!!"\r)!!!)1'$rri!"!%Ji)3"!I!J$TS2Krra1J!!J4A8!N!9d!!!!-%9e!*!&83!!!'4\r&EJ`%!!!!LJ!!!!b!!*!,J!!!L!J!!!"&G`#3"BB!N!4&D`!%!!!!L`!!!'`!!!@\rq!!!H9(`)!UD6iIrmN!!"!!L8)Ir!N!"K!&L3!)%!A*!!S3"JJ')!!)#"!&K)!!!\r"B!!!!(ar'hP"JJ!N1(m!!)#"!&b!S3"JJCm!!S'-!!K)!!!"B!!!!%J!!!JiB2r\rrJ!%!5$JK!%"m#!1QJq(rr%k!!#"&G!-!N!3@!!!!(%9e!*!&M!!!!#4&G3#3"9%\r!!!")4@i-"!!!!*)!!!!-J!#3#i!!!'`)!!!!4AF!N!@,!*!%4@X!"!!!!*-!!!"\rX!!!'%J!!(ZPm#!+QNq(rr*!!!3!)P#(r`*!!B3"BN!#"!&b3!+%!B)"L!!#!J3"\rB5!!!!@!!!!"mIaYj3B)!*$Kr!!#!J3"FJ+%!B)'I!!+"M!!-5!!!!@!!!!")!!!\r)1'$rri!"!%Ji)3"!I!J$TS2Krra1J!!J4A3$!*!%&J!!!"a&G3#3"B`!!!!N4A8\r!N!94!!!!5%9Z$!3!!!#@!!!!$)!!N!Z!!!"X#!!!!%9h!*!&N`#3"%9V!!3!!!#\rA!!!!C!!!"QB!!"q%I!J#TT2Krrb3!!%!#*3Krm#3!'%!@*!!J3"FJ')!!)#"!&K\r)!!!"B!!!!(ar'hP"JJ!J1(m!!)#"!&b"R`!#JB`!%%J!!!&J!!!!5!!!#$KJrrq\r!!3")1#%!3(`)!kD$iIrm6S!!)%9d!`#3""B!!!!B4A8!N!@-!!!!)%9e!*!&83!\r!!%"&EJ`%!!!!Q3!!!!b!!*!,J!!!C!J!!!"&G`#3"CF!N!4&D`!%!!!!QJ!!!-!\r!!!DX!!!Ikh`)!UD6iIrmNm(rq*!!!3!)P#(r`$[$!!#3!)%!A*!!S3"JJ')!!$L\rH!!")!!!"B!!!!(ar'hP"JJ"`1(m!!)#"!&b!S3"JJCm!!S'-!"4)!!!"B!!!!(a\rr'hP"JJ"-J')!!$LI!!!iS!!!5!!!!@!!!!!l``!!,"lrrd'#!!`iIJ!!5!!!+#`\rI!!""JJ!F1(m!!$L!!!'"R`!#JB`!B%J!!!&J!!!!1'$rri!"!%Ji)3"!I!J$TS2\rKrrb$`Iri6S!!)%9d!`#3""B!!!!J4A8!N!@-!!!!+%9e!*!&83!!!%a&G!-!N!3\r@!!!!A%9e!*!&G3!!!'K&G3#3"9%!!!#F4@i-"!!!!*X!!!!-J!#3#i!!!-!3!!!\r!4AF!N!@D!*!%4@X!"!!!!*`!!!!i!!!(+!!!)2Ym#!+QN!!"!!L8)Ir!N!"K!&J\ri!2rrN!!#!!#!BJ!!J)%!@%J!!!&J!!!!J!%!5$JK!%"m#!1Q6S!!)%9c%!#3"#8\r!!!!84A3$!*!%&J!!!"K&G3#3"Am!!!!J4@i-"!!!!*d!!!!-J!#3#i!!!$J!N!4\r&G`#3"C`!N!4&D`!%!!!!RJ!!!33!!!G5!!!MDR`)!UD6iIrmNm(rq*1Krr56JIr\r`N!!"!!L8)Iq`N!"K!'L3!)%!E*!!S3"`N!$"!(5$iJ!!Jm)!!)1L!!#)(J!)I!!\r(G8'#!&4)!!!"B!!!!#`$!!"!JJ!`J"m!!#J!!!""JJ!`1'!!#BLH!!KmK!GdJCm\r!!%J!!!&J!!!!,!-!!%'#!"!iB!!%5!!!!8J!!!`i!!!!N!!G!!!i!!!!N!!"!$L\r!BJ!!J)%!D%J!!!&J!!!!I(`EH8'#!$!iI!!!J)%!E)#K!(#!`3"d11!!!$N"!$L\r"R!!#JB`!)%J!!!&J!!!!5!!!#$KJrrq!!3"B1#%!8(`)!kD$iIrmJm(rq)1Krr5\r$JIr`6S!!)%9d!`#3""d!!!!X4A3$!*!%!J!!!$"&G!-!N!3h!!!!0%9e!*!&R`!\r!!%4&G3#3"9%!!!"`4A8!N!8f!!!!K%9d!`#3""B!!!#F4A8!N!@-!!!!T%9e!*!\r&83!!!04&EJ`%!!!!S`!!!!b!!*!,J!!""#!!!!"&G`#3"Ci!N!4&D`!%!!!!T!!\r!!33!!!I5!!!N2R`)!UD6iIrmNm(rq*1Krr56JIr`N!!"!!L8)Iq`N!"K!'L3!)%\r!E*!!S3"`N!$"!(53!1%!H*%"!(b$iJ!!Jm)!!)1L!!#)(J!)I!!(G8'#!&4)!!!\r"B!!!!#`$!!"!JJ!`J"m!!#J!!!""JJ!`1'!!#BLH!!KmK!GdJCm!!%J!!!&J!!!\r!,!-!!%'#!"!iB!!%5!!!!8J!!!`i!!!!N!!G!!#!BJ!!J)%!D%J!!!&J!!!!I(`\rEH8'#!$!iI!!!J)%!E)#K!(#!`3"dJ1%!H)%"!(b"R!!#JB`!)%J!!!&J!!!!5!!\r!#$KJrrq!!3"B1#%!8(`)!kD$iIrmJm(rq)1Krr5$JIr`6S!!)%9d!`#3""d!!!!\rd4A3$!*!%!J!!!$K&G!-!N!3h!!!!2%9e!*!&R`!!!%a&G3#3"9%!!!"i4A8!N!8\rf!!!!M%9d!`#3""B!!!#F4A8!N!@-!!!!T%9e!*!&83!!!04&EJ`%!!!!TJ!!!!b\r!!*!,J!!""#!!!!"&G`#3"D3!N!4&D`!%!!!!T`!!!83!!!KB!!!P*A`)!UDr!Ir\rJN!!"!!L8)Iq3!*!!B3#)1i3!!*!!S3#3!)2L!!#$`J!!Jk)!!)JH!!Km!!Ge3B)\r!9%J!!!&J!!!!,!-!!%##!$#!(`!!+!!!!%'#!$!iB!!*L*i!#(b%"h5"R`!!5!!\r!!@!!!!!X!`!!3B)!%$KJ!!4)!!!"5!!!$$J!!!#3!"d!!)"L!!#!J3#)5!!!!@!\r!!!"mHaYj3B)!P$KK!$L!R!!)J,`!$%J!!!&J!!!!J!%!2#J!!!""JJ"31(X!!)#\r"!$b!S3"!J-%!N!#!r!!!14`!")'E!!+"M!!J5!!!!@!!!!!l!`!!N`%!3$YB!!!\riB3!i1)$rrdJ!!!&J!!!!1(S!!%J!!#`iB!!-5!!!!6XM!!!iB3!i1)$rrdJ!!!&\rJ!!!!1(N!!%J!!!JiB2rrJ!%!H$JK!("m#!1QZ`(ri%k!!#"&G!-!N!3G!!!!(%9\rd!`#3"!)!!!!J4A3$!*!%0`!!!#4&G3#3"Cm!!!!d4A8!N!94!!!!B%9e!*!&0J!\r!!(4&G!-!N!3@!!!!K%9e!*!&M!!!!)a&G3#3"DJ!!!#S4A8!N!94!!!!h%9e!*!\r&U3!!!2K&G3#3"6B!!!%-4A8!N!@T!!!"(%9Z$3)!!!#r!!!!')!!N!G!!!$J!1!\r!%!%3!4!!%!!!JJ!!1!#3"%9f#J`!!!$!!!!!&%9Z$!3!!!$"!!!!$)!!N!d"4!#\r3"%9h!*!&T`#3"%9h$3#3",m!!!!)4@S!"!!!!-)!!!#!!!!)iJ!!*Xjm#!+QNq(\rrr*!!!3!)P#(r`$[M!!!X(rrr3))!8)"L!!#!!`!!,!!!#d'#!%"!J!!3,!!!"%'\r#!$4)!!!8,!!!*N#!!!`X!!!N3)!!))"L!!#)!`!1+!!!!%'#!"!iB!!05!!!!@!\r!!!!iI`!!J!%!5$JK!%"m#!1QJq(rr%k!!#"&G!-!N!3h!!!!(%9d!`#3"!)!!!"\r-4A8!N!A$!!!!B%9Z$!3!!!$&!!!!$)!!N!Z!!!#!#!!!!%9h!*!&`J#3"%9V!!3\r!!!$'!!!"2!!!#53!!#I0I!J#TVmKrq53!!%!#*3Krj!!N!"K!)L3!)%!M*!!S3#\r3!)2L!!#$`J!!Jk)!!)JH!!Km!!Ge3B)!9%J!!!&J!!!!,!-!!%##!$#!(`!!+!!\r!!%'#!$!iB!!*L*i!#(b%"h5"R`!!5!!!!@!!!!!X!`!!3B)!%$KJ!!4)!!!"5!!\r!$$J!!!#3!"d!!)"L!!#!J3#)5!!!!@!!!!"mI"Yj3B)!M$KK!$L!J3#-J+%!N!"\r)!!!"B!!!!)!"!$`S!!!!3B)!5$Km!!#!J3!mJ+%!3)'F!!+"M!!F5!!!!@!!!!!\rl)`!!Nb%!3%J!!!%lB`!!1'%!1$L!rrp)!!!"B!!!!$Kl!!")!!!X1'!!$%J!!!%\rl3`!!1'%!1$L!rrp)!!!"B!!!!$Kk!!")!!!)1'$rri!"!(Ji)3"`I!J$TVXKrq4\r1J!!J4A3$!*!%(3!!!"a&G!-!N!3#!!!!)%9d!`#3"$F!!!!N4A8!N!@I!!!!0%9\re!*!&83!!!'"&G3#3"6B!!!"d4A3$!*!%&J!!!)4&G3#3"B`!!!#-4A8!N!A(!!!\r!U%9e!*!&83!!!0"&G3#3"F)!!!$J4A8!N!A)!!!!m%9e!*!&0J!!!34&G3#3"FJ\r!!!%84@i0!J!!!-`!!!!BJ!#3"cJ!!03!j!!3!3J"#!!3!!##!!!i!*!%4AB+$!!\r!!-d!!!!84@i-"!!!!-i!!!!-J!#3$3%m!*!%4AF!N!A'!*!%4AF0!*!%c!!!!!K\r&D`!%!!!!c`!!!3!!!!QZ!!!T#(`)!UD6iIrmNm(rq*1Krr56JIr`N!!"!!L8)Iq\r`N!"K!'L3!)%!E*!!S3"`N!$"!(5$iJ!!Jm)!!)1L!!#)(J!)I!!(G8'#!&4)!!!\r"B!!!!#`$!!"!JJ!`J"m!!#J!!!""JJ!`1'!!#BLH!!KmK!GdJCm!!%J!!!&J!!!\r!,!-!!%'#!"!iB!!%5!!!!8J!!!`i!!!!N!!G!!#!BJ!!J)%!D%J!!!&J!!!!I(`\rEH8'#!$3iI!!!J)%!E)#K!(#!`3"d11!!!$N!!!#"R!!#JB`!*%J!!!&J!!!!5!!\r!!8J!!!JiB2rrJ!%!@$JK!&"m#!1QJq(rr)2"rrL$SIrdJi(rm%k!!#"&G!-!N!3\rG!!!!,%9d!`#3"!)!!!!`4A3$!*!%0`!!!$4&G3#3"Cm!!!"%4A8!N!94!!!!F%9\re!*!&0J!!!)4&G!-!N!3@!!!!P%9e!*!&M!!!!*a&G3#3"9%!!!$-4A8!N!A#!!!\r!e%9Z$!3!!!$3!!!!$)!!N!Z!!!%!)!!!!%9h!*!&c`#3"%9V!!3!!!$4!!!"#!!\r!#KJ!!#RHI!J#TT2Krrb6`IriNk(rp*1"rr#3!!%!#*3Krl#3!'%!D*!!J3"XN!#\rK!(#3!-%!G*!!i3"iN3%!I)2L!!#$`J!!Jk)!!)JH!!Km!!Ge3B)!9%J!!!&J!!!\r!,!-!!%##!$#!(`!!+!!!!%'#!$!iB!!*L*i!#(b%"h5"R`!!5!!!!@!!!!!X!`!\r!3B)!%$KJ!!4)!!!"5!!!$$J!!!#3!"d!!)"L!!#!J3"S5!!!!@!!!!"mI"Yj3B)\r!0$Km!!#!J3"XJ+%!F)$"!(5!i3"iJ3%!I)'F!!+"M!!N5!!!!@!!!!")!!!"5!!\r!#$KJrrq!!3"B1#%!8(`)!kD$iIrmJm(rq)1Krr5$JIr`6S!!)%9d!`#3""d!!!!\rd4A3$!*!%!J!!!$K&G!-!N!3h!!!!2%9e!*!&R`!!!%a&G3#3"9%!!!"i4A8!N!8\rf!!!!M%9d!`#3""B!!!#F4A8!N!@-!!!!T%9e!*!&83!!!04&G3#3"F)!!!$F4@i\r-"!!!!03!!!!-J!#3#i!!!3JJ!!!!4AF!N!A4!*!%4@X!"!!!!08!!!&)!!!+RJ!\r!+ZKm#!+Q[`(ri*!!!3!)P#(rN!#3!'%!L$Z%!!#3!+%!N!#$iJ!!Jm)!!)1L!!#\r)(J!)I!!(G8'#!&4)!!!"B!!!!#`$!!"!JJ!`J"m!!#J!!!""JJ!`1'!!#BLH!!K\rmK!GdJCm!!%J!!!&J!!!!,!-!!%'#!"!iB!!%5!!!!8J!!!`i!!!!N!!G!!#!BJ!\r!J)%!L%J!!!&J!!!!I(XEH8'#!*JiB3!iJ*`!#)#m!!a)!!!"B!!!!)!"!$`S!!!\r!3B)!9$Kl!!#!J3!mJ+%!3)$"!*!!J2`!!)%F!!5"Q`!#JB`!*%J!!!&J!!!!1`-\r!!*-"!%")!!!"1d-!!$KK!$JiJ2rr5!!!!@!!!!!iHJ!!5!!!,$KJ!!a)!!!"1b-\r!!$KK!$JiJ2rr5!!!!@!!!!!iH3!!5!!!#$KJrrq!!3"i1#%!F(`)!kDl!IrJ6S!\r!)%9d!`#3""d!!!!F4A3$!*!%!J!!!#"&G!-!N!3h!!!!*%9e!*!&R`!!!$4&G3#\r3"9%!!!"J4A8!N!8f!!!!G%9d!`#3""B!!!#%4A8!N!@-!!!!M%9e!*!&a`!!!+K\r&G3#3"9%!!!$F4A8!N!A#!!!!l%9e!*!&b!!!!2a&G3#3"6B!!!%34A8!N!A)!!!\r")%9Z$3)!!!$@!!!!')!!N!G!!!$J!2!!%!%8!43!%!!!JJ!!1!#3"%9f#J`!!!$\r0!!!!&%9Z$!3!!!$A!!!!$)!!N!d"5!#3"%9h!*!&e3#3"%9h$3#3"0B!!!!)4@X\r!"!!!!0J!!!%)!!!,+!!!,-"m#!+Q[f(rl*!!!3!)P#(rS$YM!!!i!!!!Q!%!1MJ\r!!!#B!3!j1!!!!*J"!$Jl`!!!1k!!!)"L!!!iQ`!!5!!!!@!!!!!S!`!!3))!%$K\rJ!!P)!!!"5!!!S)"L!!!iQ`!!5!!!!@!!!!!lJ`!!1r`!!+JF!!a8!!Ir3B)!#$[\r"!$US(`!-9!!([8'#!!JlS3!j1(`!!$LH!!!i[3!!1-!!!)'F!!+"M!"B5!!!!@!\r!!!!X!`!!3B)!2)J"!$NS!!!!3B)!&)"r!!BiJ!!#5!!!!@!!!!#)!3!k+!!!!%'\r#!"5!I`!'1)!!!8J!!!&J!!!!1'!!!)!"!'Ji)3"JI!J$TVYKrqa1J!!J4A3$!*!\r%&J!!!$4&G3#3"B`!!!!m4A8!N!8f!!!!8%9d!`#3""B!!!"B4A8!N!@-!!!!B%9\re!*!&83!!!+K&G3#3"GN!!!$-4A8!N!AC!!!!k%9Z$!3!!!$j!!!!$)!!N!Z!!!%\r)+!!!!%9h!*!&f!#3"%9V!!3!!!$k!!!'#!!!$!`!!#pVI!J#TVi"rm#3!!%!#*3\rKrf!kJ`!!1b3!!$Y&!!!lCJ!!1JF!!),L!!##SJ!!JX)!!$TJ!!!iB3"31)!!!$L\rJ!!K)!!!"B!!!!$KK!%JiJ!!!1+!!#%J!!!&J!!!!1'%!3$L!!!!iS!!)5!!!!@!\r!!!!S%!!!3B)!))"`!!3i!%%DI'-$eS!3!!!F!!!mIN-#&%J!!!`q3(Ff1P+8!%J\r!!!&J!!!!1L-!!$[J!!")!!#B+"N!!%'#!#!iB!!"9q!'rRaJ!$"AiqMkI(NB,R`\r!'$P!JJ"-+"S!!%'#!#!iB!!"9q!'rRaJ!$"AiqMkI(SB,R`!'$P!JJ!S+"X!!%'\r#!%3iB!!"9q!'rRaJ!$"AiqMkI(XB,R`!'$P"JJ!S1(8!!$LI!!")!!!"B!!!!#J\r$!!"!JJ!31'!!#8J!!!&)!!5i1rm!!A`IS!""J2pS1q!!!%J!!23iG3!!1*m!!%J\r!!!&J!!!!I(JEH8'#!0Ji!!!!+"N!!%'#!#3iB!!"9q3'rRaN)$"AiqMkI(NB,Rb\r$'$P"JJ!)1!!!!CJ"!$ii!!!!+"S!!%'#!#3iB!!"9q3'rRaN)$"AiqMkI(SB,Rb\r$'$P"JJ!)1!!!!CJ"!$di!!!!+"X!!%'#!#3iB!!"9q3'rRaN)$"AiqMkI(XB,Rb\r$'$P"JJ!)1!!!!CJ"!$b)!3!q+!!!!%##!"b)!3!p+!!!!%##!"#)!3!m+!!!!%'\r#!#3iH!!!L)%!2SLK!$f)`3!mJCJ!!S'-!&4)!!!"B!!!!$[r!!&m(k!!3B$r$$[\rJ!!")!!')1(8!!$LI!!")!!!"B!!!!(ai'hP"JJ&X1!!!!*J"!$ii!!!!Q!%!26J\r!!!#B!3!m+"N!!%'#!#Ji!!!"9q-'rR`$'$"Ai1MkI"N!,RaJ!$P"JJ!-1m%!2NJ\r!!!Jl`!!!+"S!!%'#!#Ji!!!"9q-'rR`$'$"Ai1MkI"S!,RaJ!$P"JJ!-1k%!28J\r!!!JlS!!!+"X!!%'#!#Ji!!!"9q-'rR`$'$"Ai1MkI"X!,RaJ!$P"JJ!-1i%!2%J\r!!!JlJ!!!+"i!!%##!"3S(3!!3))!$#JF!!""JJ#X1(J!!$LH!!!i[3!!10`!!)'\rB!!+"M!"B5!!!!@!!!!"qFaS8L!%!2LJ!!!""JJ!N9q$SqMKK!&"m``!Z1)!!!9I\rP"[jmK#J`I-3MH(b$!5k)!3!p+!!!!%'#!#4Ai1Mk1'%!5(c$!#iiJ!!"9q8'rRb\r%+$"ma#0iI)-",SJ"!$`S!!!!3B)!*&IJk2SiB3"!I--!,ML!!!&Aj3EqI)3S-(c\r%)hKmJ`%Z1rm!!A`IS!""J2ji,"-!!%##!,#!&J!!N!!"!$Ji!!!!N!!@!!")!!!\r"B!!!!#`$!!"!JJ!XJ"F!!#J!!!""JJ!X1'!!!6L5!!#"P`!!5!!!!@!!!!!X!`!\r!3B)!%$KJ!!4)!!!"5!!!$$J!!!#3!"B!!)!@!!!X!!!!3B)!)$TJrrq!&J!!,!!\r!!%##!$L!!3!iN!!@!!")!!!XJ"B!!#`!!!"!JJ!-J!%!1*!!&J!!5!!!!@!!!!"\rm%4K3I!#3!%""J2fm1q!!!%J!!23iG3!!1*m!!%J!!!&J!!!!I(JEH8'#!0Ji!!!\r!+"N!!%'#!#3iJ!!"9q-'rRb%'$"AiqMkI(NB,Rb$'$P"JJ!)1!!!!CJ"!$ii!!!\r!+"S!!%'#!#3iJ!!"9q-'rRb%'$"AiqMkI(SB,Rb$'$P"JJ!)1!!!!CJ"!$di!!!\r!+"X!!%'#!#3iJ!!"9q-'rRb%'$"AiqMkI(XB,Rb$'$P"JJ!)1!!!!CJ"!$b)!3!\rq+!!!!%##!"b)!3!p+!!!!%##!"#)!3!m+!!!!%'#!#3iH!!!L)%!2SLK!$f)`3!\rmJCJ!!S'-!&a)!!!"B!!!!$[r!!&m(k!!3B$r$#`6!!"!J!!31'!!"%J!!!&)!!"\r3+"N!!%'#!"5!B3"3J!%!9*!!H3!!N!!C!!3S'J!!3B)!&)"K!%L!!3"-N!"k!!#\r3!"S!"#JE!!""JJ!8J'%!3)!"!%53!(X!!*!!'`!%1(-!!)!"!+Ji)3#JI!J$TVS\r"rm"1J!!J4A3$!*!%(3!!!#4&G!-!N!3@!!!!+%9d!`#3"$F!!!!X4A8!N!Al!!!\r!3%9e!*!&q`!!!&4&G3#3"IX!!!"S4A8!N!Am!!!!R%9e!*!&M!!!!54&G3#3"6B\r!!!%i4A8!N!@-!!!"A%9e!*!&83!!!MK&G3#3"B`!!!*F4A8!N!94!!!$4%9e!*!\r&R`!!!rK&G3#3"9%!!!3J4A8!N!8f!!!%0%9e!*!&r!!!")"&G3#3"B`!!!5N4A8\r!N!94!!!&J%9e!*!&0J!!"D"&EJd#!!!"%J!!!"+!!*!(J!!$r!3i!!S!!))!!$J\r!N!C&GJS-!!!"%`!!!!j&EJ`%!!!"&!!!!!b!!*!0"JJ!N!4&G`#3"IS!N!4&G`d\r!!!!"%J!!!!K&D`#%!!!"&3!!!'L!!*!(I!J#TT2Krrb3!!%!#*3Krm"mIaYjX)%\r!AN'#!$L!BJ!!J!-!!#`!!!"!JJ!3J"m!!)"L!!#3!!-!!+J"!&iX!!!!3)%!%$K\rr!!")!!!"B!!!!$Kr!!#!!3")1#%!3(`)!kD$iIrm6S!!)%9d!`#3"$F!!!!F4A3\r$!*!%0`!!!$"&G3#3"!%@!!!!5%9Z$!3!!!%A!!!!$)!!N!Z!!!"S#!!!!%9h!*!\r%!48!N!4&D`!%!!!"'!!!!'`!!!l3!!!hYA`)!UD6iIrmN!!"!!L8)Ir!N!"K!&L\r3!)%!A*!!S3"JJ')!!)#"!&K)!!!"B!!!!(ar'hP"JJ!N1(m!!)#"!&b!S3"JJCm\r!!S'-!#K)!!!"B!!!!%J!!!JiB2rrJ!%!5$JK!%"m#!1QJq(rr%k!!#"&G!-!N!3\r@!!!!(%9e!*!&M!!!!#4&G3#3"9%!!!")4@i-"!!!!4N!!!!-J!#3#i!!!'`)!!!\r!4AF!N!3"'!#3"%9V!!3!!!%D!!!!E!!!$b3!!$K+I!J#TT2Krrb3!!%!#*3Krm#\r3!'%!@*!!J3"FN!#K!'#!BJ!!J)%!@%J!!!&J!!!!I(mEH8'#!#3iI`!!J)%!A)#\rK!'#"R`!#JB`!,%J!!!&J!!!!5!!!#$KJrrq!!3")1#%!3(`)!kD$iIrm6S!!)%9\rd!`#3""B!!!!F4A8!N!@-!!!!*%9e!*!&83!!!%K&EJ`%!!!"'`!!!!b!!*!,J!!\r!E!J!!!"&G`#3"!%D!*!%4@X!"!!!!)3!!!"N!!!2H!!!10pm#!+QNq(rr*!!!3!\r)P#(r`*!!B3"BN!#"!&b!BJ!!J)%!@%J!!!&J!!!!I(mEH8'#!#!iI`!!J)%!A)'\rI!!+"M!"35!!!!@!!!!")!!!)1'$rri!"!%Ji)3"!I!J$TS2Krra1J!!J4A3$!*!\r%&J!!!"K&G3#3"B`!!!!J4A8!N!94!!!!3%9Z$!3!!!%G!!!!$)!!N!Z!!!"N#!!\r!!%9h!*!&K!#3"%9V!!3!!!%H!!!!A!!!$li!!$P*I!J#TT2Krrb3!!%!#*3Krm#\r3!'%!@)"L!!#!J3"B5!!!!@!!!!"mIaYj3B)!()"L!!!iR`!!1+!!!%J!!!&J!!!\r!5!!!#$KJrrq!!3")1#%!3(`)!kD$iIrm6S!!)%9d!`#3""B!!!!84A8!N!@-!!!\r!(%9d!`#3""B!!!!X4A8!N!9e!!!!1%9Z$!3!!!%I!!!!$)!!N!Z!!!"F#!!!!%9\rh!*!%!4i!N!4&D`!%!!!")!!!!*`!!!rf!!!jTR`)!UD6iIrmNm(rq*1Krr53!!%\r!#*3Krl#3!'%!D$ZN!!#$iJ!!1(m!!)#"!'K)!!!"B!!!!(aq'hP!JJ!-1'$rrdJ\r!!%!iI`!!1*d!!%J!!!&J!!!!+!-!!%'#!"3iI`!!1*d!!%J!!!&J!!!!1(m!!$L\rH!!!i[3!!5!!!!@!!!!#!!3"B1#%!8(`)!kD$iIrmJm(rq)1Krr41J!!J4A3$!*!\r%&J!!!#"&G3#3"B`!!!!X4A8!N!@-!!!!6%9e!*!&I`!!!'4&G3#3"A8!!!"i4@i\r-"!!!!5)!!!!-J!#3#i!!!*`B!!!!4AF!N!3")!#3"%9V!!3!!!%M!!!!E!!!%&`\r!!$U-I!J#TT2Krrb3!!%!#*3Krm#3!'%!@*!!J3"FN!#K!'#!BJ!!J)%!@%J!!!&\rJ!!!!I(mEH8##!!`iB2rr5!!!)$Kr!!#!J3"FJ+%!B)'I!!+"M!!m5!!!!@!!!!#\r!!3")1#%!3(`)!kD$iIrm6S!!)%9d!`#3""B!!!!F4A8!N!@-!!!!*%9e!*!&83!\r!!&"&EJ`%!!!"*J!!!!b!!*!,J!!!E!J!!!"&G`#3"!%M!*!%4@X!"!!!!5F!!!"\rm!!!3`!!!1bGm#!+QNq(rr*!!!3!)P#(r`*!!B3"BN!#"!&b3!+%!B*!!`3"NN!$\rK!'L!BJ!!J)%!@%J!!!&J!!!!I(mEH8'#!#`iI`!!J)%!A)#K!'#!`3"NJ1%!D)'\rI!!+"M!!`5!!!!@!!!!")!!!)1'$rri!"!%Ji)3"!I!J$TS2Krra1J!!J4A3$!*!\r%&J!!!#4&G3#3"B`!!!!X4A8!N!94!!!!@%9Z$!3!!!%X!!!!$)!!N!Z!!!"m#!!\r!!%9h!*!%!5F!N!4&D`!%!!!",3!!!(`!!"%`!!!lfR`)!UD6iIrmN!!"!!L8)Ir\r!N!"K!&L3!)%!A*!!S3"JN!$"!'53!1%!D)"L!!#!J3"B5!!!!@!!!!"mIaYj3B)\r!,$Kr!!#!J3"FJ+%!B)$"!'5!i3"SJCm!!S'-!$4)!!!"B!!!!%J!!!JiB2rrJ!%\r!5$JK!%"m#!1QJq(rr%k!!#"&G!-!N!3@!!!!*%9e!*!&M!!!!#a&G3#3"9%!!!"\rB4@i-"!!!!5i!!!!-J!#3#i!!!(`)!!!!4AF!N!3",3#3"%9V!!3!!!%[!!!!A!!\r!%D!!!$bD9'!'2L`!!!*"JJ!m3)!!&#`!!!""JJ!B3)!!)%k!!#!X!!!%6)!!)%J\r!!#L!SJ!!N!#&!!"1J!!JJ+)!!*!!K3!!6S!!))#L!!#3!)8!!%k!!##!SJ!!N!#\r&!!"1J!!J4A3$!*!%(3!!!#a&G!-!N!3I!!!!1%9d!`#3"#%!!!"%4A3$!*!%)J!\r!!&"&D`!%!!!"0`!!!'3!!"(i!!!phP4J"MiX!!!#3B)!2%#!!"3X!!!!3B)!'%#\r!!#")!!"!,!!!"%#!!$K)!!!SJ))!!)"N!!"1J!!JJ))!!)"N!!"1J!!JJ))!!)"\rN!!"1J!!JJ))!!)"N!!"1J!!J1'!!!%k!!#"&G!-!N!3G!!!!,%9d!`#3""m!!!!\ri4A3$!*!%)3!!!%4&G!-!N!3L!!!!8%9V!!3!!!%i!!!!C!!!%N)!!$mFNq(rr*!\r!BJ!!1!!!!,!#!!!li!!!5!!!1)##!!"ri!Fd9!!31R`%!#iS!!!!3B)!(+LL!!!\riJ!!"Iq!(0(b!!$"mS!0iX!)!!$[r!!&ri!Fd,!!!%%'!rm3iB!!!Jq(rr%k!!#"\r&Fa!!N!3M!!!!"%9c%!#3"#3!!!!-4A-3!*!%)`!!!"K&Fa!!N!3N!!!!-%9c%!#\r3"#3!!!"%4@X!"!!!!6X!!!!)!!!5NJ!!2p+!BJ!!6S!!)%9c%!#3"#-!N!4&D`#\r%!!!!G!!!!'3!!"+Q!!"!e(`)!UD6iIrmN!!"!!L8)Ir!I(mEH8'!!#!X(`!83)!\r!')"L!!"Ai"!kI!-!,LJ!!!"!JJ!81'!!&NJ!!!%iB!!!5!!!%)"L!!"Ai"!kI'-\r!,S!"!%Ji)3"!I!J$TS2Krra1J!!J4A3$!!!!!6`!!!!J4A8!N!8f!!!!1%9d!`!\r!!!%m!!!!4%9Z$!3!!!&"!!!!$)!!N!Z!!!"N#!!!!%9h!*!&G!#3"%9V!!3!!!&\r#!!!!1!!!%Z!!!%'8I!J#TT!!!3!)P#(r`)"L!!#)!`!!+!!!!%'#!"#!BJ!!5!!\r!!@!!!!#!!3")1#%!3(`)!kC1J!!J4A3$!*!%,J!!!!a&G!-!!!!"23!!!"a&G3#\r3"!&$!!!!)%9Z$!3!!!&%!!!!$)!!N!Z!!!!i!*!%4AF!N!3"3J#3"%9V!!3!!!&\r&!!!!N!!!!"--!!""ih`)!UD6iIrmNm(rq*1Krr53!!%!#*3Krl!l``!!I*dMHB2\rL!!#!!J!!N!!$!!""JJ!3J')!!&HJ%$Tr``%ZJ')!!)J$!!!S!!!!3B)!+)!I!!!\rS!!!!3))!()!I!!3S!!!!3))!%$Kr!!")!!!"B!!!!$Kq!!#!!3"B1#%!8(`)!kD\r$iIrmJm(rq)1Krr41J!!J4A3$!!!!!6d!!!!J4A3$!!!!!8B!!!!N4A3$!!!!!6`\r!!!!`4A3$!*!%,J!!!$a&G3#3"!&(!!!!D%9Z$!3!!!&)!!!!$)!!N!Z!!!#3!"J\r!!!"&G`#3"!&&!*!%4@X!"!!!!8N!!!"8!!!6A!!!3k0m#!+QNq(rr*!!!3!)P#(\rr`(ar'hQ`J3"H3B)!*)!#!!#3!"m!!+J"!&iX!!!!3)%!%$Kr!!")!!!"B!!!!$K\rr!!#!!3")1#%!3(`)!kD$iIrm6S!!)%9d!`!!!!&'!!!!(%9e!*!%!4B!!!!d4@i\r-"!!!!8S!!!!-J!#3#i!!!&3)!!!!4AF!N!3"53#3"%9V!!3!!!&,!!!!+!!!%hi\r!!%3%I!J#TT!!!3!)P#(r`$KJ!#e)!!!"1'!!!)!"!%Ji)3"!I!J$TNk!!#"&G3#\r3"6B!!!!34@i-"!!!!8`!!!!-J!#3#i!!!#J!N!4&G`#3"!&,!*!%4@X!"!!!!8d\r!!!!N!!!6QJ!!4(0m#!+QN!!"!!L8)Ir!1'!!,8J!!!'!!3")1#%!3(`)!kC1J!!\rJ4A8!N!8f!!!!%%9Z$!3!!!&1!!!!$)!!N!Z!!!!N!*!%4AF!N!3"63#3"%9V!!3\r!!!&2!!!!*!!!%lB!!%60I!J#TT!!!3!)P#(r`$KJ!#e)!!!"J!%!5$JK!%"m#!1\rQ6S!!)%9e!*!&0J!!!""&EJ`%!!!"8!!!!!b!!*!,J!!!*!#3"%9h!*!%!8m!N!4\r&D`!%!!!"83!!!!3!!"25!!"&0%k!!#"&DJ!%!!!"8J!!!#J!!"2Q!!"&S(`)!UD\r3!!%!#*3Krm#!BJ!!5!!!!@!!!!#!!3")1#%!3(`)!kC1J!!J4A3$!!!!!9-!!!!\r-4A8!N!3"9!!!!""&EJ`%!!!"93!!!!b!!*!,J!!!+!#3"%9h!*!%!9)!N!4&D`!\r%!!!"9J!!!%!!!"3+!!"&cR`)!UD6iIrmN!!"!!L8)Ir!1q-!!)"L!!")!!!"B!!\r!!$J!!!'B(`%!1(m!!)!"!%Ji)3"!I!J$TS2Krra1J!!J4A3$!!!!!9F!!!!84A8\r!N!3"@!!!!"K&EJ`%!!!"@3!!!!b!!*!,J!!!3!J!!!"&G`#3"!&@!*!%4@X!"!!\r!!(8!!!#d!!!80!!!4Kam#!+QNq(rr*2"rrL6SIrdNi(rm*!!!3!)P#(rX$ZM!!!\rla!!!I,`VH8'!!!`X(!"!3B!!%$KJ!"C)!!!"5!!!@$[m!!")!!!mIq!(0&3!%$T\rm(3!Z+!!!!%##!#4ri!Fd9!!31RrG!5kSIJ!!1!-!!E!H!!"ri`Fd5!!!($[r!!&\rri!Fd,!!!3%'!rm!iB!!B5!!!!B!"!&Ji)3"3I!J$TS2Krrb$`IriJk(rp)1"rr"\r1J!!J4A8!N!8f!!!!1%9e!*!&0J!!!*!!4@i-"!!!!9X!!!!-J!#3#i!!!,3J!!!\r!4AF!N!9e!*!%4@X!"!!!!(m!!!#`!!!8Z!!!4cjm#!+QNq(rr*2"rrL6SIrdN!!\r"!!L8)Iq`1k-!!$[N!!")!!!","m!!%'!!"`X(`"!3)!!&&IJ%$Trh3!Z+"i!!%#\r#!"!iB!!*5!!!!8J!!%JiB!!!9q!31Rap!5kSIJ!!1!2rrl!H!!"m!!Fe3))!*#`\rH!!""JJ!F1(i!!$L!!!'"RJ!#JB`!B%J!!!&J!!!!1'!!!)!"!&Ji)3"3I!J$TS2\rKrrb$`IriJk(rp%k!!#"&G3#3"A!!!!!J4A8!N!8f!!!!5%9e!*!&83!!!)K&EJ`\r%!!!"A!!!!!b!!*!,J!!!X"J!!!"&G`#3"Am!N!4&D`!%!!!!M!!!!(3!!"8Q!!"\r)*(`)!UD6iIrmNm(rq*1Krr53!!%!#*3Krl!lS`!!1q3!!%J!!!%X(`!!3B!!(#`\rI!%"!J!!89q!31RrG!#iS(J!!3))!&$KJ!!P)!!!"1'!!!%J!!!JiIJ!!J!%!@$J\rK!&"m#!1QJq(rr)2"rrL$SIrd6S!!)%9e!*!&F!!!!#"&G3#3"6B!!!")4@i-"!!\r!!9d!!!!-J!#3#i!!!(3B!!!!4AF!N!@-!*!%4@X!"!!!!9i!!!#N!!!9K!!!540\rm#!+QNq(rr*2"rrL3!!%!#*3Krm"mIKYjX)%!AN'#!'b!BJ!!5!!!!@!!!!!i!!!\r!Q"i"!)"L!!")!!!"B!!!!$[J!!")!!!N9q!31R`H!#iS!!!!3B)!%$Kr!!")!!!\r"B!!!!$[r!!%X(`"!3B$rh+J"!&iX!!!!3)%!%$Kq!!")!!!"B!!!!$Kq!!#!!3"\r)1#%!3(`)!kD$iIrmJm(rq%k!!#"&G!-!!!!"8`!!!#"&G3#3"!&8!!!!*%9d!`!\r!!!&I!!!!0%9e!*!%!93!!!!i4A8!N!3"B!!!!&a&G3#3"!%@!!!!J%9Z$!3!!!&\rK!!!!$)!!N!Z!!!#N%!!!!%9h!*!%!9i!N!4&D`!%!!!!R`!!!&`!!"A8!!",0A`\r)!UD3!!%!#*3Krm#!!J!!,!!!!%'#!$4)!!!"B!!!!)!#!!"m!`"!3)%!)$J!!!#\r3!!)!!$KJ!!j)!!!"B!!!!$KJ!!&)!!!)1'!!!)!"!%Ji)3"!I!J$TNk!!#"&Fa!\r!!!!"BJ!!!!a&G3#3"I`!!!!B4A-3!!!!!@)!!!!J4A-3!!!!!@)!!!!`4A8!N!A\r$!!!!1%9Z$!3!!!&M!!!!$)!!N!Z!!!"F!*!%4AF!N!@I!*!%4@X!"!!!!@3!!!#\r8!!!@#!!!5m0m#!+QNq(rr*2"rrL3!!%!#*3Krm!l``!!J!)!!#`!!!""JJ!J5!!\r!!@!!!!#!!J!!I'!B8$J!!$ari`1@5!!!#$[J!!!S(J!!3B)!'%J!!!&J!!!!("i\r!2(`!'K4)!!!)1!!!!*!!!J!!,"m!!%#!!!`iB!!!5!!!#$Kr!!#!!3")1#%!3(`\r)!kD$iIrmJm(rq%k!!#"&Fa!!!!!"BJ!!!"K&G3#3"I`!!!!N4A-3!!!!!@)!!!!\rX4A8!N!Am!!!!6%9c%!!!!!&L!!!!C%9Z$!3!!!&R!!!!$)!!N!Z!!!#8%!!!!%9\rh!*!%!@3!N!4&DJ!%!!!"D!!!!0`!!"Bi!!"-P(`)!UD6iIrmNm(rq*1Krr56JIr\r`N!!"!!L8)Iq`N!"K!'L$`J!!Jk)!!%J!!!&J!!!!J!%!D(rJ'K4)!!!",!-!!%#\r#!$5!(J!!+!!!!%'#!$4)!!!"B!!!!(b$q&!iB!!)JCi!!%J!!!&J!!!!,!-!!%'\r#!"!iB!!%5!!!!8J!!"`i!!!!N!!G!!")!!!"B!!!!(`I'%""JIqN5!!!!@!!!!"\rmIaK31!!!2(q$!jG!J!!-1'!!!%J!!!JiI!!!J!%!@$JK!&"m#!1QJq(rr)2"rrL\r$SIrdJi(rm%k!!#"&G!-!N!3G!!!!)%9d!`#3"$F!!!!N4A8!N!Am!!!!+%9e!*!\r&R`!!!$K&G3#3"I`!!!"34A8!N!94!!!!C%9e!*!&0J!!!(K&G3#3"I`!!!#)4A8\r!N!Am!!!!Q%9Z$!3!!!&V!!!!$)!!N!Z!!!$F)!!!!%9h!*!%!@J!N!4&D`!%!!!\r"E!!!!$J!!"D1!!"0LA`)!UD3!!%!#*3Krm#3!'%!@)!"!&JF!!!$2'!!!6KM`e"\rmB"Z@5!!!!B!"!%Ji)3"!I!J$TNk!!#"&G3#3"!&S!!!!*%9Z$!3!!!&Z!!!!$)!\r!N!Z!!!!i!*!%4AF!N!3"E!#3"%9U!!3!!!&[!!!"(!!!&X!!!&%(I!J#TVl"rpL\r3!!%!#*3Krj!!1q-!!$YJ!!#J!`!!,!!!!d'#!"#J(`!!,!!!"8##!0LJ(`!19!!\r&ld'#!-b!(`!#9"R'2U!I!!j8!!3XI"V,H$J!!!#3!!%!1$[!!!!iB!!Q5!!!!@!\r!!!"mI4Yj3))!2$KJ!"C)!!!"B!!!!$L!!#")!!!"B!!!!$V$!!!mB%Y$1*B!!$K\rM5&*)!!!"B!!!!$[$!!#$S`!!+"d!!%'#!$3iI3!!1*S!!$LK!$K)!!!"B!!!!$Z\r$!!!S(J!!3B)!'$Kq!!")!!!"B!!!!%J!!!L$R`!#9jJ'2PH!!Kjm&iC`,"J!,N'\r#!!`X&`!Z3))!#$YJ!!%iH`!!J!%!H$JK!("m#!1QZX(rf%k!!#"&G3#3"!&`!!!\r!B%9e!*!%!A!!!!"d4A8!N!3"F3!!!)"&G3#3"!&b!!!!Q%9e!*!%!A-!!!#m4A8\r!N!9'!!!!e%9Z$!3!!!'&!!!!$)!!N!Z!!!%F8!!!!%9h!*!%!@m!N!4&D`!%!!!\r"KJ!!!&`!!"IQ!!"@GR`)!UD6iIrmN!!"!!L8)Ir!5!!!!@!!!!#$i`!#5!!!)$K\rr!!C)!!!"9'!'2d'#!!`iB!!"5!!!&)2r!!!S(`!!3),ri$KJ!!#!!3")1#%!3(`\r)!kD$iIrm6S!!)%9e!*!%!BF!!!!34A8!N!3"E`!!!#4&EJ`%!!!"N`!!!!b!!*!\r,J!!!A!J!!!"&G`#3"!''!*!%4@m&"!!!!C3!!!!%!!!!!`!!9fB!!!!"4@X!"!!\r!!CJ!!!+i!!!B-!!!9jCm#!+Q[b(rj*!!!3!)P#(rN!!l)`!!1d3!!)1#!!#$`J!\r!L!)!!(`!"h9!JJ!81!!!!CJ#!!!i!!!"Q!)!!$ZJ!!DS!J!!B"Z%!SJH!!`S!!!\r!3))!$$Kq!!")!!!"L!)!!#J!!!""JJ"39b!'2LJ!!!P!JJ!-1rS!!%J!!!b!BJ!\r!Jq-!!)!F!!"m!2S8N!!F!!#!(!!!9!!'rR`!q!"!J!!-1'!!)%J!!!L!I!!!5!!\r!!@!!!!")!!!"9'!'2d##!G#!BJ!!J!-!!#`!!!"!JJ!`L!)!!#J!!!""JJ!NL"i\r!$bJ!!!"!JJ!3U!)!!'!E"!")!!!-1'!!!%J!!DaA)!Bq,!!!#%'#!#"!J!!3,!!\r!!8'#!"4)!!!F,!!!#N#!!"4)!!!-I"VS!%#!!!JlS!!!1(X!!$L"!$Ji[3!!1-!\r!!%J!!!&J!!!!9'!'2d'#!05J!3!i,!!!$d'#!'a!J!!3,!!!!8'#!"4)!!#i,!!\r!&d'#!(K)!!#XJ!)!!#J!!!""JJ!8J')!!)!$!!3S!!!!3))!N!#!B3"#1)%!5%J\r!!!&J!!!!I'!(0#`!!!*!JJ"d1'%!1)#"!%K)!!!"B!!!!%J!!'#!!3!k9!!(rd'\r#!"!i!!!"Q!)!!%J!!%Ji!!!!Q!)!!%J!!$b!!J!!+!!!!%'#!"5!BJ!!J!-!A#J\r!!!"!JJ!JJ')!!)J$!!!S!!!!3B)!%$KK!$K)!!!"B!!!!+#"!$Ji!!!!9!!%2MK\rJrrpm!#!3I!-"N!#J!3!i+!!!'%#!!%5!!J!!+!!!!%'#!$L!BJ!!S!%!1&3!%$T\rm!`!Z+!!!!%'#!#!iB3!iJ))!!+!"!$K8!"!kIB3!,NJ!!!&J!!!!1'!!!%J!!"`\rmB!!"1)!!!$KMrrp)!!!"B!!!!$KJrrq!!3"i1#%!F(`)!kDl)IrN6S!!)%9d!`!\r!!!'9!!!!'%9d!`#3"!)!!!!F4A-3!!!!!CF!!!!J4A-3!!!!!CB!!!!`4A-3!!!\r!!CF!!!!i4A-3!*!%*!!!!%"&G3#3"@S!!!"B4A-3!!!!!CB!!!"F4A3$!*!%)J!\r!!(a&G3#3"!'C!!!!V%9e!*!%!BB!!!#d4A3$!!!!!C3!!!$!4A-3!!!!!CB!!!$\r34A-3!*!%*!!!!1K&G3#3"!'D!!!"3%9c%!#3"#-!!!&i4A-3!*!%)`!!!B4&G3#\r3"!'E!!!"R%9e!*!%!C`!!!'i4A-3!!!!!CB!!!(84A-3!!!!!CB!!!(J4A-3!*!\r%)`!!!HK&Fa!!N!3M!!!"p%9d!`#3"$3!!!)%4A8!N!3"R3!!!KK&Fa!!N!3M!!!\r#4%9c%!#3"#-!!!*34A-3!*!%)`!!!Qa&G3#3"9%!!!*m4A8!N!3"RJ!!!TK&EJ`\r%!!!"p!!!!!b!!*!,J!!#Z$J!!!"&G`#3"!'B!*!%4@X!"!!!!I8!!!"d!!!CRJ!\r!AUGm#!+QNq(rr*2"rrL3!!%!#*3Krm!li`!!X)%!ATLK!'-mB!!"1)!!!6KMU*p\r)!!!"B!!!!$[$!!#JB3"HL)%!BdJ!!!&J!!!!I'2`8$!$rrpm!"N3Q"m!!$Kr!!#\r!!3")1#%!3(`)!kD$iIrmJm(rq%k!!#"&G3#3"!(f!!!!,%9e!*!%!IB!!!"!4@i\r-"!!!!IN!!!!-J!#3#i!!!(33!!!!4AF!N!3"p3#3"%9V!!3!!!(k!!!!F!!!'H3\r!!&mlI!J#TT2Krrb6`IriN!!"!!L8)Iq`1q-!!*!!J3"XN!#K!(!l`!!!J'%!E$L\r"!$K)!!!"B!!!!(aJ"c9!JJ!BJ'%!1)!"!("m!`!!3B!!#$[!!!'Eh`!!1(m!!)!\r"!&Ji)3"3I!J$TS2Krrb$`Iri6S!!)%9e!*!%!IX!!!!X4@i-"!!!!Ii!!!!-J!#\r3#i!!!(!3!!!!4AF!N!3"qJ#3"%9V!!3!!!(r!!!!I!!!'MJ!!&qXI!J#TT2Krrb\r6`IriN!!"!!L8)Iq`1q-!!*!!J3"XN!#K!(#3!-%!G$[!!!#!B3"X1)%!1%J!!!&\rJ!!!!I'!(08##!##!J3"dJ'%!1)!"!("mB!!iI!3!!%##!!Jl`!!"Qpm!!$Kr!!#\r!!3"B1#%!8(`)!kD$iIrmJm(rq%k!!#"&G3#3"!(l!!!!-%9Z$!3!!!)!N!3-J!#\r3#i!!!(`3!!!!4AF!N!3"r`#3"%9V!!3!!!)"!!!!E!!!'TS!!'!aI!J#TT2Krrb\r6`IriN!!"!!L8)Ir!1q-!!*!!J3"FN!#K!'!l`!!!J'%!A)J$!!!S!!!!3B)!()'\r"!'")!!!"B!!!!(aJ"c9!JJ!)1m!!!C[I!!!iI`!!J!%!5$JK!%"m#!1QJq(rr)2\r"rrK1J!!J4A8!N!94!!!!1%9Z$!3!!!)%!!!!$)!!N!Z!!!"X%!!!!%9h!*!%!J%\r!N!4&D`!%!!!#"3!!!%`!!"VB!!"JRA`)!UD6iIrmN!!"!!L8)Ir!1q-!!*!!J3"\rFJB%!A%J!!!&J!!!!I'!(0(`!!$48!0PqQ"m!!$Kr!!#!!3")1#%!3(`)!kD$iIr\rm6S!!)%9e!*!&83!!!"a&EJ`%!!!#"J!!!!b!!*!,J!!!6!J!!!"&G`#3"!)&!*!\r%4@X!"!!!!JF!!!"N!!!E%!!!B0Ym#!+QNq(rr*2"rrL3!!%!#*3Krm!li`!!N!#\rK!'#)"!!!+!!!!%'#!"`i!!!"Q"m!!)'"!'")!!!"B!!!!%J!!!`i!!!!Q"m!!$K\rr!!#!!3")1#%!3(`)!kD$iIrmJm(rq%k!!#"&G3#3"9%!!!!d4@i-"!!!!JJ!!!!\r-J!#3#i!!!'33!!!!4AF!N!3#"`#3"%9V!!3!!!)*!!!!4!!!'hB!!'&VI!J#TT2\rKrrb3!!%!#*3Krm!li`!!N!#"!&`i!!!"Q!-!!)'"!&a)!!!"B!!!!$Kr!!#!!3"\r)1#%!3(`)!kD$iIrm6S!!)%9e!*!&83!!!#4&EJ`%!!!##J!!!!b!!*!,J!!!4!J\r!!!"&G`#3"!)*!*!%4@X!"!!!!JX!!!!S!!!EYJ!!BDii`!!!L!3!!#J!!!""JJ!\r8L!8!!#J!!!""JJ!)1-!!!CM$!!"1J!!J4@X!"!!!!K)!!!#3!!!!'r`!!')+I!J\r#TT!!!3!)P#(r`*!!B3"BN!#"!&b)!J!!I!!(G8##!"3i!!!"X!)!!$J!!!'B!J!\r!U!)!!#`!!!&!JJ!X5!!!!@!!!!#`BJ!!I'!(08##!"JiBJ!!1))!!%J!!!&J!!!\r!X')!!+J#!!#!B3"BX!-!!+J#!!#!B3"FX!-!!+KL!!#!!3")1#%!3(`)!kC1J!!\rJ4A-3!!!!!K%!!!!84A-3!!!!!K!!!!!N4A-3!!!!!K%!!!!X4A-3!!!!!K!!!!!\r`4A8!N!3#%`!!!$a&Fa!!!!!#%!!!!%4&Fa!!!!!#$`!!!&"&Fa!!!!!#$J!!!&4\r&G3#3"!)8!!!!@%9c%!!!!!)3!!!!B%9c%!!!!!)1!!!!C%9c%!!!!!)2!!!!F%9\rc%!!!!!)3!!!!I%9Z$!3!!!)A!!!!$)!!N!Z!!!#3!!#3"%9h!*!%!K)!N!4&D`!\r%!!!#'!!!!'3!!"a8!!"MMR`)!UD3!!%!#*3Krm#!BJ!!5!!!!@!!!!#!BJ!!5!!\r!!@!!!!#!BJ!!5!!!!@!!!!#!BJ!!5!!!!@!!!!#!BJ!!5!!!!@!!!!#!BJ!!5!!\r!!@!!!!#!!3")1#%!3(`)!kC1J!!J4A3$!!!!!KN!!!!-4A8!N!3#'J!!!""&G!-\r!!!!#'`!!!"K&G3#3"!)D!!!!(%9d!`!!!!)F!!!!*%9e!*!%!KS!!!!S4A3$!!!\r!!Kd!!!!`4A8!N!3#'J!!!$4&G!-!!!!#(J!!!$a&G3#3"!)D!!!!3%9d!`!!!!)\rI!!!!5%9e!*!%!KS!!!"-4@i-"!!!!L!!!!!-J!#3#i!!!'3!N!4&G`#3"!)B!*!\r%4@X!"!!!!KS!!!!X!!!FS!!!C(Pm#!+QN!!"!!L8)Ir!N!"K!&L"J3"B5!!!!@!\r!!!#!!3")1#%!3(`)!kC1J!!J4A8!N!94!!!!&%9Z$!3!!!)L!!!!$)!!N!Z!!!!\rX!*!%4AF!N!3#'J#3"%9Z"3%!!!)M!!!!$Irrrl%!!'4j8fpMDf9d4'pYB@PZ!!!\r$c89Z"33!!!)N!!!!#2rrrl!!!'4j!*!)4AB&!!!!!L-!N!4&E`8%!!!"4J!!!"M\rrrrq[!!"NH3#3'%9f"3!!!!)N!*!%4AB+!!!!!L8!!!!84AB+!!!!!LB!!!!34AB\r+!!!!!LF!!!!-4AB+!!!!!LJ!!!!)4@S!"!!!!LN!!!%SJ!#3"h`)!UD3!!%!#*3\rKrm#!BJ!!5!!!!B"L!!")!!!"J))!!)#L!!")!!!"B!!!!)"L!!!mJ'Cc1+!!!MM\r!!!)iK#!J5!!!!B"L!!!mJ'&X1+!!!6M!!!%iK'Pc5!!!!B"L!!!mJ(0d1+!!!6M\r!!!%iK'4Q5!!!!B"L!!!mJ'pc1+!!#$M!!!JiK#!J5!!!!B"L!!!mJ'0b1+!!!6M\r!!!%iK'dJ5!!!!B"L!!#!JJ!!J+)!!%J!!!'!BJ!!J))!!)#L!!")!!!"J')!!$b\r!EQ`iS!!"1-!!!6L%GA")!!!"J')!!)##!!#!SJ!!5!!!!B"L!!!mJ'9f1+!!!6M\r!!!%iK'jd5!!!!B"L!!!mJ(4Y1+!!!ML%Ch*)!!!"J!%!5$JK!%"m#!1Q6S!!)%9\rd!`#3"!)!!!!-4A8!N!8p!!!!%%9d!`#3""B!!!!84A8!N!3"9J!!!"K&G!-!!!!\r#+J!!!"a&G!-!N!39!!!!)%9e!*!%!LX!!!!N4A3$!*!%+3!!!#a&G3#3"!(r!!!\r!3%9d!`#3"#`!!!"%4A8!N!3"r`!!!&K&G!-!N!3Y!!!!A%9e!*!%!Im!!!"`4A3\r$!*!%,J!!!(4&G3#3"!(r!!!!L%9d!`#3"#m!!!#-4A8!N!3"r`!!!+"&G!-!N!3\r`!!!!T%9d!`#3"#m!!!#S4A3$!!!!!L`!!!#X4A8!N!3#!3!!!,"&G!-!N!3a!!!\r!Y%9d!`#3"$!!!!#i4A3$!!!!!Ld!!!#m4A8!N!3#!3!!!-"&G!-!N!3b!!!!a%9\re!*!%!Im!!!$B4A3$!*!%-`!!!0a&G!-!N!3a!!!!i%9d!`#3"$)!!!$N4A8!N!3\r##`!!!1K&G!-!N!3d!!!!l%9e!*!%!Im!!!%!4A3$!*!%03!!!34&G3#3"!(k!!!\r"&%9Z$!3!!!)Z!!!!$)!!N!Z!!!%S!*!%4AF!N!3#+3#3"%9X%!%!!!)4!!!!!3!\r!!!F!!')+4@`3!J!!!K!!!!!#!!!!#`!!BJT&E"!#!!!#$`!!!!)!!!!,!!"L#N9\rX%!)!!!)1!!!!!J!!!!X!!')+4@`3!3!!!CF!!!!"!!!!"`!!9jC&E"!"!!!"PJ!\r!!!%!!!!'!!"APN9Y"33!!!'9!!!!"!!!!!-!!&Gk4@`3"!!!!@)!!!!%!!!!!`!\r!5aP&E38%!!!"23!!!!Mrrrr+!!"!U%9Y"33!!!%m!!!!82rrrmX!!%"[4@d&!J!\r!!$X!!!!#!!!!#`!!#I0&E38"!!!!1J!!!!%!!!!'!!!*a%9Y"3%!!!!e!!!!![r\rrrr8!!!J'4@d&!3!!!$3!!!!#rrrrp3!!"iP&E38"!!!!-`!!!!,rrrre!!!(B89\rY"3%!!!!b!!!!![rrrr8!!!Ef4@d&!3!!!$%!!!!#rrrrp3!!"Xa&E38"!!!!-!!\r!!!,rrrre!!!'U89Y"3%!!!![!!!!![rrrr8!!!C+4@d&!3!!!#i!!!!#rrrrp3!\r!"H"&E38"!!!!,3!!!!,rrrre!!!&F%9Y"3%!!!!X!!!!![rrrr8!!!8"4@d&!3!\r!!#N!!!!#rrrrp3!!"*9&E38"!!!!+!!!!!%!!!!'!!!%Fd9X%!3!!!!R!!!!"!!\r!!!-!!!3h4@`3"!!!!#B!!!!%!!!!!`!!""P&E"!#!!!!*!!!!!)!!!!,!!!$h%9\rX%!3!!!!M!!!!"!!!!'S!!!1b4@d&"!!!!#%!!!!%rrrrpJ!!!fa&E38%!!!!&J!\r!!3,rrrrk!!!#dN9X"3%!!!!9!!!!$2rrrrX!!!,54@d&"!!!!!)!!!!Drj!%!!!\r#Jd9[#J3!!!)[!!!!#)!!N!p&GJ#3"!)D!*!%4AB2!!!!!M!!!!!%4@m+"!!!!M%\r!!!!)J!#3$d9f!*!%!KJ!N!4&GJm!!!!#-!!!!!4&E`S%!!!#-J!!!!L!!*!24AB\r!N!3#%J#3"%9f$`!!!!)`!!!!"%9[#J3!!!)c!!!!#)!!N!p&GJ#3"!),!*!%4AB\r2!!!!!M!!!!!%4@m+"!!!!M3!!!!)J!#3$d9f!*!%!JN!N!4&GJm!!!!#-!!!!!4\r&E`S%!!!#03!!!!L!!*!24AB!N!3#"`#3"%9f$`!!!!)`!!!!"%9[#J3!!!)f!!!\r!#)!!N!p&GJ#3"!)&!*!%4AB2!!!!!M!!!!!%4@m+"!!!!MF!!!!)J!#3$d9f!*!\r%!J%!N!4&GJm!!!!#-!!!!!4&E`S%!!!#1!!!!!L!!*!24AB!N!3"r`#3"%9f$`!\r!!!)`!!!!"%9[#J3!!!)j!!!!#)!!N!p&GJ#3"!(k!*!%4AB2!!!!!M!!!!!%4@m\r+"!!!!MS!!!!)J!#3$d9f!*!%!I8!N!4&GJm!!!!#-!!!!!4&E`S%!!!#1`!!!!L\r!!*!24AB!N!3"KJ#3"%9f$`!!!!)`!!!!"%9[#J3!!!)m!!!!#)!!N!p&GJ#3"!&\rX!*!%4AB2!!!!!M!!!!!%4@m+"!!!!Md!!!!)J!#3$d9f!*!%!@3!N!4&GJm!!!!\r#-!!!!!4&E`S%!!!#2J!!!!L!!*!24AB!N!@I!*!%4AB2!!!!!M!!!!!%4@m+"!!\r!!LS!!!!)J!#3$d9f!*!%!9i!N!4&GJm!!!!#-!!!!!4&E`S%!!!#2`!!!!L!!*!\r24AB!N!@-!*!%4AB2!!!!!M!!!!!%4@m+"!!!!N!!!!!)J!#3$d9f!*!&I`#3"%9\rf$`!!!!)`!!!!"%9[#J3!!!*"!!!!#)!!N!p&GJ#3"A8!N!4&GJm!!!!#-!!!!!4\r&E`S%!!!#3J!!!!L!!*!24AB!N!3"9J#3"%9f$`!!!!)`!!!!"%9Z#J3!!!&A!!!\r!#)!!N!p&GJ#3"!&5!*!%4AB2!!!!!M!!!!!%4@m+"!!!!N-!!!!)J!#3$d9f!*!\r%!9%!N!4&GJm!!!!#-!!!!!4&E`S%!!!#*3!!!!L!!*!24AB!N!3"6`#3"%9f$`!\r!!!)`!!!!"%9[#J3!!!)Q!!!!#)!!N!p&GJ#3"!&0!*!%4AB2!!!!!M!!!!!%4@m\r+"!!!!LF!!!!)J!#3$d9f!*!%!8X!N!4&GJm!!!!#-!!!!!4&E`S%!!!#+!!!!!L\r!!*!24AB!N!3"53#3"%9f$`!!!!)`!!!!"%9[#J3!!!*%!!!!#)!!N!p&GJ#3"!&\r&!*!%4AB2!!!!!M!!!!!%4@m+"!!!!N8!!!!)J!#3$d9f!*!%!8)!N!4&GJm!!!!\r#-!!!!!4&E`U%!!!#4J!!!!L!!*!24AB!N!9d!*!%4AB2!!!!!M!!!!!%4@m+"!!\r!!NF!!!!)J!#3$d9f!*!%!6X!N!4&GJm!!!!#-!!!!!4&E`S%!!!#5!!!!!L!!*!\r24AB!N!3"1!#3"%9f$`!!!!)`!!!!"%9[#J3!!!**!!!!#)!!N!p&GJ#3"!%h!*!\r%4AB2!!!!!M!!!!!%4@m+"!!!!NS!!!!)J!#3$d9f!*!%!5m!N!4&GJm!!!!#-!!\r!!!4&E`S%!!!#5`!!!!L!!*!24AB!N!3",3#3"%9f$`!!!!)`!!!!"%9[#J3!!!*\r-!!!!#)!!N!p&GJ#3"!%R!*!%4AB2!!!!!M!!!!!%4@m+"!!!!Nd!!!!)J!#3$d9\rf!*!%!5-!N!4&GJm!!!!#-!!!!!4&E`S%!!!#6J!!!!L!!*!24AB!N!3")!#3"%9\rf$`!!!!)`!!!!"%9[#J3!!!*2!!!!#)!!N!p&GJ#3"!%H!*!%4AB2!!!!!M!!!!!\r%4@m+"!!!!P!!!!!)J!#3$d9f!*!&K!#3"%9f$`!!!!)`!!!!"%9[#J3!!!*4!!!\r!#)!!N!p&GJ#3"!%D!*!%4AB2!!!!!M!!!!!%4@m+"!!!!P)!!!!)J!#3$d9f!*!\r%!4J!N!4&GJm!!!!#-!!!!!4&E`U%!!!"%`!!!!L!!*!24AB!N!3"&3#3"%9f$`!\r!!!)`!!!!"%9[#J3!!!*6!!!!#)!!N!p&GJ#3"IS!N!4&GJm!!!!#-!!!!!4&E`S\r%!!!#9!!!!!L!!*!24AB!N!AB!*!%4AB2!!!!!M!!!!!%4@m+"!!!!P8!!!!)J!#\r3$d9f!*!&e3#3"%9f$`!!!!)`!!!!"%9[#J3!!!*@!!!!#)!!N!p&GJ#3"G%!N!4\r&GJm!!!!#-!!!!!4&E`S%!!!#9`!!!!L!!*!24AB!N!A2!*!%4AB2!!!!!M!!!!!\r%4@m+"!!!!PJ!!!!)J!#3$d9f!*!&aJ#3"%9f$`!!!!)`!!!!"%9[#J3!!!*C!!!\r!#)!!N!p&GJ#3"DF!N!4&GJm!!!!#-!!!!!4&E`S%!!!#@J!!!!L!!*!24AB!N!@\rN!*!%4AB2!!!!!M!!!!!%4@m+"!!!!PX!!!!)J!#3$d9f!*!&RJ#3"%9f$`!!!!)\r`!!!!"%9[#J3!!!*F!!!!#)!!N!p&GJ#3"C`!N!4&GJm!!!!#-!!!!!4&E`S%!!!\r#A3!!!!L!!*!24AB!N!@D!*!%4AB2!!!!!M!!!!!%4@m+"!!!!Pi!!!!)J!#3$d9\rf!*!&P`#3"%9f$`!!!!)`!!!!"%9[#J3!!!*I!!!!#)!!N!p&GJ#3"C-!N!4&GJm\r!!!!#-!!!!!4&E`S%!!!#B!!!!!L!!*!24AB!N!@,!*!%4AB2!!!!!M!!!!!%4@m\r+"!!!!Q%!!!!)J!#3$d9f!*!&KJ#3"%9f$`!!!!)`!!!!"%9[#J3!!!*L!!!!#)!\r!N!p&GJ#3"B)!N!4&GJm!!!!#-!!!!!4&E`S%!!!#B`!!!!L!!*!24AB!N!9q!*!\r%4AB2!!!!!M!!!!!%4@m+"!!!!Q3!!!!)J!#3$d9f!*!&F`#3"%9f$`!!!!)`!!!\r!"%9[#J3!!!*P!!!!#)!!N!p&GJ#3"A)!N!4&GJm!!!!#-!!!!!4&E`S%!!!#CJ!\r!!!L!!*!24AB!N!9`!*!%4AB2!!!!!M!!!!!%4@m+"!!!!QF!!!!)J!#3$d9f!*!\r&DJ#3"%9f$`!!!!)`!!!!"%9[#J3!!!*S!!!!#)!!N!p&GJ#3"9!!N!4&GJm!!!!\r#-!!!!!4&E`S%!!!#D3!!!!L!!*!24AB!N!8p!*!%4AB2!!!!!M!!!!!%4@m+"!!\r!!QS!!!!)J!#3$d9f!*!&13#3"%9f$`!!!!)`!!!!"%9[#J3!!!*V!!!!#)!!N!p\r&GJ#3"6B!N!4&GJm!!!!#-!!!!!4&E`S%!!!!(J!!!!L!!*!24AB!N!3"Q!#3"%9\rf$`!!!!)`!!!!"%9[!`3!!!!e!!!!")!!N!Y&GJ8!N!3e!*!%4@m$"!!!!$-!!!!\r%J!#3#d9f"3#3"$-!N!4&E`-%!!!!-J!!!!5!!*!,4AB&!*!%-J#3"%9[!`3!!!)\rY!!!!")!!N!Y&GJS!!!!#,3#3"%9[!`3!!!!a!!!!")!!N!Y&GJ8!N!3a!*!%4@m\r$"!!!!L`!!!!%J!#3#d9f#J!!!!)X!*!%4@m$"!!!!$!!!!!%J!#3#d9f"3#3"$!\r!N!4&E`-%!!!!,`!!!!5!!*!,4AB&!*!%,`#3"%9[!`3!!!!Y!!!!")!!N!Y&GJ8\r!N!3Y!*!%4@m$"!!!!#`!!!!%J!#3#d9f"3#3"#`!N!4&E`-%!!!!+3!!!!5!!*!\r,4AB&!*!%+3#3"%9Z!`3!!!!9!!!!")!!N!Y&GJ8!N!39!*!%4@m$"!!!!LS!!!!\r%J!#3#d9f#J!!!!)U!*!%4@m$"!!!!Km!!!!%J!#3#d9f#J!!!!)I!*!%4@m$"!!\r!!Ki!!!!%J!#3#d9f#J!!!!)H!*!%4@m$"!!!!Kd!!!!%J!#3#d9f#J!!!!)G!*!\r%4@m$"!!!!K`!!!!%J!#3#d9f#J!!!!)F!*!%4@m$"!!!!KX!!!!%J!#3#d9f#J!\r!!!)E!*!%4@m$"!!!!KN!!!!%J!#3#d9f#J!!!!)C!*!%4@m$"!!!!$3!!!!%J!#\r3#d9f"3#3"$3!N!4&E`-%!!!"P!!!!!5!!*!,4AB&!!!!!C3!N!4&E`-%!!!"P3!\r!!!5!!*!,4AB&!!!!!C8!N!4&E`-%!!!"A`!!!!5!!*!,4AB+!!!!!9m!N!4&EJ-\r%!!!"9`!!!!5!!*!,4AB+!!!!!9F!N!4&E`-%!!!"8`!!!!5!!*!,4AB+!!!!!9-\r!N!4&E`-%!!!"4J!!!!5!!*!,4AB&!!!!!8B!N!4&E`-%!!!"23!!!!5!!*!,4AB\r&!!!!!6d!N!4&E`-%!!!!,J!!!!5!!*!,4AB&!*!%,J#3"%9[!`3!!!%m!!!!")!\r!N!Y&GJ8!!!!"2!#3"%9[!`3!!!!L!!!!")!!N!Y&GJ8!N!3L!*!%4@m$"!!!!"m\r!!!!%J!#3#d9f"3#3""m!N!4&E`-%!!!!(3!!!!5!!*!,4AB&!*!%(3#3"%9[!`3\r!!!!#!!!!")!!N!Y&GJ8!N!3#!*!%4@m$"!!!!"B!!!!%J!#3#d9f"3#3""B!N!4\r&E`-%!!!!E!!!!!5!!*!,4AB&!*!%E!#3"%9[!`3!!!!K!!!!")!!N!Y&GJ8!N!3\rK!*!%4@m$"!!!!$X!!!!%J!#3#d9f"3#3"$X!N!4&E`-%!!!!1J!!!!5!!*!,4AB\r&!*!%1J#3"%9[!`3!!!!h!!!!")!!N!Y&GJ8!N!3h!*!%4@m2"!!!!M!!N!5!!*!\r(4@J!!&0C68J!!"c5!!!!83!!!!)!N"%"!*!'#-J!!!!)!!!)d`!!!"!!!!MLrj!\r%!!!)l3!"!!!!1!!!!!-"!*!%!`!"!*!'#68!!!!)!!!*3!!!!"!!!!P2rj!%!!!\r*@`!"!!!!1!!!!!-"!*!%!`!"!*!'#MN!!!!B!!!+C!!!!$!!!!UD!!!!2!!!#V-\r!!!"-!!!+a`!!!)J!!!Y1!!!!R!!!#id!!!#S!!!,T!!!!-3!!![T!!!!d!!!$!-\r!!!$B!!!-'!!!!13!!!a6!!!!m!!!$(J!!!$i!!!-M3!!!3J!!!bR!!!"&!!!$-F\r!!!%F!!!-hJ!!!9J!!!fj!!!#R!!!$iX!!!+i!!!2Y!!!!X3!!!r0!!!#d!!!$rB\r!!!,F!!!3#J!!!ZJ!!"!J!!!$"!!!%&!!!!-3!!!3D3!!!c3!!"$F!!!$2!!!%2-\r!!!0B!!!4(`!!!iJ!!"&&!!!$P!!!%9N!!!1S!!!4J3!!!lJ!!"'A!!!$a!!!%E)\r!!!23!!!4drq3"!!!%G-!"J!!!%Irrrrc!3#3""i!!!")!!!!!`#3"4m!!!"*!!!\r!!`#3"4d!!!"+!!!!!`#3"4X!!!",rrrrmJ#3"4`!!!"1!!!!#`#3"4N!N!J5(!!\r!!$3!!"*6!!!!8!!!%US!!!"`!!!5m3!!!)J!!"-C!!!!S!!!%fm!!!$)!!!6hJ!\r!!1`!!"3A!!!"'!!!&)F!!!%S!!!8MJ!!!83!!"6p!!!"A!!!&66rN!3!!"8d!!B\r!!!"(rrrrm`%!N!3H!!!!9rrrrqm"!*!%(3!!!%N!!!!$!*!&(`!!!&hrrrrX!!-\r!!!!i!!!!AJ!!!'B!N!8F!!!!ArrrrqX!!`!!!%!!N!J9CJ!!!"!!!"9T!!!!,!!\r!&Ci!!!!m!!!9YJ!!!%J!!"Adrj!%!!!9p!!"!!!!4rrrrr-"!`!!!&J!N!JB-2q\r3"!!!'$!!N!SB8`!!!#!!!"KX!!!!+!!!')3!!!!X!!!BQ2q3"!!!'*J!!3!!!%I\rrrrrT!3#3""m!!3#3"KN8rj!%!!!C+!!!!!%!N!BC@J!!!#J!!"Q4!!!!,!!!'DX\r!!!"!!!!Ce3!!!'3!!"S!N!5%!!!D,!!!!)`!!"T$!!!!V!!!'P)!!!#m!!!DB!!\r!!-J!!"U$rj!%!!!DMJ!'!!!!GJ!!!!-"!`!!!'J!!!"h!!!!!`%$!!!!E!!!!(J\r!!!!$!3-!!!"`!!!!H3!!!!-!N!8G!!!!H[rrrrJ!N!8I!!!!HrrrrqJ!N!8H!!%\r!N!BDcJ!!!$!!!"Vm!!!!0!!!'aB!!!")!!!E3!!!!(!!!"Y[!!!!N!!!!"ZK!!!\r!X!!!'p3!!!#i!!!ElJ!!!-J!!"a$!!!!k!!!(&F!!!%)!!!FF!!!!4J!!"aq!!!\r"*!!!(+(rN!3!!"bX!!B!!!"f!!!!!`%$!!!!D!!!!(F!!!!$!3-!!!"X!!!!H!!\r!!!-"!`!!!(!!!!#!rrrrjJ%!N!3H!!!!H[rrrq8!!`!!!$J!!!"lrrrrk!#3"4d\r!!3#3"Kc#!!!!&!!!(-8!!!!F!!!Fh`!!!$J!!"d1!!!!3!!!(4S!!!"B!!!G,rq\r3"!!!(9!!!3!!!(RrrrrQ!3#3""m!!3#3"Kfp!!!!-!!!(GB!!!"!!!!H!*!%F!!\r!(NErN!3!!"j4!!J!!!"f!!!!!`%$!!!!@!!!!(F!!!!$!3-!!!"F!!!!K`!!!'B\r"!`!!!'!!!!#)!!!!C!%$!!!!C!!!!%d!!!!$!3-!!!"S!!!!9`!!!'3"!`!!!'`\r!!!#*rrrrjJ%$!!!!F!!!!([rrrrS!*!&(`!"!*!'(Si!!!!N!!!HNIq3"!!!(ZB\r!"!!!!)d!!!!$!3-!!!"B!!!!9rrrrq3"!`!!!&`!!!#*!!!!!`%$!!!!B!!!!(V\rrrrri!*!&(`!"!*!'(bB!!!!N!!!I+Iq3"!!!(i%!"!!!!)d!!!!$!3-!!!"B!!!\r!P2rrrq3"!`!!!&`!!!#9!!!!!`%$!!!!B!!!!(Vrrrri!*!&(`!"!*!'(k!!!!!\rJ!!!ISrq3"!!!(qJ!!`!!!)d!!!!$!3-!!!"B!!!!Q!!!!!-"!`!!!&`!!!"krrr\rrq!#3"4m!!3#3"L!L!!!!+!!!)#8!!!!i!!!J6`!!!&`!!#"k!!!!I!!!)+8!!!#\r%!!!JZ`!!!+3!!#$+rj!%!!!Je3!%!!!!M3!!!!-"!*!%(J!!!*6rrrrN!3-!!!"\rF!!!!PIrrrqB"!`!!!'!!!!"krrrrq!#3"4m!!3#3"L%5!!!!)!!!)5MrN!3!!#&\r#!!%!!!#0!!!!!`%$!!!!@!!"!*!')jm!!!"%!!!MSJ!!!*3!!#1q!!!!T!!!)p2\rrN!3!!#3l!!B!!!#0!!!!!`%$!!!!D!!!!+!!!!"N!3-!!!"X!!!!S3!!!!-"!`!\r!!(!!!!"0!!!!!`%$!!!!G!!!!(Vrrrri!*!&(!!!!+)!!!!$!!-!!!!i!!%!N!B\rNR!!!!%`!!#5I!!!!R!!!*,[rN!3!!#8L!!F!!!#0!!!!!`%$!!!!D!!!!+!!!!"\rN!3-!!!"X!!!!S3!!!!-"!`!!!(!!!!"0!!!!!`%$!!!!G!!!!+ArrrrN!3-!!!"\ri!!!!S[rrrqB"!`!!!(`!!!"krrrrq!#3"4`!!3#3"L9A!!!!0!!!*9S!!!#%!!!\rPGJ!!!*`!!#@L!!!![!!!*I-!!!%)!!!QQ`!!!5`!!#E!rj!%!!!Qb`!&!!!!M3!\r!!!-"!`!!!)J!!!#Urrrri3%!N!3F!!!!63!!!!-"!`!!!*!!!!!!Y[rrrpd!!`!\r!!$J!!!"krrrrq!#3"4X!!3#3"LEh!!!!(!!!*`i!!!"-!!!RIJ!!!&`!!#HD!!!\r!D!!!*l[rN!3!!#I+!!%!!!$%!!!!!`%!N!3I!!%!N!BS!`!!!$3!!#J'!!!!K!!\r!+#)!!!#F!!!S6J!!!,`!!#Kj!!!"!!!!+08!!!%N!!!Sq[q3"!!!+38!"3!!!)d\r!!!!$!3-!!!#)!!!!bIrrrpm"!`!!!)`!!!#p!!!!!`%$!!!!N!!!!!$+rrrrf`!\r$!!!!1!!!!(Vrrrri!*!&(!!"!*!'+8-!!!"%!!!T4J!!!*3!!#PLrj!%!!!Tf`!\r&!!!!M3!!!!-"!`!!!'J!!!#J!!!!C!%$!!!!E!!!!+%!!!!$!3-!!!"`!!!!63!\r!!!-"!`!!!(3!!!"krrrrq!#3"4`!!3#3"LT"!!!!6!!!+N3!!!#F!!!UB2q3"!!\r!+Z8!"`!!!)d!!!!$!3-!!!"S!!!!S!!!!'3"!`!!!'`!!!#K!!!!!`%$!!!!F!!\r!!%d!!!!$!3-!!!"d!!!!d[rrrq3"!`!!!(J!!!$6!!!!!`%$!!!!I!!!!(Vrrrr\ri!*!&(!!"!*!'+b!!!!!d!!!V)`!!!)3!!#Xr!!!!R!!!+fX!!!#m!!!VZJ!!!3`\r!!#aS!!!"-!!!,)hrN!3!!#bB!!8!!!#0!!!!!`%$!!!!L!!!!+VrrrrK!3#3""`\r!!!"0!!!!!`%$!!!!N!!!!!$+rrrrf`!$!!!!1!!!!(Vrrrri!*!&'`!"!*!',0J\r!!!!m!!!YD3!!!%`!!#em!!!!@!!!,CN!!!"m!!!Z&3!!!)!!!#ia!!!!M!!!,Pm\r!!!#3!!!!,R`!!!#i!!!ZY`!!!-3!!#l,!!!!e!!!,`J!!!$J!!!['`!!!2!!!#p\rErj!%!!![D!!)!!!!M3!!!!-"!*!%'`!!!0VrrrrD!*!&(`!!!(Vrrrri!*!&(!!\r!!23!!!"S!*!&(3!!!28!!!"S!*!&(J!!!2B!!!!'!!-!!!!i!!!!p`!!!!B!!`!\r!!$N!!!$i!!!!"J!$!!!!1J!"!*!',p!!!!"!!!!`Q`!!!&3!!$#U!!!!D!!!-,N\r!!!"i!!!`c!!!!*3!!$%0!!!!R!!!-@-!!!#`!!!a[J!!!4`!!$)r!!!"0!!!-P3\r!!!&-!!!bF3!!!93!!$+3!!!!!@`!!$+X!!!##!!!-bJ!!!)J!!!c23!!!N!!!$0\rD!!!#6!!!-fF!!!*8!!!cLJ!!!Q`!!$1R!!!#Y!!!0"!!!!,N!!!d6J!!!a3!!$5\r3!!!!!b`!!$5p!!!$A!!!04)!!!0m!!!e'3!!!iJ!!$8c!!!$U!!!06S!!!1d!!!\re9!!!!p3!!$9M!!!$i!!!0@F!!!2S!!!eN`!!!rJ!!$@l!!!%4!!!0F!!!!43!!!\red!!!"'J!!$AM!!!%E!!!0H`!!!5!!!!el`!!"*3!!$BK!!!%R!!!0N!!!!5d!!!\rfA!!!"9!!!$EB!!!&D!!!0Zd!!!@)!!!h#`!!"C3!!$F4!!!&R!!!0b)!!!@S!!!\rh3!!!"E!!!$G2!!!&`!!!0em!!!A)!!!hE`!!"GJ!!$H!!!!&i!!!0j%!!!A`!!!\rhT2q3"!!!0l)!&!!!!2d!!!!$!3#3""3!!!$qrrrrd`%!N!3C!!!"!Irrrp-"!*!\r%'J!!!3,rrrr6!3#3""X!!!%$rrrrd!%!N!33!!!""rrrrmi!!`!!!$J!!!$f!!!\r!D!#3"4`!!!$h!!!!D!#3"4d!!!$i!!!!D!#3"4i!!!%+!!!!"J!$!!!!2!!!!3X\r!!!!'!!-!!!!p!!!"$!!!!!B!!`!!!$i!!!%0rrrrdJ!$!!!!3!!!!3lrrrr5!!-\r!!!")!!!"$rrrrp)!!`!!!&!!!!%3!!!!!`#3"4)!!!%4!!!!!`#3"4%!!!#0!!!\r!!`#3"4m!!!#p!!!!!`#3"4-!!!"krrrrq!#3"4J!!3#3"MIa!!!!*!!!0r6rN!3\r!!$K(!!3!!!#0!!!!!`%$!!!!@!!!!&IrrrrN!3-!!!"F!!!!LIrrrqB"!`!!!'!\r!!!"krrrrq!#3"4m!!3#3"ML'!!!!*!!!1)RrN!3!!$MF!!3!!!#0!!!!!`%$!!!\r!@!!!!&IrrrrN!3-!!!"F!!!!LIrrrqB"!`!!!'!!!!"krrrrq!#3"4m!!3#3"MM\rm!!!!)!!!12q3"3!!188!!`!!!)d!!!!$!3-!!!"B!!!"(!!!!!-"!`!!!&`!!!"\rkrrrrq!#3"4m!!3#3"MPB!!!!(!!!19[rN!3!!$QM!!)!!!#0!!!!!`%$!!!!@!!\r!!(Vrrrri!*!&(`!"!*!'1Ei!!!!X!!!j`3!!!$`!!$RX!!!!4!!!1IN!!!"F!!!\rk$!!!!'`!!$SLrj!%!!!k4!!$!!!!M3!!!!-"!`!!!'J!!!%K!!!!!`%!N!3G!!!\r!H[rrrrJ!N!8H!!%!N!Bka3!!!#3!!$V)!!!!0!!!1[-!!!!m!!!l!Iq3"!!!1b3\r!"!!!!)d!!!!$!3-!!!"B!!!"*!!!!!)"!`!!!&`!!!%Prrrrc3%$!!!!B!!!!(V\rrrrri!*!&(`!"!*!'1h%!!!!X!!!lG2q3"!!!1pF!"J!!!)d!!!!$!3-!!!"B!!!\r"+!!!!!-"!`!!!&`!!!%T!!!!!`%$!!!!B!!!!5S!!!"N!3-!!!"N!!!"+rrrrqB\r"!`!!!'J!!!"krrrrq!#3"4m!!3#3"M`S!!!!,!!!2#[rN!3!!$bA!!B!!!#0!!!\r!!`%$!!!!@!!!!5J!!!!$!3-!!!"F!!!"+3!!!!-"!`!!!'!!!!%U!!!!C!%$!!!\r!C!!!!5X!!!!$!3-!!!"S!!!!H[rrrrJ!N!8I!*!)20!!!!!X!!!mp`!!!$J!!$d\re!!!!4!!!2A3!!!"3!!!pY3!!!&J!!$hErj!%!!!pf`!#!!!"-2rrrm`"!*!%!`!\r!!6Errrrf!3#3"!3!!3#3"Mi*!!!!,!!!2M!!!!!i!!!qB`!!!%3!!$kA!!!!8!!\r!2X`!!!"F!!!qrj!&!!!r'3!"!!!"-2rrrm`"!*!%!`!"!*!'2d)!!!!%!!!r8J!\r!!"J!!$q@!!!!-!!!2ki!!!"B!!!raIq3"!!!2mm!!J!!!6N!!!"U!3#3"!-!!!%\rk!!!!#`#3"4m!!3#3"Mrkrj!%!!"!$3!!!!%!N!C""!!!!"J!!%%(!!!!0!!!38`\r!!!"%!!""HIq3"!!!3C%!!3!!!(B!!!!$!3#3""m!N!K"V`!!!!`!!%'b!!!!(!!\r!3FF!!!!S!!""i2q3"!!!3H!!!!!"!*!'3JS!!!!`!!"$)!!!!$`!!%-l!!!!C!!\r!3i-!!!"`!!"$S2q3"!!!3k!!!J!!!%IrrrrS!3#3""i!!!"f!!!!!`%!N!3G!!%\r!N!C$`Iq3"!!!3m-!!3!!!%IrrrrS!3#3""m!!3#3"N3Z!!!!$!!!4$(rN!3!!%4\rA!!!!!3#3"N5R!!!!$!!!4+VrN!3!!%6*!!!!!3#3"N82!!!!$!!!44,rN!3!!%8\ra!*!+49ArN!3!!%99!*!+4EN!!!!-!!"&[!!!!"J!!%A,rj!%!!"&b`!!!!%!N!C\r&k3!!!"J!!%AXrj!%!!"''!!"!!!!4rrrrqN"!*!%(`!"!*!'4Nm!!!!X!!"'AJ!\r!!$3!!%D&!!!!3!!!4U)!!!")!!"'b3!!!&`!!%EJ!!!!I!!!4a`!!!#-!!"()2q\r3"!!!4cX!"!!!!%IrrrrT!3#3""d!!!"krrrrq!%!N!3H!!!"@J!!!!-"!*!%(!!\r!!(N!!!!,!*!&(`!"!*!'4ei!!!!J!!"(FJ!!!#3!!%H$!!!!4!!!4ld!!!"3!!"\r(f3!!!(!!!%J)!!!!N!!!!%JArj!%!!"))3!$!!!!4rrrrqN"!*!%(3!!!(N!!!!\r$!3#3""m!!!"krrrrq!#3"4i!!3#3"NK0!!!!)!!!5'%!!!!N!!")F`!!!%3!!%L\r[!!!!9!!!50[rN!3!!%MS!!-!!!"(rrrrk3%!N!3G!!!!H3!!!!-"!*!%(`!!!(V\rrrrri!*!&(J!"!*!'55m!!!!J!!"*E`!!!$J!!%T@!!!!5!!!5Ti!!!"B!!"+XIq\r3"!!!5VX!!J!!!%IrrrrT!3#3""i!!!"*!!!!!`#3"4m!!3#3"NY+!!!!$!!!5dd\r!!!!X!!",I!!!!$J!!%Z0!!!!5!!!5lErN!3!!%[!!!!!!3#3"N[Irj!%!!"-N3!\r#!!!"C3!!!!)"!*!%(J!!!@B!!!!$!*!&(`!"!*!'6,8!!!!S!!"-Z!!!!$J!!%d\rI!!!!Q!!!656rN!3!!%f'!!-!!!&T!!!!!`%$!!!!D!!!!@B!!!!$!*!&(!!!!@S\r!!!!$!*!&(`#3#%fP!!!!*!!!6DJ!!!!S!!"0bIq3"!!!6FN!!3!!!@d!!!!#!3-\r!!!"B!!%!N!C40`!!!#3!!&(`!!!!-!!!8UF!!!!m!!"5dJ!!!'!!!&2U!!!!F!!\r!9$S!!!#B!!"8P`!!!+J!!&6M!!!!X!!!92B!!!$3!!"91!!!!0`!!&96!!!!i!!\r!99i!!!$N!!"9J3!!!2J!!&A8!!!"!!!!9JF!!!%%!!"@A2q3"!!!9R-!#`!!!A6\rrrrr*!3#3""m!!!&l!!!!CJ#3"4d!!!&m!!!!C`#3"4i!!!&p!!!!!J!$!!!!1!!\r!!Ai!!!!$!*!&&J!!!Am!!!!$!*!&&`!!!B!!!!!$!*!&'!!!!B%!!!!$!*!&(!!\r!!B)!!!!$!*!&'3!!!B-!!!!,!*!&'J!!!B3!!!!'!*!&'`!"!*!'9Si!!!!3!!"\r@T3!!!#!!!&EN!!!!-!!!9aN!!!!i!!"A-!!!!%3!!&G9rj!%!!"AB`!"!!!"L2r\rrrmF!N!8I!!%!N!CA`J!!!#`!!&I&!!!!2!!!@"-!!!"8!!"BMJ!!!&`!!&LX!!!\r!D!!!@-)!!!#%!!"C"J!!!,3!!&QL!!!!`!!!@FX!!!$F!!"D(J!!!1J!!&TU!!!\r!p!!!@TF!!!$m!!"DV3!!!53!!&VI!!!",!!!@eX!!!%`!!"EM!!!!9!!!&Zm!!!\r"H!!!@q3!!!'8!!"F%`!!!E!!!&a(!!!"`!!!A')!!!(%!!"FHJ!!!G!!!&b5!!!\r"h!!!A,-!!!(S!!"FlJ!!!J3!!&dM!!!#&!!!A@i!!!)J!!"G[J!!!QJ!!&i(!!!\r#K!!!AL-!!!+-!!"H1J!!!U!!!&j3rj!%!!"H@`!(!!!!U[rrrm)"!*!%'3!!!DS\r!!!!$!3#3""S!!!'V!!!!!`#3"4m!!!'X!!!!#`#3"4X!!!'Y!!!!!`#3"4d!!!'\rZrrrrb!!$!!!!1!!!!Drrrrr"!!-!!!")!!%!N!CHh`!!!#`!!&lLrj!%!!"I1!!\r$!!!!4rrrrl-"!*!%(`!!!IF!!!!+!3-!!!"H!!!"q!!!!!F"!`!!!'-!!3#3"Pp\rP!!!!,!!!AhErN!3!!&qT!!3!!!"(rrrrX`%!N!3I!!!!G`!!!!)"!`!!!'`!!!(\rm!!!!!`%$!!!!F!!!!Id!!!!$!!-!!!!i!!%!N!CIi3!!!$!!!&rbrj!%!!"J,J!\r&!!!!4rrrrl-"!*!%(`!!!(F!!!!#!3-!!!"X!!!"V!!!!!-"!`!!!(!!!!(m!!!\r!!`%$!!!!G!!!!Id!!!!$!!-!!!!i!!%!N!CJGrq3"!!!B*S!!`!!!%Irrrqc!3#\r3""m!!!)#rrrrX`%$!!!!A!!!!J2rrrrf!3-!!!"J!!%!N!CJa3!!!"`!!'$)rj!\r%!!"Jf!!#!!!!4rrrrl-"!*!%(`!!!J2rrrrf!3-!!!"F!!%!N!CK)!!!!#J!!'%\rj!!!!0!!!B8J!!!!m!!"K83!!!%!!!'&D!!!!5!!!B@MrN!3!!'&S!!-!!!"(rrr\rrX`%!N!3I!!!#![rrrl-"!*!%(J!!!J2rrrrf!3-!!!"J!!%!N!CKNJ!!!#3!!''\rM!!!!,!!!BD[rN!3!!''V!!)!!!"(rrrrX`%!N!3I!!!#!rrrrrB"!`!!!&`!!3#\r3"Q(`!!!!*!!!BJIrN!3!!')(!!-!!!"(rrrrX`%!N!3$!!!#$2rrrl-"!*!%"!!\r!!Jhrrrqc!3#3"!8!!3#3"Q)p!!!!)!!!BQX!!!!`!!"LJ`!!!$`!!'+6!!!!8!!\r!BUi!!!"N!!"Lf2q3"!!!B`-!!J!!!KArrrqb!3-!!!"B!!!#&[rrrl)"!`!!!&`\r!N!KMTJ!!!!`!!'1T!!!!'!!!Bmm!!!!N!!"Mp!!!!$!!!'38!!!!2!!!C$3!!!"\r)!!"N93!!!&3!!'4frj!%!!"NGJ#3#Q5B!!!!&!!!C*X!!!!F!!"NSrq3"!!!C+-\r!!3!!!L(rrrrf!3-!!!"B!!(rrrrm!!!!"!!!!!%!!!!(!!,rrrrp!!!!%3!!!!`\r!!`!!!",rrrrm!*!(%`!!!!)!!!!%!!!!&!!!!!)!!!!)!!$rrrrq!!(rrrrp!!,\rrN!3!!!!$!!!!'J!0!!!!"!!!!!)!N!F&!!!!!J!!!!3!!!!'!!!!"`!!!!J!!!!\r(!!!!"J!!!!N!!!!)!!!!"J!!!!S!!!!*!!!!"J!!!!X!!!!+!!!!"J!!!!`!!!!\r,!!!!"J!!!!d!!!!-!!!!"J!!!!i!!!!0!!!!"J!!!!m!!!!1!!!!!J!!!"!!!!!\r2!!!!#`!!!"3!!!!3rrrrrJ!!!"B!!IrrrrX!!!!-!!!!!3!!!!F!![rrrrF!!!!\rC!!!!"J!#!!!!'J!!!!X!N!FE!!!!C!!!!!)!!2rrrrJ!!IrrrrF!!IrrrrN!!!%\r!N!3%rrrrq!!#rrrrqJ!!!"F!!!%#!!)!!!!Brrrrq3#3"a`!!!!'!!!"!!!!rrr\rrpJ!"!!!!DJ!#rrrrp3!!!#S!!!!#!!%!!!!V!!!!"J#3"3(rrrrd!!!!!J!!!!%\r!!!!(!!$rrrrc!!(rN!3!!Irrrr!!!!!-!!!!$2rrrrd!![rrrr%!!!"-!!!!(!!\r(!!!!"!!!!!)!N!F&!!!!!J!!!!3!!!!'!!!!"`!!!!J!!!"0!!!!"J!!!!N!!!!\r1!!!!!J!!!!S!!!!2!!!!#`!!!!i!!!!3rrrrm!!!!"!!!2rrrr)!![rrrr%!![r\rrrqd!!!"D!!!!4J!$!!!!@`!!!!X!N!GF!!!!!`!!!!)!!!"A!!!!!3!!!!B!![r\rrrqi!!!"B!!!!4J!"!!!!@Irrrqd!N!Errrr[!!(rrrrZ!!(rrrrX!!!!"3!!!!%\r!!!!(!!,rrrrU!!!!C3!!!!3!!J!!!'B!!!!,!*!(C`!!!!X!!!!#!!,rrrrV!!!\r!B!!!!"!!"3!!!'%!!!!#!*!(BJ!!!!)!!!!%!!!!B`!!!!S!!!!)!!!!C2rrrqS\r!!!!+!!!!D!!!!!X!!!!1!!$rrrrT!!(rrrrk!!,rrrrR!!!!I!!!!!3!!3!!!"X\r!!!"N!*!'rrrrk!!"rrrrj`!!rrrrjJ!"!!!!!`!"rrrrj3!!!!J!!!!%rrrrq!!\r"rrrriJ!!!!i!!!!"!!!!"`!#rrrri`!!!)i!!!!3!!-!!!#2!!!!"J#3"j!!!!!\r!"J!!!!%!!!#4rrrriJ!!!!)!!2rrrq3!!Irrrq-!![rrrpi!!!#[!!!!#!!#!!!\r!X!!!!'B!N!Ha!!!!!`!!!!3!!2rrrpm!!Irrrpi!![rrrq!!!!#V!!!!(!!(!!!\r!V!!!!'B!N!HY!!!!!J!!!!3!!!#Zrrrrh`!!!!J!!!#b!!!!!J!!!!`!!!#c!!!\r!CJ!!!"!!!!#d!!!!!J!!!"3!!!#e!!!!!`!!!"J!!2rrrq%!!Irrrq!!![rrrp`\r!!!#j!!!!'!!'!!!!ZJ!!!'F!N!Hl!!!!C!!!!!3!!!#m!!!!!`!!!!J!!!#p!!!\r!!`!!!!`!!!#qrrrrh`!!!"!!!!!E!!!!C!!!!"3!![rrrpd!!!#h!!!!'!!"!!!\r!Z2rrrp`!N!8#rrrrf`!!!-X!!!!B!!%!!!#irrrrh!#3"3,rrrr@!!!!l3!!!!3\r!!3!!!1i!!!!#!*!&!Irrrp8!!!!)!!!!!3!!!!F!![rrrpF!!!$S!!!!%!!&!!!\r!k3!!!!B!N!IU!!!!"J!!!!%!!!$V!!!!#J!!!!)!!!$XrrrreJ!!!!3!!!$[rrr\rre3!!!!J!![rrrpJ!!!$G!!!!3J!0!!!!h[rrrrF!N!II!!!!C!!!!!B!!!$J!!!\r!#`!!!!S!!!$K!!!!#`!!!!`!!!$L!!!!!J!!!!i!!!$M!!!!"J!!!")!!!$N!!!\r!"J!!!"-!!!$P!!!!CJ!!!"3!!!$Q!!!!!`!!!"J!!!$Rrrrre`!!!"`!!!$`rrr\rre`!!!#`!!!$a!!!!"J!!!$`!!!$b!!!!!`!!!$i!!2rrrp3!![rrrpN!![rrrpN\r!!!$E!!!!4J!#!!!!h2rrrpJ!N!Icrrrre!!!!%)!!2rrrpS!!IrrrpN!!Irrrp%\r!!!!)!!!!"!!!!!-!![rrrp)!!!$r!!!!#!!"!!!"!2rrrp%!N!Errrr6!!(rrrr\r5!!,rrrr2!!!""!!!!!J!!J!!!38!!!!$!*!'!3B!!!!$!!!!"!!!rrrrd!!"rrr\rrc`!#rrrrcJ!!!3J!!!!%!!%!!!%*!!!!!`#3"[rrrmd!!3!!!!-!!rrrrm`!!!%\ra!!B!"!!!!6)!N!B"-`!!!!%!!!%d!!!!!J!!!68!!!!$!!(rrrr,!!!!8!!!!!6\rrrrrS!!,rrrr+!!!"2J!!!!J!!J!!!6m!!!!#!*!'!8!!!!!#!!!!"!!#rrrrb!!\r!!A8!!!!3!!8!!!&f!!!!#J#3"J&h!!!!!J!!!!)!!!&i!!!!!J!!!!B!!!&jrrr\rrkJ!!!!S!!!&k!!!!#J!!!!i!!2rrrmN!!IrrrmJ!!Irrrm-!!!!#!!!!!J!!!!X\r!![rrrm3!!!',!!!!#!!$!!!"L[rrrm8!N!B"M!!!!!X!!!!%!!!"MIrrrm-!!!!\r'!!$rrrr&!!(rrrr%!!,rrrr'!!!"L3!!!"B!"`!!!BVrrrr&!*!'!B`!!!!,!!!\r!"!!!!Bi!!!!+!!!!"J!!!Bm!!!!#!!!!#!!!!C!!!!!!!J!!!!`!!!'4rrrrkJ!\r!!"!!!!'5!!!!#J!!!"3!!2rrrmF!!IrrrmB!!rrrrm)!!!'I!!B!#J!!!D!!N!B\r"S3!!!!%!!!'L!!!!!J!!!D-!!!!$!!!"T!!!!!3!!!'P!!!!"3!!!DB!!!!'!!!\r"T`!!!!F!!!'S!!!!#!!!!DN!!!!*!!,rrrqq!!!"Y`!!!!J!"!!!!EJ!!!!,!*!\r'!EN!!!!,!!!!!J!!!ES!!!!,!!!!"!!!!EX!!!!,!!!!"J!#rrrr[`!!!E-!!!!\r1!!-!!!'d!!!!CJ#3"J'e!!!!#`!!!!3!!!'frrrr[J!!!!B!![rrrl`!!!'q!!!\r!#J!#!!!"[`!!!!S!N!B"`2rrrli!!!!#!!$rrrqp!!,rrrqm!!(rrrqk!!!!#!!\r!!!%!!!!'!!,rrrql!!!"``!!!!J!!3!!!F6rrrqk!*!&![rrrl3!!!(L!!!!&!!\r(!!!"i`!!!!)!N!B"h3!!!!F!!!!%!!!"j!!!!!F!!!!&!!!"j3!!!!S!!!!'!!!\r"j[rrrrB!!!!)!!!"hJ!!!!)!!!!-!!!"j`!!!!)!!!!3!!(rrrqe!!!!&!!!!"6\rrrrqd!!,rrrqf!!!"fJ!!!#!!#!!!!GX!!!!+!*!($J!!!!F!!!!#!!!"h!!!!!B\r!!!!$!!!"h3!!!!)!!!!%!!!"hJ!!!!B!!!!)!!!"h`!!!!B!!!!*!!!"i!!!!!S\r!!!!+!!!"iIrrrl8!!!!-!!$rrrqh!!(rrrqf!!,rrrqi!!!"f!!!!$3!$3!!!GR\rrrrqh!*!'!HMrrrqh!!!!"!!!!HRrrrqh!!!!#!!!!HVrrrqh!!!!$!!!!H[rrrq\rh!!!!%!!!!Hcrrrqh!!!!&!!!!Hhrrrqh!!!!'!!!!Hlrrrqh!!!!(!!!!Hrrrrq\rh!!!!)!!!!I$rrrqh!!!!*!!!!I(rrrqh!!!!+!!!!I,rrrqh!!!!,!!!!I2rrrq\rh!!!!-!!!rrrrZ3!"rrrrZ!!#rrrr`!!!!E!!!!"X!"N!!!'a!!!!#`#3"J'brrr\rr[`!!!!)!!!'mrrrr[J!!!"!!!!'prrrr[3!!!"J!!!("rrrr[3!!!"`!!!(#rrr\rrZ`!!!#!!!!(&rrrrZ`!!!#J!!!('rrrrkJ!!!$!!!!((rrrrkJ!!!$3!!!()!!!\r!#`!!!$J!!!(*rrrrZ`!!!$S!!!(+!!!!#`!!!%)!!!(,!!!!#`!!!%3!!!(-!!!\r!"J!!!%B!!!(0!!!!#`!!!%J!!!(1!!!!#`!!!%S!!!(2!!!!!`!!!%`!!!(3!!!\r!!`!!!&!!!!(4!!!!!`!!!&3!!!(5!!!!#`!!!&J!!!(6!!!!#`!!!&S!!!(8!!!\r!C`!!!&`!!!(9!!!!C`!!!'!!!!(@!!!!C`!!!'3!!!(ArrrrZ3!!!'J!!2rrrm%\r!!Irrrm!!!2rrrl-!!Irrrr8!!2rrrl)!!3!!!!X!!Irrrl%!!!!0!!!!!3!!!!F\r!![rrrl$rN!3!!!!)!!!!![rrrkrrN!3!!!!B!!!%U%G98dN!!ZK(990*3fpZCQP\rR!!'l4e96580[EQCTCh9bBA4TEfi!!mYNC@CKG@ad9(P`C3!'%'4PCQ&eE(4$FQ9\rKG'pb!!!ZBA9dEe0`D@i!"a&ZEd0SC'Pb!!%bB@0MGA*6G'&d!!,qD'&c3fpZFfp\rXC3!'kQj[3A9dEdPZDA4(FQ&Q!!)(FfKKFQ9N6h"PEJ!(9R0TCe"TF'8!"DTZEd&\r`F'aP4ACPER4c!!G%GQ9bFfP[EJ!$P'jeE90eCQCTBf9c!!#1Fh9QCQPMCA-!!TC\r(990*8h9QCQPi!!D`Fh9QCQPi!!#,Fh9QCP4jF'8!!r"cG@CQ3h*PBA4[FJ!%B8!\rj-6B!"l*6Ef0VCA4c!!0&8fpMDf9d9'&LE'8!"kTcEf0VCA4c!!Ej8fpMDf9d!!!\rFFQ9Q3fpeER3!"r0IAhC`G()N!!5eEQ9PC(0$EfjcEfaP!!"a4e96590`D@i!"eC\r(990*4'9QBA9XG&0`D@i!!"j(990*4AKPB`!(!%G98dP%C@CKG@ad4AKPB`!"0%G\r98dP'9(P`C3!#f'G(990*8h"PC@3!!J&PGR4)B@jNE'9b!!GaCACd6@&cD`!"I'9\rbFQpb8fpMD`!"`'9bFQpb9(P`C3!#Tf9bFQpb3fpeER3!!Lp$BA4MD&0dC%P2!!9\rkD'&c6@&VC8C68h"PB`!(SdCPBA4eFQ8!",pREfpN!!!,D'&c3@aTBA-!!#&SBA0\r1CAG64J!&XfKKFe"bEf0PFh00Ch)!!%jSBA0$8NeI8!!'a'KKFd0563!'q@KKFd0\r83J!$%@KKFe0dC%j#8&p3!!&pD'&c8h4N6N*3!!D`D'&c3A"`E'9&GQ9ZG(-!!Ej\rSBA05CACTFf9N9'PYC8eRFJ!$V5j(990*Af9bFQpb!!AaCA*bEQm!!c9PFR)!"e`\rZ4e9659pPFR*[FPpZD@`!"S*QDA*cG&4TE@9IAc%h4e96580[EQCTCh9bBA4TEfi\r!"eahC9pI-6G(990*3fpZCQPRGA*KG'P[EJ!%!d!j0MJ!"#dZAepMG&pI-6G(990\r*3fpZCQPRGA*KG'P[ENCf!!-[,N0eFP*PFdCTE'8!!jFZ9A0P8Q9c4QPXC3!&U#j\r(CA3a8Q9cEh9bBf8!"XSZ4f9d5'&ZC'aP8fPkC3!$,#jIAfjhB9pI4P9X!!D),NK\r-Ef0V!!GP,QePE@0`H3!'ibjMD'4TFJ!!p5j5C@aPBA0P8Q9cEh9bBf8!"&YdD'P\rc!!&UDJ!"D@N!!$PMEfjQ8fPkC3!')Q0[EQCTC`!'-NG98dP$EfjQD@G5Fh*M!!8\r"CQaKCh-!!Rj[E'45CA0'D@aP!!3%3$Nf13!$6bj6CA4%C@CKG@ad4P4jF'9IAc%\rh4e96580[EQCTCh9bBA4TEfj$4P*$194'D@aP8h"PB`!$P#jIAh"dFPpRE(9P!!)\r(,NK(CA4'5@jQE`!#15j36(0dFR*MD()!!'NZFh4bEQ0`H3!!!#jcG(*ZBfe`!!+\rN,NK6CA4'5@jQE`!%UfjKE@8!!AY84QPXC90`C@-!"b8N4P06F'9M!!B)4P06F'9\rM!!FHGP*PCNjeE3!&bR"KFNP%!!4)Ff9KFQ0SFh9QCQPi!!2cC'pd!!5UD@jQE`!\r&INC*EQC[!!CQCQ48HA"P!!&VCQ4$FQ9KG'pb!!HmCQ4'E'&RF`!#"QCN6'pMBA4\rTEfi!"D43EfPZG!!"GRB!!@KS!!DfCQ4'E'4b!!4$3$Ni0`!(R#j%Ed&eG'p*EQP\rd4h*KCPpI-6G(990*3fpZCQPRGA*KG'P[EN0'GJ!(q#j-68GPG%0eFR*PER4"03!\r#NR&N!!'[,NPZDA4(FQ&Q!!4G3$Nj-3!!!5j*EQPd3fpZFfpXC9pI4RB!"D8Z5@j\rTG%0[ER0[E'9IAc%a8fpMDf9d9'&LE'9'GJ!&HN!a-$!h!!Ea,QGPG'4dB@*XCA0\rTHQ8!"fBZFfpMDf9d!!(H,N4[E@&TEPpI-6*6Ef0VCA4%EfeKD@j'D3!"Pbj*ER0\rdB@aXAema-90[BfYPG&4KBQaP4P!f8fpMDf9dD3!'Gf4[E@&TEJ!%Eh4jF'8!!,9\r`FQpdEf0[E!!#-'CN!!3ZFfpMD`!$l'4[E3!%0&0[BfYPG%4[E@&TEJ!&Y%!a-$)\ra!!0#,R0[BfYPG("KDA)!!-mZ8Q9YEhCPAema-90[BfYPG&4KBQaP4QN!!Z4cGJ!\r&h%!a-$-j!!@2,R"TF'8!"%%Z4e965AGTG'K9EQPi8fpMDf9dF`!"1#jcD(9dC'p\rhEJ!&pN!a-$3c!!HI,Q0SEfpcC3!'mh"bEfe`G!!#Y'0[ER0dFQ&TER3!"k*ZB@e\rPE'9Z!!Ak3$%`0$F!"8BZBQPZC!!'r#jIAhCMAema-90[BfYPG&4KBQaP4QN!!A0\rc!!#IFfpMDf&NC()!"YKcB9pXC@i!!GGcB9pQB@eTE(N!"`KcB9pNBA4K!!Am3$%\r`0$N!!0JZBfpZEQ9MG!!%3'&NC()!"qaKC'4bE'9Z!!883$%`06%!"aSZE'PcG'9\rZ!!5&F@aPEJ!&&N!a-$8c!!HA,Q&MBf9`G!!&0d!a-$Bc!!5S,Q0XEh0PFfpMDf9\rd!!8j3$%`0M8!"3mZFQ9MGJ!$@Lj(990*3fKPBfY"E'&bE9pI4RB!"J0LG@CQCA)\r!"[GLG@CXC@i!"f9QFQpYE'9Z!!9@3$%`0c)!!F3ZFQ9MGQCbEfd!"$0QFQpY!!9\rG3$%`0cN!!1iZFQ9MGQecC`!$JbjIAf0dAemj8f0KG(4PFQ9b4P"$0@P[GQ9MD3!\r$,5jIAf4dAemj8f0KG(4PFQ9b4RB!!fYYFfF!"M9YFfGSC()!!"GYFfGIEQ&YC3!\r$-fecCepZB@ePE'9Z!!GVEA0RAfP[GJ!&-fP[GQ9M!!"bD@pfAf*KFf8!"`aTEhC\rIE'9Z!!+#EA0RAfP[GQaPEJ!$X'ecCepMEfjdFQpX!!BNEA0RAf0[ER4bEfaXC@i\r!!AYYFfGICQaKCh-!"A"cBf&dG!!"390MBA4dCA*PFJ!#2L46Bf&dG%GKG'J!!FC\r6Bf&dG%GKG'J!"aecBh*KG'0S!!1HBR9Q!!2-E'9Z!!8&BfpeER3!!TaTE`!&Q8!\ra-$Ne!!)-AepNG&pI190MBA4dCA*PFNCf!!@D3$%`16B!"JiZ5'&ZC'aP9h*TG'9\r&FR*[FR0IAdCT!!BB,R*KDA0P!!ERFQ9dGQ&X!!@I3$%a-$J!"dJZGh*TG'9f!!,\rH,PpIBh4IAcK(BA4SCA*PFNC33c9TEhCPBfN!!MBZAepNG&pI1%GKG'KPFQ9b4RB\r!!`PTEhB!"!YRBA4S!!"-4f&dD'9bCA)!"GY!-6%b0!!"VPpIC(4IAcK(BA4SCA*\rPFNCf!!AF3$%a-M8!"H-ZFf9ZC!!&q8!a-6-b!!H0,R0PEQ4dE`!#rA4[!!A(G'p\rXC@i!"3"!-6%c13!!I5jcC@jNEA0R!!8p3$%a068!"6j!-6%e0J!&E5jeF'4KG'9\rcG'&dGA-!"hJZGhK0B@06Ef0VCA4)B@jNE'9b8(*[B`!(ZA4MF(0[BfX!!Ep83e"\r6Ef0VCA3!!lXN58j&9&0[BfYPG!!#c%P14946Ef0VCA3!"rBN8fpMDf9d!!$IGhK\rbC@CMEfi!"b9hH'9fC@jd!!2RGhKPGQ9ZG'eKFfX!"R*cG(*PB@d!"XjcG'&dGA-\r!!ieZEfjLE'pMDfPZC`!(pR*PBhC#G@B!"CTbC@0fC!!#ch0K!!2NFfpMDf&NC(*\rID@i!"`*cD@jIE'9Z!!,!FfPZAfCKE@PXH3!!@R0TEPp`Eh*d!!!$FfPZAf&NC()\r!"feTEPpKC'4b!!CpFepKC'4b!!#bFfPZAhTPFQm!"1a`C@9b!!DaFh0dBA4P!!$\r(BA0jEQ0PFR)!"%*cC@aQ!!%FBf&Z9h*TG'93!!$ABf&Z8Q9KC&!!!B&PH'0PF(4\rTEfi!!'CMB@jAFQPdC3!(2'0KEP*PB@3!"AK!-6%h-!!(FLjcC@aPBh3!"cmZE@9\rYFf9d!!0,,Na04f9d9'PMDh-!"3phD@4dD!!(a(*PB@4QC(-!"ReQC&pcCA3!!#"\rQC(0IBQPdF`!!EAGbDA4PCQ4c!!(iCAKMCA"dCQ4c!!G*G'PYC@peG!!(fh4TE@9\rfB@`!"UPdGPpcC@-!"a9dGPpeFf9M!!'BFf&fC89bFQj[!!,'4A*bEQp6BACPFJ!\r$D@C6BACPC%9bFQj[!!&PC3!"GhF!!A*b!!)3C@3!!P*hC!!#XR*N!!"GGf&TG(4\rTE@8!!@KcG'&bG(4TE@8!"9a!-6)f-!!%m&pIC(4IAc%`4A*bEQp6BACPFNCf!!9\rG3$%b0M%!"BFZAepNG&pI-6"&FR*ZEe0KGQ9b4RB!!NmZAepNE&pI4P"f!!9K3$%\rb0M8!"+8ZCf9dFfpMDfjKE@8!"@0!-6)f0`!%@bjRCA4`C@9bEQ&YC3!&C8!a-MB\rj!!-'D'ph!!9p3$%b0c%!"--ZC(9`!!9r3$%b0c-!"DSZC(9`-J!#Rh-a!!@&3$%\rb0cN!"(%ZD@pMG'acEf0VCA3!"c"bCA&eCA0d!!5hBA*RF!!&Rd!a-MJc!!2[,QG\rPG(0[BfY[F(3!"@YXCACPE!!(3'p`G'jKE@8!"[e[F(4fB@`!"MG[F(4XC@i!"D&\r!-6)i03!$DLjcCA4cEf0VEh"d!!@M3$%b1$F!"$JZ4e96590PG%K[EfX!"'"MEf4\rP!!4-4e9658K[EfY$Ef4P!!A[4e9659p6F'PZ5'p[D`!&f%G98dPI4AKPBdK[EfX\r!"J&(990*AdC8HA"P5'p[D`!'"NG98dPI8h"PC@4)EfpV!!4+D'p[D`!%-5j(990\r*4f9d5'p[D`!'0bj(990*8f9d4ACPER4c!!92G'&LE'8!!lKPGR3!"NXZ4e9658G\rPG%9fC@jdF`!(Mf4[E@&TER0IAc%b8fpMDf9d4'pYB@PZ!!HBF(*[Bf9cFepI-6*\r6Ef0VCA4%EfeKD@i!!lY3FQpMCA0c8f9bD@&X6R9YBQ9b!!@-D'PRD%a[EQG2CP"\r66J!%H@a[Gda[EQG2CP"66J!&a8!a-c%f!!!R,P*PB@4jAema-P0[BfYPG%4[E@&\rTENCf!!C2,PGKDf99F&"bEf0PFh-!"Gp!-6-b-!!(kbjIAf0dAema-P0[BfYPG%4\r[E@&TENCT!!4JAepfG&pI-6*6Ef0VCA4%EfeKD@i!!M%Z4f9d3h9bFQ9ZG&"bEf0\rPFh-!"HG!-6-b1!!(i5jIAf4dAema-P0[BfYPG%4[E@&TENCf!!8"3$%c-c)!!KB\rZFfpMDf9dAema-P0[BfYPG%4[E@&TENCTF`!&!d!a-c-d!!H',R0[BfYPG("KDA*\rIAc%b8fpMDf9d4'pYB@PZ4QPc8&!f8fpMDf9d!!8&3$%c-cB!!T8ZBfK[Eh0PAem\ra-P0[BfYPG%4[E@&TENCT8'03GQP3GP"T!!8(3$%c-cJ!"(BZ4'pZG&0dFQP`Aem\ra-P0[BfYPG%4[E@&TENCf!!FL,NCXGA0S8h4ND@pIAdCf!!B&CQCXGA0S!!E-,QC\rhB@aV!!8J3$%c0$%!"Q%ZAepMG&pI-6&6Ef0VCA48B@*XC8Cf!!Eh4QaeFfK6G'4\rTEepI4RB!"j8ZBA4PH'Pd!!8L3$%c0$-!"CPcG'&bG!!&48!a-c8e!!9N3$%c0M3\r!"B&!-6-h-3!'V5jIAf4dAema-90[BfYPG&4KBQaP4RB!"MPQBfa[Ff8!"LNZBfa\r[Ff8!"D*!-6-i-J!"0dG98dP"E'&bE3!&U%!a-cJi!!Bi,Q&XBA*Y!!I1Ff9MEfj\rNF`!"-h*PE@&TEQPZC`!&`%!a-cN`!!6*,N4[8faPCA"IAdCX!!9PG'PMDh-!"Vj\rhB@YPGA!!"D4!-63`-3!(G#jeFfaPCA!!!"PeFf9MEfjNF`!&TN!a0$!c!!-H,N0\rYC&"PFQP[C&pI4P!a-89fC@jd8Q9MEh*N!!&r,NGPG&0MFQP`G%eKEQ&RCA*@BA*\rTB@*XC3!#9#j(CA46Bh*TF(4@BA*TB@*XC3!%6bj(CA45CA0[GA*MC3!&##j,CAP\r8FQ&ZFfaKG'8!!'adD'9&GQ9ZG!!$T89fC@jd8Q9MEh*N!!6CGfKKG!!(5fePFh0\rKCf8!"&0hD'9Z!!92GfKPFQ8!!5aYEf4TCQPPFR-!"mK,3dK58(4b!!9dD%Y$5&)\r!"FTcG'&dC3!'C'YPH80*C!!!3@KTCfK$D'&b!!HqE'ph3fKKFJ!(YfYPH8PZCQm\r!!ZGfDA*dG@&X5f9j!!GUDf9j3fpNC3!$j@C8D@eP9'p4G@Pd!!AM3$%d-M!!!PF\rZ4e9658PZG'9bFR9`G&pI4RB!!28Z6%e(CA4&GQ9ZG&&eCA9P!!CZCACPER44!!9\rN4AC44@`!"4Ya6'PZD`!&Ie&&E'9Y!!@DF94jF'8!"Bja4'&dB3!!Ff9fG&&AD'&\rd!!-*CACd88ePFh0KCf8!!-jPGR449fKPEJ!"[f9fG&&AD'9bC3!&%f9fG&&0Ef4\rTCQPPFR-!"30!-63c-!!#rP0dB@jN3@a[EQ8!!,9R4e96590`D@j$EfjdFQpX!!%\rjD@j'Eh*PCh*[G@jN*$%d-c%!"39!-63c-J!!##j(990*4'9QBA9XG&0`D@i!"98\rZ8QpdBA4P3h9bFfpb!!BR,PGKDA41CAKd4ACPER3!!`8Z4QPZC&GTEQ4[G`!%`5j\r6HA0dC@e$E'PMD`!%Cbj"49"bEf0PFh0"F("XC89fC@jd!!39,NCXGA0S4ACPER4\rc!!!PFh"TEPpYFfF!"d468&p0590$!!'H8e"I8d9-4808!!IP8e"I6N&043!(8e0\r3Ad&%4&)!"M"68&p69&*&38eI8N9"4!!(i&03Ae088N9"69pA8NP843!&"903Ad4\r(8N&0Ae*&383!"S*68&p%4e*"69pA8NP843!!aP03Ae0-4893!!498e"I39986ep\r68%P1!!-kBA*R!!FaBfpZG(*TBJ!%m@eKFfX!!5pcE'9PF&4TE@8!!L*PGJ!$@(G\rTEJ!!BdGbB@C3Eh*d!!DaC'9fD@0P!!"0F'pbG%*TG(-!"LC#DA40BA!!!,0LBA0\rP3@4NFJ!!IR*[Gd*jG'9c!!BVBQpeEQ4c!!4r8Q9MG!!$,h4[F!!%$'aPCR3!"L*\rLEh4dEfd!"GCbD@GSG!!!*("[FR45C@0d!!B`GQPc8QGZ!!(&6@&M8Q9RD@pZ!!G\r"FQGZ8fPkC3!(cR*REN*#EhJ!"k4ME'P`8QGZ!!@CBQY3BA3!"kT3BA4dCA*Z!!0\rKF'&d!!F8CQPXE&"KG!!&`("Z6'pM!!DVF'j6DATP!!BCF'j0Ef4P!!ArF'j3BA3\r!"4G`EPCTF`!'hR4i4QpZG!!'9A4i4Q&MC3!'-A4i6@pNC3!'ih4i8fPkC3!(Zh0\r`4AKdFQ%!"epQCd0[E'pb!!FiBQY$Efa[FJ!([@0[E(*#DA3!!XC`BA46G(*PG'0\rS!!GdF'PM8f&fC3!(SA*REP0KGQ8!!!a`Efaj8f&fC3!"-QGbB@C3FQpMF`!()e&\r%8(*[Bh-!!%GdCAKd8(*[B`!"[e*[GA4TEQ9%CA0MFQP`G'pb!!FRCfp0DAKPC%e\r[C'98FQ&`!!B)FQpeG'PZC84PFf0bDA"dEh*'E'&RF`!"9R*PFf9bGQ9N-3!"9h*\rPFf9bGQ9N-J!%Gh0PE'9MG'pb5@jQE`!%+R*[GA4TEQ9$Eh9ZG!!'m(*[GA4TEQ9\r5C@0[FQ4c!!8I8QpeG'PZC9*PBfpbC!!![h"bEf0*EQC[!!23590"!!6lFQpeG'P\rZC8CXB@Gc!!D%F(*[Bd4PFf0bDA"dEh)!!0GcC@aPBh4[FJ!!M@aTEQ93FQpM!!#\rjFQ9MG&"bEf-!!3jb8Q9MG&"bEf-!!*&[GQ&X8(*[B`!()@&bBe"bEf-!!2"`Efa\rj8(*[B`!(JA*REP"bEf-!!+TLDA4c8(*[B`!$lQ0[E@ePER43FQpM!!)lG(K0C@&\rc8(*[B`!#j'GPG&"TBe"bEf-!!R&`GA43D@03FQpM!!@N3$%d1$!!",-ZAepMG&p\rI0dCPBA4eFQ9'9A06B`!!Bbj14f9d9(*KF%&NC(*PFh-!"k0dFQ&`6R9Y!!3UG&4\rjF!!&TN!a0$Jb!!1k,PpIBh4IAcG'C@&dGA*P4P9XE!!!-5j(CA0dB@ad!!9BGQ&\rXG@8!")0KG(4b!!@S3$%d1$3!"--ZAepMG&pI0dCPBA4eFQ9'9@aXE!!&UN!a0$J\rf!!IU,PpIBh4IAcG'C@&dGA*P4P*$0dCPBA4eFQ934RCIF`!%`h"bC@0[EQ4TG'P\r[EJ!%$fPZDA3!"Da!-63i1!!&$LjIAf0dAemh4Q9KG(9bC8C34RCIF`!&a%!a0$N\r`!!IY,PpIBh4IAcG'C@&dGA*P4P*$0dCPBA4eFQ934RCIGJ!&b8!a0$Ne!!84,Pp\rIBh4IAcG'C@&dGA*P4P"'GPpf!!A,3$%d16F!"1dZAepMG&pI0dCPBA4eFQ9'8N-\rh4Q9KG(9bC9*$0dCPBA4eFQ8!"@9MEfjN-3!&CQ0[EQ3b!!+rEAPZCA3N-63j13!\r$0fejEQpNC53a06!`!!!aCA*b*$%e-$%!"DP!-68`-J!"ELj"F("XC94KE'Y*C'9\rZG'PdH9pI4P*c8R-!!)iZ69"36h"PEJ!(kLj(CA41Ef4P3@4NFQ9cF`!$ZQjPG!!\r%iQj[C'8!"E"!-68`13!"q#j(990*4'9QBA9XG&0PG(9`!!$D4e965AGTG'K"F("\rXC94KE'Y6Ef0VCA4c!!+Q,NG98dP6CA4eF!!(#%G98dPhDA4S5@jdCA*ZCA46Ef0\rVCA4c!!+)4e965AGTG'K339"6Ef0VCA4c!!,b4e965AGTG'K38%06Ef0VCA4c!!2\rr4e965AGTG'K9EQPi8fpMDf9dF`!%#%G98dPhDA4S8dP299K6Ef0VCA4c!!A)3$%\re-6%!"&*`FQpM!!A+3$%e-6-!"FY!-68a0!!'r&pI8P4859pI-6*6Ef0VCA4%Efe\rKD@i!!8PMD'p[Ff9IAc%b8fpMDf9d4'pYB@PZ4QP3Be"fD9"f8'N!"SpcEf0VCA4\r`B@PbAema-P0[BfYPG%4[E@&TENCTFe"30P0[BfYPG!!"mA0[BfYPG&pI-6*6Ef0\rVCA4%EfeKD@j'DA-!"J0IAf4dAema-P0[BfYPG%4[E@&TENCf!!##,PpIFfPZDA4\rI4e96584TFh"KG'0SAf0`!!@UAepNG&pI-6&6Ef0VCA48B@*XC8Cf!!($,PpIFQ9\rRDA0dCA*ICfa[BQ&XAfpLDQ9MG!!(F%PZDA4$8Nd!!#9*EQPd3e4#9A4TE'PdD@9\rc!!A03$%e-6B!!5P(990*8f9dGA!!!hj86d-!!1C(990*4'9QBA9XG&0PG(9`!!$\r$3A"`E'98B@aV5@4PER4TG(PIAdC5Fe*c!!1MAepMG&pI0dCPBA4eFQ9'8N-h4Q9\rKG(9bC9*$0dCPBA4eFQ8!"&GIAf0dAemh4Q9KG(9bC8C34RCIGJ!'3epIBh4IAcG\r'C@&dGA*P4P*$0dCPBA4eFQ934RCIGJ!%9&pIBh4IAcG'C@&dGA*P4P"'GPpc!!C\r!AepMG&pI0dCPBA4eFQ9'8N-h4Q9KG(9bC9"'GPpc!!25AepMG&pI0dCPBA4eFQ9\r'9@aXE!!#-epIBh4IAcG'C@&dGA*P4P9XE!!$iPpIBh4IAcG'C@&dGA*P4P9c8f-\r!!3T(990*5@jdCA*bGA"dAep'GJ!'fR9cE'9PF!!&E@&XBA*Y!!*,4e96580SC@0\rV3@aKFQeIAdCf!!9fAepfBepI-6&6Ef0VCA48B@*XC8CT!!GT8Q9YEhCPAema-90\r[BfYPG&4KBQaP4QN!!-G*ER0dB@aXAema-90[BfYPG&4KBQaP4P!f8fpMDf9dD3!\r&cPpIBh4IAc%a8fpMDf9d9'&LE'9'GJ!$D84[ER46G(*TF&pI-6*6Ef0VCA4%Efe\rKD@j'GJ!'69pIBh4IAc%b8fpMDf9d4'pYB@PZ4QN!"lT5C@&NH9pI-6*6Ef0VCA4\r%EfeKD@j'GJ!!-%4[E@&TEPpI-6*6Ef0VCA4%EfeKD@j'D3!&e%G98dP(CA4&GQ9\rZG(-!"H"(990*8f9d4ACPER4c!!0M4e9658GPG%K[EfX!!fC(990*8f9d5'p[D`!\r#qR0PG(0[BfY[F(3!!SCRCA4cEf0VEh"d!!-&D@pMG'acEf0VCA3!"%4NGA!b!!1\r3!'4eF!!!RR0SGA4NEhGZ!!1LCf9dF'9PFQjKE@8!!jKRCA4cEf0VEQ&YC3!'jA0\rPE'9MG!!%M(9`C'&dCA0dBA4eF`!(+h0PEQ4YFfF!"J0cC@jNG'm!")&cC@jN!!D\rVGh*TG'9f!!GMFQ9MGQecC`!!6R*PBhCQFQpY!!5aFQ9MGJ!$1Q0XEh0PFfpMDf9\rd!!BKB@0MCA"d!!CeE'PcG'9Z!!G,BfpZEQ9MG!!%k'*TEQ3!"K9MD'p[Ff8!"$"\r`DA"P!!,8FfpMDf9dF'&TFJ!'ZA0[BfYPG!!&2QGPG'4dB@*XCA0THQ8!")T*EQP\rd3fpZFfpXC9pI-6&6Ef0VCA48B@*XC8Cf!!C-4'p"GA4[5@jTG%GbB@CIAc%h4e9\r6580[EQCTCh9bBA4TEfj$4RB!!S46CA4%C@CKG@ad4P4jF'9IAc%h4e96580[EQC\rTCh9bBA4TEfj$4P*$194'D@aP8h"PB`!$U&pIBh4IAc%h4e96580[EQCTCh9bBA4\rTEfj'GJ!'$%G98dPICA*bEh*IEQPX!!+L4e9659pPFR*[FJ!!#3P36eG5!*!'$I!\r!!"4D!!!!4`!!$P`!!!Aq!!!)1!#3"jm!!!!)!*"!4@F!!%9T!*!&!89U!!3!!!!\r#!!!!6!!!!#!!!!)MNq(rr$[J!!&)!!!XL!-!!#`!!$T!JJ!F1!!!!*J$!!#)!`!\r"I!!(G8'#!!Jlr`!"1'-!!BJ$!!"m!!Ge3),rd$Kr!!#$iIrm6S!!)%9U!!3!!!!\r&!!!!H!!!!)!!!!,[L!-!!(`!"h3X!!!U3B)!4%#!!#JX!2r&3B)!1%#!!"!X!2q\rf3B)!0%J!!%3X!!!!3B)!0%J!!$JX!!"F3B)!(%#!!#`X!!!r3B)!#%J!!#!iB!!\r"6S!!))`$!!&m!!Ge3))!$$KJ!!"1J!!J1'-!!8[rrj!!6S!!)%9V!!3!!!!'!!!\r#B!!!!-)!!!3DI!J#TVmKrq53!!%!#*3Krk!li`!!1i3!!$XP!!#$BJ!!1!!!!*!\r!!`")1!!!!*!!!`"-L!3!!(`!"h9!JJ!31!$rfl!E!!")!!#%L"`!!#`!!$T"JJ!\rX1(`!!$L!!$T)!!!"B!!!!#J$!!""JJ!81(m!!%J!!!&J!!!!5!!!8#JC!!""JJ!\rm1,rrq$LCrrJi!!!)I!N$TS4N!!L!"!!%P'8!#*!!"3!%3J$rm)"N!!LJ"!!-N!"\rP!!L`"3!-5!!!%$Kr!!")!!!"B!!!!)JF!!!X!!!k3))!+)`F!!&m!!Ge3))!($J\r!!!#B(`"(1!!!!CJI!%BiI`!!5!!"@$Km!!")!!!"B!!!!$Y$!!#S'`!!I!!!0&3\r!fAkB(`"'9!!'2d'#!"`iHJ!"5!!!!@!!!!#3!(m!5#J$!!"!JJ!-1(m!!%J!!4#\r!I`")1*`!!$Lk!!&)!!!"B!!!!)"r!%K)!!!"1k-!!#`G!(p!J3!81!$rfl!E!!!\riI`!!5!!!f"ap!!a)!!!"B!!!!*!!I`"-+!-!!%##!!`iI`!!5!!!Z*Zr!%H$h`"\r)1k!!!%J!!&3iIJ!!5!!!!94J"Mp"JJ!-1)!!!%J!!!JiJ2rrJ(m!6"`G!!amJ`-\rZJ*m!6"ap!!`i!`!)Im3",MKq!!!l[3!"5!!!!@!!!!"r`r)81pi!!BJI!%Gm!!G\rdI"d!!%'!rk3iI`!!5!!!!@!!!!"8B!Br3B)!%$J!!!#!I`"-X!-!!$Kr!!#!R`"\r-L,m!4hbP"h3i`!!"5!!!!@!!!!#BI`"'1(m!!)!"!'Ji)3"JI!J$TVXKrq41J!!\rJ4A3$!*!%"`!!!"a&G3#3"3J!!!"F4A8!N!8*!!!!F%9e!*!&#J!!!-"&G3#3"3X\r!!!$m4A8!N!8-!!!"*%9e!*!&$3!!!8a&G3#3"3)!!!&B4A8!N!8-!!!"I%9e!*!\r&"3!!!Da&G3#3"3X!!!(S4A8!N!81!!!#$%9e!*!&$`!!!Ma&EJ`%!!!!)J!!!!b\r!!*!,J!!#B$J!!!"&G`#3"3B!N!4&D`!%!!!!)`!!!)`!!!(L!!!)F(`)!UD6iIr\rmNm(rq*!!!3!)P#(r`$[M!!#,``"(Ipi(G%J!!%!iI`!!J*m!6"`H!!amK!)8L"m\r!4h`!"h4m[J"31-!!!%J!!!&J!!!!Q(m!4P4J"Mp"JJ!-1'!!!8J!!"JX(J!!1pl\rrrd##rl`iB!!!Q(m!4S!"!%Ji)3"!I!J$TS2Krrb$`Iri6S!!)%9e!*!&$`!!!%4\r&EJ`%!!!!*3!!!!b!!*!,J!!!M"!!!!"&G`#3"5-!N!4&DJ!%!!!!*J!!!BJ!!!)\rU!!!*%R`)!UDr3IrSN!!"!!L8)Iq`1q-!!$ZN!!!la3!!Jd)!!%J!!35)(3!!I!!\r(G#`!!#T"JJ$83)!!(#`!rm9"JJ$)3)!!1#`!rlC"JJ!J5!!!,#`!!&a"JJ!83)!\r!)#`!!$p"JJ#!5!!!&)`G!!&m!!Ge3))!#$Zprrq)(`!!I!-(G)JG!!"m!!GdI!-\r!!%'#!&5,R`!!Ij`(G#`Frrp!JJ!-1'$rrdJ!!!aAJ!BqI(S!VSYp!!"rH`Gd,"[\rrrd##!!`i!2rr5!!!$&GJ"Mjm'J#ZI!-!!%'#!!`iB!!!5!!!Q$[r!!%l[3!"5!!\r!2#`H!!!lh[rr3)!!$$KJ!!")!!"i1rm!!6Kr!!!iR3!"1,i!!8J!!!&8B!Br3B,\rre$KJ!!&)!!"8,"i!!$[Hrrp!J[li5!!!0)JG!!"m!!Gd,!!!+N'#!"4!J!!B,!$\rra8'#!!K)!!!-1ld!!8J!!!`iB!!!5!!!&)JG!!"m!!Ge3),rb$KJ!!'!!3"B1#%\r!8(`)!kDl3IrS6S!!)%9d!`#3"#F!!!!F4A8!N!8Q!!!"%%9Z$!3!!!!T!!!!$)!\r!N!Z!!!')-!!!!%9h!*!&*J#3"%9Z%!%!!!!U!!!!!IrrrrJ!!!`-!*!%4@X!"!!\r!!!m!!!(N!!!#q!!!$!am#!+Q[f(rl*!!!3!)P#(qN!!li`!!1m3!!(bm+hNlCJ!\r!Jk)!!%##!$3iI`!!5!!!!@!!!!"8B!Br3))!$$KJ!!")!!'3!$Kr!!")!!!"B!!\r!!$KJ!!&)!!&mU"i!!#`!rrp!JJ"i9f!'2d##!!`iB!!!5!!"B)"q!!L)!`!!I!!\r(G8##!"JiB3%31*m!!%J!!!&J!!!!5!!!'$KK!-JiR`!!J,i!#%J!!!&J!!!!U"d\r!!(`!"c9"JJ!-1'!!!%J!!43iI`!!1*i!$$Lmrrmi`!!"5!!!!8J!!2aAB!Br3B)\r!4$KK!)!iR`!!1+)!!%J!!!&J!!!!U"d!!#`!!!""JJ!-1'!!!%J!!-`i!!!!X"i\r!!+JI!!#`(J!#J"m!!T!!(J!%U"i!!V!I!!#!(J!%N!!I!!)iB3!i1*m!!+Lq!!!\ri"3!"X"i!!(`&"c4)!!!"B!!!!$LrrrJiJ3!`1!!!#(`*!kD%C!!)J!3!"*4P!!L\r3!!8!"%)!rr#!C!!)S!3!$*!!C3!)X!8!$+JG!!!X!!!!3))!3$Kr!!H!RJ!)L,m\r!"NJ!!!&8B!Br3B,rI$Kr!!!iRJ!-1,crrcM!!!&)!!!"9'!'2d'#rf!iB!!"5!!\r!#$KJ!!#!!3&i1#%"F(`)!kDlBIrX6S!!)%9d!`#3"!F!!!!J4A8!N!8V!!!!,%9\re!*!&,!!!!%K&G3#3"5d!!!#-4A8!N!8Z!!!!T%9e!*!&$`!!!0"&Fa!!N!3U!!!\r!k%9e!*!&,J!!!1a&G3#3"5m!!!&)4A8!N!8Q!!!"R%9e!*!&$`!!!EK&EJ`%!!!\r!-3!!!!b!!*!,J!!"j#J!!!"&G`#3"3m!N!4&D`!%!!!!-J!!!)!!!!2d!!!29A`\r)!UD6iIrmNm(rq*!!!3!)P#(r`*!!B3"B1'!!8%J!!!&J!!!!I(mEH8'#!"3iI`!\r!J)%!@$LJ!!")!!!"1pm!!)"L!!#S!`!!,!!!!%##!!`iIJ!!5!!!&$Kq!!")!!!\r"B!!!!$KJ!!#!!3")1#%!3(`)!kD$iIrmJm(rq%k!!#"&G3#3"6-!!!!F4A8!N!8\r'!!!!1%9d!`#3"!F!!!"!4A8!N!8d!!!!A%9Z$3)!!!!f!!!!%S!!N!F3!!!m!$`\r!#J!!LS!!(`#3"N9f#T`!!!!h!!!!$N9Z$!3!!!!i!!!!$)!!N!k!!*!%4AF!N!8\rb!*!%4AF0!*!%0J!!!!K&D`!%!!!!13!!!#J!!!4%!!!2qA`)!UD3!!%!#*3Krm#\r3!'%!@)"K!&K)!!!"J!%!5$JK!%"m#!1Q6S!!)%9e!*!&)`!!!"4&EJ`%!!!!1J!\r!!!b!!*!,J!!!+!#3"%9h!*!&13#3"%9V!!3!!!!l!!!!5!!!"'i!!"!lL!-!4LJ\r!!!""JJ!i116rq$M$rrJi!!!)I!N$TS5Q!!L!"J!%P+F!#*!!"`!%3J$rm)#Q!!L\rJ"J!-N!#R!!L`"`!-L'-!4Nk!!#"&D`!%!!!!23!!!#`!!!5Z!!!3`h`)!UD3!!%\r!#*3Krm#3!'%!@)"K!&K)!!!"B!!!!)!"!%Ji)3"!I!J$TNk!!#"&G3#3"63!!!!\r84@i-"!!!!$i!!!!-J!#3#i!!!#`!N!4&G`#3"6d!N!4&E`S%!!!!2`!!!!L!!*!\r24AB!N!8p!*!%4AB2!*!%3!!!!!4&E`S%!!!!33!!!!L!!*!24AB!N!8l!*!%4AB\r2!*!%3!!!!!4&E`S%!!!!3J!!!!L!!*!24AB!N!8j!*!%4AB2!*!%3!!!!!4&E`S\r%!!!!3`!!!!L!!*!24AB!N!8b!*!%4AB2!*!%3!!!!!4&E`S%!!!!4!!!!!L!!*!\r24AB!N!82!*!%4AB2!*!%3!!!!!4&E`S%!!!!43!!!!L!!*!24AB!N!8M!*!%4AB\r2!*!%3!!!!!4&E`S%!!!!4J!!!!L!!*!24AB!N!8'!*!%4AB2!*!%3!!!!!4&E`-\r%!!!!*`!!!!5!!*!,4AB&!*!%*`#3"%9[!`3!!!!(!!!!")!!N!Y&GJ8!N!3(!*!\r%4@m2"!!!!%!!N!5!!*!(4@J!!&0C68J!!!6J!!!!#3#3&3%!N!B#6!!!!!3!!!*\r2!!!!$!!!!S3!!!!B!!!#RJ!!!#`!!!,(!!!!-!!!!Y8!!!"!!!!#frq3"!!!!Z`\r!!J!!!!-!!!"Q!3#3"!-!!!!%!!!!!`#3"4m!!3#3"J-V!!!!8!!!!fB!!!"B!!!\r$M`!!!'3!!!22!!!!E!!!!rMrN!3!!!3A!!%!!!!$!!!!CJ%!N!3$!!%!N!B%BJ!\r!!$`!!!5G!!!!5!!!",8!!!"X!!!%qJ!!!(`!!!8)!!!!K!!!"4J!!!#m!!!&33!\r!!-J!!!92!!!!e!!!"@J!!!$J!!!&T3!!!2J!!!AJ!!!")!!!"J%!!!%i!!!'2!!\r!!8!!!!C(!!!"@!!!"Qd!!!&S!!!'VJ!!!AJ!!!E6!!!"N!!!!!Ep!!!"Q!!!"`N\r!!!'S!!!(J`!!!HJ!!!IK!!!##!!!##!!!!)F!!!)-!!!!LJ!!!K)rj!%!!!)E3!\r'!!!!%2q3"!%!N!3I!!!!!`!!!'B"!*!%(!!!!"lrrrrj!3#3""N!!!!I!!!!CJ#\r3"4i!!!!J!!!!!`#3"4d!!!!K!!!!!`#3"4S!!3#3"JL+!!!!*!!!#,8!!!"B!!!\r)k3!!!'`!!!Mjrj!%!!!*$`!#!!!!%2q3"!%!N!3I!!!!*!!!!!-!N!8H!!%!N!B\r*B3!!!#3!!!Pk!!!!D!!!#DS!!!"d!!!*[`!!!(J!!!S1!!!!f!!!#P!!!!$J!!!\r+J!!!!1`!!!Vd!!!!q!!!#``!!!%!!!!,+`!!!33!!!Y@!!!"(!!!#eX!!!%N!!!\r,I3!!!6!!!!Z"!!!"0!!!#j3!!!&8!!!,``!!!9`!!![Q!!!"C!!!#rB!!!&`!!!\r,r2q3"!!!$!N!!`!!!"J!!!"Q!3#3""m!!!!$!!!!CJ%!N!3G!!!!+!!!!!-"!*!\r%(J!"!*!'$&!!!!!S!!!-B`!!!$`!!!ae!!!!4!!!$)8!!!"3!!!-N`!!!&J!!!b\rQ!!!!C!!!$0%!!!"X!!!-pJ!!!(3!!!d'!!!!K!!!$4m!!!#B!!!0-J!!!+`!!!e\r3!!!!f!!!$Bm!!!$J!!!0R3!!!23!!!f[!!!"!!!!$Em!!!%)!!!0dJ!!!5!!!!i\rX!!!"5!!!$Q8!!!'3!!!!$VB!!!'S!!!1r`!!!F3!!!mQ!!!"c!!!$cRrN!3!!!p\r(!!3!!!!3rj!%!3#3""m!!!!Errrrq`%!N!3H!!!!*!!!!!-"!*!%(!!!!$!!!!!\r'!3#3""X!!3#3"Jq$!!!!(!!!$iB!!!"3!!!2bJ!!!&J!!!rD!!!!C!!!$qVrN!3\r!!!rf!!)!!!!$!!!!CJ%$!!!!@!!!!$ArN!3!N!8H!!%!N!B3)!!!!"3!!"!Mrj!\r%!!!31!!"!!!!0Iq3"!%$!!!!@!!"!*!'%(F!!!!-!!!3M!!!!%!!!"#Urj!%!!!\r3`!!#!!!!0Iq3"!%!N!3$!!!!22rrrrF"!*!%"!#3#"$U!!!!&!!!%1d!!!!F!!!\r3q[q3"!!!%2S!!3!!!$ArN!3"!`!!!&J!![rrrr`!!!!9!!!!4J!$!!!!&J!!!!X\r!N!FA!!!!!`!!!!)!!!!B!!!!!3!!!!B!![rrrrd!!!!6!!!!4J!"!!!!&2rrrr`\r!N!8#rrrrqJ!!!"`!!!!-!!3!!!!G!!!!#`#3"aB!!!!,!!!!!J!!!"F!!!!$!!!\r!"!!!!!-!!!"Q!!!!#!!!rrrrq`!"rrrrqJ!#rrrrrJ!!!"%!!!"3!!8!!!!5rrr\rrr3#3"aN!!!!'!!!!4J!!!!3!!!!(!!!!4`!!!"S!!!"Q!!!!5!!!!"[rrrrl!!!\r!6!!!rj!%!!(rrrrq!!$rrrrj!!(rrrrp!!(rrrri!!!!!3!!!!%!!!!(!!$rrrr\rh!!(rrrrm"+K(990*!!2E,P0XD@0P8f9RE@9ZG(0IAdC3B`!(SR"KG(4PFQi!!!K\rcC@GYC@jdF`!#Fbj)BA0AD@aN3f&bC(0IAdC3B`!"eLjIAf0dAemj9%CTE'9(E'p\rL4P"$Be"$194'D@aP8h"PB`!"l'9bFQpbAemj9%CTE'96F'9M!!IG,R0dFQ0SFJ!\r$H#j5EfpdAemj9%CTE'96F'9M4RB!"Q%Z4'9QBA9XG&pI194'D@aP8h"PBdCf!!H\rp,R0dFQaPEJ!$,#jIAfjhB9pI4P9X!!GP,QePE@0`H3!&1#j*Fe*[Eh4IAcP84QP\rXC90`C@0'GJ!%!Lj1CAKdAemj9%CTE'9(E'pL4P"4-MP84QPXC8GXEf)j3Q&MDe4\rbB@0VD99M!!4EG'KTF`!"S94'D@aP4fa[BJ!#r5484QPXC90`C@-!!AY84QPXC90\r`C@-!"b8N4P06F'9M!!B)4P06F'9M!!FHGP*PCNjeE3!&bR"KFNP%!!5VEQ&YC3!\r&eRCKE'PN!!DZF'&d3R9Q!!9FG(*KBfX!!F4#B@0V9(*KBfX!"@0TEQ4PH!!!A(0\rdBA*d4'Pb!!EaF'&d8f9R!!"#Ff9R3fpeER3!"Re`BA4XC@i!"2T!1$Bc!!0P,Nj\rPH(4IAcP84QPXC8GXEf*'GJ!&N@4PF(4S!!3C3$Jh-J!%,Lj0BA4MD%jKE@9IAdC\r33f033f0T!!-&AepeF("PFPpYBA!!"b&ZB@eP6'9Z!!4"3$N`0J!%Sd!j-cJ!"M-\rZ4AKTFh4cAemj9%CTE'96F'9M3dCf!!3),N*XCA0cAemj9%CTE'96F'9M4RB!!p3\rZAepYE9pI194'D@aP8h"PBdCf!!Dd,PpIBA"XAemj9%CTE'96F'9M4P"$B`!%)#j\rIAhCMAemj9%CTE'96F'9M3dCc!!32D@jTG!!%T%!j-cN!",BZ6Q9h4QPXC8GXEf)\r!!RXZAepZGepI4P9X!!*2,PpIC'aIAdC3GJ!%X@GXEf)!"-"!163e!!&FAepNE&p\rI4P"f!!6"3$Nd0J!&!Lj1CAKd4QPXC8GXEf)!"-0!163i!!"!,NCTE'9(E'pL-NC\r68h"PB`!%Dh0`C@-!!-BZ4'PcF'pcC8CTE'9(E'pL!!6H3$Ne-`!(2d4TFh"[Ff9\r'D@aP4fa[BJ!$IP423`!(RNCTE'9(E'pL-NC68h"PB`!%58jPH(4'D@aP4fa[BJ!\r$@%jPGdCTE'9(E'pL!!0(6Q9iG&pI194'D@aP4fa[BNC386)j9%CTE'9(E'pL18*\rKBfY8FQ&MDfP9B`!#ZdjPH(4IAcP84QPXC8GXEf*'GJ!!LPpIBh4IAcP84QPXC8G\rXEf*'8%0M8%-j9%CTE'96F'9M!!"36eG5!*!')J3!!%!%!!!"a!!!)R!!!"f8!!!\r-q!!!!"i!!!0&!!!!)!#33%9R!!"&D`!%!!!!Z`!!!!3!!!!J!!!'T%k!!#"&D`!\r%!!!![3!!!!3!!!"#!!!'fdk!!#"&D`!%!!!![J!!!!3!!!"N!!!(&%k!!#"&D`!\r%!!!!`!!!!!3!!!#'!!!(5dk!!#"&D`!%!!!!`3!!!2`!!!#S!!!)#T2Krrb$iJ!\r!,!1Q(%'#!*4!J!!d,!1Q&d'#!+"!J!!F,!1Q"d'#!+"!J!#d,!1Q!d'#!+")!!#\rS,!1Q'8'#!(")!!#F,!1Q)d'#!%"!J!!3,!1Q)8'#!%")!!#%,!-!!%'#!"4!J!"\ri,!1Q+8#!!(")!!!-1'!!!%J!!(`i!!!'N!!I!!")!!"X1!!!1T!!(`!!5!!!B$J\r!!$L3!"m!!%J!!&3i!!!jN!!I!!")!!")1!!!2C!!(`!!5!!!2$J!!$#3!"m!!%J\r!!$!i!!"!N!!I!!")!!!N1!!!3C!!(`!!5!!!'#`$!!"!J3!)5!!!#$KJ!"D3!(m\r!!$KJrrq$iIrm6S!!)%9d!`#3"-)!!!!%4@X!"!!!!-3!!!#J!!!")J!!$&"m#!+\rQNq(rr*!!!3!)P#(r`$[M!!")!!!"B!!!!)!#!!#3!"m!!MKr!"`iJ!!!1+!!%%J\r!!!&J!!!!1(m!,$L!!!!iS!!35!!!!@!!!!!i!!!#Q"m!(6J!!"#B(`!F1!!!!CJ\rI!")i!!!!Q"m!%cJ!!!#3!"m!"MJ!!!#`(`!+J')!!%J!!!&J!!!!1(m!!)!"!%J\ri)3"!I!J$TS2Krra1J!!J4A8!N!A&!!!!&%9d!`#3"-B!!!!F4A8!N!A(!!!!-%9\re!*!&a`!!!%4&G!-!N!3#!!!!I%9e!*!&b!!!!)"&EJd#!!!!bJ!!!"D!!*!(#!!\r!0!#%!!S!!)D!!"m!N!T&GJS-!!!!b`!!!"*&EJ`%!!!!c!!!!!b!!*!1S!#3"%9\rh!*!&a!#3"%9h$3#3"-S!!!!)4@X!"!!!!-d!!!#F!!!"C!!!$S"m#!+QNq(rr*!\r!!3!)P#(r`$[M!!#3!)%!A%J!!!&J!!!!J!)!!*!!(`!#J!%!A*!!(`!11!!!!TJ\rI!"di!!!3Q"m!($J!!!+B(`!Y1!!!%*JI!#`i!!!"Q"m!%MJ!!!@B(`!m1!!!!*J\rI!"-i!!!!N!!I!!Bi!!!!X"m!#S"L!!")!!!"B!!!!$Kr!!#!!3")1#%!3(`)!kD\r$iIrm6S!!)%9e!*!&a3!!!"K&G!-!N!6'!!!!)%9d!`#3"!)!!!"i4A8!N!A)!!!\r!I%9Z$3)!!!$1!!!!&S!!N!F)!!#!!)!!#J!!KS!!(`#3#N9f#J`!!!$,!!!!%N9\rZ$!3!!!$2!!!!$)!!N!kF!*!%4AF!N!A0!*!%4AF0!*!%cJ!!!!K&D`!%!!!!d!!\r!!(!!!!'N!!!3*R`)!UD6iIrmN!!"!!L8)Ir!I(mEHE#"!&j"JJ"!J!)!!*!!(`!\r#J')!!%J!!!&J!!!!1(m!!$L!!!")!!!"B!!!!+J"!&iX!!!!3)%!%$Kr!!")!!!\r"B!!!!$Kr!!#!!3")1#%!3(`)!kD$iIrm6S!!)%9d!`#3"-B!!!!F4A3$!*!%!J!\r!!#4&G3#3"G%!!!!S4A8!N!A5!!!!1%9e!*!&d`!!!&"&EJ`%!!!!e!!!!!b!!*!\r,J!!!F!J!!!"&G`#3"G!!N!4&D`!%!!!!e3!!!!J!!!(1!!!3B6KJ!!"1J!!J4@X\r!"!!!!0B!!!$`!!!"iJ!!%*Gm#!+QNq(rr*2"rrL6SIrdNi(rm*!!!3!)P#(rX$[\rM!!"mR#0jNi-!"N'#!+!i!!!!Q!%!1MJ!!!#B!3!j1m!!!$ZJ!!#S(`!-9!!(rd'\r#!!Jl`3!kU"m!$&3!"le"JJ!)1k%!16Kr!!!iRJ!!1,d!!$M!!!#"R`!#JB`!@%J\r!!!&J!!!!,!-!!%'#!%L)!3!j+!!!!%'#!"5!I`!'1)!!!NJ!!!&J!!!!L!%!1LJ\r!!!""JJ!JJ(m!"ML!!!&)!!!"B!!!!%J!!!`i!!!!X"m!$)!"!&Ji)3"3I!J$TS2\rKrrb$`IriJk(rp)1"rr"1J!!J4A8!N!AA!!!!I%9e!*!&f!!!!+"&G3#3"GJ!!!#\rm4@i-"!!!!0i!!!!-J!#3#i!!!2!J!!!!4AF!N!A@!*!%4@X!"!!!!0m!!!"B!!!\r#UJ!!%`Tm#!+QNq(rr*!!!3!)P#(r`,"K!&U`J3"HN!#K!'#!BJ!!U)%!@NJ!!!&\rJ!!!!1!!!!,!$!!US!3"HX!-!$)#"!'")!!!"J!%!5$JK!%"m#!1QJq(rr%k!!#"\r&G!-!N!6J!!!!(%9e!*!&i3!!!#4&G3#3"GB!!!"!4@i-"!!!!18!!!!-J!#3#i!\r!!&J)!!!!4AF!N!AI!*!%4@X!"!!!!1B!!!$X!!!$$J!!&bCm#!+QNq(rr*2"rrL\r3!!%!#*3Krm!l``!!N!#"!&b3!+%!B)2K!&b!!3"J,!!!%%#!!"3iB!!@5!!!!@!\r!!!")!!#BL"m!!5J!!!*"JJ!81'!!,dJ!!!&J!!!!5!!!I+!H!"iS!!!!3B)!&$K\rJ!"C)!!!"B!!!!%J!!'#!(`!%+!!!!%'#!$L!I`!%2!1"!#J!!!&"JJ!S5!!!!@!\r!!!#!(`!%I!!B3%'#!"3iB!!a5!!!!@!!!!")!!!JJ"m!"*!!(J!JS"m!!V!H!"i\ri!!!3Q"i!($KJ!!#!!3")1#%!3(`)!kD$iIrmJm(rq%k!!#"&G3#3"HF!!!!d4A8\r!N!AR!!!!8%9e!*!&j`!!!'a&G3#3"HJ!!!#84A8!N!AR!!!!V%9Z$!3!!!$X!!!\r!$)!!N!Z!!!$X%!!!!%9h!*!&jJ#3"%9V!!3!!!$Y!!!!J!!!!k)!!"ZlI!J#TT2\rKrrb3!!%!#*3Krm#3!'%!@*!!J3"F1q8!!)!&!!!X!!!!3)!!&$KJ!"C)!!!"B!!\r!!%J!!$L!B3"FJ)%!@$L%!"b!(`!!,!!!%%#!!!b![`!!5!!!#$LJ!"#3!,m!!%J\r!!!&J!!!!1'!!!)!"!%Ji)3"!I!J$TS2Krra1J!!J4A8!N!AR!!!!,%9e!*!&lJ!\r!!'"&EJ`%!!!!l`!!!!b!!*!,J!!!J!J!!!"&G`#3"Hd!N!4&D`!%!!!!m!!!!+!\r!!!2`!!!H5h`)!UD6iIrmNm(rq*!!!3!)P#(r`$[$!!#3!)%!A$[P!!#!"3!!,!!\r!!%#!!"3iB!!@5!!!!@!!!!")!!"3L"i!,#J!!!"!JJ!81'!!18J!!!&J!!!!5!!\r!0)"K!&`iRJ!XJ"m!!#`!!""!J!!-J,m!!%J!!!JiS!!3N!#r!!")!!!"B!!!!$K\rJ!!#!!3")1#%!3(`)!kD$iIrmJm(rq%k!!#"&G3#3"HF!!!!`4A8!N!AR!!!!6%9\re!*!&lJ!!!(a&EJ`%!!!!m3!!!!b!!*!,J!!!S"!!!!"&G`#3"I!!N!4&D`!%!!!\r!mJ!!!*J!!!41!!!JaR`)!UD6iIrmN!!"!!L8)Ir!1q-!!*!!J3"FJ!%!A#`!!!&\r"JJ!`3)!!%#`!!!"!J!!85!!!3#`!!!0!J!!i5!!!*)JI!"*J!!!#Q"m!%NJ!!$5\r)(`!5B!!!"*JI!"*)!!!NL"m!%Q!!!!DB(`!55!!!&$KJ!"C)!!!"B!!!!%J!!!J\riB!!!J!%!5$JK!%"m#!1QJq(rr%k!!#"&G3#3"HF!!!"d4@i-"!!!!23!!!!-J!#\r3#i!!!*J)!!!!4AF!N!Ab!*!%4@X!"!!!!28!!!#F!!!%TJ!!*5Pm#!+QNq(rr*!\r!!3!)P#(r`$[M!!#3!)%!A*!!S3"JJ!%!A#`!!!4"JJ!`3)!!9#`!!!0!J!!)5!!\r!5)JI!"-S!!!!3B)!$$KJ!!4)!!"!1'!!!%J!!$L!!3"J9!!(Hd'#!"!i!!!"Q"m\r!%dJ!!!`i!!!!Q"m!%cKJ!!")!!!31'!!,8J!!!&J!!!!J!%!5$JK!%"m#!1QJq(\rrr%k!!#"&G3#3"HF!!!#!4@i-"!!!!2J!!!!-J!#3#i!!!*`)!!!!4AF!N!Ae!*!\r%4@X!"!!!!2N!!!$B!!!&*!!!*c"m#!+QNq(rr*2"rrL6SIrdNi(rm*!!!3!)P#(\rrX$Z$!!!lT!!!1q8!!&5HK2j8J!"$3B)!)#`H!!""JJ!B1(m!!$L!!!!i[J!!5!!\r!!@!!!!#6i3!i2'"!"$KMCRpm(4J!3B)!,%#!!%JmB)!%1'0QIR`G'!""JJ!)5!!\r!0)!I!!#B(!!61'!!!%J!!$!iI!!!JC`!!S'-!'4)!!!"B!!!!*!!I`!!1'!!!%J\r!!"!iB!!Y5!!!!@!!!!#!!3"B1#%!8(`)!kD$iIrmJm(rq)1Krr5$JIr`6S!!)%9\re!*!&a`!!!%K&G3#3"GF!!!#B4A8!N!AR!!!!X%9Z$!3!!!$r!!!!$)!!N!Z!!!$\rB)!!!!%9h!*!&q3#3"%9V!!3!!!%!N!3S!!!&VJ!!+MPm#!+QN!!"!!L8)Ir!J')\r!!%J!!!&J!!!!J!%!5$JK!%"m#!1Q6S!!)%9d!`#3"!)!!!!-4A8!N!3"!3!!!""\r&EJ`%!!!"!J!!!!b!!*!,J!!!+!#3"%9h!*!%!3#3"89V!!3!!!%$!!!!I!!!"G)\r!!#U#I!J#TT2Krrb3!!%!#*3Krk!li`!!1)!!!NJ!!!&J!!!!J!)!!*!!(`!!1'%\r!1%J!!!&J!!!!1!!!!E!I!!3i!!!"X"m!"MJ!!!#`(`!)1!!!!,!I!!Si!!!!X"m\r!$$J!!!#3!"m!$MKr!!#!!3"S1#%!B(`)!kD$iIrm6S!!)%9e!*!%!33!!!!B4A3\r$!!!!!38!!!!J4A8!N!3""J!!!#a&EJd#!!!"'3!!!"D!!*!(#!!!-!!`!!S!!)D\r!!"m!N!T&GJS-!!!"'J!!!"*&EJ`%!!!"'`!!!!b!!*!1I!#3"%9h!*!%!3-!N!4\r&G`d!!!!"'3!!!!K&EJ8"!!!"(!!!!!Arrrr)!!!VP`3Z59"3!!!!4@X!"!!!!4d\r!!!"m!!!'#J!!+jGm#!+QNq(rr*!!!3!)P#(rF$[M!!#S!`!%,!!!!8##!$3i!!!\r!N!!"!%5!!J!!N!!"!%Si!!!!Q!%!8cKK!$K)!!!"B!!!!,"r!!5S!3"3X"m!#+J\rI!!3X!!!!3B)!$$KJ!!")!!!)U(m!#)!"!*Ji)3#3!(`)!kD$iIrm6S!!)%9d!`!\r!!!%F!!!!+%9e!*!%!4i!!!!m4@i-"!!!!@i!!!!-J!#3#i!!!(`)!!!!4AF!N!3\r"(3#3"%9V!!3!!!&[!!!!6!!!"P)!!#cKI!J#TT2Krrb3!!%!#*3Krm!li`!!5!!\r!!DJI!!BX!!!"3))!&$KJ!!")!!!"B!!!!,"r!!DSI`!'J!%!5$JK!%"m#!1QJq(\rrr%k!!#"&G3#3"!%G!!!!&%9e!*!%!A!!!!!S4@i-"!!!!A%!!!!-J!#3#i!!!%`\r)!!!!4AF!N!3"E`#3"%9V!!3!!!&b!!!"D!!!"S`!!$09I!J#TVmKrq53!!%!#*3\rKrk#3!'%!H*!!J3"mJq)!!$[!!!#!(`!!N!!"!$Ji!!!!N!!I!!#!B3"i5!!!!Aa\rJ"c9!JJ!`1'!!-NJ!!!&J!!!!1f-!!)!I!!!X!!!!3))!$)!"!$L3!"m!!$Kl!!"\r)!!$XJ!%!I#`!!!*"JJ!m3)!!B#`!!!&!J!!)5!!!9$KJ!%C)!!!"B!!!!(ap'hP\r"JJ!31(d!!%J!!!&J!!!!1pd!!%J!!$JiB!"#5!!!!@!!!!"mI"Yj3B)!%$Km!!"\r)!!!"B!!!!$[F!!")!!!31'!!,%J!!!&J!!!!+"i!!%'#!&#!(`!!,!!!!%'#!%3\rX(J!!3B)!($Kq!!!iJ!!"JCi!!S'-!'")!!!"B!!!!$Y!!!#!(`!!,!!!!%##!!b\r!!3!iN!!I!!!iHJ!!5!!!)$Xq!!#!(`!!,!!!!%##!!b!!3!iN!!I!!!iH3!!J!%\r!D$JK!'"m#!1QZb(rj%k!!#"&G!-!N!6#!!!!'%9e!*!%!4d!!!!d4A8!N!3"F`!\r!!%4&G3#3"!&d!!!!M%9e!*!%!A8!!!#J4A8!N!3"G!!!!,4&G3#3"!&f!!!!b%9\re!*!&j`!!!0a&G3#3"GF!!!%34@i0!J!!!AX!!!"#J!#3"cJ!!$J!N!!!+J#N!+3\r!)J#i!,J!+J$-!-`!-J$J!43!+J!!#S!!(3#3"))!!$J!N!3+J!!F!*!%JJ!!1!#\r3"N9f#J`!!!&m!!!!*N9f#J`!!!&p!!!!,N9f#J`!!!&m!!!!0N9f#J`!!!&p!!!\r!2N9Z$!3!!!&q!!!!$)!!N!d"D!#3"%9h!*!%!A)!N!4&G`d!!!!"H`!!!!K&D`#\r%!!!"I`!!!'L!!*!(I!J#TT2Krrb3!!%!#*3Krm"mIaYjX)%!AN'#!$L!BJ!!J!-\r!!#`!!!"!JJ!3J"m!!)"L!!#3!!-!!+J"!&iX!!!!3)%!%$Kr!!")!!!"B!!!!$K\rr!!#!!3")1#%!3(`)!kD$iIrm6S!!)%9d!`#3"-)!!!!F4A3$!*!%`J!!!$"&G3#\r3"G-!!!")4@i-"!!!!B!!!!!-J!#3#i!!!'J)!!!!4AF!N!3"I`#3"%9V!!3!!!'\r"!!!!6!!!"c!!!$6qNq(rr+L$!!`i"!!"X!-!$(`!"c3X!!!J3))!$$J!!!#`!`!\r-J)-!$UJ$!!`F!!"UIq3#&+JI!"!X!!!"3B,rb$Kr!!#$iIrm6S!!)%9V!!3!!!$\r)!!!!D!!!"i!!!$@mI!J#TT2Krrb3!!%!#*3Krm!li`!!U'-!#MJ$!!'`(`!+I'!\r(08##!$!iB!e!5!!!!@!!!!#3!(m!$LJ$!!"!JJ!B1!!!$)"L!!#3!!-!!$J!!!#\r`(`!+J!%!5$JK!%"m#!1QJq(rr%k!!#"&G3#3"!'$!!!!,%9d!`#3"-)!!!"%4@i\r-"!!!!B3!!!!-J!#3#i!!!'J)!!!!4AF!N!A)!*!%4@X!"!!!!0%!!!"3!!!(ZJ!\r!0P4m#!+QNq(rr*!!!3!)P#(r`$[M!!#SB`!+1!2rrl!I!!Tm!!Fe3))!')"r!!j\r)!!!"B!!!!$J!!!#3!"m!$S!"!%Ji)3"!I!J$TS2Krra1J!!J4A8!N!3"K3!!!#a\r&EJ`%!!!"KJ!!!!b!!*!,J!!!8!J!!!"&G`#3"G%!N!4&EJ8"!!!"K`!!!"(rrrq\rj!!!f9%P14946Ef0VCA4%EfeKD@i!N!4&EJ8"!!!"L!!!!!hrrrqi!!!f9&0[BfY\rPG%4[E@&TEJ!`"2*&EJ8%!!!"L3!!!!Mrrrqh!!!f9!#3#%9f"3!!!!')!*!%4@i\r&"!!!!BS!!!!-rrrrYJ!!0P3!N!a&GJ8!!!!"L3#3"%9Z"33!!!',!!!!#2rrrl8\r!!$C8!*!)4AB&!!!!!BF!N!4&GJ8!!!!"LJ!!!!4&E`8%!!!""3!!!"Mrrrqd!!!\rf9!#3'%9f"3!!!!',!*!%4AB+!!!!!B`!!!!84AB+!!!!!Bd!!!!34AB+!!!!!Bi\r!!!!)4AB+!!!!!Bm!!!!-4@X!K!!!!C!!!!!!C)!!N!Gm#!+QNq(rr*!!!3!)P#(\rr`(ar'hQ`J3"H3B)!0)!#!!#3!"m!!$Kr!!!iJ!!!5!!!!@!!!!#S!3"H,!!!!%#\r"!"!iI`!!5!!!!@!!!!!iI`!!J!%!5$JK!%"m#!1QJq(rr%k!!#"&G!-!!!!""3!\r!!"a&G3#3"!'4!!!!,%9e!*!&d`!!!%4&EJ`%!!!"NJ!!!!b!!*!,J!!!C!J!!!"\r&G`#3"!'3!!#3"%9Z"3%!!!'6!!!!#rrrrl-!!$C858j&9&0[BfYPG!"J4@i&!3!\r!!C3!!!!(rrrrXJ!!0P46Ef0VCA3!mN9Z"33!!!'9!!!!#2rrrl%!!$C8!*!)4AB\r&!!!!!C3!N!4&EJ8%!!!"PJ!!!!crrrq`!!!f9!#3$%9f"3!!!!'9!*!%4@i&"!!\r!!CF!!!!)rrrrV`!!0P3!N!K&GJ8!!!!"N`#3"%9f"3!!!!'@!!!!"%9["33!!!$\r'!!!!D2rrrki!!$C8!*"S4AB&!!!!!CF!N!4&GJS!!!!"Q!!!!&a&GJS!!!!"Q3!\r!!&K&GJS!!!!"QJ!!!&4&GJS!!!!"Q`!!!%a&GJS!!!!"R!!!!%K&GJS!!!!"R3!\r!!%4&GJS!!!!"RJ!!!%"&GJS!!!!"R`!!!$4&GJS!!!!"S!!!!$"&GJS!!!!"S3!\r!!#4&GJS!!!!"SJ!!!#"&GJS!!!!"S`!!!"a&GJS!!!!"T!!!!"K&GJS!!!!"T3!\r!!"4&GJS!!!!"TJ!!!""&GJS!!!!"T`!!!!a&GJS!!!!"U!!!!&"&GJS!!!!"U3!\r!!$a&GJS!!!!"UJ!!!$K&GJS!!!!"U`!!!#a&GJS!!!!"V!!!!#K&GJS!!!!"V3!\r!!!K&GJS!!!!"VJ!!!'4&GJS!!!!"V`!!!'"&DJ!%!!!"X!!!!$5!!*!(I!J#TT!\r!!3!)P#(r`)"L!!")!!!"J))!!)#L!!")!!!"B!!!!)!"!%Ji)3"!I!J$TNk!!#"\r&G!-!N!3#!!!!$%9e!*!%!3-!!!!34A3$!!!!!Bi!!!!84A3$!*!%!3!!!"K&G3#\r3"!'a!!!!(%9Z$!3!!!'b!!!!$)!!N!Z!!!!d!*!%4AF!N!3"X!#3"%9Y"33!!!!\r#!!!!%[rrrri!!!Bp4@`&!3!!!!%!!!!-rj!%!!!'289[#S3!!!'1!!!!#)!!N!p\r&GJ#3"!'3!!#3"%9f$`!!!!'c!!!!"%9[#J3!!!'d!!!!#)!!N!p&GJ#3"G%!N!4\r&GJm!!!!"X`!!!!4&E`S%!!!"Y3!!!!L!!*!24AB!N!A)!*!%4AB2!!!!!E-!!!!\r%4@m+"!!!!EB!!!!)J!#3$d9f!*!%!B%!N!4&GJm!!!!"X`!!!!4&E`U%!!!"I3!\r!!!L!!*!24AB!N!3"I`#3"%9f$`!!!!'c!!!!"%9[#J3!!!'2!!!!#)!!N!p&GJ#\r3"!&b!*!%4AB2!!!!!E-!!!!%4@m+"!!!!EF!!!!)J!#3$d9f!*!%!@m!N!4&GJm\r!!!!"X`!!!!4&E`S%!!!"Z!!!!!L!!*!24AB!N!3"(3#3"%9f$`!!!!'c!!!!"%9\r[#J3!!!'j!!!!#)!!N!p&GJ#3"!%$!*!%4AB2!!!!!E-!!!!%4@m+"!!!!ES!!!!\r)J!#3$d9f!*!%!3#3"89f$`!!!!'c!!!!"%9[#J3!!!'T!!!!#)!!N!p&GJ#3"IN\r!N!4&GJm!!!!"X`!!!!4&E`S%!!!"UJ!!!!L!!*!24AB!N!Ae!*!%4AB2!!!!!E-\r!!!!%4@m+"!!!!DJ!!!!)J!#3$d9f!*!&mJ#3"%9f$`!!!!'c!!!!"%9[#J3!!!'\rV!!!!#)!!N!p&GJ#3"I!!N!4&GJm!!!!"X`!!!!4&E`S%!!!"V!!!!!L!!*!24AB\r!N!AY!*!%4AB2!!!!!E-!!!!%4@m+"!!!!Dd!!!!)J!#3$d9f!*!&jJ#3"%9f$`!\r!!!'c!!!!"%9[#J3!!!'l!!!!#)!!N!p&GJ#3"Gm!N!4&GJm!!!!"X`!!!!4&E`S\r%!!!"[!!!!!L!!*!24AB!N!A@!*!%4AB2!!!!!E-!!!!%4@m+"!!!!Di!!!!)J!#\r3$d9f!*!&e3#3"%9f$`!!!!'c!!!!"%9[#J3!!!'[!!!!#)!!N!p&GJ#3"G!!N!4\r&GJm!!!!"X`!!!!4&E`S%!!!"[3!!!!L!!*!24AB!N!A0!*!%4AB2!!!!!E-!!!!\r%4@m+"!!!!Ei!!!!)J!#3$d9f!*!&a!#3"%9f$`!!!!'c!!!!"%9[#J3!!!'r!!!\r!#)!!N!p&GJ#3"F%!N!4&GJm!!!!"X`!!!!4&E`S%!!!"`!!!!!L!!*!24AB!N!A\r!!*!%4AB2!!!!!E-!!!!%4@m+"!!!!F%!!!!)J!#3$d9f!*!&[J#3"%9f$`!!!!'\rc!!!!"%9[#J3!!!(#!!!!#)!!N!p&GJ#3"Ed!N!4&GJm!!!!"X`!!!!4&E`S%!!!\r"``!!!!L!!*!24AB!N!@l!*!%4AB2!!!!!E-!!!!%4@i$"!!!!!%!!!!%J!#3#d9\rf"3#3"!%!N!4&E`-%!!!"MJ!!!!5!!*!,4AB+!!!!!Bi!N!4&EJ-%!!!"(!!!!!5\r!!*!,4AB&!!!!!4`!N!4&E`-%!!!""3!!!!5!!*!,4AB&!!!!!38!N!4&E`-%!!!\r!i!!!!!5!!*!,4AB&!*!%i!#3"%9[!`3!!!!#!!!!")!!N!Y&GJ8!N!3#!*!%4@m\r$"!!!!-B!!!!%J!#3#d9f"3#3"-B!N!4&E`-%!!!!`J!!!!5!!*!,4AB&!*!%`J#\r3"%9[$`3!!!'c!*!%J!#3"d9S!!"6@8e)!!!(p!!!!&)!!!!)!*!4!3#3"JE1rj!\r%!!!'f!!"!!!![!!!!!)"!*!%!`!"!*!'"`IrN!3!!!F4!!%!!!#m!!!!#J%!N!3\r$!!%!N!B(2[q3"!!!"dJ!!3!!!,m!!!!#!3#3"!-!!3#3"JGhrj!%!!!(J3!"!!!\r![`!!!!S"!*!%!`!"!*!'##F!!!"d!!!)6!!!!(`!!!Ld!!!!L!!!#4X!!!#8!!!\r*H3!!!+!!!!R8!!!!V!!!#Mm!!!#i!!!+X`!!!-3!!!X&!!!!d!!!#dN!!!$F!!!\r,L`!!!2!!!![krj!%!!!-"3!"!!!!``!!!!-"!*!%!`!"!*!'$'S!!!!`!!!-RJ!\r!!%3!!!c*!!!!J!!!$D8!!!#)!!!0[rq3"!!!$Em!!3!!!-RrrrrA!3#3""m!!3#\r3"JkU!!!!I!!!$md!!!#%!!!3)rq3"!!!%#-!!J!!!-RrrrrA!3#3""m!!!#V!!!\r!!J%$!!!!A!!"!*!'%%!!!!!S!!!33rq3"!!!%&i!!3!!!-RrrrrA!3#3""m!!3#\r3"K#+rj!%!!!3P!#3#K$#!!!!,!!!%2)!!!"3!!!4I3!!!&3!!"'9!!!!B!!!%EB\r!!!"N!!!4dJ!!!)`!!"))!!!!Q!!!%K`!!!#S!!!56`!!!,3!!"*L!!!!a!!!%TJ\r!!!$)!!!5T!!!!0!!!"+frj!%!!!5YJ!'!!!!bIrrrpF"!*!%(`!!!0N!!!"N!3#\r3""`!!!$D!!!!D!#3"4d!!!$E!!!!D!#3"4i!!!$F!!!!"J!$!!!!13!!!0d!!!!\r'!!-!!!!k!*!)%dB!!!!N!!!653!!!%!!!"1T!!!!4!!!%m2rN!3!!"2$!!3!!!$\rL!!!!#`%$!!!!@J!!!1-!!!!,!3-!!!"H!!!!j!!!!'3"!`!!!'!!!!#Mrrrre`#\r3"4m!!3#3"KG9!!!!-!!!&m3!!!"!!!!Ai3!!!%`!!"J%!!!!A!!!'#F!!!"S!!!\rB8`!!!(J!!"Lp!!!!P!!!'3S!!!#S!!!C2`!!!,J!!"RJrj!%!!!DEJ!%!!!!bIr\rrrpF"!*!%(J!!!1N!!!"N!3-!!!"F!!!!kJ!!!!-"!`!!!'!!!!$Vrrrrd3#3"4m\r!!3#3"K[a!!!!+!!!(!J!!!!i!!!F*Iq3"!!!((i!!`!!!-RrrrrA!3-!!!"B!!!\r!k`!!!'3"!`!!!&`!!!$Urrrrd!%!N!3I!!%!N!BHJ3!!!#`!!"kB!!!!2!!!(V3\r!!!")!!!HbJ!!!&J!!"lVrj!%!!!I4J!$!!!!bIrrrpF"!*!%(J!!!1X!!!"N!3-\r!!!"F!!!!k[rrrp!"!*!%(`!"!*!')1J!!!"!!!!K"J!!!&!!!#%k!!!!B!!!)@i\r!!!"`!!!KZ!!!!)!!!#(Crj!%!!!Ki`!#!!!!bIrrrpF"!*!%(`!!!2-!!!!$!3-\r!!!"F!!%!N!BP@J!!!$J!!#AY!!!!4!!!*J%!!!"-!!!Q'`!!!&3!!#DR!!!!B!!\r!*Vd!!!"X!!!Qf`!!!(3!!#Ee!!!!I!!!*`[rN!3!!#FY!!-!!!$*rrrre`%!N!3\rI!!!!pJ!!!!)"!`!!!&`!!!$h!!!!!`%$!!!!B!!"!*!'*fJ!!!!d!!!SMJ!!!$`\r!!#M(!!!!8!!!+-X!!!"m!!!T)J!!!)`!!#Q*!!!!V!!!+FcrN!3!!#RZ!!8!!!$\r*rrrre`%!N!3F!!!!qJ!!!!)"!*!%(3!!!2X!!!"N!3#3""m!!!$m!!!!!`#3"4i\r!!!$prrrrc`!$!!!!1!#3##TM!!!!$!!!+QB!!!!B!!!UIrq3"!!!+Rm!!!!"!*!\r'+UJ!!!!X!!!Ua2q3"!!!+j3!!J!!!-Rrrrr0!3#3""m!!!%(rrrrc!!$!!!!1!!\r"!*!'+lJ!!!!J!!!Vl!!!!$`!!#aQ!!!!8!!!,,RrN!3!!#cH!!)!!!$*rrrrc3%\r!N!3I!!!!$[rrrmF!!`!!!$J!!3#3"Ld%!!!!&!!!,3F!!!!N!!!Y,!!!!$3!!#e\r5rj!%!!!YD!!"!!!!bIrrrmd"!*!%(`!"!*!'-iJ!!!!d!!!c[J!!!%!!!$22!!!\r!E!!!-rm!!!#)!!!d*!!!!,!!!$4C!!!!f!!!0)B!!!$N!!!dUJ!!!1`!!$5f!!!\r!q!!!0-B!!!%B!!!df3!!!6J!!$6Zrj!%!!!dq`!%!!!!bIrrrmd"!`!!!(J!!!&\rh!!!!!`%$!!!!I!!!!AMrrrqk!!-!!!!i!!!!SrrrrpF!N!8H!!%!N!Be*J!!!!3\r!!$9)!!!!(!!!0@3!!!!N!!!eG3!!!%!!!$@Vrj!%!!!eZ3!#!!!!bIrrrmd"!*!\r%!`!!!B,rrrrm!*!&(`#3#$AJ!!!!+!!!0IJ!!!"!!!!f*`!!!&3!!$C4rj!%!!!\rf83!"!!!!bIrrrmd"!*!%(`#3#$Cj!!!!+!!!0T)!!!!d!!!fU3!!!$`!!$Dkrj!\r%!!!fZJ!"!!!!bIrrrmd"!*!%(`!"rj!%!!!!$!!!!!%!!!!(!!,rrrrp!!!!"3!\r!!!3!!3!!!!B!!!"N!*!&!IrrrrJ!!!!-!!!!!3!!!!F!!2rrrr-!!3!!!'S!![r\rrrr3!!!!G!!!!&!!(!!!!(J!!!!)!N!FB!!!!"`!!!!3!!!!I!!!!"`!!!!8!!!!\rJ!!!!#J!!!!B!!!!Krrrrm`!!!!J!!!!C!!!!!J!!!!`!!!!L!!!!!J!!!"!!!Ir\rrrr8!!!!8!!!!&2rrrr3!![rrrrB!!!!8!!!!)!!)!!!!&3!!!!S!N!F@!!!!"`!\r!!!)!!!!A!!!!"J!!!!-!!!!B!!!!!J!!!!3!!!!C!!!!"J!!!!J!!!!D!!!!"J!\r!!!N!!!!E!!!!#J!!!!S!!!!Frrrrp3!!!!`!!2rrrrF!!IrrrrB!![rrrr%!!!!\rX!!!!%!!%!!!!,3!!!'B!N!FZ!!!!!J!!!!3!!!![rrrrp`!!!!J!!!!`!!!!CJ!\r!!!`!!Irrrqm!!!!S!!!!!3!!!!F!![rrrr!!!!!b!!!!3J!3!!!!-`!!!!F!N!F\rd!!!!"`!!!!%!!!!e!!!!"`!!!!)!!!!f!!!!"`!!!!-!!!!h!!!!!J!!!!3!!!!\ri!!!!#J!!!!J!!!!j!!!!!J!!!!S!!!!k!!!!#J!!!!i!!!!l!!!!"`!!!"!!!!!\rm!!!!"`!!!"%!!!!p!!!!"J!!!")!!!!q!!!!"`!!!"-!!!!r!!!!"`!!!"3!!!"\r!!!!!"`!!!"8!!!""rrrrl`!!!"B!!!!`!!!!CJ!!!$i!![rrrqi!!!"$!!!!&!!\r+!!!!-`!!!!F!N!Fd!!!!"`!!!!%!!!!e!!!!"`!!!!)!!!"%!!!!"J!!!!-!!!"\r&!!!!"J!!!!3!!!"'!!!!"`!!!!8!!!"(!!!!CJ!!!!B!!!")!!!!!J!!!!S!!!"\r*!!!!#J!!!!i!!!!`!!!!CJ!!!"!!![rrrqd!!!",!!!!&J!+!!!!0J!!!!F!N!G\r-!!!!"J!!!!%!!!"&!!!!"J!!!!)!!!"'!!!!"`!!!!-!!!!Y!!!!CJ!!!!3!!!!\rZ!!!!#J!!!!J!!!"0!!!!CJ!!!!S!!!"1!!!!#J!!!!i!!!"2!!!!#J!!!"!!!!!\r`!!!!CJ!!!")!![rrrq`!!!"4!!!!#!!&!!!!-`!!!!F!N!Fd!!!!"`!!!!%!!!!\re!!!!"`!!!!)!!!"'!!!!"`!!!!-!!!!`!!!!CJ!!!!3!![rrrqX!!!"6!!!!"!!\r"!!!!-!!!!'B!N!8#rrrrjJ!!!(!!!!!'!!)!!!"a!!!!#J#3"h)!!!!#!!!!!J!\r"rrrrj`!!!#S!!!!'rrrrjJ!#rrrrk!!!!'8!!!"@!"!!!!"Q!!!!!J#3"fF!!!!\r#!!!!"!!!!'J!!!!#!!!!#!!!!'N!!!!#!!!!$!!!!'S!!!!#!!!!%!!!!'X!!!!\r#!!!!&!!!!'`!!!!#!!!!'!!!!'d!!!!#!!!!(!!!!'i!!!!+!!!!)!!!!'rrrrr\rR!!!!)J!!!')!!!!+!!!!6!!!!(-!!!!+!!!!6J!!!(3!!!!+!!!!8!!!!(8!!!!\r+!!!!8J!!!(B!!!!(!!!!9!!!!(F!!!!(!!!!93!!rrrrk3!"rrrrk!!#rrrrkJ!\r!!&8!!!"'!"N!!!!c!!!!"`#3"c3!!!!(!!!!!3!!!&B!!!!$!!!!!J!!!$F!!!!\r#!!!!"J!!!$J!!!!+!!!!#J!!!$N!!!!#!!!!$!!!!$S!!!!+!!!!%!!!!$X!!!!\r(!!!!%J!!!$`!!!!(!!!!%`!!!&F!!!!(!!!!&!!!!%B!!!!(!!!!&3!!!&J!!!!\r+!!!!&J!!!&N!!!!+!!!!'!!!!&S!!!!+!!!!'J!!!&X!!!!+!!!!(!!!!&`!!!"\rQ!!!!(J!!!&d!!!!#!!!!)J!!!&i!!!!#!!!!*J!!!&m!!!!#!!!!+J!!!'!!!!!\r#!!!!,J!!!'%!!!!#!!!!-J!!!')!!!!#!!!!0J!!!'-!!!!#!!!!1J!!!'6rrrr\rT!!!!2J!!!$!!!!"Q!!!!3J!#rrrri`!!!(X!!!!B!!B!!!"m!!!!!J#3"hd!!!!\r#!!!!"!!!!(i!!!!#!!!!#!!!!(m!!!!#!!!!$!!!!)!!!!!#!!!!%!!!!)%!!!!\r#!!!!&!!!rrrrj!!"rrrri`!#rrrri3!!!)-!!!!d!!d!!!#%!!!!!J#3"i8!!!!\r#!!!!"!!!!)B!!!!#!!!!#!!!!)F!!!!#!!!!$!!!!)J!!!!#!!!!%!!!!)N!!!!\r#!!!!&!!!!)S!!!!#!!!!'!!!!)X!!!!#!!!!(!!!!)`!!!!#!!!!)!!!!)d!!!!\r#!!!!*!!!!)i!!!!#!!!!+!!!!)m!!!!#!!!!,!!!!*!!!!!!!J!!!$!!!2rrrq)\r!!Irrrq%!!2rrrpm!!3!!!!)!!Irrrq!!!!!%!!!!"2rrrpm!![rrrq8!!!"j!!!\r!%J!&!!!!H[rrrq3!N!H#rrrriJ!!!!3!!!#4rrrri!!!!!J!!!!`!!!!CJ!!!!`\r!!!#5!!!!#J!!!"!!![rrrr)!!!!U!!!!4J!)!!!!+rrrrr%!N!Farrrrm!#3"d,\rrrrrZ!*!(5[rrrqd!N!G3rrrrl!#3"e,rrrrV!*!(92rrrqS!N!Girrrrj3#3"3,\rrrrrj!!!!%3!!!'B!#3!!!",rrrri!*!(%rrrrrF!!!!-!!!!)`!!!!X!!!!3!!!\r!*!!!!'B!!!!5!!!!*3!!!!X!!!!@!!!!*J!!!!X!!!!B!!!!*`!!!!X!!!!D!!!\r!+!!!!!)!!!!F!!!!+Irrrr)!!!!J!!(rrrrG!!!!$!!!!!%!!!!(!!,rrrrE!!!\r!P`!!!"3!"J!!!#d!!!"Q!*!(,J!!!!)!!!!%!!!!,rrrrrF!!!!)!!!!1J!!!!S\r!!!!-!!!!-!!!!'B!!!!1!!!!Q!!!!!S!!!!5!!,rrrrD!!!!Q3!!!"B!#3!!!*S\r!!!!+!*!(0`!!!!)!!!!#!!!!1!!!!!S!!!!'!!!!4`!!!'B!!!!)!!!!Q`!!!!B\r!!!!-!!!!4J!!!!F!!!!0!!!!53!!!!S!!!!1!!!!-!!!!'B!!!!3!!!!1J!!!!S\r!!!!8!!,rrrrC!!!!R!!!!"S!#3!!!*d!!!!+!*!(0`!!!!)!!!!#!!!!1!!!!!S\r!!!!'!!!!,3!!!'B!!!!)!!!!,J!!!!S!!!!-!!!!6`!!!!S!!!!1!!!!-!!!!'B\r!!!!3!!!!RJ!!!!)!!!!8!!!!R`!!!!S!!!!B!!,rrrrB!!!!S3!!!!S!!`!!!+)\r!!!!+!*!(0`!!!!)!!!!#!!!!-!!!!'B!!!!'!!,rrrrF!!!!PJ!!!"S!"!!!!#[\rrrrrE!*!(3[rrrpS!N!G+rrrrf3#3"k$rrrrB!*!&![rrrpi!!!#8!!!!1J!*!!!\r!%[rrrpd!N!F6rrrrp`!!!!`!!!!M!!!!#`!!!"!!!!!N!!!!CJ!!!")!!!!P!!!\r!#`!!!"B!!!!Q!!!!#`!!!"J!!!!R!!!!#`!!!"S!!!#9!!!!!J!!!"`!!!!Trrr\rrh!!!!#!!![rrrrS!!!!2!!!!CJ!#!!!!%2rrrrN!N!H6rrrrhJ#3"3,rrrr9!!!\r!TJ!!!!B!!J!!!+F!!!!,!*!("J!!!'3!!!!#!!,rrrr6!!!!Y3!!!!3!!3!!!,B\r!!!!#!*!&!Irrrp)!!!!)!!!!!3!!!!F!![rrrp3!!!#`!!!!%!!&!!!!X3!!!!B\r!N!Hb!!!!"J!!!!%!!!#c!!!!#J!!!!)!!!#drrrrd`!!!!3!!!#hrrrrdJ!!!!J\r!![rrrpB!!!#N!!!!3J!0!!!!TIrrrp8!N!HS!!!!C!!!!!B!!!#T!!!!#`!!!!S\r!!!#U!!!!#`!!!!`!!!#V!!!!!J!!!!i!!!"8!!!!"J!!!")!!!#X!!!!"J!!!"-\r!!!#Y!!!!CJ!!!"3!!!#Z!!!!!`!!!"J!!!#[rrrre!!!!"`!!!#irrrre!!!!#`\r!!!#j!!!!"J!!!$`!!!#k!!!!!`!!!$i!!2rrrpF!!IrrrpB!![rrrrX!!!!0!!!\r!DJ!#!!!!$[rrrrS!N!HMrrrre`!!!'B!!2rrrr`!!IrrrrX!![rrrri!!!!$!!!\r!%J!(!!!!"2rrrrd!N!F(!!!!#`!!!!3!!!!)!!!!#`!!!!B!!!!*!!!!#`!!!!J\r!!!!+!!!!#`!!!!S!!!!,!!!!#`!!!!`!!!!-rrrrr!!!!!i!!2rrrp%!!Irrrp3\r!!2rrrp!!!3!!!!-!![rrrmi!!!$q!*!)rrrrc`!"rrrrcJ!!rrrrc3!"rrrrrJ!\r"rrrrb3!!!!3!!!!"!!!!"`!#rrrrbJ!!!48!!!!-!!-!!!%@rrrrb3#3"J%A!!!\r!!J!!!!3!!!%B!!!!!J!!!!J!!2rrrmX!!IrrrmS!![rrrm`!!!%)!!!!'J!0!!!\r"#3!!!!)!N!B"#J!!!!)!!!!%!!!"#`!!!!F!!!!)!!!"$!!!!!B!!!!*!!!"$3!\r!!!B!!!!+!!!"$J!!!!B!!!!,!!!"$`!!!!B!!!!-!!!"%!!!!!B!!!!0!!!"%3!\r!!!B!!!!1!!!"%J!!!!B!!!!2!!!!&J!!!!)!!!!3!!!"%`!!!!X!!!!8!!!"&2r\rrrmX!!!!@!!(rrrr)!!!!"3!!!!%!!!!'!!(rrrr$!!!!!J!!!!)!!!!,!!,rrrr\r%!!!")`!!!!J!!`!!!5,rrrr&!*!'!53!!!!,!!!!"!!!!5Arrrr$!!!!"J!!rrr\rra3!"rrrra!!#rrrraJ!!!5%!!!!b!"%!!!%Lrrrra3#3"J%N!!!!#`!!!!3!!!%\rQ!!!!#`!!!!B!!!%R!!!!CJ!!!!J!!!!6rrrrp`!!!!`!!!!M!!!!#`!!!"!!!!!\rN!!!!D`!!!")!!!!P!!!!#`!!!"B!!!%S!!!!#`!!!"J!!!%T!!!!"`!!!"S!!!%\rU!!!!"`!!!"X!!!%V!!!!CJ!!!"`!!!%X!!!!CJ!!!#!!!!%Y!!!!!`!!!#3!!!%\rZ!!!!!`!!!#J!!!%[!!!!#`!!!#`!!!%`!!!!!`!!!#i!![rrrm!!!!%r!!!!"!!\r#!!!"3!!!!!X!N!Hm!!!!#`!!!!)!![rrrm%!!!%k!!!!%!!&!!!"1`!!!!)!N!B\r"2!!!!!)!!!!%!!!"23!!!!S!!!!)!!!"2[rrrm!!!!!+!!!"33!!!!X!!!!1!!,\rrrrr#!!!"-J!!!&!!'!!!!5,rrrr&!*!'!53!!!!,!!!!"!!!!5B!!!!,!!!!"J!\r!!5F!!!"Q!!!!#!!!!"2rrrrh!!!!$!!!!#-!!!!,!!!!%!!!!#3!!!"V!!!!%J!\r!!#8!!!!,!!!!&J!!!6-!!!!,!!!!'!!!!63!!!!(!!!!'J!!!68!!!!(!!!!'`!\r!!6B!!!!,!!!!(!!!!6F!!!!(!!!!(J!!!6J!!!!(!!!!(`!!!6Rrrrr"!!!!)!!\r!!8)!!!!#!!!!-!!!!8-!!!!+!!!!0!!!!83!!!!$!!!!0J!!!88!!!!$!!!!1J!\r!!8B!!!!+!!!!2J!!!8F!!!!$!!!!3!!!!8J!!!!$!!!!4!!!!8N!!!!#!!!!5!!\r!!8S!!!!#!!!!6!!#rrrr[`!!!8`!!!"!!"B!!!%Lrrrra3#3"J%N!!!!#`!!!!3\r!!!%Q!!!!#`!!!!B!!!%R!!!!CJ!!!!J!!!!6rrrrp`!!!!`!!!!M!!!!#`!!!"!\r!!!!N!!!!D`!!!")!!!!P!!!!#`!!!"B!!!&0!!!!!`!!!"J!!!&1!!!!#`!!!"`\r!!!&2!!!!!J!!!"i!!!&3!!!!!J!!!#)!!!&4!!!!#J!!!#B!!!&5!!!!#J!!!#J\r!!!&6!!!!#J!!!#S!!!&8!!!!#`!!!#`!!!&9!!!!#J!!!#i!!!&@!!!!!J!!!$!\r!!!&A!!!!!J!!!$3!!!&B!!!!#J!!!$J!!!&C!!!!!J!!!$S!!!&D!!!!#J!!!$i\r!!Irrrld!!!!@!!!!!J!!!!X!![rrrli!!!&F!!!!-J!,!!!")[rrrm8!N!B"*!!\r!!!X!!!!%!!!"*J!!!!X!!!!'!!!"*`!!!'B!!!!)!!!!%rrrrrF!!!!-!!!!)`!\r!!!X!!!!3!!!!*!!!!'X!!!!5!!!!*3!!!!X!!!!@!!!!*J!!!!X!!!!B!!!!*`!\r!!!X!!!!D!!!!+Irrrld!!!!F!!,rrrqm!!!"AJ!!!#3!$`!!!5,rrrr&!*!'!53\r!!!!,!!!!"!!!!5B!!!!,!!!!"J!!!5F!!!"Q!!!!#!!!!"2rrrrh!!!!$!!!!#-\r!!!!,!!!!%!!!!#3!!!"V!!!!%J!!!#8!!!!,!!!!&J!!!9m!!!!,!!!!'!!!!@!\r!!!!(!!!!'J!!!@%!!!!(!!!!'`!!!@)!!!"Q!!!!(!!!!@-!!!!,!!!!)!!!!@3\r!!!!(!!!!)J!!!@8!!!!(!!!!)`!#rrrrZ`!!!@F!!!!Q!!i!!!%Lrrrra3#3"J%\rN!!!!#`!!!!3!!!%Q!!!!#`!!!!B!!!%R!!!!CJ!!!!J!!!!6rrrrp`!!!!`!!!!\rM!!!!#`!!!"!!!!!N!!!!D`!!!")!!!!P!!!!#`!!!"B!!!&S!!!!#`!!!"J!!!&\rT!!!!"`!!!"S!!!&U!!!!"`!!!"X!!!&V!!!!CJ!!!"`!!!&X!!!!#`!!!#!!!!&\rY!!!!CJ!!!#)!![rrrmF!!!%I!!!!8!!'!!!")2rrrmB!N!B"-Irrrm)!N!B"5rr\rrrlm!N!B"@rrrrli!N!B"AIrrrl`!N!B"C[rrrlX!N!8#rrrrZJ!!!AN!!!!%!!%\r!!!&k!!!!!`#3"3(rrrqj!!!!%3!!!!%!!!!(!!(rrrqi!!!!$3!!!!%!!!!(!!,\rrrrqhrj!%!!!!#!!!!!,rrrqfrj!%!!!!$!!!!!,rrrqerj!%!!!!#!!!!!,rrrq\rdrj!%!!!!'!!!!!(rrrqc!!!!#`!!!!%!!!!(!!(rrrqb!!!!"`!!!!%!!!!(!!,\rrrrqarj!%!!!!#!!!!!,rrrq`rj!%!!!!$!!!!!,rrrq[rj!%!!!!#!!!!!,rrrq\rZrj!%!!!!D!!!"&p!1$%i!!--58j&9&0[BfYPG(-!!&P*6N988fpMDf9d4'pYB@P\rZ!!Ab*&0[BfYPG%4[E@&TEJ!%0&0[BfYPG%4[E@&TEJ!(mepIGR"dFL3!!q*NFQP\rfCA*6G'&dC3!&&(*PFfpXGQ9b8h4KG'8!!YPNFRCb8Q9Q6R9Y!!%1D@jPG%0[G@j\rd!!CeF'*-BA0d!!D9F'*-DA0d!!-#3@jZEh4KG'9N8%)!!R"`BJ!&b8"ME'&cFb3\rh16K(990*58j&9&pMF!!$VR4MF!!(Fe4$8'P[F')!"[*QD@aX-6)!"0YTEd0[EA"\rXCA4TEfi!!Ep5Eh9dD@jP4'9cBh*TF(4[FJ!(*fG[6@PiC@40Ef4P9(*KF!!(4(C\rPFR0TEfi!"JKbEh9dD@jP4'9cBh*TF(4[FNCXB@Gc!!&@FQ9cCA*fC@3a!!&AFQ9\rcCA*fC@3b!!4hFf9XC@0dEh**EQC[!!3UFQpeG'PZC80[G@jd!!E`FQpeG'PZC9*\rPBfpbC(-!"4p5Eh9dD@jP8Q9MEh*N!!#rF(*[BdPZCQm!!p"*8d%!"2YbEh9dD@j\rP4QaKCh-!"S4`FQpM4'9cBh*TF(4[FJ!!eh0PE'9MG'pb!!"rD@p5CA0eE(3!!GC\rTEdjKE@93G()!!@aTEeC5C@C1G@d!!4CTEd05C@C1G@d!"UTMFd0[C'8!!IpdBh"\r6G(*PB@d!"mKMFe"KFQ&Y!!@l3'0XBA0c*$Fi0dG98dP*6N98Af0`!!DCBh*PBA4\rP!!1k9%033h*PBA4P8%)!"p"bBhC#G@CQ!!+8FQ0f3R9QCNaPEJ!#h@j[G'PQH9"\rbEf-!!bTeFf9b4'&dB9"dFJ!%F'p`C@i!!4p83e"2F'9Z8%)!"iaeE("8D@ePEh9\rd9Q&XG@8!!(peE("8D@ePEh9d3@0dD@pZ!!@NGQ&XD@4TG(P'E'&RF`!$$@0[E@e\rKEQ48D@ePEh9d9Q&XG@8!!YTbC@e[G'9)Eh0d!!+qFQ9YEh4P8'pbG!!"cQa[Bf&\rX5'pcG!!"XQa[Bf&X8'pbG!!!i(4[FdCXB@Gc!!*rF(*PBf9NC@jMC3!!Ff4[ER4\r'FQ&R!!)rG'PYC94[6'PfC3!!kA0PBh9bDA4j!!(eEh"dD@pZ3fjd!!FNEh"dD@p\rZF`!%JA0PEQ3!!9"83e"6C@jN8%)!!,C`GA0S4QaKC`!#2(9bCf9ZG%CXB@F!"VP\rQD@aXCA)!"[ahC(03G()!!"*cC@jN4R*PC3!#QR0PEQ4-C@jRG'J!"`PbC@0PDAC\rP!!4c9%038Q9MC@PfC9"#!!#&E@&bDdCXB@F!"LCbC(03G()!!CabC(0-C@jRG'J\r!"qYcC@0[EQ48D@eP8h4KEA!!"IeME'pcC3!#ie4$8%0XEh0P8%)!"F0KBQpbG!!\r#Qe4$8%&LEh*d8%)!"XjcG'&dGA-!!ep83e"6G'&dGA033J!'@R9ZGA0PC!!(Kf0\r[EQjPBh4TEfj6G'&dC3!#Sh0PEQ4AD@jNEhF!!3PbBhCAD@jNEhF!"V&KEA49EQ&\rMDf9N4'&dB3!&D'&YG&9ZFQ9KC%4KG'%!!,jcC@0eFQPdH8aPGQ9X8(4b!!11Ff9\rZC&9ZB@0VC@3!!&0cC@jN6Q9iG!!!KQ0[EQGPFh4TEfjAD@jNEhF!"`TbBhC1CAK\rd!!5'Fh*dG!!(BfaKFh459&3!"NKcC@jN6@&i8f9R8fPkC3!$H@0[EQj6G'&d8(4\rb!!,99%033fpZEQ9MG'P[EP0dBA4c!!4&C'&dB9"VG(05BhCN!!6GC'&dB9"VG(0\r6C@jd!!EGC'&dB9"VG(05CA0PER3!!ICLHA4PFe*MGQ3!"+GLHA4PFe*MGQ4%GA!\r!!i9LHA4PFe*MGQ43BA0d9fPZC'ph!!'+BRPdCA06C@jd!!1JBRPdCA05CA0PER3\r!"jaZG@e)DA0dEd*eBfYPG(-!"44cC@jd8fPkC8KTFh4[!!1m5'PcG'p#G@0VCA3\r!"9KfB@aeC3!(%Q0[G@jdCA)!"r"dEA*68P48!!-mFR4d9Q&bD@&ZBf8!"KYdEA*\r59%m!!FCcC@jN9(*TCA-!!0CcEh9bBfK4G@9ZBfK5BhCN!!,rCfa[BQ&X5@jQE`!\r(T94$8%GXEf*KE%PZCQp33J!$%R4MF&"KFQ&Y8(4b!!!Q9%038'&bB@d!"j!!G'0\r`8R4[33!"$A4MF&*dEdeTEJ!"&R4MF&*dEdeKH!!&qR4MF%eKH&0PCe0THQ8!!Pe\rdBh"0BAK$EfjZ!!4TG'0`6@&i9fPZC'ph!!2MG'0`8h4KG(03G()!!)K83e"6G'&\rdF`!(C(4MF%0[EQj"G(4PEA"dF`!&dh4MF%0[EQj2F'9ZC@3!"fPdBh"$EfjZ3@0\rMCA"dC@3!"5"dBh"$EfjZ3fa[Ff9N!!BrG'0`3fpZEN&LEh*dC@3!!lCdBh"2Bh4\rPG(0*EJ!%3h4MF%pMG'9dFdpeG!!'Kh4MF%pMG'9dFdPZ4(9`!!!cG'0`6f0dCA4\rc8Q9dFQ&ZF`!%IA4MF%PZF(9d8'YdF`!&)(4MF%peG("eG&"VG(-!!JpdBh"%GA"\r3Dh4c!!EfG'0`8Q9dFQ&ZFe"VG(-!!kCdBh"$4%*8B@*XC3!"G'eKH&4$8%0[EQj\rPBh4TEfjc!!1bG@4`!!F`9843D@p`BJ!"rR9NF&0dFQ9KE3!&r%"ME'&cFb3h16"\r(990*58j&9&pMF!!$cP9%8%0bC@&dC9"#!!*3C@jND@jR8'pbG!!"@99%8&0PEQ4\r33J!!+A*PFf9bGQ9N!!"!BfKPBfY6G@d!"&a94&"5C@0PDACP8%)!"mPdD@eP6h9\rd!!"UC'9cG%K[Fh3!!%jNCA0d8'pbG!!$Q@edG3!!qP9%8%e899"#!!HCEA4e8fP\rkC3!%,R0[BfX!!Xa*6N988fpMDf9d!!If*&0[BfYPG!!'q90[BfYPG!!!((*PCN0\r[G@jd!!$IGhKbC@CMEfi!"b9hH'9fC@jd!!2RGhKPGQ9ZG'eKFfX!"R*cG(*PB@d\r!!ieZEfjLE'pMDfPZC`!(pR*PBhC#G@B!"CTbC@0fC!!#ch0K!!2NFfpMDf&NC(*\rID@i!"`*cD@jIE'9Z!!,!FfPZAfCKE@PXH3!!@R0TEPp`Eh*d!!!$FfPZAf&NC()\r!"feTEPpKC'4b!!CpFepKC'4b!!#bFfPZAhTPFQm!"1a`C@9b!!DaFh0dBA4P!!$\r(BA0jEQ0PFR)!"S3ZD(4[EQ`!!@KS!!D,,QKdEfjc!!DN,QjdEfKX!!&ZEJ!'Ubj\rZG'pSF`!'a#j83e"ICA*bEh*IAdCT!!AaCA*bEQm!!B40B@083e"PFR)!"G%ZAep\rMG&pI-6"*6N988fpMDf9d4RB!!$-ZAepMG&pI0P0[BfYPG%Cf!!+EAepfG&pI-6"\r*6N988fpMDf9d!!Fr,QePEA0PG!!"$5j2F'9Z8fpMDf9dAema0NP14946Ef0VCA4\r%EfeKD@j'GJ!%@h4SDA-!",G!1$3`!!I8AepNG&pI0P0[BfYPG%Cf!!5i3$Jd-3!\r'JLjIAf0dAema-%P14946Ef0VCA4'9@`!",T!1$3c!!5l3$Jd0!!&"#jIAf4dAem\ra-%P14946Ef0VCA4'GJ!#`5j$E'pcC90[BfYPG&pI-6C*6N988fpMDf9d4'pYB@P\rZ4RB!!%)ZAepNG&pI0P0[BfYPG%Cf!!*2,PpIC'aIAdC3GJ!%[d!i0$J!!Z!Z3AC\rKD@aKBQaPAema-%P14946Ef0VCA4'GJ!$#bj6CA45C@C$EfjIAc%`58j&9&0[BfY\rPG%C3GJ!$P#jIAh"dFPpRE(9P!!Gi,RGi6@&M8fpMDf9d5'&ZC'aPFP"bEf-!"MG\rbC@CMEfi!!4aMB@jAFQPdC9!!!0GMB@j5C@&N8!!!CQ0KEPGbDA4P!!FmBf&Z8Q9\rKC!!%qd!i0M3!!EBZ4e96590PG&*PCQ9bC@jMC3!(XP0[BfYPG(-!"[`ZAepfBep\rI-6&6Ef0VCA48B@*XC8CT!!&cF`!%m@eKFfX!")GNBA4K!!6p3$Jf0J!(R5jLD@j\rNAema-%P14946Ef0VCA4'8(CT!!1Y,NG98dPICA*bEh)!!PJZCf9dD'pcG'PN!!4\r!B@4NFJ!(SQjKE@9XC@i!"+YZB@eP!!3J3$Jh13!(hbjRCA4cEf0VEQ&YC9pI-6"\r*6N988fpMDf9d4P"f8'N!"f8ZE@9YBh"j!!3l3$Ji-`!(p#jRCA4`C@9bEQ&YC9p\rI-6"*6N988fpMDf9d4P"f8'N!"%&!1$Jj!!&%,R0SGA4NEhGZAema-%P14946Ef0\rVCA4'D3!$"QK[G`!%AN!i16B!!$8ZCQ0ZG'aIAc%`58j&9&0[BfYPG%C9D@N!!jp\rME@3!!cTKFQF!"%0!16!i!!'Y,QP[Bh4XAema-%P14946Ef0VCA4'9@P3GJ!(-(*\rPFA9PFh3!",GKFQG`!!6cFfPkC3!$j'PQFJ!&N@PQFQ9a!!4M3$Na1!!!Tbj(990\r*GfPdD%PZG'9bEQ9d8fpMDf9dF`!%GLj%Efjd8h4bDA"IAc%b8fpMDf9d4'pYB@P\rZ4RB!"(Y!16)`!!-&,PpIBh4IAc%f58j&9&0[BfYPG%4[E@&TENCf!!IV,PpIBh4\rIAc%b8fpMDf9d4'pYB@PZ4QN!!*0IAhCdAema0NP14946Ef0VCA4%EfeKD@i!"#d\rZAepMG&pI-6G(990*3fpZCQPRGA*KG'P[ENCf!!5MBfpZCJ!"ZdG98dP$EfjQD@G\reFQ&dD@pZ!!2,C'9QBA9XG&4jF'8!"K"NC@CKG@ad3h*PBA4[FJ!!,Q&eG'p6F'P\rZ!!F4EQp$D'4TFJ!"-Q&MBh9b8h4KG!!#rQKKFd0[ER0[E'8!"ZTZEd&eG'p*EQP\rd4h*KCJ!#"h0SBA*PC%p`C@i!"eCcD@G3DA"P!!@UEQp"F("XC89fC@jdF`!$P'j\reE90eCQCTBf9c!!#1Fh9QCQPMCA-!!TC(990*8h9QCQPi!!D`Fh9QCQPi!!#,Fh9\rQCP4jF'8!!r"cG@CQ3h*PBA4[FJ!%I8!j-M)!"J0IAf4dAema-P0[BfYPG%4[E@&\rTENCf!!4q3$Nb-`!%JN!j-MF!"8iZ4(*TGQ9bAema0NP14946Ef0VCA4%EfeKD@j\r'GJ!$bbj33Np`C@j6H@jM!!8T8'&bB@e#E'pMDe*PB`!(,@P[8'&bB@d!"iP*6e"\rKFQ&Y!!8EF8aTEQX!"Ap44@aPE3!&QR&8HA"P!!@1F84KG'%!"M9TEe4bBA!!!G9\rTEd0YC%&NC()!!(TTEe*PCNjeE3!"fQP[9Q9bFdjeE3!"bfP[8'9bEA0cEJ!'afP\r[6@PcB`!!2@P[3R9QCQ9b!!+UD@p5CA&$Eh9ZG!!#C@P[3@0d3fpeER3!!@4TEe"\r[Fde[C'8!!e*TEe"[FdpQCR0PG!!"0fCTE'93BA*KE3!"edCTE'93BA*KE3!"D'P\r[4P*PCNjeE3!#-'P[4PCPFR01G@d!"fKQD@aXCA)a!!0BD@p'4'Pb5@jNCAJ!!M"\rTEdCX3A4dFQPL!!-#D@p'E&CPFR01G@d!"0&TEdCX4QjNFNPZCQm!"Aj'5@jQE`!\r'CQCN9(P`C3!"DfCN3h*PBA4[FJ!(['CN4QaKCh-!!JCQC%a[Bf&dD@pZ!!@N8'p\rTER3!!ACf!!DfCQ4'E'4b!!FND@p'E%jeE3!"$fP[4Qa6G%*XD`!"rfP[4Qa-Cda\rPEJ!"c'P[4Qa3H8aPEJ!#k@P[4Qa58h4#E'X!!N"TEdCX8NaR6'9Z!!++D@p'E&*\r3H8aPEJ!"[@P[4Qa$FN4KG!!"efP[4Qa0C%4KG!!$ZhC[E(9YC9"KFQ&Y!!-j9Qp\rXG@eP8'&bB@d!"fPQD@aXCA)b!!*MD@p@Efa*EQ4PH!!"`fP[9N0b4'&dC3!",fP\r[9Nac3QY9F!!([@P[9N&dFQ)!!)9TEeC1E8CXF`!!9'P[9N4TFP0d!!GND@p@3Qa\r-EJ!$,@P[9NjY3@a#E'Yc!!1JD@p@3@a#E'Y6DAS!!I"TEeC$E("6DAS!!*&TEd&\rX3Qa6G!!#FfP[9NjiG%C1G@d!!&*TEeC'FN*XD`!#c'0ZG(*X8'&bB@d!!X"$ER4\rbE&"KFQ&Y!!5+Ffa[G%4PGP"KFQ&Y!!6D8fa[G%4PGP"KFQ&Y!!%UD@p68Q9Q6R9\rY!!))D@p69Q9bFdjeE3!#Z@P[8e"PFQecFfi!"NPTEe00DAJ!!"eTEe0'E'&RF`!\r'JfP[8fa[G!!%hfP[583!"6YYG@adD84PGP"KFQ&Y!!@c6A9XG'P%CAC3BA*KE3!\r"UfP[69*PCNjeE3!#R@P[69CPFR01G@d!!QPTEde3CA*YFh0Z!!C+D@p06@Pi!!"\r"D@p04QaKCh-!!PTTEe0&3QaV8(4b!!5$3$Nb1!!(C5j5CA0[E(CPFPpI-6C*6N9\r88fpMDf9d4'pYB@PZ4RB!"IBZ6h"PEP*PFfpXGQ9b!!5G3$Nc-J!'%#jcEf0VCA4\rIAc%f58j&9&0[BfYPG%4[E@&TENCTF`!(A#j(990*Af9bFQpbAfjTE!!#HbjIAfj\rhAep'9@`!!h)ZAepMG&pI194$8&0[BfYPG%Cf!!2R,PpIBh4IAcP94&"6Ef0VCA4\r'GJ!%Eh4jF'8!!CKcBACP4A*bEQm!!XC&FR*ZEe0KGQ9b!!0TCP0KGQ9N4A*bEQm\r!"2e!16Bb!!&FAepNE&pI4P"f!!6`AepNG&pI-6"&FR*ZEe0KGQ9b4RB!"2j!16B\rc!!@(,PpIC(4IAc%`4A*bEQp6BACPFNCf!!3#3$Nf0`!%$Lj(CA433PpI-6C*6N9\r88fpMDf9d4'pYB@PZ4RB!"HCMGA*33J!$,#jIAfjhB9pI4P9X!!3m3$Ni-!!$Sbj\rIAf4XB9pI4P"f!!4!3$Ni0!!%38!j1$8!"%0!16Jh!!EmAep59&4*Aema-P0[BfY\rPG%4[E@&TEJ!%3N!j1$B!!N0IAe*89%PIAc%f58j&9&0[BfYPG%4[E@&TEJ!"5@0\rSEfpcC9pI-6*6Ef0VCA4%EfeKD@j'D9"M8(CT8(C3D3!'Mh0[BfYPG("KDA*IAc%\rb8fpMDf9d4'pYB@PZ4QPc8&!f8fpMDf9d!!,dAepNG&pI-6C*6N988fpMDf9d4'p\rYB@PZ4RB!"E9cEf0VCA4IAc%f58j&9&0[BfYPG%4[E@&TENCTF`!$cbjIAf4dAem\ra0NP14946Ef0VCA4%EfeKD@j'GJ!(i5jIAf4dAema-P0[BfYPG%4[E@&TENCf!!4\rG3$Nj-3!%AN!j16)!"'"!16Nd!!IrAep59&4*Aemf8fpMDf9d!!4I3$Nj-`!%"Pp\rI8P4859pI-6"*6N988fpMDf9d!!0hF'pcG&pcC@aPBh4IAcC6Ef0VCA4'9@09Be9\rM!!&)Ff9XC@0dAemf8fpMDf9d4P"9Be"9Be"9B`!#E("bC9pcC@aPBh4IAcC6Ef0\rVCA4'9@09Be9M!!&#DA0KG(4jAemf8fpMDf9d4RB!"(eQG(*eEQ0KG'9IAcC6Ef0\rVCA4'E!!"B'acC@9VAemf8fpMDf9d4QaT!!8[CR0dBA4IAcC6Ef0VCA4'8$4cG'&\rd!!&,Ff9dFfpMDfp`G&pI0P0[BfYPG%CTD9"fD3!#b'GPG(0[BfY[F(4IAcC6Ef0\rVCA4'D@P3GP"T!!FFFf9ZC(4[Aemf8fpMDf9d4P"fD@P3GQN!!R"bC@0fCR*[E9p\rI0P0[BfYPG%C3GQPT8(C3D3!#2AGbDA4PAemf8fpMDf9d4P"fD3!"TR*PB@4IAcC\r6Ef0VCA4'8(CT!!5@B@0MCA"dAemf8fpMDf9d4P"f8'N!!FKXDA0dC@jIAcC6Ef0\rVCA4'D3!%kQ0[EQjPBh4IAcC6Ef0VCA4'8(CT!!#&FfKeG'4[GfjIAc%`58j&9&0\r[BfYPG%CT!!$UD@pMG'aIAc%`58j&9&0[BfYPG%C9D9"f!!G4CQ0ZG'aIAc%`58j\r&9&0[BfYPG%C9D@N!"P9RCA4`C@9bEQ&YC9pI-6"*6N988fpMDf9d4P"f8'N!"Qa\rRCA4cEf0VEQ&YC9pI-6"*6N988fpMDf9d4P"f8'N!"Q&LD@jNAema-%P14946Ef0\rVCA4'8(CT!!%"3ACKD@aKBQaPAema-%P14946Ef0VCA4'GJ!%!PpIC(4IAc%`58j\r&9&0[BfYPG%Cf!!6L,PpIFfPZDA4I4e9658P1494IBh!!!F-ZAepbC@GTFh4PFPp\rRE'pLB@aIEf*UC@0d!!4L3$Nj0J!$IP423`!"!%0XEh0P8fpMDf9dAema0NP1494\r6Ef0VCA4%EfeKD@j'GJ!!6%p`C@j6Ef0VCA4IAc%f58j&9&0[BfYPG%4[E@&TENC\rf!!2f4f9d8%*IAc%f58j&9&0[BfYPG%4[E@&TENCf!!CL8Q9cEfafCA*IAc%f58j\r&9&0[BfYPG%4[E@&TENCf!!3T4(*TGQ9bAema0NP14946Ef0VCA4%EfeKD@j'GJ!\r#-&pIBh4IAc%f58j&9&0[BfYPG%4[E@&TENCf!!F)4e965AGTG'K*ER4PFQjPG&0\r[BfYPG(-!!"a(990*8f9d8Q9QCA*PEQ0P!!,f8f9d8Q9Q3fpZAema-%P14946Ef0\rVCA4'8(B!"HTIAf0dAema-%P14946Ef0VCA4'9@`!""4IAf0dAema-%P14946Ef0\rVCA4'GJ!&d&4$8&pPFR*[FPpI4QN!"EjZG'pSF`!&YfjdEfKX!!@ID(4[ER-!"CK\rSG'pZE!!!8%pA8J#3"MES!!"G-J!!!J-!!$G8!!!PhJ!!&I!!!!*f!!!%9J!!!%!\r!N%"&C`!!4AX!N!8"XJXHZd9T!*!&"%9V!!3!!!!&!!!!C!!!!#!!!!PkI!J#TT2\rKrrb3!!%!#*3Krm!mB!!"1)!!!6KMUQj)!!!"B!!!!$[M!!!mB!!"1)!!!6KMU'j\r)!!!"B!!!!(`$q%"!JJ!-1'!#!%J!!!JiB!3!J!%!5$JK!%"m#!1QJq(rr%k!!#"\r&G3#3"3B!!!!F4A8!N!8'!!!!0%9Z$!3!!!!(!!!!$)!!N!Z!!!"N#!!!!%9h!*!\r&"3#3"%9T!*!&"%9V!!3!!!!)!!!!'!!!!%`!!!SX9'!&+8##!!`iB!!!6S!!)$K\rJ!!&1J!!J4@X!"!!!!!S!!!#F!!!!IJ!!#Z9m#!+QNq(rr*2"rrL6SIrdN!!"!!L\r8)Iq`1q-!!%J!!!%l``!!Im!(G#`!!!&!JJ!J5!!!!AaM"c4Ar`9qIq!(0(`!'!"\r"J!!)1q#SRcKr!!!iRJ!!5!!!!@!!!!!lS`!!2'!!!6L!!!%iBkLI5!!!!@!!!!"\rmBqK3-!2rrhaJ'4#!!3"B1#%!8(`)!kD$iIrmJm(rq)1Krr41J!!J4A8!N!8)!!!\r!(%9e!*!&"3!!!$"&G3#3"3B!!!"84A8!N!8'!!!!E%9Z$!3!!!!-!!!!$)!!N!Z\r!!!#F'!!!!%9h!*!&#J#3"%9V!!3!!!!0!!!!G!!!!-i!!!`4I!J#TT2Krrb6`Ir\riN!!"!!L8)IqJ1m-!!$[N!!!iB!!"1)%!2%J!!!&J!!!!U'%!5MLH!!!i[`!!1-%\r!1%J!!!&J!!!!I'!(08'#!"3i!!!!X"i!!$J!!!#3!"m!!)!"!'Ji)3"JI!J$TS2\rKrrb$`Iri6S!!)%9e!*!&$J!!!#4&G3#3"3m!!!!m4@i-"!!!!"i!!!!-J!#3#i!\r!!(33!!!!4AF!N!80!*!%4@X!"!!!!"m!!!$!!!!"1J!!$20m#!+QNq(rr*2"rrL\r6SIrdN!!"!!L8)Iq`1k-!!$[%!!!li!!!1'#KV8J!!!&8B!Br3B)!*$aJCQmiBfa\rN1)%!1%J!!!&J!!!!I'!(08##!!Jli!!"9q!'2d##!"3iI3!!1*i!!%J!!!&)!!!\rm1'#!!$b!Bh3iS!!!10d!!$Mq!!!iK(*X5!!!!@!!!!"mB!Fe3B)!&$J!!!#`(3!\r!1!!!!*!!(J!!J!%!@$JK!&"m#!1QJq(rr)2"rrL$SIrd6S!!)%9e!*!&#J!!!#K\r&G3#3"5!!!!"!4A8!N!80!!!!C%9e!*!&)3!!!)4&EJ`%!!!!*!!!!!b!!*!,J!!\r!`"J!!!"&G`#3"4m!N!4&D`!%!!!!*3!!!1J!!!(1!!!2)(`)!UDrBIrXN!!"!!L\r8)Ii`1f-!!$Z%!!!lT3!!1mB!!$J!!!#3!!%"4$J"!$L3!!%"5V1K!8k6`3&S1!!\r!!E!"!94)!!"mJ!%"@(`!f%"!JJ"JJ!%"A(`!i%"!JJ"81(d!!$LH!!!iS3!i1-!\r!!8J!!!&J!!!!1q-!!$aJC'iiJ!!"1'0bF%J!!!&J!!!!+!-!!%##!"3iI`!!5!!\r!!@!!!!")!!!-1(m!!%J!!#bSB3&81!-!!E!"!956`3&S1'%"1%J!!!&J!!!!I'!\r(08'#rhJiB2rrJ!%"f$JK!G"m#!1QZf(rl%k!!#"&G3#3"5B!!!"X4A8!N!8R!!!\r!K%9e!*!&+!!!!*K&G3#3"5N!!!$!4@i-"!!!!3%!!!!-J!#3#i!!!1JS!!!!4AF\r!N!8P!*!%4@X!"!!!!3)!!!$S!!!#K!!!%[0m#!+QNq(rr*!!!3!)P#(rX$KK!$`\riJ3!i5!!!!6aJBf3mJ(TdU+%!2)$"!$JiBf9f1)4MF%J!!!%li`!!Iq!(0#`!rrp\r"JJ!-1(m!!%J!!)JiB3!m1)%!1%J!!!%mB'0N2)"YG+LK!$b!`3!i1'0PGML%Bh"\r)!!!"1q-!!(rJ"c3X!2rr3B)!$$Kr!!")!!")1'%!2$L"!$K)!!!"2'"MC$b!EA5\rSS3!mJ-%!1$KMCABiK'0`5!!!!6[M!!"ri!Fd,!$rrd'#!!`iI`!!5!!!#$KJrrq\r!!3"B1#%!8(`)!kD$iIrm6S!!)%9e!*!&(`!!!"K&G3#3"58!!!!d4A8!N!80!!!\r!@%9e!*!&*3!!!(4&G3#3"4m!!!#B4A8!N!8P!!!!Y%9Z$!3!!!%$!!!!$)!!N!Z\r!!!$S#!!!!%9h!*!%!3)!N!4&D`!%!!!""!!!!3`!!!-5!!!9J(`)!UD6iIrmNm(\rrq*!!!3!)P#(r`*!!B3"BJ!)!!#J!!!""JJ!-1'!!!%J!!-a)!!!"1q-!!$aJC'i\riJ!!"1'0bF%J!!!&J!!!!N!"L!!#!!J!!+!!!!%##!"")!!!"B!!!!%J!!*5!BJ!\r!5!!!!@!!!!"ri!Fd,!$rrd'#!"!iI`!!5!!!!@!!!!#!BJ!!5!!!!@!!!!#!BJ!\r!5!!!!@!!!!#!BJ!!J!-!!*!!!J!!J')!!$L!!q%iS!!"J-%!@%J!!!&J!!!!1m-\r!!(r!"c9"JJ!NJ')!!%J!!!&J!!!!J')!!%J!!!&J!!!!1!!!!*!!!J!!1(i!!)!\r"!%Ji)3"!I!J$TS2Krrb$`Iri6S!!)%9c%!#3"!-!!!!B4A8!N!3"!J!!!#a&G3#\r3"5F!!!"!4A-3!*!%!J!!!%K&Fa!!N!3#!!!!6%9e!*!%!38!!!"B4A-3!*!%!J!\r!!'4&G3#3"!%'!!!!D%9e!*!&+!!!!)"&Fa!!N!3#!!!!L%9e!*!%!3F!!!#-4A-\r3!*!%!J!!!*4&G3#3"!%)!!!!Q%9c%!#3"!)!!!#J4A-3!*!%!`!!!+K&Fa!!N!3\r$!!!!V%9e!*!%!3N!!!#m4A-3!*!%!J!!!0"&G3#3"!%+!!!!e%9c%!#3"!)!!!$\rF4A8!N!3"#`!!!1"&Fa!!N!3$!!!!l%9Z$!3!!!%1!!!!$)!!N!Z!!!%-%!!!!%9\rh!*!%!33!N!4&D`!%!!!"$`!!!'J!!!2)!!!D%A`)!UD3!!%!#*3Krm#!!J!!+!!\r!!%##!!`iB2rN5!!!2)"L!!!iJ!$K1+!!!NJ!!!&J!!!!J')!!%J!!!&J!!!!J')\r!!%J!!!&J!!!!1!!!!*!!!J!!1'!!!)!"!%Ji)3"!I!J$TNk!!#"&Fa!!N!3$!!!\r!$%9c%!#3"!-!!!!J4A8!N!3"#3!!!#a&Fa!!N!3#!!!!0%9e!*!%!3S!!!!i4A-\r3!*!%!J!!!%"&G3#3"!%,!!!!4%9c%!#3"!-!!!"34@i-"!!!!4!!!!!-J!#3#i!\r!!'J!N!4&G`#3"!%2!*!%4@X!"!!!!4%!!!"S!!!%$!!!(%&m#!+QN!!"!!L8)Ir\r!N!"K!&L3!)%!A*!!S3"JN!$"!'5!!J!!+!!!!%##!!`iB2rN5!!!,)"L!!!mJ!!\r"1+!!!i$"!&L!i3"FJ3%!B)%K!'3iK2rK5!!!!@!!!!#!!3")1#%!3(`)!kC1J!!\rJ4A-3!*!%!`!!!"a&Fa!!N!3$!!!!-%9e!*!%!3N!!!"34@i-"!!!!4X!!!!-J!#\r3#i!!!'J!N!4&G`#3"!%4!*!%4@X!"!!!!4`!!!"F!!!%D!!!(JGm#!+QN!!"!!L\r8)Ir!N!"K!&L3!)%!A)!#!!!S!!!!3))!$$KJrq4)!!!SJ')!!$L!$q%iS!!%J-%\r!@)$K!&a)!!!"B!!!!,"K!$JiB!!!J!%!5$JK!%"m#!1Q6S!!)%9c%!#3"!-!!!!\r84A-3!*!%!`!!!#K&G3#3"!%*!!!!2%9Z$!3!!!%I!!!!$)!!N!Z!!!"F!*!%4AF\r!N!3"(!#3"%9V!!3!!!%J!!!!9!!!",B!!"pUI!J#TT!!!3!)P#(r`*!!B3"BN!#\r"!&b!!J!!+!!!!%##!!`iB2rN5!!!))"L!!!iJ!rK1+!!"B$"!&L!i3"F5!!!!@!\r!!!#!!3")1#%!3(`)!kC1J!!J4A-3!*!%!`!!!"4&Fa!!N!3$!!!!+%9e!*!%!3N\r!!!!m4@i-"!!!!5%!!!!-J!#3#i!!!&3!N!4&G`#3"!%J!*!%4@X!"!!!!5)!!!"\rS!!!%pJ!!)0Tm#!+QN!!"!!L8)Ir!N!"K!&L3!)%!A*!!S3"JN!$"!'5!!J!!+!!\r!!%##!!`iB2rN5!!!,)"L!!!mJ!!"1+!!"S$"!&L!i3"FJ3%!B)%K!'3iK2rK5!!\r!!@!!!!#!!3")1#%!3(`)!kC1J!!J4A-3!*!%!`!!!"a&Fa!!N!3$!!!!-%9e!*!\r%!3N!!!"34@i-"!!!!5-!!!!-J!#3#i!!!'J!N!4&G`#3"!%L!*!%4@X!"!!!!53\r!!!"S!!!&8J!!)Tjm#!+QN!!"!!L8)Ir!N!"K!&L3!)%!A*!!S3"JN!$"!'5!!J!\r!+!!!!%##!!`iB2rN5!!!,)"L!!!mJ!!"1+!!"i$"!&L!i3"FJ3%!B)%K!'3iK2r\rK5!!!!@!!!!#!!3")1#%!3(`)!kC1J!!J4A-3!*!%!`!!!"a&Fa!!N!3$!!!!-%9\re!*!%!3N!!!"34@i-"!!!!6)!!!!-J!#3#i!!!'J!N!4&G`#3"!%N!*!%4@X!"!!\r!!6-!!!"S!!!&VJ!!*'"m#!+QN!!"!!L8)Ir!N!"K!&L3!)%!A*!!S3"JN!$"!'5\r!!J!!+!!!!%##!!`iB2rN5!!!,)"L!!!mJ!!"1+!!#)$"!&L!i3"FJ3%!B)%K!'3\riK2rK5!!!!@!!!!#!!3")1#%!3(`)!kC1J!!J4A-3!*!%!`!!!"a&Fa!!N!3$!!!\r!-%9e!*!%!3N!!!"34@i-"!!!!63!!!!-J!#3#i!!!'J!N!4&G`#3"!%c!*!%4AX\r!N!T&DJ!%!!!"03!!!!`!!!B+!!!&UMJ!!!'B"!!!6S!!)%9["33!!!%h!!!!)2r\rrrr8!!!B1U[i(!*!,!m!!!3!%!*!-4AB+!!!!!6J!!!!84@i3"!!!!6X!!!!%rrr\rrc!!!$p8!N!4&EJ8%!!!"23!!!"6rrrr*!!!3-!!!!!3!N!F#!!!!"!#3"%9f"3!\r!!!%m!!!!%%9f"3!!!!%l!!!!"%9f"3!!!!%k!*!%4@i&!3!!!83!!!!+rrrrb!!\r!%4*XEf0KE'K[Fh3!8Q4&D`!%!!!"43!!!Y`!!!Bd!!!4%R`)!UDr)IrNN!!"!!L\r8)Iq3!$XM!!#$BJ!!Jk)!!)2#!!#$JJ!!J))!!%J!!!&J!!!!,!-!!%##!&")!!!\r"B!!!!$Y$!!#633!iJ!%!1*!!!3!mJ!%!2#J!!!""JJ!F1'%!2$L!!!3iS!!#5!!\r!!@!!!!")!!*B1!!!!C!!(!!!1'!!!%J!!NL!BJ!!5!!!!@!!!!"mB!Fe3B)!&$J\r!!!13!"`!!$KJ!!")!!)N1q!!!%J!!"JiJ!!!9q-31MJ$!34mRJ%Z1rm!!5`I!!4\r"J2rS1!!!!*J"!%!iH3!!1*i!!)#L!!!i`3"!5!!!!AaJ"c3X!+Aq3))!A%J!!!&\rJ!!!!,!-!!%##!#b!(3!!+!!!!%'#!$3iB!!#1)!!!)'G!!")!!!"B!!!!#`$!!"\r"JJ!B1'!!"%J!!!&J!!!!1'!!!%J!!Bb)!3"!+!!!!%'#rkb!(J!!,!#Pr8'#!'a\r!J!!X,!#PqN'#!*!!3)!!&#`!TIK"JJ#N3)!!N!")!!#X,!#Pr%#!!&4)!!"J,!!\r!!%'#!+K!J!#8,!#Prd'#!!a!J!#)5!!!&$J!!!'3!"`!!$KJ!!")!!%F1!!!!j!\r!(!!!1'!!!%J!!3`i!!!$N!!F!!!iB!!!5!!!r$J!!!'3!"`!!$KJ!!")!!$X1!!\r!!C!!(!!!1'!!!%J!!0`i!!!#N!!F!!!iB!!!5!!!c$J!!!13!"`!!$KJ!!")!!#\rm1!!!!T!!(!!!1'!!!%J!!+`i!!!$N!!F!!!iB!!!5!!!R)JH!!4m!!Ge3))!&$J\r!!!'3!"`!!$KJ!!")!!#!1(i!"%J!!!&J!!!!1q2rrcJI!!4m(J#ZI!!(G#`!!#j\r!JJ!31'!!!$JI!!4mIJ'Z1q!!!%J!!"aAia!k1!-""(aq!K4Ai"!kI(X",M[r!!%\rX(`!%3)!!'&IM%$Si!`%%I"i!,LJ!!!"!J[r31'!!!&IJ%$TmH`%ZJ')!!)!"!(J\ri)3"`I!J$TVXKrq41J!!J4A3$!!!!!6`!!!!84A3$!!!!!8B!!!!B4A3$!!!!!6S\r!!!!F4A3$!!!!!6N!!!!J4A3$!!!!!83!!!!N4A8!N!3"4`!!!#K&G3#3"!&)!!!\r!1%9e!*!%!8N!!!"S4A3$!!!!!8S!!!#%4A8!N!3"5`!!!)K&G!-!!!!"0`!!!0a\r&G3#3"!%4!!!!j%9e!*!%!8`!!!$d4A8!N!3"63!!!4a&G3#3"!&1!!!"-%9e!*!\r%!8m!!!*34A3$!!!!!6d!!!,%4@i-"!!!!93!!!!-J!#3#i!!!Y`i!!!!4AF!N!3\r"43#3"%9V!!3!!!&*!!!#8!!!"f!!!"FRI!J#TVmKrq53!!%!#*3Krk!l)`!!Ji)\r!!)1L!!#$`J!!Jf)!!)"L!!")!!!"B!!!!(aJ"c9"JJ!81!!!!j!!'`!!1'!!!%J\r!!IJli!!!5!!!'$L!!!"Aia!k1!-""(bH!5ilr`!","m!"%'!rqJi!!!!Q!%!1)"\rj!!!m!i%!+!!!!8##!"")!!!"B!!!!%J!!!L!H3!!1d-!!$LH!!#!SJ!!1-%!1%J\r!!!&mB!Fd,!#PrN##!&a)!!!"B!!!!#`$!!"!JJ!XJ"d!!#J!!!""JJ!d1'!!!cL\r!!!#"R3!!5!!!!@!!!!!X!`!!3B)!'$KJ!!4)!!!"B!!!!$KJ!!")!!&!L!%!1#J\r!!!""J[qXJ"i!!#`!TIa"JJ"83)!!+#`!TIP"JJ"i3)!!%#`!TIK!J!"m5!!!L#`\r!TIY!J!"!5!!!6#`!!!""JJ#%3)!!F#`!TIj"JJ!)5!!!C$J!!!13!"X!!$KJ!!"\r)!!$B1!!!!C!!'`!!1'!!!%J!!-Ji!!!"N!!E!!!iB!!!5!!!Z$J!!!+3!"X!!$K\rJ!!")!!#S1!!!!j!!'`!!1'!!!%J!!*Ji!!!#N!!E!!!iB!!!5!!!L$J!!!13!"X\r!!$KJ!!")!!"i1(i!"%J!!!&J!!!!1q2rrcJI!!4m(J#ZI!!(G#`!!#j!JJ!31'!\r!!$JI!!4mIJ'ZJ"i""#J!!!"!JJ!)Nei""$[J!!")!!!F9q-31MJ$!34mIJ)89q!\r31Ram!5ilr`!","m!"%'!rq3i!!!!N!!F!"#!BJ!!J!%!D$JK!'"m#!1QZb(rj%k\r!!#"&G!-!!!!"2!!!!"4&G!-!!!!"4J!!!"K&G!-!!!!"1J!!!"a&G!-!!!!"13!\r!!#"&G!-!!!!"5J!!!#4&G3#3"!&,!!!!+%9e!*!%!8J!!!#%4A3$!!!!!6F!!!#\rF4A8!N!3")J!!!+4&G3#3"!&-!!!!Y%9e!*!%!8d!!!$F4A8!N!3"6J!!!2"&G3#\r3"!&2!!!"c%9d!`!!!!%p!!!#1%9Z$!3!!!&@!!!!$)!!N!Z!!!*31!!!!%9h!*!\r%!8N!N!4&D`!%!!!"9`!!!'!!!!KF!!!F&(`)!UD3!!%!#*3Krm#3!'%!@)"L!!"\r)!!!"B!!!!(aJ"c9"JJ!B1!!!!i"L!!#3!!-!!$KJ!!")!!!FJ'%!@)##!!!iK!!\r%5!!!!B"L!!!iB`!%J!%!5$JK!%"m#!1Q6S!!)%9d!`!!!!&+!!!!%%9e!*!%!8X\r!!!!84A3$!!!!!6N!!!!S4A3$!!!!!6S!!!!m4A8!N!3"(!!!!%4&G!-!!!!"1J!\r!!%K&EJ`%!!!"@3!!!!b!!*!,J!!!B!#3"%9h!*!%!9F!N!4&D`!%!!!"@J!!!23\r!!!L@!!!Feh`)!UD6iIrmNm(rq*!!!3!)P#(rS*!!B3"iN!#"!(b$iJ!!J')!!%J\r!!!&J!!!!I'!(08'#!#Ji!!!$J')!!*!!!`!!1!$rrj!!!3"3J'%!H)!"!&#3!!-\r!!%J!!)L!B3"m1*m!!$LJ!!!i`!!!5!!!!AaJ"c9"JJ!NJ!%!H*!!!3")1!$rrj!\r!!3"-J'%!5)!"!%b3!!-!!%J!!%b)(`!%I!!(G8'#!#5!!3"iN!!"!%!i!2rrN!!\r"!%5!B3"!J!%!4*!!!`!!5!!!))2I!35!!3"iN!!"!$L6`3!mJ'%!1)!"!$b3!!-\r!!)!"!'Ji)3"JI!J$TS2Krrb$`Iri6S!!)%9d!`!!!!%k!!!!(%9d!`!!!!&+!!!\r!)%9e!*!%!8X!!!!N4A3$!!!!!6N!!!!i4A8!N!3"%3!!!'K&EJ`%!!!"A!!!!!b\r!!*!,J!!!p"!!!!"&G`#3"!&D!*!%4@X!"!!!!8J!!!#)!!!)m!!!(Spm#!+QN!!\r"!!L8)IqJL!)!!(`!"h9!JJ!81!!!!*!!!J!!1!!!!CJ#!!#!!J!!,!!!!%'#!!b\r!BJ!!5!!!3)"L!!")!!!"B!!!!,"K!&!i!!!2X!%!8MKK!$K)!!!"B!!!!(aJ"c9\r"JJ!-1'!!!%J!!!b!B3"8N!"L!!#!!3"S1#%!B(`)!kC1J!!J4A-3!!!!!9i!!!!\r-4A-3!!!!!9d!!!!F4A-3!!!!!9i!!!!N4A-3!!!!!9d!!!!S4A-3!!!!!9d!!!!\rd4A3$!!!!!8S!!!!m4A8!N!3"A`!!!%"&G3#3"!&J!!!!@%9c%!!!!!&G!!!!G%9\rZ$!3!!!&R!!!!$)!!N!Z!!!#)!*!%4AF!N!3"5!#3"%9Z"3%!!!&U!!!!$2rrrm8\r!!#"N*@3Z*@3Z*@3Z*@3!4@X!"!!!!@X!!!&8!!!*5J!!)'4m#!+QNq(rr*2"rrL\r6SIrdNi(rm*!!!3!)P#(rX$Z$!!!lT!!!L!)!!(`!"h9!JJ!81!!!!*!!!J!!1!!\r!!CJ#!!#!!J!!+!!!!%##!-K)!!!"1m-!!*2"!$L!!3!iN!!"!$b!!3!m+!!!!%#\r#!"3iB!!b5!!!!@!!!!")!!#m1'%!2$L!!!3iS!!#5!!!!Aar'hP!JJ"8,"d!%%#\r!!"3iB!!@5!!!!@!!!!")!!#-1(`!!)##!!#!!3!m9!9'2S!"!$a8"SBqJ!%!2&3\r(aMk!!3!m9!J'2NJ!!!&J!!!!1'!!!%J!!&5!I`!!5!!!!@!!!!!iB`!"5!!!!@!\r!!!#3!')!!)"L!!#!R`!!5!!!!@!!!!!iI!!!J))!!$Lp!!")!!!"B!!!!$J!!!"\rmIH)8Q!2rrcKJ!!#!!3"B1#%!8(`)!kD$iIrmJm(rq)1Krr5$JIr`6S!!)%9c%!!\r!!!&T!!!!*%9c%!!!!!&S!!!!0%9c%!!!!!&T!!!!2%9c%!!!!!&S!!!!3%9e!*!\r%!8J!!!"-4A8!N!3"6J!!!("&G3#3"!&*!!!!L%9e!*!%!8i!!!#J4A3$!!!!!@S\r!!!#`4A8!N!3"E!!!!04&G3#3"!&2!!!!k%9e!*!%!@d!!!$d4A-3!!!!!@J!!!$\rm4A-3!!!!!@J!!!%!4A8!N!3"EJ!!!3K&Fa!!!!!"D!!!!44&G3#3"!&[!!!"(%9\rZ$!3!!!&c!!!!$)!!N!Z!!!&8)!!!!%9h!*!%!@X!N!4&EJ8"!!!"G!!!!"(rrrr\r$!!!MqQ9MD'mJ)#!*#5!J0bpeC(!!N!4&EJ8"!!!"G3!!!"2rrrr#!!!MqQ4TFf0\rKFQ3J)#!*)#!j,h9NF!#%4@i&!3!!!AB!!!!4rrrr`3!!)rTdD@eP)#!J#3NJ-cF\r[G@4`!'PZG89Z"3%!!!&h!!!!%[rrrm!!!#2kC'pYB@PZ)#!J#5!e-bpeC(!!!`"\r&EJ8"!!!"H!!!!",rrrqr!!!MqR0eER*`Bb!J)!Na-6%[G@4`!!E#4@i&!3!!!AN\r!!!!3rrrr[J!!)rTdCR4`)#!*#5!f15peC(!!4@i&!3!!!AS!!!!4rrrr[3!!)rT\rLD@CQ)#!J#3Ne-6)[G@4`!-1V#%9Z"3%!!!&l!!!!%2rrrl`!!#2kGfK[)#!J#3N\re-6-[G@4`!%9Z"3%!!!&m!!!!%IrrrlX!!#2kG'&XDb!J)!N*06%h,h9NF!"6!!"\r&EJ8"!!!"I3!!!"2rrrqk!!!MqQCdF#eNBA4K)#!*)$)`,h4MF!#J4@i&!3!!!Ai\r!!!!2rrrrZ3!!)rTQG(!J)!N*)$)a,h4MF!!!4@i&!3!!!Am!!!!4rrrrZ!!!)rT\rdC@aZCA3J)!NJ-M-[G'0`!*!%4@i&!3!!!B!!!!!3rrrrY`!!)rTcEA4`)#!*#5!\rb05pdBh!!4@i&!3!!!B%!!!!3rrrrYJ!!)rTdD@eP)#!*#5!c0bpdBh!!4@i&!3!\r!!B)!!!!4rrrrY3!!)rThD'pTFb!J#3NJ0$-[G'0`!*!%4@i&!3!!!B-!!!!5rrr\rrY!!!)rTNEfeKD@iJ#5!*)$8c,h4MF!#Vc%9Z"3%!!!'%!!!!%rrrrl-!!#2kD'p\rcG'jKE@9c)#!a-$%[G'0`!!"&EJ8"!!!"K3!!!"(rrrqb!!!MqQjZG(!J)#!*#6%\ra15pdBh!!N!4&EJ8"!!!"KJ!!!"(rrrqa!!!MqQCTEQGPFL!J#5!h15pdBh!!N!4\r&EJ8"!!!"K`!!!"$rrrq`!!!MqQjdF#!J)!N*-6)c,h4MF!"&EJ8"!!!"L!!!!"(\rrrrq[!!!MqR9eBh!J)#!*#68d-#pdBh!!Z+[-4@i&"!!!!BN!!!"BrrrrVJ!!)rS\r!N&K&GJ8!!!!"L!!!!&"&GJ8!!!!"K`!!!%a&GJ8!!!!"KJ!!!%K&GJ8!!!!"K3!\r!!%4&GJ8!!!!"K!!!!%"&GJ8!!!!"J`!!!$a&GJ8!!!!"JJ!!!$K&GJ8!!!!"J3!\r!!$4&GJ8!!!!"J!!!!$"&GJ8!!!!"I`!!!#a&GJ8!!!!"IJ!!!#K&GJ8!!!!"I3!\r!!#4&GJ8!!!!"I!!!!#"&GJ8!!!!"H`!!!"a&GJ8!!!!"HJ!!!"K&GJ8!!!!"H3!\r!!"4&GJ8!!!!"H!!!!""&GJ8!!!!"G`!!!!a&GJ8!!!!"GJ!!!!K&GJ8!!!!"G3!\r!!!4&GJ8!!!!"G!#3"%9V!!3!!!'f!!!!G!!!#Hi!!#D(I!J#TT!!!3!)P#(r`*!\r!B3"BJ!)!!#J!!!""JJ!JJ')!!$J!rrpm!`"!3B)!%)"L!!")!!!"B!!!!$J!!!#\r3!!)!!$KJ!!#!!J!!,!!!!%##!"#!!3"B,!!!!%'#!!JiB!!"N!"L!!#!!3")1#%\r!3(`)!kC1J!!J4A-3!!!!!C%!!!!34A-3!!!!!C%!!!!F4A-3!!!!!C%!!!!X4A8\r!N!3"Y`!!!$"&Fa!!!!!"X`!!!$a&Fa!!!!!"Y3!!!%4&Fa!!!!!"Y3!!!'"&EJ`\r%!!!"Z3!!!!b!!*!,J!!!G!#3"%9h!*!%!EB!N!4&D`!%!!!"ZJ!!!&3!!!S`!!!\rR'R`)!UD3!!%!#*3Krm#!!J!!+!!!!%'#!#L!BJ!!1!$rrh`$!%""JJ!BJ')!!%J\r!!!&J!!!!1!!!!*!!!J!!1!!!!*!!!J!!J!%!5$JK!%"m#!1Q6S!!)%9c%!!!!!'\r4!!!!$%9c%!!!!!'4!!!!'%9c%!!!!!'4!!!!+%9e!*!%!EX!!!!X4A-3!!!!!C%\r!!!!i4A-3!!!!!E8!!!"!4@i-"!!!!E`!!!!-J!#3#i!!!&3!N!4&G`#3"!'k!*!\r%4@i&!3!!!Ed!!!!1rrrrT!!!*j30,f9dBbpcCA*fD@0PF`!!4@i3!3!!!Ei!!!!\r#rrrrS`!!*j4b!()!4@i3!3!!!Em!!!!$rrrrSJ!!*j3M$3!!4@i3!3!!!F!!!!!\r$rrrrS3!!*j3J#3#)4@i3!3!!!F%!!!!$rrrrS!!!*j3[,!!!4@X!"!!!!F)!!!)\r-!!!+C!!!*j4m#!+Q[f(rl*!!!3!)P#(rB)2#!!#$SJ!!Ji)!!)!#!!!S!!!!3))\r!F$KJJ!!mJ("b1+!!!$M"!$Jii3!k1)4PCNJ!!!&J!!!!I'!(08##!$JiB3!qJ))\r!!%J!!!&J!!!!1'%!1%J!!!&J!!!!1))!!%J!!!&J!!!!N!"L!!!S!`!!3))!&$J\r!rrq3!!)!!$J!!!#3!!)!!)"L!!!i!2rrI!-!3%##!%b!BJ!!J!)!!&3!%$Tm!`!\rZ+!!!!%##!!`iB!!!5!!"1$Km!!#!SJ!!J))!!$J%!!'3!!)!!&5!%$TmK3!Z5!!\r!!@!!!!")!!!S1(`!!$L!!)#!SJ!!5!!!!@!!!!!S!`!!3))!$$KJ!!")!!$X1(`\r!!$L#!!")!!!"B!!!!(al'hP"JJ!-1!!!!*JE!!#)(!!!I!!(G8'#re`iI!!!1))\r!!%J!!!&J!!!!N!"p!!!S!`!!3B,r3$KJ!!!iJJ!!5!!!!@!!!!"mHaYj3B,r+$K\rl!!!iJJ!!5!!!!@!!!!#3!(d!$#J$!!""J[m-1)!!!)"p!!`i!`!"N!!G!!bBJ`!\r!1(X!!%J!!!&J!!!!N!"p!!L6h3!%1q!!!%J!!#JiB!!!1))!!%J!!!&J!!!!9q!\r31Raq!5iS!`!!1rm!!8'#!!`X(`!(3B$rf$KJ!!"Ai"!kI(i",MKp!!#!!3#S1#%\r!S(`)!kDlBIrX6S!!)%9d!`!!!!'d!!!!%%9d!`!!!!',!!!!&%9d!`!!!!'+!!!\r!'%9c%!!!!!'4!!!!(%9e!*!&)3!!!%"&G!-!!!!"[3!!!&4&G3#3"!($!!!!@%9\re!*!%!F3!!!"N4A-3!!!!!Ei!!!"X4A8!N!3"a3!!!("&Fa!!!!!"N3!!!(K&Fa!\r!!!!"N3!!!)K&Fa!!!!!"X`!!!*!!4A-3!!!!!C%!!!#84A3$!!!!!BN!!!#N4A-\r3!!!!!E-!!!#S4A3$!!!!!BN!!!$)4A-3!!!!!E-!!!$-4A-3!!!!!E-!!!$84A8\r!N!3"EJ!!!1"&Fa!!!!!"N3!!!24&G3#3"!('!!!!q%9c%!!!!!'r!!!"&%9e!*!\r%!FF!!!%B4A-3!!!!!F!!!!&!4A8!N!3"b!!!!84&Fa!!!!!"`!!!!9a&G3#3"!(\r)!!!"B%9c%!!!!!("!!!"G%9e!*!%!FF!!!&i4A8!N!3"b3!!!D4&Fa!!!!!"`!!\r!!F"&G3#3"!()!!!"a%9Z$!3!!!(1!!!!$)!!N!Z!!!)-+!!!!%9h!*!%!F)!N!4\r&D`!%!!!"c`!!!0`!!!Y+!!!X!A`)!UD6iIrmNm(rq*1Krr56JIr`N!!"!!L8)Iq\r`1m-!!$Z%!!!iB!!!5!!!!8J!!(!iIJ!!J*d!!%J!!!&J!!!!,!-!!%'#!$L$r3!\r%5!!!)$Kq!!#!R`!!5!!!!@!!!!!X!`!!3B)!'$[r!!5!(`!!+!!!!%##rpa)!!!\rN+"`!!%'#!#JiI!!!J*d!$%J!!!&J!!!!,!-!!%'#!"")!!!"I(dEH8##rib!!J!\r!,!!!!%##!!K)!!!"1(d!!)!"!&Ji)3"3I!J$TS2Krrb$`IriJk(rp)1"rr"1J!!\rJ4A8!N!3"YJ!!!#K&G3#3"!&(!!!!1%9e!*!%!8F!!!"B4A8!N!3"4`!!!)a&G3#\r3"!(#!!!!R%9c%!!!!!'e!!!!U%9e!*!%!ES!!!#d4@i-"!!!!G-!!!!-J!#3#i!\r!!0`J!!!!4AF!N!3"c`#3"%9V!!3!!!(8!!!!P!!!#rB!!#ffI!J#TT2Krrb6`Ir\riNk(rp*!!!3!)P#(rX$ZM!!!la!!!1'!!!%J!!!&)!!!`J"m!#(`G!!"!JJ!N+"i\r!!%'#!#JiIJ!!J*m!$%J!!!&J!!!!,!-!!%'#!"")!!!"I(mEH8##rmb!!J!!,!!\r!!%##!!K)!!!"1(m!!)!"!&Ji)3"3I!J$TS2Krrb$`IriJk(rp%k!!#"&G3#3"!'\rf!!!!*%9e!*!%!8F!!!")4A8!N!3"`J!!!&K&Fa!!!!!"Y3!!!'4&G3#3"!'k!!!\r!F%9Z$!3!!!(@!!!!$)!!N!Z!!!#8'!!!!%9h!*!%!G3!N!4&EK!"!!!"e`!!!!6\rrrrqG!!!Z`A4MF!"&EK!"!!!"f!!!!!6rrrqF!!!Zh(9NF!"&EK!"!!!"h`!!!!6\rrrrqC!!![Ch9NF!"&EK!"!!!"i!!!!!6rrrqB!!![Ch4MF!"&D`!%!!!"i3!!!03\r!!!aX!!![Ch`)!UD6iIrmNm(rq*!!!3!)P#(r`$[$!!#!BJ!!J!)!!"`!!!ari`)\r81(i!!$L#!!")!!!"B!!!!#`$!!"!JJ!B1!)!!*!!(`!!1!!!%C!!(`!)5!!!4$K\rq!!!iJJ!!5!!!!@!!!!!X!`!!3))!'$J#!!#3!"m!!$J!!!D3!"m!#%J!!"Ji!!!\rVJ')!!*!!!`!!1'!!!%J!!#`i!J!!N!!I!!5!BJ!!1)-!!6KJ!!Tm""[@I!!CeR`\r!)&#3!!)!!$Kr!!#!!3")1#%!3(`)!kD$iIrmJm(rq%k!!#"&G!-!!!!"f3!!!"K\r&Fa!!!!!"hJ!!!"a&Fa!!!!!"h`!!!#a&G3#3"!&(!!!!-%9c%!!!!!(B!!!!3%9\rc%!!!!!(J!!!!@%9e!*!%!8F!!!"F4A-3!!!!!GF!!!"X4A3$!!!!!H)!!!#%4A-\r3!!!!!6X!!!#84A-3!!!!!Gi!!!#F4A-3!!!!!Gi!!!#d4@i-"!!!!H3!!!!-J!#\r3#i!!!033!!!!4AF!N!3"i3#3"%9V!!3!!!(P!!!!N!!!!!c-!!!a'j2Krrb!JJ!\r!J!)!!"`!!!arj!)8,!-!%8##!"Ji!J!!N!!I!!!i!!!4N!!I!!K)!!!d,!-!"N#\r#!"Ji!J!!N!!I!!!i!!!'N!!I!!K)!!!B1!!!+i##!!#3!!3!!$KJ!!")!!!X1!)\r!!*!!(`!%J))!!$LN!!%iJ!!+I!8MeR`!)GCm!#K3N!!#!!!iI`!!Jq(rr%k!!#"\r&G!-!!!!"f3!!!!4&Fa!!!!!"hJ!!!!K&Fa!!!!!"f!!!!"a&Fa!!!!!"e`!!!$K\r&G!-!!!!"iJ!!!&"&Fa!!!!!"1`!!!'"&Fa!!!!!"hJ!!!'K&Fa!!!!!"hJ!!!)"\r&E"!%!!!"hJ!!!!3!!!!$!!![3d9X"33!!!(C!!!!H2rrrjX!!#m44@`3"!!!!E8\r!!!!%!!!!!`!!*QP&E!8%!!!"Y!!!!#$rrrqP!!!Q5N9X%!3!!!'c!!!!"!!!!!-\r!!#Bb4@`3"!!!!C%!!!!%rrrrU`!!*KG&E!8%!!!"L`!!!"$rrrqX!!!Pqd9X"3%\r!!!'+!!!!J2rrrkd!!#AF4@`3!3!!!@N!!!!"!!!!"`!!)'4&E"!%!!!"D!!!!!3\r!!!"Q!!!JC%9X%!%!!!&H!!!!!3!!!!F!!"k24@`3"!!!!9d!!!!%!!!!!`!!(Sp\r&E!8%!!!"2!!!!"6rrrr,!!!3"%9X"33!!!%k!!!"&2rrrpF!!!qI4@d&"!!!!6N\r!!!!%!!!!!`!!"SY&E"!%!!!!!`!!!!6rN!3!!!Hq4@`3"!!!!!)!!!!%!!!!C`!\r!"jP&E`S%!!!"jJ!!!!L!!*!24AB!N!3"j3#3"%9f$`!!!!(R!!!!"%9[#J3!!!(\rS!!!!#)!!N!p&GJ#3"!(K!*!%4AB2!!!!!HF!!!!%4@m+"!!!!HN!!!!)J!#3$d9\rf!*!%!G3!N!4&GJm!!!!"j`!!!!4&E`S%!!!"kJ!!!!L!!*!24AB!N!3"c`#3"%9\rf$`!!!!(R!!!!"%9[#J3!!!(V!!!!#)!!N!p&GJ#3"!(#!*!%4AB2!!!!!HF!!!!\r%4@m+"!!!!H`!!!!)J!#3$d9f!*!%!ES!N!4&GJm!!!!"j`!!!!4&E`S%!!!"l3!\r!!!L!!*!24AB!N!3"YJ#3"%9f$`!!!!(R!!!!"%9[#J3!!!(Z!!!!#)!!N!p&GJ#\r3"!&V!*!%4AB2!!!!!HF!!!!%4@m+"!!!!Hm!!!!)J!#3$d9f!*!%!8J!N!4&GJm\r!!!!"j`!!!!4&E`S%!!!"m!!!!!L!!*!24AB!N!3"@J#3"%9f$`!!!!(R!!!!"%9\r[#J3!!!(a!!!!#)!!N!p&GJ#3"!&A!*!%4AB2!!!!!HF!!!!%4@m+"!!!!I)!!!!\r)J!#3$d9f!*!%!8N!N!4&GJm!!!!"j`!!!!4&E`S%!!!"m`!!!!L!!*!24AB!N!3\r"43#3"%9f$`!!!!(R!!!!"%9Z#J3!!!%i!!!!#)!!N!p&GJ#3"!%e!*!%4AB2!!!\r!!HF!!!!%4@m+"!!!!I3!!!!)J!#3$d9f!*!%!6-!N!4&GJm!!!!"j`!!!!4&E`S\r%!!!"p3!!!!L!!*!24AB!N!3"*!#3"%9f$`!!!!(R!!!!"%9[#J3!!!(f!!!!#)!\r!N!p&GJ#3"!%L!*!%4AB2!!!!!HF!!!!%4@m+"!!!!IF!!!!)J!#3$d9f!*!%!5!\r!N!4&GJm!!!!"j`!!!!4&E`S%!!!"q!!!!!L!!*!24AB!N!3"(!#3"%9f$`!!!!(\rR!!!!"%9[#J3!!!(j!!!!#)!!N!p&GJ#3"!%4!*!%4AB2!!!!!HF!!!!%4@m+"!!\r!!IS!!!!)J!#3$d9f!*!%!3m!N!4&GJm!!!!"j`!!!!4&E`S%!!!"q`!!!!L!!*!\r24AB!N!3""!#3"%9f$`!!!!(R!!!!"%9[#J3!!!(m!!!!#)!!N!p&GJ#3"!%#!*!\r%4AB2!!!!!HF!!!!%4@m+"!!!!Id!!!!)J!#3$d9f!*!&*3#3"%9f$`!!!!(R!!!\r!"%9[#J3!!!(q!!!!#)!!N!p&GJ#3"4m!N!4&GJm!!!!"j`!!!!4&E`S%!!!"r`!\r!!!L!!*!24AB!N!80!*!%4AB2!!!!!HF!!!!%4@m+"!!!!J#3"!L!!*!24AB!N!8\r+!*!%4AB2!!!!!HF!!!!%4@m+"!!!!J%!!!!)J!#3$d9f!*!&#!#3"%9f$`!!!!(\rR!!!!"%9[#J3!!!)#!!!!#)!!N!p&GJ#3"38!N!4&GJm!!!!"j`!!!!4&E`-%!!!\r"iJ!!!!5!!*!,4AB&!!!!!H)!N!4&EJ-%!!!"f3!!!!5!!*!,4AB&!!!!!GN!N!4\r&EJ-%!!!"Y!!!!!5!!*!,4AB&!!!!!E3!N!4&EJ-%!!!"L`!!!!5!!*!,4AB&!!!\r!!BX!N!4&EJ-%!!!"LJ!!!!5!!*!,4AB&!!!!!BS!N!4&EJ-%!!!"L3!!!!5!!*!\r,4AB&!!!!!BN!N!4&EJ-%!!!"[3!!!!5!!*!,4AB&!!!!!Ed!N!4&EJ-%!!!"DJ!\r!!!5!!*!,4AB&!!!!!@S!N!4&EJ-%!!!"23!!!!5!!*!,4AB&!!!!!6d!N!4&EJ-\r%!!!"2!!!!!5!!*!,4AB&!!!!!6`!N!4&E`-%!!!"4J!!!!5!!*!,4AB&!!!!!8B\r!N!4&E`-%!!!"0`!!!!5!!*!,4AB&!!!!!6F!N!4&EJ-%!!!"1J!!!!5!!*!,4AB\r&!!!!!6S!N!4&E`-%!!!"5J!!!!5!!*!,4AB&!!!!!8S!N!4&E`-%!!!"13!!!!5\r!!*!,4AB&!!!!!6N!N!4&EJ-%!!!"4!!!!!5!!*!,4AB&!!!!!83!N!4&E`m%!!!\r"j`#3")!!N!G&D!!!8eP05!!!$5`!!!"T!*!9!3#3"JQ@!!!!%!!!#CN!!!"%!!!\r*kJ!!!%`!!!S"rj!%!!!+%!!!!!%!N!B+KJ!!!!J!!!Ui!!!!%!!!#Y$rN!3!!!V\rL!!%!!!!*!!!!#`%!N!3$!!%!N!B,"`!!!"`!!!XL!!!!-!!!#dF!!!")!!!,PJ!\r!!%`!!!Zbrj!%!!!-$J!#!!!!#3!!!!X"!*!%(`!!!!X!!!!(!*!&(J#3#!a&!!!\r!*!!!$'X!!!!m!!!-J`!!!%`!!!c2!!!!A!!!$2$rN!3!!!c`!!3!!!!3rrrrrJ%\r!N!3H!!!!%Irrrrd"!*!%(`!!!")!!!!$!!-!!!!i!!!!%rrrrr`!!`!!!$`!N!J\r0*`!!!#J!!!eD!!!!0!!!$A`!!!"3!!!0X`!!!&3!!!h*!!!!A!!!$H)!!!"S!!!\r1"`!!!'`!!!iH!!!!P!!!$S`!!!#N!!!1X[q3"!!!$V)!"!!!!"$rrrrq!3#3""d\r!!!!4rrrrr3%!N!3H!!!!)J!!!!-!!`!!!$J!!!!M!!!!"J#3"4m!!3#3"Jpk!!!\r!4!!!%0J!!!"F!!!4GJ!!!)3!!"'d!!!!P!!!%Gm!!!#N!!!5!3!!!+`!!")r!!!\r![!!!%U%!!!$3!!!5T2q3"!!!%V!!"`!!!#S!!!!$!3#3""X!!!!V!!!!!`%!N!3\rF!!!!,!!!!!X"!*!%(3!!!#d!!!!$!3#3""i!!!!Z!!!!#`#3"4m!!!![!!!!!3!\r$!!!!1!!!!$$rrrrl!!-!!!%i!!%!N!B6#3!!!"!!!"0X!!!!(!!!%j!!!!!!5!!\r!%q%!!!"3!!!8*`!!!&`!!"4,!!!!L!!!&*`!!!#3!!!!&1F!!!#F!!!9#`!!!-J\r!!"9F!!!!d!!!&A$rN!3!!"9l!!-!!!!Y!!!!!`!$!!!!1!!!!#`!!!!,!!-!!!!\rm!!!!,J!!!!X!N!8I!!%!N!B9S`!!!#3!!"B&!!!!,!!!&T3!!!"!!!!A63!!!&J\r!!"HY!!!!C!!!&mF!!!"`!!!AjJ!!!(`!!"Iq!!!!L!!!''%!!!#8!!!BH3!!!+!\r!!"L4!!!![!!!'4`!!!$3!!!CXJ!!!0`!!"R,!!!!k!!!'HS!!!$`!!!D!Iq3"!!\r!'Jd!!`!!!3`!!!"Q!3-!!!"B!!!"$3!!!!X!N!8H!!!!,J!!!!X!N!8I!!%!N!B\rD+`!!!!`!!"S`!!!!'!!!'Q`!!!!J!!!E6!!!!$J!!"Yj!!!!3!!!'j%!!!"-!!!\rEVrq3"!!!'p)!!!!"!*!'(+J!!!!S!!!Fj`!!!$!!!"f6rj!%!!!H!`!%!!!"%J!\r!!'B"!`!!!&J!!!%6rrrrf!%$!!!!A!!!!4Rrrrrf!3-!!!"J!!!"'J!!!'B"!`!\r!!'3!!3#3"Kik!!!!)!!!(S8!!!!S!!!I#2q3"!!!(fB!!`!!!4J!!!!#!3-!!!"\rB!!!"(3!!!'B"!`!!!&`!!!%H!!!!#`!$!!!!1!!"!*!'(k8!!!!J!!!Ij3!!!#J\r!!#"jrj!%!!!Je!!#!!!"'IrrrrB"!`!!!&J!!!%D!!!!CJ%$!!!!A!!"!*!')8B\r!!!!S!!!KK3!!!$!!!#)Xrj!%!!!LQJ!%!!!"'!!!!!)"!`!!!&J!!!%6rrrrf!%\r$!!!!A!!!!4Rrrrrf!3-!!!"J!!!"'J!!!'B"!`!!!'3!!3#3"L-4!!!!+!!!)e!\r!!!!`!!!Mp2q3"!!!*&`!"!!!!4)!!!"Q!3-!!!"B!!!"*Irrrp8"!`!!!&`!!!%\rarrrrpJ%$!!!!B!!!!4S!!!"Q!3-!!!"N!!%!N!BNe!!!!#J!!#86!!!!-!!!*EM\rrN!3!!#BL!!3!!!%5!!!!CJ%$!!!!@!!!!5Arrrr9!3-!!!"F!!!"-IrrrrB"!`!\r!!'!!!!%D!!!!CJ%$!!!!C!#3#!AV!!!!#!!!"IRrN!3!!!Aj!!%!!!%f!!!!D!%\r!N!3%!!%!N!B423!!!#J!!"&B!!!!1!!!%Bm!!!"F!!!4e3!!!(3!!")D!!!!K!!\r!%Nd!!!#B!!!5E3!!!+J!!"+D!!!!X!!!%V`!!!$-!!!5d`!!!13!!",M!!!!p!!\r!%dm!!!&-!!!68`!!!D!!!"1B!!!"X!!!%p-!!!(!!!!8$3!!!G!!!"4(!!!"i!!\r!&)-!!!(`!!!8[3!!!J!!!"6b!!!#%!!!&5`!!!)J!!!9A`!!!M!!!"@[!!!#2!!\r!&Fi!!!*-!!!@1J!!!R!!!"Cq!!!#I!!!&TB!!!+%!!!@cJ!!!VJ!!"Emrj!%!!!\rA*!!%!!!![J!!!'B"!*!%'3!!!9$rrrr(!!-!!!!m!!!"8`!!!!-!N!8I!!!"0J!\r!!!B!!`!!!%!!!3#3"KGM!!!!+!!!&i!!!!!i!!!AS!!!!%J!!"I-!!!!8!!!&qi\r!!!"X!!!B"3!!!+3!!"K)!!!!Y!!!',8!!!%-!!!BZ3!!!9J!!"Mr!!!"D!!!'6N\r!!!&i!!!CG3!!!BJ!!"Q[!!!"Q!!!'H3!!!'S!!!D(J!!!EJ!!"T4!!!"b!!!'VN\r!!!(X!!!Dr3!!!IJ!!"YC!!!#"!!!'h%!!!))!!!EM3!!!K!!!"Z[!!!#-!!!'ph\rrN!3!!"`4!!3!!!&9!!!!CJ%!N!3C!!!"'!!!!!)!N!8D!!!"8`!!!!-!N!8I!!!\r"0J!!!!B!!`!!!$J!!3#3"K`m!!!!&!!!($m!!!!N!!!FA`!!!$J!!"b-rj!%!!!\rFe!!"!!!"@2rrrmF"!`!!!&J!!3#3"Kcr!!!!*!!!(3)!!!!d!!!G)J!!!&J!!"e\rM!!!!G!!!(CN!!!#8!!!Gj!!!!+!!!"i"!!!!`!!!(L6rN!3!!"j+!!%!!!&E!!!\r!CJ%$!!!!I!!"!*!'(U!!!!!-!!!HS`!!!#J!!"kp!!!!0!!!(X`!!!!m!!!I!3!\r!!&J!!"p)!!!!D!!!(fm!!!"`!!!IJIq3"!!!(kJ!!3!!!@(rrrr'!!-!!!!i!!%\r!N!BJN!!!!!!`!!!JN`!!!%!!!##e!!!!6!!!)2)!!!"X!!!K9J!!!(`!!#&i!!!\r!P!!!)G`!!!#F!!!L#J!!!+`!!#)T!!!!j!!!)a3!!!%)!!!M3`!!!4!!!#0Urj!\r%!!!MeJ!%!!!"F!!!!'B"!*!%(!!!!A%!!!!$!3#3""d!!!&brrrra!#3"4m!!!&\r3rrrra`!$!!!!2!#3##DP!!!!(!!!*UJ!!!!X!!!Qd`!!!$J!!#ES!!!!C!!!*aI\rrN!3!!#FA!!%!!!'i!!!!!`%$!!!!@!#3##FX!!!!$!!!*bm!!!!S!!!R@J!!!$`\r!!#H$!!!!4!!!*j(rN!3!!#H4!!!!!3#3"LHc!!!!+!!!*r`!!!"3!!!SJ`!!!'3\r!!#Lp!!!!K!!!+2m!!!#8!!!T-`!!!+3!!#P4!!!![!!!+@`!!!$%!!!TPJ!!!1`\r!!#R$!!!"#!!!+HX!!!%3!!!U$`!!!5J!!#Sc!!!"-!!!+M`!!!%m!!!UA`!!!9J\r!!#UI!!!"F!!!+Y!!!!'-!!!V#J!!!D3!!#XK!!!"[!!!+i`!!!(J!!!Va3!!!HJ\r!!#[2rj!%!!!VrJ!$!!!"Lrrrrjm!!`!!!$J!!!(-!!!!!`#3"4m!!!(0!!!!CJ#\r3"4X!!3#3"La(!!!!+!!!,(-!!!!X!!!XK3!!!$!!!#bN!!!!5!!!,0X!!!"3!!!\rY!`!!!'J!!#dI!!!!H!!!,6-!!!"m!!!Y53!!!*`!!#f!!!!!U!!!,B8!!!#d!!!\rYPJ!!!,J!!#fRrj!%!!!YX`!%!!!![J!!!'B"!*!%(J!!!G!!!!"Q!3#3""`!!!(\r4!!!!C`#3"4m!!!(5rrrrRJ#3"4d!!3#3"Lhc!!!!*!!!,Jm!!!!S!!!Z)3!!!#`\r!!#iq!!!!@!!!,SB!!!"N!!!ZN!!!!!"`!!!ZS3!!!(3!!#kbrj!%!!!Z[J!$!!!\r"e3!!!!-"!*!%(3!!!G!!!!"Q!3#3""i!!!(5rrrrRJ#3"4m!!3#3"LqE!!!!-!!\r!,pF!!!"!!!![q3!!!&3!!$!`!!!!E!!!-&3!!!#!!!!`M`!!!*3!!$#lrj!%!!!\ra'!!#!!!![J!!!'B"!*!%(J!!!H2rrrqA!*!&(`!"!*!'-8N!!!!%!!!aB`!!!"`\r!!$'M!!!!-!!!-GS!!!!i!!!aq3!!!%`!!$)d!!!!B!!!-Q$rN!3!!$+p!!)!!!(\r3!!!!!`%!N!3$!!!"irrrrjF!N!8I!!$rN!3!!3!!!'S!!2rrrri!!3!!!!X!!2r\rrrrd!!3!!!!-!![rrrr`!!!!8!!!!%!!*!!!!&3!!!!X!N!F@!!!!#`!!!!)!!!!\rA!!!!#`!!!!3!!!!B!!!!#`!!!!B!!!!C!!!!"J!!!!J!!!!D!!!!"J!!!!N!!!!\rE!!!!#`!!!!S!!!!F!!!!#`!!!!`!!!!G!!!!#`!!!!i!!IrrrrF!!!!#!!!!!J!\r!!!X!![rrrrJ!!!!e!!!!#!!$!!!!02rrrrN!N!Ff!!!!#`!!!!3!!!!hrrrrp`!\r!!!B!!2rrrrN!!IrrrrJ!![rrrr-!!!"%!!!!&!!(!!!!43!!!!)!N!Fr!!!!"`!\r!!!3!!!"'!!!!"`!!!!8!!!"(!!!!#J!!!!B!!!")rj!%!!!!#!!!!%!!!!!#!!!\r!$!!!!%N!!!!#!!!!%!!"rrrrp!!!!"3!!!!8rrrrm`!#rrrrp3!!!$X!!!!J!!J\r!!!!m!!!!#J#3"cd!!!!(!!!!!J!!!$i!!!!'!!!!!`!!!$m!!!!#!!!!"!!!!%!\r!!!!'!!!!#!!!!%%!!!!'!!!!#3!!!%)!!!!+!!!!#J!!!%2rrrrd!!!!$!!!rrr\rrpJ!"rrrrp3!#rrrrqJ!!!$-!!!!b!"%!!!!drrrrq3#3"cB!!!!,!!!!"!!!!$J\r!!!!,!!!!"J!!!$N!!!"Q!!!!#!!!!$Vrrrrf!!!!$!!!!%S!!!!,!!!!%!!!!%X\r!!!"V!!!!%J!!!%`!!!!,!!!!&J!!!%d!!!!,!!!!'!!!!%i!!!!(!!!!'J!!!%m\r!!!!(!!!!'`!!!&!!!!"Q!!!!(!!!!&%!!!"Q!!!!)!!!!&)!!!!$!!!!*!!!!&-\r!!!!$!!!!+!!!!&3!!!!,!!!!,!!!!&8!!!!$!!!!,J!#rrrrm!!!!'3!!!!%!!)\r!!!"P!!!!#`#3"fB!!!!,!!!!!J!#rrrrm3!!!&m!!!!3!!8!!!"J!!!!!J#3"f%\r!!!!#!!!!"!!!!')!!!!+!!!!#!!!!'2rrrr`!!!!#J!!!'F!!!!,!!!!$J!#rrr\rrmJ!!!&F!!!"3!"J!!!!drrrrq3#3"cB!!!!,!!!!"!!!!$J!!!!,!!!!"J!!!$N\r!!!"Q!!!!#!!!!$Vrrrrf!!!!$!!!!%S!!!!,!!!!%!!!!%X!!!"V!!!!%J!!!%`\r!!!!,!!!!&J!!!&J!!!!,!!!!'!!!!&N!!!!(!!!!'J!!!&S!!!!(!!!!'`!!!&X\r!!!!,!!!!(!!!!&`!!!!(!!!!(J!!!&d!!!!(!!!!(`!!!&lrrrra!!!!)!!!!'J\r!!!!$!!!!-!!!!'N!!!!+!!!!0!!!!'S!!!!$!!!!0J!!!'X!!!!$!!!!1J!!!'`\r!!!!+!!!!2J!!!'d!!!!$!!!!3!!!!'i!!!!$!!!!4!!!!'m!!!!#!!!!5!!!!(!\r!!!!#!!!!6!!"rrrrlJ!!!#!!!!!%!!!!!`!#rrrrl`!!!()!!!"k!#!!!!!drrr\rrq3#3"cB!!!!,!!!!"!!!!$J!!!!,!!!!"J!!!$N!!!"Q!!!!#!!!!$Vrrrrf!!!\r!$!!!!%S!!!!,!!!!%!!!!%X!!!"V!!!!%J!!!%`!!!!,!!!!&J!!!(-!!!!$!!!\r!'!!!!(3!!!!,!!!!(!!!!(8!!!!#!!!!(J!!!(B!!!!#!!!!)J!!!(F!!!!,!!!\r!*J!!!(J!!!!+!!!!+!!!!(N!!!!+!!!!+J!!!(S!!!!+!!!!,!!!!(X!!!!+!!!\r!,J!!!(`!!!!#!!!!-!!!!(d!!!!#!!!!0!!!!(i!!!!+!!!!1!!!!(m!!!!#!!!\r!1J!!!)!!!!!+!!!!2J!!!)%!!!!+!!!!3!!!!))!!!!,!!!!3J!!!)-!!!!,!!!\r!4!!!!)3!!!!,!!!!4J!!!)8!!!!#!!!!5!!!!)B!!!!,!!!!6!!!!)F!!!!#!!!\r!6J!!!)J!!!!#!!!!8J!!!)N!!!!#!!!!9J!!!)VrrrrZ!!!!@J!#rrrrl3!!!)`\r!!!!d!")!!!!drrrrq3#3"cB!!!!,!!!!"!!!!$J!!!!,!!!!"J!!!$N!!!"Q!!!\r!#!!!!$Vrrrrf!!!!$!!!!%S!!!!,!!!!%!!!!%X!!!"V!!!!%J!!!%`!!!!,!!!\r!&J!!!)d!!!!,!!!!'!!!!)i!!!!,!!!!'J!!!)m!!!!,!!!!(!!!!*!!!!!!"`!\r!!"i!!!#4!!!!"`!!!"m!!!#5!!!!!`!!!#!!!!#6!!!!!`!!!#3!!!#8!!!!!`!\r!!#J!!!#9!!!!!`!!!#`!!!"S!!!!!`!!!$!!![rrrq`!!!#A!!!!*!!-!!!!02r\rrrrN!N!Ff!!!!#`!!!!3!!!!i!!!!#`!!!!B!!!!j!!!!CJ!!!!J!!!!krrrrpJ!\r!!!`!!!"+!!!!#`!!!"!!!!",!!!!D`!!!")!!!"-!!!!#`!!!"B!!!#B!!!!#`!\r!!"J!!!#C!!!!#`!!!"S!!!#D!!!!D`!!!"`!!!#E!!!!!`!!!#!!![rrrqX!!!#\rG!!!!0!!3!!!!02rrrrN!N!Ff!!!!#`!!!!3!!!!i!!!!#`!!!!B!!!!j!!!!CJ!\r!!!J!!!!krrrrpJ!!!!`!!!"+!!!!#`!!!"!!!!",!!!!D`!!!")!!!"-!!!!#`!\r!!"B!!!#H!!!!#`!!!"J!!!#I!!!!#`!!!"S!!!#J!!!!D`!!!"`!!!#K!!!!D`!\r!!#!!!!#L!!!!!`!!!#3!!!#M!!!!!`!!!#J!!!#N!!!!!`!!!#`!!!"S!!!!!`!\r!!$!!![rrrqS!!!#Q!!!!0!!4!!!!02rrrrN!N!Ff!!!!#`!!!!3!!!!i!!!!#`!\r!!!B!!!!j!!!!CJ!!!!J!!!!krrrrpJ!!!!`!!!"+!!!!#`!!!"!!!!",!!!!D`!\r!!")!!!"-!!!!#`!!!"B!!!#R!!!!#`!!!"J!!!#S!!!!#`!!!"S!!!#T!!!!!`!\r!!"`!!!#U!!!!#`!!!#!!!!#V!!!!#`!!!#)!!!#X!!!!!`!!!#3!!!#Y!!!!!`!\r!!#J!!!#Z!!!!!`!!!#`!!!#[!!!!!`!!!$!!![rrrqN!!!#a!!!!1J!4!!!!02r\rrrrN!N!Ff!!!!#`!!!!3!!!!i!!!!#`!!!!B!!!!j!!!!CJ!!!!J!!!!krrrrpJ!\r!!!`!!!"+!!!!#`!!!"!!!!",!!!!D`!!!")!!!"-!!!!#`!!!"B!!!#M!!!!!`!\r!!"J!!!#b!!!!D`!!!"`!!!#N!!!!!`!!!#!!!!#c!!!!!`!!!#3!!!#d!!!!!`!\r!!#J!!!#e!!!!!`!!!#`!!!#f!!!!!`!!!$!!!!#h!!!!#`!!!$3!!!#i!!!!!`!\r!!$B!![rrrqB!!!#m!!!!4J!$!!!!,!!!!!X!N!Hp!!!!!`!!!!)!!!#q!!!!!3!\r!!!B!!2rrrqF!!IrrrqB!!Irrrq%!!!!'!!!!!J!!!!X!![rrrq)!!!$)!!!!%!!\r'!!!!b3!!!!X!N!I+rrrri3!!!!)!!!$,!!!!"`!!!!J!!!$-!!!!"`!!!!N!!!$\r0!!!!#`!!!!S!!!$1!!!!!`!!!!`!![rrrq-!!!$&!!!!E!!F!!!!02rrrrN!N!F\rf!!!!#`!!!!3!!!!i!!!!#`!!!!B!!!!j!!!!CJ!!!!J!!!!krrrrpJ!!!!`!!!"\r+!!!!#`!!!"!!!!",!!!!D`!!!")!!!"-!!!!#`!!!"B!!!"B!!!!#`!!!"J!!!"\rC!!!!"`!!!"S!!!"D!!!!"`!!!"X!!!"E!!!!#`!!!"`!!!"F!!!!"`!!!"i!!!#\r4!!!!"`!!!"m!!!"Hrrrrm3!!!#!!!!"S!!!!!`!!!$!!!!"T!!!!#J!!!$3!!!"\rU!!!!!`!!!$B!!!"V!!!!!`!!!$S!!!"X!!!!#J!!!$i!!!"Y!!!!!`!!!%!!!!"\rZ!!!!!`!!!%3!!!"[!!!!!J!!!%J!!!"`!!!!!J!!!%`!!!$'!!!!!J!!!&!!!!$\r(rrrriJ!!!&3!!!$2!!!!!`!!!'3!!!$3!!!!!`!!!'J!![rrrpi!!!$@!!!!#!!\r%!!!!e`!!!!X!N!IB!!!!#`!!!!)!!!$C!!!!#`!!!!3!!!$D!!!!#`!!!!B!![r\rrrpm!!!$8!!!!%!!%!!!!eIrrrpi!N!IE!!!!#J!!!!J!!!$Frrrrm!!!!!S!!!$\rG!!!!#`!!!!i!!Irrrpd!!!!5!!!!!J!!!!X!![rrrp`!!!$N!!!!%!!'!!!!jIr\rrrr!!N!IQ!!!!!`!!!!3!!!$R!!!!"`!!!!J!!!$S!!!!"`!!!!N!!!$T!!!!#`!\r!!!S!!!$U!!!!!`!!!!`!![rrrq!!!!$5!!!!D!!A!!!!02rrrrN!N!Ff!!!!#`!\r!!!3!!!!i!!!!#`!!!!B!!!!j!!!!CJ!!!!J!!!!krrrrpJ!!!!`!!!"+!!!!#`!\r!!"!!!!",!!!!D`!!!")!!!"-!!!!#`!!!"B!!!"B!!!!#`!!!"J!!!"C!!!!"`!\r!!"S!!!"D!!!!"`!!!"X!!!"E!!!!#`!!!"`!!!"F!!!!"`!!!"i!!!#4!!!!"`!\r!!"m!!!$6rrrrh`!!!#!!!!$H!!!!!`!!!$!!!!$I!!!!#J!!!$3!!!#0rrrrh3!\r!!$B!!!$J!!!!!J!!!%J!!!$K!!!!!J!!!%`!!!$L!!!!!J!!!&!!!!$Mrrrrh!!\r!!&3!!!$V!!!!!`!!!'3!![rrrq3!!!$$!!!!E!!#!!!!a2rrrq-!N!I4rrrri!#\r3"[rrrq8!!Irrrq3!!IrrrpS!!!!-!!!!!J!!!!X!![rrrpX!!!$[!!!!%!!#!!!\r!m!!!!!-!N!IarrrrfJ!!!!3!![rrrqJ!!!#k!!!!6!!5!!!!02rrrrN!N!Ff!!!\r!#`!!!!3!!!!i!!!!#`!!!!B!!!!j!!!!CJ!!!!J!!!!krrrrpJ!!!!`!!!"+!!!\r!#`!!!"!!!!",!!!!D`!!!")!!!"-!!!!#`!!!"B!!!#lrrrrj`!!!"J!!!#r!!!\r!!`!!!"`!!!$!!!!!!`!!!#!!!!$"!!!!!`!!!#3!!!$#rrrrj3!!!#J!!!$Xrrr\rrj3!!!#`!!!$Y!!!!!`!!!$!!!!$Zrrrrf`!!!$3!!!$b!!!!CJ!!!%3!!!$c!!!\r!!`!!!%J!![rrrpN!!!$e!!!!4!!6!!!!02rrrrN!N!Ff!!!!#`!!!!3!!!!i!!!\r!#`!!!!B!!!!j!!!!CJ!!!!J!!!!krrrrpJ!!!!`!!!"+!!!!#`!!!"!!!!",!!!\r!D`!!!")!!!"-!!!!#`!!!"B!!!$f!!!!!`!!!"J!!!$h!!!!!`!!!"`!!!$i!!!\r!CJ!!!#!!!!$j!!!!!`!!!#3!!!$k!!!!!`!!!#J!!!$l!!!!!`!!!#`!!!$m!!!\r!!`!!!$!!!!$p!!!!!`!!!$3!!!$q!!!!!`!!!$J!!!$r!!!!!`!!!$`!!!%!N!3\r$!!!!3!!#rrrrq`!!!$%!!!"k!!S!!!!brrrrqJ#3"eErrrrb!*!(FIrrrqm!N!H\r,rrrrl3#3"jErrrrX!*!(R2rrrqX!N!HPrrrrkJ#3"l$rrrrT!*!(ZIrrrqJ!N!I\rdrrrrf3#3"3(rrrr@!!!!%!!!!!3!!!!#!!,rrrrA!!!"&!!!!43!"!!!!48!!!!\r$!*!'!4B!!!!3!!!!"!!!!4F!!!!(!!!"!`!!!4Mrrrr@!!!""!!!rrrrf!!"rrr\rre`!"rrrrdJ!!!"!!!!!%!!!!!J!"rrrrd!!!!"i!!!!"!!!!"`!"rrrrc`!!!"i\r!!!!"!!!!"`!#rrrrd3!!!5S!!!!m!!)!!!%Vrrrrd!#3"J%Xrrrrc`!!!"i!!Ir\rrrmd!!!$r!!!!!3!!!!F!![rrrmi!!!%Z!!!"!J!#!!!",`!!!!S!N!B"-2rrrmd\r!!!!#!!,rrrr6!!!"+!!!!3)!!`!!!4Mrrrr5!*!'!5Rrrrr4!*!'!5hrrrr1!*!\r&![rrrp3!!!%Q!!!#"J!%!!!"&3!!!!-!N!B"&J!!!"!!!!!%!!!"&`!!!!F!!!%\r$!!!"*rrrrp-!!!%%!!$rrrr9!!(rrrr8!!(rrrr-!!!!"!!!!!3!!!"Q!!$rrrr\r+!!%!!!!#!!(rrrr,!!!!&!!!!!6rrrr+!!,rrrr*!!!"2J!!!"3!"3!!!6m!!!"\rQ!*!'!8!!!!"R!!!!"!!!!8%!!!!$!!!!#!!!!8)!!!!$!!!!$!!!!8-!!!"R!!!\r!%!!"rrrrb!!!!!S!!!!"!!!!"`!#rrrra`!!!9%!!!!%!!%!!!&5!!!!!J#3"3,\rrrrr'!!!"BJ!!!#3!$!!!!$6rrrrj!*!(0J!!!!X!!!!%!!!!1!!!!!X!!!!'!!!\r!13!!!'B!!!!)!!!!1[rrrrB!!!!-!!!!5J!!!!X!!!!3!!!!5`!!!'X!!!!5!!!\r!6!!!!!X!!!!@!!!"B`!!!!X!!!!B!!!"C!!!!!X!!!!D!!!"C3!!!!)!!!!F!!!\r"CJ!!!!-!!!!J!!(rrrr&!!!!$!!!!!%!!!!(!!$rrrr%!!(rrrr*!!(rrrr$!!!\r!%3!!!!%!!!!(!!(rrrr#!!!!%`!!!!%!!!!(!!(rrrr"!!!!%3!!!!%!!!!(!!(\rrrrr!!!!!%J!!!!%!!!!(!!(rrrqr!!!!%J!!!!%!!!!(!!(rrrqq!!!!%!!!!!%\r!!!!(!!(rrrqp!!!!%3!!!!%!!!!(!!(rrrqm!!!!%!!!!!%!!!!(!!(rrrql!!!\r!%3!!!!%!!!!(!!(rrrqk!!!!%`!!!!%!!!!(!!(rrrqj!!!!$`!!!!%!!!!(!!(\rrrrqi!!!!%3!!!!%!!!!(!!(rrrqh!!!!%!!!!!%!!!!(!!(rrrqf!!!!%!!!!!%\r!!!!(!!(rrrqe!!!!%3!!!!%!!!!(!!(rrrqd!!!!%J!!!!%!!!!(!!(rrrqc!!!\r!%`!!!!%!!!!(!!(rrrqb!!!!%3!!!!%!!!!(!!(rrrqa!!!!%3!!!!%!!!!(!!(\rrrrq`!!!!%!!!!!%!!!!(!!(rrrq[!!!!%3!!!!%!!!!(!!(rrrqZ!!!!@!!!!!3\r!!!"Q!!(rrrqY!!!!J!!!!!%!!!!(!!,rrrqX!!!"M!!!!"!!"!!!!Bd!!!"Q!*!\r'!Bi!!!"R!!!!"!!!!Bm!!!!$!!!!#!!!!C!!!!!!CJ!!!!`!![rrrkN!!!'9!!!\r!"!!'!!!"PJ!#(alrN!3!!!'A!!)G'rq3"!!!!CJ!!KSCrj!%!!!"Q3!#'"ErN!3\r!!!'D!!)9&2q3"!!!!CX!!K-6rj!%!!,rrrqS!!!"R3!!!!J!"!!!!Ci!!KmGrj!\r%!!!"R`!#("crN!3!!!'J!!!!"J!!!!3!!!'K!!!!"J!!!!8!!IrrrkF!!!!#!!!\r!!3!!!!B!!IrrrkB!!!!%!!!!!J!!!!S!![rrrkS!!!'5!!!!6!!8!!!"N`!!!!)\r!N!B"P2rrrkN!!!!%!!!"R2rrrkJ!!!!)!!!"SJ!!!!B!!!!3!!!"S`!!!!B!!!!\r4!!!"T2rrrkF!!!!5!!!"TIrrrkB!!!!8!!!"TJ!!!!)!!!!B!!!"T`!!!'J!!!!\rF!!!"U!!!!!)!!!!J!!!"U3!!!'J!!!!N!!!"UJ!!!!)!!!!S!!!"U`!!!!)!!!!\rX!!!"V!!!!!)!!!!`!!!"V3!!!!)!!!!d!!!"V[q3"!!!!$J!!!'[rj!%!!!!2!!\r!!E$rN!3!!!"!!!!"XIq3"!!!!%3!!!'brj!%!!!!5!!!rrrrU`!"rrrrUJ!"rrr\rrT3!!!#!!!!!%!!!!CJ!"rrrrT!!!!!i!!!!"!!!!"J!"rrrrS`!!!!)!!!!"!!!\r!"`!"rrrrSJ!!!!-!!!!"!!!!"`!"rrrrS3!!!!-!!!!"!!!!"`!"rrrrS!!!!!-\r!!!!"!!!!"`!#rrrrR`!!!FS!!!"'!!%!!!(,rrrrjJ#3"[rrrji!!Irrrk`!!Ir\rrrjd!!!!%!!!!!3!!!!F!!Irrrj`!!!!%!!!!!3!!!!F!![rrrjS!!!(D!!!!$!!\r$!!!"f`!!!'B!N!B"h!!!!'F!!!!%!!!"h3!!!!-!!!!)!!(rrrqE!!!!H!!!!!c\rrrrqD!!(rrrqC!!!!"!!!!!%!!!!(!!(rrrqB!!!!"!!!!!%!!!!(!!$rrrqA!!(\rrrrqD!I"%CACPE'p`1N0[C'9ABA*bD@pb)&"bEb!d1NePG(*[Gf9bDh-J3fpNC9G\rKFR*TEh)k6@&M6e-J8h9`F'pbG$T)C@&NCA*c1P0jFh4PE5"&H(4bBA-J5'9KC'9\rbFcT0B@083e!J5'9KC'9bFcTNER)ZB`!%9fG%6P*$Ef4P5'jNE!!$6QG%6P*$Ef4\rP8(4b!!$Q9A4TE%eKD@i!"*XZ6R9Y9'p[E'*[H&4bBA"cAep'GJ!!Bbj14f9d9(*\rKF%&NC(*PFh-!"&j!1$%h!!!5,NGPG&4bBA"8HA"PAep'F`!(`(4SC94bBA!!"dN\rZ9(*KF%9iDA0dFepI4R-!!fYdD'98FQ&`9(P`C3!%I8!i-MB!"ddZ4f9d8hPcG'9\rY4QpXC'9bAep'8(03E!!%)#j6HA0&ERCTFQpZF`!#R5j(CA4A4%PZCQm!!"0f8Q9\rQ6R9Y8!!'p@4TFNP%8!!!DRGN8(*[BdP%!!5UD@jQE`!"Ie0jFd9ZGP*PB`!(Hf9\rZGQPbEfjc9Q9bFfP[EJ!$"@eKBfKTEQ98HA"P!!A2FhPcG'9Y9Q9bFfP[EJ!"BA"\rbEf0PFh0[FJ!'H'KKFdC393!#ifKKFd0[E'pb883!"%9VCAP#Ef&bC&4jF'8!"BC\rKG%4bGR*@CA*c6R9Y!!)[FhPc9P*PCNjeE3!%Pd!i-c!!"mdZ4f9d3e"KEQ9X4Qp\rXC'9bAep'8(03E!!!-5j(CA0dB@ad!!1",NCTEQ4'EfaNCA)!"lGQC@&dGA*P!!4\r)D'&c4QpXC'9b6@Gb!!5i3$Jd-3!$A5j6C@&bBfK'EfaNCA*'Eh*%6P*3Aep'E'a\rcE!!&cbj)6h"PEP*PFdCTE'8!"j8Z4f9d5@jN8Q9cEh9bBf8!"9FZ3fa[Ff95CA0\r'D@aP!!"b,P"#5%GPG%C*EQC[8hPZB`!#QR4KFQGPG&4jF'8!"9PdBA*RCA4$FQ9\rKG'pb!!FHGP*PCNjeE3!&,@4TFNP%!!BrFQ9QER9Y!!#TCQPXC@jKE@8!!M9QD3!\r'YNK3BA*KE8*XEf0V8Q9M!!FYD@p3BA*KE3!!5dK*6e"KFQ&Y!!8EF8aTEQX!"Ap\r44@aPE3!&QR&8HA"P!!@1F84KG'%!"M9TEe4bBA!!!G9TEd0YC%&NC()!"0YTEd0\r[EA"XCA4TEfi!!Ep5Eh9dD@jP4'9cBh*TF(4[FJ!(*fG[6@PiC@40Ef4P9(*KF!!\r(4(CPFR0TEfi!"JKbEh9dD@jP4'9cBh*TF(4[FNCXB@Gc!!&@FQ9cCA*fC@3a!!&\rAFQ9cCA*fC@3b!!4hFf9XC@0dEh**EQC[!!3UFQpeG'PZC80[G@jd!!E`FQpeG'P\rZC9*PBfpbC(-!"4p5Eh9dD@jP8Q9MEh*N!!#rF(*[BdPZCQm!!p"*8d%!"2YbEh9\rdD@jP4QaKCh-!"S4`FQpM4'9cBh*TF(4[FJ!!eh0PE'9MG'pb!!"rD@p5CA0eE(3\r!!GCTEdjKE@93G()!!@aTEeC5C@C1G@d!!(TTEe*PCNjeE3!"fQP[9Q9bFdjeE3!\r"bfP[8'9bEA0cEJ!'afP[6@PcB`!!2@P[3R9QCQ9b!!+UD@p5CA&$Eh9ZG!!#C@P\r[3@0d3fpeER3!!@4TEe"[Fde[C'8!!e*TEe"[FdpQCR0PG!!"0fCTE'93BA*KE3!\r##NK'D@aP8'&bB@d!!@KTEdC5C@C1G@d!!M"TEdC@CA*c6R9Y!!GSCQPXE'9b-3!\r$@'P[4N4TFNPZC'9i!!)`D@p'E%&dG(*TBJ!$!QP[4Qa@CA*c6R9Y!!64D@p'E%C\rZC(**EQC[!!9q4NPZCQm!"QCQC&4jF'8!!@YQC%0bC@&dEh)!"laQC%CXB@Gc!!)\r'CQ4-Ef0KG'P[EJ!&T&"[D@jd!!&fGJ!"D'J!"VCQC%CXC()!"mKTEd4TFNP%!!%\r2D@p'E&0d3QaV!!(rD@p'E%aR6'9Z!!(-D@p'E&"j6'9Z!!,TD@p'E&*6G%*XD`!\r#3'P[4Qa56'G-C@i!!STTEdCX8P"j6'9Z!!'pD@p'E%0b4'&d!!(AD@p'E%eN4'&\rd!!1lGQpXG@eP8'&bB@d!"(C)9QpXG@eP8'&bB@d!"fPQD@aXCA)b!!*MD@p@Efa\r*EQ4PH!!"`fP[9N0b4'&dC3!!f@P[9Nac6@pN!!HpD@p@3A4bBJ!!K@P[9NjY4Qa\rc!!'0D@p@3QPd6@&`!!,#D@p"E'a[Be"dFJ!$,@P[9NjY3@a#E'Yc!!1JD@p@3@a\r#E'Y6DAS!!I"TEeC$E("6DAS!!*&TEd&X3Qa6G!!#BfP[9NjiG%01583!!&*TEeC\r'FN*XD`!#k'P[9P0TCeG[FQ3!!NCTEeC%FRC*EQC[!!*LD@p@4&*PCNjeE3!(I'P\r[9NC6583!"i4TEeC#De9`!!%!D@p@8f9a6R9Y!!"3D@p@9h*$ER3!!IjTEeC'D@a\r$ER3!!3&TEeC%DA*$ER3!!`pTEeC'EQ4b5@jQE`!$'f&MBf9cFe"KFQ&Y!!1F3@0\rMCA0c8'&bB@d!"fTQD@aXCA)c!!1(D@p%C@jj6@pNCA-!"fYQD@aXCA)d!!GXCQP\rXE'9b03!!e'P[3809Ff9b!!GYCQPXE'9b0J!$[@P[3802GfjPFNP%!!2"D@p"3dG\rbEh9`583!!NKTEd&$3@0MCA0c!!#rEf*U8'&bB@d!!-"2BQT3BA*KE3!(EQCTE'a\rPFMF!!C0TEdpLDP4jF'8!"29TEdpLDNjKE@93G()!"h*TEdpLDNP%!!&4Bfp`H9"\rKFQ&Y!!&b3fp`H9"KFQ&Y!!3KD@p%Fh4@8Q9Q6R9Y!!G[CQPXE'9b1!!"HQP[6Q9\rh6Q&YC3!#DQP[3fp`H8jKE@8!!QGTEdjPGd4TFNP%!!""CQPXE'9b-63!!%*QD@a\rXCA)a03!(ZAGN8'&bB@d!"q4A4&"KFQ&Y!!G`CQPXE'9b13!")'P[9d4*EQ4PH!!\r#cQP[9d43FQpM583!!b9TEeG%9P*PCNjeE3!!2@CTE'aPFM%`!!!qCQPXE'9b-6%\r!!$pQD@aXCA)a-J!!3'CTE'aPFM%c!!&cD@pA4%4TFNP%!!!XCQPN8'&bB@d!!,&\r'5843BA*KE3!&4'P[4'9cG%jKE@93G()!!jTTEd4PFh4%DA**4!!!3fCTE'aPFM%\rf!!"%CQPXE'9b-6F!!QKTEe0bBd4TFNP%!!"&CQPXE'9b-6J!!!*TEdCTE'9*4!!\r(b'0c8'&bB@d!"qp$8e"KFQ&Y!!*aD@p0BA4MD&"dFJ!'#%C68h"PB`!&bR"KFNP\r%!!5VEQ&YC3!(!'P[8Q9a6@&dBfK$Eh9ZG!!(d'P[3@0d6@&dBfK$Eh9ZG!!%kQP\r[8f9KFQ0S3QPdF`!&b'P[8f9KFQ0S5@jQEc%!!ZK$5@jQEe"#8Q9M!!'ZD%CTE'9\r*EQC[!!&05%CTE'9*EQC[!!&*D@p'E%*V4'&d!!9KD@p'E&K'EQ4b5@jQE`!'H%C\rB5@jQE`!!SfCN5@0[ENP%!!!fCQ49ER9cC@3!!-PQC&0MFQP`G!!!+'CN@%CXB@G\rc!!'5CQ4$EfeYC@jd!!(9CQ43GA4"Gf&j!!%,D@p'E&"KFNP%!!*4D@p'E%0XF&0\rTHJ!(H@4TFNPZCQm!"k&%DA**EQC[!!)5D@p%FP9cFPGNF`!&hN4*EQC[!!B#CR*\r5C@0d!!4r8Q9MG!!$,h4[F!!%$'aPCR3!"L*LEh4dEfd!"GCbD@GSG!!(CfCb4Qa\rKCh-!!PKQFNa[Bf&dD@pZ!!C6CR*@D@9h!!(SD@p%FN4TFNP%!!'1D@p%FNjY4Qa\rc!!(AD@p%FN0b4'&d!!'0D@p%FNeN4'&d!!(MD@p%FN*V4'&d!!6!D@p%FNCZC(*\r*EQC[!!DN4&K*EQC[!!#fCR*6Bh*[E'`!!maQFNp`C@j$D'&TEJ!!4QCb8f0bDA"\rd!!#ZCR*B4QaKCh-!!F*QFN0[E@ePER3!!BPQFP"eG%&hBAN!!54TEd4b8'&b583\r!"FPTEe0PBA*MD%PZCQmb!!6SD@p6C@&bBfK8D@eP!!A6D@p$BA43Eh0TG'P[EJ!\r'CN0KG&"[FfPdD@pZ8Q9M!!)kD@jTG'PKE'PkC3!%TA"bDAB!!`TTEdp`G%*eCQC\rPFJ!%+@P[6h"d3R9Q8fPkC3!!2@C[FQ9TCfj3FQPf8'&bB@d!!&&'Eh*PD@GZ8(*\rTGP"KFQ&Y!!+kD@p'D@aXCA)b-3!#ZfP[4QPXE'9b-M)!!hTTEdC[FQ9TCfj3FQP\rf3R9QCQ9b!!9fD@p'Eh*PD@GZ8(*TGN&MG%0[G@jd!!9hD@p'Eh*PD@GZ8(*TGP*\rPF80[G@jd!!+mD@p'D@aXCA)b-`!#3@P[4QpbC@PREP"bDAC%DA**4!!#qQP[4Qp\rbC@PREP"bDAC*EQC[-3!#qfP[4QpbC@PREP"bDAC*EQC[-J!#r'P[4QpbC@PREP"\rbDAC*EQC[-`!#r@P[4QpbC@PREP"bDAC*EQC[0!!%fN!i06-!"Q8Z6h"PENpeFP*\r'Aep'GJ!%q%!i0M%!"IBZ6h"PEP*PFfpXGQ9b!!&Y,P*PFd9bFQpb!!GX,N4PG'&\rMD&*PFfpeFQ0P!!$`,Ne[GQ9)5'N!"SJZ5%a[BfX!![%Z3f&XE&9ZDACPFR0KE&"\rbEf-!!'`Z5&9ZE'pMD`!'`bj%DA0`Eh0P5'&ZC'aP!!#jCQPXC8jKE@8!!V&bB`!\r%'%!i0c%!"KNZ3fa[Ff95CA0[E(CPFJ!%(%!i0c8!!ZJZ8h4b9'p"C'4b!!$UD'p\rcG%jKE@8!!BPbG'j6G(*eBh3!!1&SEh0d5@jQE`!(2(*dEN0[C'8!"H9MEQ&YC3!\r'Z@CTE'aPFJ!%3'&NC()!!TpbCA0eE(4`FQpM!!-UGA0PFN4KG'&3G()!"#"!1$F\rj!!+e,N&NC(*8Ee0dFJ!(E@&NC(*6G()!!c9PFR)!"$Y!1$Jc!!*C,N9ZG@e$B@0\rSC3!%2d!i1$F!!j!!,N&NC(*8EdjKE@8!"&P!1$Na!!CU,NK*EQC[!!5ZFQ9dGA*\rZ8Q9M8(4b!!(BFQ9dGA*Z8Q9M!!@ZFQ4KG'%!"K0!BfaKFh-N1$!j4e9658jPG%4\r#Af0`!!8XD'PZCQm!!%0)5@jQEe*PB`!(J'0`G94jF'8!"QP[Fe4jF'8!!L9YH!!\r&f8eB8Q9M!!+NF(*PCQ9bC@jMC3!!rQ9iBfKKEQGP!!,[FQ9cG@ad8(*[B`!%A8!\ri168!"cmZ69K*EQC[!!4K3$Jj13!!CLj%6P*%EfjP!!3LC'pZC3!!m(9%6P*%Efj\rP!!I94%j54'pZC3!(EQKICA*bEQm!"`*YB@0)Eh0d!!'dB@aTBA03G(*c!!#IB@4\rNFP"dFR-!!29eEQPi5'pcG!!(-@K[Fh4PER3!"TCSAfjKE@8!!FGSAf&XD@&cCA-\r!!VpSAf&NC(*dHA"P!!"eD&pXC@jRG'J!!aPSAf&NC(*IE'PcG!!%`N!j0$F!"L-\rZCf9dD'pcG'*jEQ&YC3!!F8G98dP6F'PZ!!Gm,R0dFQ0YF!!#@#jRCA4SEh0dD@3\r!"RNZCf9dD'pcG'*jB@4NFJ!$$%P14946Ef0VCA4c!!GP,P*PFfpXGQ9bAema0NP\r14946Ef0VCA4%EfeKD@j'GJ!$@Lj(990*3fKPBfY"E'&bE9pI4RB!!j3ZAep`G(*\rICfaeC3!$V5j(990*Af9bFQpb!!Hp,R0dFQaPEJ!'HQP`B@4NFJ!(E@PZAf&NC()\r!"RecAf&NC()!!@PT!!6$3$Nd1!!&@'&NC(*3!!4"3$Ni03!#'5jTEQ9dAfjdEf%\r!"YTTEQ&NC()!"%9!16Jj!!,q,QPZCA4IB@4NFJ!(Gf&NC(*PFh-!"AK!-6!`03!\r%-(0)Eh0d583N-6!`0J!&HN!a-$!h!!91,N4bDACPFPpI-6C*6N988fpMDf9d4'p\rYB@PZ4RB!"PmZ8%*$EfjdFQpX8hPZB`!$J("LFJ!"d%GPG%&NC(*3BA*KE8*XEf0\rV!!%@D@p$8Q9Q6R9Y!!DUBh0$Ef4P!!+9Eh9b3@4NFQ9cF`!#@QpeFNjPG%eKFfX\r!"CK!-6!a03!'FA0)Eh0d6Q&YC53a-$%f!!@D3$%`-6F!"G9!-6!c-J!%cLjRCA4\rSEh0dEQ&YC3!!C#jcF(*TER4Q!!-X,PpIERGKAep'9@`!"q8ZFh4bBh"j!!"T,R0\rdFQjMF(N!!"eYB@0SEQ&YC3!'pf*eCQaPEJ!#I@K`!!A@3$%`-c-!"GG!-6!c0!!\r&f%!a-$-e!!AC3$%`-cB!"GT!-6!c0`!&fd!a-$-i!!AF3$%`-cN!"I0!-6!d-!!\r&p%!a-$3a!!Ae3$%`0$)!"IC!-6!d-`!&pd!a-$3d!!Ai3$%`0$8!"IP!-6!d0J!\r&qN!a-$3h!!Al3$%`0$J!"Ia!-6!d13!&%d!a-$8`!!883$%`06%!"49!-6!e-J!\r&&N!a-$8c!!8A3$%`063!!1YcCA*fE'PcG!!!1h0PFRCXD@jP!!36Ff9bGJ!(3(0\rPFRCPER3!"JGcAfjKE@8!!30cAf&XD@&cCA-!"[4cAh"[FR3!"i0cAh"bEh4[!!H\rmFf9bGQCTE!!&E&p'58a&!!BKD'&ZC'aP!!4KE@pNC3!%6&pICQPXC9pYEf4PF`!\r"['p`C@jIE@pNC3!(P@P[Afe[C'8!!q&LG@CQCA*IE@pNC3!"[QCTE'9IDfPZC!!\r!GfCTE'9IEh*TC@jdBA4TEfi!!44LD@jKFRPID@m!"FTcG'&dC3!%pepICQPXC9p\rcG'&dC3!!V'P[Ah0dBA4P!!-5CR*PC9pLG@CQCA)!!mPPEfB!"44PFR*[FJ!$['0\rSBA*IBR9QCQ9b!!6GBfKKFPpLG@CQCA*IEhCPFQCXEhF!"84eEQGPG'0IBR9QCQ9\rb!!C*G@jRCA4hBepLG@CQCA)!!(C`Eh0TG'P[EJ!'!f*eCQCPFJ!$Ef*eCQCPFPp\rcDATP!!*qBR9QCQ9bAh"dFJ!#U'*eCQCPFPpXC@i!!2GLG@CQCA*IB@aTCfjYC@j\rd!!$(Ff&fC@4IBR9QCQ9bAfaPEJ!#hQ*eCQCPFPp`Eh-!"D&`Eh0TG'P[EPp`FQp\rM!!(aFQ9KC&p`FQpM!!)EGh*TG'9IF(*[B`!#Y'0XEh0PAh"bEf-!!6KTC'aPAh"\rbEf-!"dYcCA*fF(4b!!'6Ff9bGQ&XD@&c!!!pFf9bGR0dBAN!!cJZFf9dFf9bGQ9\rZG!!(*bjbCAGTEQ3!!(0cG'&jEh"PEJ!&(%!a-$8j!!1L,Q9ZC(0PFRCPER3!"bm\rZCQ0XEh0P!!8i3$%`0M3!"Ce!-6!j13!&Pd!a-6!`!!@B3$%a-$%!"CP!-6%`-J!\r&QN!a-6!c!!2Y,QGPG(0PFRCPER3!!E8Z8%acG(*MF(N!!-mZ4R9XE&"KG'KIAcP\r84QPXC90`C@0$4RB!"N)ZCQp`C@i!"YdZCQGPG(-!!(NZFh4bF'*bD`!('bjcG(*\rdEfX!"6FZBA4[D3!"He4'D@aP8h"PB`!(*54'8e0`C@-!!UKKE'PKFf0[G@jd!!&\r`F!!&Qd!a-6!d!!D',QGPG(0PFRCLH@jKE@8!"GY`FQpdE`!#Q'&X!!1hC@jd!!A\rF3$%a-M8!"SXZCf9dFf9bGQ*jF'pbG!!%Q("[FR3!"Ij!-6%c0`!$VR4MF!!$XR9\rNF!!"+h"bEh4[C@jdF`!!aA"bEh4[C@jd!!B&F&pZB@eP!!(HF&pKE'PKFf9c!!G\r"F&p`FQpdE`!'Ih"bEh4[C@jdAf0[G@jd!!8F3$%a0$8!"4e!-6%d0J!(kLjRCA4\r`FQpdEf*jEQ&YC3!&m@9bFQj[!!*cF'8!"4j!-6%d0`!"DbjRCA4`FQpdEf*jER9\rYBQ9b!!$UCf9dF(*[G'pLH@jeE@*PFJ!$IP423`!'K@GPG("bEh4[BRPZB@eP!!9\rkCf9dFf9bGQ*jF'pbG!!&N@GPG(0PFRCLH@jKE@8!!J0RCA4cCA*fC@jd!!)lC@j\rNFf9bGQ9ZG!!#L(0PG(0PFRCPER3!!b"RCA4SEh0dEQ&YC3!"j@GPG'K[Fh4TC!!\r"4@PZCA4IB@4NFJ!"A'PZCA4IER4[B3!&XQGPG'K[Fh4LH@&NC()!"@"RCA4SEh0\rdBRPZB@eP!!DU69K*EQC[!!8H5%PZCQm!!NC"C'4b9'p1B@eP!!(Q4@jeE80KBfK\rP!!'V3@4NFP4[8h4b!!'28h4b9'p"C'4b!!AQ3fa[Ff95CA0[E(CPFJ!%f%p`C@j\r5CA0[E(CPFJ!&%Np`C@j2GA*54PpI4RB!!Ve6C@&bBfK'EfaNCA*'Eh*%6P*3Aep\r'E'acE!!'M%GPG%03B@jPE%C[E'4PFPpI4P"c8'`!"Re(CA46HA0dC@e'EfaNCA*\rIAdC3Fe"X!!Dc9(*KF%9iDA0dFepI4R-!"kj(CA48FQ&`9(P`C9pI4R-!!lK1G@e\r8EfpXBQpi9(*KF(0IAdCf!'0b8%pA8J#3"JbF!!!BV!!!!2!!!!d)!!!,T!!!!U3\r!N!B"k!!!!!`!N%"&C`!!4@X!"!!!!!%!!!!m!!!!)!!!!aem#!+QNq(rr*!!!3!\r)P#(r`$[M!!")!!!"B!!!!)!#!!#3!"m!!MKr!!#!!3")1#%!3(`)!kD$iIrm6S!\r!)%9e!*!&!J!!!"4&G!-!N!3$!!!!(%9Z$!3!!!!+!!!!$)!!N!Z!!!!m#!!!!%9\rh!*!&!3#3"%9V!!3!!!!,!!!!#!!!!%)!!!-l1'!!!%k!!#"&D`!%!!!!$!!!!!J\r!!!"@!!!$E6KP!!"1J!!J4@X!"!!!!!i!!!"-!!!!H!!!!kD6iIrm1q!!!#J%!!"\r"JJ!31!!!!CJ%!!!lr`!"+!8!!%'#!"!i!!!"Q!8!!$[r!!%S"J!!3B)!$$J!!!#\rB"J!!1(m!!)2Krra1J!!J4@X!"!!!!"-!!!"%!!!!r!!!",Tm#!+QNq(rr*!!!3!\r)P#(r`*!!B3"B1q3!!)"K!&K)!!!"B!!!!$J!)ED`(`!'1'!!!)!"!%Ji)3"!I!J\r$TS2Krra1J!!J4A8!N!88!!!!(%9Z$!3!!!!N!!!!$)!!N!Z!!!"%#!!!!%9h!*!\r&%`#3"%9Z"3%!!!!P!!!!#IrrrrS!!!9hC'9f1QjeE'`!-AVi4@X!"!!!!#B!!!#\r)!!!"0!!!"AGm#!+QNq(rr*2"rrL6SIrdN!!"!!L8)Iq`1m3!!$[P!!!lS!!!J!3\r![LJ!!!"!JJ!m9q!'2d'#!""Ai!Bq+!!!"N##!#L!IJ#kJ))!!$LJ!!!i`!!"5!!\r!!@!!!!"8B!Br3B)!#$ZJ!!%iI3!!J!%!@$JK!&"m#!1QJq(rr)2"rrL$SIrd6S!\r!)%9d!`#3"#8!!!")4A8!N!8R!!!!9%9Z$!3!!!#U!!!!$)!!N!Z!!!#)'!!!!%9\rh!*!&*J#3"%9V!!3!!!#V!!!!H!!!!@3!!!CCI!J#TT2Krrb6`IriNk(rp*!!!3!\r)P#(rX$[M!!#!!`!3+!!!!%##!#3iB!!'5!!!!@!!!!"mIKYj3B)!$$Kq!!")!!!\r"Npm!%)1r!"#SI3!!1!-!!E!G!!#!I`!3J!%!@$JK!&"m#!1QJq(rr)2"rrL$SIr\rd6S!!)%9e!*!&V!!!!#a&G3#3"3%!!!"!4@i0!J!!!,!!!!!5J!#3"aJ!!%3!4!!\r+!!#+J!!H!*!'4AB+R!!!!,%!!!!14@i-"!!!!,)!!!!-J!#3$RJ!N!4&G`#3"DX\r!N!4&G`d!N!5`!!!!#%9Z"3%!!!#c!!!!%IrrrpJ!!!CC6R9XE&0[BfYPG%4[E@&\rTEJ#Sj1"&EJ8"!!!!Y!!!!!hrrrrA!!!'@90[BfYPG%4[E@&TEJ#3"%9Z"33!!!#\re!!!!#2rrrpB!!!CC!*!)4AB&!*!%Y!#3"%9Z"3%!!!#f!!!!%Irrrp8!!!CC4QP\rXC90[BfYPG%4[E@&TEJ#DfI"&EJ8%!!!!Y`!!!!crrrr8!!!'@3#3$%9f"3#3",8\r!N!4&EJ8%!!!!Z!!!!!Mrrrr6!!!'@3#3#%9f"3#3",B!N!4&GJ8!N!5h!!!!"%9\rZ"33!!!#j!!!!&2rrrp)!!!CC!*!84AB&!*!%Z!!!!!K&GJ8!N!5e!*!%4@i&"!!\r!!,S!!!!)rrrrd3!!"PN!N!K&GJ8!N!5c!*!%4AB&!*!%Z3!!!!4&E`8%!!!!Z`!\r!!%6rrrr3!!!'@3#34%9f"3#3",S!N!4&GJS!N!5m!!!!%%9f#J#3",d!!!!-4AB\r+!*!%[J!!!"4&GJS!N!5r!!!!3%9f#J#3"-!!!!!m4AB+!*!%`3!!!$K&GJS!N!6\r#!!!!0%9f#J#3"--!!!!`4AB+!*!%a!!!!#a&GJS!N!6&!!!!+%9f#J#3"-B!!!!\rN4AB+!*!%a`!!!#"&GJS!N!6)!!!!#%9f#J#3"-N!!!!F4AB+!*!%bJ!!!"K&D`#\r%!!!!b`!!!'5!!*!(I!J#TT2Krrb3!!%!#*3Krm"mIaYjX)%!AN'#!$5!!J!!N!!\rI!!!iI`!!1)!!!%J!!!&J!!!!U!%!AL`!!!"!J3!31(m!!%J!!!&J!!!!1(m!!)!\r"!%Ji)3"!I!J$TS2Krra1J!!J4A3$!*!%Z`!!!"a&G3#3"F`!!!!X4A8!N!A0!!!\r!4%9Z$!3!!!$1!!!!$)!!N!Z!!!"N#!!!!%9h!*!&b`#3"%9Z"3%!!!$2!!!!#rr\rrrmm!!!CC6R9XE&0[BfYPG!"[4@i&!3!!!0!!!!!(rrrrcJ!!"PP6Ef0VCA3!Ed9\rZ"33!!!$4!!!!#2rrrmd!!!CC!*!)4AB&!*!%d!#3"%9Z"33!!!$5!!!!$2rrrm`\r!!!CC!*!-4AB&!*!%d3#3"%9Z"33!!!$6!!!!#2rrrmX!!!CC!*!)4AB&!*!%c`#\r3"%9f"3#3"0)!!!!%4@m&"!!!!!-!!!"NrrrrbJ!!"PN!N'4&GJ8!N!66!*!%4AB\r+!*!%e!!!!&a&GJS!N!69!!!!9%9f#J#3"0B!!!"34AB+!*!%e`!!!%a&GJS!N!6\rB!!!!5%9f#J#3"0N!!!"%4AB+!*!%fJ!!!$a&GJS!N!6E!!!!1%9f#J#3"0`!!!!\rd4AB+!*!%h3!!!$"&GJS!N!6H!!!!,%9f#J#3"0m!!!!S4AB+!*!%i!!!!#4&GJS\r!N!6K!!!!)%9f#J#3"1)!!!!84AB+!*!%i`!!!""&GJS!N!6N!!!!$%9f#J#3"18\r!!!!)4AB+!*!%jJ!!!'"&GJS!N!6R!!!!3%9f#J#3"1J!!!"B4AB+!*!%k3!!!"a\r&GJS!N!6U!!!!'%9V!)3!!!$V!!!!C)!!N!Gm#!+QNq(rr*!!!3!)P#(r`(ar'hQ\r`J3"H3B)!0)!#!!#3!"m!!MKr!!!iJ!!!5!!!!@!!!!#S!3"H,!!!!%#"!"!iI`!\r!5!!!!@!!!!!iI`!!J!%!5$JK!%"m#!1QJq(rr%k!!#"&G!-!N!3$!!!!(%9e!*!\r&l!!!!#a&G3#3"Fd!!!"%4@i-"!!!!1d!!!!-J!#3#i!!!'3)!!!!4AF!N!AV!*!\r%4@m+K!!!!1B!!!!)J!#3$d9f!*!&k`#3"%9f$`#3"1i!!!!%4@m+K!!!!-J!!!!\r)J!#3$d9f!*!&b`#3"%9f$`#3"1i!!!!%4@m+"!!!!-N!!!!)J!#3$d9f!*!&U`#\r3"%9f$`#3"1i!!!!%4@m+"!!!!-S!!!!)J!#3$d9f!*!&*J#3"%9f$`#3"1i!!!!\r%4@m+"!!!!1F!!!!)J!#3$d9f!*!&%`#3"%9f$`#3"1i!!!!%4@m+"!!!!1J!!!!\r)J!#3$d9f!*!&$J#3"%9f$`#3"1i!!!!%4@m+"!!!!1N!!!!)J!#3$d9f!*!&$!#\r3"%9f$`#3"1i!!!!%4@m+"!!!!1S!!!!)J!#3$d9f!*!&#`#3"%9f$`#3"1i!!!!\r%4@m+"!!!!1m!!!!)J!#3$d9f!*!&!3#3"%9f$`#3"1i!!!!%4@m$"!!!!,X!!!!\r%J!#3#d9f"3#3",X!N!4&EJ-%!!!!*3!!!!5!!*!,4AB&!*!%*3#3"%9[!`3!!!!\r$!!!!")!!N!Y&GJ8!N!3$!*!%4@m2"!!!!1i!N!5!!*!(4@J!!&0C68J!!!'@!!!\r!0J!!!!S!N"%"!*!'!cErN!3!!!-i!!%!!!!%rj!%!3#3""m!!3#3"J0Jrj!%!!!\r$DJ!!!!%!N!B$Prq3"!!!!k-!!3!!!!d!!!!$!3#3"!8!!3#3"J2j!!!!"!!!!r`\r!!!!3!!!%*!!!!"`!!!4)!!!!*!!!"&S!!!!`!!!%I`!!!$J!!!53!!!!!%!!!!5\rRrj!%!!!%Y`!%!!!!$`!!!'J"!*!%"!!!!"!!!!"S!3#3"!8!!!!4!!!!D!%!N!3\r'!!!!%J!!!!-!N!8I!!%!N!B%i`!!!"`!!!6Qrj!%!!!&+`!#!!!!"2q3"!%$!!!\r!@!!!!"Arrrrm!3#3""m!!3#3"JA6rj!%!!!'9J!#!!!!+2rrrrN"!*!%(J!!!*l\rrrrrF!3#3""m!!3#3"JD6!!!!+!!!"UJ!!!")!!!'arq3"!!!"ZS!!3!!!!6rrrr\rE!3#3""m!![rrrrd!!!!(!!!!"J!#!!!!#!!!!!X!N!F*!!!!C!!!!!)!![rrrri\r!!!!&!!!!"J!"!!!!"[rrrrd!N!ErN!3!!Irrrri!![rrrrX!!!!@!!!!+!!0!!!\r!&`!!!!X!N!FB!!!!!J!!!!)!!!!C!!!!#J!!!!B!!!!D!!!!#J!!!!J!!!!E!!!\r!#J!!!!S!!!!F!!!!#J!!!!`!!!!G!!!!#`!!!!i!!!!H!!!!!`!!!"!!!!!I!!!\r!!J!!!"3!!!!J!!!!!J!!!"J!!!!K!!!!!J!!!"`!!!!L!!!!!`!!!#!!!!!M!!!\r!!`!!!#3!!2rrrr`!!IrrrrX!!IrrrrS!!!!*!!!!!3!!!!F!![rrrrB!!!![!!!\r!4J!$!!!!-!!!!!X!N!Fa!!!!!`!!!!)!!!!b!!!!!3!!!!B!![rrrrF!!!!Y!!!\r!4J!"!!!!,[rrrrB!N!8"rrrrm3!!!!)!!!!#!!!!#`!#rrrrmJ!!!$J!!!!)!!-\r!!!!hrrrrm`#3"cN!!!!,!!!!"!!!!$Vrrrra!!!!"J!!rrrrm`!"rrrrmJ!!rrr\rrl!!"!!!!DJ!#rrrrl3!!!%F!!!!8!!F!!!")!!!!!J#3"d)!!!!(!!!!"!!!!%N\r!!!!(!!!!"3!!!%S!!!!+!!!!"J!!!%[rrrrX!!!!#!!!!%-!!!!#!!!!$!!!!%`\r!!!!#!!!!%!!"rrrrlJ!!!"3!!!!8rrrrl3!#rrrrl`!!!$i!!!!J!!J!!!!r!!!\r!#J#3"d!!!!!(!!!!!J!!!%%!!!!'!!!!!`!!!%)!!!!#!!!!"!!!!%-!!!!'!!!\r!#!!!!%3!!!!'!!!!#3!!!%8!!!!+!!!!#J!!!%ErrrrZ!!!!$!!!rrrrm!!"rrr\rrl`!#rrrrkJ!!!&`!!!!%!!)!!!"G!!!!#`#3"ei!!!!,!!!!!J!#rrrrk`!!!&F\r!!!!3!!8!!!"B!!!!!J#3"eN!!!!#!!!!"!!!!&S!!!!+!!!!#!!!!&[rrrrU!!!\r!#J!!!&m!!!!,!!!!$J!"rrrrk!!!!!B!!!!#!!!!#`!#rrrrk3!!!'X!!!!3!!B\r!!!"X!!!!#`#3"fhrrrrS!!!!!J!!!'i!!!!(!!!!#!!!!'m!!!!(!!!!#3!!!(!\r!!!!,!!!!#J!!!(%!!!!$!!!!$!!#rrrrp!!!!$B!!!"X!"`!!!!hrrrrm`#3"cN\r!!!!,!!!!"!!!!$X!!!!,!!!!"J!!!$`!!!"Q!!!!#!!!!$hrrrr`!!!!$!!!!%d\r!!!!,!!!!%!!!!%i!!!"V!!!!%J!!!%m!!!!,!!!!&J!!!&!!!!!,!!!!'!!!!&%\r!!!!(!!!!'J!!!&)!!!!(!!!!'`!!!&-!!!!,!!!!(!!!!&3!!!!(!!!!(J!!!&8\r!!!!(!!!!(`!!!&ErrrrV!!!!)!!!!'!!!!!$!!!!-!!!!'%!!!!+!!!!0!!!!')\r!!!!$!!!!0J!!!'-!!!!$!!!!1J!!!'3!!!!+!!!!2J!!!'8!!!!$!!!!3!!!!'B\r!!!!$!!!!4!!!!'F!!!!#!!!!5!!!!'J!!!!#!!!!6!!!!'N!!!!#!!!!8!!!!'V\rrrrrT!!!!9!!!!()!!!!$!!!!C!!!!(-!!!!$!!!!D!!#rrrrj3!!!(N!!!!)!!3\r!!!"k!!!!#`#3"hX!!!!,!!!!!J!!!(`!!!!,!!!!"!!!!(d!!!!,!!!!"J!#rrr\rrjJ!!!(F!!!!3!!3!!!"irrrrj3#3"hi!!!!+!!!!#!!!!(rrrrrU!!!!#J!!!)!\r!!!!,!!!!$J!"rrrrj!!!!")!!!!#!!!!#`!#rrrri`!!!)J!!!!3!!B!!!#*rrr\rrkJ#3"iS!!!!$!!!!"!!!!)X!!!!(!!!!#!!!!)`!!!!(!!!!#3!!!)d!!!!,!!!\r!#J!!!)i!!!!$!!!!$!!#rrrrj`!!!(8!!!"S!"F!!!!hrrrrm`#3"cN!!!!,!!!\r!"!!!!$X!!!!,!!!!"J!!!$`!!!"Q!!!!#!!!!$hrrrr`!!!!$!!!!%d!!!!,!!!\r!%!!!!%i!!!"V!!!!%J!!!%m!!!!,!!!!&J!!!&!!!!!,!!!!'!!!!&%!!!!(!!!\r!'J!!!&)!!!!(!!!!'`!!!&-!!!!,!!!!(!!!!&3!!!!(!!!!(J!!!&8!!!!(!!!\r!(`!!!(ErrrrQ!!!!)!!!!)%!!!!$!!!!-!!!!))!!!!+!!!!0!!!!)2rrrrN!!!\r!0J!!!)3!!!!#!!!!5!!!!)8!!!!#!!!!6!!!!)B!!!!#!!!!8!!!!)IrrrrM!!!\r!9!!!!)m!!!!$!!!!C!!#rrrrp3!!!$3!!!"X!!)!!!!errrrp!#3"h6rrrrR!*!\r&![rrrq!!!!#6!!!!"!!"!!!!#3!!!'3!N!8#rrrrhJ!!!*F!!!!5!!B!!!!'rrr\rrr3#3"jMrrrrI!!!!"J!!!*RrrrrI!!!!#J!!!*S!!!!,!!!!$J!!!*X!!!!'!!!\r!%!!!!*`!!!!'!!!!%3!!rrrrh`!"rrrrhJ!#rrrri3!!!*%!!!!3!!3!!!#5rrr\rri!#3"j6rrrrL!!!!"!!!!*ArrrrL!!!!#!!!!*ErrrrI!!!!$!!!rrrriJ!"rrr\rri3!!rrrrh3!"rrrrp`!#rrrrq!!!!#N!!!$#!!F!!!!U!!!!#`#3"bX!!!!'!!!\r!!J!!!#crrrrh!!!!"!!!!$2rrrre!!!!5J!!!*!!rrrriJ!!!,B!!!!b!!!!CJ!\r!!,S!!!#Grrrrh3!!!,i!!2rrrrN!!IrrrrJ!!rrrrp`!!!#I!!B!#J!!!+!!N!H\rK!!!!!3!!!+)!!!!#!!!!S`!!!!-!!!#N!!!!"!!!!+8!!!!&!!!!TJ!!!!B!!!#\rR!!!!"`!!!+J!!!!)!!!!U3!!!!N!!2rrrpN!!Irrrrd!![rrrpS!!!#Y!!!!&!!\r#!!!!V[rrrq%!N!H[rrrrf3!!!"!!!2rrrpX!!IrrrpS!!IrrrpJ!!!!4!!!!!3!\r!!!F!!IrrrpF!!!!0!!!!!3!!!!F!![rrrpErN!3!!!!)!!!!!Irrrp8!!!!4!!!\r!!3!!!!F!![rrrp6rN!3!!!!-!!!!![rrrp2rN!3!!!!)!!!!![rrrp,rN!3!!!!\r8!!!!![rrrp(rN!3!!!!)!!!!![rrrp$rN!3!!!"%!!!!!Irrrmm!!!!,!!!!!3!\r!!!F!!Irrrmi!!!!(!!!!!3!!!!F!![rrrmhrN!3!!!!)!!!!![rrrmcrN!3!!!!\r-!!!!![rrrm[rN!3!!!!)!!!!![rrrmVrN!3!!!"N!!!&H5jIAf0dAema-%jeE'a\r6Ef0VCA4'GJ!!-bjIAf0dAemf8fpMDf9d4RB!!T9IAhCdAema-%jeE'a6Ef0VCA3\r!"&YdD'Pc!!+H6R9XE&0[BfYPG!!(pL46Ef0VCA3!"[P6Ef0VCA3!!"abC@C$Eh9\rZG!!(mepIGR"dFL3!"$p!1$!i!!Gp,R*PB@4IAc%`6R9XE&0[BfYPG%C3GQN!!$!\rZGh*TG'9IAc%`6R9XE&0[BfYPG%C3GQN!!maXC@i!"jFZFf9XC@0dAema-%jeE'a\r6Ef0VCA4'8&9M8&9M8&9M!!FmBf&Z8Q9KC!!!CQ0KEPGbDA4P!!'"CAKMCA"dD@p\rZ!!HKCfp[C'PPF`!$4bjQFh4KG&pI-6"1G@aX8fpMDf9d4P!dFh4KG!!'`5jQFh4\rKG&pI0P0[BfYPG%C30(0dBA3!!jjLG@B!"#YcG'&d!!D5Fh4IC'9f!!E!Fh4ID@j\r[!!FGFh4IE@pNC3!!dR0dAfjXD@jV!!BNFh4IG@PN!!EXFh4ICfPN!!HTFh4IFQ4\rPGJ!(Vh0dAh0THQ8!!(acG&pKG'PYC3!!`(0dAfedD@eP!!#FFh4IBh4TE@8!!Q9\rcG&pLE'YcDATP!!(rFh4IBQa[BfYc!!4J3$Ja13!%H%!i-M%!"SNZ@@peFR0IAc%\rf6R9XE&0[BfYPG%4[E@&TENC53c%a4e9658CTE'95C@C4-M%f4QPXC90[BfYPG%4\r[E@&TEMG5CA&eCA0d!!50,Q9aG@&XFh4bD@jR!!2FFQ9Q!!214e9658CTE'95C@B\r!"44PFR*[FJ!(RQKKFdPZCQm!"+GQD@aP!!&l9%CTE'96F'9M!!FP*%C68h"PB`!\r'#%C68h"PB`!((RC5C@C1G@d!"FT`BA**4!!%UfjKE@8!"+TTEQC[!!,S3dPZCQp\r33P*PB`!"VQK'D@aP5@jQE`!"68K'D@aP5@jQE`!&'h&-D@jV!!9r889XC@d!"CT\ra9(P`C3!&MR&%BA4K!!BeD@p8FQ&`!!(9D@p$E@4"C'4b!!6ED@p$Efe`E'9dD@p\rZ!!'r8QpeG'PZC84PFf0bDA"dEh)!"bGREdeTH'9N6@pNC94bBA!!"d4fCA*cD@p\rZ!!B)FQpeG'PZC84PFf0bDA"dEh*'E'&RF`!"9R*PFf9bGQ9N-3!"9h*PFf9bGQ9\rN-J!%Gh0PE'9MG'pb5@jQE`!%+R*[GA4TEQ9$Eh9ZG!!'m(*[GA4TEQ95C@0[FQ4\rc!!8I8QpeG'PZC9*PBfpbC!!![h"bEf0*EQC[!!23590"!!6lFQpeG'PZC8CXB@G\rc!!D%F(*[Bd4PFf0bDA"dEh)!!0GcC@aPBh4[FJ!!IfP[8Q9cG@ad!!(@D@p1B@e\rP8(4b!!&XD@p@8Q9Q6R9Y!!&SD@p'8Q9Q6R9Y!!)`D@p'9Q9bFdjeE3!(D'CTE'a\rPFM%!!eKTEdC%DA**EQ4PH!!#-'P[4Qa"G(4bD@)!!04TEd&$9A0PFJ!%d@P[4Qa\r'EQ4b5@jQE`!&INC*EQC[!!CQCQ48HA"P!!&VCQ4$FQ9KG'pb!!HmCQ4'E'&RF`!\r#"QCN6'pMBA4TEfi!"D43EfPZG!!"GRB!!@KS!!DfCQ4'E'4b!!I)D@p%DA**4!!\r"$fP[4Qa6G%*XD`!"rfP[4Qa-CdaPEJ!"c'P[4Qa3H8aPEJ!#k@P[4Qa58h4#E'X\r!!N"TEdCX8NaR6'9Z!!++D@p'E&*3H8aPEJ!"[@P[4Qa$FN4KG!!"efP[4Qa0C%4\rKG!!"5@P[4Qa#Dd4KG!!&B@P[4QaB4QjNFNPZCQm!"RK'@%PZCQm!!+0QC%PMEfj\r*4!!!0QCN9@jeFf9N!!$*CQ46Bh*TF(3!!#KQC&K'E'&RF`!"NQCN3fpYE@9ZG!!\r"e@CN8(9d3AGKH3!"#fP[4Qa3BA**4!!#8@P[4Qa$E("6DAS!"hPNDA**EQC[!!H\rK4'Pb5@jQE`!#%QP[4(*9Fh*AC(-!"Gj%5@jQE`!'!QCb8Q9MG!!%Ie*PBh3!!bp\rdEh!!"!aXC@Cd!!BLBQpdG'pY!!A@FQPRD(3!"fGQFNCXB@Gc!!*BCR*-Ef0KG'P\r[EJ!'8fCb9QPPG`!"k'P[4(*%DA**4!!"MQP[4(*1E8CXF`!(DQCTE'aPFM-!!GG\rTEd4b3h*%BA3!!BeTEd4b6@4%BA3!!H0TEd4b3QY%BA3!"-"TEd4b4QjNFNPZCQm\r!"U4%@%PZCQm!!,CQFP0MFQpXE!!$c'Cb6h"PEN0SB@PZ!!"'CR*6Bh*TF(3!!+j\rQFPK'E'&RF`!"`QCb3fpYE@9ZG!!"L@Cb8(9d3AGKH3!"*'P[4(*3BA**4!!'Gf4\r[E@&TEJ!!K%CTE'96Ef0VCA4%EfeKD@i!"I)N8fpMDf9d4'pYB@PZ!!3d8fpMDf9\rd4'pYB@PZ!!$hEQ9iG%4PGQPMC84[E@&TEJ!'q@jPH(4'D@aP4'pYB@PZ!!9#CQP\rbFh3!!J9'D@aP8fpMDf9d!!3NF(*PGJ!%5fjPH(3!"`TQ8Q9Q6R9Y!!BSBA"`C@j\rN!!%NG'9YF'pbBA*j!!4VFh"PB`!(-(*PFA9PFh3!!49'D@aP8fpMDf9d4'pYB@P\rZ1MT5CA&eCA0d!!"LGfPXE%p`C@i!!JjhD@aX8Q9YEhCP!!*9GfPXE&*PEQ&YC3!\r(5AGTE'a(CA4'D@aP5@jQE`!(p(GTE'a6CA4'D@aP5@jQE`!$j(GTE'a'3@0MCA0\rc!!$HGfPXE&0dBA3!!DahD@aX3fKYEf3!!A"hD@aX994TE@8!!MahD@aX3@0MCA0\rc!!4j3$Jb-J!#A#j[F'9ZAema0NjeE'a6Ef0VCA4%EfeKD@j'8N-a-8G98dP'D@a\rP8Q9QD3!#HbjIAfjhAep'9@`!!1K1G@aX8fpMDf9d4'pYB@PZ!!'9*%CTE'96Ef0\rVCA4%EfeKD@i!!BacD@jRE'9dEfi!"*G!1$-`!!&FAepNE&pI4P"f!!5B3$Jc-3!\r%Q8!i-c)!"*Y!1$-d!!EmAep59&4*Aema-P0[BfYPG%4[E@&TEJ!%R%!i-c8!"*e\r!1$-f!!**Aep59&4*Aema0NCTE'96Ef0VCA4%EfeKD@i!"*T!1$-c!!)$Aep59&4\r*Aema0NjeE'a6Ef0VCA4%EfeKD@i!!#eIAhCdAema0NjeE'a6Ef0VCA4%EfeKD@i\r!"SpcEf0VCA4`B@PbAema-P0[BfYPG%4[E@&TENCTFe"30P0[BfYPG!!"mA0[BfY\rPG&pI-6*6Ef0VCA4%EfeKD@j'DA-!"DTMD'p[Ff9IAc%f4QPXC90[BfYPG%4[E@&\rTENCT8'03GQP3GP"T!!0cB@0MCA0cAema0NCTE'96Ef0VCA4%EfeKD@j'8N-a-8G\r98dP'D@aP8Q9QD3!$9(9dD@ePAema0NCTE'96Ef0VCA4%EfeKD@j'8N-a-8G98dP\r'D@aP8Q9Q8%-hGA4TE@*eCJ!$,Q0SE@pNAema0NCTE'96Ef0VCA4%EfeKD@j'8N-\ra-8G98dP'D@aP8Q9Q9A-!"[TcG'&dAema0NCTE'96Ef0VCA4%EfeKD@j'8N-a-8G\r98dP'D@aP8Q9Q8$4cG'&d!!H)CQ&MBf9cFepI-6C'D@aP8fpMDf9d4'pYB@PZ4P*\r$-6&(990*4QPXC9*PCP9T8'`!""PQFf9dCQPXC@PZCQpIAc%f4QPXC90[BfYPG%4\r[E@&TENC53c%a4e9658CTE'95C@C9E&9X!!DjCQGPG'CTE'9TEQC[Aema0NCTE'9\r6Ef0VCA4%EfeKD@j'8N-a-8G98dP'D@aP8Q9Q8&9X8&9X!!A4FQ9ZB@ePAema0NC\rTE'96Ef0VCA4%EfeKD@j'8N-a-8G98dP'D@aP8Q9Q8%0M!!*pFQ9YEhCPAema0NC\rTE'96Ef0VCA4%EfeKD@j'8N-a-8G98dP'D@aP8Q9Q!!)bAepNG&pI-6C1G@aX8fp\rMDf9d4'pYB@PZ4RB!!B0[F'9ZAema0NjeE'a6Ef0VCA4%EfeKD@j'8N-a-8G98dP\r'D@aP8Q9QD3!&qPP[GA*cAema0NjeE'a6Ef0VCA4%EfeKD@j'8N-a-8G98dP'D@a\rP8Q9Q86)a0NCTE'96Ef0VCA4%EfeKD@ih8Q9aG@9cG!!$r5jIAf4dAema0NjeE'a\r6Ef0VCA4%EfeKD@j'GJ!$ZLjIAf4dAema0NCTE'96Ef0VCA4%EfeKD@j'GJ!#6bj\rIAf4XAep'8(B!",G!1$3`!!5i3$Jd-3!%ZN!i0$-!"rpIAe*89%PIAcC6Ef0VCA3\r!",P!1$3b!!6lAep59&4*Aema-%jeE'a6Ef0VCA3!!hG`Eh0dAh0PE'9MG&pI0P0\r[BfYPG%C9Be9M9@-!!Qa`FQ9IFf9XC@0dAemf8fpMDf9d4P9M9@09B`!$lR0SGA4\rNEhGZAemf8fpMDf9d4QN!!8*TFf&dG(PIAcC6Ef0VCA4'GJ!%I@CdFR9ZBf&dC9p\rI0P0[BfYPG%CX!!&JE(0PC@YIAcC6Ef0VCA4'E'N!!fpTEf0dE&pI0P0[BfYPG%C\r9D9"f!!*(CQ0ZG'aIAcC6Ef0VCA4'9@PT!!&,Ff9dFfpMDfp`G&pI0P0[BfYPG%C\rTD9"fD3!#b'GPG(0[BfY[F(4IAcC6Ef0VCA4'D@P3GP"T!!&!Cf9dF'9PFQjKE@9\rIAcC6Ef0VCA4'8(C3D3!"afGPG(0[BfYZB@ePAemf8fpMDf9d4P"f8'N!"aacC@j\rNG'pIAcC6Ef0VCA4'8(CTD9"fD3!#F(*PBhCQFQpYAemf8fpMDf9d4P"fD@P3GP"\rT!!5@B@0MCA"dAemf8fpMDf9d4P"f8'N!!FKXDA0dC@jIAcC6Ef0VCA4'D3!%kQ0\r[EQjPBh4IAcC6Ef0VCA4'8(CT!!&-BQPZC&pI0P0[BfYPG%C3GQN!"&4IAf4dAem\ra-%jeE'a6Ef0VCA4'GJ!#TfCcG'&dAema-%jeE'a6Ef0VCA4'8$4cG'&d!!E$Ff9\rXC@0dAema-%jeE'a6Ef0VCA4'8&9M8&9M8&9M!!IdGh*TG'9IAc%`6R9XE&0[BfY\rPG%C3GQN!"NPbC@&NAema-%jeE'a6Ef0VCA4'8(CT!!9Z,PpIC(4IAc%`6R9XE&0\r[BfYPG%Cf!!"#,PpIC(4IAcC6Ef0VCA4'GJ!%[N!i0$F!!hj86d-!"(9IAf0dAem\ra-%jeE'a6Ef0VCA4'GJ"5C9"29e)!N!B4E!!!&LS!!!"N!!!4f!!!"&)!!!3`!*!\r'!KF!!!!%!*"!4@F!!%9T!*!&!89V!!3!!!!#!!!!&!!!!#!!!!2GJ!)!!*!!!`!\r#1!!!!,!$!!"1J!!J4A3$!*!%!`#3"%9V!!3!!!!)!!!!9!!!!%S!!!3#I!J#TT2\rKrrb3!!%!#*3Krm"mIaYjX)%!AN'#!#5!!J!!N!!I!!+S!3"H,!!!!%#"!"!iI`!\r!5!!!!@!!!!!iI`!!J!%!5$JK!%"m#!1QJq(rr%k!!#"&G!-!N!3$!!!!(%9e!*!\r&#3!!!$4&EJ`%!!!!#J!!!!b!!*!,J!!!9!J!!!"&G`#3"3J!N!4&D`!%!!!!#`!\r!!#J!!!"X!!!%'A`)!UD3!!%!#*3Krm!iB!!Y5!!!!@!!!!#!!3")1#%!3(`)!kC\r1J!!J4A8!N!8-!!!!%%9Z$!3!!!!0!!!!$)!!N!Z!!!!S!*!%4AF!N!8,!*!%4@X\r!"!!!!!i!!!!S!!!!L!!!"&am#!+QN!!"!!L8)Ir!1'!!,8J!!!&J!!!!J!%!5$J\rK!%"m#!1Q6S!!)%9e!*!&$!!!!""&EJ`%!!!!$`!!!!b!!*!,J!!!+!#3"%9h!*!\r&$J#3"%9V!!3!!!!3!!!!+!!!!+3!!!5LI!J#TT!!!3!)P#(r`$KJ!#e)!!!"B!!\r!!)!"!%Ji)3"!I!J$TNk!!#"&G3#3"3`!!!!34@i-"!!!!"%!!!!-J!#3#i!!!#J\r!N!4&G`#3"4!!N!4&D`!%!!!!%J!!!#J!!!$!!!!%hh`)!UD3!!%!#*3Krm!iB!!\rY5!!!!@!!!!#!!3")1#%!3(`)!kC1J!!J4A8!N!86!!!!%%9Z$!3!!!!8!!!!$)!\r!N!Z!!!!S!*!%4AF!N!85!*!%4@X!"!!!!"8!!!"B!!!!h!!!"6Tm#!+QN!!"!!L\r8)Ir!N!"K!&L3!)%!A*!!S3"J1!!!!*!!!3!iJ'%!@)#"!&b!S3"J1-!!!$MJ!!!\rj!3!iJB-!!S'-!#")!!!"B!!!!)!"!%Ji)3"!I!J$TNk!!#"&G3#3"4B!!!"!4@i\r-"!!!!"S!!!!-J!#3#i!!!&J!N!4&G`#3"48!N!4&D`!%!!!!'`!!!&!!!!%`!!!\r&Xh`)!UD3!!%!#*3Krm#3!'%!@*!!J3"FN!#K!'#!B3"BJ)%!A)#K!'!i`!!!11!\r!!$N!!!#"J`!#JB`!*%J!!!&J!!!!J!%!5$JK!%"m#!1Q6S!!)%9e!*!&&J!!!$K\r&EJ`%!!!!(!!!!!b!!*!,J!!!8!#3"%9h!*!&'`#3"%9V!!3!!!!G!!!!+!!!!AB\r!!!B3I!J#TT!!!3!)P#(r`$KJ!#e)!!!"B!!!!)!"!%Ji)3"!I!J$TNk!!#"&G3#\r3"3`!!!!34@i-"!!!!"i!!!!-J!#3#i!!!#J!N!4&G`#3"4d!N!4&D`!%!!!!(`!\r!!#J!!!'5!!!'Dh`)!UD3!!%!#*3Krm!iB!!Y5!!!!@!!!!#!!3")1#%!3(`)!kC\r1J!!J4A8!N!8-!!!!%%9Z$!3!!!!J!!!!$)!!N!Z!!!!S!*!%4AF!N!8I!*!%4@X\r!"!!!!#%!!!!S!!!"VJ!!"X*m#!+QN!!"!!L8)Ir!1'!!,8J!!!&J!!!!J!%!5$J\rK!%"m#!1Q6S!!)%9e!*!&$!!!!""&EJ`%!!!!)J!!!!b!!*!,J!!!+!#3"%9h!*!\r&)3#3"%9V!!3!!!!M!!!!+!!!!FS!!!F1I!J#TT!!!3!)P#(r`$KJ!#e)!!!"B!!\r!!)!"!%Ji)3"!I!J$TNk!!#"&G3#3"3`!!!!34@i-"!!!!#3!!!!-J!#3#i!!!#J\r!N!4&G`#3"5-!N!4&D`!%!!!!*3!!!#J!!!(Q!!!(@R`)!UD3!!%!#*3Krm!iB!!\rY5!!!!@!!!!#!!3")1#%!3(`)!kC1J!!J4A8!N!8-!!!!%%9Z$!3!!!!Q!!!!$)!\r!N!Z!!!!S!*!%4AF!N!8P!*!%4@X!"!!!!#F!!!!S!!!#!J!!"kpm#!+QN!!"!!L\r8)Ir!1'!!,8J!!!&J!!!!J!%!5$JK!%"m#!1Q6S!!)%9e!*!&$!!!!""&EJ`%!!!\r!+!!!!!b!!*!,J!!!+!#3"%9h!*!&*`#3"%9V!!3!!!!T!!!!+!!!!Ki!!!J#I!J\r#TT!!!3!)P#(r`$KJ!#e)!!!"B!!!!)!"!%Ji)3"!I!J$TNk!!#"&G3#3"3`!!!!\r34@i-"!!!!#S!!!!-J!#3#i!!!#J!N!4&G`#3"5N!N!4&D`!%!!!!+`!!!#J!!!)\rk!!!)6(`)!UD3!!%!#*3Krm!iB!!Y5!!!!@!!!!#!!3")1#%!3(`)!kC1J!!J4A8\r!N!8-!!!!%%9Z$!3!!!!X!!!!$)!!N!Z!!!!S!*!%4AF!N!8V!*!%4@X!"!!!!#d\r!!!#`!!!#9J!!#*Pm#!+QNq(rr*!!!3!)P#(r`$[N!!!i!!!!X!3!!$J!!!#3!!3\r!!MaJ!!%iBm'fX'3!"MJ!!!'`"!!)1!!!!,!%!!Si!!!!X!3!$$J!!!#`"!!11!!\r!!C!!"!!31'!!!%J!!!&J!!!!N!"r!"3iB!!!5!!!!@!!!!#3!(m!'$KJ!!")!!!\r"B!!!!*!!I`!F1!!!!*!!(`!J1!!!!C!!(`!N1'!!!)!"!%Ji)3"!I!J$TS2Krra\r1J!!J4A8!N!8Z!!!!A%9e!*!&,J!!!'a&G3#3"5i!!!"m4@i-"!!!!$i!!!!-J!#\r3#i!!!,!)!!!!4AF!N!8Y!*!%4@X!"!!!!$m!!!!S!!!#N!!!!!S'I!J#TT!!!3!\r)P#(r`$KJ!"e)!!!"B!!!!)!"!%Ji)3"!I!J$TNk!!#"&G3#3"3`!!!!34@i-"!!\r!!%!!!!!-J!#3#i!!!#J!N!4&G`#3"6m!N!4&D`!%!!!!33!!!#J!!!+X!!!+4A`\r)!UD3!!%!#*3Krm!iB!!@5!!!!@!!!!#!!3")1#%!3(`)!kC1J!!J4A8!N!8-!!!\r!%%9Z$!3!!!"#!!!!$)!!N!Z!!!!S!*!%4AF!N!9"!*!%4@X!"!!!!%-!!!!)!!!\r#b!!!#S)iB!!!6S!!)%9V!!3!!!"%!!!!+!!!!Y`!!!URI!J#TT!!!3!)P#(r`$K\rJ!#e)!!!"B!!!!)!"!%Ji)3"!I!J$TNk!!#"&G3#3"3`!!!!34@i-"!!!!%8!!!!\r-J!#3#i!!!#J!N!4&G`#3"83!N!4&D`!%!!!!4J!!!!3!!!,i!!!+jNk!!#"&D`!\r%!!!!4`!!!!J!!!--!!!,(MKJ!!"1J!!J4@X!"!!!!%J!!!!%!!!$)!!!#f*1J!!\rJ4@i&!3!!!%N!!!!(rrrrq`!!#f*6Ef0VCA3!!%9Z"33!!!"+!!!!#2rrrrS!!!Y\rL!*!)4AB&!*!%53#3"%9["33!!!!$!!!!C2rrrrN!!!YL!*"N4AB&!*!%5J#3"%9\rf#J#3"%X!!!"J4AB+!*!%6!!!!&a&GJS!N!40!!!!@%9f#J#3"%i!!!"84AB+!*!\r%6`!!!&"&GJS!N!43!!!!6%9f#J#3"&%!!!")4AB+!*!%8J!!!%4&GJS!N!46!!!\r!3%9f#J#3"&3!!!!m4AB+!*!%93!!!$K&GJS!N!4@!!!!0%9f#J#3"&F!!!!`4AB\r+!*!%@!!!!#a&GJS!N!4C!!!!+%9f#J#3"&S!!!!N4AB+!*!%@`!!!#"&GJS!N!4\rF!!!!(%9f#J#3"&d!!!!B4AB+!*!%AJ!!!"4&GJS!N!4I!!!!%%9f#J#3"'!!!!!\r-4AB+!*!%B3!!!!K&E`S%!!!!6!!!!!L!!*!24AB!N!9)!*!%4AB2!*!%BJ!!!!4\r&E`S%!!!!63!!!!L!!*!24AB!N!9(!*!%4AB2!*!%BJ!!!!4&E`S%!!!!6J!!!!L\r!!*!24AB!N!9'!*!%4AB2!*!%BJ!!!!4&E`S%!!!!6`!!!!L!!*!24AB!N!9%!*!\r%4AB2!*!%BJ!!!!4&E`S%!!!!8!!!!!L!!*!24AB!N!9$!*!%4AB2!*!%BJ!!!!4\r&E`S%!!!!83!!!!L!!*!24AB!N!9"!*!%4AB2!*!%BJ!!!!4&E`S%!!!!8J!!!!L\r!!*!24AB!N!8r!*!%4AB2!*!%BJ!!!!4&E`S%!!!!8`!!!!L!!*!24AB!N!8Y!*!\r%4AB2!*!%BJ!!!!4&E`S%!!!!9!!!!!L!!*!24AB!N!8V!*!%4AB2!*!%BJ!!!!4\r&E`S%!!!!93!!!!L!!*!24AB!N!8T!*!%4AB2!*!%BJ!!!!4&E`S%!!!!9J!!!!L\r!!*!24AB!N!8R!*!%4AB2!*!%BJ!!!!4&E`S%!!!!9`!!!!L!!*!24AB!N!8P!*!\r%4AB2!*!%BJ!!!!4&E`S%!!!!@!!!!!L!!*!24AB!N!8M!*!%4AB2!*!%BJ!!!!4\r&E`S%!!!!@3!!!!L!!*!24AB!N!8K!*!%4AB2!*!%BJ!!!!4&E`S%!!!!@J!!!!L\r!!*!24AB!N!8I!*!%4AB2!*!%BJ!!!!4&E`S%!!!!@`!!!!L!!*!24AB!N!8G!*!\r%4AB2!*!%BJ!!!!4&E`S%!!!!A!!!!!L!!*!24AB!N!8E!*!%4AB2!*!%BJ!!!!4\r&E`S%!!!!A3!!!!L!!*!24AB!N!89!*!%4AB2!*!%BJ!!!!4&E`S%!!!!AJ!!!!L\r!!*!24AB!N!85!*!%4AB2!*!%BJ!!!!4&E`S%!!!!A`!!!!L!!*!24AB!N!83!*!\r%4AB2!*!%BJ!!!!4&E`S%!!!!B!!!!!L!!*!24AB!N!81!*!%4AB2!*!%BJ!!!!4\r&E`S%!!!!B3!!!!L!!*!24AB!N!8,!*!%4AB2!*!%BJ!!!!4&E`S%!!!!5`!!!!L\r!!*!24AB!N!8)!*!%4AB2!*!%BJ!!!!4&E`S%!!!!B`!!!!L!!*!24AB!N!8#!*!\r%4AB2!*!%BJ!!!!4&E`-%!!!!!`!!!!5!!*!,4AB&!*!%!`#3"%9[$`3!!!"L!*!\r%J!#3"d9S!!"6@8e)!!!$0!!!!!F!!!!#!*!4!3#3"J2Z!!!!%!!!!rq3"3!!!rm\r!!3!!!!6rN!3"!*!%!`!"!*!'""6rN!3!!!3@!!%!!!!%rj!%!3#3""m!!3#3"J3\rh!!!!$!!!"$VrN!3!!!4C!!!!!3#3"J4p!!!!$!!!")$rN!3!!!5I!!!!!3#3"J5\rk!!!!$!!!",hrN!3!!!6F!!!!!3#3"J8'!!!!$!!!"3RrN!3!!!8h!!!!!3#3"J9\rQ!!!!3!!!"AhrN!3!!!@`!!3!!!!%rj!%!3-!!!"B!!!!&`!!!'3"!`!!!&`!!!!\rB!!!!!`%$!!!!B!!!!"N!!!!$!!-!!!!i!!%!N!B&i!!!!$J!!!AMrj!%!!!'$3!\r$!!!!"2q3"!%$!!!!@!!!!"F!!!"N!3-!!!"F!!!!'!!!!!-"!`!!!'!!!3#3"JC\r'!!!!$!!!"NRrN!3!!!CS!!!!!3#3"JDG!!!!$!!!"U$rN!3!!!Dr!!!!!3#3"JE\rT!!!!$!!!"ZcrN!3!!!F,!!!!!3#3"JFe!!!!$!!!"cMrN!3!!!GA!!!!!3#3"JH\r+!!!!$!!!"ihrN!3!!!HX!!!!!3#3"JIG!!!!$!!!"q$rN!3!!!Ir!!!!!3#3"JJ\rR!!!!$!!!##VrN!3!!!K*!!!!!3#3"JKd!!!!$!!!#(IrN!3!!!L@!!!!!3#3"JL\rq!!!!A!!!#A%!!!"X!!!*M`!!!(`!!!QYrj!%!!!+!`!"!!!!,rrrrrd"!*!%(`!\r"!*!'#L3!!!!-!!!+*rq3"!!!#N)!!!!"!*!'#Q%!!!!-!!!+C2q3"!!!#Rm!!!!\r"!*!'#TVrN!3!!!UN!!!!!3#3"JV"!!!!$!!!#X6rN!3!!!VM!*!+#a[rN!3!!!X\rE!!!!!3#3"JY9rj!%!!!,A`#3#JZBrj!%!!!,Q!!!!!,rrrrq!!!!"3!!!!B!!J!\r!!!B!!!!,!*!("`!!!'3!!!!#!!$rN!3!!Irrrri!![rrrr`!!!!`!!!!+!!0!!!\r!-3!!!!X!N!Fb!!!!!J!!!!)!!!!c!!!!#J!!!!B!!!!d!!!!#J!!!!J!!!!e!!!\r!#J!!!!S!!!!f!!!!#J!!!!`!!!!h!!!!#`!!!!i!!!!i!!!!!`!!!"!!!!!j!!!\r!!J!!!"3!!!!k!!!!!J!!!"J!!!!l!!!!!J!!!"`!!!!m!!!!!`!!!#!!!!!p!!!\r!!`!!!#3!!2rrrrd!!Irrrr`!!IrrrrX!!!!(!!!!!3!!!!F!![rrrrVrN!3!!!!\r)!!!!![rrrrRrN!3!!!"N!!!%U%G98dN!!$-ZAepMG&pI0P0[BfYPG%Cf!!ALAep\rfG&pI0P0[BfYPG!!%@h4SDA-!"[P6Ef0VCA3!!"abC@C$Eh9ZG!!(mepIGR"dFL3\r!!%)ZAepNG&pI0P0[BfYPG%Cf!!*2,PpIC'aIAdC3GJ!%R%!h0$N!!VFZBQPZC&p\rI0P0[BfYPG%C3GQN!!kdZ4e9659pPFR*[FJ!%Y%!h06%!"H`ZBfpZEQ9MG&pI0P0\r[BfYPG%C3GQN!",C!0c8c!!*#,QaTFh4PEPpI0P0[BfYPG%CT!!5i3$Fe03!&QLj\rKBf0PF(4IAcC6Ef0VCA4'8(C3D3!(A#j(990*Af9bFQpbAfjTE!!%ZN!h06F!!ZB\rZFQ9KC&pI0P0[BfYPG%C3GQN!!j3ZAep`G(*ICfaeC3!'!f*eCQCPFJ!'pf*eCQa\rPEJ!(C@CbEfeXC@i!",a!0c8j!!18,RGbDA4PAemf8fpMDf9d4P"fD3!%e%!h0M%\r!!fdZFQ9MGQCbEfeIAcC6Ef0VCA4'8(CTD9"f8'N!"0C!0cBc!!!C,R0PEQ4dEep\rI0P0[BfYPG%C3GQPT8(CT!!6B3$Ff03!#p#jRCA4cEf0VEQ&YC9pI0P0[BfYPG%C\r3GP"T!!6D3$Ff0`!#fLjRCA4`C@9bEQ&YC9pI0P0[BfYPG%C3GP"T!!6F3$Ff13!\r$abjRCA4cEf0VEh"dAemf8fpMDf9d4QPT8(C3D3!%p%!h0c%!!V%ZFf9dFfpMDfp\r`G&pI0P0[BfYPG%CTD9"fD3!%pN!h0c-!!pSZCQ0ZG'aIAcC6Ef0VCA4'9@PT!!6\ri3$Fh03!%I#jTEf0dE&pI0P0[BfYPG%C9D9"f!!6k3$Fh0`!'`5jQFh4KG&pI0P0\r[BfYPG%C30(0dBA3!"93ZG'PYC3!$RQ*eCJ!%+h0dBA3!"T*cG&pNCAB!"X"cG&p\rTEQm!"aecG&pYEf4P!!$5Fh4IEQaTEQX!"L4cG&peD@3!"ZacG&pRD@3!"kPcG&p\rbC'9f!!H[Fh4IFfPkC3!!I(0dAf&dD@eP!!$!Fh4IEA4TE@8!!*acG&pMG'PYC3!\r#CA0dAf*XDh0THQ8!!IpcG&pLE'pMDh-!"2a!0cFj!!)6,QacC@9VAemf8fpMDf9\rd4QaT!!383$Fi-3!&"bjQG(*eEQ0KG'9IAcC6Ef0VCA4'E!!%&N!h1$-!!SBZDA0\rKG(4jAemf8fpMDf9d4RB!"2mZFfKeG'4[GfjIAcC6Ef0VCA4'D3!%'8!h1$B!!`!\rZF(*PAh0PE'9MG&pI0P0[BfYPG%C9Be9M9@-!![SZFf9XC@0dAemf8fpMDf9d4P"\r9Be"9Be"9B`!%R5j`Eh0dAh0PE'9MG&pI0P0[BfYPG%C9Be9M9@-!"$4!0cN`!!I\rrAep59&4*Aemf8fpMDf9d!!I8AepNG&pI0P0[BfYPG%Cf!!0hF'pcG&pcC@aPBh4\rIAcC6Ef0VCA4'9@09Be9M!!&)Ff9XC@0dAemf8fpMDf9d4P"9Be"9Be"9B`!#E("\rbC9pcC@aPBh4IAcC6Ef0VCA4'9@09Be9M!!2ZFfKeG'4[GfjIAcC6Ef0VCA4'D3!\r"3QPcBA4dH9pI0P0[BfYPG%Cf!!4pCR4bG@jMBA4PAemf8fpMDf9d4Q`!!@"XFf9\rPDepI0P0[BfYPG%CXD3!&,fCcG'&dAemf8fpMDf9d4P!dFh4KG!!$EfP[Bh4XAem\rf8fpMDf9d4P9T8(B!!NGQBfjdE&pI0P0[BfYPG%C9D@N!!8YcCA4cEf0VEh"dAem\rf8fpMDf9d4QPT8(CT!!,)Cf9dFfpMDfp`G&pI0P0[BfYPG%CTD9"f8'N!!8"RCA4\r`C@9bEQ&YC9pI0P0[BfYPG%C3GP"T!!((Cf9dFfpMDfjKE@9IAcC6Ef0VCA4'8(C\r3D3!(((0PEQ4dEepI0P0[BfYPG%C3GQPT8(CT!!*`FQ9MGQCbEfeIAcC6Ef0VCA4\r'8(CTD9"f8'N!!MehFQPdC9pI0P0[BfYPG%C3GQN!!DCbC@&NAemf8fpMDf9d4P"\rfD3!%PQ&MBf9`G&pI0P0[BfYPG%C3GP"T!!()E'PcG'9ZAemf8fpMDf9d4QN!"1T\rMEfjZC@0dAemf8fpMDf9d4P"fD3!"6'*TEQ4IAcC6Ef0VCA4'8(CT!!0q9%p$!!H\r%AepMG&pI0P0[BfYPG%Cf!!!*,e"29e)!N!BfS!!!8UJ!!!&G!!!h$!!!'j`!!"h\rB!*!'!fi!!!!S!*"!4@F!!%9V!!3!!!!"!!!"2!!!!#!!!!C5I!J#TT2Krrb3!!%\r!#*3Krm#`J3"HN!#K!'#!B3"JJq-!!$J!!!#`(`!+S!%!AL`!!!0"JJ"N3)!!%#`\r!!!&"JJ!85!!!Z#`!!!9!J!#`5!!!Q+JI!!a8!!Gl3B)!$$J!!!5`(`!+L"m!2#J\r!!!*"JJ!3L"m!2#J!!!0!JJ!31!!!"jJI!$a)!!"d1!!!"TJI!$a)!!"SU"m!$&3\r!"hY"JJ!-1!!!",!I!!U)(`!m+!!!"d'#!%L)(`!m+!!!!N'#!"#)(`!m+!!!!d#\r#!"!i!!!(Q"m!2%J!!#3i!!!"Q"m!2%J!!"LS(`!-9!!(rd'#!!`i!!!"X"m!#S!\rI!!BS!!!!3B)!)+JI!!SX!!!!3B)!&)"r!!DSR`!+5!!!!@!!!!")!!!"B!!!!)!\r"!%Ji)3"!I!J$TS2Krra1J!!J4A8!N!8#!!!"'%9e!*!&!`!!!5"&EJ`%!!!!)`!\r!!!b!!*!,J!!"2!J!!!"&G`#3"3%!N!4&E`8%!!!!*!!!!#$rrrrh!!!*m+Vq"`#\r3#ql!!!%!"!#3$%9f#J#3"$3!!!!84@X!"!!!!$8!!!$%!!!!eJ!!#Rjm#!+QNq(\rrr*2"rrL6SIrdN!!"!!L8)Iq`1k-!!)2M!'Blh3!!U"d!%*!!(`!q,!!!!%##!$5\r!(J!UN!!I!##J(J!ZX"m!(MJ!!"#B(`!XJ"i!**!!(`!`S"i!+,!I!#ii!!!&Q"m\r!2+JI!!a8!!Eh3B)!$$J!!"#`(`!+J"m!"LJ!!!""JJ!JU"m!#L`!!!""JJ!8J(m\r!"ULI!!T)!!!"B!!!!%J!!!&J!!!!J!%!@$JK!&"m#!1QJq(rr)2"rrL$SIrd6S!\r!)%9e!*!&!J!!!*K&G3#3"3-!!!#J4@i-"!!!!,X!!!!-J!#3#i!!!-3B!!!!4AF\r!N!8e!*!%4@m&"!!!!,`!!!!Jrrrrp`!!$05UrJF!N!c"!!%!"!#3$%9f#J#3",d\r!!!!84@X!"!!!!,i!!!%!!!!"2!!!$B"m#!+QNq(rr*2"rrL6SIrdN!!"!!L8)Iq\r`1k-!!)2M!'Blh3!!U"d!%#`!TL&"JJ"B3)!!(#`!TKj"JJ"-3)!!5#`!TKT!J!"\r!5!!!2#`!!!""JJ!)5!!!-$J!!"#B(`!XJ"i!**!!(`!`S"i!+,!I!#ii!!!$Q"m\r!2$J!!!#3!"m!2NJ!!"3i!!!(Q"m!2+JH!"#3!"m!2UJI!!a8!!Fj3B)!%$J!!!L\r`(`!+5!!!$$J!!!#`(`!+J"m!"LJ!!!""JJ!JU"m!#L`!!!""JJ!8J(m!"ULI!!T\r)!!!"B!!!!%J!!!&J!!!!J!%!@$JK!&"m#!1QJq(rr)2"rrL$SIrd6S!!)%9e!*!\r&!J!!!04&G3#3"3-!!!$F4@i-"!!!!,m!!!!-J!#3#i!!!3!B!!!!4AF!N!@q!*!\r%4@m&"!!!!-!!!!!Jrrrrp`!!%(1UrJF!N!c"!!%!"!#3$%9f#J#3"-%!!!!84@X\r!"!!!!-)!!!#i!!!"XJ!!%4Ym#!+QNq(rr*2"rrL6SIrdNi(rm*!!!3!)P#(rX$Z\r$!!#$``"Q1l`!!+JF!"!X!!!!3))!$+2p!#L6rJ!BU"i!$&3!"rp!JJ!3U"i!$&3\r!"le"JJ!31!!!),!H!!T)!!!-1!!!!,!H!!U!(J!'+!!!!%'#!##S(J!+,!!!!%'\r#!"5!IJ!'U*i!#NJ!!!&J!!!!5!!!!@!!!!#!!3"B1#%!8(`)!kD$iIrmJm(rq)1\rKrr5$JIr`6S!!)%9e!*!&!J!!!)K&G3#3"3-!!!#3!%9Z$!3!!!$%!!!!$)!!N!Z\r!!!#i)!!!!%9h!*!&`J#3"%9["33!!!$&!!!!)2rrrrF!!"+SU[i(!*!-`3!"!!3\r!N!a&GJS!N!6'!!!!&%9V!!3!!!$(!!!"5!!!!Li!!"0)I!J#TT2Krrb6`IriNk(\rrp*!!!3!)P#(rX$ZM!!#$i`"Q1pd!!+JG!"!X!+BH3B)!P%#!!$3X!+BD3B)!L%#\r!!"`X!+B)3B)!I%#!!(JX!+B%3B)!A%J!!'`X!+BF3B)!8%J!!'!X!+BM3B)!4%#\r!!"`X!+BK3B)!6%#!!%JX!+BJ3)!!,%J!!$`X!!!!3B)!#%J!!$!i!!!!J(i!*V!\r$!!!i!!!!N!!I!$j)!!!S1!!!!CJI!$`i!!!jN!!I!$j)!!!81!!!!CJI!$bS(J!\r3N!!I!$kS(`!-9!!(rd##!"#S(`!-9!!([8'#!"!i!!!JX"m!#NJ!!!`i!!!!X"m\r!#S!I!!BS!!!!3B)!)+JI!!SX!!!!3B)!&)"r!!DSR`!+5!!!!@!!!!")!!!"B!!\r!!)!"!&Ji)3"3I!J$TS2Krrb$`IriJk(rp%k!!#"&G3#3"3)!!!%F4A8!N!8$!!!\r"*%9Z$!3!!!$)!!!!$)!!N!Z!!!&)'!!!!%9h!*!&a`#3"%9["33!!!$*!!!!)2r\rrrrF!!"CKU[i(!*!-`3!"!!3!N!a&GJS!N!6+!!!!&%9V!!3!!!$,!!!"N!!!!!+\rX!!!A5R`)!UD6iIrmN!!"!!L8)Ip31q-!!%J!!!&J!!!!J!)!!*!!(`!#1!!!!CJ\rI!$`iB!!%5!!!!@!!!!#3!(m!3S"r!%+6i`!!J')!!%J!!!&J!!!!X'%!8$J!!"k\r`!3"51'"!!%J!!!&J!!!!N!"K!&Ji!%!!N!!"!&b!!J!!N!!"!'#!(`"#N!!"!'5\r!!3"B+!!!!%##!"JiB!!h5!!!!@!!!!!iI`!!5!!!h$KK!$K)!!!"B!!!!(aJ"c3\rX!+BL3B)!,%#!!"`X!+BI3B)!5%#!!&JX!+BE3B)!+%J!!%`X!!!!3B)!@%J!!%!\riB!!h5!!!!@!!!!!iI`!!5!!!L$KJ!$G)!!!"B!!!!$Kr!!")!!"d1'!!'%J!!!&\rJ!!!!1(m!!%J!!'!iB!!b5!!!!@!!!!!iI`!!5!!!6$J!!!+B(`!Y1!!!!*JI!#`\ri!!!!N!!I!$!i!!!!X"m!,MKr!$3iJ!!!1+!!#%J!!!&J!!!!1!!!!*!!(`!qJ!%\r!9*!!(`!11(m!!)!"!,Ji)3#`I!J$TS2Krra1J!!J4A8!N!A-!!!!&%9d!`#3"-d\r!!!!F4A8!N!A1!!!!-%9d!`#3"-m!!!"%4A8!N!A3!!!!5%9e!*!&d3!!!'"&G!-\r!N!3N!!!!G%9e!*!&dJ!!!*4&G3#3"G-!!!#S4A8!N!A5!!!!k%9e!*!&dJ!!!2a\r&G3#3"G)!!!%34A8!N!A5!!!"*%9e!*!&e!!!!@"&EJd#!!!!eJ!!!"D!!*!(#!!\r!0!&N!!S!!)D!!"m!N!T&GJS-!!!!e`!!!"*&EJ`%!!!!f!!!!!b!!*!0!C!!!*!\r%4AF!N!A,!*!%4AF0!*!%eJ!!!!K&D`!%!!!!f3!!!I!!!!-d!!!E4h`)!UD6iIr\rmNm(rq*!!!3!)P#(rN!!li`!!N!#"!)b!J3#-5!!!!@!!!!#!!J!!N!!I!!)mB'P\rZ1'0PG*!!B3"%J!)!!*!!!3"!1'!!"%J!!!&J!!!!N!"r!%+!I`"#Nq-!!$J!!!#\r3!"m!2MKK!$K)!!!"B!!!!$aJFfNiJ3"%1+!!"$M"!%JiBfGZ5!!!!@!!!!!mB%P\r12)"86MLK!%Ji`2rr11!!!$N"!&JiBd981)4'@8J!!!&J!!!!1'%!@$b!8e3mS'a\r[1-%!M$MJ!!3iK&*01+9ZCdJ!!!&J!!!!1'%!@$b!39-mS'a[1-%!3$MJ!!3iK&)\rJ1+9ZCdJ!!!&J!!!!1'%!@$b!99-mS'a[10m!3MMJ!!3iK&*31+9ZCdJ!!!&J!!!\r!1'%!@$b!F(-mS("c1-%!1$MJ!!JiK'iJ1+9Z)%J!!!&J!!!!1'%!@$L"!&!iS!!\r$1-!!!6MJ!(Jj!!!!15!!!%J!!!&J!!!!1'%!8%J!!!&J!!!!1'%!@%J!!!&J!!!\r!1'%!5%J!!!&J!!!!1(m!!%J!!!&J!!!!1m-!!$J!!#L`!`!D5!!!!@!!!!#!(J!\rXN!!I!##J(J!`X"m!(MJ!!"#B(`!XJ"i!*T!!(`!`S"i!+V!I!#iiI`!!J!%!H$J\rK!("m#!1QJq(rr)2"rrK1J!!J4A8!N!AD!!!!)%9d!`#3"-d!!!!S4A3$!*!%*!!\r!!$a&G3#3"Fi!!!")4A8!N!AE!!!!D%9e!*!&h!!!!)4&G3#3"Gd!!!#X4A8!N!A\rH!!!!d%9e!*!&hJ!!!24&G3#3"Gi!!!%B4A8!N!AH!!!"2%9e!*!&h`!!!@"&G3#\r3"H!!!!&X4A8!N!AJ!!!"H%9e!*!&i!!!!B4&G3#3"H%!!!'3!%9e!*!&d`!!!D4\r&EJd#!!!!lJ!!!"D!!*!(%!!!6!'S!!S!!)D!!"m!N!T&GJS-!!!!e`!!!"*&EJ`\r%!!!!l`!!!!b!!*!0!I!!N!4&G`#3"GN!N!4&G`d!N!6Z!!!!#%9V!!3!!!$`!!!\r!k!!!"$B!!##RI!J#TT2Krrb6`IriN!!"!!L8)Ir!1q-!!$[%!!")!!!"B!!!!)!\r#!!#3!"m!!S!H!!k3!"m!$SJH!"+B(`!5L"i!%jJI!"1!(J!8N!!I!"5!(J!BN!!\rI!"L!IJ!FJ"i!)*!!I`!FN!!I!##!IJ!NJ"i!+*!!I`!NN!!I!#L!IJ!XJ"i!-*!\r!I`!XN!!I!$#!IJ!dJ"i!1*!!I`!dN!!I!$L)(J!mQ"m!2$J!!!#3!"m!2S!H!%+\r3!"m!3S"r!%+6i`!!1'!!"%J!!!&J!!!!N!"q!%+!IJ"#Nm-!!$Kr!!#!!3")1#%\r!3(`)!kD$iIrmJm(rq%k!!#"&G3#3"F`!!!!F4A3$!*!%c3!!!#4&G3#3"Fi!!!#\ri4@i0!J!!!2%!!!!@J!#3"a!!!,`![!!+!!#'J!!I!*!+4AB+$!!!!0F!!!!54@i\r-"!!!!2)!!!!-J!#3$ZJ!N!4&G`#3"I!!N!4&G`d!N!6a!!!!#%9V!!3!!!$c!!!\r$6!!!"'i!!#+5I!J#TVpKrqb3!!%!#*3Kri"mHaYjX)%!RS2L!!#$SJ!!3B)$&)!\r#!!#3!"X!!S!G!!#3!!%!@$J!!!#3!"d!!$Kl!!")!!!"B!!!!$[$!!!i!!!SX!-\r!'NJ!!!&J!!!!5!!!!@!!!!!X!`!!3))!,)!I!!!S!!!!3B)!-$KJ!!!iJ!!!JCm\r!!%J!!!&J!!!!,!-!!%'#!"3iB!!%5!!!!@!!!!")!!!-1!!!!*!!(3!!J"d!!#`\r!!!"!JJ!3S"i!1LJ!!!"!J[pm1(X!!%J!!!&J!!!!1m-!!$J!!!#3!!-!$$J!!#D\r`!`!D1!$r`*J$!#)i!!!mQ!-!)$J!!!'B!`!K5!!!!@!!!!")!!!"B!!!!#`$!!"\r!JJ!XJ"m!!#J!!!""JJ!`1'!!!$L!!!#"R`!!5!!!!@!!!!!X!`!!3B)!&$KJ!!4\r)!!!"B!!!!%J!!"Ji!!!!N!!G!!#S(J!3,!!!!8'#rkLS(J!3,!#Q)%'#!&"!J!!\rJ,!#Q(8'#!#a!J!!S,!#Q(%#!!$K)!!!F5!!!'#`!!!""JJ!S3)!!$#`!TL0"JJ!\rFJ"d!!#`!!!"!JJ&NJ!%!@*!!(3!!5!!"@+JH!"!X!!!!3))!l$Kl!!")!!!"B!!\r!!$[$!!!lJ!!!5!!!c$J!!!#3!"i!$$J!!#1`(J!D1!!!!CJH!#!i!3!iN!!H!#S\ri!!!%X"i!,MKq!!")!!!"B!!!!%J!!!&J!!!!,!-!!%##!#b!(`!!+!!!!%'#!$!\riB!!!1)!!!)'I!!")!!!"B!!!!#`$!!""JJ!81'!!"%J!!!&J!!!!5!!!'$J!!!#\r3!"d!!+JH!"!X!!!"3B,rU+JH!"!X!!!!3))!1$J!!#5`(J!D1!%!1*!!(J!U1(i\r!!%J!!!&J!!!!J"d!!#`!!!"!JJ!31j`!!5`F!!K"J2md1!!!+V!H!"SiIJ!!5!!\r!!@!!!!"mB!Fe3B)!()!G!!!X!!!!3))!2)!"!&L3!"d!!%J!!$#!IJ!J5!!!!@!\r!!!#!H`"#5!!!!@!!!!#!(3!!,!!!!%##!!b!!3"BN!!G!!!iH`!!1)!!!%J!!!&\rJ!!!!U!%!RL`!!!"!J3!31(X!!%J!!!&J!!!!1(X!!)!"!)Ji)3#!I!J$TVYKrqa\r1J!!J4A3$!*!%p!!!!"K&G!-!N!6e!!!!(%9d!`#3"-d!!!!N4A8!N!AK!!!!3%9\re!*!&d`!!!&4&G3#3"IB!!!"F4A8!N!Ah!!!!K%9e!*!&dJ!!!*K&G3#3"H%!!!$\r)4A8!N!Ai!!!!r%9e!*!&pJ!!!34&G3#3"IF!!!%X4A8!N!A5!!!"3%9e!*!&i3!\r!!FK&G3#3"IJ!!!))4A8!N!Af!!!#%%9e!*!&p`!!!MK&G3#3"G)!!!*-4A8!N!A\r6!!!#M%9e!*!&d`!!!VK&G3#3"IN!!!,N4A8!N!Ak!!!#m%9e!*!&q`!!!a4&G3#\r3"IS!!!-X4@i0!J!!!33!!!!5J!#3"bJ!!%3#p!!+!!##!!"B!*!'4AB+$!!!!38\r!!!!14@i-"!!!!3B!!!!-J!#3$30-!*!%4AF!N!Ac!*!%4AF0!!!!!33!!!!)4@X\r!K!!!!3F!!!"SJ!#3"h`)!UD6iIrmN!!"!!L8)Ir!I(mEHE#"!&j"JJ!iJ')!!)!\r$!!!X!!!!3))!%)!I!!#!BJ!!N!!$!!#S!3"H,!!!!%#"!"!iI`!!5!!!!@!!!!!\riI`!!J!%!5$JK!%"m#!1QJq(rr%k!!#"&G!-!N!6e!!!!(%9d!`#3"28!!!!`4A8\r!N!Ak!!!!5%9Z$!3!!!%)!!!!$)!!N!Z!!!"S#!!!!%9h!*!%!3F!N!4&D`!%!!!\r!i3!!!'!!!!@)!!!T8h`)!UD6iIrmNm(rq*!!!3!)P#(r`$[$!!#!BJ!!5!!!!@!\r!!!!li`!!J')!!%J!!!&J!!!!X(m!')!H!!k3!"m!(*2I!'BiI`!!J!%!5$JK!%"\rm#!1QJq(rr)2"rrK1J!!J4A3$!*!%c`!!!"K&G3#3"!%*!!!!(%9d!`#3"-m!!!!\rS4A8!N!A3!!!!,%9Z$!3!!!%+!!!!$)!!N!Z!!!"J%!!!!%9h!*!&i3#3"%9V!!3\r!!!%,!!!!@!!!"FJ!!#SAI!J#TT2Krrb3!!%!#*3Krm#3!'%!@)"K!&K)!!!"1q-\r!!$J!!#L`!`!D5!!!!@!!!!"mB!Fe3B)!$$KJ!!")!!!)S(m!2)!"!%Ji)3"!I!J\r$TS2Krra1J!!J4A8!N!AK!!!!'%9e!*!&d`!!!#K&EJ`%!!!"$!!!!!b!!*!,J!!\r!@!J!!!"&G`#3"!%,!*!%4@X!"!!!!3d!!!+d!!!''!!!,50m#!+Q[Z(rh*!!!3!\r)P#(rN!!lJ`!!N!#"!)b3!+%!N!#$SJ!!Jq)!!)0K!)b!!3#3!#`!!"""JJ!81'!\r!&NJ!!!&J!!!!5!!#B)JE!!%S!!!#3B)!&$KJ!#p)!!!"B!!!!%J!!N5)(!!m+!!\r!"%##!$#!(!!q,!!!!%'#!"3iB!!p5!!!!@!!!!")!!)F1'!!*8J!!!&J!!!!5!!\r#$)JF!$`S!!!"3B)!&$KJ!$K)!!!"B!!!!%J!!I!i!!!%Q"`!2$Km!!")!!!"1m-\r!!)!#!!#3!!-!$$J!!##`!`!D1!$r`*J$!#)i!!!mQ!-!)$J!!!'B!`!K1!!!!*J\r$!#1!H`!%2!1"!#J!!!&!JJ!35!!!!@!!!!")!!!)J(X!"*!!IJ!NS"X!!V!H!#J\ri!!!!N!!H!#UJ(!!HX"i!,MJ!!!#B(J!b1!!!!*JH!$-i!!!!Q"i!0$J!!!#B(J!\re1(i!!%J!!!&J!!!!1d-!!(p!"c9"JJ!F1!!!!CJF!$ar3`Fd5!!!!@!!!!")!!%\rJL"`!%bJ!!!""JJ!81'!!*%J!!!&J!!!!5!!"")!I!!#3!!%!1$J!!!#3!"m!!%J\r!!!&J!!!!,!-!!%##!#b!(3!!+!!!!%'#!$!iB!!!1)!!!)'G!!")!!!"B!!!!#`\r$!!""JJ!81'!!"%J!!!&J!!!!5!!!'$J!!!#3!"m!!+JH!"!X!!!"3B,rU)!I!!!\rX!!!!3))!%+JH!"!X!!!!3B)!C$J!!!'B(!!mJ"m!!#`!!!""JJ!N1b$rri!I!!!\rX!!!!3))!$)!"!$L3!"m!!$Kj!!")!!"-U(i!%%J!!!&J!!!!1`-!!)!I!!!X!!!\r!3))!$)!"!$L3!"m!!$Ki!!")!!!J1Z!!!)!I!!!X!!!!3))!$)!"!$L3!"m!!$K\rh!!#!!3"i1#%!F(`)!kDkiIrF6S!!)%9d!`#3"23!!!!F4A3$!*!%p3!!!#"&G3#\r3"G)!!!!i4A8!N!A5!!!!9%9e!*!&dJ!!!(a&G3#3"G)!!!#-4A8!N!A5!!!!U%9\re!*!&i3!!!-"&G!-!N!5m!!!!b%9e!*!%!3i!!!%)4A8!N!Ai!!!"@%9e!*!%!3m\r!!!&i4A8!N!A5!!!"P%9e!*!&pJ!!!E"&G3#3"IF!!!(B4A8!N!A5!!!"l%9e!*!\r%!3m!!!*F4@i0!J!!!43!!!!5J!#3"dJ!!E3#B!!+!!##!!!i!*!'4AB+$!!!!38\r!!!!14@i-"!!!!48!!!!-J!#3$3+d!*!%4AF!N!3"$3#3"%9h$3!!!!%8!!!!#%9\rV!!3!!!%@!!!"p!!!"dB!!$2hI!J#TVmKrq53!!%!#*3Krk!lJ`!!Jq)!!)2#!!#\r)!`!m+!!!!8'#!"3iB!!i5!!!!@!!!!")!!'X1!!!!TJF!$`iI!!!5!!!!6ZM!!#\r!BJ!!5!!!!@!!!!#`I3!BJ!)!!*!!(3!-1!!!(l!G!"Si!2r!Q"d!)MJ!rrqB(3!\rJ1!!!!*JG!#%i!!!!Q"d!)cJ!!!#3!"d!*$J!!!#`(3!S1!!!!*!!(3!US"`!(V!\rG!#ii!!!!Q"d!-MJ!!!#B(3!c1!!!!*JG!$3i!!!!Q"d!06Kp!!")!!!"B!!!!$Y\rM!!"rB!Fe3B)!($J!!!'B(!!mIf-(0%J!!!&J!!!!5!!!k)!H!!#3!!%!1$J!!!#\r3!"i!!%J!!!&J!!!!,!-!!%##!#b!(`!!+!!!!%'#!$!iB!!!1)!!!)'I!!")!!!\r"B!!!!#`$!!""JJ!81'!!"%J!!!&J!!!!5!!!'$J!!!#3!"i!!+!G!#iS!!!!3B,\rrU)!H!!!X!!!%3B,rR)!H!!!X!!!!3B)!1)!H!!!X!!!%3B)!,$J!!!'B(!!m1d$\rrri!H!!!X!!!!3))!$)!"!$L3!"i!!$Kk!!")!!!`J"d!+T!!(!!JS"d!,V!F!"i\rl)!!!J"i!!#`!!!"!JJ!-J!%!1*!!(J!!1(N!!)!"!'Ji)3"JI!J$TVXKrq41J!!\rJ4A3$!*!%p!!!!"4&G!-!N!6e!!!!'%9e!*!&dJ!!!#a&G3#3"H%!!!"%4A3$!*!\r%c`!!!%a&G3#3"G!!!!"34A3$!*!%`!!!!&a&G3#3"IJ!!!$34A8!N!3"$`!!!2"\r&G3#3"IB!!!%-4A8!N!Ah!!!"0%9e!*!&dJ!!!8K&EJd#!!!"&`!!!"+!!*!(1!!\r"%!&-!!S!!))!!$J!N!C&GJS-!!!""3!!!!j&EJ`%!!!"'!!!!!b!!*!0!I3!N!4\r&G`#3"!%@!*!%4AF0!!!!!4F!!!!)4@X!"!!!!4N!!!0`!!!)#J!!194m#!+Q[d(\rrk*!!!3!)P#(rX$[M!!#3!)%!E$Y&!!#$`J!!L!-!2#J!!!&!JJ!mJ"m!2L`!!!"\r"JJ!JJ(m!2NJ!!!&J!!!!1!!!!*!!(`!q1'!!!%J!!``iB!!j5!!!!@!!!!")!!,\rmL"m!2#J!!!*"JJ!XL"m!2#J!!!0"JJ!JL"m!2#J!!!G"JJ!81'!!18J!!!&J!!!\r!5!!#b)JI!$`S!!!#3))!V)JI!"-S!!!!3B)!&$KJ!!Y)!!!"B!!!!%J!!U")!!!\r"B!!!!#`$!!"!JJ!XJ"i!!#J!!!""JJ!d1'!!!$L!!!#"RJ!!5!!!!@!!!!!X!`!\r!3B)!'$KJ!!4)!!!"B!!!!$KJ!!")!!*8L"m!2#J!!!*"J[qXL"m!2#J!!!0"JJ!\rXL"m!2#J!!!G"JJ!JJ(m!2NJ!!!&J!!!!1!!!!*!!(`!q1'!!!%J!!K5)(`!m+!!\r!!d##!!`i!!!&5!!!#$J!!!'B(`!m1'!!4NJ!!!&J!!!!I(XEH8'#!"!iH`!!1*m\r!!%J!!!&rI0Yj3))!C$Kr!!")!!!"1!!!*l!$!"T)!!!"B!!!!$J!!!'B(`!m1(m\r!!$L!!!@"R`!#JB`!%%J!!!&J!!!!,!-!!%#!!"3i!!!"Q"m!2$KJ!!")!!'!1'!\r!$%J!!!&J!!!!5!!"F$J!!!'B(`!m1(m!!%J!!!%lS`!!1!!!(V!$!"SiB%!!5!!\r!!@!!!!#3!(d!)$J!3!#3!"d!*)!#!!#3!"d!+)!I!%+3!"d!,)!G!#!S!!!!3))\r!&$KJ!$G)!!!"B!!!!%J!!4!iI3!!5!!!!@!!!!"mB!Fd,!#Q)N'#!#a!J!!F,!#\rQ(d'#!%"!J!"-,!#Q'd'#!#4)!!"!,!!!!%'#!%K)!!!d1'!!0dJ!!!&J!!!!5!!\r!`$KJ!$G)!!!"B!!!!%J!!,!iB!!B5!!!!@!!!!")!!#J1'!!-NJ!!!&J!!!!5!!\r!N!!i!!!#Q"m!,6J!!!#B(`!X1!!!!*!!(`!`1!!!!,!I!#iiI`!d1)!!!$LJ!!K\r)!!!"B!!!!$J!!!#3!"m!2S!G!"b3!"m!$MKr!!!iJ!!&JCm!!S'-!"")!!!"B!!\r!!)"K!'`iR!!XJ"S!!#`!!""!J!!-J,S!!%J!!!JiS!!3N!#k!!")!!!"B!!!!$K\rm!!#!!3"B1#%!8(`)!kDl3IrS6S!!)%9d!`#3"23!!!!F4A8!N!3"$`!!!$a&G3#\r3"!%D!!!!@%9e!*!%!4S!!!#-4A8!N!3"'J!!!,4&G3#3"IB!!!$!4A8!N!Ah!!!\r!k%9e!*!&dJ!!!2a&G3#3"!%2!!!"0%9e!*!&cJ!!!@a&G3#3"I!!!!'%4A8!N!A\rK!!!"P%9e!*!&d`!!!D"&G3#3"IF!!!(!4A8!N!3"'J!!!H4&G3#3"H%!!!(m4A8\r!N!A4!!!#%%9d!`#3"#3!!!)N4A8!N!3"'J!!!N4&G3#3"G-!!!*84A8!N!3"'J!\r!!T4&G3#3"!%D!!!#T%9e!*!%!4S!!!+d4A8!N!3"'J!!!X4&G3#3"G3!!!,m4A8\r!N!Ah!!!$*%9e!*!%!4X!!!034@i0!J!!!4i!!!!5J!#3"c!!!BJ"L!!+!!#+J!!\rE!*!'4AB+$!!!!4m!!!!14@i-"!!!!5!!!!!-J!#3$30`!*!%4AF!N!3"'3#3"%9\rh$3!!!!%H!!!!#%9V!!3!!!%K!!!#r!!!#93!!%M4I!J#TVp"rqL3!!%!#*3Krl!\rl``!!N!#"!'`lK3!!I2SlHC%"!(b$iJ!!3B)!)$Kq!!!iQJ!!J+%!I)'H!!+"M!!\rX5!!!!@!!!!#)(J!59!!([8'#!"3iB!!k5!!!!@!!!!")!!+)L"i!2#J!!!4!JJ"\rdL"i!%bJ!!!""JJ!81'!!#dJ!!!&J!!!!5!!#B%J!!!&J!!!!,!-!!%##!#b!(`!\r!+!!!!%'#!$!iB!!!1)!!!)'I!!")!!!"B!!!!#`$!!""JJ!81'!!"%J!!!&J!!!\r!5!!#')JH!$`S!!!%3B,rX)JH!$`S!!!&3B)!D)JH!$`S!!!'3))!$$KJ!!")!!(\rXL"i!2#J!!!&!JJ!iJ"i!2L`!!!""JJ!XJ"i!2L`!!!&"JJ!JJ(i!2NJ!!!&J!!!\r!1!!!!*!!(J!q1'$rrdJ!!D`iB!!j5!!!!@!!!!")!!'F1(i!!)'H!!+"M!"N5!!\r!!@!!!!!lB`!!L"i!%bJ!!!""JJ!F+"X!!%##!"3iB!!,5!!!!@!!!!")!!&JJ!%\r!E*!!(J!81!!!!*!!(J!B1!!!!C!!(J!q1(i!!%J!!!%lS`!!J!)!!*!!!`!-1!!\r!*E!$!"Si!!!!Q!-!))!H!"53!!-!*$aJ!!%iBrrrI"`B!%#!!!`iI!!!5!!!$$a\rJ!!%iBrrrX(d!+$Kp!!")!!!"B!!!!%J!!!&J!!!!,!-!!%##!#b!(`!!+!!!!%'\r#!$!iB!!%1*`!!)'I!!")!!!"B!!!!#`$!!""JJ!81'!!"%J!!!&J!!!!5!!!T+J\rG!"!X!!!"3B,rX+JG!"!X!+BB3))!$$J!!!#`(3!3U"d!%#`!TKp"JJ"X3)!!,#`\r!TKY"JJ"J3)!!%#`!TKK"JJ"85!!!8#`!TKe"JJ")3)!!4%J!!$JX!+BM3B)!-%#\r!!"!X!+BK3B)!,%J!!#JX!!!!3B)!#%J!!"`i!!!!N!!H!$k!IJ!B5!!!')"q!"K\r)!!!3U(d!%%J!!!&J!!!!J!%!@$JK!&"m#!1QZd(rk%k!!#"&G!-!N!6d!!!!*%9\re!*!&p`!!!%"&G3#3"G)!!!"B4A8!N!A5!!!!J%9e!*!&pJ!!!)a&G3#3"IF!!!#\rd4A8!N!A5!!!!b%9e!*!%!3m!!!%S4A8!N!A5!!!"4%9e!*!&p`!!!9a&G3#3"G)\r!!!'!4A8!N!AK!!!"U%9d!`#3"-8!!!'`4A8!N!Ai!!!"q%9e!*!&pJ!!!J"&G3#\r3"IF!!!)S4A8!N!A5!!!#2%9e!*!%!3m!!!,J4@i-"!!!!58!!!!-J!#3#i!!![`\r`!!!!4AF!N!3")3#3"%9V!!3!!!%Q!!!%&!!!#TS!!&A1I!J#TVkKrp53!!%!#*3\rKrh!l3`!!1`3!!$[&!!!kTJ!!N!$K!,L#`J!!Jq)!!)J$!"*8!!Gl3B)!&$KJ!$T\r)!!!"B!!!!%J!!lb!!3#i+!!!!%'#!"3iB!!Y5!!!!@!!!!")!!1JL"S!2#J!!!9\r"JJ!JL"S!2#J!!!4"JJ!81'!!18J!!!&J!!!!5!!$H)JD!$`S!!!%3))!G)JD!"-\rS!!!!3B)!&$KJ!#9)!!!"B!!!!%J!!e")!!!"B!!!!#`$!!"!JJ!XJ"m!!#J!!!"\r"JJ!`1'!!!$L!!!#"R`!!5!!!!@!!!!!X!`!!3B)!&$KJ!!4)!!!"B!!!!%J!!`L\r)'J!m+!!!"%'#rl#)'J!m+!!!"8'#!%L)'J!m+!!!!8##!#b!'J!q,!!!!%'#!##\r!HJ!q5!!!!@!!!!!i!!!!N!!D!$iiB2rr5!!#[$KJ!$P)!!!"B!!!!%J!!U`iHJ!\r!5!!!!6YM!!!i!!!SX!-!'NJ!!!&J!!!!I'!(08'#!!`ki!!!5!!!'+"l!$UJ'`!\rfIZ-!88#!!!Jki!!!L"S!%bJ!!!""JJ!S,"F!!%##!"3iB!!,5!!!!@!!!!")!!*\r)I"I`!%#!!!Jle`!!1[i!!$KK!$JiJ!!!1+!!)%J!!!&J!!!!1k%!1$Z!!!")!!'\rFJ"S!2L`!!!""JJ!JJ(S!2NJ!!!&J!!!!1!!!!*!!'J!q1'$rrdJ!!I!mB!!"1'2\rrrh`H'!"!J!!-1ci!!%J!!)3r)!!"1cRrrdJ!!(KrJ`Fd1!-!!A`F&R"rR!'89j`\r31RqF!""rJ!Fe3B)!$$Zp!!K)!!!)1k%!1%J!!!&J!!!!,!-!!%##!#b!(`!!+!!\r!!%'#!$!iB!!&1*i!!)'I!!")!!!"B!!!!#`$!!""JJ!81'!!"%J!!!&J!!!!5!!\r"@+!G!!!S!!!!3),rK,-p!!#6(3!#1(S!!%J!!!%lB`!!NX-!$$J!!#+`!`!D1!$\rr`*J$!#)i!!!mQ!-!)$J!!!'B!`!K2+!!!9I%$riiTIrrI+2qF(`H+""m!b%8Q"X\r!)eDJ"rkB'`!NNlX!*MJ!!!#3!"X!+MJ!!!#`'`!Z1(X!!%J!!!&J!!!!5!!!!@!\r!!!!X!`!!3))!,)!I!!!S!!!!3B)!-$KJ!!8iRJ!!JCm!!%J!!!&J!!!!,!-!!%'\r#!"3iB!!%5!!!!@!!!!")!!#)IpR`8(mBbK3X(J!!3B(qC%J!!!&J!!!!,!-!!%#\r#!#b!(`!!+!!!!%'#!$!iB!!&1)!!!)'I!!")!!!"B!!!!#`$!!""JJ!81'!!"%J\r!!!&J!!!!5!!!-+JE!"!X!!!"3B,rX+JE!"!X!!!!3))!$$Kh!!")!!!3U(X!%%J\r!!!&J!!!!J!%!Q$JK!*!!I!J$TVUKrp41J!!J4A3$!*!%b3!!!#4&G!-!N!6d!!!\r!+%9e!*!&dJ!!!$a&G3#3"G)!!!"B4A8!N!A5!!!!J%9e!*!&dJ!!!+K&G3#3"IB\r!!!#d4A8!N!Ah!!!!h%9e!*!&dJ!!!2"&G3#3"!%2!!!"-%9e!*!&dJ!!!8a&G3#\r3"H%!!!&F4A8!N!A6!!!"E%9e!*!&dJ!!!E"&G3#3"G3!!!(B4A8!N!A5!!!"r%9\re!*!&pJ!!!Q4&G3#3"IF!!!+-4A8!N!A5!!!#S%9e!*!&i3!!!X4&G3#3"IJ!!!-\rX4A8!N!Af!!!$0%9e!*!&p`!!!ea&G3#3"G)!!!0`4A8!N!Af!!!$M%9e!*!&p`!\r!!l4&G3#3"G)!!!2)4A8!N!3"$`!!!rK&EJ`%!!!"-3!!!!b!!*!,J!!%&&J!!!"\r&G`#3"!%Q!*!%4@X!"!!!!6)!!!$F!!!-U!!!B3Pm#!+QNq(rr*2"rrL6SIrdNi(\rrm*!!!3!)P#(rX$ZM!!"mRL0j1i8!!$[J!!""JJ"XL"d!2#J!!!G"J3"JJ')!!&3\r!%$TmB`!ZI'N$TNk!"#!i!!!"Q"i!!$[r!!&)!!!m1(d!!)'G!!+"M!"N5!!!!@!\r!!!!S!`!!3B)!)$J!!!'B(J!!1rm!!8J!!"!i!!!"Q"i!!$[r!!%S(!!!3B)!()J\rG!$`X!!!%3B)!%$J!!!'B(!!!1rm!!6Kr!!#!!3"B1#%!8(`)!kD$iIrmJm(rq)1\rKrr5$JIr`6S!!)%9d!`!!!!%c!!!!2%9e!*!&p`!!!'a&EJ8%!!!"-`!!!##!!*!\r+Q!!!!)`!!!#B!!!!8!!!!*J!!!"J!!!!M!!!!&"&GJ#3"!%b!*!%4AB!N!3"-J!\r!!!4&GJ#3"!%b!!!!#%9f!*!%!6)!!!!-4AB!N!3"-J!!!""&GJ#3"!%b!!!!&%9\rf!*!%!6)!!!!B4AB!N!3"-J!!!"a&EJ`%!!!"0`!!!!b!!*!,J!!!h#!!!!"&G`#\r3"!%b!*!%4@i&!3!!!6J!!!!+rrrraJ!!B3P83e"6Ef0VCA3!"2*&EJ8"!!!"13!\r!!!Irrrr&!!"K#90[BfYPG!$(4@i&"!!!!6S!!!!)rrrra!!!B3N!N!K&GJ8!!!!\r"13#3"%9Z"3%!!!%l!!!!#rrrrm-!!'%*58j&9&0[BfYPG!!i4@i&"!!!!6`!!!!\r-rrrr`J!!B3N!N!a&GJ8!!!!"1J#3"%9Z"33!!!%p!!!!#2rrrm%!!'%*!*!)4AB\r&!!!!!6X!N!4&GJ8!!!!"2!!!!!4&EJ8%!!!"2J!!!"6rrrr!!!"K#3#3&%9f"3!\r!!!%p!!!!#%9f"3!!!!%k!*!%4@i&"!!!!6m!!!!)rrrr[`!!B3N!N!K&GJ8!!!!\r"1!#3"%9f"3!!!!%q!!!!"%9["33!!!$0!!!!D2rrrli!!'%*!*"S4AB&!!!!!6m\r!N!4&GJS!!!!"3!!!!&a&GJS!!!!"33!!!&4&GJS!!!!"3J!!!%a&GJS!!!!"3`!\r!!%K&GJS!!!!"4!!!!%4&GJS!!!!"43!!!%"&GJS!!!!"4J!!!$4&GJS!!!!"4`!\r!!$"&GJS!!!!"5!!!!"a&GJS!!!!"53!!!"K&GJS!!!!"5J!!!&"&GJS!!!!"5`!\r!!$a&GJS!!!!"6!!!!$K&GJS!!!!"63!!!#a&GJS!!!!"6J!!!#K&GJS!!!!"6`!\r!!!K&GJS!!!!"8!!!!&K&GJS!!!!"83!!!#4&GJS!!!!"8J!!!#"&GJS!!!!"8`!\r!!"4&GJS!!!!"9!!!!""&GJS!!!!"93!!!!a&GJS!!!!"9J!!!'4&GJS!!!!"9`!\r!!'"&E`S%!!!"8!!!!!L!!*!24AB!N!3"-J#3"%9f$`!!!!&B!!!!"%9[#J3!!!&\r4!!!!#)!!N!p&GJ#3"!%Q!*!%4AB2!!!!!9J!!!!%4@m+"!!!!9)!!!!)J!#3$d9\rf!*!%!5%!N!4&GJm!!!!"@!!!!!4&E`S%!!!"8`!!!!L!!*!24AB!N!3"'3#3"%9\rf$`!!!!&B!!!!"%9[#J3!!!&8!!!!#)!!N!p&GJ#3"!%@!*!%4AB2!!!!!9J!!!!\r%4@m+"!!!!98!!!!)J!#3$d9f!*!%!3d!N!4&GJm!!!!"@!!!!!4&E`S%!!!"9J!\r!!!L!!*!24AB!N!3"#`#3"%9f$`!!!!&B!!!!"%9[#J3!!!&C!!!!#)!!N!p&GJ#\r3"H%!N!4&GJm!!!!"@!!!!!4&E`U%!!!""3!!!!L!!*!24AB!N!3""`#3"%9f$`!\r!!!&B!!!!"%9[#J3!!!&A!!!!#)!!N!p&GJ#3"I-!N!4&GJm!!!!"@!!!!!4&E`S\r%!!!"@J!!!!L!!*!24AB!N!A`!*!%4AB2!!!!!9J!!!!%4@m+"!!!!9X!!!!)J!#\r3$d9f!*!&f3#3"%9f$`!!!!&B!!!!"%9[#J3!!!&F!!!!#)!!N!p&GJ#3"FX!N!4\r&GJm!!!!"@!!!!!4&E`S%!!!!bJ!!!!L!!*!24AB!N!A(!*!%4AB2!!!!!9J!!!!\r%4@m+"!!!!-B!!!!)J!#3$d9f!*!&`J#3"%9f$`!!!!&B!!!!"%9[#J3!!!$"!!!\r!#)!!N!p&GJ#3"Ei!N!4&GJm!!!!"@!!!!!4&E`S%!!!![3!!!!L!!*!24AB!N!8\re!*!%4AB2!!!!!9J!!!!%4@m+"!!!!$3!!!!)J!#3$d9f!*!&!3#3"%9f$`!!!!&\rB!!!!"%9Z!`3!!!%c!!!!")!!N!Y&GJ8!!!!"-`#3"%9[!`3!!!$*!!!!")!!N!Y\r&GJ8!N!6*!*!%4@m$"!!!!-8!!!!%J!#3#d9f"3#3"-8!N!4&E`-%!!!!`!!!!!5\r!!*!,4AB&!*!%`!#3"%9[!`3!!!#m!!!!")!!N!Y&GJ8!N!5m!*!%4@m$"!!!!23\r!!!!%J!#3#d9f"3#3"23!N!4&E`-%!!!!p3!!!!5!!*!,4AB&!*!%p3#3"%9[!`3\r!!!!N!!!!")!!N!Y&GJ8!N!3N!*!%4@m$"!!!!-m!!!!%J!#3#d9f"3#3"-m!N!4\r&E`-%!!!!c3!!!!5!!*!,4AB&!*!%c3#3"%9[$`3!!!&B!*!%J!#3"d9S!!"6@8e\r)!!!00!!!!%)!!!!'!*!B"X8!!!"3!!!(1!!!!&`!!!GH!!!!C!!!"hX!!!"m!!!\r(cJ!!!)J!!!Ip!!!!P!!!#%!!!!#J!!!)CJ!!!+J!!!L$!!!!Y!!!#,!!!!$-!!!\r*"!!!!0J!!!Ne!!!!j!!!#Ai!!!$`!!!*T!!!!2J!!!R-!!!"+!!!#G[rN!3!!!R\rE!!-!!!!%!!!!#J%$!!!!AJ!!!!8!!!"Q!3-!!!"J!!!!"[q3"!#3"4m!N!J+T3!\r!!$3!!!XI!!!!C!!!$'S!!!"`!!!-NJ!!!(J!!!b`!!!!U!!!$,rrN!3!!!br!!-\r!!!!frrrrm`%!N!3G!!!!1Irrrp%!N!8H!!!!"[q3"!#3"4m!N!J0TJ!!!&J!!!i\rF!!!!K!!!$im!!!#8!!!2l!!!!+!!!"!6!!!!V!!!%$F!!!#d!!!36`!!!13!!""\rHrj!%!!!3AJ!$!!!!0[rrrr-"!*!%(3!!!$Rrrrr4!*!&(J!!!!ErN!3!N!8I!*!\r)%6m!!!!d!!!4[`!!!$`!!")(!!!!9!!!%N`!!!"J!!!5E`!!!'J!!"+%!!!!Q!!\r!%T2rN!3!!"+6!!3!!!!frrrrm`%!N!3F!!!!``!!!!-!N!8I!!!!1Irrrp%!N!8\rG!!!!"[q3"!#3"4i!N!J6E!!!!*3!!"2M!!!!V!!!&,S!!!$!!!!9D3!!!0!!!"A\r!!!!!k!!!&J8!!!$d!!!@+!!!!2`!!"Bp!!!",!!!&NcrN!3!!"C-!!-!!!!frrr\rrm`%!N!3G!!!!1Irrrp%!N!8H!!!!"[q3"!#3"4m!!3#3"KGL!!!!-!!!&k8!!!"\r)!!!Ad`!!!'!!!"JH!!!!N!!!!"NR!!!!T!!!'8d!!!$N!!!C[!!!!2J!!"Rj!!!\r"$!!!'MB!!!%J!!!DCJ!!!63!!"U+!!!"B!!!'a(rN!3!!"Y%!!)!!!$9rj!%!3#\r3""m!!!!frrrrm!!$!!!!1!!"!*!''fm!!!")!!!F+!!!!'J!!"aP!!!!K!!!((m\r!!!#X!!!Fc`!!!0!!!"dj!!!!p!!!(B`!!!%B!!!Gi3!!!6`!!"i`!!!"B!!!(UF\r!!!&X!!!Hp!!!!AJ!!"m1!!!"K!!!(bN!!!'3!!!!(eF!!!'N!!!IK2q3"!!!)+3\r!#3!!!0ArN!3"!*!%(`!!!"%!!!!#!3-!!!#-!!!!0[rrrp%!N!8H!!!!i[rrrp!\r!!`!!!$J!!!$Qrrrrp!!$!!!!3!!!!1F!!!!$!!-!!!"%!!!!k2rrrmm!!`!!!%J\r!!!$Xrrrrc`!$!!!!8!!!!1hrrrr2!!-!!!"B!!%!N!BJcJ!!!,J!!#*Erj!%!!!\rLM`!#!!!!eIq3"!%!N!3I!!!!"[q3"!%!N!3H!!%!N!BLUJ!!!$`!!#,E!!!!9!!\r!)``!!!"F!!!M53!!!+`!!#0-!!!!a!!!)iN!!!$m!!!NS!!!!33!!#6a!!!"B!!\r!*38!!!'J!!!PT`!!!E3!!#@b!!!"Z!!!*Em!!!(%!!!Q*3!!!G`!!#Ca!!!##!!\r!*h)!!!)3!!!Rb3!!!Q`!!#I5!!!#H!!!*r-!!!+-!!!S9!!!!U!!!#L2!!!#V!!\r!+,!!!!+i!!!Sc!!!!Y`!!#Ma!!!#i!!!+2X!!!,X!!!T3rq3"!!!+9!!"3!!!0A\rrN!3"!*!%'`!!!2`!!!!$!*!&(!!!!2hrrrr1!!-!!!!i!!!"!Irrrm`!!`!!!&J\r!!!!frrrrd3#3"4i!!3#3"LP`!!!!(!!!+A-!!!!X!!!TRIq3"!!!+K3!!J!!!0A\rrN!3"!*!%(J!!!$Errrrc!*!&(`!"!*!'+M8!!!!B!!!U5!!!!#J!!#Te!!!!1!!\r!+TS!!!"!!!!UV2q3"!!!+Y8!!J!!!0ArN!3"!`!!!&J!!!!frrrrd3#3"4m!!3#\r3"LeA!!!!0!!!,Hd!!!"%!!!Z#J!!!&!!!#iY!!!!B!!!,RS!!!"X!!!ZS3!!!(J\r!!#kb!!!!L!!!,Yd!!!#B!!!Zq`!!!+3!!#mM!!!!Y!!!,d%!!!$!!!![B`!!!9J\r!!$)f!!!"E!!!-Q8!!!&i!!!bL!!!!B3!!$+N!!!"N!!!!$+h!!!"S!!!-bB!!!'\r`!!!c9`!!!J`!!$0E!!!#*!!!-hS!!!)i!!!cVJ!!!PJ!!$2$!!!#K!!!-qVrN!3\r!!$2d!!F!!!$9rj!%!3#3""`!!!%3!!!!C!%$!!!!M!!!!4%!!!!$!3-!!!#3!!!\r!!3(rrrr-!!-!!!!i!!!!0[rrrp%!N!8H!!!"%[rrrmX!N!8E!!!"%`!!!!X!N!8\rD!!%!N!Bd%J!!!#J!!$4E!!!!1!!!0(N!!!"%!!!dT!!!!&!!!$5r!!!!d!!!0iJ\r!!!$N!!!hYJ!!!2!!!$IF!!!!r!!!1!d!!!%-!!!iE3!!!@J!!$K`!!!"G!!!1)i\r!!!'-!!!iV`!!!D3!!$M9!!!"Y!!!118!!!(8!!!j4rq3"!!!19%!"!!!!0ArN!3\r"!*!%(!!!!3(rrrr-!!-!!!!i!!!!0[rrrp%!N!8G!!!"%`!!!!X!N!8E!!%!N!B\rjL3!!!#`!!$RC!!!!1!!!1H`!!!"8!!!k,J!!!'3!!$TF!!!!L!!!1X3!!!#B!!!\rkmJ!!!+3!!$XD!!!!X!!!1bi!!!$!!!!l[J!!!4J!!$[Z!!!"-!!!2$F!!!&-!!!\rp0!!!!@`!!$f2!!!"N!!!!$hN!!!"S!!!2K3!!!(!!!!qM3!!!G!!!$kR!!!"i!!\r!2[B!!!(`!!!rQ3!!!I`!!$qm!!!#%!!!2rB!!!*!!!""!J!!!P!!!%%[!!!#N!!\r!!%'G!!!#S!!!3HF!!!+`!!"#-3!!!X!!!%*Y!!!#d!!!3Ti!!!,m!!"$)3!!!b3\r!!%1$rj!%!!"%'`!&!!!!eIq3"!%!N!3I!!!"(!!!!'3"!`!!!'`!!!%GrrrrbJ%\r!N!3D!!!!0[rrrp%!N!8G!!!!"[q3"!#3"4`!!3#3"NNP!!!!,!!!59J!!!")!!"\r*G3!!!&3!!%QB!!!!C!!!5H8!!!"`!!"+$`!!!(`!!%SM!!!!M!!!5TX!!!$J!!"\r+`3!!!1`!!%VY!!!!q!!!5a)!!!%!!!",93!!!53!!%ZN!!!"3!!!6!8!!!&3!!"\r-*`!!!A3!!%a#!!!"I!!!6'-!!!'-!!"-K`!!!DJ!!%c*!!!"q!!!6J!!!!)!!!"\r1cJ!!!P3!!%l5!!!#B!!!6[J!!!*S!!"2%!!!!X3!!%mj!!!#e!!!6jJ!!!,F!!"\r3CIq3"!!!8)J!"`!!!0ArN!3"!*!%(J!!!5)!!!"N!3-!!!"X!!!")`!!!!-"!*!\r%(!!!!4`!!!"N!3#3""S!!!%GrrrrbJ%$!!!!I!!!!53!!!!#!*!&'`!!!$Errrr\r4!*!&(3!"!*!'9KN!!!!i!!"@V!!!!%J!!&E-!!!!9!!!9ZX!!!"N!!"A#`!!!(`\r!!&G8!!!!M!!!9k!!!!#B!!"Ab3!!!+3!!&IG!!!!Y!!!@&-!!!%)!!"BH3!!!43\r!!&M2!!!",!!!@3X!!!&)!!"CE!!!!9J!!&Q1!!!"E!!!@Ed!!!&m!!"CiJ!!!B3\r!!&Rh!!!"P!!!@PF!!!'B!!"DC`!!!D3!!&Tk!!!"V!!!@SN!!!'m!!"DX!!!!F3\r!!&V'!!!"b!!!@YF!!!(B!!"E&3!!!H`!!&[K!!!"q!!!@r3!!!)8!!"F0`!!!M3\r!!&ad!!!#1!!!A*B!!!*B!!"G"3!!!Q!!!&dF!!!#C!!!A9B!!!+X!!"GDJ!!!VJ\r!!&f)!!!#a!!!AGX!!!-X!!"IqJ!!!c3!!'"!!!!$I!!!B%3!!!1%!!"JIJ!!!i`\r!!'#f!!!$i!!!B,S!!!2X!!"Jc`!!!r3!!'$Qrj!%!!"K"J!,!!!!eIq3"!%!N!3\rD!!!")J!!!'3"!*!%'!!!!5F!!!!$!3#3""i!!!%S!!!!!`%!N!39!!!"+3!!!'3\r"!`!!!,J!!!%Urrrrb3!$!!!!1!!!!$Errrr4!*!&'`!!!5d!!!!,!*!&(!!!!5l\rrrrr(!*!&(3!!!5m!!!!$!*!&'3!!!6!!!!!$!*!&&`!"!*!'B9%!!!!`!!"KH!!\r!!&!!!'(&!!!!B!!!BJi!!!"m!!"L*3!!!)`!!'+4!!!!Q!!!BX!!!!#J!!"Ld!!\r!!,J!!'-qrj!%!!"M6J!%!!!!eIq3"!%!N!3G!!!"0!!!!'J"!*!%(J!!!68!!!"\rS!3#3""`!!!%f!!!!!`#3"4m!![rrrr`!!!!,!!!!"J!#!!!!$!!!!!X!N!F0!!!\r!C!!!!!)!![rrrrS!!!!F!!!!"!!"!!!!(3!!!!)!N!8"rrrrq3!!!!J!!!!"!!!\r!"`!#rrrrq`!!!"F!!!!3!!8!!!!B!!!!"J#3"aN!!!!'!!!!!3!!!"S!!!!+!!!\r!!J!!!"[rrrrk!!!!"!!!!"lrrrrj!!!!#!!#rrrrr3!!!!N!!!"#!!d!!!!+rrr\rrr!#3"`i!!!"N!!!!"J!!!!m!!!!,!!!!#J!!!"!!!!!,!!!!$!!!!"%!!!!#!!!\r!$J!!!")!!!!'!!!!%J!!!"-!!!!'!!!!%`!!!"3!!!"Q!!!!&!!!!"8!!!!$!!!\r!'!!!!"Errrrl!!!!(!!!!"rrrrrl!!!!,!!!!#!!!!!'!!!!2!!!!#%!!!!$!!!\r!2J!!rrrrq!!#rrrrrJ!#rrrrrJ!!!!F!!!"'!!)!!!!)rrrrr3#3"b,rrrri!!!\r!3J!!rj!%!!(rrrrq!!$rrrrd!!%!!!"U!!,rrrre!!!!,J!!!"3!"`!!!#m!!!!\r#!*!(+3!!!!F!!!!%!!!!-!!!!!F!!!!&!!!!-3!!!!S!!!!'!!!!-[rrrr3!!!!\r)!!!!+J!!!!)!!!!-!!!!-`!!!!)!!!!3!!(rrrrf!!!!&!!!!"6rrrre!!,rrrr\rh!!!!*3!!!#!!#!!!!#B!!!!+!*!(*`!!!!F!!!!#!!!!+!!!!!B!!!!$!!!!+3!\r!!!)!!!!%!!!!+J!!!!B!!!!)!!!!+`!!!!B!!!!*!!!!,!!!!!S!!!!+!!!!,Ir\rrrrB!!!!-!!(rrrr[!!!!$!!!!!%!!!!(!!$rrrrZ!!(rrrrh!!,rrrrX!!!!4J!\r!!"!!"!!!!%F!!!"Q!*!(5!!!!!)!!!!%!!!!5Irrrqi!!!!)!!!!"3!!!'B!!!!\r-!!(rrrrU!!!!+!!!!!%!!!!(!!,rrrrV!!!!5`!!!%)!%!!!!%`!!!!(!*!(63!\r!!!F!!!!"!!!!6J!!!!F!!!!#!!!!6`!!!!F!!!!$!!!!8!!!!!)!!!!%!!!!83!\r!!!S!!!!)!!!!8J!!!!)!!!!+!!!!8`!!!!S!!!!1!!!!9!!!!!F!!!!3!!!!93!\r!!!F!!!!4!!!!9J!!!!B!!!!5!!!!9`!!!!F!!!!6!!!!@!!!!!F!!!!8!!!!@3!\r!!!F!!!!9!!!!@[rrrqS!!!!@!!!!"3!!!'B!!!!q!!,rrrrT!!!!A!!!!"3!#J!\r!!%`!!!!(!*!(63!!!!F!!!!"!!!!6J!!!!F!!!!#!!!!A3!!!!B!!!!$!!!!AJ!\r!!!B!!!!%!!!!A`!!!!F!!!!&!!!!B!!!!'B!!!!'!!!!B3!!!!)!!!!+!!!!BJ!\r!!!S!!!!1!!!!"3!!!'B!!!!3!!,rrrrS!!!!C!!!!"B!#J!!!%m!!!!(!*!(C3!\r!!!B!!!!"!!!!AJ!!!!B!!!!#!!!!A`!!!!F!!!!$!!!!4`!!!'B!!!!%!!!!5!!\r!!!S!!!!)!!!!CJ!!!'B!!!!+!!!!C`!!!!S!!!!1!!!!D!!!!!S!!!!3!!!!"3!\r!!'B!!!!5!!,rrrrR!!!!DJ!!!!J!"3!!!%`!!!!(!*!(63!!!!F!!!!"!!!!6J!\r!!!F!!!!#!!!!A`!!!!F!!!!$!!!!"3!!!'B!!!!%!!,rrrrQ!!!!E!!!!!3!!3!\r!!!8!!!"Q!*!&![rrrq%!!!#)!!!!"J!#!!!!L3!!!!S!N!H+!!!!!J!!!!)!!Ir\rrrq)!!!!U!!!!"[rrrq%!![rrrq-!!!"p!!!!9J!3!!!!IJ!!!!)!N!Gr!!!!!J!\r!!!3!!!#!!!!!!J!!!!J!!!#"!!!!!J!!!!`!!!##!!!!!J!!!"!!!!#$!!!!!J!\r!!"3!!!#%!!!!!J!!!"J!!!#&!!!!!J!!!"`!!!#'!!!!#J!!!#!!!!#(rrrriJ!\r!!#)!!!"k!!!!#J!!!%`!!!#,!!!!#J!!!%i!!!#-!!!!#J!!!&!!!!#0!!!!#J!\r!!&)!!!#1!!!!"`!!!&3!!!#2!!!!"`!!!&8!!2rrrq3!!Irrrq-!![rrrq8!!!"\rY!!!!4J!C!!!!6!!!!!F!N!G0!!!!"`!!!!%!!!"Z!!!!!`!!!!)!!!"3!!!!!J!\r!!!B!!!"4!!!!#J!!!!S!!!"5!!!!!J!!!!`!!!"6!!!!#J!!!"!!!!"8!!!!"`!\r!!")!!!"9!!!!"`!!!"-!!!"[!!!!"`!!!"3!!!"I!!!!"`!!!"8!!!"`!!!!#J!\r!!"B!!!"a!!!!#J!!!"J!!!"b!!!!#J!!!"S!!!"c!!!!#J!!!"`!!!"d!!!!CJ!\r!!"i!!!"e!!!!!J!!!#)!!!"f!!!!!J!!!#B!!!"h!!!!!J!!!#S!!!"i!!!!!J!\r!!#i!!!"j!!!!!J!!!$)!!!"k!!!!!J!!!$B!!!"l!!!!!J!!!$S!!!"mrrrrj!!\r!!$i!!!!&!!!!CJ!!!%)!![rrrpi!!!#6!!!!'!!'!!!!P!!!!!)!N!H9!!!!!J!\r!!!3!!!#@!!!!!J!!!!J!!!#A!!!!!J!!!!`!!!#B!!!!!J!!!"!!!!#C!!!!!J!\r!!"3!!2rrrpm!!Irrrpi!![rrrp`!!!#E!!!!0!!0!!!!R!!!!!)!N!HG!!!!!J!\r!!!3!!!#H!!!!!J!!!!J!!!#I!!!!!J!!!!`!!!#J!!!!!J!!!"!!!!#K!!!!!J!\r!!"3!!!#L!!!!!J!!!"J!!!#M!!!!!J!!!"`!!!#N!!!!!J!!!#!!!!#P!!!!!J!\r!!#3!!!#Q!!!!!J!!!#J!!!#R!!!!!J!!!#`!!!#S!!!!!J!!!$!!!2rrrpd!!Ir\rrrp`!!2rrrpS!!3!!!!)!!IrrrpX!!!!%!!!!"2rrrpS!![rrrq!!!!#4!!!!%J!\r&!!!!N[rrrpm!N!HDrrrrh3!!!!3!!!#Trrrrf`!!!!J!!!!&!!!!CJ!!!!`!!!#\rU!!!!#J!!!"!!![rrrqd!!!"%!!!!4J!)!!!!4Irrrq`!N!G+rrrrk`#3"e[rrrr\rT!*!(BrrrrqJ!N!GTrrrrj`#3"f[rrrrQ!*!(%[rrrq8!N!H3!2rrrq!!N!8#rrr\rrm!!!!$S!!!"Q!!N!!!!lrrrrl`#3"ccrrrrZ!!!!$!!!!$d!!!!,!!!!%!!!!$i\r!!!"Q!!!!%J!!!$m!!!!,!!!!&J!!!%!!!!!,!!!!'!!!!%%!!!!,!!!!'J!!!%)\r!!!!#!!!!(!!!!%2rrrrY!!!!)!!"rrrrf!!!!!`!!!!"!!!!"`!#rrrreJ!!!+m\r!!!!8!!B!!!"(!!!!CJ#3"dJ!!!!#!!!!"!!!!%RrrrrZ!!!!#!!!!&-!!!!+!!!\r!$!!!!!8!!!"Q!!!!$J!!!,!!!!!+!!!!%J!#rrrre3!!!,%!!!!@!!N!!!#b!!!\r!#J#3"e!!!!!#!!!!!J!!!&%!!!!+!!!!"J!!!'!!!!"Q!!!!#!!!!,-!!!!'!!!\r!$!!!!&m!!!!(!!!!$3!!!')!!!!+!!!!$J!!!!8!!!"Q!!!!%!!!!&-!!!!+!!!\r!&!!#rrrre!!!!,3!!!!D!!N!!!#e!!!!#J#3"e!!!!!#!!!!!J!!!&%!!!!+!!!\r!"J!!!%F!!!"Q!!!!#!!!!%J!!!!+!!!!$!!!!'J!!!!+!!!!$J!!!!8!!!"Q!!!\r!%!!!!,B!!!!#!!!!&!!!!,F!!!!+!!!!'!!#rrrrd`!!!,N!!!!+!!-!!!#k!!!\r!#J#3"e!!!!!#!!!!!J!!!!8!!!"Q!!!!"J!#rrrre`!!!+i!!!!D!!3!!!"&rrr\rreJ#3"e[rrrr9!*!(Brrrrp3!N!Hirrrrd`#3"3,rrrrC!!!!V!!!!$S!#3!!!$[\rrrrrB!*!(22rrrqi!!!!-!!!!23!!!!X!!!!3!!!!2J!!!'B!!!!5!!!!2`!!!!X\r!!!!@!!!!3!!!!!X!!!!B!!!!33!!!!X!!!!D!!!!V3!!!!)!!!!F!!!!3rrrrpF\r!!!!J!!,rrrra!!!!1!!!!'B!!J!!!$Rrrrr`!*!(UrrrrpN!N!Errrr5!!(rrrr\rp!!,rrrrb!!!!0`!!!'S!!J!!!$Errrra!*!("[rrrp)!!!"Q!!$rrrrc!!(rrrr\rb!!$rrrr4!!(rrrr`!!,rrrr3!!!!i`!!!!J!!J!!!13!!!!#!*!(j3!!!!)!!!!\r%!!,rrrr2!!!!k3!!!!J!!J!!!1S!!!!#!*!(k`!!!'F!!!!%!!,rrrr0!!!!rJ!\r!!!B!!J!!!2m!!!!+!*!'!3#3"'B!!!!#!!(rrrr1!!!!(J!!!!Errrr0!!,rrrr\r-!!!"!J!!!!3!!3!!!3-!!!!$!*!'rrrrb`!"rrrrq`!!rrrrbJ!"!!!!!`!#rrr\rrb!!!!5X!!!!)!!-!!!$r!!!!#J#3"J%!N!4Q!!!!!J!!!5`!!!!,!!!!"J!"rrr\rrb3!!!#!!!!!)rrrrb!!!rrrra`!"rrrrb!!"rrrraJ!!!!S!!!!"!!!!"`!"rrr\rra3!!!!F!!!!"!!!!"`!#rrrra2q3"!!!!!J!!!!"rrrr``!!!!X!!!!"!!!!"`!\r#rrrr`[q3"!!!!!`!!!!#rrrr`Iq3"!!!!!J!!!!#rrrr`2q3"!!!!"3!!!!#rrr\rr[rq3"!!!!!J!!!!#rrrr[[q3"!!!!'J!!!1p,R4MF&pZEh4TCRN!"hJZGhK0B@0\r6Ef0VCA4)B@jNE'9b8(*[B`!!*bj5C@&NH9pI-6*6Ef0VCA4%EfeKD@j'GJ!"hf9\rfC@jd3fpNC3!$+R9cCA*%BA4K8(4b!!3ZFfpMD`!"[e4$8&0[BfYPG!!$Zb4*6N9\r88fpMDf9d!!,-58j&9&0[BfYPG!!(pL46Ef0VCA3!"[P6Ef0VCA3!!"abC@C$Eh9\rZG!!(mepIGR"dFL3!!0phH(*PCQ0[EJ!(*AGiCACPER3!!qGhH'9fC@jdE@&cD`!\r'FR0dFQ9KE3!'cR0dBA4eF`!$M@j[EQ*XEf0VD@jR!!IfFQ9MGN*eCJ!&QR*PBhC\rN!!,2Ff%!!q4cEf0VB@4NFPpTEJ!(!R0TEPpXC@i!!X"cD@jICQ&YD@aj!!"DFfP\rZAh"[FR3!!!0cD@jIB@4NFJ!(E@PZAf&NC()!"RecAf&NC()!!,*cD@jIHQ9bE`!\r%l("PCA)!"V&cFh4KG'8!!-GKFhPZBf9bFJ!%3R0PE'B!"(a!1$)e!!40G9pdBh"\rIEQpdD@Cj!!'r8QpeG'PZC84PFf0bDA"dEh)!"bGREdeTH'9N6@pNC94bBA!!"d4\rfCA*cD@pZ!!B)FQpeG'PZC84PFf0bDA"dEh*'E'&RF`!"9R*PFf9bGQ9N-3!"9h*\rPFf9bGQ9N-J!%Gh0PE'9MG'pb5@jQE`!%+R*[GA4TEQ9$Eh9ZG!!'m(*[GA4TEQ9\r5C@0[FQ4c!!8I8QpeG'PZC9*PBfpbC!!![h"bEf0*EQC[!!23590"!!6lFQpeG'P\rZC8CXB@Gc!!D%F(*[Bd4PFf0bDA"dEh)!!0GcC@aPBh4[FJ!#FA4MF&pZEh4TCRN\r!![NZG'0`Af0[EQjPBh4IC'pZC9pI4P!a-8&ZEQpdBA4PC&"#!!*`F')!!`*"EQj\r[G'&dC@433J!%Md"ME'&cFb3h16K(990*9%03Af0`!!1ZG'0`!!Gc9%03D@p`BJ!\r'mQCTE'`a-J!%ffP[3fpYF'aPG'P[EJ!!IfP[8Q9cG@ad!!(@D@p1B@eP8(4b!!&\rXD@p@8Q9Q6R9Y!!%@D@p$8Q9Q6R9Y!!DUBh0$Ef4P!!(rG'0`8h4bC@&Y!!I)Bh0\r3BA*KE3!%8N"ME'&cFb3h1$G(990*9%03Af0`!!DCBh*PBA4P!!1k9%033h*PBA4\rP8%)!"p"bBhC#G@CQ!!+8FQ0f3R9QCNaPEJ!#h@j[G'PQH9"bEf-!"("[F'9Z!!%\rI9%036h"PEP"#!!H-G@a`9'PYC@peG&CKE(9P!!"rG@a`9'PYC@peG%&MG'P[EJ!\r&T(CKE'PNDA4j4QaKCh-!!`eMEfeYB@jN9'PYC@peG&CKE(9P!!,DFQ9YEh4P5'p\rcG!!#[R*PE@pdC9"[FR3!!FjXEf0KE%K[Fh3!!E*XEf0KE&"[FR3!!1"dEh0'E'&\rRF`!#Ih"bC@0PC'9ZBf8!!(0NEfjd4R*KC`!#2h4TE@98EdaTGQ8!!1PcC@0eFQP\rdH3!"p@p`G'P[EN0ZG!!(*'p`G'P[ER-!")&cC@jN!!&39%038f9ZC&"#!!#fF(9\rcD%CXB@F!!MaeFQGPER4'E'&R!!DjCQPXE'9b!!EmGf4c8(4b!!!5Ff9ZC%CbC@8\r!!TTcC@jN6'9ZCh4S!!F*FQ9MC@PfC3!%Fe4$8&*PBf9TGQ933J!!K@eKFQY'E'&\rR!!BQFQ4c8(4b!!'FFQ4c6'9ZCh4S!!IVFf9MEfjN9'PYC90dB@e`!!ApBfa[Ff8\r!!Z083e"$E'pcC9"#!!A$B@*[FR3!!TY83e""BQpbG&"#!!0I9%038h4KG(9c8%)\r!"PTeER9cC@3!"iGMEfjZC@0dD@pZ8h4KG'8!!U0cC@jN9fPZC'ph!!%*FQ0f9fP\rZC'ph!!DaB@ed9@jKBfYPC%4KG'%!"@KKEA49ER*PB@4%BA4K!!#qFf9MGA*TG(P\r-CACPE&"dFJ!$MR0PEQ49EQ&MDf9N!!"6Ff9ZC%jPH(3!!)CMEfjRCA0dD@pZ9fP\rZC'ph!!F+FQ0f6Q9iG!!%KR0bG(3!"f0XBA0d8P48!!C)Ff9ZC%eKH&0PCe0THQ8\r!!hPMEfjZ8h4KG&"dFJ!#e94$8%0[EQjPBh4TEfj6G'&dF`!%4@4KG'&3Dh4c8Q0\rfC!!%h@4KG'&3Dh4c8f9ZG!!'h@4KG'&3Dh4c8Q9cC@jd!!(fBRPdCA05BhCN!!5\rRBRPdCA05BhCN4(9`!!1&BRPdCA05BhCN8'&cG&GTEQ4[G`!"LQ*jG'9c8f9ZG!!\r$S'*jG'9c8Q9cC@jd!!HFER9Y5'PcG'p#G@0VCA4c!!88Ff9ZG&0THQ9)DA0dE`!\r$[%KTFh4[3R9MDf9d!!9BGQ&XG@8!"a*MEh9ZG'9b!!I`G'eb8e*89!!$2(*dG&C\rKFQPKEQ0P!!BEG'eb8P42!!('Ff9ZC&4bD@9c!!$@FfpeFQ0S8A9PEQ0S8Q0fC!!\r#rfGXEf*KE%PZCQm!"k983e"(E'pLB@a*EQC[8%)!!a*dBh"3BA*KE9"dFJ!!*P4\r$8&"KFQ&Y!!H3!(4MF&*dEd%!!3edBh"5G'p0D@i!!4CdBh"5G'p0BAJ!"ITdBh"\r0BAK6C@G6DATP!!*GG'0`6@&i3fpZEJ!%DA4MF%eKH&GTEQ4[G`!$ih4MF&0dBA4\rc8(4b!!#)9%038h4KG(-!"f4dBh"$EfjZ3A4dC@e`G(-!"G0dBh"$EfjZ6h"PEQ9\rN!!GTG'0`3fpZEN&MBf9`G'9N!!8JG'0`3fpZEN0XEh0PC!!'2h4MF%0[EQj"BQp\rbG'9N!!1fG'0`6f0dCA4c5@i!"%0dBh"2Bh4PG(02GA3!"SGdBh"2Bh4PG(0*EN4\reF!!!-h4MF%pMG'9dFe*PG(*KER-!"(edBh"*ER"eG&"VG(-!"5"dBh"2GA4`GA4\r3Dh4c!!)2G'0`4(9`8'YdF`!'pR4MF&*PG(*KER03Dh4c!!1QG'0`3d4#9'&LE'8\r!!A4YBAK83e"$EfjZC@0dD@pZF`!$XR9NF!!(-&9%8'P[F')!!IjeC("6G(*PB@d\r!"#K!BfaKFh-N0cN`4e96594$8&pMF!!$cP9%8%0bC@&dC9"#!!*3C@jND@jR8'p\rbG!!"@99%8&0PEQ433J!!+A*PFf9bGQ9N!!"!BfKPBfY6G@d!"&a94&"5C@0PDAC\rP8%)!"mPdD@eP6h9d!!"UC'9cG%K[Fh3!!%jNCA0d8'pbG!!$Q@edG3!!qP9%8%e\r899"#!!HCEA4e8fPkC3!%QN!i-c-!!VPeAh4MF&pMEfjZC@0dAf4[EQ8!!I"dBh"\rIBfpZEQ9MG&pNEfjPAep'8$%a3@jZEh4KG'9N8%)!!C!!,R4MF&pXDA0dC@jIC'p\rZC9pI4P!a-8&ZEQpdBA4PC&"#!!5r3$Jd1!!"i(9IG'0`AfaTFh4PEPpNEfjP!!!\rMG'0`AfaTFh4PEPpNEfjPAep'8$%a3@jZEh4KG'9N8%)!"d%ZG'0`Ah*PBhCIC'p\rZC9pI4P!a-8&ZEQpdBA4PC&"#!!EdFQ9KC'PZ!!6I3$Je1!!('h9IG'0`Ah*PBhC\rIC'pZC3!'!R4MF&pbC@0fAf4[EQ9IAdC3-6&"EQj[G'&dC@433J!(45jdBh"IFf9\rZC&pNEfjPAep'8$%a3@jZEh4KG'9N8%)!""j!1$Fh!!FlG9pdBh"IFf9ZC&pNEfj\rP!!DmG'0`Ah0PEQ4IC'pZC9pI4P!a-8&ZEQpdBA4PC&"#!!0b,PpIBh4IAcP83e"\r6Ef0VCA4'GJ!&d5jIAf0dAema-%P14946Ef0VCA4'GJ!!dPpIGR4IAcP83e"6Ef0\rVCA3!!RXZAepZGepI4P9X!!--58j&9&0[BfYPG(-!"8iZ4(*TGQ9bAema0NP1494\r6Ef0VCA4%EfeKD@j'GJ!(e5j1CAG3G()!!kdZ4e9659pPFR*[FJ!'Abj33N0[ER4\rbEfa6H@jM!!Fr,QePEA0PG!!%@h4SDA-!"$p!1$Jh!!3#AepNG&pI-6"*6N988fp\rMDf9d4RB!"%"!1$Ji!!5@,PpIBh4IAcP83e"6Ef0VCA4'9@`!"S)ZAepMG&pI-6"\r*6N988fpMDf9d4P9X!!)a,NGPG%0eFR*PER43FQpMCA0c!!81,N&&3h*PBA4P4'9\rcB`!$cLj"480bC@&dC8&`F'aP4ACPER3!"RXZ3893GA43BA*KE9"dFJ!(`5j"490\rPEQ3!"MJZ389%DA0`Eh0P4'9cB`!%Dbj(CA433PpI194$8&0[BfYPG%Cf!!2j8&0\r1!!1l8(*[Bf9cFe0PFQPKE%jeE@*PFJ!&M'KTCfK-EfjR6fC38di!"(PXEhG-Efj\rR6fC38di!"hGdD'93FQpM!!HcG'KP9(P`C3!#UA4SC8&NC(*PFh-!"Pp"484PFf-\r!"MKNCA0MFQP`G'pb9(P`C3!#3@4KG'&)B@jNE'8!"eGYH9*PF'aj!!"XG'KP4AC\rPER3!"&K!1$N`!!4C3$Jj-3!&9bjIAf0dAemj9%038fpMDf9d4P!j9%038fpMDf9\rd!!4E3$Jj-`!%A%!i163!!kJZAepNG&pI194$8&0[BfYPG%Cf!!"a4e96590`D@i\r!"I&PFR*ZE`!$@Lj(990*3fKPBfY"E'&bE9pI4RB!!j3ZAep`G(*ICfaeC3!(f#j\r33N0[ER4bEfa"FhPZB`!$##j%DA0`Eh0P8(4b!!*2,PpIC'aIAdC3GJ!&"#jIAf4\rdAema-%P14946Ef0VCA4'GJ!"e("KFh0MEh9ZG!!!6A*NFf&bFQ&j!!!cFQ4c4@j\rdFRN!"[CXC@jRG'J!!m*`G()!!CKcBACP4A*bEQm!!XC&FR*ZEe0KGQ9b!!0TCP0\rKGQ9N4A*bEQm!"2a!16Ba!!6`AepNG&pI-6"&FR*ZEe0KGQ9b4RB!"2e!16Bb!!@\r(,PpIC(4IAc%`4A*bEQp6BACPFNCf!!3"3$Nf0J!%$Lj(CA433PpI-6C*6N988fp\rMDf9d4'pYB@PZ4RB!"!4!16Bj!!"C,N&fB@PXB@*XC9pI194$8&0[BfYPG%Cf!!3\rI3$Nh0!!!R5jMEfjZC@0dAemj9%038fpMDf9d4P"fD3!#@#jRCA4SEh0dD@3!"X3\rZ9%03Af9bFQpbAep'D3!(Gf&NC(*PFh-!"qaKC'4bE'9Z!!4!B@4NFJ!$0@9bFJ!\r&R%!a-$%j!!@c3$%`-M!!"6mZE'PcG'9ZAemj9%038fpMDf9d4QN!"44!-6!e-3!\r&&8!a-$8b!!!-,Q&MBf9`G&pI194$8&0[BfYPG%C3GP"T!!GF,NG98dPICA*bEh*\rIEQPX!!GP,QePE@0`H3!%-fCbEfd!"f9QFQpYE'9Z!!@@3$%`16)!!9aIAf4XAep\r'8(B!"CG!-6!j-`!'05jbC@0fCR*[E9pI194$8&0[BfYPG%C3GQPT8(C3D3!'!f*\reCQCPFJ!'pf*eCQaPEJ!"6Q4KG'&KGQ&TE!!&'8!a-63b!!2-,R0PEQ4dEepI194\r$8&0[BfYPG%C3GQPT8(CT!!8&BfpeER3!"3&QE'&RF`!#rA4[!!!PGf4cBA*bBAN\r!"j&YD@jTGf4c!!")G'9bE@PZGA-!"T!!Gf4cER9Y!!H,G'KTFhGNF`!(YA4[Gh*\rTG'8!"G"LHA4PF`!&fd!a-M)`!!9N,R0PE'9MG&pI194$8&0[BfYPG%C39@039@0\r39@-!"3*!-6)c0`!(2'0KEP*PB@3!!'CMB@jAFQPdC3!(S@G[Ef4TCA-!"30!-6)\rc1!!&"%!a-M-j!!8F3$%b0$%!"rpIAe*89%PIAcC6Ef0VCA3!"4e!-6)d-J!&(N!\ra-M3c!!3'Aep59&4*Aema-%P14946Ef0VCA3!"4Y!-6)d-!!#APpI8P4859pI194\r$8&0[BfYPG!!$Gh"[Fh4IFf9XC@0dAemf8fpMDf9d4P9M9@09B`!#E("bC9pcC@a\rPBh4IAcC6Ef0VCA4'9@09Be9M!!&#DA0KG(4jAemf8fpMDf9d4RB!"(eQG(*eEQ0\rKG'9IAcC6Ef0VCA4'E!!"B'acC@9VAemf8fpMDf9d4QaT!!8[CR0dBA4IAcC6Ef0\rVCA4'8$4cG'&d!!&,Ff9dFfpMDfp`G&pI0P0[BfYPG%CTD9"fD3!#b'GPG(0[BfY\r[F(4IAcC6Ef0VCA4'D@P3GP"T!!)pGh*TG'9IAcC6Ef0VCA4'8(CT!!'QFQ9KC&p\rI0P0[BfYPG%C3GQN!!)9cD(9dC'phEPpI-6"*6N988fpMDf9d4QN!!1TTEf0dE&p\rI-6"*6N988fpMDf9d4P9T8(B!"e&QBfjdE&pI-6"*6N988fpMDf9d4P9TD3!'9@G\rPG("PCA*ZB@ePAema-%P14946Ef0VCA4'8(C3D3!'E'GPG(0[BfYZB@ePAema-%P\r14946Ef0VCA4'8(C3D3!'B@*TEQ4IAc%`58j&9&0[BfYPG%C3GQN!"#acC@aPBh4\rIAcP83e"6Ef0VCA4'8&9M8&9M8&9M!!*BFf9ZC(4[Aemj9%038fpMDf9d4P"fD@P\r3GQN!"8PbC@0fCR*[E9pI194$8&0[BfYPG%C3GQPT8(C3D3!(rQ&MBf9`G&pI194\r$8&0[BfYPG%C3GP"T!!6iE'PcG'9ZAemj9%038fpMDf9d4QN!"`TMEfjZC@0dAem\rj9%038fpMDf9d4P"fD3!(Kd&fB@PXB@*XC9pI194$8&0[BfYPG%Cf!!+$AepNG&p\rI194$8&0[BfYPG%Cf!!0q9%p$!!1X4f9d8%*IAcP83e"6Ef0VCA4'GJ!%ZepIBh4\rIAcP83e"6Ef0VCA4'8$P83e"6Ef0VCA3!!lPIAf0dAemj9%038fpMDf9d4P9X!!+\r,AepMG&pI194$8&0[BfYPG%Cf!!"36eG5!*!''H3!!#kf!!!"+J!!'P!!!"4Q!!!\r,*!#3"J*'!!!!&!#33%9R!!"&D`!%!!!!!3!!!-J!!!!J!!!%i(`)!UD6iIrmNm(\rrq*1Krr53!!%!#*3Krl!lS`!!Jq-!CM[G!!#S(3!3,!!!!%##!"L!(J!SN!!I!"5\rJ(J!XN!!I!"K)!!!81!!!!*!!(`!81!!!!*!!(`!BU"i!%*!!(`!q1!!!%*JI!#`\ri!!!#Q"m!,B!H!#+3!"m!-+!H!#D`(`!ZJ"m!"LJ!!!""JJ!JU"m!#L`!!!""JJ!\r8J(m!"ULI!!T)!!!"B!!!!%J!!!&J!!!!J!%!@$JK!&"m#!1QJq(rr)2"rrL$SIr\rd6S!!)%9e!*!&!J!!!*a&G3#3"3-!!!#N4@i-"!!!!,8!!!!-J!#3#i!!!-JB!!!\r!4AF!N!8"!*!%4@m&"!!!!,B!!!!Jrrrrq3!!"bLUrJF!N!c"!!%!"!#3$%9f#J#\r3",F!!!!84@S!"!!!!,J!!!#%!!!!KJ!!"q"m#!+QNq(rr*2"rrL6SIrdN!!"!!L\r8)Iq`1k-!!)2M!'DS(3!3J(d!+,!$!!Bi!!!!J(d!+*!!!`!#J"m!"LJ!!!""JJ!\rJU"m!#L`!!!""JJ!8J(m!"ULI!!T)!!!"B!!!!%J!!!&J!!!!J!%!@$JK!&"m#!1\rQJq(rr)2"rrL$SIrd6S!!)%9e!*!&!J!!!&K&G3#3"3-!!!"J4@i-"!!!!,N!!!!\r-J!#3#i!!!)3B!!!!4AF!N!@i!*!%4@m&"!!!!,S!!!!Jrrrrq3!!#2UUrJF!N!c\r"!!%!"!#3$%9f#J#3",X!!!!84@X!"!!!!,`!!!"%!!!!e!!!#H*m#!+QNq(rr*!\r!!3!)P#(r`$[M!!")!!!"B!!!!)!#!!#3!"m!!MJ!!!#B(`!m1(m!!)!"!%Ji)3"\r!I!J$TS2Krra1J!!J4A8!N!@p!!!!&%9d!`#3",i!!!!F4@i-"!!!!-!!!!!-J!#\r3#i!!!%3)!!!!4AF!N!@m!*!%4@X!"!!!!-%!!!$m!!!!pJ!!#Ljm#!+QNq(rr*2\r"rrL6SIrdN!!"!!L8)Iq`1q-!!*!!J3"XJ)%!E%J!!!&J!!!!J!)!!*!!(`!#1(m\r!!%J!!!&J!!!!1m-!!)!#!!#3!!-!$$J!!"@`!`!D1!!!!,!$!#!i!!!!X!-!,NJ\r!!!&J!!!!1k-!!(qJ"c9"JJ!3Ik-(0%J!!!&J!!!!U"i!%#`!!!"!JJ!BJ"i!+*!\r!(`!8S"i!,*!!(`!B5!!!&$J!!!#3!"m!&$J!!!#3!"m!'+JH!"#3!"m!2MJ!!"#\rB(`!X1!!!!TJI!#f!(J!LN!!I!$#J(J!QX"m!,MKr!!#!!3"B1#%!8(`)!kD$iIr\rmJm(rq)1Krr41J!!J4A8!N!A#!!!!*%9d!`#3",i!!!!X4A8!N!A$!!!!1%9d!`#\r3",B!!!"%4A8!N!A%!!!!C%9e!*!&a3!!!(a&EJd#!!!!a`!!!"D!!*!('!!!2!#\r!!!S!!)D!!"m!N!T&GJS-!!!!b!!!!"*&EJ`%!!!!b3!!!!b!!*!1r!#3"%9h!*!\r&`3#3"%9h$3#3"-F!!!!)4@X!"!!!!-S!!!#X!!!"HJ!!$A9m#!+QNq(rr*2"rrL\r3!!%!#*3Krm"mIaYjX)%!AN'#!(5!!J!!N!!I!!+)(`!m+!!!!%'#!$JiI`!!5!!\r!!@!!!!!l``!!1!!!',!$!"T)!!!"B!!!!(aJ"c9!JJ!3J(i!)%J!!!&J!!!!1(m\r!!$L!!!")!!!"B!!!!+J"!&iX!!!!3)%!%$Kr!!")!!!"B!!!!$Kr!!#!!3")1#%\r!3(`)!kD$iIrmJm(rq%k!!#"&G!-!N!5q!!!!)%9e!*!&``!!!$K&G3#3"F3!!!"\r-4A8!N!A,!!!!B%9e!*!&c!!!!("&G3#3"Fd!!!#)4@i-"!!!!-i!!!!-J!#3#i!\r!!+`3!!!!4AF!N!A+!*!%4@X!"!!!!--!!!"J!!!"`J!!$P9m#!+QNq(rr*2"rrL\r3!!%!#*3Krm!l``!!J')!!%J!!!&J!!!!1q-!!)"L!!")!!!"B!!!!,"r!"L!(J!\r1N!!I!"b6h`"Q1(m!!)!"!%Ji)3"!I!J$TS2Krrb$`Iri6S!!)%9d!`#3"-m!!!!\rB4A8!N!A3!!!!(%9d!`#3"-m!!!!S4A8!N!A4!!!!,%9Z$!3!!!$5!!!!$)!!N!Z\r!!!"J%!!!!%9h!*!&``#3"%9V!!3!!!$6!!!!(!!!!J)!!!mEJ!-!2L`!!!&!JJ!\r-1'!!!%k!!##!B`!B6S!!)%9V!!3!!!$8!!!!e!!!!L3!!!pcI!J#TT2Krrb6`Ir\riNk(rp*!!!3!)P#(rX$[$!!")!!!"1q-!!$J!!"5`!`!D1'"!!%J!!!&J!!!!N!"\rr!#!i!%!!N!!I!#3i!!!!N!!I!#LJ(J!HX"m!,$Kr!!")!!!"B!!!!$ZM!!"rS!F\re3B)!&(qM"c4)!!!"B!!!!%J!!%#!(`!FN!!H!!kJ(`!XX"i!(MJ!!!'B(J!m1!!\r!!*!!(J!B1!!!!*!!(J!81!!!!C!!(J!q1(i!!%J!!!&J!!!!J!%!@$JK!&"m#!1\rQJq(rr)2"rrL$SIrd6S!!)%9e!*!&``!!!"a&G3#3"G8!!!!`4A8!N!A%!!!!@%9\re!*!&a3!!!("&G3#3"GB!!!#`4@i-"!!!!0F!!!!-J!#3#i!!!03B!!!!4AF!N!A\r8!*!%4@X!"!!!!0J!!!#-!!!#NJ!!%E9m#!+QNq(rr*2"rrL6SIrdN!!"!!L8)Iq\r`1m-!!%J!!!%i!!!!N!!$!!`i!!!@X!-!'S!H!"53!!-!+$J!!!#3!"i!&$J!!!#\r3!"i!'%J!!!&J!!!!1k-!!(qJ"c9"JJ!8Ik-(0%J!!!&J!!!!5!!!#$KJ!!#!!3"\rB1#%!8(`)!kD$iIrmJm(rq)1Krr41J!!J4A8!N!A$!!!!(%9e!*!&f3!!!%K&G3#\r3"F8!!!"J4@i-"!!!!0S!!!!-J!#3#i!!!)`B!!!!4AF!N!AB!*!%4@X!"!!!!0B\r!!!#3!!!!![!!!"-pI!J#TT2Krrb6`IriNk(rp*!!!3!)P#(rX$[$!!")!!!"J!)\r!!*!!!`!-1!!!&E!$!"Si!!!!X!-!)$J!!!#`!`!Z1!!!!C!!(J!q5!!!!@!!!!!\rlS`!!Ik!(08'#!"KrS`FdN!"q!$j)!!!"B!!!!%J!!!JiB!!!J!%!@$JK!&"m#!1\rQJq(rr)2"rrL$SIrd6S!!)%9e!*!&``!!!"a&G!-!N!5f!!!!)%9e!*!&f3!!!%K\r&G3#3"F8!!!"N4@i-"!!!!0X!!!!-J!#3#i!!!*!!'!!!!%9h!*!&eJ#3"%9V!!3\r!!!$F!!!!C!!!!di!!"@JI!J#TT2Krrb3!!%!#*3Krm!li`!!N!#"!&b3!+%!B)#\r"!&b!S3"J5!!!!@!!!!!X!`!!3))!&$Kr!!")!!!",!-!!%'#!!`iB2rr5!!!#$K\rJ!!#!!3")1#%!3(`)!kD$iIrm6S!!)%9e!*!&h3!!!#4&G3#3"G3!!!!i4@i-"!!\r!!1!!!!!-J!#3#i!!!'3)!!!!4AF!N!AF!*!%4@X!"!!!!1%!!!"S!!!$T!!!&h&\rm#!+QNq(rr*!!!3!)P#(r`$[M!!#3!)%!A*!!S3"JL!-!2#J!!!"!JJ!F1(m!!%J\r!!!%X!`!!3B)!$$KJrrp)!!!B1(m!!)#"!&b!S3"J5!!!!@!!!!#!!3")1#%!3(`\r)!kD$iIrm6S!!)%9e!*!&e!!!!#a&G3#3"H)!!!"-4@i-"!!!!13!!!!-J!#3#i!\r!!'J)!!!!4AF!N!AK!*!%4@X!"!!!!18!!!$S!!!$qJ!!'aam#!+QNq(rr*2"rrL\r3!!%!#*3Krm!li`!!N!#"!&b3!+%!B)2"!&b!!3"J,!!!%%'#!"3iB!!@5!!!!@!\r!!!")!!#8L"i!!5J!!!*"JJ!81'!!,dJ!!!&J!!!!5!!!H)JI!$`S!!!!3))!($K\rr!!")!!!",!-!!%'#!$!iB2rr5!!!9)!I!"3S!!!!3B)!($Kr!!")!!!",!-!!%'\r#!!`iB2rr5!!!-$J!!"#B(`!XJ"i!"*!!(`!`S"i!!V!I!#ii!!!#Q"m!,6J!!!@\rB(`!m1'!!!)!"!%Ji)3"!I!J$TS2Krrb$`Iri6S!!)%9e!*!&jJ!!!$4&G3#3"HB\r!!!"34A8!N!A8!!!!E%9e!*!&f!!!!*!!4@i-"!!!!1N!!!!-J!#3#i!!!1J3!!!\r!4AF!N!AP!*!%4@X!"!!!!1S!!!&`!!!%PJ!!)ICm#!+Q[f(rl*!!!3!)P#(rX$[\rM!!#3!)%!E$ZP!!!lC`!!1iJ!!)2#!!#)!`!m+!!!!%##!"`iI`!!5!!!!5`$!!"\r"JJ!-1'$rrdJ!!45)(`!6+!!!!%'#!##!(`!q,!!!!8##!"3iB!!,5!!!!@!!!!"\r)!!$X5!!!!@!!!!!X!`!!3))!,)!H!!!S!!!!3B)!-$KJ!!BiJ!!!JCi!!%J!!!&\rJ!!!!,!-!!%'#!"3iB!!%5!!!!@!!!!")!!#NJ"m!2L`!!!&"J[q`J"m!2L`!!!"\r"JJ!8J(m!2NJ!!!&J!!!!5!!!I)!I!"Km(3!!3)!!#%J!!!L$[`!BJ(m!&)#"!'`\ri[3!!5!!!!@!!!!!S'`!!3B)!1)!F!!!X!!!33B!!,)"r!#b!(`!`N!"l!!#3!"X\r!")"r!$5!(`!iN!"l!!L3!"X!$$J!!"#3!"`!!$Kr!!")!!!"1(m!!%J!!!%iI3!\r!J!%!@$JK!&"m#!1QZf(rl%k!!#"&G!-!N!6V!!!!*%9e!*!&e!!!!$K&G3#3"HB\r!!!"S4A8!N!AX!!!!G%9e!*!&l3!!!*a&G3#3"HB!!!#`4A8!N!A&!!!!f%9e!*!\r&lJ!!!34&G3#3"GJ!!!&-4A8!N!A@!!!"9%9Z$!3!!!$c!!!!$)!!N!Z!!!&`+!!\r!!%9h!*!&kJ#3"%9V!!3!!!$d!!!"Z!!!"9J!!#STI!J#TVp"rqL3!!%!#*3Krk!\rlB`!!N!#"!(`la3!!1iF!!)2L!!#)!`!m+!!!!%##!"`iH`!!5!!!!5`$!!""JJ!\r-1'$rrdJ!!@!mB!!"1'2rih`H'!"!J3!81'!!+%J!!!&J!!!!5!!"3$J!!!#`!3!\rqXm%!1)!"!(b3!!%!1LJF!!"!JJ!SL"X!,#J!!!""JJ!-1jX!,%J!!"3iB!""5!!\r!!@!!!!")!!%!1(X!!%J!!!%lS`!!J!)!!*!!!`!-1!!!&l!$!"U!I!!%2!1"!#J\r!!!&!JJ!35!!!!@!!!!")!!!)J(`!"*!!I3!LS"`!!V!G!#Bi!3!iN!!G!#Ji!!!\r"Q"d!,$J!!!#`(3!Z1(d!!%J!!!&J!!!!1d-!!(p!"c9"JJ!8Id-(0%J!!!&J!!!\r!5!!!H%J!!!&J!!!!,!-!!%##!#b!(`!!+!!!!%'#!$!iB!!(1*i!!)'I!!")!!!\r"B!!!!#`$!!""JJ!81'!!"%J!!!&J!!!!5!!!-)!"!$SS!!!!3),rX+J"!$iX!!!\r!3)!!&+KK!$j)!!!"B!!!!%J!!!JiIJ!!J!%!D$JK!'"m#!1QZd(rk%k!!#"&G!-\r!N!6V!!!!)%9e!*!&e!!!!$4&G3#3"HB!!!"F4A8!N!AQ!!!!R%9e!*!&``!!!+a\r&G!-!N!5k!!!!Y%9e!*!&p3!!!04&G3#3"GN!!!%-4A8!N!A&!!!"*%9e!*!&l!!\r!!6"&G3#3"Hd!!!&B4A8!N!AQ!!!"E%9e!*!&a3!!!C4&EJ`%!!!!r3!!!!b!!*!\r,J!!"Z$!!!!"&G`#3"I3!N!4&D`!%!!!!rJ!!!+3!!!C'!!![$h`)!UD6iIrmNm(\rrq*1Krr56JIr`N!!"!!L8)Iq`1i-!!(bG)hNla3!!1q!!!%##!!`S(J!!3B)!')J\rF!$`S!!!!3))!$$Km!!")!!!"+"d!!%'#!"b!(!!q,!!!!8'#!"!i!!!"Q"d!!$[\rr!!%S(J!!3B)!%$J!!!'B(J!!1rm!!6Kr!!#!!3"B1#%!8(`)!kD$iIrmJm(rq)1\rKrr5$JIr`6S!!)%9e!*!&e!!!!%K&EJ`%!!!"!J!!!!b!!*!,J!!!T#!!!!"&G`#\r3"Ii!N!4&EJ8"!!!"!`!!!!Vrrrr1!!![$e9%8&0[BfYPG!$DD%9Z"3%!!!%%!!!\r!"rrrrmd!!#m28fpMDf9d!!"&EJ8%!!!""3!!!!Mrrrr-!!![$`#3#%9f"3!!!!%\r%!*!%4@i&!3!!!3B!!!!,rrrrb`!!,`p*6N988fpMDf9d!!"&EJ8%!!!""`!!!!c\rrrrr+!!![$`#3$%9f"3!!!!%&!*!%4@i&"!!!!3J!!!!)rrrrb3!!,`m!N!K&GJ8\r!!!!""J#3"%9f"3!!!!%(!!!!"%9Z"33!!!%*!!!!&2rrrmJ!!#m2!*!84AB&!!!\r!!3J!!!!)4AB&!!!!!38!N!4&EJ8%!!!"#J!!!!Mrrrr(!!![$`#3#%9f"3!!!!%\r$!*!%4AB&!!!!!3N!!!!%4@m&"!!!!,i!!!"SrrrraJ!!,`m!N'K&GJ8!!!!"#J#\r3"%9f#J!!!!%,!!!!A%9f#J!!!!%-!!!!9%9f#J!!!!%0!!!!6%9f#J!!!!%1!!!\r!5%9f#J!!!!%2!!!!4%9f#J!!!!%3!!!!3%9f#J!!!!%4!!!!0%9f#J!!!!%5!!!\r!-%9f#J!!!!%6!!!!(%9f#J!!!!%8!!!!'%9f#J!!!!%9!!!!&%9f#J!!!!%@!!!\r!%%9f#J!!!!%A!!!!8%9f#J!!!!%B!!!!2%9f#J!!!!%C!!!!1%9f#J!!!!%D!!!\r!,%9f#J!!!!%E!!!!@%9f#J!!!!%F!!!!*%9f#J!!!!%G!!!!)%9f#J!!!!%H!!!\r!$%9f#J!!!!%I!!!!+%9f#J!!!!%J!!!!#%9f#J!!!!%K!!!!C%9f#J!!!!%L!!!\r!B%9[#J3!!!%E!!!!#)!!N!p&GJ#3"Ii!N!4&GJm!!!!")`!!!!4&E`S%!!!"(!!\r!!!L!!*!24AB!N!Ad!*!%4AB2!!!!!5-!!!!%4@m+"!!!!4d!!!!)J!#3$d9f!*!\r&kJ#3"%9f$`!!!!%M!!!!"%9[#J3!!!%H!!!!#)!!N!p&GJ#3"H8!N!4&GJm!!!!\r")`!!!!4&E`S%!!!"(`!!!!L!!*!24AB!N!AK!*!%4AB2!!!!!5-!!!!%4@m+"!!\r!!5!!!!!)J!#3$d9f!*!&h!#3"%9f$`!!!!%M!!!!"%9[#J3!!!%N!!!!#)!!N!p\r&GJ#3"GB!N!4&GJm!!!!")`!!!!4&E`S%!!!"*3!!!!L!!*!24AB!N!AB!*!%4AB\r2!!!!!5-!!!!%4@m+"!!!!5B!!!!)J!#3$d9f!*!&e!#3"%9f$`!!!!%M!!!!"%9\r[#J3!!!%K!!!!#)!!N!p&GJ#3"G-!N!4&GJm!!!!")`!!!!4&E`S%!!!"*`!!!!L\r!!*!24AB!N!A$!*!%4AB2!!!!!5-!!!!%4@m+"!!!!5)!!!!)J!#3$d9f!*!&bJ#\r3"%9f$`!!!!%M!!!!"%9[#J3!!!%S!!!!#)!!N!p&GJ#3"F%!N!4&GJm!!!!")`!\r!!!4&E`S%!!!"+3!!!!L!!*!24AB!N!@m!*!%4AB2!!!!!5-!!!!%4@i+"!!!!,X\r!!!!)J!#3$d9f!*!&Z!#3"%9f$`!!!!%M!!!!"%9[#J3!!!#h!!!!#)!!N!p&GJ#\r3"3%!N!4&GJm!!!!")`!!!!4&E`-%!!!!ZJ!!!!5!!*!,4AB&!*!%ZJ#3"%9[!`3\r!!!$V!!!!")!!N!Y&GJ8!N!6V!*!%4@m$"!!!!-m!!!!%J!#3#d9f"3#3"-m!N!4\r&E`-%!!!!YJ!!!!5!!*!,4AB&!*!%YJ#3"%9[!`3!!!#q!!!!")!!N!Y&GJ8!N!5\rq!*!%4@m2"!!!!5-!N!5!!*!(4@J!!&0C68J!!!ED!!!!1J!!!!B!N"J&#J!!!$!\r!!!9c!!!!4!!!"Gm!!!"8!!!'$!!!!)J!!!F%!!!!V!!!"a2rN!3!!!F6!!-!!!!\r%rj!%!3#3""d!!!#+rrrre!#3"4i!!!#Drrrrd`#3"4m!N!J)#`!!!%3!!!M@!!!\r!D!!!#1ArN!3!!!MP!!-!!!!%rj!%!3#3""d!!!#+rrrre!#3"4i!!!#Drrrrd`#\r3"4m!!3#3"JRkrj!%!!!++`!"!!!![rrrrp-"!*!%(`!"!*!'#PB!!!!i!!!+M!!\r!!'3!!![*!!!!H!!!#r3!!!#%!!!-"`!!!*!!!!!-(J!!!+3!!!am!!!!Y!!!$*h\rrN!3!!!eb!!3!!!#rrrrrd`%!N!3I!!!!S`!!!!)"!`!!!'`!!!!%rrrre!#3"4i\r!!!$'!!!!#`#3"4d!!3#3"Jf0!!!!0!!!$G)!!!"-!!!1"!!!!&`!!!iUrj!%!!!\r18J!#!!!![rrrrp-"!*!%(`!!!!6rrrr8!*!&(J!"!*!'$R)!!!!F!!!1G3!!!#`\r!!!kIrj!%!!!2'!!#!!!![rrrrp-"!*!%(J!!!!6rN!3!N!8I!!%!N!B23rq3"!!\r!$h!!!3!!!,rrrrr6!3#3"!-!!3#3"Jq1!!!!(!!!$km!!!!`!!!2j`!!!&J!!"#\rf!!!!E!!!%1%!!!"m!!!3r!!!!,!!!"'Hrj!%!!!4XJ!$!!!![rrrrp-"!*!%(J!\r!!!6rrrr8!*!&(`!!!-B!!!!,!*!&(3!"!*!'%G8!!!!F!!!51!!!!%J!!",P!!!\r!A!!!%a%!!!"X!!!6-2q3"!!!%cS!!`!!!,rrrrr6!3#3""i!!!!%rrrre!#3"4m\r!!!$'!!!!#`#3"4d!!3#3"K0B!!!!(!!!%hN!!!")!!!8JJ!!!&`!!"5Z!!!!F!!\r!&02rN!3!!"6G!!-!!!#rrrrrd`%!N!3H!!!!"2rrrp3!N!8I!!!!aJ!!!!X!N!8\rG!!%!N!B9cJ!!!#3!!"A4!!!!4!!!&JF!!!"-!!!@'[q3"!!!&L3!!`!!!,rrrrr\r6!3#3""m!!!$H!!!!C!%$!!!!A!!!!0m!!!!$!3-!!!"J!!%!N!BATJ!!!#J!!"I\r2!!!!1!!!&q-!!!"!!!!Am2q3"!!!'"m!!`!!!,rrrrr6!3#3""m!!!$M!!!!C!%\r$!!!!A!!!!0rrrrr4!3-!!!"J!!%!N!BE8!!!!$!!!"[&!!!!3!!!'q)!!!"-!!!\rF"3!!!&`!!"aB!!!!D!!!()!!!!"i!!!FP!!!!)!!!"bR!!!!M!!!(,B!!!#F!!!\rFc`!!!+3!!"cdrj!%!!!Ga3!%!!!![rrrrp-"!*!%(`!!!1F!!!"N!3-!!!"F!!!\r!k!!!!!-"!`!!!'!!!!$Hrrrrd!#3"4i!!3#3"L*+!!!!0!!!)U)!!!"%!!!LYJ!\r!!%`!!#,Z!!!!C!!!)a)!!!"d!!!M@3!!!-J!!#0G!!!!e!!!)h3!!!$N!!!Mf!!\r!!2J!!#2f!!!"$!!!*"`!!!%J!!!N@3!!!8J!!#82!!!"9!!!*5,rN!3!!#9"!!8\r!!!#rrrrrd`%!N!3I!!!!l`!!!'3"!`!!!'`!!!$`!!!!!`%!N!3G!!!!m3!!!'3\r"!*!%'`!!!2,rrrr4!3#3""`!!3#3"LTZ!!!!-!!!+[F!!!"!!!!V#`!!!%J!!#X\rC!!!!@!!!+c3!!!"S!!!V93!!!)3!!#[a!!!!N!!!!#`'!!!!Q!!!,"`!!!#S!!!\rX3!!!!3`!!#hE!!!")!!!,JF!!!%`!!!ZY`!!!B3!!#km!!!"N!!!!#l9!!!"S!!\r!,[lrN!3!!#m-!!F!!!#rrrrrd`%!N!3E!!!!l`!!!'3"!`!!!(`!!!$f!!!!!`%\r!N!3H!!!!p`!!!'3"!*!%(!!!!!6rrrr8!*!&(3!!!-B!!!!,!*!&'J!!!2Mrrrr\r2!!-!!!!i!!%!N!B[9`!!!$!!!#pa!!!!1!!!,i`!!!"%!!![X`!!!%`!!#r'!!!\r!9!!!,p8!!!"J!!![l3!!!'`!!$!8!!!!G!!!-#B!!!#!!!!`5rq3"!!!-&X!"!!\r!!,rrrrr6!3#3""`!!!$r!!!!D!%!N!3G!!!"!*!%D!%!N!3H!!!"!3!!!!-!N!8\rI!!(rrrrl!!!!$!!!!!%!!!!(!!$rrrrf!!%!!!"U!!,rrrrh!!!!&!!!!"3!"`!\r!!"8!!!!#!*!($`!!!!F!!!!%!!!!&J!!!!F!!!!&!!!!&`!!!!S!!!!'!!!!'2r\rrrrB!!!!)!!!!%!!!!!)!!!!-!!!!'3!!!!)!!!!3!!(rrrri!!!!&!!!!"6rrrr\rh!!,rrrrj!!!!#`!!!#!!#!!!!!`!!!!+!*!($3!!!!F!!!!#!!!!$J!!!!B!!!!\r$!!!!$`!!!!)!!!!%!!!!%!!!!!B!!!!)!!!!%3!!!!B!!!!*!!!!%J!!!!S!!!!\r+!!!!%rrrrrJ!!!!-!!$rrrrk!!(rrrrj!!,rrrrd!!!!)`!!!"!!"!!!!#3!!!"\rQ!*!(*3!!!!)!!!!%!!!!*[rrrrS!!!!)!!!!*`!!!'B!!!!-!!(rrrrb!!!!+!!\r!!!%!!!!(!!,rrrrc!!!!+3!!!%)!%!!!!#S!!!!(!*!(+`!!!!F!!!!"!!!!,!!\r!!!F!!!!#!!!!,3!!!!F!!!!$!!!!,J!!!!)!!!!%!!!!,`!!!!S!!!!)!!!!-!!\r!!!)!!!!+!!!!-3!!!!S!!!!1!!!!-J!!!!F!!!!3!!!!-`!!!!F!!!!4!!!!0!!\r!!!B!!!!5!!!!03!!!!F!!!!6!!!!0J!!!!F!!!!8!!!!0`!!!!F!!!!9!!!!12r\rrrr)!!!!@!!!!*`!!!'B!!!!q!!,rrrra!!!!1J!!!"3!#J!!!#S!!!!(!*!(+`!\r!!!F!!!!"!!!!,!!!!!F!!!!#!!!!1`!!!!B!!!!$!!!!2!!!!!B!!!!%!!!!23!\r!!!F!!!!&!!!!2J!!!'B!!!!'!!!!2`!!!!)!!!!+!!!!3!!!!!S!!!!1!!!!*`!\r!!'B!!!!3!!,rrrr`!!!!3J!!!"B!#J!!!#d!!!!(!*!(3`!!!!B!!!!"!!!!2!!\r!!!B!!!!#!!!!23!!!!F!!!!$!!!!*!!!!'B!!!!%!!!!*3!!!!S!!!!)!!!!4!!\r!!'B!!!!+!!!!43!!!!S!!!!1!!!!4J!!!!S!!!!3!!!!*`!!!'B!!!!5!!,rrrr\r[!!!!5!!!!!J!"3!!!#S!!!!(!*!(+`!!!!F!!!!"!!!!,!!!!!F!!!!#!!!!23!\r!!!F!!!!$!!!!*`!!!'B!!!!%!!,rrrrZ!!!!5J!!!!3!!3!!!#F!!!"Q!*!&![r\rrrqN!!!"R!!!!"J!#!!!!D!!!!!S!N!GT!!!!!J!!!!)!!IrrrqS!!!!U!!!!"[r\rrrqN!![rrrqX!!!"F!!!!9J!3!!!!A3!!!!)!N!GH!!!!!J!!!!3!!!"I!!!!!J!\r!!!J!!!"J!!!!!J!!!!`!!!"K!!!!!J!!!"!!!!"L!!!!!J!!!"3!!!"M!!!!!J!\r!!"J!!!"N!!!!!J!!!"`!!!"P!!!!#J!!!#!!!!"QrrrrkJ!!!#)!!!"C!!!!#J!\r!!%`!!!"U!!!!#J!!!%i!!!"V!!!!#J!!!&!!!!"X!!!!#J!!!&)!!!"Y!!!!"`!\r!!&3!!!"Z!!!!"`!!!&8!!2rrrq`!!IrrrqX!![rrrqd!!!"-!!!!4J!C!!!!+J!\r!!!F!N!FV!!!!"`!!!!%!!!"0!!!!!`!!!!)!!!!Z!!!!!J!!!!B!!!![!!!!#J!\r!!!S!!!!`!!!!!J!!!!`!!!!a!!!!#J!!!"!!!!!b!!!!"`!!!")!!!!c!!!!"`!\r!!"-!!!"1!!!!"`!!!"3!!!!p!!!!"`!!!"8!!!"2!!!!#J!!!"B!!!"3!!!!#J!\r!!"J!!!"4!!!!#J!!!"S!!!"5!!!!#J!!!"`!!!"6!!!!CJ!!!"i!!!"8!!!!!J!\r!!#)!!!"9!!!!!J!!!#B!!!"@!!!!!J!!!#S!!!"A!!!!!J!!!#i!!!"B!!!!!J!\r!!$)!!!"C!!!!!J!!!$B!!!"D!!!!!J!!!$S!!!"Errrrl!!!!$i!!!!R!!!!CJ!\r!!%)!![rrrqB!!!"b!!!!'!!'!!!!F`!!!!)!N!Gd!!!!!J!!!!3!!!"e!!!!!J!\r!!!J!!!"f!!!!!J!!!!`!!!"h!!!!!J!!!"!!!!"i!!!!!J!!!"3!!2rrrqF!!Ir\rrrqB!![rrrq3!!!"k!!!!0!!0!!!!H`!!!!)!N!Gm!!!!!J!!!!3!!!"p!!!!!J!\r!!!J!!!"q!!!!!J!!!!`!!!"r!!!!!J!!!"!!!!#!!!!!!J!!!"3!!!#"!!!!!J!\r!!"J!!!##!!!!!J!!!"`!!!#$!!!!!J!!!#!!!!#%!!!!!J!!!#3!!!#&!!!!!J!\r!!#J!!!#'!!!!!J!!!#`!!!#(!!!!!J!!!$!!!2rrrq8!!Irrrq3!!2rrrq)!!3!\r!!!)!!Irrrq-!!!!%!!!!"2rrrq)!![rrrqJ!!!"`!!!!%J!&!!!!FIrrrqF!N!G\rjrrrrj3!!!!3!!!#)rrrri`!!!!J!!!!R!!!!CJ!!!!`!!!#*!!!!#J!!!"!!![r\rrrr8!!!!K!!!!4J!)!!!!)[rrrr3!N!FSrrrrm`#3"cRrrrra!*!(3Irrrr!!N!G\r(rrrrl`#3"dRrrrrZ!*!(5rrrrqd!N!G[rrrrk!#3"3,rrrrm!!!!#!!!!'B!#3!\r!!!Rrrrrl!*!(#[rrrrS!!!!-!!!!'J!!!!X!!!!3!!!!'`!!!'B!!!!5!!!!(!!\r!!!X!!!!@!!!!(3!!!!X!!!!B!!!!(J!!!!X!!!!D!!!!(`!!!!)!!!!F!!!!)2r\rrrr8!!!!J!!(rrrrJ!!!!$!!!!!%!!!!(!!,rrrrH!!!!MJ!!!"3!"J!!!#3!!!"\rQ!*!(*3!!!!)!!!!%!!!!*[rrrrS!!!!)!!!!-3!!!!S!!!!-!!!!*`!!!'B!!!!\r1!!!!M`!!!!S!!!!5!!,rrrrG!!!!N!!!!!!@!!N!!!#4!!!!#J#3"bi!!!!#!!!\r!!J!!!#m!!!!+!!!!"J!!!$i!!!"Q!!!!#!!!!*)!!!!'!!!!$!!!!$d!!!!(!!!\r!$3!!!%!!!!!+!!!!$J!!!#F!!!"Q!!!!%!!!!$%!!!!+!!!!&!!#rrrrh!!!!*-\r!!!!D!!N!!!#8!!!!#J#3"bi!!!!#!!!!!J!!!#m!!!!+!!!!"J!!!#3!!!"Q!!!\r!#!!!!#8!!!!+!!!!$!!!!%B!!!!+!!!!$J!!!#F!!!"Q!!!!%!!!!*8!!!!#!!!\r!&!!!!*B!!!!+!!!!'!!#rrrrf`!!!*J!!!!+!!-!!!#C!!!!#J#3"bi!!!!#!!!\r!!J!!!#F!!!"Q!!!!"J!#rrrrh`!!!)d!!!!D!!3!!!!LrrrrhJ#3"cRrrrrG!*!\r(3Irrrp`!N!HArrrrf`#3"3,rrrrK!!!!L`!!!$S!#3!!!!RrrrrJ!*!(#[rrrrS\r!!!!-!!!!'J!!!!X!!!!3!!!!'`!!!'B!!!!5!!!!(!!!!!X!!!!@!!!!(3!!!!X\r!!!!B!!!!(J!!!!X!!!!D!!!!M!!!!!)!!!!F!!!!)2rrrpm!!!!J!!,rrrrp!!!\r!"J!!!'B!!J!!!!Irrrrm!*!(L[rrrq%!N!8#rrrrf!!!!*d!!!!'!!)!!!#H!!!\r!#`#3"jm!!!"N!!!!!J!#rrrreJ!!!+d!!!!%!!%!!!#Z!!!!!J#3"3(rrrr9!!!\r!#!!!!!%!!!!(!!,rrrrA!!!!U!!!!"!!"3!!!+N!!!!'!*!(UJ!!!!B!!!!"!!!\r!U`!!!!S!!!!#!!!!V2rrrpB!!!!%!!!!Vrrrrp8!!!!)!!,rrrrC!!!!Q`!!!%)\r!$3!!!*crrrrB!*!(S!!!!'3!!!!'!!!!S3!!!!X!!!!+!!!!SJ!!!!X!!!!-!!!\r!S`!!!!)!!!!1!!!!5`!!!!B!!!!5!!!!T!!!!!B!!!!6!!!!T3!!!'B!!!!8!!!\r!TJ!!!!-!!!!B!!!!TrrrrpF!!!!F!!!!X2rrrpF!!!!X!!!!X3!!!!B!!!!m!!!\r!XJ!!!!-!!!!q!!$rrrrD!!(rrrrC!!,rrrrq!!!!"3!!!'S!!J!!!!6rrrrp!*!\r(Q[rrrpS!!!"Q!!$rN!3!!Irrrri!!2rrrp3!!Irrrq%!![rrrp)!!!#c!!!!3J!\r"!!!!Y2rrrpN!N!Errrr6!!(rrrr5!!$rrrr4!!%!!!!$!!$rrrr3!!(rrrrA!!,\rrrrr2!!!!q3!!!!J!!`!!!2S!!!!+!*!(q`!!!'B!!!!#!!!!r!!!!!X!!!!'!!(\rrrrr1!!!!#J!!!!%!!!!(!!(rrrr0!!!!"`!!!!%!!!!(!!,rrrr-rj!%!!!!#!!\r!!!(rrrr,!!!!#`!!!!%!!!!(!!,rrrr+rj!%!!!!$!!!!!,rrrr*rj!%!!!!#!!\r!!!,rrrr)rj!%!!!!&!!!!!,rrrr(rj!%!!!!#!!!!!,rrrr'rj!%!!!!D!!!"3J\rZG@4`Ah*PB@4IB@KPB@4IC'pZC9pI4P!a-8&ZEQpdBA4PC&"#!!Gi,RGi6@&M8fp\rMDf9d5'&ZC'aPFP"bEf-!!#FZ8Q9KC(PIAc%b8fpMDf9d4'pYB@PZ4RB!!R"`BJ!\r$!N&ZEQpdBA4PC&"#!!5G3'0XBA0c*$Fj1%G98dP94&"IBh!!!kjdBh!!"h083e"\rTEh"L!!EbCQPXE$%b!!6ED@p$Efe`E'9dD@pZ!!'r8QpeG'PZC84PFf0bDA"dEh)\r!"bGREdeTH'9N6@pNC94bBA!!"d4fCA*cD@pZ!!B)FQpeG'PZC84PFf0bDA"dEh*\r'E'&RF`!"9R*PFf9bGQ9N-3!"9h*PFf9bGQ9N-J!%Gh0PE'9MG'pb5@jQE`!%+R*\r[GA4TEQ9$Eh9ZG!!'m(*[GA4TEQ95C@0[FQ4c!!8I8QpeG'PZC9*PBfpbC!!![h"\rbEf0*EQC[!!23590"!!6lFQpeG'PZC8CXB@Gc!!D%F(*[Bd4PFf0bDA"dEh)!!0G\rcC@aPBh4[FJ!!IfP[8Q9cG@ad!!(@D@p1B@eP8(4b!!&XD@p@8Q9Q6R9Y!!%@D@p\r$8Q9Q6R9Y!!DUBh0$Ef4P!!(rG'0`8h4bC@&Y!!I)Bh03BA*KE3!%!8"ME'&cFb3\rh1$G(990*9843Af0`!!DCBh*PBA4P!!1k9%033h*PBA4P8%)!"p"bBhC#G@CQ!!+\r8FQ0f3R9QCNaPEJ!#h@j[G'PQH9"bEf-!!bTeFf9b4'&dB9"dFJ!%F'p`C@i!!4p\r83e"2F'9Z8%)!"iaeE("8D@ePEh9d9Q&XG@8!!(peE("8D@ePEh9d3@0dD@pZ!!@\rNGQ&XD@4TG(P'E'&RF`!$$@0[E@eKEQ48D@ePEh9d9Q&XG@8!!YTbC@e[G'9)Eh0\rd!!+qFQ9YEh4P8'pbG!!"cQa[Bf&X5'pcG!!"XQa[Bf&X8'pbG!!!i(4[FdCXB@G\rc!!*rF(*PBf9NC@jMC3!!Ff4[ER4'FQ&R!!)rG'PYC94[6'PfC3!!kA0PBh9bDA4\rj!!(eEh"dD@pZ3fjd!!FNEh"dD@pZF`!%JA0PEQ3!!9"83e"6C@jN8%)!!,C`GA0\rS4QaKC`!#2(9bCf9ZG%CXB@F!"VPQD@aXCA)!"[ahC(03G()!!"*cC@jN4R*PC3!\r#QR0PEQ4-C@jRG'J!"`PbC@0PDACP!!4c9%038Q9MC@PfC9"#!!#&E@&bDdCXB@F\r!"LCbC(03G()!!CabC(0-C@jRG'J!"qYcC@0[EQ48D@eP8h4KEA!!"IeME'pcC3!\r#ie4$8%0XEh0P8%)!"F0KBQpbG!!#Qe4$8%&LEh*d8%)!"XjcG'&dGA-!!ep83e"\r6G'&dGA033J!'@R9ZGA0PC!!(Kf0[EQjPBh4TEfj6G'&dC3!#Sh0PEQ4AD@jNEhF\r!!3PbBhCAD@jNEhF!"V&KEA49EQ&MDf9N4'&dB3!&D'&YG&9ZFQ9KC%4KG'%!!,j\rcC@0eFQPdH8aPGQ9X8(4b!!11Ff9ZC&9ZB@0VC@3!!&0cC@jN6Q9iG!!!KQ0[EQG\rPFh4TEfjAD@jNEhF!"`TbBhC1CAKd!!5'Fh*dG!!(BfaKFh459&3!"NKcC@jN6@&\ri8f9R8fPkC3!$H@0[EQj6G'&d8(4b!!,99%033fpZEQ9MG'P[EP0dBA4c!!4&C'&\rdB9"VG(05BhCN!!6GC'&dB9"VG(06C@jd!!EGC'&dB9"VG(05CA0PER3!!ICLHA4\rPFe*MGQ3!"+GLHA4PFe*MGQ4%GA!!!i9LHA4PFe*MGQ43BA0d9fPZC'ph!!'+BRP\rdCA06C@jd!!1JBRPdCA05CA0PER3!"jaZG@e)DA0dEd*eBfYPG(-!"44cC@jd8fP\rkC8KTFh4[!!1m5'PcG'p#G@0VCA3!"9KfB@aeC3!(%Q0[G@jdCA)!"r"dEA*68P4\r8!!-mFR4d9Q&bD@&ZBf8!"KYdEA*59%m!!FCcC@jN9(*TCA-!!0CcEh9bBfK4G@9\rZBfK5BhCN!!,rCfa[BQ&X5@jQE`!(T94$8%GXEf*KE%PZCQp33J!$%R4MF&"KFQ&\rY8(4b!!!Q9%038'&bB@d!"j!!G'0`8R4[33!"$A4MF&*dEdeTEJ!"&R4MF&*dEde\rKH!!&qR4MF%eKH&0PCe0THQ8!!PedBh"0BAK$EfjZ!!4TG'0`6@&i9fPZC'ph!!2\rMG'0`8h4KG(03G()!!)K83e"6G'&dF`!(C(4MF%0[EQj"G(4PEA"dF`!&dh4MF%0\r[EQj2F'9ZC@3!"fPdBh"$EfjZ3@0MCA"dC@3!"5"dBh"$EfjZ3fa[Ff9N!!BrG'0\r`3fpZEN&LEh*dC@3!!lCdBh"2Bh4PG(0*EJ!%3h4MF%pMG'9dFdpeG!!'Kh4MF%p\rMG'9dFdPZ4(9`!!!cG'0`6f0dCA4c8Q9dFQ&ZF`!%IA4MF%PZF(9d8'YdF`!&)(4\rMF%peG("eG&"VG(-!!JpdBh"%GA"3Dh4c!!EfG'0`8Q9dFQ&ZFe"VG(-!!kCdBh"\r$4%*8B@*XC3!"G'eKH&4$8%0[EQjPBh4TEfjc!!1bG@4`!!F`9843D@p`BJ!"rR9\rNF&0dFQ9KE3!%2N"ME'&cFb3h16"(990*9843Af0`!!2198433h*PBA4P8%)!!P"\rPEQ4TEQG3Eh*d!!&C98438f9ZC&"#!!!TFQ9cCA*fC@3!!%"MD'9MDe0eE3!%A&9\r%8&*PBf9TGQ933J!(bA4TE@92GA3!!'TNCA0d5'pcG!!!6Q4PFh43Eh*d!!1CEA4\re!!$k984369498%)!"jPYG(96DATP!!3ZFfpMD`!#c%P14946Ef0VCA3!"rBN8fp\rMDf9d!!Ej8fpMDf9d!!!FFQ9Q3fpeER3!"r0IAhC`G()N!!$IGhKbC@CMEfi!"b9\rhH'9fC@jd!!2RGhKPGQ9ZG'eKFfX!"R*cG(*PB@d!!ieZEfjLE'pMDfPZC`!(pR*\rPBhC#G@B!"CTbC@0fC!!#ch0K!!2NFfpMDf&NC(*ID@i!"`*cD@jIE'9Z!!,!FfP\rZAfCKE@PXH3!!@R0TEPp`Eh*d!!!$FfPZAf&NC()!"feTEPpKC'4b!!CpFepKC'4\rb!!#bFfPZAhTPFQm!"1a`C@9b!!DaFh0dBA4P!!$(BA0jEQ0PFR)!!HK94&"6Ef0\rVCA3!!lXN58j&9&0[BfYPG!!%2d!i-$J!"3PeAh9NF&pbC@&NAf&SC@&NAf4[EQ8\r!"-KeC("IFQ9KC&pKD'9KC&pNEfjPAep'8$%a3@jZEh4KG'9N8%)!"d3ZG@4`Ah0\rPEQ4IC'pZC9pI4P!a-8&ZEQpdBA4PC&"#!!4C3$Ja-J!(VA9IG@4`Ah0PEQ4IC'p\rZC3!'eA9NF&pcC@jNAf4[EQ9IAdC3-6&"EQj[G'&dC@433J!$jbjIAf0dAemj984\r38fpMDf9d4RB!"G%ZAepMG&pI-6"*6N988fpMDf9d4RB!!+4IAhCdAemj98438fp\rMDf9d!!4EG'KTF`!%@d!i-63!"%3ZAepMG&pI199%8&0[BfYPG%C9E!!'JLjIAf0\rdAema-%P14946Ef0VCA4'9@`!"$mZ4f9d8%*IAcP94&"6Ef0VCA4'GJ!'Abj33N0\r[ER4bEfa6H@jM!!E%,P4$8&pPFR*[FPpI4QN!!c9PFR)!"(K!1$)a!!3#AepNG&p\rI-6"*6N988fpMDf9d4RB!"(P!1$)b!!-%,PpIC(4IAcP94&"6Ef0VCA4'GJ!$##j\r%DA0`Eh0P8(4b!!8%,PpIC(4IAc%`58j&9&0[BfYPG%Cf!!*2,PpIC'aIAdC3GJ!\r%Pd!i-c!!!`a*6N988fpMDf9dF`!%$Lj(CA433PpI-6C*6N988fpMDf9d4'pYB@P\rZ4RB!"8iZ4(*TGQ9bAema0NP14946Ef0VCA4%EfeKD@j'GJ!%QN!i-c-!!2dZ3AC\rKD@aKBQaPAemj98438fpMDf9d4RB!!0)Z6Q9h8h4bC@&YAemj98438fpMDf9d4RB\r!"p8Z6Q9h8(4b!!"9,P*PB@4"D'9KC&pI199%8&0[BfYPG%Cf!!5I3$Jc1!!&)5j\r'E(9cD&*PB@4"D'9KC&pI199%8&0[BfYPG%Cf!!IB,P"#3fpZG(*[E%&cH@jM!!5\rk3$Jd-`!%[N!i0$F!"6XZBQPZC&pI199%8&0[BfYPG%C3GQN!"jdZBQPZC&pI-6"\r*6N988fpMDf9d4P"fD3!%3'&NC()!"k*ZB@ePE'9Z!!6D3$Je-`!&f#jRCA4cEf0\rVEQ&YC9pI199%8&0[BfYPG%C3GP"T!!II,QGPG(0[BfYZB@ePAema-%P14946Ef0\rVCA4'8(C3D3!%UfjKE@8!"1"!1$8j!!"S,Q0[EQjPBh4IAcP94&"6Ef0VCA4'8(C\rT!!1Y,NG98dPICA*bEh)!"hGKC'4bCA0c!!IXB@4NFQaPEJ!%'d!i0c3!"KSZFQ9\rMGQCbEfeIAcP94&"6Ef0VCA4'8(CTD9"f8'N!!(&(990*8h"TEJ!$@Lj(990*3fK\rPBfY"E'&bE9pI4RB!!j3ZAep`G(*ICfaeC3!#,bj#E'pMDde[GQ8!"J0LG@CQCA)\r!"[GLG@CXC@i!"$0QFQpY!!GPCR*[E@aPEJ!%AN!i16B!!pFZFf9ZC(4[Aemj984\r38fpMDf9d4P"fD@P3GQN!!PJZCf9dD'pcG'PN!!8&BfpeER3!![edE`!%MQ&hC(-\r!"j&YD@jTGf4c!!EfE'9ZCh4S!!2#F(4b!!")G'9bE@PZGA-!"(e!16)b!!@[,R0\rPE'9MG&pI199%8&0[BfYPG%C39@039@039@-!"caMB@j5C@&N!!"QBf&Z9h*TG'8\r!"k&REfpND@9c!!5J3$Nc03!%S8!j-cB!"+0!16-i!!IrAep59&4*Aemf8fpMDf9\rd!!5N3$Nc13!%Zd!j0$!!"!CIAe*89%PIAc%`58j&9&0[BfYPG!!%SN!j-cF!!Qe\rIAe*89%PIAcP94&"6Ef0VCA3!!hG`Eh0dAh0PE'9MG&pI0P0[BfYPG%C9Be9M9@-\r!!Qa`FQ9IFf9XC@0dAemf8fpMDf9d4P9M9@09B`!"3QPcBA4dH9pI0P0[BfYPG%C\rf!!4pCR4bG@jMBA4PAemf8fpMDf9d4Q`!!@"XFf9PDepI0P0[BfYPG%CXD3!&,fC\rcG'&dAemf8fpMDf9d4P!dFh4KG!!"5h0PG(0[BfY[F(4IAcC6Ef0VCA4'D@P3GQN\r!!XKRCA4cEf0VEh"dAemf8fpMDf9d4QPT8(C3D3!#2AGbDA4PAemf8fpMDf9d4P"\rfD3!"TR*PB@4IAcC6Ef0VCA4'8(CT!!5@B@0MCA"dAemf8fpMDf9d4P"f8'N!!FK\rXDA0dC@jIAcC6Ef0VCA4'D3!!KA0SGA4NEhGZAema-%P14946Ef0VCA4'D3!!kQP\r[Bh4XAema-%P14946Ef0VCA4'9@P3GJ!(8@CMER4XAema-%P14946Ef0VCA4'9@P\rT!!C9Cf9dF'9PFQjKE@9IAc%`58j&9&0[BfYPG%C3GP"T!!5aFf9XC@0dAemj984\r38fpMDf9d4P"9Be"9Be"9B`!#PR0PEQ4dEepI199%8&0[BfYPG%C3GQPT8(CT!!8\rfFQ9MGQCbEfeIAcP94&"6Ef0VCA4'8(CTD9"f8'N!"hTMEfjZC@0dAemj98438fp\rMDf9d4P"fD3!%[@GPG(0[BfYZB@ePAemj98438fpMDf9d4P"f8'N!",eLD@jNAem\rj98438fpMDf9d4P"fD3!(cN&fB@PXB@*XC9pI199%8&0[BfYPG%Cf!!,AAepNG&p\rI199%8&0[BfYPG%Cf!!0q9%p$!!IV8Q9KC%&SC@&NAemj98438fpMDf9d4RB!"2"\r'E(9cD&*PB@4"D'9KC&pI199%8&0[BfYPG%Cf!!G[6Q9h8h4bC@&YAemj98438fp\rMDf9d4RB!!`K(CA433PpI199%8&0[BfYPG%Cf!!0$AepMG&pI199%8&0[BfYPG%C\r9E!!#hepIBh4IAcP94&"6Ef0VCA4'GJ!!8%pA8J#3"P(X!!"5@!!!!0J!N!STJ!!\r!!R8!!!44!!!!+!#33%9R!!"&D3#3"3&&E`8%!!!!"!!!!!5!!*!(rj!%4@i3!3!\r!!!B!!!!"J!#3#!3%-%9V!!3!!!!(!!!!I)!!N!Gm#!+QN!!"!!L8)Im`N!"K!1J\riB3#!J)%!k%J!!!&J!!!!1'%!1$L"!)!iSJ!!5!!!!@!!!!#!BJ!!U!-!!#`!!!"\r"JJ!3J')!!+KM!!")!!!JU!%!J)"L!!#`!`!!J!%!JS"L!!#3!!-!!$KJ!!#!!3$\rB1#%!d(`)!kC1J!!J4A8!N!8)!!!!'%9c%!#3"!B!!!!S4A8!N!8*!!!!,%9d!`#\r3"!)!!!!d4A3$!*!%!J!!!%4&G!-!N!3$!!!!9%9d!`#3"!3!!!"J4@i-"!!!!!S\r!!!!-J!#3#i!!!(`!N!4&G`#3"3F!N!4&DJ!%!!!!#`!!!(#!!*!(I!J#TT2Krrb\r3!!%!#*3Krd#3!'%!f*!!J3$F1!%!1*!!!3#+1'%!H%J!!!&J!!!!1q-!!(rJ"c9\r"JJ!-1(m!!%J!!##S!3#BJ'%!f,!$!!#!!3#SJ'%!h*!!!`!!1'!!!)!"!-Ji)3$\r!I!J$TS2Krra1J!!J4A8!N!8-!!!!*%9Z$!3!!!!0!!!!$)!!N!Z!!!"`#!!!!%9\rh!*!&#`#3"%9V!!3!!!!1!!!!G)!!N!Gm#!+QNq(rr*!!!3!)P#(r`$[M!!!i!!!\r!Q!-!"S"L!!#!!`!!,!$rrd'#!#5!BJ!!U!-!!,!I!!#!BJ!!J!-!!*!!(`!#1'!\r!!%J!!"JiI`!!1*m!!NJ!!!'!JJ!!X'3!!)!"!%Ji)3"!I!J$TS2Krra1J!!J4A3\r$!*!%"!!!!"a&G!-!N!3$!!!!,%9d!`#3"!3!!!!i4A8!N!8,!!!!9%9d!`#3"!)\r!!!"B4@i-"!!!!!m!!!!-J!#3#i!!!(3)!!!!4AF!N!81!*!%4@X!"!!!!"!!!!#\rSJ!#3"h`)!UD6iIrmNm(rq*1Krr53!!%!#*3Krf!li`!!1k3!!)2#!!#)!`!'+!!\r!!%##!!arS!Fe3)%!2$JI!!D3!!%!5V1K!&3iB3!i5!!!!@!!!!#`IJ!!I'!(08'\r#!!bSIJ!!5!!!,+J"!%k`(`!!5!!!&$J!!!#`(J!!1!!!!,!I!!!i!!!"N!!I!!+\rSIJ!!J!%!U$JK!+"m#!1QJq(rr)2"rrL$SIrd6S!!)%9d!`#3"!)!!!!J4A8!N!8\r4!!!!5%9Z$!3!!!!5!!!!$)!!N!Z!!!#S'!!!!%9h!*!&%!#3"%9V!!3!!!!6!!!\r!+)!!N!Fi!!+DX!-!!$J!!!#3!!-!!MJ!!!#B!`!'1!!!!)##!!#`"!!!6S!!)%9\rd!`#3"!)!!!!F4@X!"!!!!"3!!!!SJ!#3"cL!!!#!!`!#,!!!!%##!"5S!`!!,!!\r#QN##!!JiJ!!"1'3!!%k!!#"&D`!%!!!!&3!!!%b!!*!(I!J#TT2Krrb3!!%!#*3\rKrh!li`!!5!!!!AaJ"c9!JJ!81'%!1$LI!!")!!!"B!!!!)"L!!#SB`!!J!%!Q$J\rK!*!!I!J$TS2Krra1J!!J4A8!N!81!!!!&%9e!*!&&J!!!#K&G!-!N!3#!!!!-%9\rZ$!3!!!!A!!!!$)!!N!Z!!!"-#!!!!%9h!*!&&3#3"%9V!!3!!!!)!!!!I)!!N!G\rm#!+QNq(rr*2"rrL3!!%!#*3Krm!l``!!1q3!!+J%!!#`!`!!J!3!!T!!!`!#L!3\r!"LJ!!%"!J!!B1(i!"MLI!!C)!!!"B!!!!%J!!"JiIJ!'1*m!"MLJ!%")!!!"B!!\r!!$Kq!!#!!3")1#%!3(`)!kD$iIrmJm(rq%k!!#"&G3#3"4J!!!"!4A8!N!8C!!!\r!@%9Z$!3!!!!D!!!!$)!!N!Z!!!"m%!!!!%9h!*!&#!#3"%9V!!3!!!!E!!!!V)!\r!N!Gm#!+QNq(rr*2"rrL3!!%!#*3Krm!li`!!1m3!!*LK!'1S"!!!X!-!!)!%!!+\r3!!-!!SJ%!!BS!!"!3)!!'$Kr!!BiRJ!'5!!!!@!!!!")!!!B1(m!"MLH!!BiS!"\r!5!!!!@!!!!#)!3"M+!!!!%##!#5!BJ!!L!-!!#J!!!""JJ!81(m!!$L!!!&)!!!\r"B!!!!$Kr!!#!!3")1#%!3(`)!kD$iIrmJm(rq%k!!#"&G3#3"4J!!!"%4A8!N!8\rC!!!!A%9d!`#3""`!!!"`4A8!N!8G!!!!L%9Z$!3!!!!H!!!!$)!!N!Z!!!#X%!!\r!!%9h!*!&'`#3"%9V!!3!!!!I!!!"!)!!N!Gm#!+Q[f(rl*!!!3!)P#(rX$[M!!!\rlC!!!1i8!!$['!!#Bi3"lJ')!!)J$!!!S!!!!3B)!0$Kl!!!iR!!!1,i!!$MI!!"\r)!!!"B!!!!$ZM!!"rS!Fe3B)!-(qJ"c3X!2r93B)!*,0r!!#6R`!#1(m!"MLH!!#\r)[J!!1+8!!8J!!!&J!!!!L!%!HbJ!!!"!JJ!NJ')!!)J$!!!S!!!!3B)!&$Kr!!!\riJ!!"5!!!!@!!!!!iI`!'1*i!!$LJ!!!i`!!"5!!!!@!!!!"8B!Br3B)!($Kr!!B\riRJ!!L,i!!$LP!!&)!!!"B!!!!$Kr!!#!!3"B1#%!8(`)!kDlBIrX6S!!)%9d!`#\r3"#!!!!!N4A8!N!8K!!!!4%9e!*!&'3!!!(a&G!-!N!3F!!!!N!"&G3#3"4d!!!#\rS4A8!N!8L!!!!`%9e!*!&'3!!!1"&EJ`%!!!!)`!!!!b!!*!,J!!"!#J!!!"&G`#\r3"4m!N!4&D`!%!!!!*!!!!9b!!*!(I!J#TT2Krrb6`IriNk(rp*1"rr#3!!%!#*3\rKri!li`!!1i3!!$[&!!#B`3#RJ')!!)J$!!!S!!!!3B)!0$Km!!!iJ!!!1,i!!$M\rI!!")!!!"B!!!!$ZM!!"rS!Fe3B)!H(qJ"c3X!2r93B)!E$J!!!#3!!%!5V1"!%i\ri!!!!X!%!8MJ!!!#3!!%!9$KK!$K)!!!"B!!!!)##!!#`C!!!I'!(08'#!!`iI`!\r!5!!!P+J"!&L`(`!!J!%!D*!!(`!#1(m!"MLH!!#)[J!!1+8!!8J!!!&J!!!!L!%\r!TbJ!!!"!JJ!NJ')!!)J$!!!S!!!!3B)!&$Kr!!!iJ!!"5!!!!@!!!!!iI`!'1*i\r!!$LJ!!!i`!!"5!!!!@!!!!"8B!Br3B)!($Kr!!BiRJ!!L,i!!$LP!!&)!!!"B!!\r!!$Kr!!#!!3#)1#%!J(`)!kD$iIrmJm(rq)1Krr5$JIr`6S!!)%9d!`#3"#!!!!!\rX4A8!N!8K!!!!6%9e!*!&*3!!!)a&G!-!N!3#!!!!P%9e!*!&'3!!!-a&G!-!N!3\rF!!!!i%9e!*!&(3!!!2K&G3#3"5)!!!%34A8!N!8C!!!"-%9Z$!3!!!!Q!!!!$)!\r!N!Z!!!&F)!!!!%9h!*!&*!#3"%9Z"3%!!!!T!!!!#B!!N!F)G'e`-*!'!$&&EJ8\r"!!!!+J!!!!D!!*!(*6!eE'3!!!"&D`!%!!!!+`!!!8#!!*!(I!J#TVpKrqb3!!%\r!#*3Krf!li`!!1k3!!$YP!!!lKJ!!Jm)!!$`GUl-S!&"'3))!'#`F!!""JJ!3Xhm\r!!*1I!!*)!!"31(X!!$`GUl-S!&"'3))!%$b!G'8iK'e`5!!!#$LG!!!iS!!"10m\r!!$Mr!!*)!!!"B!!!!)##!!#`C!!!I'!(08'#!!`iI`!!5!!!S$`GUl-S!&"'3))\r!I)J#!!"m!!Ge3))!&$J!rrq3!!)!!$J!!!'B!J!!1(m!"S##!!")!!!"B!!!!)"\rL!!!iJ`!"2'!!!MKMKU"m""[@I!!CeR`!)&#3!!)!!$Kr!!SiRJ!!J+)!!%J!!!&\rJ!!!!1(m!!%J!!!&J!!!!9'!'2d##rla)!!!B1'%!1$LI!!!iS!!"5!!!!@!!!!!\riI`!!J!%!U$JK!+"m#!1QZf(rl%k!!#"&G!-!N!3U!!!!)%9e!*!&,!!!!("&G!-\r!N!3#!!!!H%9c%!#3"#J!!!#F4A-3!*!%*`!!!+a&Fa!!N!3S!!!!Y%9d!`#3"#N\r!!!#m4A8!N!8B!!!!`%9c%!#3"#F!!!$)4A-3!*!%*`!!!14&Fa!!N!3R!!!!m%9\re!*!&,3!!!24&G3#3"5i!!!%!4A8!N!8[!!!")%9Z$!3!!!!`!!!!$)!!N!Z!!!&\r!+!!!!%9h!*!&+`#3"%9V!!3!!!!a!!!!I)!!N!Gm#!+QNq(rr*!!!3!)P#(rJ$[\rM!!#`J3#H1"m!"T!!!3"+U!%!RV!"!&!i!!!!X!%!9$KK!$K)!!!"B!!!!)##!!#\r`C!!!I'!(08'#!!`iI`!!5!!!'+J"!'b`(`!!J!%!FT!!(`!#1(m!!)!"!)Ji)3#\r!I!J$TS2Krra1J!!J4A8!N!8b!!!!0%9d!`#3"!)!!!!m4@i-"!!!!$-!!!!-J!#\r3#i!!!(`)!!!!4AF!N!8a!*!%4@X!"!!!!$3!!!$8J!#3"h`)!UD6iIrmN!!"!!L\r8)Ip`1q-!!)"L!!#)!`!!+!!!!%'#!*3iS3!`1*rrq$J!!!Km#31QK'3!#)!%!!5\r8C3!)N!!&!!4#!2r`J'3!#+!%!!b3!'8!#,!&!!bSB3!iJ)%!1MLK!$iih`!!5!!\r!!@!!!!#!JJ!!X'3!!$KK!$iiR`!'1+!!!$M!!!&)!!!"B!!!!&4J"Mp"JJ!X1(m\r!"ML"!$k)S3!q1+8!!8J!!!&J!!!!5!!!%$J!!!#!BJ!!X!-!!)!"!*Ji)3#3!(`\r)!kD$iIrm6S!!)%9d!`#3"#!!!!!84A8!N!8K!!!!D%9d!`#3"!)!!!"`4A8!N!8\rL!!!!L%9e!*!&'3!!!+K&G!-!N!3#!!!!Z%9Z$!3!!!!e!!!!$)!!N!Z!!!$8#!!\r!!%9h!*!&0!#3"%9U!!3!!!!h!!!!I)!!N!Gm#!+QNq(rr*2"rrL3!!%!#*3Krm!\rl``!!1q3!!*LK!'1)!3"M+!!!!%'#!"Ji!!!kJ(i!!$KMrrq3!(i!!*J$!!#)I`!\r!J"i!!(`$!&#3!"i!!)"q!!!iR`!"L,m!!%J!!!&J!!!!J!%!5$JK!%"m#!1QJq(\rrr)2"rrK1J!!J4A8!N!8i!!!!A%9Z$!3!!!!j!!!!$)!!N!Z!!!"m%!!!!%9h!*!\r&0`#3"%9Z%!%!!!!k!!!!!B!!N!LY,QP&D`!%!!!!1`!!!1b!!*!(I!J#TT2Krrb\r6`IriNk(rp*1"rr#3!!%!#*3Krl!l``!!Jq)!!)1#!!#!BJ!!1!-"rj!!!3!iJk)\r!!$J!!!#!B3!iQ!-!!$KK!$JiRJ!'J,i!!MJ!!!&m"3"3I!!!0&3&fAj)!!!"Nlm\r!%S!H!!+3!"m!C%J!!%bS(J!!X"m!&MJ!rrq`(`!FJ"m!C*!!(`!`1(m!!%J!!!&\rJ!!!!X(`!!(aJ"c9"JJ!-1')!!%J!!#3iB3!i1*d!!$LJ!!&)!!!"J"m!C#`!!!&\r!J[q`J'%!1)!"!&Ji)3"3I!J$TS2Krrb$`IriJk(rp)1"rr"1J!!J4A3$!*!%"3!\r!!#"&G!-!N!3#!!!!*%9d!`#3"$B!!!!S4A3$!*!%0J!!!$4&G3#3"6F!!!"J4A8\r!N!8m!!!!N!"&Fa!!N!3k!!!!T%9e!*!&0`!!!,K&EJ`%!!!!23!!!!b!!*!,J!!\r!l#!!!!"&G`#3"6X!N!4&D`!%!!!!2J!!!K5!!*!(I!J#TVm"rq#3!!%!#*3Krc!\rl!`!!Jf)!!)1L!!!i'`(rN!!"!+3lf`!!1!!!!)"K!+5B!`!!1(J!!$L"!$JiS!!\r!5!!!!@!!!!#`I3!!I'!(08'#!!`iB!!!5!!"U)"L!!#)!`!!+!!!!%'#!#`iB!!\r!L!%!9P3!"[G!JJ!8S!%!B&3!"#&"JJ!)1'!!!94J"Mp!JJ!81!$r2l!G!!!iB!!\r!5!!"B%J!!!&J!!!!1b-!!$Ki!!!iJ!!"5!!!!@!!!!!l3`!!Id!(0#`!rrp!JJ!\rB5!!!!@!!!!#`I3!!1i!!!%J!!%JmB'&X1)!!!$KMDA0)!!!"B!!!!(am'hP"JJ!\r81(`!!%J!!!&J!!!!5!!!%%J!!!&J!!!!X(d!!$Kk!!")!!!"B!!!!$Kj!!")!!!\r"B!!!!#JF!!"!JJ!-1'!!!%J!!-!li!!!5!!!1)JE!!"m!!Ge3B)!6$KK!+3iRJ!\r!Iq8(0$J!!!"m!!FdI+8!8$!&rrpmS#N35!!!!6[r!!%iI!!!1*m!!$Lq!!")!!!\r"B!!!!,"p!!"mB!Fe3B,rX+JG!!!X!!!!3))!0$Km!!!iJ2rr1,i!!%J!!!&J!!!\r!X(d!!(aJ"c9!JJ!81'%!T$LH!!!iS!!"5!!!!6Km!!")!!!"B!!!!+JG!!!X!!!\r!3B)!$$KJ!!")!!!)J'%!T)!"!0Ji)3$3I!J$TVX"rq"1J!!J4A3$!*!%0J!!!"4\r&G!-!N!3#!!!!'%9e!*!&2`!!!%"&G!-!N!3F!!!!A%9e!*!&3!!!!+4&G3#3"8%\r!!!#i4A8!N!9#!!!!d%9e!*!&3`!!!2"&G3#3"83!!!%%4A8!N!9#!!!"%%9e!*!\r&43!!!5"&G3#3"8B!!!%X4A8!N!8h!!!"H%9e!*!&4`!!!Ba&G3#3"8F!!!'i4A8\r!N!8h!!!"f%9e!*!&5!!!!H"&EJ`%!!!!53!!!!b!!*!,J!!#&%!!!!"&G`#3"6i\r!N!4&D`!%!!!!5J!!!&b!!*!(I!J#TT2Krrb3!!%!#*3Krl!li`!!1'%!2$L"!$K\r)!!!"I'!(08'#!"!iI`!!5!!!!8J!!"JiI`!!U)%!2)#K!$K)!!!"B!!!!)!"!&J\ri)3"3I!J$TS2Krra1J!!J4A8!N!8,!!!!(%9e!*!&1`!!!#a&G3#3"8X!!!"!4@i\r-"!!!!%`!!!!-J!#3#i!!!&`)!!!!4AF!N!9+!*!%4@X!"!!!!%d!!!#FJ!#3"h`\r)!UD6iIrmNm(rq*!!!3!)P#(r-$[$!!#3!)%!l)2L!!!iB3#!J)%!l$LJ!!")!!!\r"U"m!!#`!!!""JJ!31(i!!%J!!!&)!!"!1'%!1$L"!)")!!!"B!!!!+JI!!!X!!!\r!3B)!%$Kq!!")!!!"5!!!'$Kq!!#SJ3#!J+%!JNJ!!!&J!!!!J!%!f$JK!0"m#!1\rQJq(rr)2"rrK1J!!J4A3$!*!%!J!!!"a&G3#3"4X!!!!X4A8!N!8l!!!!3%9e!*!\r&6J!!!&"&G3#3"6X!!!"S4A8!N!9,!!!!I%9Z$!3!!!"2!!!!$)!!N!Z!!!#F%!!\r!!%9h!*!&63#3"%9V!!3!!!",!!!#')!!N!Gm#!+Q[b(rj*!!!3!)P#(rS$Z$!!!\rlC!!!1d8!!)2L!!#$SJ!!Jb)!!)!$!!)X!!!"3))!@+Km!!"rB!FdI!-!!%##!"3\rX'J!#3))!$$[G!!")!!!J1(d!!$LF!!H)[!!'5!!!!@!!!!#)(!!'Ipd#&$J!!$U\rB(J!!1!!!!*JH!!%iI3!!5!!"J*1r!"+cI`!@1!$rrl!I!"b6A`!`1(m!!%J!!!&\rJ!!!!X(N!!(aJ"c9"JJ!-1')!!%J!!8arB`FdU"`!!(`$!!"!JJ"3J(m!C)!F!!*\rm!`!!3))!3$Kp!!!iR!!'L"d!!(`&"h3iT3!"5!!!!@!!!!!X!`!!3))!($J!!$U\rB(3!!1!!!!*JG!!%iI3!!5!!!m$J!!!#B(3(rL(`!"MJG!Ipr``"31(i!!$LF!!H\r)[!!'5!!!!@!!!!#6[`!5J"`!!T!!(`"N1!!!1T`HrrprB`FdU"`!!(`$!!"!JJ!\riJ"m!C(`D!!"!JJ!X1(i!!6L!!$T)!!!"B!!!!#J$!!""JJ!-1(i!!%J!!(JiIJ!\r"5!!!F+JF!!#`(`!@1!$rrl!I!"b!(`"NN!!I!$!iI`!!5!!!!@!!!!#`H3!!I'!\r(08'#!!`iBJ!!5!!!1)JG!!"m!!GdIm$`8$Kq!!!iR3!"L,d!!(bP"h4)!!!"B!!\r!!)!I!$!X!!!#3),r8$Kq!!#!!3"S1#%!B(`)!kDl)IrN6S!!)%9d!`#3"!8!!!!\rF4A3$!*!%0J!!!#"&G!-!N!3#!!!!*%9e!*!&'3!!!'"&G3#3"6`!!!#J4A-3!*!\r%1J!!!,4&G3#3"9!!!!$`4A8!N!8C!!!"1%9e!*!&83!!!AK&G3#3"6`!!!'d4A-\r3!*!%1J!!!FK&G3#3"6J!!!(X4@i-"!!!!&)!!!!-J!#3#i!!!KJi!!!!4AF!N!9\r,!*!%4@i&!3!!!&-!!!!-J!#3"a%P-$4S@#8`1&Jk!%9V!!3!!!"8!!!!G)!!N!G\rm#!+QNq(rr*2"rrL3!!%!#*3Krm!li`!!Jm)!!$Kq!!#!JJ!!U,m!!)$I!!*)!!!\r"B!!!!$Kq!!iiR`!(L,m!"NJ!!!&J!!!!1)!!!)JI!!CmB2)8Q)-!$MKq!!#!!3"\r)1#%!3(`)!kD$iIrmJm(rq%k!!#"&G!-!N!3f!!!!'%9d!`#3"&-!!!!J4A8!N!8\rY!!!!,%9e!*!&'3!!!%"&EJ`%!!!!93!!!!b!!*!,J!!!G"!!!!"&G`#3"93!N!4\r&D`!%!!!!2`!!!)L!!*!(I!J#TT2Krrb6`IriN!!"!!L8)Ir!1m-!!$[N!!#BS3"\rMU!-!!,!%!"D!!`!#N!!%!$!i(J!'N!!%!"+)!3"M+!!!!%'#!!`i!2rr5!!!#$J\r!!!#`(`!F1!!!!*JI!"miI`!!5!!!!@!!!!#!JJ!!X'3!!)!"!%Ji)3"!I!J$TS2\rKrrb$`Iri6S!!)%9e!*!&2!!!!'"&G!-!N!3#!!!!D%9Z$!3!!!"@!!!!$)!!N!Z\r!!!#)%!!!!%9h!*!&2`#3"%9V!!3!!!!@!!!!I)!!N!Gm#!+QNq(rr*!!!3!)P#(\rr`*!!B3"B1q3!!)!%!!)X!!!"3))!%$Kr!!")!!!"5!!!-$Kr!!#!JJ!!1+!!!8J\r!!!'!BJ!!U!-!!#`!!!"!JJ!3J')!!)!$!'53!"m!!S"K!&JiR`!!5!!!!B!"!%J\ri)3"!I!J$TS2Krra1J!!J4A8!N!86!!!!+%9d!`#3"!8!!!!d4A8!N!8r!!!!2%9\rd!`#3"!)!!!"!4A3$!*!%"3!!!&"&G3#3"3J!!!"N4@i-"!!!!&F!!!!-J!#3#i!\r!!(`)!!!!4AF!N!8@!*!%4@X!"!!!!%i!!!%%J!#3"h`)!UD6iIrmNm(rq*!!!3!\r)P#(r`*!!B3"B1m3!!)2L!!!iIJ!!5!!!!94J"Mp"JJ!J1!!!!,!H!!!i!!!"N!!\rH!!)i!!!!Q"i!"NJ!!*JiIJ!!1*m!!$LJ!!")!!!"I'!(08##!)!iB!!!L"m!(P3\r!"[G!JJ!8S"m!+&3!"#&"JJ!)1'!!!94J"Mp"JJ!d1(i!!$LI!!")!!!"B!!!!(a\rJ"c9!JJ"!1(i!!$LI!!!iS!!!5!!!!AaJ"c9!JJ!SL"m!(P3!"[G!JJ!81!$XAi"\rL!!#`!`!!5!!!$)!I!$#3!"i!!S"K!&JiRJ!!5!!!!B!"!%Ji)3"!I!J$TS2Krrb\r$`Iri6S!!)%9d!`#3"!8!!!!F4A8!N!88!!!!*%9e!*!&2`!!!&K&G3#3"9J!!!#\r84A8!N!8r!!!!X%9d!`#3"!)!!!$-4A8!N!8)!!!!k%9Z$!3!!!"C!!!!$)!!N!Z\r!!!%%%!!!!%9h!*!&6J#3"%9V!!3!!!![!!!!H)!!N!Gm#!+QNq(rr*2"rrL6SIr\rdN!!"!!L8)Ip`N!"K!+Jla!!!1k8!!)2L!!")!!!F1'%!1$LH!!")!!!"U"m!!#`\r!!!"!JJ!3,"d!!$Zprrp"JIrJJ'%!U$LH!!")!!!"J!%!Q$JK!*!!I!J$TS2Krrb\r$`IriJk(rp%k!!#"&G!-!N!3#!!!!*%9e!*!&&J!!!$4&G3#3"3J!!!"B4@i-"!!\r!!&S!!!!-J!#3#i!!!(JB!!!!4AF!N!8[!*!%4@X!"!!!!&X!!!"%J!#3"h`)!UD\r3!!%!#*3Kri#3!'%!Q*!!J3#FN!#K!+!iB3!iJ)%!R%J!!!'!B3#B1)%!1)#K!+"\r)!!!"J!%!L$JK!)"m#!1Q6S!!)%9e!*!&#!!!!#"&G3#3"5m!!!!`4@i-"!!!!&`\r!!!!-J!#3#i!!!%3!N!4&G`#3"9X!N!4&D`!%!!!!@!!!!)#!!*!(I!J#TT2Krrb\r3!!%!#*3Krl#3!'%!D$[N!!#!BJ!!L!-!!#J!!!""JJ!mL"m!(P3!"[G!JJ!`S"m\r!+&3!"#&"JJ!NJ'%!D$L!!!%iS3!j1-%!1%J!!!&J!!!!I'-(0%J!!!JiB!!!J))\r!!,"N!!#!!3"B1#%!8(`)!kD$iIrm6S!!)%9d!`#3""`!!!!B4A8!N!9G!!!!8%9\rd!`#3"!)!!!"N4@i-"!!!!&i!!!!-J!#3#i!!!)!)!!!!4AF!N!9B!*!%4@X!"!!\r!!"d!!!"mJ!#3"h`)!UD6iIrmNm(rq*!!!3!)P#(r`$[$!!#BJ3"IJq)!!)##!!!\riS!!!5!!!!DJI!!!X!!!!3B)!*)J"!&mS!!!!3B)!%$KJ!!#`I`!!5!!!'+Kr!!"\r)!!!31(i!!)##!!")!!!"J!%!5$JK!%"m#!1QJq(rr)2"rrK1J!!J4A3$!*!%!J!\r!!"a&G!-!N!3&!!!!)%9e!*!&2`!!!#K&G!-!N!3&!!!!A%9e!*!&@!!!!'"&EJ`\r%!!!!A`!!!!b!!*!,J!!!I"!!!!"&G`#3"4d!N!4&D`!%!!!!,J!!!&5!!*!(I!J\r#TT2Krrb3!!%!#*3Krm#3!'%!@)"K!&L!JJ!!1+!!!%J!!!&mB!FdI!!!0&3IfAi\ri!!!!J')!!,!$!!!iI`!!J!%!5$JK!%"m#!1QJq(rr%k!!#"&G!-!N!3&!!!!'%9\re!*!&2`!!!#"&G!-!N!3#!!!!0%9Z$!3!!!"J!!!!$)!!N!Z!!!"8#!!!!%9h!*!\r&,J#3"%9V!!3!!!"K!!!!L)!!N!Gm#!+QNq(rr*2"rrL6SIrdN!!"!!L8)Iq`1m-\r!!$[N!!!lS!!!U'-!!+J%!!"m!`!!3))!1)"q!!+!(`!#I!-!!%##!#JiIJ!'1*m\r!"MLJ!!!i`!!"5!!!!@!!!!"8B!Br3B)!#$ZJ!!%iI3!!J!%!@$JK!&"m#!1QJq(\rrr)2"rrL$SIrd6S!!)%9e!*!&)J!!!&4&EJ`%!!!!BJ!!!!b!!*!,J!!!L"J!!!"\r&G`#3"@%!N!4&D`!%!!!!B`!!!)L!!*!(I!J#TT2Krrb6`IriNk(rp*!!!3!)P#(\rrX$[$!!!lj!!!1k!!!+KM!!#S"!!!I!-!!%##!$5!IJ!#J"m!!R`$!!"!JJ!N1(i\r!"MLI!!BiS!!!1-!!!8J!!!&J!!!!9'!'2d##!!JlS!!"1(d!!)!"!&Ji)3"3I!J\r$TS2Krrb$`IriJk(rp%k!!#"&G3#3"5)!!!"84@i-"!!!!'3!!!!-J!#3#i!!!)J\rB!!!!4AF!N!9M!*!%4@X!"!!!!'8!!!#3!)!!N!Gm#!+QNq(rr*2"rrL3!!%!#*3\rKrZ!l``!!N!#"!6b$iJ!!1'%!J)#"!6`iS!!"5!!!!6KK!-JiJ3#!5!!!!8J!!#`\riB3$)1*i!!%J!!!&8B!Br3B)!$$KJ!!&)!!!J1'%!1$L"!-K)!!!"U"m!!#`!!!"\r"J[r31'!!!)!"!5Ji)3%JI!J$TS2Krrb$`Iri6S!!)%9d!`#3"!)!!!!F4A8!N!9\rE!!!!,%9e!*!&#!!!!$K&G3#3"@%!!!")4A8!N!8@!!!!C%9Z$!3!!!"Q!!!!$)!\r!N!Z!!!#3!"!!!!"&G`#3"@8!N!4&D`!%!!!!C`!!!+b!!*!(I!J#TT2Krrb6`Ir\riN!!"!!L8)Ip`N!"K!+Jlj!!!N!#K!,!laJ!!,"i!2d#"!"3i!2rEJ')!!,!$!!"\r)!!"31'%!1$LI!!")!!!"J')!!+J$!!!X!!!!3))!0$Kr!!H!J3#`Qpm!"PI&"Mj\r)!!!"B!!!!)!I!!)X!!!"3))!%$Kr!!!iJ2rr5!!!!B"K!+JiR`!!5!!!!B!"!*J\ri)3#3!(`)!kD$iIrmJm(rq%k!!#"&G!-!N!3#!!!!-%9e!*!&6J!!!%4&G!-!N!3\r#!!!!5%9e!*!&'3!!!'K&G3#3"4!!!!#%4A8!N!8)!!!!N!"&EJ`%!!!!D!!!!!b\r!!*!,J!!!V"!!!!"&G`#3"@F!N!4&D`!%!!!!#3!!!%5!!*!(I!J#TT2Krrb3!!%\r!#*3Krm#3!'%!@*!!J3"F1q8!!)"K!&L!J3"F1,m!!BMI!!")!!!"J!%!5$JK!%"\rm#!1QJq(rr%k!!#"&G3#3"@F!!!!X4@i-"!!!!'N!!!!-J!#3#i!!!%3)!!!!4AF\r!N!8*!*!%4@X!"!!!!'S!!!"%J!#3"h`)!UD3!!%!#*3Kri#3!'%!Q*!!J3#FN!#\rK!+!iB3!iJ)%!R%J!!!'!B3#B1)%!1)#K!+")!!!"J!%!L$JK!)"m#!1Q6S!!)%9\re!*!&#!!!!#"&G3#3"3N!!!!`4@i-"!!!!'X!!!!-J!#3#i!!!%3!N!4&G`#3"@S\r!N!4&D`!%!!!!E!!!!&#!!*!(I!J#TT2Krrb3!!%!#*3Krm#3!'%!@*!!J3"F1q8\r!!$Kr!!")!!!"B!!!!$M$!!#!B3"BJ)%!A$Lr!!")!!!"J!%!5$JK!%"m#!1QJq(\rrr%k!!#"&G3#3"@d!!!!J4A8!N!9R!!!!1%9Z$!3!!!"Z!!!!$)!!N!Z!!!"3#!!\r!!%9h!*!&E!#3"%9V!!3!!!"[!!!!4)!!N!Gm#!+QN!!"!!L8)Iq!N!"K!*L3!)%\r!R*!!S3#J1'%!1)#"!*a)!!!"J'%!Q$L"!$L!S3#J5!!!!B!"!)Ji)3#!I!J$TNk\r!!#"&G3#3"3J!!!!J4A8!N!9X!!!!-%9Z$!3!!!"`!!!!$)!!N!Z!!!"%!*!%4AF\r!N!9[!*!%4@X!"!!!!(%!!!#JJ!#3"h`)!UD6iIrmNm(rq*!!!3!)P#(rF*!!B3#\rSN!#"!+`la3!!Jq)!!$KK!$L!J3#X5!!!!B!"!$SX!!!"3))!&$KK!$JiRJ!!5!!\r!!8J!!$5S!3!iX"m!&S!"!$U3!"m!-$J"!$k3!"m!%V2I!"`iI`!!5!!!!@!!!!#\r!JJ!!X'3!!)"K!+JiJ3!i5!!!!B!"!*Ji)3#3!(`)!kD$iIrmJm(rq%k!!#"&G!-\r!N!3&!!!!)%9e!*!&#!!!!#a&G3#3"4!!!!"%4A8!N!8m!!!!E%9d!`#3"!)!!!"\rd4A8!N!8)!!!!K%9Z$!3!!!"b!!!!$)!!N!Z!!!#J%!!!!%9h!*!&F3#3"%9U!!3\r!!!"c!!!!d)!!N!Fi!!!!N!!&!!")!!#dJ!8!!&3!)$D3!!8!!)J$!!"m!!Gd,!!\r!4d#!!#3X!!!k3)!!%#`!!$"!J!!S5!!!H#`!!%&!J!"85!!!E#`!!'G!J!"N,!!\r!B8#!!#4)!!"BJ18!!)J$!!"m"JGd1!Erd(cJ!hL3!!8!!%J!!%5!j3!!L!-!!(`\r'"h3i"[qTI1!$H*!!"3!!5!!!+)$P!!#)!`!!I!B(G$J'rmPmi!0iN!!&!!")!!!\r-1'!!!%k!!#!iB`!",!3!!$L%rrp!J[p)1'!!!8k!!#"&D`!%!!!!G!!!!G#!!*!\r(I!J#TT2Krrb6`IriNk(rp*!!!3!)P#(rB$[$!!!lj!!!Q+%!`i1L!!#)"!!!,!!\r!%6[r!!&"JJ!-1'!!!%J!!AJiI`!!1)!!"$LK!)")!!!"9'!'2d'#!9b!!3#!X"i\r!!$Kr!!3iJ!!)1+%!J%J!!!&8B!Br3B)"2)!"!)#3!"i!!S`I!!`X!!!k3))"+$K\rr!!%iJ!!k5!!!!@!!!!!S!`!!3))"%)JI!!&m!!Ge3))!'$KK!$JiRJ!!5!!!!6K\rJ!!&)!!$d1(m!!8J!!!&J!!!!Q(m!!)"L!!#)!`!!+!!!!%'#!%#SIJ!!J*i!!ML\rr!!!ihJ!!5!!!!@!!!!#`I3!!I'!(08'#!$LS(3!!,!$re8##!#`i!!!!X"d!!%J\r!!#!iIJ!'1*m!!)JI!!"m"3Gd1+8!!8J!!!&J!!!!L!%!`bJ!!!"!JJ!JJ')!!)J\r$!!!S!!!!3B)!%$Kq!!!iJ!!"5!!!!6Kq!!BiR`!!1+!!!$M!!!&)!!!"B!!!!&4\rJ"Mp"JJ!J1(i!"MLI!!#)(`!!I!8(G$LP!!&)!!!"B!!!!$J!!$UB(`!!1'!!!8J\r!!!JiB!!!J!%!U$JK!+"m#!1QJq(rr)2"rrL$SIrd6S!!)%9d!`#3"!)!!!!N4A8\r!N!9c!!!!6%9e!*!&F`!!!'a&G3#3"9%!!!#84A8!N!8@!!!!Z%9e!*!&E3!!!-K\r&G!-!N!3J!!!!e%9e!*!&)3!!!24&G3#3"4N!!!%d4A3$!*!%(!!!!8K&G3#3"4d\r!!!&J4A8!N!8L!!!"G%9e!*!&'3!!!CK&EJ`%!!!!G3!!!!b!!*!,J!!"d"J!!!"\r&G`#3"A3!N!4&D`!%!!!!GJ!!!Y5!!*!(I!J#TVmKrq53!!%!#*3Kra!l``!!1q3\r!!$XP!!#$3J!!Ji)!!%J!!!&8B!Br3B)!$$Kq!!")!!+-1(m!!%J!!!&J!!!!N!"\rK!-L$BJ!!J')!!)J$!!!S!!!!3B)!l$Kq!!")!!!"1(m!!$LE!!")!!!"B!!!!+K\rq!!#!RJ!#1,X!!$MH!!")!!!"B!!!!,"m!!"mB!Fe3B)!*%#!!+`X!2r93B)!#%J\r!!+!i!!!!X"`!!$Kq!!")!!)-9b!'2d##!"b)'J!!+!!!!%'#!"!iIJ!!1)!!!8J\r!!!%iI`!!1)!!1NJ!!!&J!!!!I(dEH8'#!!Jlr3!"1(m!!$LE!!")!!!"B!!!!$K\rq!!BiQ`!!1+!!!$M!!!&)!!!"B!!!!&4J"Mp"JJ!F1(i!"MLE!!#)Z`!!1+8!!8J\r!!!&J!!!!1(i!!%J!!B#)(`!!,!!!1N'#!"`iI`!!1)!!1NJ!!!&J!!!!I(dEH8#\r#!#!iIJ!!5!!!!BJI!!!X!!!k3))!D$[r!!&)!!"JI"rS8#`!!$j!J3!81!$rfl!\rF!!!iIJ!!5!!"*$Kq!!FiR`!!I,rS8$J&!!'B(J!'9!8'2NJ!!!&J!!!!1(i!!$L\r!rrp)!!!"I'!(08'#!!`iIJ!!5!!!k$[p!!'S(!!!,!!!!%'#!+JiIJ!!5!!!d)J\rI!!!X!!!k3))!0$Kq!!!iJ!!"5!!!!6KK!)!iRJ!!5!!!!DJF!!!X!!!!1rm!!8'\r#!'`iIJ!!5!!!P$Kr!!!iJ!!k5!!!!@!!!!"mI4Yj3B)!$$J!!!#B(3!!1'%!1$L\rH!!!i[`!!5!!!!5JG!!""JJ!-1!!!1TJG!!#S(!!!,!!!!%'#!!`iIJ!!5!!!3#J\rG!!""JJ!81rd!!BJI!!"m!!Ge3),rA&FJ"Mp!JJ!FL"S!!#J!!!""JJ!31(i!!$L\r!!!&)!!!"1(i!!)!"!2Ji)3$`I!J$TVXKrq41J!!J4A3$!*!%(!!!!"a&G!-!N!3\r#!!!!)%9e!*!&G!!!!#4&G3#3"@d!!!!m4A3$!*!%0J!!!%K&G!-!N!3J!!!!6%9\re!*!&$J!!!'"&G3#3"AF!!!"X4A8!N!8K!!!!K%9e!*!&(3!!!04&G3#3"AJ!!!$\rJ4A8!N!9h!!!!r%9e!*!&)J!!!44&G3#3"4N!!!%d4A8!N!94!!!"@%9e!*!&&3!\r!!@a&G3#3"4N!!!'i4A8!N!83!!!"b%9e!*!&(3!!!JK&G3#3"4B!!!)84A8!N!9\r4!!!#1%9e!*!&E!!!!Pa&G3#3"4d!!!+i4@i-"!!!!(N!!!!-J!#3#i!!!Y3i!!!\r!4AF!N!9f!*!%4@X!"!!!!(S!!!!iJ!#3"h`)!UD3!!%!#*3Kri#3!'%!Q$KK!$L\r!J3#B1+!!!8J!!!%iB3!i5!!!!B!"!)Ji)3#!I!J$TNk!!#"&G3#3"4X!!!!F4A8\r!N!8l!!!!*%9Z$!3!!!"l!!!!$)!!N!Z!!!!i!*!%4AF!N!9k!*!%4@X!"!!!!(`\r!!!!iJ!#3"h`)!UD3!!%!#*3Kri#3!'%!Q$KK!$L!J3#B1+!!!8J!!!%iB3!i5!!\r!!B!"!)Ji)3#!I!J$TNk!!#"&G3#3"4X!!!!F4A8!N!9+!!!!*%9Z$!3!!!"p!!!\r!$)!!N!Z!!!!i!*!%4AF!N!9m!*!%4@X!"!!!!(i!!!"!J!#3"h`)!UD3!!%!#*3\rKri#3!'%!Q*!!J3#F1'%!1)#"!*JiS!!"5!!!!6KK!$L!J3#F5!!!!B!"!)Ji)3#\r!I!J$TNk!!#"&G3#3"4X!!!!J4A8!N!90!!!!,%9Z$!3!!!"r!!!!$)!!N!Z!!!"\r!!*!%4AF!N!9q!*!%4@X!"!!!!)!!!!!iJ!#3"h`)!UD3!!%!#*3Kri#3!'%!Q$K\rK!$L!J3#B1+!!!8J!!!%iB3!i5!!!!B!"!)Ji)3#!I!J$TNk!!#"&G3#3"4X!!!!\rF4A8!N!98!!!!*%9Z$!3!!!#"!!!!$)!!N!Z!!!!i!*!%4AF!N!@!!*!%4@X!"!!\r!!))!!!"`J!#3"h`)!UD3!!%!#*3Kri#`B3#DN!#"!*`iB3!iU)%!QNJ!!!'!B3#\rF1+2rq$L"!$!i!!!)I!N$TS4N!!L!"!!%P'8!#*!!"3!%3J$rm)"N!!LJ"!!-N!"\rP!!L`"3!-J')!!+KM!!#!!3#)1#%!J(`)!kC1J!!J4A8!N!8a!!!!(%9d!`#3"!)\r!!!"B4@i-"!!!!)-!!!!-J!#3#i!!!(!!N!4&G`#3"B)!N!4&D`!%!!!!K!!!!(b\r!!*!(I!J#TT!!!3!)P#(rJ,"K!*U3!)%!R*!!S3#J1'%!1+L"!*U!S3#F1-!!!%J\r!!!'!B3#J1+2rq$L"!$!i!!!)I!N$TS4N!!L!"!!%P'8!#*!!"3!%3J$rm)"N!!L\rJ"!!-N!"P!!L`"3!-J')!!+KM!!#!!3#)1#%!J(`)!kC1J!!J4A8!N!8N!!!!+%9\rd!`#3"!)!!!"N4@i-"!!!!)8!!!!-J!#3#i!!!(`!N!4&G`#3"B3!N!4&D`!%!!!\r!KJ!!!(5!!*!(I!J#TT!!!3!)P#(rJ*!!B3#BN!#"!*`iB3!iJ)%!Q$LJ!!")!!!\r"J'%!R$LMrrJiJ3!`1!!!#(`*!kD%C!!)J!3!"*4P!!L3!!8!"%)!rr#!C!!)S!3\r!$*!!C3!)X!8!$)"L!!#SB`!!J!%!L$JK!)"m#!1Q6S!!)%9e!*!&GJ!!!#"&G!-\r!N!3#!!!!A%9Z$!3!!!#(!!!!$)!!N!Z!!!"d!*!%4AF!N!@'!*!%4@X!"!!!!)J\r!!!#!J!#3"h`)!UD3!!%!#*3Kri#3!'%!Q,#"!*k3!+%!S*!!`3#N1'%!1)#"!*L\rSS3#HJ-%!S%J!!!'!B3#N1+2rq$L"!$!i!!!)I!N$TS4N!!L!"!!%P'8!#*!!"3!\r%3J$rm)"N!!LJ"!!-N!"P!!L`"3!-J')!!+KM!!#!!3#)1#%!J(`)!kC1J!!J4A8\r!N!8V!!!!,%9d!`#3"!)!!!"S4@i-"!!!!)N!!!!-J!#3#i!!!)!!N!4&G`#3"BJ\r!N!4&D`!%!!!!LJ!!!)#!!*!(I!J#TT2Krrb3!!%!#*3Krc!li`!!1'%!J$LI!!!\riS!!!5!!!!6KK!$JiJ3#!5!!!!6LrrrJiJ3!`1!!!#(`*!kD%C!!)J!3!"*4P!!L\r3!!8!"%)!rr#!C!!)S!3!$*!!C3!)X!8!$)"L!!#SB`!!J!%!f$JK!0"m#!1QJq(\rrr%k!!#"&G3#3"4X!!!!J4A8!N!8@!!!!,%9d!`#3"!)!!!"N4@i-"!!!!)X!!!!\r-J!#3#i!!!)!)!!!!4AF!N!@+!*!%4@X!"!!!!)`!!!#)J!#3"h`)!UD6iIrmN!!\r"!!L8)Im`1q-!!*!!J3$X1'%!J$LI!!!iS!!!5!!!!6KK!$JiJ3#!J+%!l%J!!!%\ri[rri1)%!-$J!!!Km#31QK'3!#)!%!!58C3!)N!!&!!4#!2r`J'3!#+!%!!b3!'8\r!#,!&!!b!BJ!!U'-!!)!"!0Ji)3$3I!J$TS2Krra1J!!J4A8!N!8E!!!!*%9e!*!\r&DJ!!!$4&G!-!N!3#!!!!E%9Z$!3!!!#0!!!!$)!!N!Z!!!#)#!!!!%9h!*!&M!#\r3"%9V!!3!!!#1!!!!I)!!N!Gm#!+QNq(rr*2"rrL6SIrdN!!"!!L8)Ip`1k-!!$[\r%!!!iB3!i1*d!!$LJ!!")!!!"1'%!1$LH!!!iS!!!5!!!!6[M!!"ri!Fe3B)!$$K\rr!!")!!!31"d!"T!!(J!51'!!!)!"!*Ji)3#3!(`)!kD$iIrmJm(rq)1Krr41J!!\rJ4A8!N!8E!!!!,%9e!*!&2`!!!$a&EJ`%!!!!M`!!!!b!!*!,J!!!I"J!!!"&G`#\r3"Bi!N!4&D`!%!!!!N!!!!!#)J!#3"h`)!UD6iIrmN!!"!!L8)Im`1q-!!,#"!1i\riB3#!1*m!!$LJ!!")!!!"1'%!1$L"!)#SS3$Z5!!!!6LrrrJiJ3!`1!!!#(`*!kD\r%C!!)J!3!"*4P!!L3!!8!"%)!rr#!C!!)S!3!$*!!C3!)X!8!$)"L!!#SB`!!J!%\r!f$JK!0"m#!1QJq(rr%k!!#"&G3#3"4X!!!!N4A8!N!9a!!!!0%9d!`#3"!)!!!"\rX4@i-"!!!!*%!!!!-J!#3#i!!!)J)!!!!4AF!N!@3!!#3"%9U!!3!!!#5!!!!B)!\r!N!Gm#!+QNq(rr*!!!3!)P#(rF*!!B3#S1!!!!*!!!3"+1'%!1%J!!!&J!!!!1q-\r!!(rJ"c9"JJ!-1(m!!%J!!"5S!3"1J'%!U,!$!!!iB!!!J!%!Q$JK!*!!I!J$TS2\rKrra1J!!J4A8!N!@6!!!!)%9Z$!3!!!#8!!!!$)!!N!Z!!!"J#!!!!%9h!*!&NJ#\r3"%9V!!3!!!#9!!!&q)!!N!Gm#!+Q[d(rk*!!!3!)P#(lF*!!B35SN!#""+`iB33\rSJ)%%U$LJ!!&)!!!"1'%$i)#""+`iS!!"5!!!!6KK!4!iJ32J1+!!!8J!!!%iB31\rB1)%"%%J!!!'S!33S,!!!!%##!#!iB33S5!!!!6[M!!"ri!Fe3B)!$$Kr!!")!!9\rXU!%$i#`!!!"!JJ!J1'%$i%J!!!%li`!!Iq!(08'#!!`iI`!!5!!&4+KK"#LS!32\rJI!-!!%'#!!`iB2VT5!!&,$KK"#iiJ32Q1+!!!$M!!!&)!!!"B!!!!&4J"Mjm!!!\rd9"lCIS"K"#U!!32LI'-!8$!$rrprS"N31'%$i$L"!RJiS!!!5!!!!AaJ"c4m!!!\rd9"cCIMKK"#JiJ3,N1+!!!%J!!!%li`!!Iq!(08'#!!`iI`!!5!!%Y)J"!`*8!!E\rh3B)!)$KK"#JiJ32J5!!!!94J"Mp"JJ!-1'$rKNJ!")`lB!!!L!%$!P3!"[G!JJ!\r8L!%$!P3!"rp"JJ!)1f!!!9GJ"Mp"JJ!BU'%%+)#""#SiS33Z5!!!!@!!!!"A`!B\rr3))!&&HJ"Mp!JJ!-1q!!!%J!!maAJ!Br3B)!f)J"!TC8!!Eh3B)!'+!"!U`S!!!\r!3B)!$$KJrp&)!!331'%!b$b!9%fSS32JJ-%$iML%8%C)!!!"1+%#+$L$rrJi!!!\r)I!N$TS4N!!L!"!!%P'8!#*!!"3!%3J$rm)"N!!LJ"!!-N!"P!!L`"3!-1d!!!)J\r"!TC8!!Eh3))!&)J"!TC8!!Ir3B)!#$Y!!!&A3!Br3B)!'+KK!q#!J32L1+%$jNJ\r!!!&J!!!!U'%$i)#"!q)iS32Q1-%#0NJ!!!&J!!!!1q-!!(rJ"c9"JJ!-1(m!!%J\r!!eaAS!Br3))!*+KK"#L!J33U1+%%,MM"!qC)!!!"B!!!!$[M!!")!!*X9m!'2d#\r#!#LSB33SJ)%%+MLK"#k!`31D11%$RNJ!!!&J!!!!1q-!!%J!!N!iB3#!U)%%+)#\rK"#Si`32Q11!!!%J!!!%iS30)1)2rq$J!!!Km#31QK'3!#)!%!!58C3!)N!!&!!4\r#!2r`J'3!#+!%!!b3!'8!#,!&!!`iB3035!!!!94J"Mp!JJ"XU'%%+)#""#SiS33\rZ1-%$jNJ!!!&J!!!!1q-!!(rJ"c9!JJ(!U'%%+)#""#SiS32QJ-%$QMMK!jj)!!!\r"B!!!!$[M!!"ri!Fe3B)"Q+KK"#L!J33U1+%$jMM""#j)!!!"B!!!!%J!!A`iB3(\rS2)"86DLK!q#!`32L1)434NJ!!!%iB30@1)%"lSLK!HiiT3!"5!!!!@!!!!")!!"\r-1'%"S$b!9%fSS3(SJ-%"kML%8%C)!!!"1'%$9ML"!DD)S3'Q1+8!!8J!!!&J!!!\r!1'%"lML"!DD)S3'Q1+8!!8J!!!&J!!!!1'%$8%J!!!&8B!Br3),rV$KK!HK)!!!\r"9'!'2d##rjbSB33SJ)%%+MLK"#ii`30@5!!!!@!!!!!li`!!Iq!(08##!,bSB33\rSJ)%%+MLK!eD!`31D11%$RNJ!!!&J!!!!1q-!!(rJ"c9"JJ!JU'%%+)#""#SiS30\r@1-%%,NJ!!!&J!!!!5!!!H+KK!q#!J32L1+%$9MM"!qC)!!!"B!!!!$[M!!"ri!F\re3B)!9$KK!$JiJ33S1+!!!8J!!!%iB3&B1)%!1%J!!!'SB32JJ)%$iMLK!eD!`3&\rD11%"ANJ!!!&J!!!!U'%%+)#""#SiS30@1-%%,NJ!!!&J!!!!9i!'2d'#!&Kri!F\re3B)!2+KK!M#!J3)b1+%#0MM"!qC)!!!"B!!!!&G!"Mp"JJ!`U'%$i)#"!q)iS32\rQ5!!!!@!!!!")!!!BU'%#-)#"!M)iS3)f5!!!!@!!!!"ri!Fe3))!+&I!"Mp!JJ!\rJU'%$i)#"!q)iS32Q1-%$jNJ!!!&J!!!!1q-!!&GJ"Mp"JJ!iIq!(08'#!"bSB33\rSJ)%%+MLK"#j)!!!"B!!!!%J!!"LSB32JJ)%$iMLK!qC)!!!"B!!!!$Kr!!#!!35\rB1#%%N!"m#!1QZd(rk%k!!#"&G3#3"4X!!!!N4A8!N!8E!!!!0%9e!*!&@`!!!%4\r&G3#3"3J!!!"34A8!N!@5!!!!C%9e!*!&NJ!!!)a&G3#3"5)!!!$-4A8!N!8r!!!\r"!%9e!*!&2`!!!4a&G3#3"@8!!!&)4A8!N!@@!!!"N!"&G3#3"5X!!!(X4A8!N!@\r@!!!#@%9e!*!&P`!!!R"&G3#3"CF!!!+N4A8!N!@B!!!#d%9e!*!&(`!!![4&G3#\r3"5i!!!-`4A8!N!@A!!!$6%9e!*!&Q!!!!h4&G3#3"CF!!!1B4A8!N!8V!!!$Z%9\re!*!&'3!!!ma&G3#3"5X!!!2X4A8!N!8C!!!%!%9e!*!&'3!!""K&G3#3"5i!!!3\rN4A8!N!8Z!!!%0%9e!*!&P`!!"&"&G3#3"CJ!!!4i4A8!N!@A!!!%R%9e!*!&P`!\r!",K&G3#3"9X!!!6B4A8!N!8)!!!%j%9e!*!&Q!!!"2a&G3#3"CF!!!884A8!N!@\rA!!!&2%9e!*!&Q3!!"9K&G3#3"CS!!!9`4A8!N!@A!!!&Q%9e!*!&Q3!!"F"&G3#\r3"CN!!!AB4@i-"!!!!*X!!!!-J!#3#i!!"IJ`!!!!4AF!N!@9!*!%4@X!"!!!!*`\r!!!#3!)!!N!Gm#!+QNq(rr*2"rrL3!!%!#*3Krh!l``!!Jq)!!$KK!$JiRJ!!1+!\r!!%J!!!'S(`!!,!!!!%'#!!bSI`!!5!!!2$LqrrJiJ3!`1!!!#(`*!kD%C!!)J!3\r!"*4P!!L3!!8!"%)!rr#!C!!)S!3!$*!!C3!)X!8!$$KJ!!#!!3#B1#%!N!"m#!1\rQJq(rr)2"rrK1J!!J4A3$!*!%!J!!!"K&G3#3"4X!!!!S4@i-"!!!!*d!!!!-J!#\r3#i!!!*!!%!!!!%9h!*!&R!#3"%9V!!3!!!#H!!!!I)!!N!Gm#!+QNq(rr*!!!3!\r)P#(r!*!!B3%B1'%!T)#"!4JiS!!"5!!!!6KK!+3iJ3!i1+!!!8J!!!%li`!!Iq!\r(08'#!!`iI`!!5!!!*$KK!)4)!!!"B!!!!)!"!*b3!!%!D$KK!$K)!!!"B!!!!)!\r"!3Ji)3%!I!J$TS2Krra1J!!J4A8!N!8E!!!!)%9e!*!&2`!!!$"&G3#3"Cm!!!"\r-4A8!N!@J!!!!B%9Z$!3!!!#K!!!!$)!!N!Z!!!"m#!!!!%9h!*!&RJ#3"%9X"3%\r!!!!f!!!#!)!!N!G&E"!"!!!!+!!!!!'!!*!(4@`3"!!!!#F!!!!%J!#3"d9Y"33\r!!!!&!!!!E)!!N!G&E38#!!!!!`!!!!+!!*!(4@d&!J!!!!)!!!!#J!#3"d9[#J3\r!!!#L!!!!#)!!N!p&GJ#3"Ci!N!4&GJm!N!5M!!!!"%9[#J3!!!#N!!!!#)!!N!p\r&GJ#3"C`!N!4&GJm!N!5M!!!!"%9[#J3!!!#P!!!!#)!!N!p&GJ#3"C8!N!4&GJm\r!N!5M!!!!"%9[#J3!!!#Q!!!!#)!!N!p&GJ#3"C!!!*!%4AB2!*!%S`!!!!4&E`S\r%!!!!T`!!!!L!!*!24AB!N!@1!*!%4AB2!*!%S`!!!!4&E`S%!!!!U!!!!!L!!*!\r24AB!N!@-!*!%4AB2!*!%S`!!!!4&E`S%!!!!U3!!!!L!!*!24AB!N!@+!*!%4AB\r2!*!%S`!!!!4&E`S%!!!!UJ!!!!L!!*!24AB!N!@)!*!%4AB2!*!%S`!!!!4&E`S\r%!!!!U`!!!!L!!*!24AB!N!@'!*!%4AB2!*!%S`!!!!4&E`S%!!!!V!!!!!L!!*!\r24AB!N!@%!*!%4AB2!*!%S`!!!!4&E`S%!!!!V3!!!!L!!*!24AB!N!@#!*!%4AB\r2!*!%S`!!!!4&E`S%!!!!VJ!!!!L!!*!24AB!N!@!!*!%4AB2!*!%S`!!!!4&E`S\r%!!!!V`!!!!L!!*!24AB!N!9q!*!%4AB2!*!%S`!!!!4&E`S%!!!!X!!!!!L!!*!\r24AB!N!9m!*!%4AB2!*!%S`!!!!4&E`S%!!!!X3!!!!L!!*!24AB!N!9k!*!%4AB\r2!*!%S`!!!!4&E`S%!!!!XJ!!!!L!!*!24AB!N!9f!*!%4AB2!*!%S`!!!!4&E`S\r%!!!!X`!!!!L!!*!24AB!N!9d!*!%4AB2!*!%S`!!!!4&E`S%!!!!Y!!!!!L!!*!\r24AB!N!9a!*!%4AB2!*!%S`!!!!4&E`S%!!!!Y3!!!!L!!*!24AB!N!9[!*!%4AB\r2!*!%S`!!!!4&E`S%!!!!YJ!!!!L!!*!24AB!N!9X!*!%4AB2!*!%S`!!!!4&E`S\r%!!!!Y`!!!!L!!*!24AB!N!9U!*!%4AB2!*!%S`!!!!4&E`S%!!!!Z!!!!!L!!*!\r24AB!N!8*!*!%4AB2!*!%S`!!!!4&E`S%!!!!Z3!!!!L!!*!24AB!N!9R!*!%4AB\r2!*!%S`!!!!4&E`S%!!!!ZJ!!!!L!!*!24AB!N!9P!*!%4AB2!*!%S`!!!!4&E`S\r%!!!!Z`!!!!L!!*!24AB!N!9M!*!%4AB2!*!%S`!!!!4&E`S%!!!![!!!!!L!!*!\r24AB!N!9K!*!%4AB2!*!%S`!!!!4&E`S%!!!![3!!!!L!!*!24AB!N!8Z!*!%4AB\r2!*!%S`!!!!4&E`S%!!!![J!!!!L!!*!24AB!N!8G!*!%4AB2!*!%S`!!!!4&E`S\r%!!!![`!!!!L!!*!24AB!N!9B!*!%4AB2!*!%S`!!!!4&E`S%!!!!`!!!!!L!!*!\r24AB!N!9E!*!%4AB2!*!%S`!!!!4&E`S%!!!!`3!!!!L!!*!24AB!N!8[!*!%4AB\r2!*!%S`!!!!4&E`S%!!!!`J!!!!L!!*!24AB!N!91!*!%4AB2!*!%S`!!!!4&E`S\r%!!!!``!!!!L!!*!24AB!N!8@!*!%4AB2!*!%S`!!!!4&E`S%!!!!a!!!!!L!!*!\r24AB!N!8r!*!%4AB2!*!%S`!!!!4&E`S%!!!!a3!!!!L!!*!24AB!N!98!*!%4AB\r2!*!%S`!!!!4&E`S%!!!!aJ!!!!L!!*!24AB!N!9,!*!%4AB2!*!%S`!!!!4&E`S\r%!!!!a`!!!!L!!*!24AB!N!90!*!%4AB2!*!%S`!!!!4&E`S%!!!!b!!!!!L!!*!\r24AB!N!9+!*!%4AB2!*!%S`!!!!4&E`S%!!!!b3!!!!L!!*!24AB!N!8q!*!%4AB\r2!*!%S`!!!!4&E`S%!!!!bJ!!!!L!!*!24AB!N!8l!*!%4AB2!*!%S`!!!!4&E`S\r%!!!!b`!!!!L!!*!24AB!N!8d!*!%4AB2!*!%S`!!!!4&E`S%!!!!c!!!!!L!!*!\r24AB!N!8a!*!%4AB2!*!%S`!!!!4&E`S%!!!!c3!!!!L!!*!24AB!N!8V!*!%4AB\r2!*!%S`!!!!4&E`S%!!!!cJ!!!!L!!*!24AB!N!8N!*!%4AB2!*!%S`!!!!4&E`S\r%!!!!c`!!!!L!!*!24AB!N!8I!*!%4AB2!*!%S`!!!!4&E`S%!!!!d!!!!!L!!*!\r24AB!N!8E!*!%4AB2!*!%S`!!!!4&E`S%!!!!d3!!!!L!!*!24AB!N!8)!*!%4AB\r2!*!%S`!!!!4&E`S%!!!!dJ!!!!L!!*!24AB!N!89!*!%4AB2!*!%S`!!!!4&E`S\r%!!!!d`!!!!L!!*!24AB!N!88!*!%4AB2!*!%S`!!!!4&E`S%!!!!e!!!!!L!!*!\r24AB!N!86!*!%4AB2!*!%S`!!!!4&E`S%!!!!e3!!!!L!!*!24AB!N!83!*!%4AB\r2!*!%S`!!!!4&E`S%!!!!eJ!!!!L!!*!24AB!N!81!*!%4AB2!*!%S`!!!!4&E`S\r%!!!!e`!!!!L!!*!24AB!N!8(!*!%4AB2!*!%S`!!!!4&EJ-%!!!!8`!!!!5!!*!\r,4AB&!*!%8`#3"%9[!`3!!!!&!!!!")!!N!Y&GJ8!N!3&!*!%4@i$"!!!!$B!!!!\r%J!#3#d9f"3#3"$B!N!4&EJ-%!!!!+J!!!!5!!*!,4AB&!*!%+J#3"%9Z!`3!!!!\rT!!!!")!!N!Y&GJ8!N!3T!*!%4@m$"!!!!#!!!!!%J!#3#d9f"3#3"#!!N!4&E`-\r%!!!!(!!!!!5!!*!,4AB&!*!%(!#3"%9[!`3!!!!%!!!!")!!N!Y&GJ8!N!3%!*!\r%4@m$"!!!!!-!!!!%J!#3#d9f"3#3"!-!N!4&E`-%!!!!!J!!!!5!!*!,4AB&!*!\r%!J#3"%9[$`3!!!#M!*!%J!#3"d9S!!!%U%G98dN!!HaPFR*[FPpI194'D@aP8h"\rPB`!#qQ0eFPC[E&pI194'D@aP8h"PB`!#Qf0eFN4TFPpI194'D@aP8h"PB`!%Zfa\rKFh4*EQC[Aemj9%CTE'96F'9M!!4D3$Ja-`!(k#j$D%4TFPpI194'D@aP8h"PBdC\r53cP84QPXC90`C@-!"[!ZAepMG&pI194'D@aP8h"PBdC53cP84QPXC90`C@-!"cF\rZAepKF'aIAcP84QPXC90`C@0'8%09B`!%@d!i-63!![NZ3h9bFQ9ZG%4TFPpI4P*\rc8Q`!"N`Z8%*)4f9d9QpX8hPZB`!%Ad!i-6J!!DBZ4'9QBA9XG%4TFPpI194'D@a\rP8h"PBdCf!!4k3$Jb-`!'!Lj'D@jN9QpXAemj9%CTE'96F'9M4R-!"i)Z8%*(CA4\r@5@jQEe0jEQ-!"*K!1$-a!!0i,P*[Eh4IAcP84QPXC90`C@0'GJ!&1#j*Fe*[Eh4\rIAcP84QPXC90`C@0'GJ!'B5j%C@CKG@adAemj9%CTE'96F'9M4RB!!p3ZAepYE9p\rI194'D@aP8h"PBdCf!!5I3$Jc1!!"Y5j36(0dFQ0`H3!(C5jYC@eMF(N!",T!1$3\rc!!@S,PpIBh4IAcP84QPXC90`C@0'8N-f4P06F'9M9@-!!!YSBA0"E'PKF`!(ILj\r5CA0[E(CPAemj9%CTE'96F'9M4P9M!!6B3$Je-3!#&#jIAf0dAemj9%CTE'96F'9\rM4R0X8%09Be9M!!9kD'&c6@&VC8C68h"PB`!&Cbj'8deKDf9'8e0`C@-!"%`Z4A&\reB@a6G(*TEQF!"2P!1$Bb!!'K,PpIBh4IAcP84QPXC90`C@0'Fe"$9@09B`!!P5j\r33NGPG&G%5@jQEe0jEQ-!""a!1$Fe!!DKER)N1$Jd!!3p3$Ji03!%A%!i163!"&e\r!1$Ne!!B(,PpIBh4IAcP84QPXC90`C@0'9@acE!!$J5j'D@jN4QpXC'9b!!"N,R0\r`FQPZG'B!"M-Z4AKTFh4cAemj9%CTE'96F'9M3dCf!!3Z,PpIB@eTAemj9%CTE'9\r6F'9M4QN!"&j!1$Nf!!-F,PpIBh4IAcP84QPXC90`C@0'F`!"Y#j33NGPG%C$3NP\rZCQp6H@jM!!3l3$N`-!!%##j#E'9cFepI194'D@aP8h"PBdCf!!4#3$N`0`!!lfC\reE'a3BA4S!!)[,N0[F(P$Efe`EfjPER4IAdC58'033e9M9@-!!0BZE@9YE@pfC3!\r%A%!j-6%!"(Y!16)`!!$2,NCeE'a3BA4SAemj9%CTE'96F'9M3dCf!!&1,P"#4f9\rd3f&d5@jQEe0jEQ-!"(a!16)a!!8h,NCeE'a"E'PKFe"KG'KIAcP84QPXC90`C@0\r$4RB!"BmZ3f&d5@jQEepI194'D@aP8h"PBd0'8M%`3dPZCQp33P*PBe9M!!-[,N0\reFP*PFdCTE'8!"qBZ4P0`6h"PEP*PFdCTE'8!!@dZ8Q9c4A*bEh)!"DJZ4f9d-9*\rPFfpeFQ0P!!GX,N4PG'&MD&*PFfpeFQ0P!!9A,N0XEh0P8Q9c4QPXC3!$Pbj9Ff9\r5CA0'D@aP!!9),NGPG%&XD@&c5@jQE`!'`bj%DA0`Eh0P5'&ZC'aP!!6#3$Nd0`!\r(D#j5C@a3BA4SAemj9%CTE'96F'9M3dCf!!!B,P*PE&"KG'KIAcP84QPXC90`C@0\r$4R0X!!6G3$Ne-J!("Lj5C@a3BA4SAemj9%CTE'96F'9M3dC53cC'8e0`C@-!!aB\rZAep`F&pI194'D@aP8h"PBdCf!!6l3$Nf-!!(r#jYC@eMEA!!"pdZFh4bBfKb!!3\rr3$Ni-`!%38!j1$8!"K3Z4@jMEf4PAemj9%CTE'96F'9M3dCf!!4#3$Ni0J!%4%!\rj1$J!"'&!16Ne!!0c,P*PFfpXGQ9IAcP84QPXC90`C@0'8N-a-%0*EQC[8%*5C@-\r!"Aa!-6!`13!&Qd!a-$%i!!6a,PpIE@PIAcP84QPXC90`C@0$4QN!"E0!-6!b-!!\r"iLj5CA0[E(CP3@aTBA0'D@aP!!@e3$%`-M)!"G0!-6!c-!!&e8!a-$-b!!Hm,Pp\rICA&IAcP84QPXC90`C@0$4P*$194'D@aP8h"PB`!&ed!a-$-d!!Ge,PpIEQ9IAcP\r84QPXC90`C@0$4P*$194'D@aP8h"PB`!&f8!a-$-f!!9D,NPc8'&bC@jd6fCIAcP\r84QPXC90`C@0$4P*$194'D@aP8h"PB`!&qN!a-$3h!!)$,N&NC&"KG'K$Efe`Efj\rPER4IAcP84QPXC90`C@0'8%0MD3!&'N!a-$8h!!8F3$%`06N!"cSZAep`E&pI194\r'D@aP8h"PBd0'8%09B`!&08!a-$Ba!!Dd,PpIBA"XAemj9%CTE'96F'9M4P"$B`!\r([5jcG(*XC@i!"6G!-6!f-`!'c#jIAh"XAemj9%CTE'96F'9M3dC33f-!"6P!-6!\rf03!%)#jIAhCMAemj9%CTE'96F'9M3dCc!!983$%`0c!!!h8Z8Q9KC%j)CAKIAdC\r33f0T8&9X!!*p,NPc4@jMEf4PC%C68h"PBepI194'D@aP8h"PBdC33f09B`!&hN!\ra-6)h!!IF,PpIBh4IAcP84QPXC90`C@0'8%0M9@-!"#%Z3fp`H8-b8&0dFPpI4P"\r$Be"9B`!!AbjcG(*bBfKb!!@"3$%a0cN!"98Z4P0`-NCeE'a3BA4S!!@C3$%a1$%\r!"'%Z4P0`-P*PE&"KG'J!"CY!-6%i-`!(F5j'8h!b4'Pb8Q9X8'&dD!!&R8!a-6J\re!!A5,NC6F$*&EQ0[C'PZC`!&Rd!a-6Jh!!Gc,NC5C@C1G@db4P06F'9M!!@K3$%\ra1$N!!UFZ9d3b4P06F'9M!!@j3$%a16%!"&3Z8'&dD$*'8e0`C@-!"EY!-6%j-`!\r(j#j6F'9MD@&X-NC68h"PB`!&[8!a-6Ne!!B5,NC6F&9`!!A!3$%a16J!!2`Z4P0\r`4'phEJ!&R%!a-M!a!!0J,NC6F%0KG%PZCQm!"D"!-6)`03!"@5j'8h"*EQ4PH!!\r&Sd!a-M!i!!(d,N4PCQ&eE(4@8Q9QAep'8R-!"8`Z8%*(CA4@Efa6H@jM!!@p3$%\rb-6)!"5SZ4P0`8feKFR40EhCP!!+",NK5Fh4'6'pMD`!!l5j)8Q9ZB@eP!!#J,N0\rKG%e[GQ8!!XNZ5&0PG%C-Ef0V!!#a,NK%C@aPG'8!"Ea!-6)j-!!$Fbj'8h"5CA0\r[E(CP!!A!3$%b163!"l)Z4P0`9'peBfK'EfaNCA)!")JZ4f9d4'&dC94TE@8!!8B\rZ8%*6CA4$BA4*EQC[8hPZB`!&a%!a-MNi!!B24P0`9'peBfK'EfaNCA)!!hj86d-\r!!X*'8h"5CA0[E(CP!!4l4P0`8feKFR40EhCP!!!P4P0`5@jNCAJ!!Se'8h"$BA4\r*EQC[!!G94P0`4'phEJ!&D8C6F&9`!!D&8h"PBfPKE$*'8e0`C@-!!eG3BA4S-NC\r68h"PB`!"0&G%-NC68h"PB`!'h%C5C@C1G@db4P06F'9M!!3-4P0`-N9ZBfpND@j\rR!!D+4P0`-N4TFP*PE&"KG'J!!`e'8h!b8Q9X8'&dD!!%qdC6F$*'G@aX8'&dD!!\r'@epIBh4IAcP84QPXC90`C@0'8%0M9@-!!69*Fd9ZBfpNC@4'8e0`C@0IAcP84QP\rXC90`C@0'8%0M9@-!!qPIAhCMAemj9%CTE'96F'9M3dCc!!9UAep`E&pI194'D@a\rP8h"PBd0'8%0M!!@ZAepKF'aIAcP84QPXC90`C@0'8%0M!!EZAep`E&pI194'D@a\rP8h"PBd0'8%09B`!'GepIBA"XAemj9%CTE'96F'9M4P"$9@-!!A*"C'43BA4S3fp\rYF'pZC@jdAemj9%CTE'96F'9M4P"$BfN!"#0*Fe"KFQ9ZG%pQAemj9%CTE'96F'9\rM3dC53cP84QPXC90`C@-!"[pIAfjPAemj9%CTE'96F'9M3dC53cP84QPXC90`C@-\r!"N&IAf9aAemj9%CTE'96F'9M3dC53cP84QPXC90`C@-!"Ie&H'PcG(0IAcP84QP\rXC90`C@0$4RB!"[95CA0[E(CPAemj9%CTE'96F'9M4P9M!!+r8Q9cEfafC9pI194\r'D@aP8h"PBdC53c%`3dPZCQp33P*PB`!$29pIE@PIAcP84QPXC90`C@0$4QN!!r"\rIAf&YD9pI194'D@aP8h"PBdCT!!*iAep`F&pI194'D@aP8h"PBdCf!!+GAepYE9p\rI194'D@aP8h"PBdCf!!4p3f&d5@jQEepI194'D@aP8h"PBd0'8M%`3dPZCQp33P*\rPBe9M!!@E4@jMEf4PAemj9%CTE'96F'9M3dCf!!H&8Q9X8'&dD&pI194'D@aP8h"\rPBd0'Ff`!"Mp5C@a3BA4SAemj9%CTE'96F'9M3dC53cC'8e0`C@-!"XY5C@a3BA4\rSAemj9%CTE'96F'9M3dCf!!4A4R9XE%&XD@&c8'&dD&pI194'D@aP8h"PBd0'GJ!\r(N8CeE'a3BA4SAemj9%CTE'96F'9M3dCf!!0J3QaPFh0IAcP84QPXC90`C@0'GJ!\r#&&pIBh4IAcP84QPXC90`C@0'F`!&!epIBh4IAcP84QPXC90`C@0'9@acE!!!Rep\rIBh4IAcP84QPXC90`C@0'Fe"$9@09B`!"e&pIBh4IAcP84QPXC90`C@0'Ffa33e9\rM9@-!"'*IAf0dAemj9%CTE'96F'9M4P*$0NC68h"PBe9M!!AdAepMG&pI194'D@a\rP8h"PBdC53cP84QPXC90`C@-!"G&%C@CKG@adAemj9%CTE'96F'9M4RB!"(0*Fe*\r[Eh4IAcP84QPXC90`C@0'GJ!#bP*[Eh4IAcP84QPXC90`C@0'GJ!&DdCTEQ4@Efa\rIAcP84QPXC90`C@0'F`!!i84PCQ&eE(4%DA*IAcP84QPXC90`C@0'GJ!'4%0S4'P\rbAemj9%CTE'96F'9M4P*$194'D@aP8h"PB`!!QY%!!!%!!!!"!*!)(R4*4&0jE@*\r[E!Q3"$dJ-M-X$3PV4QpZG%P%6@pLD@aP#C!%25!b0!ep1`d0)fPQ)%p-4&*2994\r*6N9138e&8`d0C@jeE5"l$3PZCAGCEh*V#C!'25"V4QpZG%P%6Q9h@@pbDb`0#@G\rPEQ9fB3Q3"MdJDdC[ER4*4%GPEQ9fB5`0#@e[EQ&ME`Q3"MdJDdC[ER4*4%e[EQ&\rMEb`0#ACPEQPMC3Q3"MdJDdC[ER4*4&CPEQPMC5`0#@a[EQ4[EJQ3"MdJDdC[ER4\r*4%a[EQ4[EL`0#@&dD'9ZF`Q3"Md!!!%!!!!"!*!)(J#3#4`!([rr5aJ:\r
\ No newline at end of file
diff --git a/src/mac/morefile/DirectoryCopy.c b/src/mac/morefile/DirectoryCopy.c
deleted file mode 100644 (file)
index dd484c9..0000000
+++ /dev/null
@@ -1,685 +0,0 @@
-/*
-       File:           DirectoryCopy.c
-
-       Contains:       A robust, general purpose directory copy routine.
-
-       Version:        MoreFiles
-
-       Copyright:      © 1992-2001 by Apple Computer, Inc., all rights reserved.
-
-       You may incorporate this sample code into your applications without
-       restriction, though the sample code has been provided "AS IS" and the
-       responsibility for its operation is 100% yours.  However, what you are
-       not permitted to do is to redistribute the source as "DSC Sample Code"
-       after having made changes. If you're going to re-distribute the source,
-       we require that you make it clear in the source that the code was
-       descended from Apple Sample Code, but that you've made changes.
-
-       File Ownership:
-
-               DRI:                            Apple Macintosh Developer Technical Support
-
-               Other Contact:          Apple Macintosh Developer Technical Support
-                                                       <http://developer.apple.com/bugreporter/>
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-
-       Change History (most recent first):
-
-                <2>      2/7/01        JL              Added standard header. Updated names of includes.
-               <1>             12/06/99        JL              MoreFiles 1.5.
-*/
-
-#include <MacTypes.h>
-#include <MacErrors.h>
-#include <MacMemory.h>
-#include <Files.h>
-#include <Script.h>
-#include <Math64.h>
-
-#define        __COMPILINGMOREFILES
-
-#include "MoreFiles.h"
-#include "MoreFilesExtras.h"
-#include "MoreDesktopMgr.h"
-#include "FileCopy.h"
-#include "DirectoryCopy.h"
-
-/*****************************************************************************/
-
-/* local constants */
-
-enum
-{
-       dirCopyBigCopyBuffSize  = 0x00004000,
-       dirCopyMinCopyBuffSize  = 0x00000200
-};
-
-
-/*****************************************************************************/
-
-/* local data structures */
-
-/* The EnumerateGlobals structure is used to minimize the amount of
-** stack space used when recursively calling CopyLevel and to hold
-** global information that might be needed at any time. */
-
-#if PRAGMA_STRUCT_ALIGN
-#pragma options align=mac68k
-#endif
-struct EnumerateGlobals
-{
-       Ptr                     copyBuffer;                     /* pointer to buffer used for file copy operations */
-       long            bufferSize;                     /* the size of the copy buffer */
-       CopyErrProcPtr errorHandler;    /* pointer to error handling function */
-       CopyFilterProcPtr copyFilterProc; /* pointer to filter function */
-       OSErr           error;                          /* temporary holder of results - saves 2 bytes of stack each level */
-       Boolean         bailout;                        /* set to true to by error handling function if fatal error */
-       short           destinationVRefNum;     /* the destination vRefNum */
-       Str63           itemName;                       /* the name of the current item */
-       CInfoPBRec      myCPB;                          /* the parameter block used for PBGetCatInfo calls */
-};
-#if PRAGMA_STRUCT_ALIGN
-#pragma options align=reset
-#endif
-
-typedef struct EnumerateGlobals EnumerateGlobals;
-typedef EnumerateGlobals *EnumerateGlobalsPtr;
-
-
-/* The PreflightGlobals structure is used to minimize the amount of
-** stack space used when recursively calling GetLevelSize and to hold
-** global information that might be needed at any time. */
-
-#if PRAGMA_STRUCT_ALIGN
-#pragma options align=mac68k
-#endif
-struct PreflightGlobals
-{
-       OSErr                   result;                         /* temporary holder of results - saves 2 bytes of stack each level */
-       Str63                   itemName;                       /* the name of the current item */
-       CInfoPBRec              myCPB;                          /* the parameter block used for PBGetCatInfo calls */
-
-       unsigned long   dstBlksPerAllocBlk;     /* the number of 512 byte blocks per allocation block on destination */
-                                                                               
-       unsigned long   allocBlksNeeded;        /* the total number of allocation blocks needed  */
-
-       unsigned long   tempBlocks;                     /* temporary storage for calculations (save some stack space)  */
-       CopyFilterProcPtr copyFilterProc;       /* pointer to filter function */
-};
-#if PRAGMA_STRUCT_ALIGN
-#pragma options align=reset
-#endif
-
-typedef struct PreflightGlobals PreflightGlobals;
-typedef PreflightGlobals *PreflightGlobalsPtr;
-
-/*****************************************************************************/
-
-/* static prototypes */
-
-static void    GetLevelSize(long currentDirID,
-                                                        PreflightGlobals *theGlobals);
-
-static OSErr   PreflightDirectoryCopySpace(short srcVRefNum,
-                                                                                       long srcDirID,
-                                                                                       short dstVRefNum,
-                                                                                       CopyFilterProcPtr copyFilterProc,
-                                                                                       Boolean *spaceOK);
-
-static void    CopyLevel(long sourceDirID,
-                                                 long dstDirID,
-                                                 EnumerateGlobals *theGlobals);
-                                                 
-/*****************************************************************************/
-
-static void    GetLevelSize(long currentDirID,
-                                                        PreflightGlobals *theGlobals)
-{
-       short   index = 1;
-       
-       do
-       {
-               theGlobals->myCPB.dirInfo.ioFDirIndex = index;
-               theGlobals->myCPB.dirInfo.ioDrDirID = currentDirID;     /* we need to do this every time */
-                                                                                                                       /* through, since GetCatInfo  */
-                                                                                                                       /* returns ioFlNum in this field */
-               theGlobals->result = PBGetCatInfoSync(&theGlobals->myCPB);
-               if ( theGlobals->result == noErr )
-               {
-                       if ( (theGlobals->copyFilterProc == NULL) ||
-                                CallCopyFilterProc(theGlobals->copyFilterProc, &theGlobals->myCPB) ) /* filter if filter proc was supplied */
-                       {
-                               /* Either there's no filter proc OR the filter proc says to use this item */
-                               if ( (theGlobals->myCPB.dirInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-                               {
-                                       /* we have a directory */
-                                       
-                                       GetLevelSize(theGlobals->myCPB.dirInfo.ioDrDirID, theGlobals); /* recurse */
-                                       theGlobals->result = noErr; /* clear error return on way back */
-                               }
-                               else
-                               {
-                                       /* We have a file - add its allocation blocks to allocBlksNeeded. */
-                                       /* Since space on Mac OS disks is always allocated in allocation blocks, */
-                                       /* this takes into account rounding up to the end of an allocation block. */
-                                       
-                                       /* get number of 512-byte blocks needed for data fork */
-                                       if ( ((unsigned long)theGlobals->myCPB.hFileInfo.ioFlLgLen & 0x000001ff) != 0 )
-                                       {
-                                               theGlobals->tempBlocks = ((unsigned long)theGlobals->myCPB.hFileInfo.ioFlLgLen >> 9) + 1;
-                                       }
-                                       else
-                                       {
-                                               theGlobals->tempBlocks = (unsigned long)theGlobals->myCPB.hFileInfo.ioFlLgLen >> 9;
-                                       }
-                                       /* now, calculate number of new allocation blocks needed for the data fork and add it to the total */
-                                       if ( theGlobals->tempBlocks % theGlobals->dstBlksPerAllocBlk )
-                                       {
-                                               theGlobals->allocBlksNeeded += (theGlobals->tempBlocks / theGlobals->dstBlksPerAllocBlk) + 1;
-                                       }
-                                       else
-                                       {
-                                               theGlobals->allocBlksNeeded += theGlobals->tempBlocks / theGlobals->dstBlksPerAllocBlk;
-                                       }
-                                       
-                                       /* get number of 512-byte blocks needed for resource fork */
-                                       if ( ((unsigned long)theGlobals->myCPB.hFileInfo.ioFlRLgLen & 0x000001ff) != 0 )
-                                       {
-                                               theGlobals->tempBlocks = ((unsigned long)theGlobals->myCPB.hFileInfo.ioFlRLgLen >> 9) + 1;
-                                       }
-                                       else
-                                       {
-                                               theGlobals->tempBlocks = (unsigned long)theGlobals->myCPB.hFileInfo.ioFlRLgLen >> 9;
-                                       }
-                                       /* now, calculate number of new allocation blocks needed for the resource  fork and add it to the total */
-                                       if ( theGlobals->tempBlocks % theGlobals->dstBlksPerAllocBlk )
-                                       {
-                                               theGlobals->allocBlksNeeded += (theGlobals->tempBlocks / theGlobals->dstBlksPerAllocBlk) + 1;
-                                       }
-                                       else
-                                       {
-                                               theGlobals->allocBlksNeeded += theGlobals->tempBlocks / theGlobals->dstBlksPerAllocBlk;
-                                       }
-                               }
-                       }
-               }
-               ++index;
-       } while ( theGlobals->result == noErr );
-}
-
-/*****************************************************************************/
-
-static OSErr   PreflightDirectoryCopySpace(short srcVRefNum,
-                                                                                       long srcDirID,
-                                                                                       short dstVRefNum,
-                                                                                       CopyFilterProcPtr copyFilterProc,
-                                                                                       Boolean *spaceOK)
-{
-       XVolumeParam pb;
-       OSErr error;
-       unsigned long dstFreeBlocks;
-       PreflightGlobals theGlobals;
-       
-       error = XGetVolumeInfoNoName(NULL, dstVRefNum, &pb);
-       if ( error == noErr )
-       {
-               /* Convert freeBytes to free disk blocks (512-byte blocks) */
-               dstFreeBlocks = U32SetU(U64ShiftRight(pb.ioVFreeBytes, 9));
-               
-               /* get allocation block size (always multiple of 512) and divide by 512
-                 to get number of 512-byte blocks per allocation block */
-               theGlobals.dstBlksPerAllocBlk = ((unsigned long)pb.ioVAlBlkSiz >> 9);
-               
-               theGlobals.allocBlksNeeded = 0;
-
-               theGlobals.myCPB.dirInfo.ioNamePtr = theGlobals.itemName;
-               theGlobals.myCPB.dirInfo.ioVRefNum = srcVRefNum;
-               
-               theGlobals.copyFilterProc = copyFilterProc;
-               
-               GetLevelSize(srcDirID, &theGlobals);
-               
-               /* Is there enough room on the destination volume for the source file?                                  */
-               /* Note:        This will work because the largest number of disk blocks supported                      */
-               /*                      on a 2TB volume is 0xffffffff and (allocBlksNeeded * dstBlksPerAllocBlk)        */
-               /*                      will always be less than 0xffffffff.                                                                            */
-               *spaceOK = ((theGlobals.allocBlksNeeded * theGlobals.dstBlksPerAllocBlk) <= dstFreeBlocks);
-       }
-
-       return ( error );
-}
-
-/*****************************************************************************/
-
-static void    CopyLevel(long sourceDirID,
-                                                 long dstDirID,
-                                                 EnumerateGlobals *theGlobals)
-{
-       long currentSrcDirID = 0 ;
-       long newDirID;
-       short index = 1;
-       
-       do
-       {       
-               /* Get next source item at the current directory level */
-               
-               theGlobals->myCPB.dirInfo.ioFDirIndex = index;
-               theGlobals->myCPB.dirInfo.ioDrDirID = sourceDirID;
-               theGlobals->error = PBGetCatInfoSync(&theGlobals->myCPB);               
-
-               if ( theGlobals->error == noErr )
-               {
-                       if ( (theGlobals->copyFilterProc == NULL) ||
-                                CallCopyFilterProc(theGlobals->copyFilterProc, &theGlobals->myCPB) ) /* filter if filter proc was supplied */
-                       {
-                               /* Either there's no filter proc OR the filter proc says to use this item */
-
-                               /* We have an item.  Is it a file or directory? */
-                               if ( (theGlobals->myCPB.hFileInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-                               {
-                                       /* We have a directory */
-                                       
-                                       /* Create a new directory at the destination. No errors allowed! */
-                                       theGlobals->error = DirCreate(theGlobals->destinationVRefNum, dstDirID, theGlobals->itemName, &newDirID);
-                                       if ( theGlobals->error == noErr )
-                                       {
-                                               /* Save the current source directory ID where we can get it when we come back
-                                               ** from recursion land. */
-                                               currentSrcDirID = theGlobals->myCPB.dirInfo.ioDrDirID;
-                                               
-                                               /* Dive again (copy the directory level we just found below this one) */
-                                               CopyLevel(theGlobals->myCPB.dirInfo.ioDrDirID, newDirID, theGlobals);
-                                               
-                                               if ( !theGlobals->bailout )
-                                               {
-                                                       /* Copy comment from old to new directory. */
-                                                       /* Ignore the result because we really don't care if it worked or not. */
-                                                       (void) DTCopyComment(theGlobals->myCPB.dirInfo.ioVRefNum, currentSrcDirID, NULL, theGlobals->destinationVRefNum, newDirID, NULL);
-                                                       
-                                                       /* Copy directory attributes (dates, etc.) to newDirID. */
-                                                       /* No errors allowed */
-                                                       theGlobals->error = CopyFileMgrAttributes(theGlobals->myCPB.dirInfo.ioVRefNum, currentSrcDirID, NULL, theGlobals->destinationVRefNum, newDirID, NULL, true);
-                                                       
-                                                       /* handle any errors from CopyFileMgrAttributes */
-                                                       if ( theGlobals->error != noErr )
-                                                       {
-                                                               if ( theGlobals->errorHandler != NULL )
-                                                               {
-                                                                       theGlobals->bailout =  CallCopyErrProc(theGlobals->errorHandler, theGlobals->error, copyDirFMAttributesOp,
-                                                                                                                       theGlobals->myCPB.dirInfo.ioVRefNum, currentSrcDirID, NULL,
-                                                                                                                       theGlobals->destinationVRefNum, newDirID, NULL);
-                                                               }
-                                                               else
-                                                               {
-                                                                       /* If you don't handle the errors with an error handler, */
-                                                                       /* then the copy stops here. */
-                                                                       theGlobals->bailout = true;
-                                                               }
-                                                       }
-                                               }
-                                       }
-                                       else    /* error handling for DirCreate */
-                                       {
-                                               /* note that currentSrcDirID has not been initialised when entering this execution path */
-                                               if ( theGlobals->errorHandler != NULL )
-                                               {
-                                                       theGlobals->bailout = CallCopyErrProc(theGlobals->errorHandler, theGlobals->error, dirCreateOp,
-                                                                                                               theGlobals->myCPB.dirInfo.ioVRefNum, currentSrcDirID, NULL,
-                                                                                                               theGlobals->destinationVRefNum, dstDirID, theGlobals->itemName);
-                                               }
-                                               else
-                                               {
-                                                       /* If you don't handle the errors with an error handler, */
-                                                       /* then the copy stops here. */
-                                                       theGlobals->bailout = true;
-                                               }
-                                       }
-                                       
-                                       if ( !theGlobals->bailout )
-                                       {
-                                               /* clear error return on way back if we aren't bailing out */
-                                               theGlobals->error = noErr;
-                                       }
-                               }
-                               else
-                               {
-                                       /* We have a file, so copy it */
-                                       
-                                       theGlobals->error = FileCopy(theGlobals->myCPB.hFileInfo.ioVRefNum,
-                                                                                                theGlobals->myCPB.hFileInfo.ioFlParID,
-                                                                                                theGlobals->itemName,
-                                                                                                theGlobals->destinationVRefNum,
-                                                                                                dstDirID,
-                                                                                                NULL,
-                                                                                                NULL,
-                                                                                                theGlobals->copyBuffer,
-                                                                                                theGlobals->bufferSize,
-                                                                                                false);
-                                                       
-                                       /* handle any errors from FileCopy */
-                                       if ( theGlobals->error != noErr )
-                                       {
-                                               if ( theGlobals->errorHandler != NULL )
-                                               {
-                                                       theGlobals->bailout = CallCopyErrProc(theGlobals->errorHandler, theGlobals->error, fileCopyOp,
-                                                                                                       theGlobals->myCPB.hFileInfo.ioVRefNum, theGlobals->myCPB.hFileInfo.ioFlParID, theGlobals->itemName,
-                                                                                                       theGlobals->destinationVRefNum, dstDirID, NULL);
-                                                       if ( !theGlobals->bailout )
-                                                       {
-                                                               /* If the CopyErrProc handled the problem, clear the error here */
-                                                               theGlobals->error = noErr;
-                                                       }
-                                               }
-                                               else
-                                               {
-                                                       /* If you don't handle the errors with an error handler, */
-                                                       /* then the copy stops here. */
-                                                       theGlobals->bailout = true;
-                                               }
-                                       }
-                               }
-                       }
-               }
-               else
-               {       /* error handling for PBGetCatInfo */
-                       /* it's normal to get a fnfErr when indexing; that only means you've hit the end of the directory */
-                       if ( theGlobals->error != fnfErr )
-                       {
-                               if ( theGlobals->errorHandler != NULL )
-                               { 
-                                       theGlobals->bailout = CallCopyErrProc(theGlobals->errorHandler, theGlobals->error, getNextItemOp,
-                                                                                       theGlobals->myCPB.dirInfo.ioVRefNum, sourceDirID, NULL, 0, 0, NULL);
-                                       if ( !theGlobals->bailout )
-                                       {
-                                               /* If the CopyErrProc handled the problem, clear the error here */
-                                               theGlobals->error = noErr;
-                                       }
-                               }
-                               else
-                               {
-                                       /* If you don't handle the errors with an error handler, */
-                                       /* then the copy stops here. */
-                                       theGlobals->bailout = true;
-                               }
-                       }
-               }
-               ++index; /* prepare to get next item */
-       } while ( (theGlobals->error == noErr) && (!theGlobals->bailout) ); /* time to fall back a level? */
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FilteredDirectoryCopy(short srcVRefNum,
-                                                                         long srcDirID,
-                                                                         ConstStr255Param srcName,
-                                                                         short dstVRefNum,
-                                                                         long dstDirID,
-                                                                         ConstStr255Param dstName,
-                                                                         ConstStr255Param copyName,
-                                                                         void *copyBufferPtr,
-                                                                         long copyBufferSize,
-                                                                         Boolean preflight,
-                                                                         CopyErrProcPtr copyErrHandler,
-                                                                         CopyFilterProcPtr copyFilterProc)
-{
-       EnumerateGlobals theGlobals;
-       Boolean isDirectory;
-       OSErr   error;
-       Boolean ourCopyBuffer = false;
-       Str63   srcDirName, oldDiskName;
-       Boolean spaceOK;                        
-       
-       /* Make sure a copy buffer is allocated. */
-       if ( copyBufferPtr == NULL )
-       {
-               /* The caller didn't supply a copy buffer so grab one from the application heap.
-               ** Try to get a big copy buffer, if we can't, try for a 512-byte buffer.
-               ** If 512 bytes aren't available, we're in trouble. */
-               copyBufferSize = dirCopyBigCopyBuffSize;
-               copyBufferPtr = NewPtr(copyBufferSize);
-               if ( copyBufferPtr == NULL )
-               {
-                       copyBufferSize = dirCopyMinCopyBuffSize;
-                       copyBufferPtr = NewPtr(copyBufferSize);
-                       if ( copyBufferPtr == NULL )
-                       {
-                               return ( memFullErr );
-                       }
-               }
-               ourCopyBuffer = true;
-       }
-       
-       /* Get the real dirID where we're copying from and make sure it is a directory. */
-       error = GetDirectoryID(srcVRefNum, srcDirID, srcName, &srcDirID, &isDirectory);
-       if ( error != noErr )
-       {
-               goto ErrorExit;
-       }
-       if ( !isDirectory )
-       {
-               error = dirNFErr;
-               goto ErrorExit;
-       }
-       
-       /* Special case destination if it is the root parent directory. */
-       /* Since you can't create the root directory, this is needed if */
-       /* you want to copy a directory's content to a disk's root directory. */
-       if ( (dstDirID == fsRtParID) && (dstName == NULL) )
-       {
-               dstDirID = fsRtParID;
-               isDirectory = true;
-               error = noErr;
-       }
-       else
-       {
-               /*  Get the real dirID where we're going to put the copy and make sure it is a directory. */
-               error = GetDirectoryID(dstVRefNum, dstDirID, dstName, &dstDirID, &isDirectory);
-               if ( error != noErr )
-               {
-                       goto ErrorExit;
-               }
-               if ( !isDirectory )
-               {
-                       error =  dirNFErr;
-                       goto ErrorExit;
-               }
-       }
-       
-       /* Get the real vRefNum of both the source and destination */
-       error = DetermineVRefNum(srcName, srcVRefNum, &srcVRefNum);
-       if ( error != noErr )
-       {
-               goto ErrorExit;
-       }
-       error = DetermineVRefNum(dstName, dstVRefNum, &dstVRefNum);
-       if ( error != noErr )
-       {
-               goto ErrorExit;
-       }
-       
-       if ( preflight )
-       {
-               error = PreflightDirectoryCopySpace(srcVRefNum, srcDirID, dstVRefNum, copyFilterProc, &spaceOK);
-               if ( error != noErr )
-               {
-                       goto ErrorExit;
-               }
-               if ( !spaceOK )
-               {
-                       error = dskFulErr; /* not enough room on destination */
-                       goto ErrorExit;
-               }
-       }
-
-       /* Create the new directory in the destination directory with the */
-       /* same name as the source directory. */
-       error = GetDirName(srcVRefNum, srcDirID, srcDirName);
-       if ( error != noErr )
-       {
-               goto ErrorExit;
-       }
-       
-       /* Again, special case destination if the destination is the */
-       /* root parent directory. This time, we'll rename the disk to */
-       /* the source directory name. */
-       if ( dstDirID == fsRtParID )
-       {
-               /* Get the current name of the destination disk */
-               error = GetDirName(dstVRefNum, fsRtDirID, oldDiskName);
-               if ( error == noErr )   
-               {
-                       /* use the copyName as srcDirName if supplied */
-                       if ( copyName != NULL )
-                       {
-                               /* make a copy since copyName is a const input */
-                               BlockMoveData(copyName, srcDirName, sizeof(Str31));
-                       }
-                       /* Shorten the name if it's too long to be the volume name */
-                       TruncPString(srcDirName, srcDirName, 27);
-                       
-                       /* Rename the disk */
-                       error = HRename(dstVRefNum, fsRtParID, oldDiskName, srcDirName);
-                       
-                       /* and copy to the root directory */
-                       dstDirID = fsRtDirID;
-               }
-       }
-       else
-       {
-               /* use the copyName as srcDirName if supplied */
-               error = DirCreate(dstVRefNum, dstDirID, ((copyName != NULL) ? copyName : srcDirName), &dstDirID);
-       }
-       if ( error != noErr )
-       {
-               /* handle any errors from DirCreate */
-               if ( copyErrHandler != NULL )
-               {
-                       if ( CallCopyErrProc(copyErrHandler, error, dirCreateOp,
-                                                                                                       srcVRefNum, srcDirID, NULL,
-                                                                                                       dstVRefNum, dstDirID, srcDirName) )
-                       {
-                               goto ErrorExit;
-                       }
-                       else
-                       {
-                               /* If the CopyErrProc handled the problem, clear the error here */
-                               /* and continue */
-                               error = noErr;
-                       }
-               }
-               else
-               {
-                       /* If you don't handle the errors with an error handler, */
-                       /* then the copy stops here. */
-                       goto ErrorExit;
-               }
-       }
-       
-       /* dstDirID is now the newly created directory! */
-               
-       /* Set up the globals we need to access from the recursive routine. */
-       theGlobals.copyBuffer = (Ptr)copyBufferPtr;
-       theGlobals.bufferSize = copyBufferSize;
-       theGlobals.destinationVRefNum = dstVRefNum; /* so we can get to it always */
-       theGlobals.myCPB.hFileInfo.ioNamePtr = (StringPtr)&theGlobals.itemName;
-       theGlobals.myCPB.hFileInfo.ioVRefNum = srcVRefNum;
-       theGlobals.errorHandler = copyErrHandler;
-       theGlobals.bailout = false;
-       theGlobals.copyFilterProc =  copyFilterProc;
-               
-       /* Here we go into recursion land... */
-       CopyLevel(srcDirID, dstDirID, &theGlobals);
-       error = theGlobals.error;       /* get the result */
-       
-       if ( !theGlobals.bailout )
-       {
-               /* Copy comment from source to destination directory. */
-               /* Ignore the result because we really don't care if it worked or not. */
-               (void) DTCopyComment(srcVRefNum, srcDirID, NULL, dstVRefNum, dstDirID, NULL);
-               
-               /* Copy the File Manager attributes */
-               error = CopyFileMgrAttributes(srcVRefNum, srcDirID, NULL,
-                                       dstVRefNum, dstDirID, NULL, true);
-               
-               /* handle any errors from CopyFileMgrAttributes */
-               if ( (error != noErr) && (copyErrHandler != NULL) )
-               {
-                       theGlobals.bailout = CallCopyErrProc(copyErrHandler, error, copyDirFMAttributesOp,
-                                                                                               srcVRefNum, srcDirID, NULL,
-                                                                                               dstVRefNum, dstDirID, NULL);
-               }
-       }
-
-ErrorExit:
-       /* Get rid of the copy buffer if we allocated it. */
-       if ( ourCopyBuffer )
-       {
-               DisposePtr((Ptr)copyBufferPtr);
-       }
-
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   DirectoryCopy(short srcVRefNum,
-                                                         long srcDirID,
-                                                         ConstStr255Param srcName,
-                                                         short dstVRefNum,
-                                                         long dstDirID,
-                                                         ConstStr255Param dstName,
-                                                         ConstStr255Param copyName,
-                                                         void *copyBufferPtr,
-                                                         long copyBufferSize,
-                                                         Boolean preflight,
-                                                         CopyErrProcPtr copyErrHandler)
-{
-       return ( FilteredDirectoryCopy(srcVRefNum, srcDirID, srcName,
-                                                                  dstVRefNum, dstDirID, dstName,
-                                                                  copyName,
-                                                                  copyBufferPtr, copyBufferSize, preflight,
-                                                                  copyErrHandler, NULL) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpFilteredDirectoryCopy(const FSSpec *srcSpec,
-                                                                                const FSSpec *dstSpec,
-                                                                                ConstStr255Param copyName,
-                                                                                void *copyBufferPtr,
-                                                                                long copyBufferSize,
-                                                                                Boolean preflight,
-                                                                                CopyErrProcPtr copyErrHandler,
-                                                                                CopyFilterProcPtr copyFilterProc)
-{
-       return ( FilteredDirectoryCopy(srcSpec->vRefNum, srcSpec->parID, srcSpec->name,
-                                                                  dstSpec->vRefNum, dstSpec->parID, dstSpec->name,
-                                                                  copyName,
-                                                                  copyBufferPtr, copyBufferSize, preflight,
-                                                                  copyErrHandler, copyFilterProc) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpDirectoryCopy(const FSSpec *srcSpec,
-                                                                const FSSpec *dstSpec,
-                                                                ConstStr255Param copyName,
-                                                                void *copyBufferPtr,
-                                                                long copyBufferSize,
-                                                                Boolean preflight,
-                                                                CopyErrProcPtr copyErrHandler)
-{
-       return ( FilteredDirectoryCopy(srcSpec->vRefNum, srcSpec->parID, srcSpec->name,
-                                                                  dstSpec->vRefNum, dstSpec->parID, dstSpec->name,
-                                                                  copyName,
-                                                                  copyBufferPtr, copyBufferSize, preflight,
-                                                                  copyErrHandler, NULL) );
-}
-
-/*****************************************************************************/
-
diff --git a/src/mac/morefile/DirectoryCopy.h b/src/mac/morefile/DirectoryCopy.h
deleted file mode 100644 (file)
index 14637e3..0000000
+++ /dev/null
@@ -1,559 +0,0 @@
-/*
-     File:       DirectoryCopy.h
-     Contains:   A robust, general purpose directory copy routine.
-     Version:    Technology: MoreFiles
-                 Release:    1.5.2
-     Copyright:  © 1992-2001 by Apple Computer, Inc., all rights reserved.
-     Bugs?:      For bug reports, consult the following page on
-                 the World Wide Web:
-                     http://developer.apple.com/bugreporter/
-*/
-
-/*
-    You may incorporate this sample code into your applications without
-    restriction, though the sample code has been provided "AS IS" and the
-    responsibility for its operation is 100% yours.  However, what you are
-    not permitted to do is to redistribute the source as "DSC Sample Code"
-    after having made changes. If you're going to re-distribute the source,
-    we require that you make it clear in the source that the code was
-    descended from Apple Sample Code, but that you've made changes.
-*/
-
-#ifndef __DIRECTORYCOPY__
-#define __DIRECTORYCOPY__
-
-#ifndef __MACTYPES__
-#include <MacTypes.h>
-#endif
-
-#ifndef __FILES__
-#include <Files.h>
-#endif
-
-#include "Optimization.h"
-
-
-#if PRAGMA_ONCE
-#pragma once
-#endif
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#if PRAGMA_IMPORT
-#pragma import on
-#endif
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=mac68k
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(push, 2)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack(2)
-#endif
-
-/*****************************************************************************/
-
-enum {
-  getNextItemOp                 = 1,    /* couldn't access items in this directory - no access privileges */
-  copyDirCommentOp              = 2,    /* couldn't copy directory's Finder comment */
-  copyDirAccessPrivsOp          = 3,    /* couldn't copy directory's AFP access privileges */
-  copyDirFMAttributesOp         = 4,    /* couldn't copy directory's File Manager attributes */
-  dirCreateOp                   = 5,    /* couldn't create destination directory */
-  fileCopyOp                    = 6     /* couldn't copy file */
-};
-
-
-/*****************************************************************************/
-
-typedef CALLBACK_API( Boolean , CopyErrProcPtr )(OSErr error, short failedOperation, short srcVRefNum, long srcDirID, ConstStr255Param srcName, short dstVRefNum, long dstDirID, ConstStr255Param dstName);
-/*
-    This is the prototype for the CopyErrProc function DirectoryCopy
-    calls if an error condition is detected sometime during the copy.  If
-    CopyErrProc returns false, then DirectoryCopy attempts to continue with
-    the directory copy operation.  If CopyErrProc returns true, then
-    DirectoryCopy stops the directory copy operation.
-
-    error           input:  The error result code that caused CopyErrProc to
-                            be called.
-    failedOperation input:  The operation that returned an error to
-                            DirectoryCopy.
-    srcVRefNum      input:  Source volume specification.
-    srcDirID        input:  Source directory ID.
-    srcName         input:  Source file or directory name, or nil if
-                            srcDirID specifies the directory.
-    dstVRefNum      input:  Destination volume specification.
-    dstDirID        input:  Destination directory ID.
-    dstName         input:  Destination file or directory name, or nil if
-                            dstDirID specifies the directory.
-
-    __________
-    
-    Also see:   FilteredDirectoryCopy, FSpFilteredDirectoryCopy, DirectoryCopy, FSpDirectoryCopy
-*/
-#define CallCopyErrProc(userRoutine, error, failedOperation, srcVRefNum, srcDirID, srcName, dstVRefNum, dstDirID, dstName) \
-    (*(userRoutine))((error), (failedOperation), (srcVRefNum), (srcDirID), (srcName), (dstVRefNum), (dstDirID), (dstName))
-
-/*****************************************************************************/
-
-typedef CALLBACK_API( Boolean , CopyFilterProcPtr )(const CInfoPBRec * cpbPtr);
-/*
-    This is the prototype for the CopyFilterProc function called by
-    FilteredDirectoryCopy and GetLevelSize. If true is returned,
-    the file/folder is included in the copy, otherwise it is excluded.
-    
-    pb  input:  Points to the CInfoPBRec for the item under consideration.
-
-    __________
-    
-    Also see:   FilteredDirectoryCopy, FSpFilteredDirectoryCopy
-*/
-#define CallCopyFilterProc(userRoutine, cpbPtr) \
-    (*(userRoutine))((cpbPtr))
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FilteredDirectoryCopy(
-  short               srcVRefNum,
-  long                srcDirID,
-  ConstStr255Param    srcName,
-  short               dstVRefNum,
-  long                dstDirID,
-  ConstStr255Param    dstName,
-  ConstStr255Param    copyName,
-  void *              copyBufferPtr,
-  long                copyBufferSize,
-  Boolean             preflight,
-  CopyErrProcPtr      copyErrHandler,
-  CopyFilterProcPtr   copyFilterProc);
-
-
-/*
-    The FilteredDirectoryCopy function makes a copy of a directory
-    structure in a new location. If copyBufferPtr <> NIL, it points to
-    a buffer of copyBufferSize that is used to copy files data. The
-    larger the supplied buffer, the faster the copy. If
-    copyBufferPtr = NIL, then this routine allocates a buffer in the
-    application heap. If you pass a copy buffer to this routine, make
-    its size a multiple of 512 ($200) bytes for optimum performance.
-    
-    The optional copyFilterProc parameter lets a routine you define
-    decide what files or directories are copied to the destination.
-    
-    FilteredDirectoryCopy normally creates a new directory *in* the
-    specified destination directory and copies the source directory's
-    content into the new directory. However, if root parent directory
-    (fsRtParID) is passed as the dstDirID parameter and NULL is
-    passed as the dstName parameter, DirectoryCopy renames the
-    destination volume to the source directory's name (truncating
-    if the name is longer than 27 characters) and copies the source
-    directory's content into the destination volume's root directory.
-    This special case is supported by FilteredDirectoryCopy, but
-    not by FSpFilteredDirectoryCopy since with FSpFilteredDirectoryCopy,
-    the dstName parameter can not be NULL.
-    
-    srcVRefNum      input:  Source volume specification.
-    srcDirID        input:  Source directory ID.
-    srcName         input:  Source directory name, or nil if
-                            srcDirID specifies the directory.
-    dstVRefNum      input:  Destination volume specification.
-    dstDirID        input:  Destination directory ID.
-    dstName         input:  Destination directory name, or nil if
-                            dstDirID specifies the directory.
-    copyName        input:  Points to the new directory name if the directory
-                            is to be renamed or nil if the directory isn't to
-                            be renamed.
-    copyBufferPtr   input:  Points to a buffer of copyBufferSize that
-                            is used the i/o buffer for the copy or
-                            nil if you want DirectoryCopy to allocate its
-                            own buffer in the application heap.
-    copyBufferSize  input:  The size of the buffer pointed to
-                            by copyBufferPtr.
-    preflight       input:  If true, DirectoryCopy makes sure there are
-                            enough allocation blocks on the destination
-                            volume to hold the directory's files before
-                            starting the copy.
-    copyErrHandler  input:  A pointer to the routine you want called if an
-                            error condition is detected during the copy, or
-                            nil if you don't want to handle error conditions.
-                            If you don't handle error conditions, the first
-                            error will cause the copy to quit and
-                            DirectoryCopy will return the error.
-                            Error handling is recommended...
-    copyFilterProc  input:  A pointer to the filter routine you want called
-                            for each item in the source directory, or NULL
-                            if you don't want to filter.
-    
-    Result Codes
-        noErr               0       No error
-        readErr             Ð19     Driver does not respond to read requests
-        writErr             Ð20     Driver does not respond to write requests
-        badUnitErr          Ð21     Driver reference number does not
-                                    match unit table
-        unitEmptyErr        Ð22     Driver reference number specifies a
-                                    nil handle in unit table
-        abortErr            Ð27     Request aborted by KillIO
-        notOpenErr          Ð28     Driver not open
-        dskFulErr           -34     Destination volume is full
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        tmfoErr             -42     Too many files open
-        fnfErr              -43     Source file not found, or destination
-                                    directory does not exist
-        wPrErr              -44     Volume locked by hardware
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Destination volume is read-only
-        fBsyErr             -47     The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        dupFNErr            -48     Destination file already exists
-        opWrErr             -49     File already open for writing
-        paramErr            -50     No default volume or function not
-                                    supported by volume
-        permErr             -54     File is already open and cannot be opened using specified deny modes
-        memFullErr          -108    Copy buffer could not be allocated
-        dirNFErr            -120    Directory not found or incomplete pathname
-        wrgVolTypErr        -123    Function not supported by volume
-        afpAccessDenied     -5000   User does not have the correct access
-        afpDenyConflict     -5006   The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        afpObjectTypeErr    -5025   Source is a directory, directory not found
-                                    or incomplete pathname
-    
-    __________
-    
-    Also see:   CopyErrProcPtr, CopyFilterProcPtr, FSpFilteredDirectoryCopy,
-                DirectoryCopy, FSpDirectoryCopy, FileCopy, FSpFileCopy
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpFilteredDirectoryCopy(
-  const FSSpec *      srcSpec,
-  const FSSpec *      dstSpec,
-  ConstStr255Param    copyName,
-  void *              copyBufferPtr,
-  long                copyBufferSize,
-  Boolean             preflight,
-  CopyErrProcPtr      copyErrHandler,
-  CopyFilterProcPtr   copyFilterProc);
-
-
-/*
-    The FSpFilteredDirectoryCopy function makes a copy of a directory
-    structure in a new location. If copyBufferPtr <> NIL, it points to
-    a buffer of copyBufferSize that is used to copy files data. The
-    larger the supplied buffer, the faster the copy. If
-    copyBufferPtr = NIL, then this routine allocates a buffer in the
-    application heap. If you pass a copy buffer to this routine, make
-    its size a multiple of 512 ($200) bytes for optimum performance.
-    
-    The optional copyFilterProc parameter lets a routine you define
-    decide what files or directories are copied to the destination.
-    
-    srcSpec         input:  An FSSpec record specifying the directory to copy.
-    dstSpec         input:  An FSSpec record specifying destination directory
-                            of the copy.
-    copyName        input:  Points to the new directory name if the directory
-                            is to be renamed or nil if the directory isn't to
-                            be renamed.
-    copyBufferPtr   input:  Points to a buffer of copyBufferSize that
-                            is used the i/o buffer for the copy or
-                            nil if you want DirectoryCopy to allocate its
-                            own buffer in the application heap.
-    copyBufferSize  input:  The size of the buffer pointed to
-                            by copyBufferPtr.
-    preflight       input:  If true, FSpDirectoryCopy makes sure there are
-                            enough allocation blocks on the destination
-                            volume to hold the directory's files before
-                            starting the copy.
-    copyErrHandler  input:  A pointer to the routine you want called if an
-                            error condition is detected during the copy, or
-                            nil if you don't want to handle error conditions.
-                            If you don't handle error conditions, the first
-                            error will cause the copy to quit and
-                            DirectoryCopy will return the error.
-                            Error handling is recommended...
-    copyFilterProc  input:  A pointer to the filter routine you want called
-                            for each item in the source directory, or NULL
-                            if you don't want to filter.
-    
-    Result Codes
-        noErr               0       No error
-        readErr             Ð19     Driver does not respond to read requests
-        writErr             Ð20     Driver does not respond to write requests
-        badUnitErr          Ð21     Driver reference number does not
-                                    match unit table
-        unitEmptyErr        Ð22     Driver reference number specifies a
-                                    nil handle in unit table
-        abortErr            Ð27     Request aborted by KillIO
-        notOpenErr          Ð28     Driver not open
-        dskFulErr           -34     Destination volume is full
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        tmfoErr             -42     Too many files open
-        fnfErr              -43     Source file not found, or destination
-                                    directory does not exist
-        wPrErr              -44     Volume locked by hardware
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Destination volume is read-only
-        fBsyErr             -47     The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        dupFNErr            -48     Destination file already exists
-        opWrErr             -49     File already open for writing
-        paramErr            -50     No default volume or function not
-                                    supported by volume
-        permErr             -54     File is already open and cannot be opened using specified deny modes
-        memFullErr          -108    Copy buffer could not be allocated
-        dirNFErr            -120    Directory not found or incomplete pathname
-        wrgVolTypErr        -123    Function not supported by volume
-        afpAccessDenied     -5000   User does not have the correct access
-        afpDenyConflict     -5006   The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        afpObjectTypeErr    -5025   Source is a directory, directory not found
-                                    or incomplete pathname
-    
-    __________
-    
-    Also see:   CopyErrProcPtr, CopyFilterProcPtr, FilteredDirectoryCopy,
-                DirectoryCopy, FSpDirectoryCopy, FileCopy, FSpFileCopy
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-DirectoryCopy(
-  short              srcVRefNum,
-  long               srcDirID,
-  ConstStr255Param   srcName,
-  short              dstVRefNum,
-  long               dstDirID,
-  ConstStr255Param   dstName,
-  ConstStr255Param   copyName,
-  void *             copyBufferPtr,
-  long               copyBufferSize,
-  Boolean            preflight,
-  CopyErrProcPtr     copyErrHandler);
-
-
-/*
-    The DirectoryCopy function makes a copy of a directory structure in a
-    new location. If copyBufferPtr <> NIL, it points to a buffer of
-    copyBufferSize that is used to copy files data.  The larger the
-    supplied buffer, the faster the copy.  If copyBufferPtr = NIL, then this
-    routine allocates a buffer in the application heap. If you pass a
-    copy buffer to this routine, make its size a multiple of 512
-    ($200) bytes for optimum performance.
-    
-    DirectoryCopy normally creates a new directory *in* the specified
-    destination directory and copies the source directory's content into
-    the new directory. However, if root parent directory (fsRtParID)
-    is passed as the dstDirID parameter and NULL is passed as the
-    dstName parameter, DirectoryCopy renames the destination volume to
-    the source directory's name (truncating if the name is longer than
-    27 characters) and copies the source directory's content into the
-    destination volume's root directory. This special case is supported
-    by DirectoryCopy, but not by FSpDirectoryCopy since with
-    FSpDirectoryCopy, the dstName parameter can not be NULL.
-    
-    srcVRefNum      input:  Source volume specification.
-    srcDirID        input:  Source directory ID.
-    srcName         input:  Source directory name, or nil if
-                            srcDirID specifies the directory.
-    dstVRefNum      input:  Destination volume specification.
-    dstDirID        input:  Destination directory ID.
-    dstName         input:  Destination directory name, or nil if
-                            dstDirID specifies the directory.
-    copyName        input:  Points to the new directory name if the directory
-                            is to be renamed or nil if the directory isn't to
-                            be renamed.
-    copyBufferPtr   input:  Points to a buffer of copyBufferSize that
-                            is used the i/o buffer for the copy or
-                            nil if you want DirectoryCopy to allocate its
-                            own buffer in the application heap.
-    copyBufferSize  input:  The size of the buffer pointed to
-                            by copyBufferPtr.
-    preflight       input:  If true, DirectoryCopy makes sure there are
-                            enough allocation blocks on the destination
-                            volume to hold the directory's files before
-                            starting the copy.
-    copyErrHandler  input:  A pointer to the routine you want called if an
-                            error condition is detected during the copy, or
-                            nil if you don't want to handle error conditions.
-                            If you don't handle error conditions, the first
-                            error will cause the copy to quit and
-                            DirectoryCopy will return the error.
-                            Error handling is recommended...
-    
-    Result Codes
-        noErr               0       No error
-        readErr             Ð19     Driver does not respond to read requests
-        writErr             Ð20     Driver does not respond to write requests
-        badUnitErr          Ð21     Driver reference number does not
-                                    match unit table
-        unitEmptyErr        Ð22     Driver reference number specifies a
-                                    nil handle in unit table
-        abortErr            Ð27     Request aborted by KillIO
-        notOpenErr          Ð28     Driver not open
-        dskFulErr           -34     Destination volume is full
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        tmfoErr             -42     Too many files open
-        fnfErr              -43     Source file not found, or destination
-                                    directory does not exist
-        wPrErr              -44     Volume locked by hardware
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Destination volume is read-only
-        fBsyErr             -47     The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        dupFNErr            -48     Destination file already exists
-        opWrErr             -49     File already open for writing
-        paramErr            -50     No default volume or function not
-                                    supported by volume
-        permErr             -54     File is already open and cannot be opened using specified deny modes
-        memFullErr          -108    Copy buffer could not be allocated
-        dirNFErr            -120    Directory not found or incomplete pathname
-        wrgVolTypErr        -123    Function not supported by volume
-        afpAccessDenied     -5000   User does not have the correct access
-        afpDenyConflict     -5006   The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        afpObjectTypeErr    -5025   Source is a directory, directory not found
-                                    or incomplete pathname
-    
-    __________
-    
-    Also see:   CopyErrProcPtr, FSpDirectoryCopy, FilteredDirectoryCopy,
-                FSpFilteredDirectoryCopy, FileCopy, FSpFileCopy
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpDirectoryCopy(
-  const FSSpec *     srcSpec,
-  const FSSpec *     dstSpec,
-  ConstStr255Param   copyName,
-  void *             copyBufferPtr,
-  long               copyBufferSize,
-  Boolean            preflight,
-  CopyErrProcPtr     copyErrHandler);
-
-
-/*
-    The FSpDirectoryCopy function makes a copy of a directory structure in a
-    new location. If copyBufferPtr <> NIL, it points to a buffer of
-    copyBufferSize that is used to copy files data.  The larger the
-    supplied buffer, the faster the copy.  If copyBufferPtr = NIL, then this
-    routine allocates a buffer in the application heap. If you pass a
-    copy buffer to this routine, make its size a multiple of 512
-    ($200) bytes for optimum performance.
-    
-    srcSpec         input:  An FSSpec record specifying the directory to copy.
-    dstSpec         input:  An FSSpec record specifying destination directory
-                            of the copy.
-    copyName        input:  Points to the new directory name if the directory
-                            is to be renamed or nil if the directory isn't to
-                            be renamed.
-    copyBufferPtr   input:  Points to a buffer of copyBufferSize that
-                            is used the i/o buffer for the copy or
-                            nil if you want DirectoryCopy to allocate its
-                            own buffer in the application heap.
-    copyBufferSize  input:  The size of the buffer pointed to
-                            by copyBufferPtr.
-    preflight       input:  If true, FSpDirectoryCopy makes sure there are
-                            enough allocation blocks on the destination
-                            volume to hold the directory's files before
-                            starting the copy.
-    copyErrHandler  input:  A pointer to the routine you want called if an
-                            error condition is detected during the copy, or
-                            nil if you don't want to handle error conditions.
-                            If you don't handle error conditions, the first
-                            error will cause the copy to quit and
-                            DirectoryCopy will return the error.
-                            Error handling is recommended...
-    
-    Result Codes
-        noErr               0       No error
-        readErr             Ð19     Driver does not respond to read requests
-        writErr             Ð20     Driver does not respond to write requests
-        badUnitErr          Ð21     Driver reference number does not
-                                    match unit table
-        unitEmptyErr        Ð22     Driver reference number specifies a
-                                    nil handle in unit table
-        abortErr            Ð27     Request aborted by KillIO
-        notOpenErr          Ð28     Driver not open
-        dskFulErr           -34     Destination volume is full
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        tmfoErr             -42     Too many files open
-        fnfErr              -43     Source file not found, or destination
-                                    directory does not exist
-        wPrErr              -44     Volume locked by hardware
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Destination volume is read-only
-        fBsyErr             -47     The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        dupFNErr            -48     Destination file already exists
-        opWrErr             -49     File already open for writing
-        paramErr            -50     No default volume or function not
-                                    supported by volume
-        permErr             -54     File is already open and cannot be opened using specified deny modes
-        memFullErr          -108    Copy buffer could not be allocated
-        dirNFErr            -120    Directory not found or incomplete pathname
-        wrgVolTypErr        -123    Function not supported by volume
-        afpAccessDenied     -5000   User does not have the correct access
-        afpDenyConflict     -5006   The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        afpObjectTypeErr    -5025   Source is a directory, directory not found
-                                    or incomplete pathname
-    
-    __________
-    
-    Also see:   CopyErrProcPtr, DirectoryCopy, FilteredDirectoryCopy,
-                FSpFilteredDirectoryCopy, FileCopy, FSpFileCopy
-*/
-
-/*****************************************************************************/
-
-#include "OptimizationEnd.h"
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=reset
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(pop)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack()
-#endif
-
-#ifdef PRAGMA_IMPORT_OFF
-#pragma import off
-#elif PRAGMA_IMPORT
-#pragma import reset
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* __DIRECTORYCOPY__ */
-
diff --git a/src/mac/morefile/FSpCompat.c b/src/mac/morefile/FSpCompat.c
deleted file mode 100644 (file)
index 1757768..0000000
+++ /dev/null
@@ -1,946 +0,0 @@
-/*
-       File:           FSpCompat.c
-
-       Contains:       FSSpec compatibility functions.
-
-       Version:        MoreFiles
-
-       Copyright:      © 1992-2001 by Apple Computer, Inc., all rights reserved.
-
-       You may incorporate this sample code into your applications without
-       restriction, though the sample code has been provided "AS IS" and the
-       responsibility for its operation is 100% yours.  However, what you are
-       not permitted to do is to redistribute the source as "DSC Sample Code"
-       after having made changes. If you're going to re-distribute the source,
-       we require that you make it clear in the source that the code was
-       descended from Apple Sample Code, but that you've made changes.
-
-       File Ownership:
-
-               DRI:                            Apple Macintosh Developer Technical Support
-
-               Other Contact:          Apple Macintosh Developer Technical Support
-                                                       <http://developer.apple.com/bugreporter/>
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-
-       Change History (most recent first):
-
-                <2>      2/7/01        JL              Added standard header. Updated names of includes. Updated
-                                                                       various routines to use new calling convention of the
-                                                                       MoreFilesExtras accessor functions.
-               <1>             12/06/99        JL              MoreFiles 1.5.
-*/
-
-/*
-**     If building application 68K code, set GENERATENODATA to 0 for faster code.
-**     If building stand-alone 68K code, set GENERATENODATA to 1 so globals
-**             (static variables) are not used.
-*/
-#ifndef GENERATENODATA
-#define GENERATENODATA 0
-#endif
-
-#include <MacTypes.h>
-#include <MacErrors.h>
-#include <Files.h>
-#include <LowMem.h>
-#include <Gestalt.h>
-#include <Resources.h>
-#include <Script.h>
-
-#define        __COMPILINGMOREFILES
-
-#include "MoreFilesExtras.h"
-#include "FSpCompat.h"
-
-/*****************************************************************************/
-
-/* local constants */
-
-enum {
-       gestaltBugFixAttrsTwo                                   = 'bugy',
-       gestaltFSpExchangeFilesCompatibilityFix = 26,
-       gestaltBugFixAttrsThree                                 = 'bugx',
-       gestaltFSpCreateScriptSupportFix                = 1
-};
-
-/*****************************************************************************/
-
-/* static prototypes */
-
-
-#if !__MACOSSEVENORLATER
-static Boolean FSHasFSSpecCalls(void);
-
-static Boolean QTHasFSSpecCalls(void);
-#endif /* !__MACOSSEVENORLATER */
-
-#if !__MACOSSEVENFIVEORLATER
-static Boolean HasFSpExchangeFilesCompatibilityFix(void);
-
-static OSErr   GenerateUniqueName(short volume,
-                                                                  long *startSeed,
-                                                                  long dir1,
-                                                                  long dir2,
-                                                                  StringPtr uniqueName);
-#endif /* !__MACOSSEVENFIVEORLATER */
-
-#if !__MACOSSEVENFIVEONEORLATER
-static Boolean HasFSpCreateScriptSupportFix(void);
-#endif /* !__MACOSSEVENFIVEONEORLATER */
-
-/*****************************************************************************/
-
-/* FSHasFSSpecCalls returns true if the file system provides FSSpec calls. */
-
-#if !__MACOSSEVENORLATER
-static Boolean FSHasFSSpecCalls(void)
-{
-       long                    response;
-#if !GENERATENODATA
-       static Boolean  tested = false;
-       static Boolean  result = false;
-#else
-       Boolean result = false;
-#endif
-       
-#if !GENERATENODATA
-       if ( !tested )
-       {
-               tested = true;
-#endif
-               if ( Gestalt(gestaltFSAttr, &response) == noErr )
-               {
-                       result = ((response & (1L << gestaltHasFSSpecCalls)) != 0);
-               }
-#if !GENERATENODATA
-       }
-#endif
-       return ( result );
-}
-#endif /* !__MACOSSEVENORLATER */
-
-/*****************************************************************************/
-
-/* QTHasFSSpecCalls returns true if QuickTime provides FSSpec calls */
-/* except for FSpExchangeFiles. */
-
-#if !__MACOSSEVENORLATER
-static Boolean QTHasFSSpecCalls(void)
-{
-       long                    response;
-#if !GENERATENODATA
-       static Boolean  tested = false;
-       static Boolean  result = false;
-#else
-       Boolean result = false;
-#endif
-       
-#if !GENERATENODATA
-       if ( !tested )
-       {
-               tested = true;
-#endif
-               result = (Gestalt(gestaltQuickTimeVersion, &response) == noErr);
-#if !GENERATENODATA
-       }
-#endif
-       return ( result );
-}
-#endif /* !__MACOSSEVENORLATER */
-
-/*****************************************************************************/
-
-/* HasFSpExchangeFilesCompatibilityFix returns true if FSpExchangeFiles */
-/* compatibility code has been fixed in system software. */
-/* This was fixed by System Update 3.0, so if SystemSevenFiveOrLater */
-/* is true, then we know the fix is in. */
-
-#if !__MACOSSEVENFIVEORLATER
-static Boolean HasFSpExchangeFilesCompatibilityFix(void)
-{
-       long                    response;
-#if !GENERATENODATA
-       static Boolean  tested = false;
-       static Boolean  result = false;
-#else  /* !GENERATENODATA */
-       Boolean result = false;
-#endif /* !GENERATENODATA */
-       
-#if !GENERATENODATA
-       if ( !tested )
-       {
-               tested = true;
-#endif /* !GENERATENODATA */
-               if ( Gestalt(gestaltBugFixAttrsTwo, &response) == noErr )
-               {
-                       result = ((response & (1L << gestaltFSpExchangeFilesCompatibilityFix)) != 0);
-               }
-#if !GENERATENODATA
-       }
-#endif /* !GENERATENODATA */
-       return ( result );
-}
-#endif /* !__MACOSSEVENFIVEORLATER */
-
-/*****************************************************************************/
-
-/* HasFSpCreateScriptSupportFix returns true if FSpCreate and */
-/* FSpCreateResFile have been fixed in system software to correctly set */
-/* the scriptCode in the volume's catalog. */
-/* This was fixed by System 7.5 Update 1.0 */
-
-#if !__MACOSSEVENFIVEONEORLATER
-static Boolean HasFSpCreateScriptSupportFix(void)
-{
-       long                    response;
-#if !GENERATENODATA
-       static Boolean  tested = false;
-       static Boolean  result = false;
-#else
-       Boolean result = false;
-#endif /* !GENERATENODATA */
-       
-#if !GENERATENODATA
-       if ( !tested )
-       {
-               tested = true;
-#endif /* !GENERATENODATA */
-               if ( Gestalt(gestaltBugFixAttrsThree, &response) == noErr )
-               {
-                       result = ((response & (1L << gestaltFSpCreateScriptSupportFix)) != 0);
-               }
-#if !GENERATENODATA
-       }
-#endif /* !GENERATENODATA */
-       return ( result );
-}
-#endif /* !__MACOSSEVENFIVEONEORLATER */
-
-/*****************************************************************************/
-
-/*
-**     File Manager FSp calls
-*/
-
-/*****************************************************************************/
-
-pascal OSErr   FSMakeFSSpecCompat(short vRefNum,
-                                                                  long dirID,
-                                                                  ConstStr255Param fileName,
-                                                                  FSSpec *spec)
-{
-       OSErr   result;
-       
-#if !__MACOSSEVENORLATER
-       if ( !FSHasFSSpecCalls() && !QTHasFSSpecCalls() )
-       {
-               Boolean isDirectory;
-               
-               result = GetObjectLocation(vRefNum, dirID, fileName,
-                                                                       &(spec->vRefNum), &(spec->parID), spec->name,
-                                                                       &isDirectory);
-       }
-       else
-#endif /* !__MACOSSEVENORLATER */
-       {
-               /* Let the file system create the FSSpec if it can since it does the job */
-               /* much more efficiently than I can. */
-               result = FSMakeFSSpec(vRefNum, dirID, fileName, spec);
-
-               /* Fix a bug in Macintosh PC Exchange's MakeFSSpec code where 0 is */
-               /* returned in the parID field when making an FSSpec to the volume's */
-               /* root directory by passing a full pathname in MakeFSSpec's */
-               /* fileName parameter. Fixed in Mac OS 8.1 */
-               if ( (result == noErr) && (spec->parID == 0) )
-                       spec->parID = fsRtParID;
-       }
-       return ( result );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpOpenDFCompat(const FSSpec *spec,
-                                                               char permission,
-                                                               short *refNum)
-{
-#if !__MACOSSEVENORLATER
-       if ( !FSHasFSSpecCalls() && !QTHasFSSpecCalls() )
-       {
-               OSErr                   result;
-               HParamBlockRec  pb;
-               
-               pb.ioParam.ioVRefNum = spec->vRefNum;
-               pb.fileParam.ioDirID = spec->parID;
-               pb.ioParam.ioNamePtr = (StringPtr) &(spec->name);
-               pb.ioParam.ioVersNum = 0;
-               pb.ioParam.ioPermssn = permission;
-               pb.ioParam.ioMisc = NULL;
-               result = PBHOpenSync(&pb);      /* OpenDF not supported by System 6, so use Open */
-               *refNum = pb.ioParam.ioRefNum;
-               return ( result );
-       }
-       else
-#endif /* !__MACOSSEVENORLATER */
-       {
-               return ( FSpOpenDF(spec, permission, refNum) );
-       }
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpOpenRFCompat(const FSSpec *spec,
-                                                               char permission,
-                                                               short *refNum)
-{
-#if !__MACOSSEVENORLATER
-       if ( !FSHasFSSpecCalls() && !QTHasFSSpecCalls() )
-       {
-               OSErr                   result;
-               HParamBlockRec  pb;
-               
-               pb.ioParam.ioVRefNum = spec->vRefNum;
-               pb.fileParam.ioDirID = spec->parID;
-               pb.ioParam.ioNamePtr = (StringPtr) &(spec->name);
-               pb.ioParam.ioVersNum = 0;
-               pb.ioParam.ioPermssn = permission;
-               pb.ioParam.ioMisc = NULL;
-               result = PBHOpenRFSync(&pb);
-               *refNum = pb.ioParam.ioRefNum;
-               return ( result );
-       }
-       else
-#endif /* !__MACOSSEVENORLATER */
-       {
-               return ( FSpOpenRF(spec, permission, refNum) );
-       }
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpCreateCompat(const FSSpec *spec,
-                                                               OSType creator,
-                                                               OSType fileType,
-                                                               ScriptCode scriptTag)
-{
-#if !__MACOSSEVENFIVEONEORLATER
-       OSErr                   result;
-       UniversalFMPB   pb;
-
-       
-       if (
-#if !__MACOSSEVENORLATER
-                (!FSHasFSSpecCalls() && !QTHasFSSpecCalls()) ||
-#endif /* !__MACOSSEVENORLATER */
-                !HasFSpCreateScriptSupportFix() )
-       {
-               /*      If FSpCreate isn't called, this code will be executed */
-               pb.hPB.fileParam.ioVRefNum = spec->vRefNum;
-               pb.hPB.fileParam.ioDirID = spec->parID;
-               pb.hPB.fileParam.ioNamePtr = (StringPtr) &(spec->name);
-               pb.hPB.fileParam.ioFVersNum = 0;
-               result = PBHCreateSync(&(pb.hPB));
-               if ( result == noErr )
-               {
-                       /* get info on created item */
-                       pb.ciPB.hFileInfo.ioFDirIndex = 0;
-                       result = PBGetCatInfoSync(&(pb.ciPB));
-                       if ( result == noErr )
-                       {
-                               /* Set fdScript in FXInfo */
-                               /* The negative script constants (smSystemScript, smCurrentScript, and smAllScripts) */
-                               /* don't make sense on disk, so only use scriptTag if scriptTag >= smRoman */
-                               /* (smRoman is 0). fdScript is valid if high bit is set (see IM-6, page 9-38) */
-                               pb.ciPB.hFileInfo.ioFlXFndrInfo.fdScript = (scriptTag >= smRoman) ?
-                                                                                                                       ((char)scriptTag | (char)0x80) :
-                                                                                                                       (smRoman);
-                               /* Set creator/fileType */
-                               pb.ciPB.hFileInfo.ioFlFndrInfo.fdCreator = creator;
-                               pb.ciPB.hFileInfo.ioFlFndrInfo.fdType = fileType;
-                               /* Restore ioDirID field in pb which was changed by PBGetCatInfo */
-                               pb.ciPB.hFileInfo.ioDirID = spec->parID;
-                               result = PBSetCatInfoSync(&(pb.ciPB));
-                       }
-               }
-               return ( result );
-       }
-       else
-#endif /* !__MACOSSEVENFIVEONEORLATER */
-       {
-               return ( FSpCreate(spec, creator, fileType, scriptTag) );
-       }
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpDirCreateCompat(const FSSpec *spec,
-                                                                  ScriptCode scriptTag,
-                                                                  long *createdDirID)
-{
-#if !__MACOSSEVENORLATER
-       if ( !FSHasFSSpecCalls() && !QTHasFSSpecCalls() )
-       {
-               OSErr                   result;
-               UniversalFMPB   pb;
-               
-               pb.hPB.fileParam.ioVRefNum = spec->vRefNum;
-               pb.hPB.fileParam.ioDirID = spec->parID;
-               pb.hPB.fileParam.ioNamePtr = (StringPtr) &(spec->name);
-               result = PBDirCreateSync(&(pb.hPB));
-               *createdDirID = pb.hPB.fileParam.ioDirID;
-               if ( result == noErr )
-               {
-                       /* get info on created item */
-                       pb.ciPB.dirInfo.ioFDirIndex = 0;
-                       pb.ciPB.dirInfo.ioDrDirID = spec->parID;
-                       result = PBGetCatInfoSync(&(pb.ciPB));
-                       if ( result == noErr )
-                       {
-                               /* Set frScript in DXInfo */
-                               /* The negative script constants (smSystemScript, smCurrentScript, and smAllScripts) */
-                               /* don't make sense on disk, so only use scriptTag if scriptTag >= smRoman */
-                               /* (smRoman is 0). frScript is valid if high bit is set (see IM-6, page 9-38) */
-                               pb.ciPB.dirInfo.ioDrFndrInfo.frScript = (scriptTag >= smRoman) ?
-                                                                                                                       ((char)scriptTag | (char)0x80) :
-                                                                                                                       (smRoman);
-                               /* Restore ioDirID field in pb which was changed by PBGetCatInfo */
-                               pb.ciPB.dirInfo.ioDrDirID = spec->parID;                        
-                               result = PBSetCatInfoSync(&(pb.ciPB));
-                       }
-               }
-               return ( result );
-       }
-       else
-#endif /* !__MACOSSEVENORLATER */
-       {
-               return ( FSpDirCreate(spec, scriptTag, createdDirID) );
-       }
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpDeleteCompat(const FSSpec *spec)
-{
-#if !__MACOSSEVENORLATER
-       if ( !FSHasFSSpecCalls() && !QTHasFSSpecCalls() )
-       {
-               HParamBlockRec  pb;
-               
-               pb.ioParam.ioVRefNum = spec->vRefNum;
-               pb.fileParam.ioDirID = spec->parID;
-               pb.ioParam.ioNamePtr = (StringPtr) &(spec->name);
-               pb.ioParam.ioVersNum = 0;
-               return ( PBHDeleteSync(&pb) );
-       }
-       else
-#endif /* !__MACOSSEVENORLATER */
-       {
-               return ( FSpDelete(spec) );
-       }
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpGetFInfoCompat(const FSSpec *spec,
-                                                                 FInfo *fndrInfo)
-{
-#if !__MACOSSEVENORLATER
-       if ( !FSHasFSSpecCalls() && !QTHasFSSpecCalls() )
-       {
-               OSErr                   result;
-               HParamBlockRec  pb;
-               
-               pb.fileParam.ioVRefNum = spec->vRefNum;
-               pb.fileParam.ioDirID = spec->parID;
-               pb.fileParam.ioNamePtr = (StringPtr) &(spec->name);
-               pb.fileParam.ioFVersNum = 0;
-               pb.fileParam.ioFDirIndex = 0;
-               result = PBHGetFInfoSync(&pb);
-               *fndrInfo = pb.fileParam.ioFlFndrInfo;
-               return ( result );
-       }
-       else
-#endif /* !__MACOSSEVENORLATER */
-       {
-               return ( FSpGetFInfo(spec, fndrInfo) );
-       }
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpSetFInfoCompat(const FSSpec *spec,
-                                                                 const FInfo *fndrInfo)
-{
-#if !__MACOSSEVENORLATER
-       if ( !FSHasFSSpecCalls() && !QTHasFSSpecCalls() )
-       {
-               OSErr                   result;
-               HParamBlockRec  pb;
-               
-               pb.fileParam.ioVRefNum = spec->vRefNum;
-               pb.fileParam.ioDirID = spec->parID;
-               pb.fileParam.ioNamePtr = (StringPtr) &(spec->name);
-               pb.fileParam.ioFVersNum = 0;
-               pb.fileParam.ioFDirIndex = 0;
-               result = PBHGetFInfoSync(&pb);
-               if ( result == noErr )
-               {
-                       pb.fileParam.ioFlFndrInfo = *fndrInfo;
-                       pb.fileParam.ioDirID = spec->parID;
-                       result = PBHSetFInfoSync(&pb);
-               }
-               return ( result );
-       }
-       else
-#endif /* !__MACOSSEVENORLATER */
-       {
-               return ( FSpSetFInfo(spec, fndrInfo) );
-       }
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpSetFLockCompat(const FSSpec *spec)
-{
-#if !__MACOSSEVENORLATER
-       if ( !FSHasFSSpecCalls() && !QTHasFSSpecCalls() )
-       {
-               HParamBlockRec  pb;
-               
-               pb.fileParam.ioVRefNum = spec->vRefNum;
-               pb.fileParam.ioDirID = spec->parID;
-               pb.fileParam.ioNamePtr = (StringPtr) &(spec->name);
-               pb.fileParam.ioFVersNum = 0;
-               return ( PBHSetFLockSync(&pb) );
-       }
-       else
-#endif /* !__MACOSSEVENORLATER */
-       {
-               return ( FSpSetFLock(spec) );
-       }
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpRstFLockCompat(const FSSpec *spec)
-{
-#if !__MACOSSEVENORLATER
-       if ( !FSHasFSSpecCalls() && !QTHasFSSpecCalls() )
-       {
-               HParamBlockRec  pb;
-               
-               pb.fileParam.ioVRefNum = spec->vRefNum;
-               pb.fileParam.ioDirID = spec->parID;
-               pb.fileParam.ioNamePtr = (StringPtr) &(spec->name);
-               pb.fileParam.ioFVersNum = 0;
-               return ( PBHRstFLockSync(&pb) );
-       }
-       else
-#endif /* !__MACOSSEVENORLATER */
-       {
-               return ( FSpRstFLock(spec) );
-       }
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpRenameCompat(const FSSpec *spec,
-                                                               ConstStr255Param newName)
-{
-#if !__MACOSSEVENORLATER
-       if ( !FSHasFSSpecCalls() && !QTHasFSSpecCalls() )
-       {
-               HParamBlockRec  pb;
-               
-               pb.ioParam.ioVRefNum = spec->vRefNum;
-               pb.fileParam.ioDirID = spec->parID;
-               pb.ioParam.ioNamePtr = (StringPtr) &(spec->name);
-               pb.ioParam.ioVersNum = 0;
-               pb.ioParam.ioMisc = (Ptr) newName;
-               return ( PBHRenameSync(&pb) );
-       }
-       else
-#endif /* !__MACOSSEVENORLATER */
-       {
-               return ( FSpRename(spec, newName) );
-       }
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpCatMoveCompat(const FSSpec *source,
-                                                                const FSSpec *dest)
-{
-#if !__MACOSSEVENORLATER
-       if ( !FSHasFSSpecCalls() && !QTHasFSSpecCalls() )
-       {
-               CMovePBRec      pb;
-               
-               /* source and destination volume must be the same */
-               if ( source->vRefNum != dest->vRefNum )
-                       return ( paramErr );
-               
-               pb.ioNamePtr = (StringPtr) &(source->name);
-               pb.ioVRefNum = source->vRefNum;
-               pb.ioDirID = source->parID;
-               pb.ioNewDirID = dest->parID;
-               pb.ioNewName = (StringPtr) &(dest->name);
-               return ( PBCatMoveSync(&pb) );
-       }
-       else
-#endif /* !__MACOSSEVENORLATER */
-       {
-               return ( FSpCatMove(source, dest) );
-       }
-}
-
-/*****************************************************************************/
-
-/* GenerateUniqueName generates a name that is unique in both dir1 and dir2 */
-/* on the specified volume. Ripped off from Feldman's code. */
-
-#if !__MACOSSEVENFIVEORLATER
-static OSErr   GenerateUniqueName(short volume,
-                                                                  long *startSeed,
-                                                                  long dir1,
-                                                                  long dir2,
-                                                                  StringPtr uniqueName)
-{
-       OSErr                   error = noErr;
-       long                    i;
-       CInfoPBRec              cinfo;
-       unsigned char   hexStr[16];
-       
-       for ( i = 0; i < 16; ++i )
-       {
-               if ( i < 10 )
-               {
-                       hexStr[i] = 0x30 + i;
-               }
-               else
-               {
-                       hexStr[i] = 0x37 + i;
-               }
-       }
-       
-       cinfo.hFileInfo.ioVRefNum = volume;
-       cinfo.hFileInfo.ioFDirIndex = 0;
-       cinfo.hFileInfo.ioNamePtr = uniqueName;
-
-       while ( error != fnfErr )
-       {
-               (*startSeed)++;         
-               cinfo.hFileInfo.ioNamePtr[0] = 8;
-               for ( i = 1; i <= 8; i++ )
-               {
-                       cinfo.hFileInfo.ioNamePtr[i] = hexStr[((*startSeed >> ((8-i)*4)) & 0xf)];
-               }
-               cinfo.hFileInfo.ioDirID = dir1;
-               error = fnfErr;
-               for ( i = 1; i <= 2; i++ )
-               {
-                       error = error & PBGetCatInfoSync(&cinfo);
-                       cinfo.hFileInfo.ioDirID = dir2;
-                       if ( (error != fnfErr) && (error != noErr) )
-                       {
-                               return ( error );
-                       }
-               }
-       }
-       return ( noErr );
-}
-#endif /* !__MACOSSEVENFIVEORLATER */
-
-/*****************************************************************************/
-
-pascal OSErr   FSpExchangeFilesCompat(const FSSpec *source,
-                                                                          const FSSpec *dest)
-{
-#if !__MACOSSEVENFIVEORLATER
-       if ( 
-#if !__MACOSSEVENORLATER
-                !FSHasFSSpecCalls() ||
-#endif /* !__MACOSSEVENORLATER */
-                !HasFSpExchangeFilesCompatibilityFix() )
-       {
-               HParamBlockRec                  pb;
-               CInfoPBRec                              catInfoSource, catInfoDest;
-               OSErr                                   result, result2;
-               Str31                                   unique1, unique2;
-               StringPtr                               unique1Ptr, unique2Ptr, swapola;
-               GetVolParmsInfoBuffer   volInfo;
-               long                                    theSeed, temp;
-               
-               /* Make sure the source and destination are on the same volume */
-               if ( source->vRefNum != dest->vRefNum )
-               {
-                       result = diffVolErr;
-                       goto errorExit3;
-               }
-               
-               /* Try PBExchangeFiles first since it preserves the file ID reference */
-               pb.fidParam.ioNamePtr = (StringPtr) &(source->name);
-               pb.fidParam.ioVRefNum = source->vRefNum;
-               pb.fidParam.ioDestNamePtr = (StringPtr) &(dest->name);
-               pb.fidParam.ioDestDirID = dest->parID;
-               pb.fidParam.ioSrcDirID = source->parID;
-       
-               result = PBExchangeFilesSync(&pb);
-       
-               /* Note: The compatibility case won't work for files with *Btree control blocks. */
-               /* Right now the only *Btree files are created by the system. */
-               if ( result != noErr )
-               {
-                       pb.ioParam.ioNamePtr = NULL;
-                       pb.ioParam.ioBuffer = (Ptr) &volInfo;
-                       pb.ioParam.ioReqCount = sizeof(volInfo);
-                       result2 = PBHGetVolParmsSync(&pb);
-                       
-                       /* continue if volume has no fileID support (or no GetVolParms support) */
-                       if ( (result2 == noErr) && hasFileIDs(&volInfo) )
-                       {
-                               goto errorExit3;
-                       }
-       
-                       /* Get the catalog information for each file */
-                       /* and make sure both files are *really* files */
-                       catInfoSource.hFileInfo.ioVRefNum = source->vRefNum;
-                       catInfoSource.hFileInfo.ioFDirIndex = 0;
-                       catInfoSource.hFileInfo.ioNamePtr = (StringPtr) &(source->name);
-                       catInfoSource.hFileInfo.ioDirID = source->parID;
-                       catInfoSource.hFileInfo.ioACUser = 0; /* ioACUser used to be filler2 */
-                       result = PBGetCatInfoSync(&catInfoSource);
-                       if ( result != noErr )
-                       {
-                               goto errorExit3;
-                       }
-                       if ( (catInfoSource.hFileInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-                       {
-                               result = notAFileErr;
-                               goto errorExit3;
-                       }
-                       
-                       catInfoDest.hFileInfo.ioVRefNum = dest->vRefNum;
-                       catInfoDest.hFileInfo.ioFDirIndex = 0;
-                       catInfoDest.hFileInfo.ioNamePtr = (StringPtr) &(dest->name);
-                       catInfoDest.hFileInfo.ioDirID = dest->parID;
-                       catInfoDest.hFileInfo.ioACUser = 0; /* ioACUser used to be filler2 */
-                       result = PBGetCatInfoSync(&catInfoDest);
-                       if ( result != noErr )
-                       {
-                               goto errorExit3;
-                       }
-                       if ( (catInfoDest.hFileInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-                       {
-                               result = notAFileErr;
-                               goto errorExit3;
-                       }
-                       
-                       /* generate 2 filenames that are unique in both directories */
-                       theSeed = 0x64666A6C;   /* a fine unlikely filename */
-                       unique1Ptr = (StringPtr)&unique1;
-                       unique2Ptr = (StringPtr)&unique2;
-                       
-                       result = GenerateUniqueName(source->vRefNum, &theSeed, source->parID, dest->parID, unique1Ptr);
-                       if ( result != noErr )
-                       {
-                               goto errorExit3;
-                       }
-       
-                       GenerateUniqueName(source->vRefNum, &theSeed, source->parID, dest->parID, unique2Ptr);
-                       if ( result != noErr )
-                       {
-                               goto errorExit3;
-                       }
-       
-                       /* rename source to unique1 */
-                       pb.fileParam.ioNamePtr = (StringPtr) &(source->name);
-                       pb.ioParam.ioMisc = (Ptr) unique1Ptr;
-                       pb.ioParam.ioVersNum = 0;
-                       result = PBHRenameSync(&pb);
-                       if ( result != noErr )
-                       {
-                               goto errorExit3;
-                       }
-                       
-                       /* rename dest to unique2 */
-                       pb.ioParam.ioMisc = (Ptr) unique2Ptr;
-                       pb.ioParam.ioVersNum = 0;
-                       pb.fileParam.ioNamePtr = (StringPtr) &(dest->name);
-                       pb.fileParam.ioDirID = dest->parID;
-                       result = PBHRenameSync(&pb);
-                       if ( result != noErr )
-                       {
-                               goto errorExit2;        /* back out gracefully by renaming unique1 back to source */
-                       }
-                               
-                       /* If files are not in same directory, swap their locations */
-                       if ( source->parID != dest->parID )
-                       {
-                               /* move source file to dest directory */
-                               pb.copyParam.ioNamePtr = unique1Ptr;
-                               pb.copyParam.ioNewName = NULL;
-                               pb.copyParam.ioNewDirID = dest->parID;
-                               pb.copyParam.ioDirID = source->parID;
-                               result = PBCatMoveSync((CMovePBPtr) &pb);
-                               if ( result != noErr )
-                               {
-                                       goto errorExit1;        /* back out gracefully by renaming both files to original names */
-                               }
-                               
-                               /* move dest file to source directory */
-                               pb.copyParam.ioNamePtr = unique2Ptr;
-                               pb.copyParam.ioNewDirID = source->parID;
-                               pb.copyParam.ioDirID = dest->parID;
-                               result = PBCatMoveSync((CMovePBPtr) &pb);
-                               if ( result != noErr)
-                               {
-                                       /* life is very bad.  We'll at least try to move source back */
-                                       pb.copyParam.ioNamePtr = unique1Ptr;
-                                       pb.copyParam.ioNewName = NULL;
-                                       pb.copyParam.ioNewDirID = source->parID;
-                                       pb.copyParam.ioDirID = dest->parID;
-                                       (void) PBCatMoveSync((CMovePBPtr) &pb); /* ignore errors */
-                                       goto errorExit1;        /* back out gracefully by renaming both files to original names */
-                               }
-                       }
-                       
-                       /* Make unique1Ptr point to file in source->parID */
-                       /* and unique2Ptr point to file in dest->parID */
-                       /* This lets us fall through to the rename code below */
-                       swapola = unique1Ptr;
-                       unique1Ptr = unique2Ptr;
-                       unique2Ptr = swapola;
-       
-                       /* At this point, the files are in their new locations (if they were moved) */
-                       /* Source is named Unique1 (name pointed to by unique2Ptr) and is in dest->parID */
-                       /* Dest is named Unique2 (name pointed to by unique1Ptr) and is in source->parID */
-                       /* Need to swap attributes except mod date and swap names */
-       
-                       /* swap the catalog info by re-aiming the CInfoPB's */
-                       catInfoSource.hFileInfo.ioNamePtr = unique1Ptr;
-                       catInfoDest.hFileInfo.ioNamePtr = unique2Ptr;
-                       
-                       catInfoSource.hFileInfo.ioDirID = source->parID;
-                       catInfoDest.hFileInfo.ioDirID = dest->parID;
-                       
-                       /* Swap the original mod dates with each file */
-                       temp = catInfoSource.hFileInfo.ioFlMdDat;
-                       catInfoSource.hFileInfo.ioFlMdDat = catInfoDest.hFileInfo.ioFlMdDat;
-                       catInfoDest.hFileInfo.ioFlMdDat = temp;
-                       
-                       /* Here's the swap (ignore errors) */
-                       (void) PBSetCatInfoSync(&catInfoSource); 
-                       (void) PBSetCatInfoSync(&catInfoDest);
-                       
-                       /* rename unique2 back to dest */
-errorExit1:
-                       pb.ioParam.ioMisc = (Ptr) &(dest->name);
-                       pb.ioParam.ioVersNum = 0;
-                       pb.fileParam.ioNamePtr = unique2Ptr;
-                       pb.fileParam.ioDirID = dest->parID;
-                       (void) PBHRenameSync(&pb);      /* ignore errors */
-       
-                       /* rename unique1 back to source */
-errorExit2:
-                       pb.ioParam.ioMisc = (Ptr) &(source->name);
-                       pb.ioParam.ioVersNum = 0;
-                       pb.fileParam.ioNamePtr = unique1Ptr;
-                       pb.fileParam.ioDirID = source->parID;
-                       (void) PBHRenameSync(&pb); /* ignore errors */
-               }
-errorExit3: { /* null statement */ }
-               return ( result );
-       }
-       else
-#endif /* !__MACOSSEVENFIVEORLATER */
-       {
-               return ( FSpExchangeFiles(source, dest) );
-       }
-}
-
-/*****************************************************************************/
-
-/* 
-**     Resource Manager FSp calls
-*/
-
-/*****************************************************************************/
-
-pascal short   FSpOpenResFileCompat(const FSSpec *spec,
-                                                                        SignedByte permission)
-{
-#if !__MACOSSEVENORLATER
-       if ( !FSHasFSSpecCalls() && !QTHasFSSpecCalls() )
-       {
-               return ( HOpenResFile(spec->vRefNum, spec->parID, spec->name, permission) );
-       }
-       else
-#endif /* !__MACOSSEVENORLATER */
-       {
-               return ( FSpOpenResFile(spec, permission) );
-       }
-}
-
-/*****************************************************************************/
-
-pascal void    FSpCreateResFileCompat(const FSSpec *spec,
-                                                                          OSType creator,
-                                                                          OSType fileType,
-                                                                          ScriptCode scriptTag)
-{      
-#if !__MACOSSEVENFIVEONEORLATER
-       if (
-#if !__MACOSSEVENORLATER
-                (!FSHasFSSpecCalls() && !QTHasFSSpecCalls()) ||
-#endif /* !__MACOSSEVENORLATER */
-                !HasFSpCreateScriptSupportFix() )
-       {
-               OSErr                   result;
-               CInfoPBRec              pb;
-               
-               HCreateResFile(spec->vRefNum, spec->parID, spec->name);
-               if ( ResError() == noErr )
-               {
-                       /* get info on created item */
-                       pb.hFileInfo.ioVRefNum = spec->vRefNum;
-                       pb.hFileInfo.ioDirID = spec->parID;
-                       pb.hFileInfo.ioNamePtr = (StringPtr) &(spec->name);
-                       pb.hFileInfo.ioFDirIndex = 0;
-                       result = PBGetCatInfoSync(&pb);
-                       if ( result == noErr )
-                       {
-                               /* Set fdScript in FXInfo */
-                               /* The negative script constants (smSystemScript, smCurrentScript, and smAllScripts) */
-                               /* don't make sense on disk, so only use scriptTag if scriptTag >= smRoman */
-                               /* (smRoman is 0). fdScript is valid if high bit is set (see IM-6, page 9-38) */
-                               pb.hFileInfo.ioFlXFndrInfo.fdScript = (scriptTag >= smRoman) ?
-                                                                                                               ((char)scriptTag | (char)0x80) :
-                                                                                                               (smRoman);
-                               /* Set creator/fileType */
-                               pb.hFileInfo.ioFlFndrInfo.fdCreator = creator;
-                               pb.hFileInfo.ioFlFndrInfo.fdType = fileType;
-                               
-                               /* Restore ioDirID field in pb which was changed by PBGetCatInfo */
-                               pb.hFileInfo.ioDirID = spec->parID;
-                               result = PBSetCatInfoSync(&pb);
-                       }
-                       /* Set ResErr low memory global to result */
-                       LMSetResErr(result);
-               }
-               return;
-       }
-       else
-#endif /* !__MACOSSEVENFIVEONEORLATER */
-       {
-               FSpCreateResFile(spec, creator, fileType, scriptTag);
-               return;
-       }
-}
-
-/*****************************************************************************/
diff --git a/src/mac/morefile/FSpCompat.h b/src/mac/morefile/FSpCompat.h
deleted file mode 100644 (file)
index 1014cb8..0000000
+++ /dev/null
@@ -1,586 +0,0 @@
-/*
-     File:       FSpCompat.h
-     Contains:   FSSpec compatibility functions.
-     Version:    Technology: MoreFiles
-                 Release:    1.5.2
-     Copyright:  © 1992-2001 by Apple Computer, Inc., all rights reserved.
-     Bugs?:      For bug reports, consult the following page on
-                 the World Wide Web:
-                     http://developer.apple.com/bugreporter/
-*/
-
-/*
-    You may incorporate this sample code into your applications without
-    restriction, though the sample code has been provided "AS IS" and the
-    responsibility for its operation is 100% yours.  However, what you are
-    not permitted to do is to redistribute the source as "DSC Sample Code"
-    after having made changes. If you're going to re-distribute the source,
-    we require that you make it clear in the source that the code was
-    descended from Apple Sample Code, but that you've made changes.
-*/
-
-#ifndef __FSPCOMPAT__
-#define __FSPCOMPAT__
-
-#ifndef __MACTYPES__
-#include <MacTypes.h>
-#endif
-
-#ifndef __FILES__
-#include <Files.h>
-#endif
-
-#include "Optimization.h"
-
-
-#if PRAGMA_ONCE
-#pragma once
-#endif
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#if PRAGMA_IMPORT
-#pragma import on
-#endif
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=mac68k
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(push, 2)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack(2)
-#endif
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSMakeFSSpecCompat(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   fileName,
-  FSSpec *           spec);
-
-
-/*
-    The FSMakeFSSpecCompat function fills in the fields of an FSSpec record.
-    If the file system can't create the FSSpec, then the compatibility code
-    creates a FSSpec that is exactly like an FSSpec except that spec.name
-    for a file may not have the same capitalization as the file's catalog
-    entry on the disk volume. That is because fileName is parsed to get the
-    name instead of getting the name back from the file system. This works
-    fine with System 6 where FSMakeSpec isn't available.
-    
-    vRefNum     input:  Volume specification.
-    dirID       input:  Directory ID.
-    fileName    input:  Pointer to object name, or nil when dirID specifies
-                        a directory that's the object.
-    spec        output: A file system specification to be filled in by
-                        FSMakeFSSpecCompat.
-    
-    Result Codes
-        noErr               0       No error    
-        nsvErr              -35     Volume doesnÕt exist    
-        fnfErr              -43     File or directory does not exist
-                                    (FSSpec is still valid) 
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpOpenDFCompat(
-  const FSSpec *  spec,
-  char            permission,
-  short *         refNum);
-
-
-/*
-    The FSpOpenDFCompat function opens the data fork of the file specified
-    by spec.
-    Differences from FSpOpenDF: If FSpOpenDF isn't available,
-    FSpOpenDFCompat uses PHBOpen because System 6 doesn't support PBHOpenDF.
-    This means FSpOpenDFCompat could accidentally open a driver if the
-    spec->name begins with a period.
-    
-    spec        input:  An FSSpec record specifying the file whose data
-                        fork is to be opened.
-    permission  input:  A constant indicating the desired file access
-                        permissions.
-    refNum      output: A reference number of an access path to the file's
-                        data fork.
-    
-    Result Codes
-        noErr               0       No error    
-        nsvErr              -35     No such volume  
-        ioErr               -36     I/O error   
-        bdNamErr            -37     Bad filename    
-        tmfoErr             -42     Too many files open 
-        fnfErr              -43     File not found  
-        opWrErr             -49     File already open for writing   
-        permErr             -54     Attempt to open locked file for writing 
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access to
-                                    the file
-    
-    __________
-    
-    See also:   FSpOpenAware
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpOpenRFCompat(
-  const FSSpec *  spec,
-  char            permission,
-  short *         refNum);
-
-
-/*
-    The FSpOpenRFCompat function opens the resource fork of the file
-    specified by spec.
-    
-    spec        input:  An FSSpec record specifying the file whose resource
-                        fork is to be opened.
-    permission  input:  A constant indicating the desired file access
-                        permissions.
-    refNum      output: A reference number of an access path to the file's
-                        resource fork.
-    
-    Result Codes
-        noErr               0       No error    
-        nsvErr              -35     No such volume  
-        ioErr               -36     I/O error   
-        bdNamErr            -37     Bad filename    
-        tmfoErr             -42     Too many files open 
-        fnfErr              -43     File not found  
-        opWrErr             -49     File already open for writing   
-        permErr             -54     Attempt to open locked file for writing 
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access to
-                                    the file
-    
-    __________
-    
-    See also:   FSpOpenRFAware
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpCreateCompat(
-  const FSSpec *  spec,
-  OSType          creator,
-  OSType          fileType,
-  ScriptCode      scriptTag);
-
-
-/*
-    The FSpCreateCompat function creates a new file with the specified
-    type, creator, and script code.
-    Differences from FSpCreate: FSpCreateCompat correctly sets the
-    fdScript in the file's FXInfo record to scriptTag if the problem
-    isn't fixed in the File Manager code.
-    
-    spec        input:  An FSSpec record specifying the file to create.
-    creator     input:  The creator of the new file.
-    fileType    input   The file type of the new file.
-    scriptCode  input:  The code of the script system in which the file
-                        name is to be displayed.
-    
-    Result Codes
-        noErr               0       No error    
-        dirFulErr           -33     File directory full 
-        dskFulErr           -34     Disk is full    
-        nsvErr              -35     No such volume  
-        ioErr               -36     I/O error   
-        bdNamErr            -37     Bad filename    
-        fnfErr              -43     Directory not found or incomplete pathname  
-        wPrErr              -44     Hardware volume lock    
-        vLckdErr            -46     Software volume lock    
-        dupFNErr            -48     Duplicate filename and version  
-        dirNFErrdirNFErr    -120    Directory not found or incomplete pathname  
-        afpAccessDenied     -5000   User does not have the correct access   
-        afpObjectTypeErr    -5025   A directory exists with that name   
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpDirCreateCompat(
-  const FSSpec *  spec,
-  ScriptCode      scriptTag,
-  long *          createdDirID);
-
-
-/*
-    The FSpDirCreateCompat function creates a new directory and returns the
-    directory ID of the newDirectory.
-    
-    spec            input:  An FSSpec record specifying the directory to
-                            create.
-    scriptCode      input:  The code of the script system in which the
-                            directory name is to be displayed.
-    createdDirID    output: The directory ID of the directory that was
-                            created.
-    
-    Result Codes
-        noErr               0       No error    
-        dirFulErr           -33     File directory full 
-        dskFulErr           -34     Disk is full    
-        nsvErr              -35     No such volume  
-        ioErr               -36     I/O error   
-        bdNamErr            -37     Bad filename    
-        fnfErr              -43     Directory not found or incomplete pathname  
-        wPrErr              -44     Hardware volume lock    
-        vLckdErr            -46     Software volume lock    
-        dupFNErr            -48     Duplicate filename and version  
-        dirNFErrdirNFErr    -120    Directory not found or incomplete pathname  
-        wrgVolTypErr        -123    Not an HFS volume   
-        afpAccessDenied     -5000   User does not have the correct access   
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpDeleteCompat(const FSSpec * spec);
-
-
-/*
-    The FSpDeleteCompat function deletes a file or directory.
-    
-    spec            input:  An FSSpec record specifying the file or 
-                            directory to delete.
-    
-    Result Codes
-        noErr               0       No error    
-        nsvErr              -35     No such volume  
-        ioErr               -36     I/O error   
-        bdNamErr            -37     Bad filename    
-        fnfErr              -43     File not found  
-        wPrErr              -44     Hardware volume lock    
-        fLckdErr            -45     File is locked  
-        vLckdErr            -46     Software volume lock    
-        fBsyErr             -47     File busy, directory not empty, or
-                                    working directory control block open    
-        dirNFErrdirNFErr    -120    Directory not found or incomplete pathname  
-        afpAccessDenied     -5000   User does not have the correct access   
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpGetFInfoCompat(
-  const FSSpec *  spec,
-  FInfo *         fndrInfo);
-
-
-/*
-    The FSpGetFInfoCompat function gets the finder information for a file.
-
-    spec        input:  An FSSpec record specifying the file.
-    fndrInfo    output: If the object is a file, then its FInfo.
-    
-    Result Codes
-        noErr               0       No error    
-        nsvErr              -35     No such volume  
-        ioErr               -36     I/O error   
-        bdNamErr            -37     Bad filename    
-        fnfErr              -43     File not found  
-        paramErr            -50     No default volume   
-        dirNFErrdirNFErr    -120    Directory not found or incomplete pathname  
-        afpAccessDenied     -5000   User does not have the correct access   
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname  
-    
-    __________
-    
-    Also see:   FSpGetDInfo
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpSetFInfoCompat(
-  const FSSpec *  spec,
-  const FInfo *   fndrInfo);
-
-
-/*
-    The FSpSetFInfoCompat function sets the finder information for a file.
-
-    spec        input:  An FSSpec record specifying the file.
-    fndrInfo    input:  The FInfo.
-    
-    Result Codes
-        noErr               0       No error    
-        nsvErr              -35     No such volume  
-        ioErr               -36     I/O error   
-        bdNamErr            -37     Bad filename    
-        fnfErr              -43     File not found  
-        wPrErr              -44     Hardware volume lock    
-        fLckdErr            -45     File is locked  
-        vLckdErr            -46     Software volume lock    
-        dirNFErrdirNFErr    -120    Directory not found or incomplete pathname  
-        afpAccessDenied     -5000   User does not have the correct access   
-        afpObjectTypeErr    -5025   Object was a directory  
-    
-    __________
-    
-    Also see:   FSpSetDInfo
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpSetFLockCompat(const FSSpec * spec);
-
-
-/*
-    The FSpSetFLockCompat function locks a file.
-
-    spec        input:  An FSSpec record specifying the file.
-    
-    Result Codes
-        noErr               0       No error    
-        nsvErr              -35     No such volume  
-        ioErr               -36     I/O error   
-        fnfErr              -43     File not found  
-        wPrErr              -44     Hardware volume lock    
-        vLckdErr            -46     Software volume lock    
-        dirNFErrdirNFErr    -120    Directory not found or incomplete pathname  
-        afpAccessDenied     -5000   User does not have the correct access to
-                                    the file    
-        afpObjectTypeErr    -5025   Folder locking not supported by volume  
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpRstFLockCompat(const FSSpec * spec);
-
-
-/*
-    The FSpRstFLockCompat function unlocks a file.
-
-    spec        input:  An FSSpec record specifying the file.
-    
-    Result Codes
-        noErr               0       No error    
-        nsvErr              -35     No such volume  
-        ioErr               -36     I/O error   
-        fnfErr              -43     File not found  
-        wPrErr              -44     Hardware volume lock    
-        vLckdErr            -46     Software volume lock    
-        dirNFErrdirNFErr    -120    Directory not found or incomplete pathname  
-        afpAccessDenied     -5000   User does not have the correct access to
-                                    the file    
-        afpObjectTypeErr    -5025   Folder locking not supported by volume  
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpRenameCompat(
-  const FSSpec *     spec,
-  ConstStr255Param   newName);
-
-
-/*
-    The FSpRenameCompat function renames a file or directory.
-
-    spec        input:  An FSSpec record specifying the file.
-    newName     input:  The new name of the file or directory.
-    
-    Result Codes
-        noErr               0       No error    
-        dirFulErr           -33     File directory full 
-        dskFulErr           -34     Volume is full  
-        nsvErr              -35     No such volume  
-        ioErr               -36     I/O error   
-        bdNamErr            -37     Bad filename    
-        fnfErr              -43     File not found  
-        wPrErr              -44     Hardware volume lock    
-        fLckdErr            -45     File is locked  
-        vLckdErr            -46     Software volume lock    
-        dupFNErr            -48     Duplicate filename and version  
-        paramErr            -50     No default volume   
-        fsRnErr             -59     Problem during rename   
-        dirNFErrdirNFErr    -120    Directory not found or incomplete pathname  
-        afpAccessDenied     -5000   User does not have the correct access to
-                                    the file    
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpCatMoveCompat(
-  const FSSpec *  source,
-  const FSSpec *  dest);
-
-
-/*
-    The FSpCatMoveCompat function moves a file or directory to a different
-    location on on the same volume.
-
-    source      input:  An FSSpec record specifying the file or directory.
-    dest        input:  An FSSpec record specifying the name and location
-                        of the directory into which the source file or
-                        directory is to be moved.
-    
-    Result Codes
-        noErr               0       No error    
-        nsvErr              -35     No such volume  
-        ioErr               -36     I/O error   
-        bdNamErr            -37     Bad filename or attempt to move into
-                                    a file  
-        fnfErr              -43     File not found  
-        wPrErr              -44     Hardware volume lock    
-        fLckdErr            -45     Target directory is locked  
-        vLckdErr            -46     Software volume lock    
-        dupFNErr            -48     Duplicate filename and version  
-        paramErr            -50     No default volume   
-        badMovErr           -122    Attempt to move into offspring  
-        wrgVolTypErr        -123    Not an HFS volume   
-        afpAccessDenied     -5000   User does not have the correct access to
-                                    the file    
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpExchangeFilesCompat(
-  const FSSpec *  source,
-  const FSSpec *  dest);
-
-
-/*
-    The FSpExchangeFilesCompat function swaps the data in two files by
-    changing the information in the volume's catalog and, if the files
-    are open, in the file control blocks.
-    Differences from FSpExchangeFiles: Correctly exchanges files on volumes
-    that don't support PBExchangeFiles. FSpExchangeFiles attempts to support
-    volumes that don't support PBExchangeFiles, but in System 7, 7.0.1, 7.1,
-    and 7 Pro, the compatibility code just doesn't work on volumes that
-    don't support PBExchangeFiles (even though you may get a noErr result).
-    System Update 3.0 and System 7.5 and later have the problems in
-    FSpExchangeFiles corrected.
-    
-    Result Codes
-        noErr               0       No error    
-        nsvErr              -35     Volume not found    
-        ioErr               -36     I/O error   
-        fnfErr              -43     File not found  
-        fLckdErr            -45     File is locked  
-        vLckdErr            -46     Volume is locked or read-only   
-        paramErr            -50     Function not supported by volume    
-        volOfflinErr        -53     Volume is offline   
-        wrgVolTypErr        -123    Not an HFS volume   
-        diffVolErr          -1303   Files on different volumes  
-        afpAccessDenied     -5000   User does not have the correct access   
-        afpObjectTypeErr    -5025   Object is a directory, not a file   
-        afpSameObjectErr    -5038   Source and destination files are the same   
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( short )
-FSpOpenResFileCompat(
-  const FSSpec *  spec,
-  SignedByte      permission);
-
-
-/*
-    The FSpOpenResFileCompat function opens the resource file specified
-    by spec.
-    
-    spec            input:  An FSSpec record specifying the file whose
-                            resource file is to be opened.
-    permission      input:  A constant indicating the desired file access
-                            permissions.
-    function result output: A resource file reference number, or if there's
-                            an error -1.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              Ð35     No such volume
-        ioErr               Ð36     I/O error
-        bdNamErr            Ð37     Bad filename or volume name (perhaps zero
-                                    length)
-        eofErr              Ð39     End of file
-        tmfoErr             Ð42     Too many files open
-        fnfErr              Ð43     File not found
-        opWrErr             Ð49     File already open with write permission
-        permErr             Ð54     Permissions error (on file open)
-        extFSErr            Ð58     Volume belongs to an external file system
-        memFullErr          Ð108    Not enough room in heap zone
-        dirNFErr            Ð120    Directory not found
-        mapReadErr          Ð199    Map inconsistent with operation
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( void )
-FSpCreateResFileCompat(
-  const FSSpec *  spec,
-  OSType          creator,
-  OSType          fileType,
-  ScriptCode      scriptTag);
-
-
-/*
-    The FSpCreateResFileCompat function creates a new resource file with
-    the specified type, creator, and script code.
-    Differences from FSpCreateResFile: FSpCreateResFileCompat correctly
-    sets the fdScript in the file's FXInfo record to scriptTag if the
-    problem isn't fixed in the File Manager code.
-    
-    spec        input:  An FSSpec record specifying the resource file to create.
-    creator     input:  The creator of the new file.
-    fileType    input   The file type of the new file.
-    scriptCode  input:  The code of the script system in which the file
-                        name is to be displayed.
-    
-    Result Codes
-        noErr               0       No error
-        dirFulErr           Ð33     Directory full
-        dskFulErr           Ð34     Disk full
-        nsvErr              Ð35     No such volume
-        ioErr               Ð36     I/O error
-        bdNamErr            Ð37     Bad filename or volume name (perhaps zero
-                                    length)
-        tmfoErr             Ð42     Too many files open
-        wPrErrw             Ð44     Disk is write-protected
-        fLckdErr            Ð45     File is locked
-*/
-
-/*****************************************************************************/
-
-#include "OptimizationEnd.h"
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=reset
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(pop)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack()
-#endif
-
-#ifdef PRAGMA_IMPORT_OFF
-#pragma import off
-#elif PRAGMA_IMPORT
-#pragma import reset
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* __FSPCOMPAT__ */
-
diff --git a/src/mac/morefile/FileCopy.c b/src/mac/morefile/FileCopy.c
deleted file mode 100644 (file)
index 4848613..0000000
+++ /dev/null
@@ -1,611 +0,0 @@
-/*
-       File:           FileCopy.c
-
-       Contains:       A robust, general purpose file copy routine.
-
-       Version:        MoreFiles
-
-       Copyright:      © 1992-2001 by Apple Computer, Inc., all rights reserved.
-
-       You may incorporate this sample code into your applications without
-       restriction, though the sample code has been provided "AS IS" and the
-       responsibility for its operation is 100% yours.  However, what you are
-       not permitted to do is to redistribute the source as "DSC Sample Code"
-       after having made changes. If you're going to re-distribute the source,
-       we require that you make it clear in the source that the code was
-       descended from Apple Sample Code, but that you've made changes.
-
-       File Ownership:
-
-               DRI:                            Apple Macintosh Developer Technical Support
-
-               Other Contact:          Apple Macintosh Developer Technical Support
-                                                       <http://developer.apple.com/bugreporter/>
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-
-       Change History (most recent first):
-
-                <2>      2/7/01        JL              Added standard header. Updated names of includes. Updated
-                                                                       various routines to use new calling convention of the
-                                                                       MoreFilesExtras accessor functions.
-               <1>             12/06/99        JL              MoreFiles 1.5.
-*/
-
-#include <MacTypes.h>
-#include <MacErrors.h>
-#include <MacMemory.h>
-#include <Files.h>
-#include <Math64.h>
-
-#define        __COMPILINGMOREFILES
-
-#include "MoreFiles.h"
-#include "MoreFilesExtras.h"
-#include "MoreDesktopMgr.h"
-#include "FileCopy.h"
-
-/*****************************************************************************/
-
-/* local constants */
-
-/*     The deny-mode privileges to use when opening the source and destination files. */
-
-enum
-{
-       srcCopyMode = dmRdDenyWr,
-       dstCopyMode = dmWrDenyRdWr
-};
-
-/*     The largest (16K) and smallest (.5K) copy buffer to use if the caller doesn't supply 
-**     their own copy buffer. */
-
-enum
-{
-       bigCopyBuffSize  = 0x00004000,
-       minCopyBuffSize  = 0x00000200
-};
-
-/*****************************************************************************/
-
-/* static prototypes */
-
-static OSErr   GetDestinationDirInfo(short vRefNum,
-                                                                         long dirID,
-                                                                         ConstStr255Param name,
-                                                                         long *theDirID,
-                                                                         Boolean *isDirectory,
-                                                                         Boolean *isDropBox);
-/*     GetDestinationDirInfo tells us if the destination is a directory, it's
-       directory ID, and if it's an AppleShare drop box (write privileges only --
-       no read or search privileges).
-       vRefNum         input:  Volume specification.
-       dirID           input:  Directory ID.
-       name            input:  Pointer to object name, or nil when dirID
-                                               specifies a directory that's the object.
-       theDirID        output: If the object is a file, then its parent directory
-                                               ID. If the object is a directory, then its ID.
-       isDirectory     output: True if object is a directory; false if
-                                               object is a file.
-       isDropBox       output: True if directory is an AppleShare drop box.
-*/
-
-static OSErr   CheckForForks(short vRefNum,
-                                                         long dirID,
-                                                         ConstStr255Param name,
-                                                         Boolean *hasDataFork,
-                                                         Boolean *hasResourceFork);
-/*     CheckForForks tells us if there is a data or resource fork to copy.
-       vRefNum         input:  Volume specification of the file's current
-                                                       location.
-       dirID           input:  Directory ID of the file's current location.
-       name            input:  The name of the file.
-*/
-
-static OSErr   PreflightFileCopySpace(short srcVRefNum,
-                                                                          long srcDirID,
-                                                                          ConstStr255Param srcName,
-                                                                          ConstStr255Param dstVolName,
-                                                                          short dstVRefNum,
-                                                                          Boolean *spaceOK);
-/*     PreflightFileCopySpace determines if there's enough space on a
-       volume to copy the specified file to that volume.
-       Note: The results of this routine are not perfect. For example if the
-       volume's catalog or extents overflow file grows when the new file is
-       created, more allocation blocks may be needed beyond those needed for
-       the file's data and resource forks.
-
-       srcVRefNum              input:  Volume specification of the file's current
-                                                       location.
-       srcDirID                input:  Directory ID of the file's current location.
-       srcName                 input:  The name of the file.
-       dstVolName              input:  A pointer to the name of the volume where
-                                                       the file will be copied or NULL.
-       dstVRefNum              input:  Volume specification indicating the volume
-                                                       where the file will be copied.
-       spaceOK                 output: true if there's enough space on the volume for
-                                                       the file's data and resource forks.
-*/
-
-/*****************************************************************************/
-
-static OSErr   GetDestinationDirInfo(short vRefNum,
-                                                                         long dirID,
-                                                                         ConstStr255Param name,
-                                                                         long *theDirID,
-                                                                         Boolean *isDirectory,
-                                                                         Boolean *isDropBox)
-{
-       CInfoPBRec pb;
-       OSErr error;
-
-       pb.dirInfo.ioACUser = 0;        /* ioACUser used to be filler2, clear it before calling GetCatInfo */
-       error = GetCatInfoNoName(vRefNum, dirID, name, &pb);
-       *theDirID = pb.dirInfo.ioDrDirID;
-       *isDirectory = (pb.dirInfo.ioFlAttrib & kioFlAttribDirMask) != 0;
-       /* see if access priviledges are make changes, not see folder, and not see files (drop box) */
-       *isDropBox = userHasDropBoxAccess(pb.dirInfo.ioACUser);
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-static OSErr   CheckForForks(short vRefNum,
-                                                         long dirID,
-                                                         ConstStr255Param name,
-                                                         Boolean *hasDataFork,
-                                                         Boolean *hasResourceFork)
-{
-       HParamBlockRec pb;
-       OSErr error;
-       
-       pb.fileParam.ioNamePtr = (StringPtr)name;
-       pb.fileParam.ioVRefNum = vRefNum;
-       pb.fileParam.ioFVersNum = 0;
-       pb.fileParam.ioDirID = dirID;
-       pb.fileParam.ioFDirIndex = 0;
-       error = PBHGetFInfoSync(&pb);
-       *hasDataFork = (pb.fileParam.ioFlLgLen != 0);
-       *hasResourceFork = (pb.fileParam.ioFlRLgLen != 0);
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-static OSErr   PreflightFileCopySpace(short srcVRefNum,
-                                                                          long srcDirID,
-                                                                          ConstStr255Param srcName,
-                                                                          ConstStr255Param dstVolName,
-                                                                          short dstVRefNum,
-                                                                          Boolean *spaceOK)
-{
-       UniversalFMPB pb;
-       OSErr error;
-       unsigned long dstFreeBlocks;
-       unsigned long dstBlksPerAllocBlk;
-       unsigned long srcDataBlks;
-       unsigned long srcResourceBlks;
-       
-       error = XGetVolumeInfoNoName(dstVolName, dstVRefNum, &pb.xPB);
-       if ( error == noErr )
-       {
-               /* get allocation block size (always multiple of 512) and divide by 512
-                 to get number of 512-byte blocks per allocation block */
-               dstBlksPerAllocBlk = ((unsigned long)pb.xPB.ioVAlBlkSiz >> 9);
-               
-               /* Convert freeBytes to free disk blocks (512-byte blocks) */
-               dstFreeBlocks = U32SetU(U64ShiftRight(pb.xPB.ioVFreeBytes, 9));
-               
-               /* Now, get the size of the file's data resource forks */
-               pb.hPB.fileParam.ioNamePtr = (StringPtr)srcName;
-               pb.hPB.fileParam.ioVRefNum = srcVRefNum;
-               pb.hPB.fileParam.ioFVersNum = 0;
-               pb.hPB.fileParam.ioDirID = srcDirID;
-               pb.hPB.fileParam.ioFDirIndex = 0;
-               error = PBHGetFInfoSync(&pb.hPB);
-               if ( error == noErr )
-               {
-                       /* Since space on Mac OS disks is always allocated in allocation blocks, */
-                       /* this code takes into account rounding up to the end of an allocation block. */
-
-                       /* get number of 512-byte blocks needed for data fork */
-                       if ( ((unsigned long)pb.hPB.fileParam.ioFlLgLen & 0x000001ff) != 0 )
-                       {
-                               srcDataBlks = ((unsigned long)pb.hPB.fileParam.ioFlLgLen >> 9) + 1;
-                       }
-                       else
-                       {
-                               srcDataBlks = (unsigned long)pb.hPB.fileParam.ioFlLgLen >> 9;
-                       }
-                       
-                       /* now, calculate number of new allocation blocks needed */
-                       if ( srcDataBlks % dstBlksPerAllocBlk )
-                       {
-                               srcDataBlks = (srcDataBlks / dstBlksPerAllocBlk) + 1;
-                       }
-                       else
-                       {
-                               srcDataBlks /= dstBlksPerAllocBlk;
-                       }
-               
-                       /* get number of 512-byte blocks needed for resource fork */
-                       if ( ((unsigned long)pb.hPB.fileParam.ioFlRLgLen & 0x000001ff) != 0 )
-                       {
-                               srcResourceBlks = ((unsigned long)pb.hPB.fileParam.ioFlRLgLen >> 9) + 1;
-                       }
-                       else
-                       {
-                               srcResourceBlks = (unsigned long)pb.hPB.fileParam.ioFlRLgLen >> 9;
-                       }
-
-                       /* now, calculate number of new allocation blocks needed */
-                       if ( srcResourceBlks % dstBlksPerAllocBlk )
-                       {
-                               srcResourceBlks = (srcResourceBlks / dstBlksPerAllocBlk) + 1;
-                       }
-                       else
-                       {
-                               srcResourceBlks /= dstBlksPerAllocBlk;
-                       }
-                       
-                       /* Is there enough room on the destination volume for the source file? */
-                       *spaceOK = ( ((srcDataBlks + srcResourceBlks) * dstBlksPerAllocBlk) <= dstFreeBlocks );
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FileCopy(short srcVRefNum,
-                                                long srcDirID,
-                                                ConstStr255Param srcName,
-                                                short dstVRefNum,
-                                                long dstDirID,
-                                                ConstStr255Param dstPathname,
-                                                ConstStr255Param copyName,
-                                                void *copyBufferPtr,
-                                                long copyBufferSize,
-                                                Boolean preflight)
-{
-       OSErr   err;
-
-       short   srcRefNum = 0,                  /* 0 when source data and resource fork are closed  */
-                       dstDataRefNum = 0,              /* 0 when destination data fork is closed */
-                       dstRsrcRefNum = 0;              /* 0 when destination resource fork is closed */
-       
-       Str63   dstName;                                /* The filename of the destination. It might be the
-                                                                       ** source filename, it might be a new name... */
-       
-       GetVolParmsInfoBuffer infoBuffer; /* Where PBGetVolParms dumps its info */
-       long    srcServerAdr;                   /* AppleTalk server address of source (if any) */
-       
-       Boolean dstCreated = false,             /* true when destination file has been created */
-                       ourCopyBuffer = false,  /* true if we had to allocate the copy buffer */
-                       isDirectory,                    /* true if destination is really a directory */
-                       isDropBox;                              /* true if destination is an AppleShare drop box */
-       
-       long    tempLong;
-       short   tempInt;
-       
-       Boolean spaceOK;                                /* true if there's enough room to copy the file to the destination volume */
-
-       Boolean hasDataFork;
-       Boolean hasResourceFork;
-
-       /* Preflight for size */
-       if ( preflight )
-       {
-               err = PreflightFileCopySpace(srcVRefNum, srcDirID, srcName,
-                                                                        dstPathname, dstVRefNum, &spaceOK);
-               if ( err != noErr )
-               {
-                       return ( err );
-               }
-               
-               if ( !spaceOK )
-               {
-                       return ( dskFulErr );
-               }
-       }
-
-       /* get the destination's real dirID and make sure it really is a directory */
-       err = GetDestinationDirInfo(dstVRefNum, dstDirID, dstPathname,
-                                                               &dstDirID, &isDirectory, &isDropBox);
-       if ( err != noErr )
-       {
-               goto ErrorExit;
-       }
-       
-       if ( !isDirectory )
-       {
-               return ( dirNFErr );
-       }
-
-       /* get the destination's real vRefNum */
-       err = DetermineVRefNum(dstPathname, dstVRefNum, &dstVRefNum);
-       if ( err != noErr )
-       {
-               goto ErrorExit;
-       }
-       
-       /* See if PBHCopyFile can be used.  Using PBHCopyFile saves time by letting the file server
-       ** copy the file if the source and destination locations are on the same file server. */
-       tempLong = sizeof(infoBuffer);
-       err = HGetVolParms(srcName, srcVRefNum, &infoBuffer, &tempLong);
-       if ( (err != noErr) && (err != paramErr) )
-       {
-               return ( err );
-       }
-
-       if ( (err != paramErr) && hasCopyFile(&infoBuffer) )
-       {
-               /* The source volume supports PBHCopyFile. */
-               srcServerAdr = infoBuffer.vMServerAdr;
-
-               /* Now, see if the destination volume is on the same file server. */
-               tempLong = sizeof(infoBuffer);
-               err = HGetVolParms(NULL, dstVRefNum, &infoBuffer, &tempLong);
-               if ( (err != noErr) && (err != paramErr) )
-               {
-                       return ( err );
-               }
-               if ( (err != paramErr) && (srcServerAdr == infoBuffer.vMServerAdr) )
-               {
-                       /* Source and Dest are on same server and PBHCopyFile is supported. Copy with CopyFile. */
-                       err = HCopyFile(srcVRefNum, srcDirID, srcName, dstVRefNum, dstDirID, NULL, copyName);
-                       if ( err != noErr )
-                       {
-                               return ( err );
-                       }
-                                               
-                       /* AppleShare's CopyFile clears the isAlias bit, so I still need to attempt to copy
-                          the File's attributes to attempt to get things right. */
-                       if ( copyName != NULL )                         /* Did caller supply copy file name? */
-                       {
-                               /* Yes, use the caller supplied copy file name. */
-                               (void) CopyFileMgrAttributes(srcVRefNum, srcDirID, srcName,
-                                                                                        dstVRefNum, dstDirID, copyName, true);
-                       }
-                       else
-                       {
-                               /* They didn't, so get the source file name and use it. */
-                               if ( GetFilenameFromPathname(srcName, dstName) == noErr )
-                               {
-                                       /* */
-                                       (void) CopyFileMgrAttributes(srcVRefNum, srcDirID, srcName,
-                                                                                                dstVRefNum, dstDirID, dstName, true);
-                               }
-                       }
-                       return ( err );
-               }
-       }
-
-       /* If we're here, then PBHCopyFile couldn't be used so we have to copy the file by hand. */
-
-       /* Make sure a copy buffer is allocated. */
-       if ( copyBufferPtr == NULL )
-       {
-               /* The caller didn't supply a copy buffer so grab one from the application heap.
-               ** Try to get a big copy buffer, if we can't, try for a 512-byte buffer.
-               ** If 512 bytes aren't available, we're in trouble. */
-               copyBufferSize = bigCopyBuffSize;
-               copyBufferPtr = NewPtr(copyBufferSize);
-               if ( copyBufferPtr == NULL )
-               {
-                       copyBufferSize = minCopyBuffSize;
-                       copyBufferPtr = NewPtr(copyBufferSize);
-                       if ( copyBufferPtr == NULL )
-                       {
-                               return ( memFullErr );
-                       }
-               }
-               ourCopyBuffer = true;
-       }
-
-       /* Open the source data fork. */
-       err = HOpenAware(srcVRefNum, srcDirID, srcName, srcCopyMode, &srcRefNum);
-       if ( err != noErr )
-               return ( err );
-       
-       /* Once a file is opened, we have to exit via ErrorExit to make sure things are cleaned up */
-       
-       /* See if the copy will be renamed. */
-       if ( copyName != NULL )                         /* Did caller supply copy file name? */
-               BlockMoveData(copyName, dstName, copyName[0] + 1);      /* Yes, use the caller supplied copy file name. */
-       else
-       {       /* They didn't, so get the source file name and use it. */
-               err = GetFileLocation(srcRefNum, &tempInt, &tempLong, dstName);
-               if ( err != noErr )
-               {
-                       goto ErrorExit;
-               }
-       }
-
-       /* Create the destination file. */
-       err = HCreateMinimum(dstVRefNum, dstDirID, dstName);
-       if ( err != noErr )
-       {
-               goto ErrorExit;
-       }
-       dstCreated = true;      /* After creating the destination file, any
-                                               ** error conditions should delete the destination file */
-
-       /* An AppleShare dropbox folder is a folder for which the user has the Make Changes
-       ** privilege (write access), but not See Files (read access) and See Folders (search access).
-       ** Copying a file into an AppleShare dropbox presents some special problems. Here are the
-       ** rules we have to follow to copy a file into a dropbox:
-       ** ¥ File attributes can be changed only when both forks of a file are empty.
-       ** ¥ DeskTop Manager comments can be added to a file only when both forks of a file 
-       **   are empty.
-       ** ¥ A fork can be opened for write access only when both forks of a file are empty.
-       ** So, with those rules to live with, we'll do those operations now while both forks
-       ** are empty. */
-
-       if ( isDropBox )
-       {
-               /* We only set the file attributes now if the file is being copied into a
-               ** drop box. In all other cases, it is better to set the attributes last
-               ** so that if FileCopy is modified to give up time to other processes
-               ** periodicly, the Finder won't try to read any bundle information (because
-               ** the bundle-bit will still be clear) from a partially copied file. If the
-               ** copy is into a drop box, we have to set the attributes now, but since the
-               ** destination forks are opened with write/deny-read/deny-write permissions,
-               ** any Finder that might see the file in the drop box won't be able to open
-               ** its resource fork until the resource fork is closed.
-               **
-               ** Note: if you do modify FileCopy to give up time to other processes, don't
-               ** give up time between the time the destination file is created (above) and
-               ** the time both forks are opened (below). That way, you stand the best chance
-               ** of making sure the Finder doesn't read a partially copied resource fork.
-               */
-               /* Copy attributes but don't lock the destination. */
-               err = CopyFileMgrAttributes(srcVRefNum, srcDirID, srcName,
-                                                                       dstVRefNum, dstDirID, dstName, false);
-               if ( err != noErr )
-               {
-                       goto ErrorExit;
-               }
-       }
-
-       /* Attempt to copy the comments while both forks are empty.
-       ** Ignore the result because we really don't care if it worked or not. */
-       (void) DTCopyComment(srcVRefNum, srcDirID, srcName, dstVRefNum, dstDirID, dstName);
-
-       /* See which forks we need to copy. By doing this, we won't create a data or resource fork
-       ** for the destination unless it's really needed (some foreign file systems such as
-       ** the ProDOS File System and Macintosh PC Exchange have to create additional disk
-       ** structures to support resource forks). */
-       err = CheckForForks(srcVRefNum, srcDirID, srcName, &hasDataFork, &hasResourceFork);
-       if ( err != noErr )
-       {
-               goto ErrorExit;
-       }
-       
-       if ( hasDataFork )
-       {
-               /* Open the destination data fork. */
-               err = HOpenAware(dstVRefNum, dstDirID, dstName, dstCopyMode, &dstDataRefNum);
-               if ( err != noErr )
-               {
-                       goto ErrorExit;
-               }
-       }
-
-       if ( hasResourceFork )
-       {
-               /* Open the destination resource fork. */
-               err = HOpenRFAware(dstVRefNum, dstDirID, dstName, dstCopyMode, &dstRsrcRefNum);
-               if ( err != noErr )
-               {
-                       goto ErrorExit;
-               }
-       }
-
-       if ( hasDataFork )
-       {
-               /* Copy the data fork. */
-               err = CopyFork(srcRefNum, dstDataRefNum, copyBufferPtr, copyBufferSize);
-               if ( err != noErr )
-               {
-                       goto ErrorExit;
-               }
-       
-               /* Close both data forks and clear reference numbers. */
-               (void) FSClose(srcRefNum);
-               (void) FSClose(dstDataRefNum);
-               srcRefNum = dstDataRefNum = 0;
-       }
-       else
-       {
-               /* Close the source data fork since it was opened earlier */
-               (void) FSClose(srcRefNum);
-               srcRefNum = 0;
-       }
-
-       if ( hasResourceFork )
-       {
-               /* Open the source resource fork. */
-               err = HOpenRFAware(srcVRefNum, srcDirID, srcName, srcCopyMode, &srcRefNum);
-               if ( err != noErr )
-               {
-                       goto ErrorExit;
-               }
-       
-               /* Copy the resource fork. */
-               err = CopyFork(srcRefNum, dstRsrcRefNum, copyBufferPtr, copyBufferSize);
-               if ( err != noErr )
-               {
-                       goto ErrorExit;
-               }
-       
-               /* Close both resource forks and clear reference numbers. */
-               (void) FSClose(srcRefNum);
-               (void) FSClose(dstRsrcRefNum);
-               srcRefNum = dstRsrcRefNum = 0;
-       }
-
-       /* Get rid of the copy buffer if we allocated it. */
-       if ( ourCopyBuffer )
-       {
-               DisposePtr((Ptr)copyBufferPtr);
-       }
-
-       /* Attempt to copy attributes again to set mod date.  Copy lock condition this time
-       ** since we're done with the copy operation.  This operation will fail if we're copying
-       ** into an AppleShare dropbox, so we don't check for error conditions. */
-       CopyFileMgrAttributes(srcVRefNum, srcDirID, srcName,
-                                                       dstVRefNum, dstDirID, dstName, true);
-
-       /* Hey, we did it! */
-       return ( noErr );
-       
-ErrorExit:
-       if ( srcRefNum != 0 )
-       {
-               (void) FSClose(srcRefNum);              /* Close the source file */
-       }
-       if ( dstDataRefNum != 0 )
-       {
-               (void) FSClose(dstDataRefNum);  /* Close the destination file data fork */
-       }
-       if ( dstRsrcRefNum != 0 )
-       {
-               (void) FSClose(dstRsrcRefNum);  /* Close the destination file resource fork */
-       }
-       if ( dstCreated )
-       {
-               (void) HDelete(dstVRefNum, dstDirID, dstName);  /* Delete dest file.  This may fail if the file 
-                                                                                                  is in a "drop folder" */
-       }
-       if ( ourCopyBuffer )    /* dispose of any memory we allocated */
-       {
-               DisposePtr((Ptr)copyBufferPtr);
-       }
-       
-       return ( err );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpFileCopy(const FSSpec *srcSpec,
-                                                       const FSSpec *dstSpec,
-                                                       ConstStr255Param copyName,
-                                                       void *copyBufferPtr,
-                                                       long copyBufferSize,
-                                                       Boolean preflight)
-{
-       return ( FileCopy(srcSpec->vRefNum, srcSpec->parID, srcSpec->name,
-                                        dstSpec->vRefNum, dstSpec->parID, dstSpec->name,
-                                        copyName, copyBufferPtr, copyBufferSize, preflight) );
-}
-
-/*****************************************************************************/
-
diff --git a/src/mac/morefile/FileCopy.h b/src/mac/morefile/FileCopy.h
deleted file mode 100644 (file)
index a855f1f..0000000
+++ /dev/null
@@ -1,271 +0,0 @@
-/*
-     File:       FileCopy.h
-     Contains:   A robust, general purpose file copy routine.
-     Version:    Technology: MoreFiles
-                 Release:    1.5.2
-     Copyright:  © 1992-2001 by Apple Computer, Inc., all rights reserved.
-     Bugs?:      For bug reports, consult the following page on
-                 the World Wide Web:
-                     http://developer.apple.com/bugreporter/
-*/
-
-/*
-    You may incorporate this sample code into your applications without
-    restriction, though the sample code has been provided "AS IS" and the
-    responsibility for its operation is 100% yours.  However, what you are
-    not permitted to do is to redistribute the source as "DSC Sample Code"
-    after having made changes. If you're going to re-distribute the source,
-    we require that you make it clear in the source that the code was
-    descended from Apple Sample Code, but that you've made changes.
-*/
-
-#ifndef __FILECOPY__
-#define __FILECOPY__
-
-#ifndef __MACTYPES__
-#include <MacTypes.h>
-#endif
-
-#ifndef __FILES__
-#include <Files.h>
-#endif
-
-#include "Optimization.h"
-
-
-#if PRAGMA_ONCE
-#pragma once
-#endif
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#if PRAGMA_IMPORT
-#pragma import on
-#endif
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=mac68k
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(push, 2)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack(2)
-#endif
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FileCopy(
-  short              srcVRefNum,
-  long               srcDirID,
-  ConstStr255Param   srcName,
-  short              dstVRefNum,
-  long               dstDirID,
-  ConstStr255Param   dstPathname,
-  ConstStr255Param   copyName,
-  void *             copyBufferPtr,
-  long               copyBufferSize,
-  Boolean            preflight);
-
-
-/*
-    The FileCopy function duplicates a file and optionally renames it.
-    Since the PBHCopyFile routine is only available on some
-    AFP server volumes under specific conditions, this routine
-    either uses PBHCopyFile, or does all of the work PBHCopyFile
-    does.  The srcVRefNum, srcDirID and srcName are used to
-    determine the location of the file to copy.  The dstVRefNum
-    dstDirID and dstPathname are used to determine the location of
-    the destination directory.  If copyName <> NIL, then it points
-    to the name of the new file.  If copyBufferPtr <> NIL, it
-    points to a buffer of copyBufferSize that is used to copy
-    the file's data.  The larger the supplied buffer, the
-    faster the copy.  If copyBufferPtr = NIL, then this routine
-    allocates a buffer in the application heap. If you pass a
-    copy buffer to this routine, make its size a multiple of 512
-    ($200) bytes for optimum performance.
-    
-    srcVRefNum      input:  Source volume specification.
-    srcDirID        input:  Source directory ID.
-    srcName         input:  Source file name.
-    dstVRefNum      input:  Destination volume specification.
-    dstDirID        input:  Destination directory ID.
-    dstPathname     input:  Pointer to destination directory name, or
-                            nil when dstDirID specifies a directory.
-    copyName        input:  Points to the new file name if the file is
-                            to be renamed or nil if the file isn't to
-                            be renamed.
-    copyBufferPtr   input:  Points to a buffer of copyBufferSize that
-                            is used the i/o buffer for the copy or
-                            nil if you want FileCopy to allocate its
-                            own buffer in the application heap.
-    copyBufferSize  input:  The size of the buffer pointed to
-                            by copyBufferPtr.
-    preflight       input:  If true, FileCopy makes sure there are enough
-                            allocation blocks on the destination volume to
-                            hold both the data and resource forks before
-                            starting the copy.
-    
-    Result Codes
-        noErr               0       No error
-        readErr             Ð19     Driver does not respond to read requests
-        writErr             Ð20     Driver does not respond to write requests
-        badUnitErr          Ð21     Driver reference number does not
-                                    match unit table
-        unitEmptyErr        Ð22     Driver reference number specifies a
-                                    nil handle in unit table
-        abortErr            Ð27     Request aborted by KillIO
-        notOpenErr          Ð28     Driver not open
-        dskFulErr           -34     Destination volume is full
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        tmfoErr             -42     Too many files open
-        fnfErr              -43     Source file not found, or destination
-                                    directory does not exist
-        wPrErr              -44     Volume locked by hardware
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Destination volume is read-only
-        fBsyErr             -47     The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        dupFNErr            -48     Destination file already exists
-        opWrErr             -49     File already open for writing
-        paramErr            -50     No default volume or function not
-                                    supported by volume
-        permErr             -54     File is already open and cannot be opened using specified deny modes
-        memFullErr          -108    Copy buffer could not be allocated
-        dirNFErr            -120    Directory not found or incomplete pathname
-        wrgVolTypErr        -123    Function not supported by volume
-        afpAccessDenied     -5000   User does not have the correct access
-        afpDenyConflict     -5006   The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        afpObjectTypeErr    -5025   Source is a directory, directory not found
-                                    or incomplete pathname
-    
-    __________
-    
-    Also see:   FSpFileCopy, DirectoryCopy, FSpDirectoryCopy
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpFileCopy(
-  const FSSpec *     srcSpec,
-  const FSSpec *     dstSpec,
-  ConstStr255Param   copyName,
-  void *             copyBufferPtr,
-  long               copyBufferSize,
-  Boolean            preflight);
-
-
-/*
-    The FSpFileCopy function duplicates a file and optionally renames it.
-    Since the PBHCopyFile routine is only available on some
-    AFP server volumes under specific conditions, this routine
-    either uses PBHCopyFile, or does all of the work PBHCopyFile
-    does.  The srcSpec is used to
-    determine the location of the file to copy.  The dstSpec is
-    used to determine the location of the
-    destination directory.  If copyName <> NIL, then it points
-    to the name of the new file.  If copyBufferPtr <> NIL, it
-    points to a buffer of copyBufferSize that is used to copy
-    the file's data.  The larger the supplied buffer, the
-    faster the copy.  If copyBufferPtr = NIL, then this routine
-    allocates a buffer in the application heap. If you pass a
-    copy buffer to this routine, make its size a multiple of 512
-    ($200) bytes for optimum performance.
-    
-    srcSpec         input:  An FSSpec record specifying the source file.
-    dstSpec         input:  An FSSpec record specifying the destination
-                            directory.
-    copyName        input:  Points to the new file name if the file is
-                            to be renamed or nil if the file isn't to
-                            be renamed.
-    copyBufferPtr   input:  Points to a buffer of copyBufferSize that
-                            is used the i/o buffer for the copy or
-                            nil if you want FileCopy to allocate its
-                            own buffer in the application heap.
-    copyBufferSize  input:  The size of the buffer pointed to
-                            by copyBufferPtr.
-    preflight       input:  If true, FSpFileCopy makes sure there are
-                            enough allocation blocks on the destination
-                            volume to hold both the data and resource forks
-                            before starting the copy.
-    
-    Result Codes
-        noErr               0       No error
-        readErr             Ð19     Driver does not respond to read requests
-        writErr             Ð20     Driver does not respond to write requests
-        badUnitErr          Ð21     Driver reference number does not
-                                    match unit table
-        unitEmptyErr        Ð22     Driver reference number specifies a
-                                    nil handle in unit table
-        abortErr            Ð27     Request aborted by KillIO
-        notOpenErr          Ð28     Driver not open
-        dskFulErr           -34     Destination volume is full
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        tmfoErr             -42     Too many files open
-        fnfErr              -43     Source file not found, or destination
-                                    directory does not exist
-        wPrErr              -44     Volume locked by hardware
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Destination volume is read-only
-        fBsyErr             -47     The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        dupFNErr            -48     Destination file already exists
-        opWrErr             -49     File already open for writing
-        paramErr            -50     No default volume or function not
-                                    supported by volume
-        permErr             -54     File is already open and cannot be opened using specified deny modes
-        memFullErr          -108    Copy buffer could not be allocated
-        dirNFErr            -120    Directory not found or incomplete pathname
-        wrgVolTypErr        -123    Function not supported by volume
-        afpAccessDenied     -5000   User does not have the correct access
-        afpDenyConflict     -5006   The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        afpObjectTypeErr    -5025   Source is a directory, directory not found
-                                    or incomplete pathname
-    
-    __________
-    
-    Also see:   FileCopy, DirectoryCopy, FSpDirectoryCopy
-*/
-
-/*****************************************************************************/
-
-#include "OptimizationEnd.h"
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=reset
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(pop)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack()
-#endif
-
-#ifdef PRAGMA_IMPORT_OFF
-#pragma import off
-#elif PRAGMA_IMPORT
-#pragma import reset
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* __FILECOPY__ */
-
diff --git a/src/mac/morefile/FullPath.c b/src/mac/morefile/FullPath.c
deleted file mode 100644 (file)
index 32ccb99..0000000
+++ /dev/null
@@ -1,282 +0,0 @@
-/*
-       File:           FullPath.c
-
-       Contains:       Routines for dealing with full pathnames... if you really must.
-
-       Version:        MoreFiles
-
-       Copyright:      © 1995-2001 by Apple Computer, Inc., all rights reserved.
-
-       You may incorporate this sample code into your applications without
-       restriction, though the sample code has been provided "AS IS" and the
-       responsibility for its operation is 100% yours.  However, what you are
-       not permitted to do is to redistribute the source as "DSC Sample Code"
-       after having made changes. If you're going to re-distribute the source,
-       we require that you make it clear in the source that the code was
-       descended from Apple Sample Code, but that you've made changes.
-
-       File Ownership:
-
-               DRI:                            Apple Macintosh Developer Technical Support
-
-               Other Contact:          Apple Macintosh Developer Technical Support
-                                                       <http://developer.apple.com/bugreporter/>
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-
-       Change History (most recent first):
-
-                <2>      2/7/01        JL              Added standard header. Updated names of includes.
-               <1>             12/06/99        JL              MoreFiles 1.5.
-*/
-
-#include <MacTypes.h>
-#include <MacErrors.h>
-#include <MacMemory.h>
-#include <Files.h>
-#include <TextUtils.h>
-#include <Aliases.h>
-
-#define        __COMPILINGMOREFILES
-
-#include "FSpCompat.h"
-#include "FullPath.h"
-
-/*
-       IMPORTANT NOTE:
-       
-       The use of full pathnames is strongly discouraged. Full pathnames are
-       particularly unreliable as a means of identifying files, directories
-       or volumes within your application, for two primary reasons:
-       
-       ¥       The user can change the name of any element in the path at virtually
-               any time.
-       ¥       Volume names on the Macintosh are *not* unique. Multiple
-               mounted volumes can have the same name. For this reason, the use of
-               a full pathname to identify a specific volume may not produce the
-               results you expect. If more than one volume has the same name and
-               a full pathname is used, the File Manager currently uses the first
-               mounted volume it finds with a matching name in the volume queue.
-       
-       In general, you should use a fileÕs name, parent directory ID, and
-       volume reference number to identify a file you want to open, delete,
-       or otherwise manipulate.
-       
-       If you need to remember the location of a particular file across
-       subsequent system boots, use the Alias Manager to create an alias record
-       describing the file. If the Alias Manager is not available, you can save
-       the fileÕs name, its parent directory ID, and the name of the volume on
-       which itÕs located. Although none of these methods is foolproof, they are
-       much more reliable than using full pathnames to identify files.
-       
-       Nonetheless, it is sometimes useful to display a fileÕs full pathname to
-       the user. For example, a backup utility might display a list of full
-       pathnames of files as it copies them onto the backup medium. Or, a
-       utility might want to display a dialog box showing the full pathname of
-       a file when it needs the userÕs confirmation to delete the file. No
-       matter how unreliable full pathnames may be from a file-specification
-       viewpoint, users understand them more readily than volume reference
-       numbers or directory IDs. (Hint: Use the TruncString function from
-       TextUtils.h with truncMiddle as the truncWhere argument to shorten
-       full pathnames to a displayable length.)
-       
-       The following technique for constructing the full pathname of a file is
-       intended for display purposes only. Applications that depend on any
-       particular structure of a full pathname are likely to fail on alternate
-       foreign file systems or under future system software versions.
-*/
-
-/*****************************************************************************/
-
-pascal OSErr   GetFullPath(short vRefNum,
-                                                       long dirID,
-                                                       ConstStr255Param name,
-                                                       short *fullPathLength,
-                                                       Handle *fullPath)
-{
-       OSErr           result;
-       FSSpec          spec;
-       
-       *fullPathLength = 0;
-       *fullPath = NULL;
-       
-       result = FSMakeFSSpecCompat(vRefNum, dirID, name, &spec);
-       if ( (result == noErr) || (result == fnfErr) )
-       {
-               result = FSpGetFullPath(&spec, fullPathLength, fullPath);
-       }
-       
-       return ( result );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpGetFullPath(const FSSpec *spec,
-                                                          short *fullPathLength,
-                                                          Handle *fullPath)
-{
-       OSErr           result;
-       OSErr           realResult;
-       FSSpec          tempSpec;
-       CInfoPBRec      pb;
-       
-       *fullPathLength = 0;
-       *fullPath = NULL;
-       
-       
-       /* Default to noErr */
-       realResult = result = noErr;
-       
-       /* work around Nav Services "bug" (it returns invalid FSSpecs with empty names) */
-       if ( spec->name[0] == 0 )
-       {
-               result = FSMakeFSSpecCompat(spec->vRefNum, spec->parID, spec->name, &tempSpec);
-       }
-       else
-       {
-               /* Make a copy of the input FSSpec that can be modified */
-               BlockMoveData(spec, &tempSpec, sizeof(FSSpec));
-       }
-       
-       if ( result == noErr )
-       {
-               if ( tempSpec.parID == fsRtParID )
-               {
-                       /* The object is a volume */
-                       
-                       /* Add a colon to make it a full pathname */
-                       ++tempSpec.name[0];
-                       tempSpec.name[tempSpec.name[0]] = ':';
-                       
-                       /* We're done */
-                       result = PtrToHand(&tempSpec.name[1], fullPath, tempSpec.name[0]);
-               }
-               else
-               {
-                       /* The object isn't a volume */
-                       
-                       /* Is the object a file or a directory? */
-                       pb.dirInfo.ioNamePtr = tempSpec.name;
-                       pb.dirInfo.ioVRefNum = tempSpec.vRefNum;
-                       pb.dirInfo.ioDrDirID = tempSpec.parID;
-                       pb.dirInfo.ioFDirIndex = 0;
-                       result = PBGetCatInfoSync(&pb);
-                       // Allow file/directory name at end of path to not exist.
-                       realResult = result;
-                       if ( (result == noErr) || (result == fnfErr) )
-                       {
-                               /* if the object is a directory, append a colon so full pathname ends with colon */
-                               if ( (result == noErr) && (pb.hFileInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-                               {
-                                       ++tempSpec.name[0];
-                                       tempSpec.name[tempSpec.name[0]] = ':';
-                               }
-                               
-                               /* Put the object name in first */
-                               result = PtrToHand(&tempSpec.name[1], fullPath, tempSpec.name[0]);
-                               if ( result == noErr )
-                               {
-                                       /* Get the ancestor directory names */
-                                       pb.dirInfo.ioNamePtr = tempSpec.name;
-                                       pb.dirInfo.ioVRefNum = tempSpec.vRefNum;
-                                       pb.dirInfo.ioDrParID = tempSpec.parID;
-                                       do      /* loop until we have an error or find the root directory */
-                                       {
-                                               pb.dirInfo.ioFDirIndex = -1;
-                                               pb.dirInfo.ioDrDirID = pb.dirInfo.ioDrParID;
-                                               result = PBGetCatInfoSync(&pb);
-                                               if ( result == noErr )
-                                               {
-                                                       /* Append colon to directory name */
-                                                       ++tempSpec.name[0];
-                                                       tempSpec.name[tempSpec.name[0]] = ':';
-                                                       
-                                                       /* Add directory name to beginning of fullPath */
-                                                       (void) Munger(*fullPath, 0, NULL, 0, &tempSpec.name[1], tempSpec.name[0]);
-                                                       result = MemError();
-                                               }
-                                       } while ( (result == noErr) && (pb.dirInfo.ioDrDirID != fsRtDirID) );
-                               }
-                       }
-               }
-       }
-       
-       if ( result == noErr )
-       {
-               /* Return the length */
-               *fullPathLength = GetHandleSize(*fullPath);
-               result = realResult;    // return realResult in case it was fnfErr
-       }
-       else
-       {
-               /* Dispose of the handle and return NULL and zero length */
-               if ( *fullPath != NULL )
-               {
-                       DisposeHandle(*fullPath);
-               }
-               *fullPath = NULL;
-               *fullPathLength = 0;
-       }
-       
-       return ( result );
-}
-
-/*****************************************************************************/
-
-pascal OSErr FSpLocationFromFullPath(short fullPathLength,
-                                                                        const void *fullPath,
-                                                                        FSSpec *spec)
-{
-       AliasHandle     alias;
-       OSErr           result;
-       Boolean         wasChanged;
-       Str32           nullString;
-       
-       /* Create a minimal alias from the full pathname */
-       nullString[0] = 0;      /* null string to indicate no zone or server name */
-       result = NewAliasMinimalFromFullPath(fullPathLength, fullPath, nullString, nullString, &alias);
-       if ( result == noErr )
-       {
-               /* Let the Alias Manager resolve the alias. */
-               result = ResolveAlias(NULL, alias, spec, &wasChanged);
-               
-               /* work around Alias Mgr sloppy volume matching bug */
-               if ( spec->vRefNum == 0 )
-               {
-                       /* invalidate wrong FSSpec */
-                       spec->parID = 0;
-                       spec->name[0] =  0;
-                       result = nsvErr;
-               }
-               DisposeHandle((Handle)alias);   /* Free up memory used */
-       }
-       return ( result );
-}
-
-/*****************************************************************************/
-
-pascal OSErr LocationFromFullPath(short fullPathLength,
-                                                                 const void *fullPath,
-                                                                 short *vRefNum,
-                                                                 long *parID,
-                                                                 Str31 name)
-{
-       OSErr   result;
-       FSSpec  spec;
-       
-       result = FSpLocationFromFullPath(fullPathLength, fullPath, &spec);
-       if ( result == noErr )
-       {
-               *vRefNum = spec.vRefNum;
-               *parID = spec.parID;
-               BlockMoveData(&spec.name[0], &name[0], spec.name[0] + 1);
-       }
-       return ( result );
-}
-
-/*****************************************************************************/
-
diff --git a/src/mac/morefile/FullPath.h b/src/mac/morefile/FullPath.h
deleted file mode 100644 (file)
index e1710c1..0000000
+++ /dev/null
@@ -1,311 +0,0 @@
-/*
-     File:       FullPath.h
-     Contains:   Routines for dealing with full pathnames... if you really must.
-     Version:    Technology: MoreFiles
-                 Release:    1.5.2
-     Copyright:  © 1995-2001 by Apple Computer, Inc., all rights reserved.
-     Bugs?:      For bug reports, consult the following page on
-                 the World Wide Web:
-                     http://developer.apple.com/bugreporter/
-*/
-
-/*
-    You may incorporate this sample code into your applications without
-    restriction, though the sample code has been provided "AS IS" and the
-    responsibility for its operation is 100% yours.  However, what you are
-    not permitted to do is to redistribute the source as "DSC Sample Code"
-    after having made changes. If you're going to re-distribute the source,
-    we require that you make it clear in the source that the code was
-    descended from Apple Sample Code, but that you've made changes.
-*/
-
-/*
-    IMPORTANT NOTE:
-    
-    The use of full pathnames is strongly discouraged. Full pathnames are
-    particularly unreliable as a means of identifying files, directories
-    or volumes within your application, for two primary reasons:
-    
-    ¥   The user can change the name of any element in the path at
-        virtually any time.
-    ¥   Volume names on the Macintosh are *not* unique. Multiple
-        mounted volumes can have the same name. For this reason, the use of
-        a full pathname to identify a specific volume may not produce the
-        results you expect. If more than one volume has the same name and
-        a full pathname is used, the File Manager currently uses the first
-        mounted volume it finds with a matching name in the volume queue.
-    
-    In general, you should use a fileÕs name, parent directory ID, and
-    volume reference number to identify a file you want to open, delete,
-    or otherwise manipulate.
-    
-    If you need to remember the location of a particular file across
-    subsequent system boots, use the Alias Manager to create an alias
-    record describing the file. If the Alias Manager is not available, you
-    can save the fileÕs name, its parent directory ID, and the name of the
-    volume on which itÕs located. Although none of these methods is
-    foolproof, they are much more reliable than using full pathnames to
-    identify files.
-    
-    Nonetheless, it is sometimes useful to display a fileÕs full pathname
-    to the user. For example, a backup utility might display a list of full
-    pathnames of files as it copies them onto the backup medium. Or, a
-    utility might want to display a dialog box showing the full pathname of
-    a file when it needs the userÕs confirmation to delete the file. No
-    matter how unreliable full pathnames may be from a file-specification
-    viewpoint, users understand them more readily than volume reference
-    numbers or directory IDs. (Hint: Use the TruncString function from
-    TextUtils.h with truncMiddle as the truncWhere argument to shorten
-    full pathnames to a displayable length.)
-    
-    The following technique for constructing the full pathname of a file is
-    intended for display purposes only. Applications that depend on any
-    particular structure of a full pathname are likely to fail on alternate
-    foreign file systems or under future system software versions.
-*/
-
-#ifndef __FULLPATH__
-#define __FULLPATH__
-
-#ifndef __MACTYPES__
-#include <MacTypes.h>
-#endif
-
-#ifndef __FILES__
-#include <Files.h>
-#endif
-
-#include "Optimization.h"
-
-
-#if PRAGMA_ONCE
-#pragma once
-#endif
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#if PRAGMA_IMPORT
-#pragma import on
-#endif
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=mac68k
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(push, 2)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack(2)
-#endif
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetFullPath(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  short *            fullPathLength,
-  Handle *           fullPath);
-
-
-/*
-    The GetFullPath function builds a full pathname to the specified
-    object. The full pathname is returned in the newly created handle
-    fullPath and the length of the full pathname is returned in
-    fullPathLength. Your program is responsible for disposing of the
-    fullPath handle.
-    
-    Note that a full pathname can be made to a file/directory that does not
-    yet exist if all directories up to that file/directory exist. In this case,
-    GetFullPath will return a fnfErr.
-    
-    vRefNum         input:  Volume specification.
-    dirID           input:  Directory ID.
-    name            input:  Pointer to object name, or nil when dirID
-                            specifies a directory that's the object.
-    fullPathLength  output: The number of characters in the full pathname.
-                            If the function fails to create a full
-                            pathname, it sets fullPathLength to 0.
-    fullPath        output: A handle to the newly created full pathname
-                            buffer. If the function fails to create a
-                            full pathname, it sets fullPath to NULL.
-    
-    Result Codes
-        noErr               0       No error    
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File or directory does not exist (fullPath
-                                    and fullPathLength are still valid)
-        paramErr            -50     No default volume
-        memFullErr          -108    Not enough memory
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   FSpGetFullPath
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpGetFullPath(
-  const FSSpec *  spec,
-  short *         fullPathLength,
-  Handle *        fullPath);
-
-
-/*
-    The GetFullPath function builds a full pathname to the specified
-    object. The full pathname is returned in the newly created handle
-    fullPath and the length of the full pathname is returned in
-    fullPathLength. Your program is responsible for disposing of the
-    fullPath handle.
-    
-    Note that a full pathname can be made to a file/directory that does not
-    yet exist if all directories up to that file/directory exist. In this case,
-    FSpGetFullPath will return a fnfErr.
-    
-    IMPORTANT: The definition of a FSSpec is a volume reference number (not a
-    drive number, working directory number, or 0), a parent directory ID (not 0),
-    and the name of a file or folder (not an empty name, a full pathname, or
-    a partial pathname containing one or more colon (:) characters).
-    FSpGetFullPath assumes it is getting a FSSpec that matches the rules.
-    If you have an FSSpec record that wasn't created by FSMakeFSSpec (or
-    FSMakeFSSpecCompat from FSpCompat in MoreFiles which correctly builds
-    FSSpecs), you should call GetFullPath instead of FSpGetFullPath.
-    
-    spec            input:  An FSSpec record specifying the object.
-    fullPathLength  output: The number of characters in the full pathname.
-                            If the function fails to create a full pathname,
-                            it sets fullPathLength to 0.
-    fullPath        output: A handle to the newly created full pathname
-                            buffer. If the function fails to create a
-                            full pathname, it sets fullPath to NULL.
-    
-    Result Codes
-        noErr               0       No error    
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File or directory does not exist (fullPath
-                                    and fullPathLength are still valid)
-        paramErr            -50     No default volume
-        memFullErr          -108    Not enough memory
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   GetFullPath
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpLocationFromFullPath(
-  short         fullPathLength,
-  const void *  fullPath,
-  FSSpec *      spec);
-
-
-/*
-    The FSpLocationFromFullPath function returns a FSSpec to the object
-    specified by full pathname. This function requires the Alias Manager.
-    
-    fullPathLength  input:  The number of characters in the full pathname
-                            of the target.
-    fullPath        input:  A pointer to a buffer that contains the full
-                            pathname of the target. The full pathname
-                            starts with the name of the volume, includes
-                            all of the directory names in the path to the
-                            target, and ends with the target name.
-    spec            output: An FSSpec record specifying the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     The volume is not mounted
-        fnfErr              -43     Target not found, but volume and parent
-                                    directory found
-        paramErr            -50     Parameter error
-        usrCanceledErr      -128    The user canceled the operation
-    
-    __________
-    
-    See also:   LocationFromFullPath
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-LocationFromFullPath(
-  short         fullPathLength,
-  const void *  fullPath,
-  short *       vRefNum,
-  long *        parID,
-  Str31         name);
-
-
-/*
-    The LocationFromFullPath function returns the volume reference number,
-    parent directory ID and name of the object specified by full pathname.
-    This function requires the Alias Manager.
-    
-    fullPathLength  input:  The number of characters in the full pathname
-                            of the target.
-    fullPath        input:  A pointer to a buffer that contains the full
-                            pathname of the target. The full pathname starts
-                            with the name of the volume, includes all of
-                            the directory names in the path to the target,
-                            and ends with the target name.
-    vRefNum         output: The volume reference number.
-    parID           output: The parent directory ID of the specified object.
-    name            output: The name of the specified object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     The volume is not mounted
-        fnfErr              -43     Target not found, but volume and parent
-                                    directory found
-        paramErr            -50     Parameter error
-        usrCanceledErr      -128    The user canceled the operation
-    
-    __________
-    
-    See also:   FSpLocationFromFullPath
-*/
-
-/*****************************************************************************/
-
-#include "OptimizationEnd.h"
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=reset
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(pop)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack()
-#endif
-
-#ifdef PRAGMA_IMPORT_OFF
-#pragma import off
-#elif PRAGMA_IMPORT
-#pragma import reset
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* __FULLPATH__ */
-
diff --git a/src/mac/morefile/IterateDirectory.c b/src/mac/morefile/IterateDirectory.c
deleted file mode 100644 (file)
index e748829..0000000
+++ /dev/null
@@ -1,207 +0,0 @@
-/*
-       File:           IterateDirectory.c
-
-       Contains:       File Manager directory iterator routines.
-
-       Version:        MoreFiles
-
-       Copyright:      © 1995-2001 by Jim Luther and Apple Computer, Inc., all rights reserved.
-
-       You may incorporate this sample code into your applications without
-       restriction, though the sample code has been provided "AS IS" and the
-       responsibility for its operation is 100% yours.  However, what you are
-       not permitted to do is to redistribute the source as "DSC Sample Code"
-       after having made changes. If you're going to re-distribute the source,
-       we require that you make it clear in the source that the code was
-       descended from Apple Sample Code, but that you've made changes.
-
-       File Ownership:
-
-               DRI:                            Apple Macintosh Developer Technical Support
-
-               Other Contact:          Apple Macintosh Developer Technical Support
-                                                       <http://developer.apple.com/bugreporter/>
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-
-       Change History (most recent first):
-
-                <2>      2/7/01        JL              Added standard header. Updated names of includes.
-               <1>             12/06/99        JL              MoreFiles 1.5.
-*/
-
-#include <MacTypes.h>
-#include <MacErrors.h>
-#include <Files.h>
-
-#define        __COMPILINGMOREFILES
-
-#include "MoreFilesExtras.h"
-#include "IterateDirectory.h"
-
-/*
-**     Type definitions
-*/
-
-/* The IterateGlobals structure is used to minimize the amount of
-** stack space used when recursively calling IterateDirectoryLevel
-** and to hold global information that might be needed at any time.
-*/
-#if PRAGMA_STRUCT_ALIGN
-#pragma options align=mac68k
-#endif
-struct IterateGlobals
-{
-       IterateFilterProcPtr    iterateFilter;  /* pointer to IterateFilterProc */
-       CInfoPBRec                              cPB;                    /* the parameter block used for PBGetCatInfo calls */
-       Str63                                   itemName;               /* the name of the current item */
-       OSErr                                   result;                 /* temporary holder of results - saves 2 bytes of stack each level */
-       Boolean                                 quitFlag;               /* set to true if filter wants to kill interation */
-       unsigned short                  maxLevels;              /* Maximum levels to iterate through */
-       unsigned short                  currentLevel;   /* The current level IterateLevel is on */
-       void                                    *yourDataPtr;   /* A pointer to caller data the filter may need to access */
-};
-#if PRAGMA_STRUCT_ALIGN
-#pragma options align=reset
-#endif
-
-typedef struct IterateGlobals IterateGlobals;
-typedef IterateGlobals *IterateGlobalsPtr;
-
-/*****************************************************************************/
-
-/*     Static Prototype */
-
-static void    IterateDirectoryLevel(long dirID,
-                                                                         IterateGlobals *theGlobals);
-
-/*****************************************************************************/
-
-/*
-**     Functions
-*/
-
-static void    IterateDirectoryLevel(long dirID,
-                                                                         IterateGlobals *theGlobals)
-{
-       if ( (theGlobals->maxLevels == 0) ||                                            /* if maxLevels is zero, we aren't checking levels */
-                (theGlobals->currentLevel < theGlobals->maxLevels) )   /* if currentLevel < maxLevels, look at this level */
-       {
-               short index = 1;
-               
-               ++theGlobals->currentLevel;     /* go to next level */
-               
-               do
-               {       /* Isn't C great... What I'd give for a "WITH theGlobals DO" about now... */
-               
-                       /* Get next source item at the current directory level */
-                       
-                       theGlobals->cPB.dirInfo.ioFDirIndex = index;
-                       theGlobals->cPB.dirInfo.ioDrDirID = dirID;
-                       theGlobals->result = PBGetCatInfoSync((CInfoPBPtr)&theGlobals->cPB);            
-       
-                       if ( theGlobals->result == noErr )
-                       {
-                               /* Call the IterateFilterProc */
-                               CallIterateFilterProc(theGlobals->iterateFilter, &theGlobals->cPB, &theGlobals->quitFlag, theGlobals->yourDataPtr);
-                               
-                               /* Is it a directory? */
-                               if ( (theGlobals->cPB.hFileInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-                               {
-                                       /* We have a directory */
-                                       if ( !theGlobals->quitFlag )
-                                       {
-                                               /* Dive again if the IterateFilterProc didn't say "quit" */
-                                               IterateDirectoryLevel(theGlobals->cPB.dirInfo.ioDrDirID, theGlobals);
-                                       }
-                               }
-                       }
-                       
-                       ++index; /* prepare to get next item */
-               } while ( (theGlobals->result == noErr) && (!theGlobals->quitFlag) ); /* time to fall back a level? */
-               
-               if ( (theGlobals->result == fnfErr) ||  /* fnfErr is OK - it only means we hit the end of this level */
-                        (theGlobals->result == afpAccessDenied) ) /* afpAccessDenied is OK, too - it only means we cannot see inside a directory */
-               {
-                       theGlobals->result = noErr;
-               }
-                       
-               --theGlobals->currentLevel;     /* return to previous level as we leave */
-       }
-}
-
-/*****************************************************************************/
-
-pascal OSErr   IterateDirectory(short vRefNum,
-                                                                long dirID,
-                                                                ConstStr255Param name,
-                                                                unsigned short maxLevels,
-                                                                IterateFilterProcPtr iterateFilter,
-                                                                void *yourDataPtr)
-{
-       IterateGlobals  theGlobals;
-       OSErr                   result;
-       long                    theDirID;
-       short                   theVRefNum;
-       Boolean                 isDirectory;
-       
-       /* Make sure there is a IterateFilter */
-       if ( iterateFilter != NULL )
-       {
-               /* Get the real directory ID and make sure it is a directory */
-               result = GetDirectoryID(vRefNum, dirID, name, &theDirID, &isDirectory);
-               if ( result == noErr )
-               {
-                       if ( isDirectory == true )
-                       {
-                               /* Get the real vRefNum */
-                               result = DetermineVRefNum(name, vRefNum, &theVRefNum);
-                               if ( result == noErr )
-                               {
-                                       /* Set up the globals we need to access from the recursive routine. */
-                                       theGlobals.iterateFilter = iterateFilter;
-                                       theGlobals.cPB.hFileInfo.ioNamePtr = (StringPtr)&theGlobals.itemName;
-                                       theGlobals.cPB.hFileInfo.ioVRefNum = theVRefNum;
-                                       theGlobals.itemName[0] = 0;
-                                       theGlobals.result = noErr;
-                                       theGlobals.quitFlag = false;
-                                       theGlobals.maxLevels = maxLevels;
-                                       theGlobals.currentLevel = 0;    /* start at level 0 */
-                                       theGlobals.yourDataPtr = yourDataPtr;
-                               
-                                       /* Here we go into recursion land... */
-                                       IterateDirectoryLevel(theDirID, &theGlobals);
-                                       
-                                       result = theGlobals.result;     /* set the result */
-                               }
-                       }
-                       else
-                       {
-                               result = dirNFErr;      /* a file was passed instead of a directory */
-                       }
-               }
-       }
-       else
-       {
-               result = paramErr;      /* iterateFilter was NULL */
-       }
-       
-       return ( result );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpIterateDirectory(const FSSpec *spec,
-                                                                       unsigned short maxLevels,
-                                                                       IterateFilterProcPtr iterateFilter,
-                                                                       void *yourDataPtr)
-{
-       return ( IterateDirectory(spec->vRefNum, spec->parID, spec->name,
-                                               maxLevels, iterateFilter, yourDataPtr) );
-}
-
-/*****************************************************************************/
diff --git a/src/mac/morefile/IterateDirectory.h b/src/mac/morefile/IterateDirectory.h
deleted file mode 100644 (file)
index ef6b113..0000000
+++ /dev/null
@@ -1,222 +0,0 @@
-/*
-     File:       IterateDirectory.h
-     Contains:   File Manager directory iterator routines.
-     Version:    Technology: MoreFiles
-                 Release:    1.5.2
-     Copyright:  © 1995-2001 by Jim Luther and Apple Computer, Inc., all rights reserved.
-     Bugs?:      For bug reports, consult the following page on
-                 the World Wide Web:
-                     http://developer.apple.com/bugreporter/
-*/
-
-/*
-    You may incorporate this sample code into your applications without
-    restriction, though the sample code has been provided "AS IS" and the
-    responsibility for its operation is 100% yours.  However, what you are
-    not permitted to do is to redistribute the source as "DSC Sample Code"
-    after having made changes. If you're going to re-distribute the source,
-    we require that you make it clear in the source that the code was
-    descended from Apple Sample Code, but that you've made changes.
-*/
-
-#ifndef __ITERATEDIRECTORY__
-#define __ITERATEDIRECTORY__
-
-#ifndef __MACTYPES__
-#include <MacTypes.h>
-#endif
-
-#ifndef __FILES__
-#include <Files.h>
-#endif
-
-#include "Optimization.h"
-
-
-#if PRAGMA_ONCE
-#pragma once
-#endif
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#if PRAGMA_IMPORT
-#pragma import on
-#endif
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=mac68k
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(push, 2)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack(2)
-#endif
-
-/*****************************************************************************/
-
-typedef CALLBACK_API( void , IterateFilterProcPtr )(const CInfoPBRec *cpbPtr, Boolean *quitFlag, void *yourDataPtr);
-/*
-    This is the prototype for the IterateFilterProc function which is
-    called once for each file and directory found by IterateDirectory. The
-    IterateFilterProc gets a pointer to the CInfoPBRec that IterateDirectory
-    used to call PBGetCatInfo. The IterateFilterProc can use the read-only
-    data in the CInfoPBRec for whatever it wants.
-    
-    If the IterateFilterProc wants to stop IterateDirectory, it can set
-    quitFlag to true (quitFlag will be passed to the IterateFilterProc
-    false).
-    
-    The yourDataPtr parameter can point to whatever data structure you might
-    want to access from within the IterateFilterProc.
-
-    cpbPtr      input:  A pointer to the CInfoPBRec that IterateDirectory
-                        used to call PBGetCatInfo. The CInfoPBRec and the
-                        data it points to must not be changed by your
-                        IterateFilterProc.
-    quitFlag    output: Your IterateFilterProc can set quitFlag to true
-                        if it wants to stop IterateDirectory.
-    yourDataPtr input:  A pointer to whatever data structure you might
-                        want to access from within the IterateFilterProc.
-    
-    __________
-    
-    Also see:   IterateDirectory, FSpIterateDirectory
-*/
-#define CallIterateFilterProc(userRoutine, cpbPtr, quitFlag, yourDataPtr) \
-    (*(userRoutine))((cpbPtr), (quitFlag), (yourDataPtr))
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-IterateDirectory(
-  short                  vRefNum,
-  long                   dirID,
-  ConstStr255Param       name,
-  unsigned short         maxLevels,
-  IterateFilterProcPtr   iterateFilter,
-  void *                 yourDataPtr);
-
-
-/*
-    The IterateDirectory function performs a recursive iteration (scan) of
-    the specified directory and calls your IterateFilterProc function once
-    for each file and directory found.
-    
-    The maxLevels parameter lets you control how deep the recursion goes.
-    If maxLevels is 1, IterateDirectory only scans the specified directory;
-    if maxLevels is 2, IterateDirectory scans the specified directory and
-    one subdirectory below the specified directory; etc. Set maxLevels to
-    zero to scan all levels.
-    
-    The yourDataPtr parameter can point to whatever data structure you might
-    want to access from within the IterateFilterProc.
-
-    vRefNum         input:  Volume specification.
-    dirID           input:  Directory ID.
-    name            input:  Pointer to object name, or nil when dirID
-                            specifies a directory that's the object.
-    maxLevels       input:  Maximum number of directory levels to scan or
-                            zero to scan all directory levels.
-    iterateFilter   input:  A pointer to the routine you want called once
-                            for each file and directory found by
-                            IterateDirectory.
-    yourDataPtr     input:  A pointer to whatever data structure you might
-                            want to access from within the IterateFilterProc.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume or iterateFilter was NULL
-        dirNFErr            -120    Directory not found or incomplete pathname
-                                    or a file was passed instead of a directory
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-        
-    __________
-    
-    See also:   IterateFilterProcPtr, FSpIterateDirectory
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpIterateDirectory(
-  const FSSpec *         spec,
-  unsigned short         maxLevels,
-  IterateFilterProcPtr   iterateFilter,
-  void *                 yourDataPtr);
-
-
-/*
-    The FSpIterateDirectory function performs a recursive iteration (scan)
-    of the specified directory and calls your IterateFilterProc function once
-    for each file and directory found.
-    
-    The maxLevels parameter lets you control how deep the recursion goes.
-    If maxLevels is 1, FSpIterateDirectory only scans the specified directory;
-    if maxLevels is 2, FSpIterateDirectory scans the specified directory and
-    one subdirectory below the specified directory; etc. Set maxLevels to
-    zero to scan all levels.
-    
-    The yourDataPtr parameter can point to whatever data structure you might
-    want to access from within the IterateFilterProc.
-
-    spec            input:  An FSSpec record specifying the directory to scan.
-    maxLevels       input:  Maximum number of directory levels to scan or
-                            zero to scan all directory levels.
-    iterateFilter   input:  A pointer to the routine you want called once
-                            for each file and directory found by
-                            FSpIterateDirectory.
-    yourDataPtr     input:  A pointer to whatever data structure you might
-                            want to access from within the IterateFilterProc.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume or iterateFilter was NULL
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-        
-    __________
-    
-    See also:   IterateFilterProcPtr, IterateDirectory
-*/
-
-/*****************************************************************************/
-
-#include "OptimizationEnd.h"
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=reset
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(pop)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack()
-#endif
-
-#ifdef PRAGMA_IMPORT_OFF
-#pragma import off
-#elif PRAGMA_IMPORT
-#pragma import reset
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* __ITERATEDIRECTORY__ */
-
diff --git a/src/mac/morefile/MoreDesktopMgr.c b/src/mac/morefile/MoreDesktopMgr.c
deleted file mode 100644 (file)
index 880ed26..0000000
+++ /dev/null
@@ -1,1270 +0,0 @@
-/*
-       File:           MoreDesktopMgr.c
-
-       Contains:       A collection of useful high-level Desktop Manager routines.
-                               If the Desktop Manager is not available, use the Desktop file
-                               for 'read' operations.
-
-       Version:        MoreFiles
-
-       Copyright:      © 1992-2001 by Apple Computer, Inc., all rights reserved.
-
-       You may incorporate this sample code into your applications without
-       restriction, though the sample code has been provided "AS IS" and the
-       responsibility for its operation is 100% yours.  However, what you are
-       not permitted to do is to redistribute the source as "DSC Sample Code"
-       after having made changes. If you're going to re-distribute the source,
-       we require that you make it clear in the source that the code was
-       descended from Apple Sample Code, but that you've made changes.
-
-       File Ownership:
-
-               DRI:                            Apple Macintosh Developer Technical Support
-
-               Other Contact:          Apple Macintosh Developer Technical Support
-                                                       <http://developer.apple.com/bugreporter/>
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-               (NG)    Nitin Ganatra
-
-       Change History (most recent first):
-
-                <2>      2/7/01        JL              Added standard header. Updated names of includes. Updated
-                                                                       various routines to use new calling convention of the
-                                                                       MoreFilesExtras accessor functions.
-               <1>             12/06/99        JL              MoreFiles 1.5.
-*/
-
-#include <MacTypes.h>
-#include <MacErrors.h>
-#include <MacMemory.h>
-#include <Files.h>
-#include <Resources.h>
-#include <Icons.h>
-
-#define        __COMPILINGMOREFILES
-
-#include "MoreFiles.h"
-#include "MoreFilesExtras.h"
-#include "Search.h"
-#include "MoreDesktopMgr.h"
-
-/*****************************************************************************/
-
-/*     Desktop file notes:
-**
-**     ¥       The Desktop file is owned by the Finder and is normally open by the
-**             Finder. That means that we only have read-only access to the Desktop
-**             file.
-**     ¥       Since the Resource Manager doesn't support shared access to resource
-**             files and we're using read-only access, we don't ever leave the
-**             Desktop file open.  We open a path to it, get the data we want out
-**             of it, and then close the open path. This is the only safe way to
-**             open a resource file with read-only access since some other program
-**             could have it open with write access.
-**     ¥       The bundle related resources in the Desktop file are normally
-**             purgable, so when we're looking through them, we don't bother to
-**             release resources we're done looking at - closing the resource file
-**             (which we always do) will release them.
-**     ¥       Since we can't assume the Desktop file is named "Desktop"
-**             (it probably is everywhere but France), we get the Desktop
-**             file's name by searching the volume's root directory for a file
-**             with fileType == 'FNDR' and creator == 'ERIK'. The only problem with
-**             this scheme is that someone could create another file with that type
-**             and creator in the root directory and we'd find the wrong file.
-**             The chances of this are very slim.
-*/
-
-/*****************************************************************************/
-
-/* local defines */
-
-enum
-{
-       kBNDLResType    = 'BNDL',
-       kFREFResType    = 'FREF',
-       kIconFamResType = 'ICN#',
-       kFCMTResType    = 'FCMT',
-       kAPPLResType    = 'APPL'
-};
-
-/*****************************************************************************/
-
-/* local data structures */
-
-#if PRAGMA_STRUCT_ALIGN
-#pragma options align=mac68k
-#endif
-
-struct IDRec
-{
-       short           localID;
-       short           rsrcID;
-};
-typedef struct IDRec IDRec;
-typedef        IDRec *IDRecPtr;
-
-struct BundleType
-{
-       OSType          type;                   /* 'ICN#' or 'FREF' */
-       short           count;                  /* number of IDRecs - 1 */
-       IDRec           idArray[1];
-};
-typedef struct BundleType BundleType;
-typedef BundleType *BundleTypePtr;
-
-struct BNDLRec
-{
-       OSType          signature;              /* creator type signature */
-       short           versionID;              /* version - should always be 0 */
-       short           numTypes;               /* number of elements in typeArray - 1 */
-       BundleType      typeArray[1];
-};
-typedef struct BNDLRec BNDLRec;
-typedef BNDLRec **BNDLRecHandle;
-
-struct FREFRec
-{
-       OSType          fileType;               /* file type */
-       short           iconID;                 /* icon local ID */
-       Str255          fileName;               /* file name */
-};
-typedef struct FREFRec FREFRec;
-typedef FREFRec **FREFRecHandle;
-
-struct APPLRec
-{
-       OSType          creator;                /* creator type signature */
-       long            parID;                  /* parent directory ID */
-       Str255          applName;               /* application name */
-};
-typedef struct APPLRec APPLRec;
-typedef APPLRec *APPLRecPtr;
-
-#if PRAGMA_STRUCT_ALIGN
-#pragma options align=reset
-#endif
-
-/*****************************************************************************/
-
-/* static prototypes */
-
-static OSErr   GetDesktopFileName(short vRefNum,
-                                                                  Str255 desktopName);
-
-static OSErr   GetAPPLFromDesktopFile(ConstStr255Param volName,
-                                                                          short vRefNum,
-                                                                          OSType creator,
-                                                                          short *applVRefNum,
-                                                                          long *applParID,
-                                                                          Str255 applName);
-
-static OSErr   FindBundleGivenCreator(OSType creator,
-                                                                          BNDLRecHandle *returnBndl);
-                                                                          
-static OSErr   FindTypeInBundle(OSType typeToFind,
-                                                                BNDLRecHandle theBndl,
-                                                                BundleTypePtr *returnBundleType);
-                                                                                
-static OSErr   GetLocalIDFromFREF(BundleTypePtr theBundleType,
-                                                                  OSType fileType,
-                                                                  short *iconLocalID);
-
-static OSErr   GetIconRsrcIDFromLocalID(BundleTypePtr theBundleType,
-                                                                                short iconLocalID,
-                                                                                short *iconRsrcID);
-
-static OSType  DTIconToResIcon(short iconType);
-
-static OSErr   GetIconFromDesktopFile(ConstStr255Param volName,
-                                                                          short vRefNum,
-                                                                          short iconType,
-                                                                          OSType fileCreator,
-                                                                          OSType fileType,
-                                                                          Handle *iconHandle);
-
-static OSErr   GetCommentID(short vRefNum,
-                                                        long dirID,
-                                                        ConstStr255Param name,
-                                                        short *commentID);
-
-static OSErr   GetCommentFromDesktopFile(short vRefNum,
-                                                                                 long dirID,
-                                                                                 ConstStr255Param name,
-                                                                                 Str255 comment);
-
-/*****************************************************************************/
-
-/*
-**     GetDesktopFileName
-**
-**     Get the name of the Desktop file.
-*/
-static OSErr   GetDesktopFileName(short vRefNum,
-                                                                  Str255 desktopName)
-{
-       OSErr                   error;
-       HParamBlockRec  pb;
-       short                   index;
-       Boolean                 found;
-       
-       pb.fileParam.ioNamePtr = desktopName;
-       pb.fileParam.ioVRefNum = vRefNum;
-       pb.fileParam.ioFVersNum = 0;
-       index = 1;
-       found = false;
-       do
-       {
-               pb.fileParam.ioDirID = fsRtDirID;
-               pb.fileParam.ioFDirIndex = index;
-               error = PBHGetFInfoSync(&pb);
-               if ( error == noErr )
-               {
-                       if ( (pb.fileParam.ioFlFndrInfo.fdType == 'FNDR') &&
-                                (pb.fileParam.ioFlFndrInfo.fdCreator == 'ERIK') )
-                       {
-                               found = true;
-                       }
-               }
-               ++index;
-       } while ( (error == noErr) && !found );
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   DTOpen(ConstStr255Param volName,
-                                          short vRefNum,
-                                          short *dtRefNum,
-                                          Boolean *newDTDatabase)
-{
-       OSErr error;
-       GetVolParmsInfoBuffer volParmsInfo;
-       long infoSize;
-       DTPBRec pb;
-       
-       /* Check for volume Desktop Manager support before calling */
-       infoSize = sizeof(GetVolParmsInfoBuffer);
-       error = HGetVolParms(volName, vRefNum, &volParmsInfo, &infoSize);
-       if ( error == noErr )
-       {
-               if ( hasDesktopMgr(&volParmsInfo) )
-               {
-                       pb.ioNamePtr = (StringPtr)volName;
-                       pb.ioVRefNum = vRefNum;
-                       error = PBDTOpenInform(&pb);
-                       /* PBDTOpenInform informs us if the desktop was just created */
-                       /* by leaving the low bit of ioTagInfo clear (0) */
-                       *newDTDatabase = ((pb.ioTagInfo & 1L) == 0);
-                       if ( error == paramErr )
-                       {
-                               error = PBDTGetPath(&pb);
-                               /* PBDTGetPath doesn't tell us if the database is new */
-                               /* so assume it is not new */
-                               *newDTDatabase = false;
-                       }
-                       *dtRefNum = pb.ioDTRefNum;
-               }
-               else
-               {
-                       error = paramErr;
-               }
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-/*
-**     GetAPPLFromDesktopFile
-**
-**     Get a application's location from the
-**     Desktop file's 'APPL' resources.
-*/
-static OSErr   GetAPPLFromDesktopFile(ConstStr255Param volName,
-                                                                          short vRefNum,
-                                                                          OSType creator,
-                                                                          short *applVRefNum,
-                                                                          long *applParID,
-                                                                          Str255 applName)
-{
-       OSErr error;
-       short realVRefNum;
-       Str255 desktopName;
-       short savedResFile;
-       short dfRefNum;
-       Handle applResHandle;
-       Boolean foundCreator;
-       Ptr applPtr;
-       long applSize;
-       
-       error = DetermineVRefNum(volName, vRefNum, &realVRefNum);
-       if ( error == noErr )
-       {
-               error = GetDesktopFileName(realVRefNum, desktopName);
-               if ( error == noErr )
-               {
-                       savedResFile = CurResFile();
-                       /*
-                       **      Open the 'Desktop' file in the root directory. (because
-                       **      opening the resource file could preload unwanted resources,
-                       **      bracket the call with SetResLoad(s))
-                       */
-                       SetResLoad(false);
-                       dfRefNum = HOpenResFile(realVRefNum, fsRtDirID, desktopName, fsRdPerm);
-                       SetResLoad(true);
-                       
-                       if ( dfRefNum != -1)
-                       {
-                               /* Get 'APPL' resource ID 0 */
-                               applResHandle = Get1Resource(kAPPLResType, 0);
-                               if ( applResHandle != NULL )
-                               {
-                                       applSize = GetHandleSize((Handle)applResHandle);
-                                       if ( applSize != 0 )    /* make sure the APPL resource isn't empty */
-                                       {
-                                               foundCreator = false;
-                                               applPtr = *applResHandle;
-                                               
-                                               /* APPL's don't have a count so I have to use the size as the bounds */
-                                               while ( (foundCreator == false) &&
-                                                               (applPtr < (*applResHandle + applSize)) )
-                                               {
-                                                       if ( ((APPLRecPtr)applPtr)->creator == creator )
-                                                       {
-                                                               foundCreator = true;
-                                                       }
-                                                       else
-                                                       {
-                                                               /* fun with pointer math... */
-                                                               applPtr += sizeof(OSType) +
-                                                                                  sizeof(long) +
-                                                                                  ((APPLRecPtr)applPtr)->applName[0] + 1;
-                                                               /* application mappings are word aligned within the resource */
-                                                               if ( ((unsigned long)applPtr % 2) != 0 )
-                                                               {
-                                                                       applPtr += 1;
-                                                               }
-                                                       }
-                                               }
-                                               if ( foundCreator == true )
-                                               {
-                                                       *applVRefNum = realVRefNum;
-                                                       *applParID = ((APPLRecPtr)applPtr)->parID;
-                                                       BlockMoveData(((APPLRecPtr)applPtr)->applName,
-                                                                                 applName,
-                                                                                 ((APPLRecPtr)applPtr)->applName[0] + 1);
-                                                       /* error is already noErr */
-                                               }
-                                               else
-                                               {
-                                                       error = afpItemNotFound;        /* didn't find a creator match */
-                                               }
-                                       }
-                                       else
-                                       {
-                                               error = afpItemNotFound;        /* no APPL mapping available */
-                                       }
-                               }
-                               else
-                               {
-                                       error = afpItemNotFound;        /* no APPL mapping available */
-                               }
-                               
-                               /* restore the resource chain and close the Desktop file */
-                               UseResFile(savedResFile);
-                               CloseResFile(dfRefNum);
-                       }
-                       else
-                       {
-                               error = afpItemNotFound;
-                       }
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   DTXGetAPPL(ConstStr255Param volName,
-                                                  short vRefNum,
-                                                  OSType creator,
-                                                  Boolean searchCatalog,
-                                                  short *applVRefNum,
-                                                  long *applParID,
-                                                  Str255 applName)
-{
-       OSErr error;
-       UniversalFMPB pb;
-       short dtRefNum;
-       Boolean newDTDatabase;
-       short realVRefNum;
-       short index;
-       Boolean applFound;
-       FSSpec spec;
-       long actMatchCount;
-       
-       /* get the real vRefNum */
-       error = DetermineVRefNum(volName, vRefNum, &realVRefNum);
-       if ( error == noErr )
-       {
-               error = DTOpen(volName, vRefNum, &dtRefNum, &newDTDatabase);
-               if ( error == noErr )
-               {
-                       if ( !newDTDatabase )
-                       {
-                               index = 0;
-                               applFound = false;
-                               do
-                               {
-                                       pb.dtPB.ioNamePtr = applName;
-                                       pb.dtPB.ioDTRefNum = dtRefNum;
-                                       pb.dtPB.ioIndex = index;
-                                       pb.dtPB.ioFileCreator = creator;
-                                       error = PBDTGetAPPLSync(&pb.dtPB);
-                                       if ( error == noErr )
-                                       {
-                                               /* got a match - see if it is valid */
-                                               
-                                               *applVRefNum = realVRefNum; /* get the vRefNum now */
-                                               *applParID = pb.dtPB.ioAPPLParID; /* get the parent ID now */
-       
-                                               /* pb.hPB.fileParam.ioNamePtr is already set */
-                                               pb.hPB.fileParam.ioVRefNum = realVRefNum;
-                                               pb.hPB.fileParam.ioFVersNum = 0;
-                                               pb.hPB.fileParam.ioDirID = *applParID;
-                                               pb.hPB.fileParam.ioFDirIndex = 0;       /* use ioNamePtr and ioDirID */
-                                               if ( PBHGetFInfoSync(&pb.hPB) == noErr )
-                                               {
-                                                       if ( (pb.hPB.fileParam.ioFlFndrInfo.fdCreator == creator) &&
-                                                                (pb.hPB.fileParam.ioFlFndrInfo.fdType == 'APPL') )
-                                                       {
-                                                               applFound = true;
-                                                       }
-                                               }
-                                       }
-                                       ++index;
-                               } while ( (error == noErr) && !applFound );
-                               if ( error != noErr )
-                               {
-                                       error = afpItemNotFound;
-                               }
-                       }
-                       else
-                       {
-                               /* Desktop database is empty (new), set error to try CatSearch */
-                               error = afpItemNotFound;
-                       }
-               }
-               /* acceptable errors from Desktop Manager to continue are paramErr or afpItemNotFound */
-               if ( error == paramErr )
-               {
-                       /* if paramErr, the volume didn't support the Desktop Manager */
-                       /* try the Desktop file */
-                       
-                       error = GetAPPLFromDesktopFile(volName, vRefNum, creator,
-                                                                                       applVRefNum, applParID, applName);
-                       if ( error == noErr )
-                       {
-                               /* got a match - see if it is valid */
-                               
-                               pb.hPB.fileParam.ioNamePtr = applName;
-                               pb.hPB.fileParam.ioVRefNum = *applVRefNum;
-                               pb.hPB.fileParam.ioFVersNum = 0;
-                               pb.hPB.fileParam.ioDirID = *applParID;
-                               pb.hPB.fileParam.ioFDirIndex = 0;       /* use ioNamePtr and ioDirID */
-                               if ( PBHGetFInfoSync(&pb.hPB) == noErr )
-                               {
-                                       if ( (pb.hPB.fileParam.ioFlFndrInfo.fdCreator != creator) ||
-                                                (pb.hPB.fileParam.ioFlFndrInfo.fdType != 'APPL') )
-                                       {
-                                               error = afpItemNotFound;
-                                       }
-                               }
-                               else if ( error == fnfErr )
-                               {
-                                       error = afpItemNotFound;
-                               }
-                       }
-               }
-               /* acceptable error from DesktopFile code to continue is afpItemNotFound */
-               if ( (error == afpItemNotFound) && searchCatalog)
-               {
-                       /* Couldn't be found in the Desktop file either, */
-                       /* try searching with CatSearch if requested */
-                       
-                       error = CreatorTypeFileSearch(NULL, realVRefNum, creator, kAPPLResType, &spec, 1,
-                                                                                       &actMatchCount, true);
-                       if ( (error == noErr) || (error == eofErr) )
-                       {
-                               if ( actMatchCount > 0 )
-                               {
-                                       *applVRefNum = spec.vRefNum;
-                                       *applParID = spec.parID;
-                                       BlockMoveData(spec.name, applName, spec.name[0] + 1);
-                               }
-                               else
-                               {
-                                       error = afpItemNotFound;
-                               }
-                       }
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpDTXGetAPPL(ConstStr255Param volName,
-                                                         short vRefNum,
-                                                         OSType creator,
-                                                         Boolean searchCatalog,
-                                                         FSSpec *spec)
-{
-       return ( DTXGetAPPL(volName, vRefNum, creator, searchCatalog,
-                                               &(spec->vRefNum), &(spec->parID), spec->name) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   DTGetAPPL(ConstStr255Param volName,
-                                                 short vRefNum,
-                                                 OSType creator,
-                                                 short *applVRefNum,
-                                                 long *applParID,
-                                                 Str255 applName)
-{
-       /* Call DTXGetAPPL with the "searchCatalog" parameter true */ 
-       return ( DTXGetAPPL(volName, vRefNum, creator, true,
-                                               applVRefNum, applParID, applName) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpDTGetAPPL(ConstStr255Param volName,
-                                                        short vRefNum,
-                                                        OSType creator,
-                                                        FSSpec *spec)
-{
-       /* Call DTXGetAPPL with the "searchCatalog" parameter true */ 
-       return ( DTXGetAPPL(volName, vRefNum, creator, true,
-                                               &(spec->vRefNum), &(spec->parID), spec->name) );
-}
-
-/*****************************************************************************/
-
-/*
-**     FindBundleGivenCreator
-**
-**     Search the current resource file for the 'BNDL' resource with the given
-**     creator and return a handle to it.
-*/
-static OSErr   FindBundleGivenCreator(OSType creator,
-                                                                          BNDLRecHandle *returnBndl)
-{
-       OSErr                   error;
-       short                   numOfBundles;
-       short                   index;
-       BNDLRecHandle   theBndl;
-       
-       error = afpItemNotFound;        /* default to not found */
-       
-       /* Search each BNDL resource until we find the one with a matching creator. */
-       
-       numOfBundles = Count1Resources(kBNDLResType);
-       index = 1;
-       *returnBndl = NULL;
-       
-       while ( (index <= numOfBundles) && (*returnBndl == NULL) )
-       {
-               theBndl = (BNDLRecHandle)Get1IndResource(kBNDLResType, index);
-               
-               if ( theBndl != NULL )
-               {
-                       if ( (*theBndl)->signature == creator )
-                       {
-                               /* numTypes and typeArray->count will always be the actual count minus 1, */
-                               /* so 0 in both fields is valid. */
-                               if ( ((*theBndl)->numTypes >= 0) && ((*theBndl)->typeArray->count >= 0) )
-                               {
-                                       /* got it */
-                                       *returnBndl = theBndl;
-                                       error = noErr;
-                               }
-                       }
-               }       
-               
-               index ++;
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-/*
-**     FindTypeInBundle
-**
-**     Given a Handle to a BNDL return a pointer to the desired type
-**     in it. If the type is not found, or if the type's count < 0,
-**     return afpItemNotFound.
-*/
-static OSErr   FindTypeInBundle(OSType typeToFind,
-                                                                BNDLRecHandle theBndl,
-                                                                BundleTypePtr *returnBundleType)
-{
-       OSErr                   error;
-       short                   index;
-       Ptr                             ptrIterator;    /* use a Ptr so we can do ugly pointer math */
-       
-       error = afpItemNotFound;        /* default to not found */
-       
-       ptrIterator = (Ptr)((*theBndl)->typeArray);
-       index = 0;
-       *returnBundleType = NULL;
-
-       while ( (index < ((*theBndl)->numTypes + 1)) &&
-                       (*returnBundleType == NULL) )
-       {
-               if ( (((BundleTypePtr)ptrIterator)->type == typeToFind) &&
-                        (((BundleTypePtr)ptrIterator)->count >= 0) )
-               {
-                               *returnBundleType = (BundleTypePtr)ptrIterator;
-                               error = noErr;
-               }
-               else
-               {
-                       ptrIterator += ( sizeof(OSType) +
-                                                        sizeof(short) +
-                                                        ( sizeof(IDRec) * (((BundleTypePtr)ptrIterator)->count + 1) ) );
-                       ++index;
-               }
-       }
-               
-       return ( error );
-}
-
-/*****************************************************************************/
-
-/*
-**     GetLocalIDFromFREF
-**
-**     Given a pointer to a 'FREF' BundleType record, load each 'FREF' resource
-**     looking for a matching fileType. If a matching fileType is found, return
-**     its icon local ID. If no match is found, return afpItemNotFound as the
-**     function result.
-*/
-static OSErr   GetLocalIDFromFREF(BundleTypePtr theBundleType,
-                                                                  OSType fileType,
-                                                                  short *iconLocalID)
-{
-       OSErr                   error;
-       short                   index;
-       IDRecPtr                idIterator;
-       FREFRecHandle   theFref;
-       
-       error = afpItemNotFound;        /* default to not found */
-       
-       /* For each localID in this type, get the FREF resource looking for fileType */
-       index = 0;
-       idIterator = &theBundleType->idArray[0];
-       *iconLocalID = 0;
-       
-       while ( (index <= theBundleType->count) && (*iconLocalID == 0) )
-       {
-               theFref = (FREFRecHandle)Get1Resource(kFREFResType, idIterator->rsrcID);
-               if ( theFref != NULL )
-               {
-                       if ( (*theFref)->fileType == fileType )
-                       {
-                               *iconLocalID = (*theFref)->iconID;
-                               error = noErr;
-                       }
-               }
-               
-               ++idIterator;
-               ++index;
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-/*
-**     GetIconRsrcIDFromLocalID
-**
-**     Given a pointer to a 'ICN#' BundleType record, look for the IDRec with
-**     the localID that matches iconLocalID. If a matching IDRec is found,
-**     return the IDRec's rsrcID field value. If no match is found, return
-**     afpItemNotFound as the function result.
-*/
-static OSErr   GetIconRsrcIDFromLocalID(BundleTypePtr theBundleType,
-                                                                                short iconLocalID,
-                                                                                short *iconRsrcID)
-{
-       OSErr           error;
-       short           index;
-       IDRecPtr        idIterator;
-       
-       error = afpItemNotFound;        /* default to not found */
-       
-       /* Find the rsrcID of the icon family type, given the localID */
-       index = 0;
-       idIterator = &theBundleType->idArray[0];
-       *iconRsrcID = 0;
-       
-       while ( (index <= theBundleType->count) && (*iconRsrcID == 0) )
-       {
-               if ( idIterator->localID == iconLocalID )
-               {
-                       *iconRsrcID = idIterator->rsrcID;
-                       error = noErr;
-               }
-               
-               idIterator ++;
-               index ++;
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-/*
-**     DTIconToResIcon
-**
-**     Map a Desktop Manager icon type to the corresponding resource type.
-**     Return (OSType)0 if there is no corresponding resource type.
-*/
-static OSType  DTIconToResIcon(short iconType)
-{
-       OSType  resType;
-       
-       switch ( iconType )
-       {
-               case kLargeIcon:
-                       resType = large1BitMask;
-                       break;
-               case kLarge4BitIcon:
-                       resType = large4BitData;
-                       break;
-               case kLarge8BitIcon:
-                       resType = large8BitData;
-                       break;
-               case kSmallIcon:
-                       resType = small1BitMask;
-                       break;
-               case kSmall4BitIcon:
-                       resType = small4BitData;
-                       break;
-               case kSmall8BitIcon:
-                       resType = small8BitData;
-                       break;
-               default:
-                       resType = (OSType)0;
-                       break;
-       }
-       
-       return ( resType );
-}
-
-/*****************************************************************************/
-
-/*
-**     GetIconFromDesktopFile
-**
-**     INPUT a pointer to a non-existent Handle, because we'll allocate one
-**
-**     search each BNDL resource for the right fileCreator and once we get it
-**             find the 'FREF' type in BNDL
-**             for each localID in the type, open the FREF resource
-**                     if the FREF is the desired fileType
-**                             get its icon localID
-**                             get the ICN# type in BNDL
-**                             get the icon resource number from the icon localID
-**                             get the icon resource type from the desktop mgr's iconType
-**                             get the icon of that type and number
-*/
-static OSErr   GetIconFromDesktopFile(ConstStr255Param volName,
-                                                                          short vRefNum,
-                                                                          short iconType,
-                                                                          OSType fileCreator,
-                                                                          OSType fileType,
-                                                                          Handle *iconHandle)
-{
-       OSErr                   error;
-       short                   realVRefNum;
-       Str255                  desktopName;
-       short                   savedResFile;
-       short                   dfRefNum;
-       BNDLRecHandle   theBndl = NULL;
-       BundleTypePtr   theBundleType;
-       short                   iconLocalID;
-       short                   iconRsrcID;
-       OSType                  iconRsrcType;
-       Handle                  returnIconHandle;       
-       char                    bndlState;
-       
-       *iconHandle = NULL;
-       
-       error = DetermineVRefNum(volName, vRefNum, &realVRefNum);
-       if ( error == noErr )
-       {
-               error = GetDesktopFileName(realVRefNum, desktopName);
-               if ( error == noErr )
-               {
-                       savedResFile = CurResFile();
-               
-                       /*
-                       **      Open the 'Desktop' file in the root directory. (because
-                       **      opening the resource file could preload unwanted resources,
-                       **      bracket the call with SetResLoad(s))
-                       */
-                       SetResLoad(false);
-                       dfRefNum = HOpenResFile(realVRefNum, fsRtDirID, desktopName, fsRdPerm);
-                       SetResLoad(true);
-               
-                       if ( dfRefNum != -1 )
-                       {
-                               /*
-                               **      Find the BNDL resource with the specified creator.
-                               */
-                               error = FindBundleGivenCreator(fileCreator, &theBndl);
-                               if ( error == noErr )
-                               {
-                                       /* Lock the BNDL resource so it won't be purged when other resources are loaded */
-                                       bndlState = HGetState((Handle)theBndl);
-                                       HLock((Handle)theBndl);
-                                       
-                                       /* Find the 'FREF' BundleType record in the BNDL resource. */
-                                       error = FindTypeInBundle(kFREFResType, theBndl, &theBundleType);
-                                       if ( error == noErr )
-                                       {
-                                               /* Find the local ID in the 'FREF' resource with the specified fileType */
-                                               error = GetLocalIDFromFREF(theBundleType, fileType, &iconLocalID);
-                                               if ( error == noErr )
-                                               {
-                                                       /* Find the 'ICN#' BundleType record in the BNDL resource. */
-                                                       error = FindTypeInBundle(kIconFamResType, theBndl, &theBundleType);
-                                                       if ( error == noErr )
-                                                       {
-                                                               /* Find the icon's resource ID in the 'ICN#' BundleType record */
-                                                               error = GetIconRsrcIDFromLocalID(theBundleType, iconLocalID, &iconRsrcID);
-                                                               if ( error == noErr )
-                                                               {
-                                                                       /* Map Desktop Manager icon type to resource type */
-                                                                       iconRsrcType = DTIconToResIcon(iconType);
-                                                                       
-                                                                       if ( iconRsrcType != (OSType)0 )
-                                                                       {
-                                                                               /* Load the icon */
-                                                                               returnIconHandle = Get1Resource(iconRsrcType, iconRsrcID);
-                                                                               if ( returnIconHandle != NULL )
-                                                                               {
-                                                                                       /* Copy the resource handle, and return the copy */
-                                                                                       HandToHand(&returnIconHandle);
-                                                                                       if ( MemError() == noErr )
-                                                                                       {
-                                                                                               *iconHandle = returnIconHandle;
-                                                                                       }
-                                                                                       else
-                                                                                       {
-                                                                                               error = afpItemNotFound;
-                                                                                       }
-                                                                               }
-                                                                               else
-                                                                               {
-                                                                                       error = afpItemNotFound;
-                                                                               }
-                                                                       }
-                                                               }
-                                                       }
-                                               }
-                                       }
-                                       /* Restore the state of the BNDL resource */ 
-                                       HSetState((Handle)theBndl, bndlState);
-                               }
-                               /* Restore the resource chain and close the Desktop file */
-                               UseResFile(savedResFile);
-                               CloseResFile(dfRefNum);
-                       }
-                       else
-                       {
-                               error = ResError(); /* could not open Desktop file */
-                       }
-               }
-               if ( (error != noErr) && (error != memFullErr) )
-               {
-                       error = afpItemNotFound;        /* force an error we should return */
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   DTGetIcon(ConstStr255Param volName,
-                                                 short vRefNum,
-                                                 short iconType,
-                                                 OSType fileCreator,
-                                                 OSType fileType,
-                                                 Handle *iconHandle)
-{
-       OSErr error;
-       DTPBRec pb;
-       short dtRefNum;
-       Boolean newDTDatabase;
-       Size bufferSize;
-       
-       *iconHandle = NULL;
-       error = DTOpen(volName, vRefNum, &dtRefNum, &newDTDatabase);
-       if ( error == noErr )
-       {
-               /* there was a desktop database and it's now open */
-               
-               if ( !newDTDatabase )   /* don't bother to look in a new (empty) database */
-               {
-                       /* get the buffer size for the requested icon type */
-                       switch ( iconType )
-                       {
-                               case kLargeIcon:
-                                       bufferSize = kLargeIconSize;
-                                       break;
-                               case kLarge4BitIcon:
-                                       bufferSize = kLarge4BitIconSize;
-                                       break;
-                               case kLarge8BitIcon:
-                                       bufferSize = kLarge8BitIconSize;
-                                       break;
-                               case kSmallIcon:
-                                       bufferSize = kSmallIconSize;
-                                       break;
-                               case kSmall4BitIcon:
-                                       bufferSize = kSmall4BitIconSize;
-                                       break;
-                               case kSmall8BitIcon:
-                                       bufferSize = kSmall8BitIconSize;
-                                       break;
-                               default:
-                                       iconType = 0;
-                                       bufferSize = 0;
-                                       break;
-                       }
-                       if ( bufferSize != 0 )
-                       {
-                               *iconHandle = NewHandle(bufferSize);
-                               if ( *iconHandle != NULL )
-                               {
-                                       HLock(*iconHandle);
-               
-                                       pb.ioDTRefNum = dtRefNum;
-                                       pb.ioTagInfo = 0;
-                                       pb.ioDTBuffer = **iconHandle;
-                                       pb.ioDTReqCount = bufferSize;
-                                       pb.ioIconType = iconType;
-                                       pb.ioFileCreator = fileCreator;
-                                       pb.ioFileType = fileType;
-                                       error = PBDTGetIconSync(&pb);
-       
-                                       HUnlock(*iconHandle);
-                                       
-                                       if ( error != noErr )
-                                       {
-                                               DisposeHandle(*iconHandle);     /* dispose of the allocated memory */
-                                               *iconHandle = NULL;
-                                       }
-                               }
-                               else
-                               {
-                                       error = memFullErr;     /* handle could not be allocated */
-                               }
-                       }
-                       else
-                       {
-                               error = paramErr;       /* unknown icon type requested */
-                       }
-               }
-               else
-               {
-                       error = afpItemNotFound;        /* the desktop database was empty - nothing to return */
-               }
-       }
-       else
-       {
-               /* There is no desktop database - try the Desktop file */
-               
-               error = GetIconFromDesktopFile(volName, vRefNum, iconType,
-                                                                               fileCreator, fileType, iconHandle);
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   DTSetComment(short vRefNum,
-                                                        long dirID,
-                                                        ConstStr255Param name,
-                                                        ConstStr255Param comment)
-{
-       DTPBRec pb;
-       OSErr error;
-       short dtRefNum;
-       Boolean newDTDatabase;
-
-       error = DTOpen(name, vRefNum, &dtRefNum, &newDTDatabase);
-       if ( error == noErr )
-       {
-               pb.ioDTRefNum = dtRefNum;
-               pb.ioNamePtr = (StringPtr)name;
-               pb.ioDirID = dirID;
-               pb.ioDTBuffer = (Ptr)&comment[1];
-               /* Truncate the comment to 200 characters just in case */
-               /* some file system doesn't range check */
-               if ( comment[0] <= 200 )
-               {
-                       pb.ioDTReqCount = comment[0];
-               }
-               else
-               {
-                       pb.ioDTReqCount = 200;
-               }
-               error = PBDTSetCommentSync(&pb);
-       }
-       return (error);
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpDTSetComment(const FSSpec *spec,
-                                                         ConstStr255Param comment)
-{
-       return (DTSetComment(spec->vRefNum, spec->parID, spec->name, comment));
-}
-
-/*****************************************************************************/
-
-/*
-**     GetCommentID
-**
-**     Get the comment ID number for the Desktop file's 'FCMT' resource ID from
-**     the file or folders fdComment (frComment) field.
-*/
-static OSErr   GetCommentID(short vRefNum,
-                                                        long dirID,
-                                                        ConstStr255Param name,
-                                                        short *commentID)
-{
-       CInfoPBRec pb;
-       OSErr error;
-
-       error = GetCatInfoNoName(vRefNum, dirID, name, &pb);
-       *commentID = pb.hFileInfo.ioFlXFndrInfo.fdComment;
-       return ( error );
-}
-
-/*****************************************************************************/
-
-/*
-**     GetCommentFromDesktopFile
-**
-**     Get a file or directory's Finder comment field (if any) from the
-**     Desktop file's 'FCMT' resources.
-*/
-static OSErr   GetCommentFromDesktopFile(short vRefNum,
-                                                                                 long dirID,
-                                                                                 ConstStr255Param name,
-                                                                                 Str255 comment)
-{
-       OSErr error;
-       short commentID;
-       short realVRefNum;
-       Str255 desktopName;
-       short savedResFile;
-       short dfRefNum;
-       StringHandle commentHandle;
-       
-       /* Get the comment ID number */
-       error = GetCommentID(vRefNum, dirID, name, &commentID);
-       if ( error == noErr )
-       {
-               if ( commentID != 0 )   /* commentID == 0 means there's no comment */
-               {
-                       error = DetermineVRefNum(name, vRefNum, &realVRefNum);
-                       if ( error == noErr )
-                       {
-                               error = GetDesktopFileName(realVRefNum, desktopName);
-                               if ( error == noErr )
-                               {
-                                       savedResFile = CurResFile();
-                                       /*
-                                       **      Open the 'Desktop' file in the root directory. (because
-                                       **      opening the resource file could preload unwanted resources,
-                                       **      bracket the call with SetResLoad(s))
-                                       */
-                                       SetResLoad(false);
-                                       dfRefNum = HOpenResFile(realVRefNum, fsRtDirID, desktopName, fsRdPerm);
-                                       SetResLoad(true);
-                                       
-                                       if ( dfRefNum != -1)
-                                       {
-                                               /* Get the comment resource */
-                                               commentHandle = (StringHandle)Get1Resource(kFCMTResType,commentID);
-                                               if ( commentHandle != NULL )
-                                               {
-                                                       if ( GetHandleSize((Handle)commentHandle) > 0 )
-                                                       {
-                                                               BlockMoveData(*commentHandle, comment, *commentHandle[0] + 1);
-                                                       }
-                                                       else
-                                                       {
-                                                               error = afpItemNotFound;        /* no comment available */
-                                                       }
-                                               }
-                                               else
-                                               {
-                                                       error = afpItemNotFound;        /* no comment available */
-                                               }
-                                               
-                                               /* restore the resource chain and close the Desktop file */
-                                               UseResFile(savedResFile);
-                                               CloseResFile(dfRefNum);
-                                       }
-                                       else
-                                       {
-                                               error = afpItemNotFound;
-                                       }
-                               }
-                               else
-                               {
-                                       error = afpItemNotFound;
-                               }
-                       }
-               }
-               else
-               {
-                       error = afpItemNotFound;        /* no comment available */
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   DTGetComment(short vRefNum,
-                                                        long dirID,
-                                                        ConstStr255Param name,
-                                                        Str255 comment)
-{
-       DTPBRec pb;
-       OSErr error;
-       short dtRefNum;
-       Boolean newDTDatabase;
-
-       if (comment != NULL)
-       {
-               comment[0] = 0; /* return nothing by default */
-               
-               /* attempt to open the desktop database */
-               error = DTOpen(name, vRefNum, &dtRefNum, &newDTDatabase);
-               if ( error == noErr )
-               {
-                       /* There was a desktop database and it's now open */
-                       
-                       if ( !newDTDatabase )
-                       {
-                               pb.ioDTRefNum = dtRefNum;
-                               pb.ioNamePtr = (StringPtr)name;
-                               pb.ioDirID = dirID;
-                               pb.ioDTBuffer = (Ptr)&comment[1];
-                               /*
-                               **      IMPORTANT NOTE #1: Inside Macintosh says that comments
-                               **      are up to 200 characters. While that may be correct for
-                               **      the HFS file system's Desktop Manager, other file
-                               **      systems (such as Apple Photo Access) return up to
-                               **      255 characters. Make sure the comment buffer is a Str255
-                               **      or you'll regret it.
-                               **
-                               **      IMPORTANT NOTE #2: Although Inside Macintosh doesn't
-                               **      mention it, ioDTReqCount is a input field to
-                               **      PBDTGetCommentSync. Some file systems (like HFS) ignore
-                               **      ioDTReqCount and always return the full comment --
-                               **      others (like AppleShare) respect ioDTReqCount and only
-                               **      return up to ioDTReqCount characters of the comment.
-                               */
-                               pb.ioDTReqCount = sizeof(Str255) - 1;
-                               error = PBDTGetCommentSync(&pb);
-                               if (error == noErr)
-                               {
-                                       comment[0] = (unsigned char)pb.ioDTActCount;
-                               }
-                       }
-               }
-               else
-               {
-                       /* There is no desktop database - try the Desktop file */
-                       error = GetCommentFromDesktopFile(vRefNum, dirID, name, comment);
-                       if ( error != noErr )
-                       {
-                               error = afpItemNotFound;        /* return an expected error */
-                       }
-               }
-       }
-       else
-       {
-               error = paramErr;
-       }
-       
-       return (error);
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpDTGetComment(const FSSpec *spec,
-                                                         Str255 comment)
-{
-       return (DTGetComment(spec->vRefNum, spec->parID, spec->name, comment));
-}
-
-/*****************************************************************************/
-
-pascal OSErr   DTCopyComment(short srcVRefNum,
-                                                         long srcDirID,
-                                                         ConstStr255Param srcName,
-                                                         short dstVRefNum,
-                                                         long dstDirID,
-                                                         ConstStr255Param dstName)
-/* The destination volume must support the Desktop Manager for this to work */
-{
-       OSErr error;
-       Str255 comment;
-
-       error = DTGetComment(srcVRefNum, srcDirID, srcName, comment);
-       if ( (error == noErr) && (comment[0] > 0) )
-       {
-               error = DTSetComment(dstVRefNum, dstDirID, dstName, comment);
-       }
-       return (error);
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpDTCopyComment(const FSSpec *srcSpec,
-                                                          const FSSpec *dstSpec)
-/* The destination volume must support the Desktop Manager for this to work */
-{
-       return (DTCopyComment(srcSpec->vRefNum, srcSpec->parID, srcSpec->name,
-                                               dstSpec->vRefNum, dstSpec->parID, dstSpec->name));
-}
-
-/*****************************************************************************/
diff --git a/src/mac/morefile/MoreDesktopMgr.h b/src/mac/morefile/MoreDesktopMgr.h
deleted file mode 100644 (file)
index 110c673..0000000
+++ /dev/null
@@ -1,628 +0,0 @@
-/*
-     File:       MoreDesktopMgr.h
-     Contains:   A collection of useful high-level Desktop Manager routines. If the Desktop Manager is not available, use the Desktop file for 'read' operations.
-     Version:    Technology: MoreFiles
-                 Release:    1.5.2
-     Copyright:  © 1992-2001 by Apple Computer, Inc., all rights reserved.
-     Bugs?:      For bug reports, consult the following page on
-                 the World Wide Web:
-                     http://developer.apple.com/bugreporter/
-*/
-
-/*
-    You may incorporate this sample code into your applications without
-    restriction, though the sample code has been provided "AS IS" and the
-    responsibility for its operation is 100% yours.  However, what you are
-    not permitted to do is to redistribute the source as "DSC Sample Code"
-    after having made changes. If you're going to re-distribute the source,
-    we require that you make it clear in the source that the code was
-    descended from Apple Sample Code, but that you've made changes.
-*/
-
-#ifndef __MOREDESKTOPMGR__
-#define __MOREDESKTOPMGR__
-
-#ifndef __MACTYPES__
-#include <MacTypes.h>
-#endif
-
-#ifndef __FILES__
-#include <Files.h>
-#endif
-
-#include "Optimization.h"
-
-
-#if PRAGMA_ONCE
-#pragma once
-#endif
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#if PRAGMA_IMPORT
-#pragma import on
-#endif
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=mac68k
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(push, 2)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack(2)
-#endif
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-DTOpen(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  short *            dtRefNum,
-  Boolean *          newDTDatabase);
-
-
-/*
-    The DTOpen function opens a volume's desktop database. It returns
-    the reference number of the desktop database and indicates if the
-    desktop database was created as a result of this call (if it was created,
-    then it is empty).
-
-    volName         input:  A pointer to the name of a mounted volume
-                            or nil.
-    vRefNum         input:  Volume specification.
-    dtRefNum        output: The reference number of Desktop Manager's
-                            desktop database on the specified volume.
-    newDTDatabase   output: true if the desktop database was created as a
-                            result of this call and thus empty.
-                            false if the desktop database was already created,
-                            or if it could not be determined if it was already
-                            created.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        paramErr            -50     Volume doesn't support this function
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        desktopDamagedErr   -1305   The desktop database has become corrupted - 
-                                    the Finder will fix this, but if your
-                                    application is not running with the
-                                    Finder, use PBDTReset or PBDTDelete
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-DTXGetAPPL(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  OSType             creator,
-  Boolean            searchCatalog,
-  short *            applVRefNum,
-  long *             applParID,
-  Str255             applName);
-
-
-/*
-    The DTXGetAPPL function finds an application (file type 'APPL') with
-    the specified creator on the specified volume. It first tries to get
-    the application mapping from the desktop database. If that fails,
-    then it tries to find an application in the Desktop file. If that
-    fails and searchCatalog is true, then it tries to find an application
-    with the specified creator using the File Manager's CatSearch routine. 
-
-    volName         input:  A pointer to the name of a mounted volume
-                            or nil.
-    vRefNum         input:  Volume specification.
-    creator         input:  The file's creator type.
-    searchCatalog   input:  If true, search the catalog for the application
-                            if it isn't found in the desktop database.
-    applVRefNum     output: The volume reference number of the volume the
-                            application is on.
-    applParID       output: The parent directory ID of the application.
-    applName        output: The name of the application.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        paramErr            -50     No default volume
-        rfNumErr            -51     Reference number invalid
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call
-        desktopDamagedErr   -1305   The desktop database has become corrupted - 
-                                    the Finder will fix this, but if your
-                                    application is not running with the
-                                    Finder, use PBDTReset or PBDTDelete
-        afpItemNotFound     -5012   Information not found
-    
-    __________
-    
-    Also see:   FSpDTGetAPPL
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpDTXGetAPPL(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  OSType             creator,
-  Boolean            searchCatalog,
-  FSSpec *           spec);
-
-
-/*
-    The FSpDTXGetAPPL function finds an application (file type 'APPL') with
-    the specified creator on the specified volume. It first tries to get
-    the application mapping from the desktop database. If that fails,
-    then it tries to find an application in the Desktop file. If that
-    fails and searchCatalog is true, then it tries to find an application
-    with the specified creator using the File Manager's CatSearch routine. 
-
-    volName         input:  A pointer to the name of a mounted volume
-                            or nil.
-    vRefNum         input:  Volume specification.
-    creator         input:  The file's creator type.
-    searchCatalog   input:  If true, search the catalog for the application
-                            if it isn't found in the desktop database.
-    spec            output: FSSpec record containing the application name and
-                            location.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        paramErr            -50     No default volume
-        rfNumErr            -51     Reference number invalid
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call
-        desktopDamagedErr   -1305   The desktop database has become corrupted - 
-                                    the Finder will fix this, but if your
-                                    application is not running with the
-                                    Finder, use PBDTReset or PBDTDelete
-        afpItemNotFound     -5012   Information not found
-    
-    __________
-    
-    Also see:   FSpDTGetAPPL
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-DTGetAPPL(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  OSType             creator,
-  short *            applVRefNum,
-  long *             applParID,
-  Str255             applName);
-
-
-/*
-    The DTGetAPPL function finds an application (file type 'APPL') with
-    the specified creator on the specified volume. It first tries to get
-    the application mapping from the desktop database. If that fails,
-    then it tries to find an application in the Desktop file. If that
-    fails, then it tries to find an application with the specified creator
-    using the File Manager's CatSearch routine. 
-
-    volName     input:  A pointer to the name of a mounted volume
-                        or nil.
-    vRefNum     input:  Volume specification.
-    creator     input:  The file's creator type.
-    applVRefNum output: The volume reference number of the volume the
-                        application is on.
-    applParID   output: The parent directory ID of the application.
-    applName    output: The name of the application.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        paramErr            -50     No default volume
-        rfNumErr            -51     Reference number invalid
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call
-        desktopDamagedErr   -1305   The desktop database has become corrupted - 
-                                    the Finder will fix this, but if your
-                                    application is not running with the
-                                    Finder, use PBDTReset or PBDTDelete
-        afpItemNotFound     -5012   Information not found
-    
-    __________
-    
-    Also see:   FSpDTGetAPPL
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpDTGetAPPL(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  OSType             creator,
-  FSSpec *           spec);
-
-
-/*
-    The FSpDTGetAPPL function finds an application (file type 'APPL') with
-    the specified creator on the specified volume. It first tries to get
-    the application mapping from the desktop database. If that fails,
-    then it tries to find an application in the Desktop file. If that
-    fails, then it tries to find an application with the specified creator
-    using the File Manager's CatSearch routine. 
-
-    volName     input:  A pointer to the name of a mounted volume
-                        or nil.
-    vRefNum     input:  Volume specification.
-    creator     input:  The file's creator type.
-    spec        output: FSSpec record containing the application name and
-                        location.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        paramErr            -50     No default volume
-        rfNumErr            -51     Reference number invalid
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call
-        desktopDamagedErr   -1305   The desktop database has become corrupted - 
-                                    the Finder will fix this, but if your
-                                    application is not running with the
-                                    Finder, use PBDTReset or PBDTDelete
-        afpItemNotFound     -5012   Information not found
-    
-    __________
-    
-    Also see:   DTGetAPPL
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-DTGetIcon(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  short              iconType,
-  OSType             fileCreator,
-  OSType             fileType,
-  Handle *           iconHandle);
-
-
-/*
-    The DTGetIcon function retrieves the specified icon and returns it in
-    a newly created handle. The icon is retrieves from the Desktop Manager
-    or if the Desktop Manager is not available, from the Finder's Desktop
-    file. Your program is responsible for disposing of the handle when it is
-    done using the icon.
-
-    volName     input:  A pointer to the name of a mounted volume
-                        or nil.
-    vRefNum     input:  Volume specification.
-    iconType    input:  The icon type as defined in Files.h. Valid values are:
-                            kLargeIcon
-                            kLarge4BitIcon
-                            kLarge8BitIcon
-                            kSmallIcon
-                            kSmall4BitIcon
-                            kSmall8BitIcon
-    fileCreator input:  The icon's creator type.
-    fileType    input:  The icon's file type.
-    iconHandle  output: A Handle containing the newly created icon.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        paramErr            -50     Volume doesn't support this function
-        rfNumErr            -51     Reference number invalid
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call
-        memFullErr          -108    iconHandle could not be allocated
-        desktopDamagedErr   -1305   The desktop database has become corrupted - 
-                                    the Finder will fix this, but if your
-                                    application is not running with the
-                                    Finder, use PBDTReset or PBDTDelete
-        afpItemNotFound     -5012   Information not found
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-DTSetComment(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  ConstStr255Param   comment);
-
-
-/*
-    The DTSetComment function sets a file or directory's Finder comment
-    field. The volume must support the Desktop Manager because you only
-    have read access to the Desktop file.
-
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to object name, or nil when dirID
-                    specifies a directory that's the object.
-    comment input:  The comment to add. Comments are limited to 200 characters;
-                    longer comments are truncated.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        fnfErr              Ð43     File or directory doesnÕt exist
-        paramErr            -50     Volume doesn't support this function
-        wPrErr              Ð44     Volume is locked through hardware
-        vLckdErr            Ð46     Volume is locked through software
-        rfNumErr            Ð51     Reference number invalid
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        desktopDamagedErr   -1305   The desktop database has become corrupted - 
-                                    the Finder will fix this, but if your
-                                    application is not running with the
-                                    Finder, use PBDTReset or PBDTDelete
-    
-    __________
-    
-    Also see:   DTCopyComment, FSpDTCopyComment, FSpDTSetComment, DTGetComment,
-                FSpDTGetComment
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpDTSetComment(
-  const FSSpec *     spec,
-  ConstStr255Param   comment);
-
-
-/*
-    The FSpDTSetComment function sets a file or directory's Finder comment
-    field. The volume must support the Desktop Manager because you only
-    have read access to the Desktop file.
-
-    spec    input:  An FSSpec record specifying the file or directory.
-    comment input:  The comment to add. Comments are limited to 200 characters;
-                    longer comments are truncated.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        fnfErr              Ð43     File or directory doesnÕt exist
-        wPrErr              Ð44     Volume is locked through hardware
-        vLckdErr            Ð46     Volume is locked through software
-        rfNumErr            Ð51     Reference number invalid
-        paramErr            -50     Volume doesn't support this function
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        desktopDamagedErr   -1305   The desktop database has become corrupted - 
-                                    the Finder will fix this, but if your
-                                    application is not running with the
-                                    Finder, use PBDTReset or PBDTDelete
-    
-    __________
-    
-    Also see:   DTCopyComment, FSpDTCopyComment, DTSetComment, DTGetComment,
-                FSpDTGetComment
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-DTGetComment(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  Str255             comment);
-
-
-/*
-    The DTGetComment function gets a file or directory's Finder comment
-    field (if any) from the Desktop Manager or if the Desktop Manager is
-    not available, from the Finder's Desktop file.
-
-    IMPORTANT NOTE: Inside Macintosh says that comments are up to
-    200 characters. While that may be correct for the HFS file system's
-    Desktop Manager, other file systems (such as Apple Photo Access) return
-    up to 255 characters. Make sure the comment buffer is a Str255 or you'll
-    regret it.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to object name, or nil when dirID
-                    specifies a directory that's the object.
-    comment output: A Str255 where the comment is to be returned.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        fnfErr              -43     File not found
-        paramErr            -50     Volume doesn't support this function
-        rfNumErr            Ð51     Reference number invalid
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        desktopDamagedErr   -1305   The desktop database has become corrupted - 
-                                    the Finder will fix this, but if your
-                                    application is not running with the
-                                    Finder, use PBDTReset or PBDTDelete
-        afpItemNotFound     -5012   Information not found
-        
-    __________
-    
-    Also see:   DTCopyComment, FSpDTCopyComment, DTSetComment, FSpDTSetComment,
-                FSpDTGetComment
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpDTGetComment(
-  const FSSpec *  spec,
-  Str255          comment);
-
-
-/*
-    The FSpDTGetComment function gets a file or directory's Finder comment
-    field (if any) from the Desktop Manager or if the Desktop Manager is
-    not available, from the Finder's Desktop file.
-
-    IMPORTANT NOTE: Inside Macintosh says that comments are up to
-    200 characters. While that may be correct for the HFS file system's
-    Desktop Manager, other file systems (such as Apple Photo Access) return
-    up to 255 characters. Make sure the comment buffer is a Str255 or you'll
-    regret it.
-    
-    spec    input:  An FSSpec record specifying the file or directory.
-    comment output: A Str255 where the comment is to be returned.
-
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        fnfErr              -43     File not found
-        paramErr            -50     Volume doesn't support this function
-        rfNumErr            Ð51     Reference number invalid
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        desktopDamagedErr   -1305   The desktop database has become corrupted - 
-                                    the Finder will fix this, but if your
-                                    application is not running with the
-                                    Finder, use PBDTReset or PBDTDelete
-        afpItemNotFound     -5012   Information not found
-        
-    __________
-    
-    Also see:   DTCopyComment, FSpDTCopyComment, DTSetComment, FSpDTSetComment,
-                DTGetComment
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-DTCopyComment(
-  short              srcVRefNum,
-  long               srcDirID,
-  ConstStr255Param   srcName,
-  short              dstVRefNum,
-  long               dstDirID,
-  ConstStr255Param   dstName);
-
-
-/*
-    The DTCopyComment function copies the file or folder comment from the
-    source to the destination object.  The destination volume must support
-    the Desktop Manager because you only have read access to the Desktop file.
-    
-    srcVRefNum  input:  Source volume specification.
-    srcDirID    input:  Source directory ID.
-    srcName     input:  Pointer to source object name, or nil when srcDirID
-                        specifies a directory that's the object.
-    dstVRefNum  input:  Destination volume specification.
-    dstDirID    input:  Destination directory ID.
-    dstName     input:  Pointer to destination object name, or nil when
-                        dstDirID specifies a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        fnfErr              Ð43     File or directory doesnÕt exist
-        wPrErr              Ð44     Volume is locked through hardware
-        vLckdErr            Ð46     Volume is locked through software
-        paramErr            -50     Volume doesn't support this function
-        rfNumErr            Ð51     Reference number invalid
-        paramErr            -50     Volume doesn't support this function
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        desktopDamagedErr   -1305   The desktop database has become corrupted - 
-                                    the Finder will fix this, but if your
-                                    application is not running with the
-                                    Finder, use PBDTReset or PBDTDelete
-        afpItemNotFound     -5012   Information not found
-        
-    __________
-    
-    Also see:   FSpDTCopyComment, DTSetComment, FSpDTSetComment, DTGetComment,
-                FSpDTGetComment
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpDTCopyComment(
-  const FSSpec *  srcSpec,
-  const FSSpec *  dstSpec);
-
-
-/*
-    The FSpDTCopyComment function copies the desktop database comment from
-    the source to the destination object.  Both the source and the
-    destination volumes must support the Desktop Manager.
-    
-    srcSpec     input:  An FSSpec record specifying the source object.
-    dstSpec     input:  An FSSpec record specifying the destination object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        fnfErr              Ð43     File or directory doesnÕt exist
-        wPrErr              Ð44     Volume is locked through hardware
-        vLckdErr            Ð46     Volume is locked through software
-        paramErr            -50     Volume doesn't support this function
-        rfNumErr            Ð51     Reference number invalid
-        paramErr            -50     Volume doesn't support this function
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        desktopDamagedErr   -1305   The desktop database has become corrupted - 
-                                    the Finder will fix this, but if your
-                                    application is not running with the
-                                    Finder, use PBDTReset or PBDTDelete
-        afpItemNotFound     -5012   Information not found
-        
-    __________
-    
-    Also see:   DTCopyComment, DTSetComment, FSpDTSetComment, DTGetComment,
-                FSpDTGetComment
-*/
-
-/*****************************************************************************/
-
-#include "OptimizationEnd.h"
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=reset
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(pop)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack()
-#endif
-
-#ifdef PRAGMA_IMPORT_OFF
-#pragma import off
-#elif PRAGMA_IMPORT
-#pragma import reset
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* __MOREDESKTOPMGR__ */
-
diff --git a/src/mac/morefile/MoreFiles.c b/src/mac/morefile/MoreFiles.c
deleted file mode 100644 (file)
index 8426bda..0000000
+++ /dev/null
@@ -1,643 +0,0 @@
-/*
-       File:           MoreFiles.c
-
-       Contains:       The long lost high-level and FSSpec File Manager functions.
-
-       Version:        MoreFiles
-
-       Copyright:      © 1992-2001 by Apple Computer, Inc., all rights reserved.
-
-       You may incorporate this sample code into your applications without
-       restriction, though the sample code has been provided "AS IS" and the
-       responsibility for its operation is 100% yours.  However, what you are
-       not permitted to do is to redistribute the source as "DSC Sample Code"
-       after having made changes. If you're going to re-distribute the source,
-       we require that you make it clear in the source that the code was
-       descended from Apple Sample Code, but that you've made changes.
-
-       File Ownership:
-
-               DRI:                            Apple Macintosh Developer Technical Support
-
-               Other Contact:          Apple Macintosh Developer Technical Support
-                                                       <http://developer.apple.com/bugreporter/>
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-
-       Change History (most recent first):
-
-                <2>      2/7/01        JL              Added standard header. Updated names of includes.
-               <1>             12/06/99        JL              MoreFiles 1.5.
-*/
-
-#include <MacTypes.h>
-#include <MacErrors.h>
-#include <Files.h>
-
-#define        __COMPILINGMOREFILES
-
-#include "MoreFiles.h"
-#include "MoreFilesExtras.h"
-
-/*****************************************************************************/
-
-pascal OSErr   HGetVolParms(ConstStr255Param volName,
-                                                        short vRefNum,
-                                                        GetVolParmsInfoBuffer *volParmsInfo,
-                                                        long *infoSize)
-{
-       HParamBlockRec pb;
-       OSErr error;
-
-       pb.ioParam.ioNamePtr = (StringPtr)volName;
-       pb.ioParam.ioVRefNum = vRefNum;
-       pb.ioParam.ioBuffer = (Ptr)volParmsInfo;
-       pb.ioParam.ioReqCount = *infoSize;
-       error = PBHGetVolParmsSync(&pb);
-       if ( error == noErr )
-       {
-               *infoSize = pb.ioParam.ioActCount;
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   HCreateMinimum(short vRefNum,
-                                                          long dirID,
-                                                          ConstStr255Param fileName)
-{
-       HParamBlockRec pb;
-
-       pb.fileParam.ioNamePtr = (StringPtr)fileName;
-       pb.fileParam.ioVRefNum = vRefNum;
-       pb.ioParam.ioVersNum = 0;
-       pb.fileParam.ioDirID = dirID;
-       return ( PBHCreateSync(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpCreateMinimum(const FSSpec *spec)
-{
-       return ( HCreateMinimum(spec->vRefNum, spec->parID, spec->name) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   ExchangeFiles(short vRefNum,
-                                                         long srcDirID,
-                                                         ConstStr255Param srcName,
-                                                         long dstDirID,
-                                                         ConstStr255Param dstName)
-{
-       HParamBlockRec pb;
-
-       pb.fidParam.ioVRefNum = vRefNum;
-       pb.fidParam.ioSrcDirID = srcDirID;
-       pb.fidParam.ioNamePtr = (StringPtr)srcName;
-       pb.fidParam.ioDestDirID = dstDirID;
-       pb.fidParam.ioDestNamePtr = (StringPtr)dstName;
-       return ( PBExchangeFilesSync(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   ResolveFileIDRef(ConstStr255Param volName,
-                                                                short vRefNum,
-                                                                long fileID,
-                                                                long *parID,
-                                                                StringPtr fileName)
-{
-       HParamBlockRec pb;
-       OSErr error;
-       Str255 tempStr;
-       
-       tempStr[0] = 0;
-       if ( volName != NULL )
-       {
-               BlockMoveData(volName, tempStr, volName[0] + 1);
-       }
-       pb.fidParam.ioNamePtr = (StringPtr)tempStr;
-       pb.fidParam.ioVRefNum = vRefNum;
-       pb.fidParam.ioFileID = fileID;
-       error = PBResolveFileIDRefSync(&pb);
-       if ( error == noErr )
-       {
-               *parID = pb.fidParam.ioSrcDirID;
-               if ( fileName != NULL )
-               {
-                       BlockMoveData(tempStr, fileName, tempStr[0] + 1);
-               }
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpResolveFileIDRef(ConstStr255Param volName,
-                                                                       short vRefNum,
-                                                                       long fileID,
-                                                                       FSSpec *spec)
-{
-       OSErr   error;
-       
-       error = DetermineVRefNum(volName, vRefNum, &(spec->vRefNum));
-       if ( error == noErr )
-       {
-               error = ResolveFileIDRef(volName, vRefNum, fileID, &(spec->parID), spec->name);
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   CreateFileIDRef(short vRefNum,
-                                                               long parID,
-                                                               ConstStr255Param fileName,
-                                                               long *fileID)
-{
-       HParamBlockRec pb;
-       OSErr error;
-
-       pb.fidParam.ioNamePtr = (StringPtr)fileName;
-       pb.fidParam.ioVRefNum = vRefNum;
-       pb.fidParam.ioSrcDirID = parID;
-       error = PBCreateFileIDRefSync(&pb);
-       if ( (error == noErr) || (error == fidExists) || (error == afpIDExists) )
-       {
-               *fileID = pb.fidParam.ioFileID;
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpCreateFileIDRef(const FSSpec *spec,
-                                                                  long *fileID)
-{
-       return ( CreateFileIDRef(spec->vRefNum, spec->parID, spec->name, fileID) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   DeleteFileIDRef(ConstStr255Param volName,
-                                                               short vRefNum,
-                                                               long fileID)
-{
-       HParamBlockRec pb;
-
-       pb.fidParam.ioNamePtr = (StringPtr)volName;
-       pb.fidParam.ioVRefNum = vRefNum;
-       pb.fidParam.ioFileID = fileID;
-       return ( PBDeleteFileIDRefSync(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FlushFile(short refNum)
-{
-       ParamBlockRec pb;
-
-       pb.ioParam.ioRefNum = refNum;
-       return ( PBFlushFileSync(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   LockRange(short refNum,
-                                                 long rangeLength,
-                                                 long rangeStart)
-{
-       ParamBlockRec pb;
-
-       pb.ioParam.ioRefNum = refNum;
-       pb.ioParam.ioReqCount = rangeLength;
-       pb.ioParam.ioPosMode = fsFromStart;
-       pb.ioParam.ioPosOffset = rangeStart;
-       return ( PBLockRangeSync(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   UnlockRange(short refNum,
-                                                       long rangeLength,
-                                                       long rangeStart)
-{
-       ParamBlockRec pb;
-
-       pb.ioParam.ioRefNum = refNum;
-       pb.ioParam.ioReqCount = rangeLength;
-       pb.ioParam.ioPosMode = fsFromStart;
-       pb.ioParam.ioPosOffset = rangeStart;
-       return ( PBUnlockRangeSync(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetForeignPrivs(short vRefNum,
-                                                               long dirID,
-                                                               ConstStr255Param name,
-                                                               void *foreignPrivBuffer,
-                                                               long *foreignPrivSize,
-                                                               long *foreignPrivInfo1,
-                                                               long *foreignPrivInfo2,
-                                                               long *foreignPrivInfo3,
-                                                               long *foreignPrivInfo4)
-{
-       HParamBlockRec pb;
-       OSErr error;
-
-       pb.foreignPrivParam.ioNamePtr = (StringPtr)name;
-       pb.foreignPrivParam.ioVRefNum = vRefNum;
-       pb.foreignPrivParam.ioForeignPrivDirID = dirID; 
-       pb.foreignPrivParam.ioForeignPrivBuffer = (Ptr)foreignPrivBuffer;
-       pb.foreignPrivParam.ioForeignPrivReqCount = *foreignPrivSize;
-       error = PBGetForeignPrivsSync(&pb);
-       *foreignPrivSize = pb.foreignPrivParam.ioForeignPrivActCount;
-       *foreignPrivInfo1 = pb.foreignPrivParam.ioForeignPrivInfo1;
-       *foreignPrivInfo2 = pb.foreignPrivParam.ioForeignPrivInfo2;
-       *foreignPrivInfo3 = pb.foreignPrivParam.ioForeignPrivInfo3;
-       *foreignPrivInfo4 = pb.foreignPrivParam.ioForeignPrivInfo4;
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpGetForeignPrivs(const FSSpec *spec,
-                                                                  void *foreignPrivBuffer,
-                                                                  long *foreignPrivSize,
-                                                                  long *foreignPrivInfo1,
-                                                                  long *foreignPrivInfo2,
-                                                                  long *foreignPrivInfo3,
-                                                                  long *foreignPrivInfo4)
-{
-       return ( GetForeignPrivs(spec->vRefNum, spec->parID, spec->name,
-                                                        foreignPrivBuffer, foreignPrivSize,
-                                                        foreignPrivInfo1, foreignPrivInfo2,
-                                                        foreignPrivInfo3, foreignPrivInfo4) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   SetForeignPrivs(short vRefNum,
-                                                               long dirID,
-                                                               ConstStr255Param name,
-                                                               const void *foreignPrivBuffer,
-                                                               long *foreignPrivSize,
-                                                               long foreignPrivInfo1,
-                                                               long foreignPrivInfo2,
-                                                               long foreignPrivInfo3,
-                                                               long foreignPrivInfo4)
-{
-       HParamBlockRec pb;
-       OSErr error;
-
-       pb.foreignPrivParam.ioNamePtr = (StringPtr)name;
-       pb.foreignPrivParam.ioVRefNum = vRefNum;
-       pb.foreignPrivParam.ioForeignPrivDirID = dirID; 
-       pb.foreignPrivParam.ioForeignPrivBuffer = (Ptr)foreignPrivBuffer;
-       pb.foreignPrivParam.ioForeignPrivReqCount = *foreignPrivSize;
-       pb.foreignPrivParam.ioForeignPrivInfo1 = foreignPrivInfo1;
-       pb.foreignPrivParam.ioForeignPrivInfo2 = foreignPrivInfo2;
-       pb.foreignPrivParam.ioForeignPrivInfo3 = foreignPrivInfo3;
-       pb.foreignPrivParam.ioForeignPrivInfo4 = foreignPrivInfo4;
-       error = PBSetForeignPrivsSync(&pb);
-       if ( error == noErr )
-       {
-               *foreignPrivSize = pb.foreignPrivParam.ioForeignPrivActCount;
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpSetForeignPrivs(const FSSpec *spec,
-                                                                  const void *foreignPrivBuffer,
-                                                                  long *foreignPrivSize,
-                                                                  long foreignPrivInfo1,
-                                                                  long foreignPrivInfo2,
-                                                                  long foreignPrivInfo3,
-                                                                  long foreignPrivInfo4)
-{
-       return ( SetForeignPrivs(spec->vRefNum, spec->parID, spec->name,
-                                                        foreignPrivBuffer, foreignPrivSize,
-                                                        foreignPrivInfo1, foreignPrivInfo2,
-                                                        foreignPrivInfo3, foreignPrivInfo4) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   HGetLogInInfo(ConstStr255Param volName,
-                                                         short vRefNum,
-                                                         short *loginMethod,
-                                                         StringPtr userName)
-{
-       HParamBlockRec pb;
-       OSErr error;
-
-       pb.objParam.ioNamePtr = (StringPtr)volName;
-       pb.objParam.ioVRefNum = vRefNum;
-       pb.objParam.ioObjNamePtr = userName;
-       error = PBHGetLogInInfoSync(&pb);
-       if ( error == noErr )
-       {
-               *loginMethod = pb.objParam.ioObjType;
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   HGetDirAccess(short vRefNum,
-                                                         long dirID,
-                                                         ConstStr255Param name,
-                                                         long *ownerID,
-                                                         long *groupID,
-                                                         long *accessRights)
-{
-       HParamBlockRec pb;
-       OSErr error;
-
-       pb.accessParam.ioNamePtr = (StringPtr)name;
-       pb.accessParam.ioVRefNum = vRefNum;
-       pb.fileParam.ioDirID = dirID;
-       error = PBHGetDirAccessSync(&pb);
-       if ( error == noErr )
-       {
-               *ownerID = pb.accessParam.ioACOwnerID;
-               *groupID = pb.accessParam.ioACGroupID;
-               *accessRights = pb.accessParam.ioACAccess;
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpGetDirAccess(const FSSpec *spec,
-                                                               long *ownerID,
-                                                               long *groupID,
-                                                               long *accessRights)
-{
-       return ( HGetDirAccess(spec->vRefNum, spec->parID, spec->name,
-                                                  ownerID, groupID, accessRights) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   HSetDirAccess(short vRefNum,
-                                                         long dirID,
-                                                         ConstStr255Param name,
-                                                         long ownerID,
-                                                         long groupID,
-                                                         long accessRights)
-{
-       HParamBlockRec pb;
-
-       pb.accessParam.ioNamePtr = (StringPtr)name;
-       pb.accessParam.ioVRefNum = vRefNum;
-       pb.fileParam.ioDirID = dirID;
-       pb.accessParam.ioACOwnerID = ownerID;
-       pb.accessParam.ioACGroupID = groupID;
-       pb.accessParam.ioACAccess = accessRights;
-       return ( PBHSetDirAccessSync(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpSetDirAccess(const FSSpec *spec,
-                                                               long ownerID,
-                                                               long groupID,
-                                                               long accessRights)
-{
-       return ( HSetDirAccess(spec->vRefNum, spec->parID, spec->name,
-                                                  ownerID, groupID, accessRights) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   HMapID(ConstStr255Param volName,
-                                          short vRefNum,
-                                          long ugID,
-                                          short objType,
-                                          StringPtr name)
-{
-       HParamBlockRec pb;
-
-       pb.objParam.ioNamePtr = (StringPtr)volName;
-       pb.objParam.ioVRefNum = vRefNum;
-       pb.objParam.ioObjType = objType;
-       pb.objParam.ioObjNamePtr = name;
-       pb.objParam.ioObjID = ugID;
-       return ( PBHMapIDSync(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   HMapName(ConstStr255Param volName,
-                                                short vRefNum,
-                                                ConstStr255Param name,
-                                                short objType,
-                                                long *ugID)
-{
-       HParamBlockRec pb;
-       OSErr error;
-
-       pb.objParam.ioNamePtr = (StringPtr)volName;
-       pb.objParam.ioVRefNum = vRefNum;
-       pb.objParam.ioObjType = objType;
-       pb.objParam.ioObjNamePtr = (StringPtr)name;
-       error = PBHMapNameSync(&pb);
-       if ( error == noErr )
-       {
-               *ugID = pb.objParam.ioObjID;
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   HCopyFile(short srcVRefNum,
-                                                 long srcDirID,
-                                                 ConstStr255Param srcName,
-                                                 short dstVRefNum,
-                                                 long dstDirID,
-                                                 ConstStr255Param dstPathname,
-                                                 ConstStr255Param copyName)
-{
-       HParamBlockRec pb;
-
-       pb.copyParam.ioVRefNum = srcVRefNum;
-       pb.copyParam.ioDirID = srcDirID;
-       pb.copyParam.ioNamePtr = (StringPtr)srcName;
-       pb.copyParam.ioDstVRefNum = dstVRefNum;
-       pb.copyParam.ioNewDirID = dstDirID;
-       pb.copyParam.ioNewName = (StringPtr)dstPathname;
-       pb.copyParam.ioCopyName = (StringPtr)copyName;
-       return ( PBHCopyFileSync(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpCopyFile(const FSSpec *srcSpec,
-                                                       const FSSpec *dstSpec,
-                                                       ConstStr255Param copyName)
-{
-       return ( HCopyFile(srcSpec->vRefNum, srcSpec->parID, srcSpec->name,
-                                          dstSpec->vRefNum, dstSpec->parID,
-                                          dstSpec->name, copyName) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   HMoveRename(short vRefNum,
-                                                       long srcDirID,
-                                                       ConstStr255Param srcName,
-                                                       long dstDirID,
-                                                       ConstStr255Param dstpathName,
-                                                       ConstStr255Param copyName)
-{
-       HParamBlockRec pb;
-
-       pb.copyParam.ioVRefNum = vRefNum;
-       pb.copyParam.ioDirID = srcDirID;
-       pb.copyParam.ioNamePtr = (StringPtr)srcName;
-       pb.copyParam.ioNewDirID = dstDirID;
-       pb.copyParam.ioNewName = (StringPtr)dstpathName;
-       pb.copyParam.ioCopyName = (StringPtr)copyName;
-       return ( PBHMoveRenameSync(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpMoveRename(const FSSpec *srcSpec,
-                                                         const FSSpec *dstSpec,
-                                                         ConstStr255Param copyName)
-{
-       OSErr   error;
-       
-       /* make sure the FSSpecs refer to the same volume */
-       if ( srcSpec->vRefNum != dstSpec->vRefNum )
-       {
-               error = diffVolErr;
-       }
-       else
-       {
-               error = HMoveRename(srcSpec->vRefNum, srcSpec->parID, srcSpec->name, 
-                                                       dstSpec->parID, dstSpec->name, copyName);
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetVolMountInfoSize(ConstStr255Param volName,
-                                                                       short vRefNum,
-                                                                       short *size)
-{
-       ParamBlockRec pb;
-
-       pb.ioParam.ioNamePtr = (StringPtr)volName;
-       pb.ioParam.ioVRefNum = vRefNum;
-       pb.ioParam.ioBuffer = (Ptr)size;
-       return ( PBGetVolMountInfoSize(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetVolMountInfo(ConstStr255Param volName,
-                                                               short vRefNum,
-                                                               void *volMountInfo)
-{
-       ParamBlockRec pb;
-
-       pb.ioParam.ioNamePtr = (StringPtr)volName;
-       pb.ioParam.ioVRefNum = vRefNum;
-       pb.ioParam.ioBuffer = (Ptr)volMountInfo;
-       return ( PBGetVolMountInfo(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   VolumeMount(const void *volMountInfo,
-                                                       short *vRefNum)
-{
-       ParamBlockRec pb;
-       OSErr error;
-
-       pb.ioParam.ioBuffer = (Ptr)volMountInfo;
-       error = PBVolumeMount(&pb);
-       if ( error == noErr )
-       {
-               *vRefNum = pb.ioParam.ioVRefNum;
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   Share(short vRefNum,
-                                         long dirID,
-                                         ConstStr255Param name)
-{
-       HParamBlockRec pb;
-
-       pb.fileParam.ioNamePtr = (StringPtr)name;
-       pb.fileParam.ioVRefNum = vRefNum;
-       pb.fileParam.ioDirID = dirID;
-       return ( PBShareSync(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpShare(const FSSpec *spec)
-{
-       return ( Share(spec->vRefNum, spec->parID, spec->name) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   Unshare(short vRefNum,
-                                               long dirID,
-                                               ConstStr255Param name)
-{
-       HParamBlockRec pb;
-
-       pb.fileParam.ioNamePtr = (StringPtr)name;
-       pb.fileParam.ioVRefNum = vRefNum;
-       pb.fileParam.ioDirID = dirID;
-       return ( PBUnshareSync(&pb) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpUnshare(const FSSpec *spec)
-{
-       return ( Unshare(spec->vRefNum, spec->parID, spec->name) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetUGEntry(short objType,
-                                                  StringPtr objName,
-                                                  long *objID)
-{
-       HParamBlockRec pb;
-       OSErr error;
-
-       pb.objParam.ioObjType = objType;
-       pb.objParam.ioObjNamePtr = objName;
-       pb.objParam.ioObjID = *objID;
-       error = PBGetUGEntrySync(&pb);
-       if ( error == noErr )
-       {
-               *objID = pb.objParam.ioObjID;
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
diff --git a/src/mac/morefile/MoreFiles.h b/src/mac/morefile/MoreFiles.h
deleted file mode 100644 (file)
index 25b1fcf..0000000
+++ /dev/null
@@ -1,1420 +0,0 @@
-/*
-     File:       MoreFiles.h
-     Contains:   The long lost high-level and FSSpec File Manager functions.
-     Version:    Technology: MoreFiles
-                 Release:    1.5.2
-     Copyright:  © 1992-2001 by Apple Computer, Inc., all rights reserved.
-     Bugs?:      For bug reports, consult the following page on
-                 the World Wide Web:
-                     http://developer.apple.com/bugreporter/
-*/
-
-/*
-    You may incorporate this sample code into your applications without
-    restriction, though the sample code has been provided "AS IS" and the
-    responsibility for its operation is 100% yours.  However, what you are
-    not permitted to do is to redistribute the source as "DSC Sample Code"
-    after having made changes. If you're going to re-distribute the source,
-    we require that you make it clear in the source that the code was
-    descended from Apple Sample Code, but that you've made changes.
-*/
-
-#ifndef __MOREFILES__
-#define __MOREFILES__
-
-#ifndef __MACTYPES__
-#include <MacTypes.h>
-#endif
-
-#ifndef __FILES__
-#include <Files.h>
-#endif
-
-#include "Optimization.h"
-
-
-#if PRAGMA_ONCE
-#pragma once
-#endif
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#if PRAGMA_IMPORT
-#pragma import on
-#endif
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=mac68k
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(push, 2)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack(2)
-#endif
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-HGetVolParms(
-  ConstStr255Param         volName,
-  short                    vRefNum,
-  GetVolParmsInfoBuffer *  volParmsInfo,
-  long *                   infoSize);
-
-
-/*
-    The HGetVolParms function returns information about the characteristics
-    of a volume. A result of paramErr usually just means the volume doesn't
-    support PBHGetVolParms and the feature you were going to check
-    for isn't available.
-
-    volName         input:  A pointer to the name of a mounted volume
-                            or nil.
-    vRefNum         input:  Volume specification.
-    volParmsInfo    input:  Pointer to GetVolParmsInfoBuffer where the
-                            volume attributes information is returned.
-                    output: Atributes information.
-    infoSize        input:  Size of buffer pointed to by volParmsInfo.
-                    output: Size of data actually returned.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        paramErr            -50     Volume doesn't support this function
-    
-    __________
-    
-    Also see the macros for checking attribute bits in MoreFilesExtras.h
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-HCreateMinimum(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   fileName);
-
-
-/*
-    The HCreateMinimum function creates a new file without attempting to set
-    the creator and file type of the new file.  This function is needed to
-    create a file in an AppleShare "drop box" where the user can make
-    changes, but cannot see folder or files.
-    
-    vRefNum     input:  Volume specification.
-    dirID       input:  Directory ID.
-    fileName    input:  The name of the new file.
-    
-    Result Codes
-        noErr               0       No error
-        dirFulErr           -33     File directory full
-        dskFulErr           -34     Disk is full
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     Directory not found or incomplete pathname
-        wPrErr              -44     Hardware volume lock
-        vLckdErr            -46     Software volume lock
-        dupFNErr            -48     Duplicate filename and version
-        dirNFErrdirNFErr    -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   A directory exists with that name
-    
-    __________
-    
-    Also see:   FSpCreateMinimum
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpCreateMinimum(const FSSpec * spec);
-
-
-/*
-    The FSpCreateMinimum function creates a new file without attempting to set 
-    the the creator and file type of the new file.  This function is needed to
-    create a file in an AppleShare "dropbox" where the user can make
-    changes, but cannot see folder or files. 
-    
-    spec        input:  An FSSpec record specifying the file to create.
-    
-    Result Codes
-        noErr               0       No error
-        dirFulErr           -33     File directory full
-        dskFulErr           -34     Disk is full
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     Directory not found or incomplete pathname
-        wPrErr              -44     Hardware volume lock
-        vLckdErr            -46     Software volume lock
-        dupFNErr            -48     Duplicate filename and version
-        dirNFErrdirNFErr    -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   A directory exists with that name
-    
-    __________
-    
-    Also see:   HCreateMinimum
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-ExchangeFiles(
-  short              vRefNum,
-  long               srcDirID,
-  ConstStr255Param   srcName,
-  long               dstDirID,
-  ConstStr255Param   dstName);
-
-
-/*
-    The ExchangeFiles function swaps the data in two files on the same
-    volume by changing some of the information in the volume catalog and,
-    if the files are open, in the file control blocks.
-
-    vRefNum     input:  Volume specification.
-    srcDirID    input:  Source directory ID.
-    srcName     input:  Source file name.
-    dstDirID    input:  Destination directory ID.
-    dstName     input:  Destination file name.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     Function not supported by volume
-        volOfflinErr        -53     Volume is offline
-        wrgVolTypErr        -123    Not an HFS volume
-        diffVolErr          -1303   Files on different volumes
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Object is a directory, not a file
-        afpSameObjectErr    -5038   Source and destination are the same
-
-    __________
-    
-    Also see:   FSpExchangeFilesCompat
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-ResolveFileIDRef(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  long               fileID,
-  long *             parID,
-  StringPtr          fileName);
-
-
-/*
-    The ResolveFileIDRef function returns the filename and parent directory ID
-    of the file with the specified file ID reference.
-    
-    volName input:  A pointer to the name of a mounted volume
-                    or nil.
-    vRefNum input:  Volume specification.
-    fileID  input:  The file ID reference.
-    parID   output: The parent directory ID of the file.
-    name    input:  Points to a buffer (minimum Str63) where the filename
-                    is to be returned or must be nil.
-            output: The filename.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        fnfErr              -43     File not found
-        paramErr            -50     Function not supported by volume
-        volOfflinErr        -53     Volume is offline
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        wrgVolTypErr        -123    Not an HFS volume
-        fidNotFoundErr      -1300   File ID reference not found
-        notAFileErr         -1302   Specified file is a directory
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Specified file is a directory
-        afpIDNotFound       -5034   File ID reference not found
-        afpBadIDErr         -5039   File ID reference not found
-    
-    __________
-    
-    Also see:   FSpResolveFileIDRef, CreateFileIDRef, FSpCreateFileIDRef,
-                DeleteFileIDRef
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpResolveFileIDRef(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  long               fileID,
-  FSSpecPtr          spec);
-
-
-/*
-    The FSpResolveFileIDRef function fills in an FSSpec with the location
-    of the file with the specified file ID reference.
-    
-    volName input:  A pointer to the name of a mounted volume
-                    or nil.
-    vRefNum input:  Volume specification.
-    fileID  input:  The file ID reference.
-    spec    input:  A pointer to a FSSpec record.
-            output: A file system specification to be filled in by
-                    FSpResolveFileIDRef.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        fnfErr              -43     File not found
-        paramErr            -50     Function not supported by volume or
-                                    no default volume
-        volOfflinErr        -53     Volume is offline
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        wrgVolTypErr        -123    Not an HFS volume
-        fidNotFoundErr      -1300   File ID reference not found
-        notAFileErr         -1302   Specified file is a directory
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Specified file is a directory
-        afpIDNotFound       -5034   File ID reference not found
-        afpBadIDErr         -5039   File ID reference not found
-    
-    __________
-    
-    Also see:   ResolveFileIDRef, CreateFileIDRef, FSpCreateFileIDRef,
-                DeleteFileIDRef
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-CreateFileIDRef(
-  short              vRefNum,
-  long               parID,
-  ConstStr255Param   fileName,
-  long *             fileID);
-
-
-/*
-    The CreateFileIDRef function creates a file ID reference for the
-    specified file, or if a file ID reference already exists, supplies
-    the file ID reference and returns the result code fidExists or afpIDExists.
-
-    vRefNum     input:  Volume specification.
-    parID       input:  Directory ID.
-    fileName    input:  The name of the file.
-    fileID      output: The file ID reference (if result is noErr,
-                        fidExists, or afpIDExists).
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        fnfErr              -43     File not found
-        wPrErr              -44     Hardware volume lock
-        vLckdErr            -46     Software volume lock
-        paramErr            -50     Function not supported by volume
-        volOfflinErr        -53     Volume is offline
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        wrgVolTypErr        -123    Not an HFS volume
-        fidExists           -1301   File ID reference already exists
-        notAFileErrn        -1302   Specified file is a directory
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Specified file is a directory
-        afpIDExists         -5035   File ID reference already exists
-    
-    __________
-    
-    Also see:   FSpResolveFileIDRef, ResolveFileIDRef, FSpCreateFileIDRef,
-                DeleteFileIDRef
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpCreateFileIDRef(
-  const FSSpec *  spec,
-  long *          fileID);
-
-
-/*
-    The FSpCreateFileIDRef function creates a file ID reference for the
-    specified file, or if a file ID reference already exists, supplies
-    the file ID reference and returns the result code fidExists or afpIDExists.
-
-    spec        input:  An FSSpec record specifying the file.
-    fileID      output: The file ID reference (if result is noErr,
-                        fidExists, or afpIDExists).
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        fnfErr              -43     File not found
-        wPrErr              -44     Hardware volume lock
-        vLckdErr            -46     Software volume lock
-        paramErr            -50     Function not supported by volume
-        volOfflinErr        -53     Volume is offline
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        wrgVolTypErr        -123    Not an HFS volume
-        fidExists           -1301   File ID reference already exists
-        notAFileErrn        -1302   Specified file is a directory
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Specified file is a directory
-        afpIDExists         -5035   File ID reference already exists
-    
-    __________
-    
-    Also see:   FSpResolveFileIDRef, ResolveFileIDRef, CreateFileIDRef,
-                DeleteFileIDRef
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-DeleteFileIDRef(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  long               fileID);
-
-
-/*
-    The DeleteFileIDRef function deletes a file ID reference.
-
-    volName input:  A pointer to the name of a mounted volume
-                    or nil.
-    vRefNum input:  Volume specification.
-    fileID  input:  The file ID reference.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        fnfErr              -43     File not found
-        wPrErr              -44     Hardware volume lock
-        vLckdErr            -46     Software volume lock
-        paramErr            -50     Function not supported by volume
-        volOfflinErr        -53     Volume is offline
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        wrgVolTypErr        -123    Function is not supported by volume
-        fidNotFoundErr      -1300   File ID reference not found
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Specified file is a directory
-        afpIDNotFound       -5034   File ID reference not found
-    
-    __________
-    
-    Also see:   FSpResolveFileIDRef, ResolveFileIDRef, CreateFileIDRef,
-                FSpCreateFileIDRef
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FlushFile(short refNum);
-
-
-/*
-    The FlushFile function writes the contents of a file's access path
-    buffer (the fork data) to the volume. Note: some of the file's catalog
-    information stored on the volume may not be correct until FlushVol
-    is called.
-
-    refNum  input:  The file reference number of an open file.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        fnOpnErr            -38     File not open
-        fnfErr              -43     File not found
-        rfNumErr            -51     Bad reference number
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-LockRange(
-  short   refNum,
-  long    rangeLength,
-  long    rangeStart);
-
-
-/*
-    The LockRange function locks (denies access to) a portion of a file
-    that was opened with shared read/write permission.
-
-    refNum      input:  The file reference number of an open file.
-    rangeLength input:  The number of bytes in the range.
-    rangeStart  input:  The starting byte in the range to lock.
-    
-    Result Codes
-        noErr               0       No error
-        ioErr               -36     I/O error
-        fnOpnErr            -38     File not open
-        eofErr              -39     Logical end-of-file reached
-        fLckdErr            -45     File is locked by another user
-        paramErr            -50     Negative ioReqCount
-        rfNumErr            -51     Bad reference number
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        volGoneErr          -124    Server volume has been disconnected
-        afpNoMoreLocks      -5015   No more ranges can be locked
-        afpRangeOverlap     -5021   Part of range is already locked
-
-    __________
-    
-    Also see:   UnlockRange
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-UnlockRange(
-  short   refNum,
-  long    rangeLength,
-  long    rangeStart);
-
-
-/*
-    The UnlockRange function unlocks (allows access to) a previously locked
-    portion of a file that was opened with shared read/write permission.
-
-    refNum      input:  The file reference number of an open file.
-    rangeLength input:  The number of bytes in the range.
-    rangeStart  input:  The starting byte in the range to unlock.
-    
-    Result Codes
-        noErr               0       No error
-        ioErr               -36     I/O error
-        fnOpnErr            -38     File not open
-        eofErr              -39     Logical end-of-file reached
-        paramErr            -50     Negative ioReqCount
-        rfNumErr            -51     Bad reference number
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        volGoneErr          -124    Server volume has been disconnected
-        afpRangeNotLocked   -5020   Specified range was not locked
-
-    __________
-    
-    Also see:   LockRange
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetForeignPrivs(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  void *             foreignPrivBuffer,
-  long *             foreignPrivSize,
-  long *             foreignPrivInfo1,
-  long *             foreignPrivInfo2,
-  long *             foreignPrivInfo3,
-  long *             foreignPrivInfo4);
-
-
-/*
-    The GetForeignPrivs function retrieves the native access-control
-    information for a file or directory stored on a volume managed by
-    a foreign file system.
-    
-    vRefNum             input:  Volume specification.
-    dirID               input:  Directory ID.
-    name                input:  Pointer to object name, or nil when dirID
-                                specifies a directory that's the object.
-    foreignPrivBuffer   input:  Pointer to buffer where the privilege
-                                information is returned.
-                        output: Privilege information.
-    foreignPrivSize     input:  Size of buffer pointed to by
-                                foreignPrivBuffer.
-                        output: Amount of buffer actually used.
-    foreignPrivInfo1    output: Information specific to privilege model.
-    foreignPrivInfo2    output: Information specific to privilege model.
-    foreignPrivInfo3    output: Information specific to privilege model.
-    foreignPrivInfo4    output: Information specific to privilege model.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        paramErr            -50     Volume is HFS or MFS (that is, it has
-                                    no foreign privilege model), or foreign
-                                    volume does not support these calls
-    
-    __________
-    
-    Also see:   FSpGetForeignPrivs, SetForeignPrivs, FSpSetForeignPrivs
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpGetForeignPrivs(
-  const FSSpec *  spec,
-  void *          foreignPrivBuffer,
-  long *          foreignPrivSize,
-  long *          foreignPrivInfo1,
-  long *          foreignPrivInfo2,
-  long *          foreignPrivInfo3,
-  long *          foreignPrivInfo4);
-
-
-/*
-    The FSpGetForeignPrivs function retrieves the native access-control
-    information for a file or directory stored on a volume managed by
-    a foreign file system.
-    
-    spec                input:  An FSSpec record specifying the object.
-    foreignPrivBuffer   input:  Pointer to buffer where the privilege
-                                information is returned.
-                        output: Privilege information.
-    foreignPrivSize     input:  Size of buffer pointed to by
-                                foreignPrivBuffer.
-                        output: Amount of buffer actually used.
-    foreignPrivInfo1    output: Information specific to privilege model.
-    foreignPrivInfo2    output: Information specific to privilege model.
-    foreignPrivInfo3    output: Information specific to privilege model.
-    foreignPrivInfo4    output: Information specific to privilege model.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        paramErr            -50     Volume is HFS or MFS (that is, it has
-                                    no foreign privilege model), or foreign
-                                    volume does not support these calls
-    
-    __________
-    
-    Also see:   GetForeignPrivs, SetForeignPrivs, FSpSetForeignPrivs
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-SetForeignPrivs(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  const void *       foreignPrivBuffer,
-  long *             foreignPrivSize,
-  long               foreignPrivInfo1,
-  long               foreignPrivInfo2,
-  long               foreignPrivInfo3,
-  long               foreignPrivInfo4);
-
-
-/*
-    The SetForeignPrivs function changes the native access-control
-    information for a file or directory stored on a volume managed by
-    a foreign file system.
-    
-    vRefNum             input:  Volume specification.
-    dirID               input:  Directory ID.
-    name                input:  Pointer to object name, or nil when dirID
-                                specifies a directory that's the object.
-    foreignPrivBuffer   input:  Pointer to privilege information buffer.
-    foreignPrivSize     input:  Size of buffer pointed to by
-                                foreignPrivBuffer.
-                        output: Amount of buffer actually used.
-    foreignPrivInfo1    input:  Information specific to privilege model.
-    foreignPrivInfo2    input:  Information specific to privilege model.
-    foreignPrivInfo3    input:  Information specific to privilege model.
-    foreignPrivInfo4    input:  Information specific to privilege model.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        paramErr            -50     Volume is HFS or MFS (that is, it has
-                                    no foreign privilege model), or foreign
-                                    volume does not support these calls
-    
-    __________
-    
-    Also see:   GetForeignPrivs, FSpGetForeignPrivs, FSpSetForeignPrivs
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpSetForeignPrivs(
-  const FSSpec *  spec,
-  const void *    foreignPrivBuffer,
-  long *          foreignPrivSize,
-  long            foreignPrivInfo1,
-  long            foreignPrivInfo2,
-  long            foreignPrivInfo3,
-  long            foreignPrivInfo4);
-
-
-/*
-    The FSpSetForeignPrivs function changes the native access-control
-    information for a file or directory stored on a volume managed by
-    a foreign file system.
-    
-    spec                input:  An FSSpec record specifying the object.
-    foreignPrivBuffer   input:  Pointer to privilege information buffer.
-    foreignPrivSize     input:  Size of buffer pointed to by
-                                foreignPrivBuffer.
-                        output: Amount of buffer actually used.
-    foreignPrivInfo1    input:  Information specific to privilege model.
-    foreignPrivInfo2    input:  Information specific to privilege model.
-    foreignPrivInfo3    input:  Information specific to privilege model.
-    foreignPrivInfo4    input:  Information specific to privilege model.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        paramErr            -50     Volume is HFS or MFS (that is, it has
-                                    no foreign privilege model), or foreign
-                                    volume does not support these calls
-    
-    __________
-    
-    Also see:   GetForeignPrivs, FSpGetForeignPrivs, SetForeignPrivs
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-HGetLogInInfo(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  short *            loginMethod,
-  StringPtr          userName);
-
-
-/*
-    The HGetLogInInfo function retrieves the login method and user name
-    used to log on to a particular shared volume.
-    
-    volName     input:  A pointer to the name of a mounted volume
-                        or nil.
-    vRefNum     input:  The volume reference number.
-    loginMethod output: The login method used (kNoUserAuthentication,
-                        kPassword, kEncryptPassword, or
-                        kTwoWayEncryptPassword).
-    userName    input:  Points to a buffer (minimum Str31) where the user
-                        name is to be returned or must be nil.
-                output: The user name.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Specified volume doesnÕt exist
-        paramErr            -50     Function not supported by volume
-    
-    __________
-    
-    Also see:   HGetDirAccess, FSpGetDirAccess, HSetDirAccess,
-                FSpSetDirAccess, HMapName, HMapID
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-HGetDirAccess(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  long *             ownerID,
-  long *             groupID,
-  long *             accessRights);
-
-
-/*
-    The HGetDirAccess function retrieves the directory access control
-    information for a directory on a shared volume.
-    
-    vRefNum         input:  Volume specification.
-    dirID           input:  Directory ID.
-    name            input:  Pointer to directory name, or nil if dirID
-                            specifies the directory.
-    ownerID         output: The directory's owner ID.
-    groupID         output: The directory's group ID or
-                            0 if no group affiliation.
-    accessRights    output: The directory's access rights.
-    
-    Result Codes
-        noErr               0       No error
-        fnfErr              -43     Directory not found
-        paramErr            -50     Function not supported by volume
-        afpAccessDenied     -5000   User does not have the correct access
-                                    to the directory
-    
-    __________
-    
-    Also see:   HGetLogInInfo, FSpGetDirAccess, HSetDirAccess,
-                FSpSetDirAccess, HMapName, HMapID
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpGetDirAccess(
-  const FSSpec *  spec,
-  long *          ownerID,
-  long *          groupID,
-  long *          accessRights);
-
-
-/*
-    The FSpGetDirAccess function retrieves the directory access control
-    information for a directory on a shared volume.
-    
-    spec            input:  An FSSpec record specifying the directory.
-    ownerID         output: The directory's owner ID.
-    groupID         output: The directory's group ID or
-                            0 if no group affiliation.
-    accessRights    output: The directory's access rights.
-    
-    Result Codes
-        noErr               0       No error
-        fnfErr              -43     Directory not found
-        paramErr            -50     Function not supported by volume
-        afpAccessDenied     -5000   User does not have the correct access
-                                    to the directory
-    
-    __________
-    
-    Also see:   HGetLogInInfo, HGetDirAccess, HSetDirAccess,
-                FSpSetDirAccess, HMapName, HMapID
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-HSetDirAccess(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  long               ownerID,
-  long               groupID,
-  long               accessRights);
-
-
-/*
-    The HSetDirAccess function changes the directory access control
-    information for a directory on a shared volume. You must own a directory
-    to change its access control information.
-    
-    vRefNum         input:  Volume specification.
-    dirID           input:  Directory ID.
-    name            input:  Pointer to directory name, or nil if dirID
-                            specifies the directory.
-    ownerID         input:  The directory's owner ID.
-    groupID         input:  The directory's group ID or
-                            0 if no group affiliation.
-    accessRights    input:  The directory's access rights.
-    
-    Result Codes
-        noErr               0       No error
-        fnfErr              -43     Directory not found
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     Parameter error
-        afpAccessDenied     -5000   User does not have the correct access
-                                    to the directory
-        afpObjectTypeErr    -5025   Object is a file, not a directory
-    
-    __________
-    
-    Also see:   HGetLogInInfo, HGetDirAccess, FSpGetDirAccess,
-                FSpSetDirAccess, HMapName, HMapID
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpSetDirAccess(
-  const FSSpec *  spec,
-  long            ownerID,
-  long            groupID,
-  long            accessRights);
-
-
-/*
-    The FSpSetDirAccess function changes the directory access control
-    information for a directory on a shared volume. You must own a directory
-    to change its access control information.
-    
-    spec            input:  An FSSpec record specifying the directory.
-    ownerID         input:  The directory's owner ID.
-    groupID         input:  The directory's group ID or
-                            0 if no group affiliation.
-    accessRights    input:  The directory's access rights.
-    
-    Result Codes
-        noErr               0       No error
-        fnfErr              -43     Directory not found
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     Parameter error
-        afpAccessDenied     -5000   User does not have the correct access
-                                    to the directory
-        afpObjectTypeErr    -5025   Object is a file, not a directory
-    
-    __________
-    
-    Also see:   HGetLogInInfo, HGetDirAccess, FSpGetDirAccess, HSetDirAccess,
-                HMapName, HMapID
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-HMapID(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  long               ugID,
-  short              objType,
-  StringPtr          name);
-
-
-/*
-    The HMapID function determines the name of a user or group if you know
-    the user or group ID.
-    
-    volName     input:  A pointer to the name of a mounted volume
-                        or nil.
-    vRefNum     input:  Volume specification.
-    objType     input:  The mapping function code: 1 if you're mapping a
-                        user ID to a user name or 2 if you're mapping a
-                        group ID to a group name.
-    name        input:  Points to a buffer (minimum Str31) where the user
-                        or group name is to be returned or must be nil.
-                output: The user or group name.
-    
-    Result Codes
-        noErr               0       No error
-        fnfErr              -43     Unrecognizable owner or group name
-        paramErr            -50     Function not supported by volume
-    
-    __________
-    
-    Also see:   HGetLogInInfo, HGetDirAccess, FSpGetDirAccess, HSetDirAccess,
-                FSpSetDirAccess, HMapName
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-HMapName(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  ConstStr255Param   name,
-  short              objType,
-  long *             ugID);
-
-
-/*
-    The HMapName function determines the user or group ID if you know the
-    user or group name.
-    
-    volName     input:  A pointer to the name of a mounted volume
-                        or nil.
-    vRefNum     input:  Volume specification.
-    name        input:  The user or group name.
-    objType     input:  The mapping function code: 3 if you're mapping a
-                        user name to a user ID or 4 if you're mapping a
-                        group name to a group ID.
-    ugID        output: The user or group ID.
-
-    Result Codes
-        noErr               0       No error
-        fnfErr              -43     Unrecognizable owner or group name
-        paramErr            -50     Function not supported by volume
-    
-    __________
-    
-    Also see:   HGetLogInInfo, HGetDirAccess, FSpGetDirAccess, HSetDirAccess,
-                FSpSetDirAccess, HMapID
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-HCopyFile(
-  short              srcVRefNum,
-  long               srcDirID,
-  ConstStr255Param   srcName,
-  short              dstVRefNum,
-  long               dstDirID,
-  ConstStr255Param   dstPathname,
-  ConstStr255Param   copyName);
-
-
-/*
-    The HCopyFile function duplicates a file and optionally renames it.
-    The source and destination volumes must be on the same file server.
-    This function instructs the server to copy the file.
-    
-    srcVRefNum  input:  Source volume specification.
-    srcDirID    input:  Source directory ID.
-    srcName     input:  Source file name.
-    dstVRefNum  input:  Destination volume specification.
-    dstDirID    input:  Destination directory ID.
-    dstPathname input:  Pointer to destination directory name, or
-                        nil when dstDirID specifies a directory.
-    copyName    input:  Points to the new file name if the file is to be
-                        renamed or nil if the file isn't to be renamed.
-    
-    Result Codes
-        noErr               0       No error
-        dskFulErr           -34     Destination volume is full
-        fnfErr              -43     Source file not found, or destination
-                                    directory does not exist
-        vLckdErr            -46     Destination volume is read-only
-        fBsyErr             -47     The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        dupFNErr            -48     Destination file already exists
-        paramErr            -50     Function not supported by volume
-        wrgVolTypErr        -123    Function not supported by volume
-        afpAccessDenied     -5000   The user does not have the right to
-                                    read the source or write to the
-                                    destination
-        afpDenyConflict     -5006   The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        afpObjectTypeErr    -5025   Source is a directory
-    
-    __________
-    
-    Also see:   FSpCopyFile, FileCopy, FSpFileCopy
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpCopyFile(
-  const FSSpec *     srcSpec,
-  const FSSpec *     dstSpec,
-  ConstStr255Param   copyName);
-
-
-/*
-    The FSpCopyFile function duplicates a file and optionally renames it.
-    The source and destination volumes must be on the same file server.
-    This function instructs the server to copy the file.
-    
-    srcSpec     input:  An FSSpec record specifying the source file.
-    dstSpec     input:  An FSSpec record specifying the destination
-                        directory.
-    copyName    input:  Points to the new file name if the file is to be
-                        renamed or nil if the file isn't to be renamed.
-    
-    Result Codes
-        noErr               0       No error
-        dskFulErr           -34     Destination volume is full
-        fnfErr              -43     Source file not found, or destination
-                                    directory does not exist
-        vLckdErr            -46     Destination volume is read-only
-        fBsyErr             -47     The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        dupFNErr            -48     Destination file already exists
-        paramErr            -50     Function not supported by volume
-        wrgVolTypErr        -123    Function not supported by volume
-        afpAccessDenied     -5000   The user does not have the right to
-                                    read the source or write to the
-                                    destination
-        afpDenyConflict     -5006   The source or destination file could
-                                    not be opened with the correct access
-                                    modes
-        afpObjectTypeErr    -5025   Source is a directory
-    
-    __________
-    
-    Also see:   HCopyFile, FileCopy, FSpFileCopy
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-HMoveRename(
-  short              vRefNum,
-  long               srcDirID,
-  ConstStr255Param   srcName,
-  long               dstDirID,
-  ConstStr255Param   dstpathName,
-  ConstStr255Param   copyName);
-
-
-/*
-    The HMoveRename function moves a file or directory and optionally
-    renames it. The source and destination locations must be on the same
-    shared volume.
-    
-    vRefNum     input:  Volume specification.
-    srcDirID    input:  Source directory ID.
-    srcName     input:  The source object name.
-    dstDirID    input:  Destination directory ID.
-    dstName     input:  Pointer to destination directory name, or
-                        nil when dstDirID specifies a directory.
-    copyName    input:  Points to the new name if the object is to be
-                        renamed or nil if the object isn't to be renamed.
-    
-    Result Codes
-        noErr               0       No error
-        fnfErr              -43     Source file or directory not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Destination volume is read-only
-        dupFNErr            -48     Destination already exists
-        paramErr            -50     Function not supported by volume
-        badMovErr           -122    Attempted to move directory into
-                                    offspring
-        afpAccessDenied     -5000   The user does not have the right to
-                                    move the file  or directory
-    
-    __________
-    
-    Also see:   FSpMoveRename, HMoveRenameCompat, FSpMoveRenameCompat
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpMoveRename(
-  const FSSpec *     srcSpec,
-  const FSSpec *     dstSpec,
-  ConstStr255Param   copyName);
-
-
-/*
-    The FSpMoveRename function moves a file or directory and optionally
-    renames it. The source and destination locations must be on the same
-    shared volume.
-    
-    srcSpec     input:  An FSSpec record specifying the source object.
-    dstSpec     input:  An FSSpec record specifying the destination
-                        directory.
-    copyName    input:  Points to the new name if the object is to be
-                        renamed or nil if the object isn't to be renamed.
-    
-    Result Codes
-        noErr               0       No error
-        fnfErr              -43     Source file or directory not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Destination volume is read-only
-        dupFNErr            -48     Destination already exists
-        paramErr            -50     Function not supported by volume
-        badMovErr           -122    Attempted to move directory into
-                                    offspring
-        afpAccessDenied     -5000   The user does not have the right to
-                                    move the file  or directory
-    
-    __________
-    
-    Also see:   HMoveRename, HMoveRenameCompat, FSpMoveRenameCompat
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetVolMountInfoSize(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  short *            size);
-
-
-/*
-    The GetVolMountInfoSize function determines the how much space the
-    program needs to allocate for a volume mounting information record.
-    
-    volName     input:  A pointer to the name of a mounted volume
-                        or nil.
-    vRefNum     input:  Volume specification.
-    size        output: The space needed (in bytes) of the volume mounting
-                        information record.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        paramErr            -50     Parameter error
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-
-    __________
-    
-    Also see:   GetVolMountInfo, VolumeMount BuildAFPVolMountInfo,
-                RetrieveAFPVolMountInfo
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetVolMountInfo(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  void *             volMountInfo);
-
-
-/*
-    The GetVolMountInfo function retrieves a volume mounting information
-    record containing all the information needed to mount the volume,
-    except for passwords.
-    
-    volName         input:  A pointer to the name of a mounted volume
-                            or nil.
-    vRefNum         input:  Volume specification.
-    volMountInfo    output: Points to a volume mounting information
-                            record where the mounting information is to
-                            be returned.
-    
-    Result Codes
-        noErr               0       No error    
-        nsvErr              -35     Volume not found    
-        paramErr            -50     Parameter error 
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-
-    __________
-    
-    Also see:   GetVolMountInfoSize, VolumeMount, BuildAFPVolMountInfo,
-                RetrieveAFPVolMountInfo
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-VolumeMount(
-  const void *  volMountInfo,
-  short *       vRefNum);
-
-
-/*
-    The VolumeMount function mounts a volume using a volume mounting
-    information record.
-    
-    volMountInfo    input:  Points to a volume mounting information record.
-    vRefNum         output: A volume reference number.
-    
-    Result Codes
-        noErr               0       No error
-        notOpenErr          -28     AppleTalk is not open
-        nsvErr              -35     Volume not found
-        paramErr            -50     Parameter error; typically, zone, server,
-                                    and volume name combination is not valid
-                                    or not complete, or the user name is not
-                                    recognized
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        memFullErr          -108    Not enough memory to create a new volume
-                                    control block for mounting the volume
-        afpBadUAM           -5002   User authentication method is unknown
-        afpBadVersNum       -5003   Workstation is using an AFP version that
-                                    the server doesnÕt recognize
-        afpNoServer         -5016   Server is not responding
-        afpUserNotAuth      -5023   User authentication failed (usually,
-                                    password  is not correct)
-        afpPwdExpired       -5042   Password has expired on server
-        afpBadDirIDType     -5060   Not a fixed directory ID volume
-        afpCantMountMoreSrvrs -5061 Maximum number of volumes has been
-                                    mounted
-        afpAlreadyMounted   -5062   Volume already mounted
-        afpSameNodeErr      -5063   Attempt to log on to a server running
-                                    on the same machine
-
-    __________
-    
-    Also see:   GetVolMountInfoSize, GetVolMountInfo, BuildAFPVolMountInfo,
-                RetrieveAFPVolMountInfo
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-Share(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The Share function establishes a local volume or directory as a
-    share point.
-
-    vRefNum         input:  Volume specification.
-    dirID           input:  Directory ID.
-    name            input:  Pointer to directory name, or nil if dirID
-                            specifies the directory.
-    
-    Result Codes
-        noErr               0       No error    
-        tmfoErr             -42     Too many share points   
-        fnfErr              -43     File not found  
-        dupFNErr            -48     Already a share point with this name    
-        paramErr            -50     Function not supported by volume    
-        dirNFErrdirNFErr    -120    Directory not found 
-        afpAccessDenied     -5000   This directory cannot be shared 
-        afpObjectTypeErr    -5025   Object was a file, not a directory  
-        afpContainsSharedErr -5033  The directory contains a share point    
-        afpInsideSharedErr  -5043   The directory is inside a shared directory  
-
-    __________
-    
-    Also see:   FSpShare, Unshare, FSpUnshare
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpShare(const FSSpec * spec);
-
-
-/*
-    The FSpShare function establishes a local volume or directory as a
-    share point.
-
-    spec    input:  An FSSpec record specifying the share point.
-    
-    Result Codes
-        noErr               0       No error    
-        tmfoErr             -42     Too many share points   
-        fnfErr              -43     File not found  
-        dupFNErr            -48     Already a share point with this name    
-        paramErr            -50     Function not supported by volume    
-        dirNFErrdirNFErr    -120    Directory not found 
-        afpAccessDenied     -5000   This directory cannot be shared 
-        afpObjectTypeErr    -5025   Object was a file, not a directory  
-        afpContainsSharedErr -5033  The directory contains a share point    
-        afpInsideSharedErr  -5043   The directory is inside a shared directory  
-
-    __________
-    
-    Also see:   Share, Unshare, FSpUnshare
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-Unshare(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The Unshare function removes a share point.
-
-    vRefNum         input:  Volume specification.
-    dirID           input:  Directory ID.
-    name            input:  Pointer to directory name, or nil if dirID
-                            specifies the directory.
-    
-    Result Codes
-        noErr               0       No error    
-        fnfErr              -43     File not found  
-        paramErr            -50     Function not supported by volume    
-        dirNFErrdirNFErr    -120    Directory not found 
-        afpObjectTypeErr    -5025   Object was a file, not a directory; or,
-                                    this directory is not a share point 
-
-    __________
-    
-    Also see:   Share, FSpShare, FSpUnshare
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpUnshare(const FSSpec * spec);
-
-
-/*
-    The FSpUnshare function removes a share point.
-
-    spec    input:  An FSSpec record specifying the share point.
-    
-    Result Codes
-        noErr               0       No error    
-        fnfErr              -43     File not found  
-        paramErr            -50     Function not supported by volume    
-        dirNFErrdirNFErr    -120    Directory not found 
-        afpObjectTypeErr    -5025   Object was a file, not a directory; or,
-                                    this directory is not a share point 
-
-    __________
-    
-    Also see:   Share, FSpShare, Unshare
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetUGEntry(
-  short       objType,
-  StringPtr   objName,
-  long *      objID);
-
-
-/*
-    The GetUGEntry function retrieves user or group entries from the
-    local file server.
-
-    objType     input:  The object type: -1 = group; 0 = user
-    objName     input:  Points to a buffer (minimum Str31) where the user
-                        or group name is to be returned or must be nil.
-                output: The user or group name.
-    objID       input:  O to get the first user or group. If the entry objID
-                        last returned by GetUGEntry is passed, then user or
-                        group whose alphabetically next in the list of entries
-                        is returned.
-                output: The user or group ID.
-    
-    Result Codes
-        noErr               0       No error    
-        fnfErr              -43     No more users or groups 
-        paramErr            -50     Function not supported; or, ioObjID is
-                                    negative    
-
-    __________
-    
-    Also see:   GetUGEntries
-*/
-
-/*****************************************************************************/
-
-#include "OptimizationEnd.h"
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=reset
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(pop)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack()
-#endif
-
-#ifdef PRAGMA_IMPORT_OFF
-#pragma import off
-#elif PRAGMA_IMPORT
-#pragma import reset
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* __MOREFILES__ */
-
diff --git a/src/mac/morefile/MoreFilesExtras.c b/src/mac/morefile/MoreFilesExtras.c
deleted file mode 100644 (file)
index 05a0ce9..0000000
+++ /dev/null
@@ -1,3632 +0,0 @@
-/*
-       File:           MoreFilesExtras.c
-
-       Contains:       A collection of useful high-level File Manager routines
-
-       Version:        MoreFiles
-
-       Copyright:      © 1992-2001 by Apple Computer, Inc., all rights reserved.
-
-       You may incorporate this sample code into your applications without
-       restriction, though the sample code has been provided "AS IS" and the
-       responsibility for its operation is 100% yours.  However, what you are
-       not permitted to do is to redistribute the source as "DSC Sample Code"
-       after having made changes. If you're going to re-distribute the source,
-       we require that you make it clear in the source that the code was
-       descended from Apple Sample Code, but that you've made changes.
-
-       File Ownership:
-
-               DRI:                            Jim Luther
-
-               Other Contact:          Apple Macintosh Developer Technical Support
-                                                       <http://developer.apple.com/bugreporter/>
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-
-       Change History (most recent first):
-
-                <2>      2/7/01        JL              [2500429]  Changed null output parameters to real variables when
-                                                                       calling GetSharedLibrary to prevent crashes with older versions
-                                                                       of CFM. Added standard header. Updated names of includes. Added
-                                                                       C function implementations of accessors that used to be macros
-                                                                       since the generated Pascal headers no longer contain
-                                                                       implementations. Updated various other routines to use new
-                                                                       calling convention of the accessor functions.
-               <1>             12/06/99        JL              MoreFiles 1.5.
-*/
-
-#include <MacTypes.h>
-#if !TARGET_CARBON
-#include <Traps.h>
-#include <FSM.h>
-#include <Disks.h>
-#else
-#include <HFSVolumes.h>
-#endif
-#include <OSUtils.h>
-#include <MacErrors.h>
-#include <MacMemory.h>
-#include <Files.h>
-#include <Devices.h>
-#include <Finder.h>
-#include <Folders.h>
-#include <Gestalt.h>
-#include <TextUtils.h>
-#include <Script.h>
-#include <Math64.h>
-#include <CodeFragments.h>
-#include <stddef.h>
-
-#define        __COMPILINGMOREFILES
-
-#include "MoreFiles.h"
-#include "MoreDesktopMgr.h"
-#include "FSpCompat.h"
-
-#include "MoreFilesExtras.h"
-
-/*****************************************************************************/
-
-/* Functions to get information out of GetVolParmsInfoBuffer. */
-
-/* version 1 field getters */
-
-pascal short   GetVolParmsInfoVersion(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( volParms->vMVersion );
-}
-
-pascal long    GetVolParmsInfoAttrib(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( volParms->vMAttrib );
-}
-
-pascal Handle  GetVolParmsInfoLocalHand(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( volParms->vMLocalHand );
-}
-
-pascal long    GetVolParmsInfoServerAdr(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( volParms->vMServerAdr );
-}
-
-/* version 2 field getters (assume zero result if version < 2) */
-
-pascal long    GetVolParmsInfoVolumeGrade(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMVersion >= 2) ? volParms->vMVolumeGrade : 0 );
-}
-
-pascal long    GetVolParmsInfoForeignPrivID(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMVersion >= 2) ? volParms->vMForeignPrivID : 0 );
-}
-
-/* version 3 field getters (assume zero result if version < 3) */
-
-pascal long    GetVolParmsInfoExtendedAttributes(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMVersion >= 3) ? volParms->vMExtendedAttributes : 0 );
-}
-
-/* attribute bits supported by all versions of GetVolParmsInfoBuffer */
-
-pascal Boolean isNetworkVolume(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( volParms->vMServerAdr != 0 );
-}
-
-pascal Boolean hasLimitFCBs(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bLimitFCBs)) != 0 );
-}
-
-pascal Boolean hasLocalWList(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bLocalWList)) != 0 );
-}
-
-pascal Boolean hasNoMiniFndr(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bNoMiniFndr)) != 0 );
-}
-
-pascal Boolean hasNoVNEdit(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bNoVNEdit)) != 0 );
-}
-
-pascal Boolean hasNoLclSync(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bNoLclSync)) != 0 );
-}
-
-pascal Boolean hasTrshOffLine(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bTrshOffLine)) != 0 );
-}
-
-pascal Boolean hasNoSwitchTo(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bNoSwitchTo)) != 0 );
-}
-
-pascal Boolean hasNoDeskItems(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bNoDeskItems)) != 0 );
-}
-
-pascal Boolean hasNoBootBlks(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bNoBootBlks)) != 0 );
-}
-
-pascal Boolean hasAccessCntl(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bAccessCntl)) != 0 );
-}
-
-pascal Boolean hasNoSysDir(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bNoSysDir)) != 0 );
-}
-
-pascal Boolean hasExtFSVol(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bHasExtFSVol)) != 0 );
-}
-
-pascal Boolean hasOpenDeny(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bHasOpenDeny)) != 0 );
-}
-
-pascal Boolean hasCopyFile(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bHasCopyFile)) != 0 );
-}
-
-pascal Boolean hasMoveRename(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bHasMoveRename)) != 0 );
-}
-
-pascal Boolean hasDesktopMgr(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bHasDesktopMgr)) != 0 );
-}
-
-pascal Boolean hasShortName(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bHasShortName)) != 0 );
-}
-
-pascal Boolean hasFolderLock(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bHasFolderLock)) != 0 );
-}
-
-pascal Boolean hasPersonalAccessPrivileges(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bHasPersonalAccessPrivileges)) != 0 );
-}
-
-pascal Boolean hasUserGroupList(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bHasUserGroupList)) != 0 );
-}
-
-pascal Boolean hasCatSearch(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bHasCatSearch)) != 0 );
-}
-
-pascal Boolean hasFileIDs(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bHasFileIDs)) != 0 );
-}
-
-pascal Boolean hasBTreeMgr(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bHasBTreeMgr)) != 0 );
-}
-
-pascal Boolean hasBlankAccessPrivileges(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bHasBlankAccessPrivileges)) != 0 );
-}
-
-pascal Boolean supportsAsyncRequests(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bSupportsAsyncRequests)) != 0 );
-}
-
-pascal Boolean supportsTrashVolumeCache(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (volParms->vMAttrib & (1L << bSupportsTrashVolumeCache)) != 0 );
-}
-
-/* attribute bits supported by version 3 and greater versions of GetVolParmsInfoBuffer */
-
-pascal Boolean volIsEjectable(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (GetVolParmsInfoExtendedAttributes(volParms) & (1L << bIsEjectable)) != 0 );
-}
-
-pascal Boolean volSupportsHFSPlusAPIs(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsHFSPlusAPIs)) != 0 );
-}
-
-pascal Boolean volSupportsFSCatalogSearch(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsFSCatalogSearch)) != 0 );
-}
-
-pascal Boolean volSupportsFSExchangeObjects(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsFSExchangeObjects)) != 0 );
-}
-
-pascal Boolean volSupports2TBFiles(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupports2TBFiles)) != 0 );
-}
-
-pascal Boolean volSupportsLongNames(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsLongNames)) != 0 );
-}
-
-pascal Boolean volSupportsMultiScriptNames(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsMultiScriptNames)) != 0 );
-}
-
-pascal Boolean volSupportsNamedForks(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsNamedForks)) != 0 );
-}
-
-pascal Boolean volSupportsSubtreeIterators(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsSubtreeIterators)) != 0 );
-}
-
-pascal Boolean volL2PCanMapFileBlocks(const GetVolParmsInfoBuffer *volParms)
-{
-       return ( (GetVolParmsInfoExtendedAttributes(volParms) & (1L << bL2PCanMapFileBlocks)) != 0 );
-}
-
-/*****************************************************************************/
-
-/* Functions for testing ioACUser bits. */
-
-pascal Boolean userIsOwner(SInt8 ioACUser)
-{
-       return ( (ioACUser & kioACUserNotOwnerMask) == 0 );
-}
-
-pascal Boolean userHasFullAccess(SInt8 ioACUser)
-{
-       return ( (ioACUser & acUserAccessMask) == acUserFull );
-}
-
-pascal Boolean userHasDropBoxAccess(SInt8 ioACUser)
-{
-       return ( (ioACUser & acUserAccessMask) == acUserDropBox );
-}
-
-pascal Boolean userHasBulletinBoard(SInt8 ioACUser)
-{
-       return ( (ioACUser & acUserAccessMask) == acUserBulletinBoard );
-}
-
-pascal Boolean userHasNoAccess(SInt8 ioACUser)
-{
-       return ( (ioACUser & acUserAccessMask) == acUserNone );
-}
-
-/*****************************************************************************/
-
-/* local data structures */
-
-/* The DeleteEnumGlobals structure is used to minimize the amount of
-** stack space used when recursively calling DeleteLevel and to hold
-** global information that might be needed at any time. */
-
-#if PRAGMA_STRUCT_ALIGN
-       #pragma options align=mac68k
-#endif //      PRAGMA_STRUCT_ALIGN
-struct DeleteEnumGlobals
-{
-       OSErr                   error;                          /* temporary holder of results - saves 2 bytes of stack each level */
-       Str63                   itemName;                       /* the name of the current item */
-       UniversalFMPB   myPB;                           /* the parameter block used for PBGetCatInfo calls */
-};
-#if PRAGMA_STRUCT_ALIGN
-       #pragma options align=reset
-#endif //      PRAGMA_STRUCT_ALIGN
-
-typedef struct DeleteEnumGlobals DeleteEnumGlobals;
-typedef DeleteEnumGlobals *DeleteEnumGlobalsPtr;
-
-/*****************************************************************************/
-
-/*
-**     CallPBXGetVolInfoSync is the glue code needed to make PBXGetVolInfoSync
-**     File Manager requests from CFM-based programs. Apple added PBXGetVolInfoSync
-**     to InterfaceLib in Mac OS 8.5, so if __MACOSEIGHTFIVEORLATER is defined,
-**     CallPBXGetVolInfoSync is defined back to PBXGetVolInfoSync.
-**
-**     Non-CFM 68K programs don't needs this glue (and won't get it) because
-**     they instead use the inline assembly glue found in the Files.h interface
-**     file.
-*/
-
-#if TARGET_API_MAC_CARBON || !TARGET_RT_MAC_CFM
-
-       // Carbon builds and 68K builds don't need this glue
-       #define CallPBXGetVolInfoSync PBXGetVolInfoSync
-
-#else  //      TARGET_API_MAC_CARBON || !TARGET_RT_MAC_CFM
-
-       #if     __WANTPASCALELIMINATION
-               #undef  pascal
-       #endif  //      __WANTPASCALELIMINATION
-       
-       /* This is exactly like the simple mixed mode glue in InterfaceLib in Mac OS 8.5 and 8.6 */
-       static pascal OSErr PBXGetVolInfoSyncGlue(XVolumeParamPtr paramBlock)
-       {
-               enum
-               {
-                       uppFSDispatchProcInfo = kRegisterBased
-                                | REGISTER_RESULT_LOCATION(kRegisterD0)
-                                | RESULT_SIZE(SIZE_CODE(sizeof(OSErr)))
-                                | REGISTER_ROUTINE_PARAMETER(1, kRegisterD0, SIZE_CODE(sizeof(long)))  /* selector */
-                                | REGISTER_ROUTINE_PARAMETER(2, kRegisterD1, SIZE_CODE(sizeof(long)))  /* trap word */
-                                | REGISTER_ROUTINE_PARAMETER(3, kRegisterA0, SIZE_CODE(sizeof(XVolumeParamPtr)))
-               };
-               
-               static UniversalProcPtr fsDispatchTrapAddress = NULL;
-               
-               /* Is this the first time we've been called? */
-               if ( fsDispatchTrapAddress == NULL )
-               {
-                       /* Yes - Get the trap address of _FSDispatch */
-                       fsDispatchTrapAddress = NGetTrapAddress(_FSDispatch, OSTrap);
-               }
-               return ( CallOSTrapUniversalProc(fsDispatchTrapAddress,
-                                                                                       uppFSDispatchProcInfo,
-                                                                                       kFSMXGetVolInfo,
-                                                                                       _FSDispatch,
-                                                                                       paramBlock) );
-       }
-       
-       /*
-       ** PBXGetVolInfoSync was added to the File Manager in System software 7.5.2.
-       ** However, PBXGetVolInfoSync wasn't added to InterfaceLib until Mac OS 8.5.
-       ** This wrapper calls PBXGetVolInfoSync if it is found in InterfaceLib;
-       ** otherwise, it calls PBXGetVolInfoSyncGlue. This ensures that your program
-       ** is calling the latest implementation of PBXGetVolInfoSync.
-       */
-       static pascal OSErr CallPBXGetVolInfoSync(XVolumeParamPtr paramBlock)
-       {
-               typedef pascal OSErr (*PBXGetVolInfoProcPtr) (XVolumeParamPtr paramBlock);
-               
-               OSErr                                           result;
-               CFragConnectionID                       connID;
-               Ptr                                                     mainAddr;
-               Str255                                          errMessage;
-               static PBXGetVolInfoProcPtr     PBXGetVolInfoSyncPtr = NULL;
-               
-               //* Is this the first time we've been called? */
-               if ( PBXGetVolInfoSyncPtr == NULL )
-               {
-                       /* Yes - Get our connection ID to InterfaceLib */
-                       result = GetSharedLibrary("\pInterfaceLib", kPowerPCCFragArch, kLoadCFrag, &connID, &mainAddr, errMessage);
-                       if ( result == noErr )
-                       {
-                               /* See if PBXGetVolInfoSync is in InterfaceLib */
-                               if ( FindSymbol(connID, "\pPBXGetVolInfoSync", &(Ptr)PBXGetVolInfoSyncPtr, NULL) != noErr )
-                               {
-                                       /* Use glue code if symbol isn't found */
-                                       PBXGetVolInfoSyncPtr = PBXGetVolInfoSyncGlue;
-                               }
-                       }
-               }
-               /* Call PBXGetVolInfoSync if present; otherwise, call PBXGetVolInfoSyncGlue */
-               return ( (*PBXGetVolInfoSyncPtr)(paramBlock) );
-       }
-
-       #if     __WANTPASCALELIMINATION
-               #define pascal  
-       #endif  //      __WANTPASCALELIMINATION
-
-#endif //      TARGET_API_MAC_CARBON || !TARGET_RT_MAC_CFM
-
-/*****************************************************************************/
-
-pascal void    TruncPString(StringPtr destination,
-                                                        ConstStr255Param source,
-                                                        short maxLength)
-{
-       short   charType;
-       
-       if ( source != NULL && destination != NULL )    /* don't do anything stupid */
-       {
-               if ( source[0] > maxLength )
-               {
-                       /* Make sure the string isn't truncated in the middle of */
-                       /* a multi-byte character. */
-                       while (maxLength != 0)
-                       {
-                               // Note: CharacterByteType's textOffset parameter is zero-based from the textPtr parameter
-                               charType = CharacterByteType((Ptr)&source[1], maxLength - 1, smSystemScript);
-                               if ( (charType == smSingleByte) || (charType == smLastByte) )
-                                       break;  /* source[maxLength] is now a valid last character */ 
-                               --maxLength;
-                       }
-               }
-               else
-               {
-                       maxLength = source[0];
-               }
-               /* Set the destination string length */
-               destination[0] = maxLength;
-               /* and copy maxLength characters (if needed) */
-               if ( source != destination )
-               {
-                       while ( maxLength != 0 )
-                       {
-                               destination[maxLength] = source[maxLength];
-                               --maxLength;
-                       }
-               }
-       }
-}
-
-/*****************************************************************************/
-
-pascal Ptr     GetTempBuffer(long buffReqSize,
-                                                 long *buffActSize)
-{
-       enum
-       {
-               kSlopMemory = 0x00008000        /* 32K - Amount of free memory to leave when allocating buffers */
-       };
-       Ptr     tempPtr;
-       
-       /* Make request a multiple of 1024 bytes */
-       buffReqSize = buffReqSize & 0xfffffc00;
-       
-       if ( buffReqSize < 0x00000400 )
-       {
-               /* Request was smaller than 1024 bytes - make it 1024 */
-               buffReqSize = 0x00000400;
-       }
-       
-       /* Attempt to allocate the memory */
-       tempPtr = NewPtr(buffReqSize);
-       
-       /* If request failed, go to backup plan */
-       if ( (tempPtr == NULL) && (buffReqSize > 0x00000400) )
-       {
-               /*
-               **      Try to get largest 1024-byte block available
-               **      leaving some slop for the toolbox if possible
-               */
-               long freeMemory = (FreeMem() - kSlopMemory) & 0xfffffc00;
-               
-               buffReqSize = MaxBlock() & 0xfffffc00;
-               
-               if ( buffReqSize > freeMemory )
-               {
-                       buffReqSize = freeMemory;
-               }
-               
-               if ( buffReqSize == 0 )
-               {
-                       buffReqSize = 0x00000400;
-               }
-               
-               tempPtr = NewPtr(buffReqSize);
-       }
-       
-       /* Return bytes allocated */
-       if ( tempPtr != NULL )
-       {
-               *buffActSize = buffReqSize;
-       }
-       else
-       {
-               *buffActSize = 0;
-       }
-       
-       return ( tempPtr );
-}
-
-/*****************************************************************************/
-
-/*
-**     GetVolumeInfoNoName uses pathname and vRefNum to call PBHGetVInfoSync
-**     in cases where the returned volume name is not needed by the caller.
-**     The pathname and vRefNum parameters are not touched, and the pb
-**     parameter is initialized by PBHGetVInfoSync except that ioNamePtr in
-**     the parameter block is always returned as NULL (since it might point
-**     to the local tempPathname).
-**
-**     I noticed using this code in several places, so here it is once.
-**     This reduces the code size of MoreFiles.
-*/
-pascal OSErr   GetVolumeInfoNoName(ConstStr255Param pathname,
-                                                                       short vRefNum,
-                                                                       HParmBlkPtr pb)
-{
-       Str255 tempPathname;
-       OSErr error;
-       
-       /* Make sure pb parameter is not NULL */ 
-       if ( pb != NULL )
-       {
-               pb->volumeParam.ioVRefNum = vRefNum;
-               if ( pathname == NULL )
-               {
-                       pb->volumeParam.ioNamePtr = NULL;
-                       pb->volumeParam.ioVolIndex = 0;         /* use ioVRefNum only */
-               }
-               else
-               {
-                       BlockMoveData(pathname, tempPathname, pathname[0] + 1); /* make a copy of the string and */
-                       pb->volumeParam.ioNamePtr = (StringPtr)tempPathname;    /* use the copy so original isn't trashed */
-                       pb->volumeParam.ioVolIndex = -1;        /* use ioNamePtr/ioVRefNum combination */
-               }
-               error = PBHGetVInfoSync(pb);
-               pb->volumeParam.ioNamePtr = NULL;       /* ioNamePtr may point to local tempPathname, so don't return it */
-       }
-       else
-       {
-               error = paramErr;
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-/*
-**     XGetVolumeInfoNoName uses pathname and vRefNum to call PBXGetVolInfoSync
-**     in cases where the returned volume name is not needed by the caller.
-**     The pathname and vRefNum parameters are not touched, and the pb
-**     parameter is initialized by PBXGetVolInfoSync except that ioNamePtr in
-**     the parameter block is always returned as NULL (since it might point
-**     to the local tempPathname).
-*/
-pascal OSErr   XGetVolumeInfoNoName(ConstStr255Param pathname,
-                                                                       short vRefNum,
-                                                                       XVolumeParamPtr pb)
-{
-       Str255 tempPathname;
-       OSErr error;
-       
-       /* Make sure pb parameter is not NULL */ 
-       if ( pb != NULL )
-       {
-               pb->ioVRefNum = vRefNum;
-               pb->ioXVersion = 0;                     /* this XVolumeParam version (0) */
-               if ( pathname == NULL )
-               {
-                       pb->ioNamePtr = NULL;
-                       pb->ioVolIndex = 0;             /* use ioVRefNum only */
-               }
-               else
-               {
-                       BlockMoveData(pathname, tempPathname, pathname[0] + 1); /* make a copy of the string and */
-                       pb->ioNamePtr = (StringPtr)tempPathname;        /* use the copy so original isn't trashed */
-                       pb->ioVolIndex = -1;    /* use ioNamePtr/ioVRefNum combination */
-               }
-               
-               {
-#if !TARGET_API_MAC_CARBON
-                       long response;
-                       
-                       /* Is PBXGetVolInfo available? */
-                       if ( ( Gestalt(gestaltFSAttr, &response) != noErr ) || ((response & (1L << gestaltFSSupports2TBVols)) == 0) )
-                       {
-                               /* No, fall back on PBHGetVInfo */
-                               error = PBHGetVInfoSync((HParmBlkPtr)pb);
-                               if ( error == noErr )
-                               {
-                                       /* calculate the ioVTotalBytes and ioVFreeBytes fields */
-                                       pb->ioVTotalBytes = U64Multiply(U64SetU(pb->ioVNmAlBlks), U64SetU(pb->ioVAlBlkSiz));
-                                       pb->ioVFreeBytes = U64Multiply(U64SetU(pb->ioVFrBlk), U64SetU(pb->ioVAlBlkSiz));
-                               }
-                       }
-                       else
-#endif
-                       {
-                               /* Yes, so use it */
-                               error = CallPBXGetVolInfoSync(pb);
-                       }
-               }
-               pb->ioNamePtr = NULL;           /* ioNamePtr may point to local tempPathname, so don't return it */
-       }
-       else
-       {
-               error = paramErr;
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr GetCatInfoNoName(short vRefNum,
-                                                          long dirID,
-                                                          ConstStr255Param name,
-                                                          CInfoPBPtr pb)
-{
-       Str31 tempName;
-       OSErr error;
-       
-       /* Protection against File Sharing problem */
-       if ( (name == NULL) || (name[0] == 0) )
-       {
-               tempName[0] = 0;
-               pb->dirInfo.ioNamePtr = tempName;
-               pb->dirInfo.ioFDirIndex = -1;   /* use ioDirID */
-       }
-       else
-       {
-               pb->dirInfo.ioNamePtr = (StringPtr)name;
-               pb->dirInfo.ioFDirIndex = 0;    /* use ioNamePtr and ioDirID */
-       }
-       pb->dirInfo.ioVRefNum = vRefNum;
-       pb->dirInfo.ioDrDirID = dirID;
-       error = PBGetCatInfoSync(pb);
-       pb->dirInfo.ioNamePtr = NULL;
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   DetermineVRefNum(ConstStr255Param pathname,
-                                                                short vRefNum,
-                                                                short *realVRefNum)
-{
-       HParamBlockRec pb;
-       OSErr error;
-
-       error = GetVolumeInfoNoName(pathname,vRefNum, &pb);
-       if ( error == noErr )
-       {
-               *realVRefNum = pb.volumeParam.ioVRefNum;
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   HGetVInfo(short volReference,
-                                                 StringPtr volName,
-                                                 short *vRefNum,
-                                                 unsigned long *freeBytes,
-                                                 unsigned long *totalBytes)
-{
-       OSErr   result;
-       UInt64  freeBytes64;
-       UInt64  totalBytes64;
-       
-       // get the best values possible from XGetVInfo
-       result = XGetVInfo(volReference, volName, vRefNum, &freeBytes64, &totalBytes64);
-       if ( result == noErr )
-       {
-               // and pin those values if needed
-               if ( UInt64ToUnsignedWide(freeBytes64).hi != 0 )
-               {
-                       // pin to maximum 512-byte block aligned value
-                       *freeBytes = 0xfffffe00;
-               }
-               else
-               {
-                       *freeBytes = U32SetU(freeBytes64);
-               }
-               
-               if ( UInt64ToUnsignedWide(totalBytes64).hi != 0 )
-               {
-                       // pin to maximum 512-byte block aligned value
-                       *totalBytes = 0xfffffe00;
-               }
-               else
-               {
-                       *totalBytes = U32SetU(totalBytes64);
-               }
-       }
-       
-       return ( result );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   XGetVInfo(short volReference,
-                                                 StringPtr volName,
-                                                 short *vRefNum,
-                                                 UInt64 *freeBytes,
-                                                 UInt64 *totalBytes)
-{
-       OSErr                   result;
-       XVolumeParam    pb;
-       
-#if !TARGET_API_MAC_CARBON
-       
-       long                    response;
-       
-#endif //      !TARGET_API_MAC_CARBON
-       
-       pb.ioVRefNum = volReference;
-       pb.ioNamePtr = volName;
-       pb.ioXVersion = 0;      /* this XVolumeParam version (0) */
-       pb.ioVolIndex = 0;      /* use ioVRefNum only, return volume name */
-       
-#if !TARGET_API_MAC_CARBON
-
-       /* See if large volume support is available */
-       if ( ( Gestalt(gestaltFSAttr, &response) == noErr ) && ((response & (1L << gestaltFSSupports2TBVols)) != 0) )
-       
-#endif //      !TARGET_API_MAC_CARBON
-       
-       {
-               /* Large volume support is available */
-               result = CallPBXGetVolInfoSync(&pb);
-               if ( result == noErr )
-               {
-                       /* The volume name was returned in volName (if not NULL) and */
-                       /* we have the volume's vRefNum and allocation block size */
-                       *vRefNum = pb.ioVRefNum;
-                       
-                       /* return the freeBytes and totalBytes */
-                       *totalBytes = pb.ioVTotalBytes;
-                       *freeBytes = pb.ioVFreeBytes;
-               }
-       }
-       
-#if !TARGET_API_MAC_CARBON
-       
-       else
-       {
-               /* No large volume support */
-               /* Use PBHGetVInfoSync to get the results */
-               result = PBHGetVInfoSync((HParmBlkPtr)&pb);
-               if ( result == noErr )
-               {
-                       VCB                             *theVCB;
-               
-                       /* The volume name was returned in volName (if not NULL) and */
-                       /* we have the volume's vRefNum */
-                       *vRefNum = pb.ioVRefNum;
-                       
-                       /* System 7.5 (and beyond) pins the number of allocation blocks and */
-                       /* the number of free allocation blocks returned by PBHGetVInfo to */
-                       /* a value so that when multiplied by the allocation block size, */
-                       /* the volume will look like it has $7fffffff bytes or less. This */
-                       /* was done so older applications that use signed math or that use */
-                       /* the GetVInfo function (which uses signed math) will continue to work. */
-                       /* However, the unpinned numbers (which we want) are always available */
-                       /* in the volume's VCB so we'll get those values from the VCB. */
-                       /* Note: Carbon doesn't support the VCB queue, so this code cannot be */
-                       /* used (and is conditionalized out) by Carbon applications. */
-                       
-                       /* Find the volume's VCB */
-                       theVCB = (VCB *)(GetVCBQHdr()->qHead);
-                       while ( theVCB != NULL )
-                       {
-                               if ( theVCB->vcbVRefNum == *vRefNum )
-                               {
-                                       break;
-                               }
-                               
-                               theVCB = (VCB *)(theVCB->qLink);        /* next VCB */
-                       }
-                       
-                       if ( theVCB != NULL )
-                       {
-                               /* Found a VCB we can use. Get the un-pinned number of allocation blocks */
-                               /* and the number of free blocks from the VCB. */
-                               *freeBytes = U64Multiply(U64SetU((unsigned short)theVCB->vcbFreeBks), U64SetU((unsigned long)pb.ioVAlBlkSiz));
-                               *totalBytes = U64Multiply(U64SetU((unsigned short)theVCB->vcbNmAlBlks), U64SetU((unsigned long)pb.ioVAlBlkSiz));
-                       }
-                       else
-                       {
-                               /* Didn't find a VCB we can use. Return the number of allocation blocks */
-                               /* and the number of free blocks returned by PBHGetVInfoSync. */
-                               *freeBytes = U64Multiply(U64SetU((unsigned short)pb.ioVFrBlk), U64SetU((unsigned long)pb.ioVAlBlkSiz));
-                               *totalBytes = U64Multiply(U64SetU((unsigned short)pb.ioVNmAlBlks), U64SetU((unsigned long)pb.ioVAlBlkSiz));
-                       }
-                       
-               }
-       }
-       
-#endif //      !TARGET_API_MAC_CARBON
-       
-       return ( result );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   CheckVolLock(ConstStr255Param pathname,
-                                                        short vRefNum)
-{
-       HParamBlockRec pb;
-       OSErr error;
-
-       error = GetVolumeInfoNoName(pathname,vRefNum, &pb);
-       if ( error == noErr )
-       {
-               if ( (pb.volumeParam.ioVAtrb & kHFSVolumeHardwareLockMask) != 0 )
-               {
-                       error = wPrErr;         /* volume locked by hardware */
-               }
-               else if ( (pb.volumeParam.ioVAtrb & kHFSVolumeSoftwareLockMask) != 0 )
-               {
-                       error = vLckdErr;       /* volume locked by software */
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-//
-//     The following routines call Mac OS routines that are not supported by
-//     Carbon:
-//     
-//             GetDriverName
-//             FindDrive
-//             GetDiskBlocks
-//             GetVolState
-
-#if !TARGET_API_MAC_CARBON     //      {
-
-       /*****************************************************************************/
-
-       pascal  OSErr GetDriverName(short driverRefNum,
-                                                               Str255 driverName)
-       {
-               OSErr result;
-               DCtlHandle theDctl;
-               DRVRHeaderPtr dHeaderPtr;
-               
-               theDctl = GetDCtlEntry(driverRefNum);
-               if ( theDctl != NULL )
-               {
-                   if ( (**theDctl).dCtlFlags & dRAMBasedMask )
-                   {
-                       /* dctlDriver is handle - dereference */
-                               dHeaderPtr = *((DRVRHeaderHandle)(**theDctl).dCtlDriver);
-                   }
-                   else
-                   {
-                               /* dctlDriver is pointer */
-                     dHeaderPtr = (DRVRHeaderPtr)(**theDctl).dCtlDriver;
-                   }
-                       BlockMoveData((*dHeaderPtr).drvrName, driverName, (*dHeaderPtr).drvrName[0] + 1);
-                       result = noErr;
-               }
-               else
-               {
-                       driverName[0] = 0;
-                       result = badUnitErr;    /* bad reference number */
-               }
-               
-               return ( result );
-       }
-
-       /*****************************************************************************/
-
-       pascal  OSErr   FindDrive(ConstStr255Param pathname,
-                                                         short vRefNum,
-                                                         DrvQElPtr *driveQElementPtr)
-       {
-               OSErr                   result;
-               HParamBlockRec  hPB;
-               short                   driveNumber;
-               
-               *driveQElementPtr = NULL;
-               
-               /* First, use GetVolumeInfoNoName to determine the volume */
-               result = GetVolumeInfoNoName(pathname, vRefNum, &hPB);
-               if ( result == noErr )
-               {
-                       /*
-                       **      The volume can be either online, offline, or ejected. What we find in
-                       **      ioVDrvInfo and ioVDRefNum will tell us which it is.
-                       **      See Inside Macintosh: Files page 2-80 and the Technical Note
-                       **      "FL 34 - VCBs and Drive Numbers : The Real Story"
-                       **      Where we get the drive number depends on the state of the volume.
-                       */
-                       if ( hPB.volumeParam.ioVDrvInfo != 0 )
-                       {
-                               /* The volume is online and not ejected */
-                               /* Get the drive number */
-                               driveNumber = hPB.volumeParam.ioVDrvInfo;
-                       }
-                       else
-                       {
-                               /* The volume's is either offline or ejected */
-                               /* in either case, the volume is NOT online */
-
-                               /* Is it ejected or just offline? */
-                               if ( hPB.volumeParam.ioVDRefNum > 0 )
-                               {
-                                       /* It's ejected, the drive number is ioVDRefNum */
-                                       driveNumber = hPB.volumeParam.ioVDRefNum;
-                               }
-                               else
-                               {
-                                       /* It's offline, the drive number is the negative of ioVDRefNum */
-                                       driveNumber = (short)-hPB.volumeParam.ioVDRefNum;
-                               }
-                       }
-                       
-                       /* Get pointer to first element in drive queue */
-                       *driveQElementPtr = (DrvQElPtr)(GetDrvQHdr()->qHead);
-                       
-                       /* Search for a matching drive number */
-                       while ( (*driveQElementPtr != NULL) && ((*driveQElementPtr)->dQDrive != driveNumber) )
-                       {
-                               *driveQElementPtr = (DrvQElPtr)(*driveQElementPtr)->qLink;
-                       }
-                       
-                       if ( *driveQElementPtr == NULL )
-                       {
-                               /* This should never happen since every volume must have a drive, but... */
-                               result = nsDrvErr;
-                       }
-               }
-               
-               return ( result );
-       }
-
-       /*****************************************************************************/
-
-       pascal  OSErr   GetDiskBlocks(ConstStr255Param pathname,
-                                                                 short vRefNum,
-                                                                 unsigned long *numBlocks)
-       {
-               /* Various constants for GetDiskBlocks() */
-               enum
-               {
-                       /* return format list status code */
-                       kFmtLstCode = 6,
-                       
-                       /* reference number of .SONY driver */
-                       kSonyRefNum = 0xfffb,
-                       
-                       /* values returned by DriveStatus in DrvSts.twoSideFmt */
-                       kSingleSided = 0,
-                       kDoubleSided = -1,
-                       kSingleSidedSize = 800,         /* 400K */
-                       kDoubleSidedSize = 1600,        /* 800K */
-                       
-                       /* values in DrvQEl.qType */
-                       kWordDrvSiz = 0,
-                       kLongDrvSiz = 1,
-                       
-                       /* more than enough formatListRecords */
-                       kMaxFormatListRecs = 16
-               };
-               
-               DrvQElPtr               driveQElementPtr;
-               unsigned long   blocks;
-               ParamBlockRec   pb;
-               FormatListRec   formatListRecords[kMaxFormatListRecs];
-               DrvSts                  status;
-               short                   formatListRecIndex;
-               OSErr                   result;
-
-               blocks = 0;
-               
-               /* Find the drive queue element for this volume */
-               result = FindDrive(pathname, vRefNum, &driveQElementPtr);
-               
-               /* 
-               **      Make sure this is a real driver (dQRefNum < 0).
-               **      AOCE's Mail Enclosures volume uses 0 for dQRefNum which will cause
-               **      problems if you try to use it as a driver refNum.
-               */ 
-               if ( (result == noErr) && (driveQElementPtr->dQRefNum >= 0) )
-               {
-                       result = paramErr;
-               }
-               else
-               {
-                       /* Attempt to get the drive's format list. */
-                       /* (see the Technical Note "What Your Sony Drives For You") */
-                       
-                       pb.cntrlParam.ioVRefNum = driveQElementPtr->dQDrive;
-                       pb.cntrlParam.ioCRefNum = driveQElementPtr->dQRefNum;
-                       pb.cntrlParam.csCode = kFmtLstCode;
-                       pb.cntrlParam.csParam[0] = kMaxFormatListRecs;
-                       *(long *)&pb.cntrlParam.csParam[1] = (long)&formatListRecords[0];
-                       
-                       result = PBStatusSync(&pb);
-                       
-                       if ( result == noErr )
-                       {
-                               /* The drive supports ReturnFormatList status call. */
-                               
-                               /* Get the current disk's size. */
-                               for( formatListRecIndex = 0;
-                                        formatListRecIndex < pb.cntrlParam.csParam[0];
-                                ++formatListRecIndex )
-                       {
-                               if ( (formatListRecords[formatListRecIndex].formatFlags &
-                                         diCIFmtFlagsCurrentMask) != 0 )
-                               {
-                                       blocks = formatListRecords[formatListRecIndex].volSize;
-                               }
-                               }
-                       if ( blocks == 0 )
-                       {
-                               /* This should never happen */
-                               result = paramErr;
-                       }
-                       }
-                       else if ( driveQElementPtr->dQRefNum == (short)kSonyRefNum )
-                       {
-                               /* The drive is a non-SuperDrive floppy which only supports 400K and 800K disks */
-                               
-                               result = DriveStatus(driveQElementPtr->dQDrive, &status);
-                               if ( result == noErr )
-                               {
-                                       switch ( status.twoSideFmt )
-                                       {
-                                       case kSingleSided:
-                                               blocks = kSingleSidedSize;
-                                               break;
-                                       case kDoubleSided:
-                                               blocks = kDoubleSidedSize;
-                                               break;
-                                       default:
-                                               /* This should never happen */
-                                               result = paramErr;
-                                               break;
-                                       }
-                               }
-                       }
-                       else
-                       {
-                               /* The drive is not a floppy and it doesn't support ReturnFormatList */
-                               /* so use the dQDrvSz field(s) */
-                               
-                               result = noErr; /* reset result */
-                               switch ( driveQElementPtr->qType )
-                               {
-                               case kWordDrvSiz:
-                                       blocks = driveQElementPtr->dQDrvSz;
-                                       break;
-                               case kLongDrvSiz:
-                                       blocks = ((unsigned long)driveQElementPtr->dQDrvSz2 << 16) +
-                                                        driveQElementPtr->dQDrvSz;
-                                       break;
-                               default:
-                                       /* This should never happen */
-                                       result = paramErr;
-                                       break;
-                               }
-                       }
-               }
-               
-               if ( result == noErr )
-               {
-                       *numBlocks = blocks;
-               }
-               
-               return ( result );
-       }
-
-       /*****************************************************************************/
-
-       pascal  OSErr   GetVolState(ConstStr255Param pathname,
-                                                               short vRefNum,
-                                                               Boolean *volumeOnline,
-                                                               Boolean *volumeEjected,
-                                                               Boolean *driveEjectable,
-                                                               Boolean *driverWantsEject)
-       {
-               HParamBlockRec pb;
-               short driveNumber;
-               OSErr error;
-
-               error = GetVolumeInfoNoName(pathname,vRefNum, &pb);
-               if ( error == noErr )
-               {
-                       if ( pb.volumeParam.ioVDrvInfo != 0 )
-                       {
-                               /* the volume is online and not ejected */
-                               *volumeOnline = true;
-                               *volumeEjected = false;
-                               
-                               /* Get the drive number */
-                               driveNumber = pb.volumeParam.ioVDrvInfo;
-                       }
-                       else
-                       {
-                               /* the volume's is either offline or ejected */
-                               /* in either case, the volume is NOT online */
-                               *volumeOnline = false;
-
-                               /* Is it ejected? */
-                               *volumeEjected = pb.volumeParam.ioVDRefNum > 0;
-                               
-                               if ( *volumeEjected )
-                               {
-                                       /* If ejected, the drive number is ioVDRefNum */
-                                       driveNumber = pb.volumeParam.ioVDRefNum;
-                               }
-                               else
-                               {
-                                       /* If offline, the drive number is the negative of ioVDRefNum */
-                                       driveNumber = (short)-pb.volumeParam.ioVDRefNum;
-                               }
-                       }
-                       
-                       {
-                               DrvQElPtr drvQElem;
-                               
-                               /* Find the drive queue element by searching the drive queue */
-                               drvQElem = (DrvQElPtr)(GetDrvQHdr()->qHead);
-                               while ( (drvQElem != NULL) && (drvQElem->dQDrive != driveNumber) )
-                               {
-                                       drvQElem = (DrvQElPtr)drvQElem->qLink;
-                               }
-                               
-                               if ( drvQElem != NULL )
-                               {
-                                       /*
-                                       **      Each drive queue element is preceded by 4 flag bytes.
-                                       **      Byte 1 (the second flag byte) has bits that tell us if a
-                                       **      drive is ejectable and if its driver wants an eject call.
-                                       **      See Inside Macintosh: Files, page 2-85.
-                                       */
-                                       {
-                                               Ptr             flagBytePtr;
-                                               
-                                               /* point to byte 1 of the flag bytes */
-                                               flagBytePtr = (Ptr)drvQElem;
-                                               flagBytePtr -= 3;
-                                               
-                                               /*
-                                               **      The drive is ejectable if flag byte 1 does not contain
-                                               **      0x08 (nonejectable) or 0x48 (nonejectable, but wants eject call).
-                                               */
-                                               
-                                               *driveEjectable = (*flagBytePtr != 0x08) && (*flagBytePtr != 0x48);
-                                               
-                                               /*
-                                               **      The driver wants an eject call if flag byte 1 does not contain
-                                               **      0x08 (nonejectable). This may seem like a minor point, but some
-                                               **      disk drivers use the Eject request to flush their caches to disk
-                                               **      and you wouldn't want to skip that step after unmounting a volume.
-                                               */
-                                               
-                                               *driverWantsEject = (*flagBytePtr != 0x08);
-                                       }
-                               }
-                               else
-                               {
-                                       /* Didn't find the drive (this should never happen) */
-                                       *driveEjectable = false;
-                                       *driverWantsEject = false;
-                               }
-                       }
-               }
-               
-               return ( error );
-       }
-
-       /*****************************************************************************/
-
-#endif //      }       !TARGET_API_MAC_CARBON
-
-/*****************************************************************************/
-
-pascal OSErr   GetVolFileSystemID(ConstStr255Param pathname,
-                                                                  short vRefNum,
-                                                                  short *fileSystemID)
-{
-       HParamBlockRec pb;
-       OSErr error;
-
-       error = GetVolumeInfoNoName(pathname,vRefNum, &pb);
-       if ( error == noErr )
-       {
-               *fileSystemID = pb.volumeParam.ioVFSID;
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-//
-//     Note:   Under Carbon there are no drive numbers, so you cannot call
-//                     Eject with a drive number after unmounting a volume.
-//                     When a Carbon application calls UnmountVol, CarbonLib will make
-//                     sure ejectable media is ejected (leaving ejectable media in the
-//                     disk drive makes no sense to Carbon applications).
-//
-pascal OSErr   UnmountAndEject(ConstStr255Param pathname,
-                                                               short vRefNum)
-{
-       HParamBlockRec pb;
-       OSErr error;
-
-       error = GetVolumeInfoNoName(pathname, vRefNum, &pb);
-       if ( error == noErr )
-       {
-       
-#if    !TARGET_API_MAC_CARBON
-
-               short driveNum;
-               Boolean ejected, wantsEject;
-               DrvQElPtr drvQElem;
-               
-               if ( pb.volumeParam.ioVDrvInfo != 0 )
-               {
-                       /* the volume is online and not ejected */
-                       ejected = false;
-                       
-                       /* Get the drive number */
-                       driveNum = pb.volumeParam.ioVDrvInfo;
-               }
-               else
-               {
-                       /* the volume is ejected or offline */
-                       
-                       /* Is it ejected? */
-                       ejected = pb.volumeParam.ioVDRefNum > 0;
-                       
-                       if ( ejected )
-                       {
-                               /* If ejected, the drive number is ioVDRefNum */
-                               driveNum = pb.volumeParam.ioVDRefNum;
-                       }
-                       else
-                       {
-                               /* If offline, the drive number is the negative of ioVDRefNum */
-                               driveNum = (short)-pb.volumeParam.ioVDRefNum;
-                       }
-               }
-               
-               /* find the drive queue element */
-               drvQElem = (DrvQElPtr)(GetDrvQHdr()->qHead);
-               while ( (drvQElem != NULL) && (drvQElem->dQDrive != driveNum) )
-               {
-                       drvQElem = (DrvQElPtr)drvQElem->qLink;
-               }
-               
-               if ( drvQElem != NULL )
-               {
-                       /* does the drive want an eject call */
-                       wantsEject = (*((Ptr)((Ptr)drvQElem - 3)) != 8);
-               }
-               else
-               {
-                       /* didn't find the drive!! */
-                       wantsEject = false;
-               }
-               
-#endif //      !TARGET_API_MAC_CARBON
-
-               /* unmount the volume */
-               pb.volumeParam.ioNamePtr = NULL;
-               /* ioVRefNum is already filled in from PBHGetVInfo */
-               error = PBUnmountVol((ParmBlkPtr)&pb);
-
-#if    !TARGET_API_MAC_CARBON
-
-               if ( error == noErr )
-               {
-                       if ( wantsEject && !ejected )
-                       {
-                               /* eject the media from the drive if needed */
-                               pb.volumeParam.ioVRefNum = driveNum;
-                               error = PBEject((ParmBlkPtr)&pb);
-                       }
-               }
-               
-#endif //      !TARGET_API_MAC_CARBON
-
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   OnLine(FSSpecPtr volumes,
-                                          short reqVolCount,
-                                          short *actVolCount,
-                                          short *volIndex)
-{
-       HParamBlockRec pb;
-       OSErr error = noErr;
-       FSSpec *endVolArray;
-
-       if ( *volIndex > 0 )
-       {
-               *actVolCount = 0;
-               for ( endVolArray = volumes + reqVolCount; (volumes < endVolArray) && (error == noErr); ++volumes )
-               {
-                       pb.volumeParam.ioNamePtr = (StringPtr) & volumes->name;
-                       pb.volumeParam.ioVolIndex = *volIndex;
-                       error = PBHGetVInfoSync(&pb);
-                       if ( error == noErr )
-                       {
-                               volumes->parID = fsRtParID;             /* the root directory's parent is 1 */
-                               volumes->vRefNum = pb.volumeParam.ioVRefNum;
-                               ++*volIndex;
-                               ++*actVolCount;
-                       }
-               }
-       }
-       else
-       {
-               error = paramErr;
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr SetDefault(short newVRefNum,
-                                                long newDirID,
-                                                short *oldVRefNum,
-                                                long *oldDirID)
-{
-       OSErr   error;
-       
-       /* Get the current default volume/directory. */
-       error = HGetVol(NULL, oldVRefNum, oldDirID);
-       if ( error == noErr )
-       {
-               /* Set the new default volume/directory */
-               error = HSetVol(NULL, newVRefNum, newDirID);
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr RestoreDefault(short oldVRefNum,
-                                                        long oldDirID)
-{
-       OSErr   error;
-       
-#if    !TARGET_API_MAC_CARBON
-
-       short   defaultVRefNum;
-       long    defaultDirID;
-       long    defaultProcID;
-       
-       /* Determine if the default volume was a wdRefNum. */
-       error = GetWDInfo(oldVRefNum, &defaultVRefNum, &defaultDirID, &defaultProcID);
-       if ( error == noErr )
-       {
-               /* Restore the old default volume/directory, one way or the other. */
-               if ( defaultDirID != fsRtDirID )
-               {
-                       /* oldVRefNum was a wdRefNum - use SetVol */
-                       error = SetVol(NULL, oldVRefNum);
-               }
-               else
-               {
-               
-#endif //      !TARGET_API_MAC_CARBON
-
-                       /* oldVRefNum was a real vRefNum - use HSetVol */
-                       error = HSetVol(NULL, oldVRefNum, oldDirID);
-
-#if    !TARGET_API_MAC_CARBON
-
-               }
-       }
-#endif //      !TARGET_API_MAC_CARBON
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr GetDInfo(short vRefNum,
-                                          long dirID,
-                                          ConstStr255Param name,
-                                          DInfo *fndrInfo)
-{
-       CInfoPBRec pb;
-       OSErr error;
-       
-       error = GetCatInfoNoName(vRefNum, dirID, name, &pb);
-       if ( error == noErr )
-       {
-               if ( (pb.dirInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-               {
-                       /* it's a directory, return the DInfo */
-                       *fndrInfo = pb.dirInfo.ioDrUsrWds;
-               }
-               else
-               {
-                       /* oops, a file was passed */
-                       error = dirNFErr;
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr FSpGetDInfo(const FSSpec *spec,
-                                                 DInfo *fndrInfo)
-{
-       return ( GetDInfo(spec->vRefNum, spec->parID, spec->name, fndrInfo) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr SetDInfo(short vRefNum,
-                                          long dirID,
-                                          ConstStr255Param name,
-                                          const DInfo *fndrInfo)
-{
-       CInfoPBRec pb;
-       Str31 tempName;
-       OSErr error;
-
-       /* Protection against File Sharing problem */
-       if ( (name == NULL) || (name[0] == 0) )
-       {
-               tempName[0] = 0;
-               pb.dirInfo.ioNamePtr = tempName;
-               pb.dirInfo.ioFDirIndex = -1;    /* use ioDirID */
-       }
-       else
-       {
-               pb.dirInfo.ioNamePtr = (StringPtr)name;
-               pb.dirInfo.ioFDirIndex = 0;     /* use ioNamePtr and ioDirID */
-       }
-       pb.dirInfo.ioVRefNum = vRefNum;
-       pb.dirInfo.ioDrDirID = dirID;
-       error = PBGetCatInfoSync(&pb);
-       if ( error == noErr )
-       {
-               if ( (pb.dirInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-               {
-                       /* it's a directory, set the DInfo */
-                       if ( pb.dirInfo.ioNamePtr == tempName )
-                       {
-                               pb.dirInfo.ioDrDirID = pb.dirInfo.ioDrParID;
-                       }
-                       else
-                       {
-                               pb.dirInfo.ioDrDirID = dirID;
-                       }
-                       pb.dirInfo.ioDrUsrWds = *fndrInfo;
-                       error = PBSetCatInfoSync(&pb);
-               }
-               else
-               {
-                       /* oops, a file was passed */
-                       error = dirNFErr;
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr FSpSetDInfo(const FSSpec *spec,
-                                                 const DInfo *fndrInfo)
-{
-       return ( SetDInfo(spec->vRefNum, spec->parID, spec->name, fndrInfo) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetDirectoryID(short vRefNum,
-                                                          long dirID,
-                                                          ConstStr255Param name,
-                                                          long *theDirID,
-                                                          Boolean *isDirectory)
-{
-       CInfoPBRec pb;
-       OSErr error;
-
-       error = GetCatInfoNoName(vRefNum, dirID, name, &pb);
-       if ( error == noErr )
-       {
-               *isDirectory = (pb.hFileInfo.ioFlAttrib & kioFlAttribDirMask) != 0;
-               if ( *isDirectory )
-               {
-                       *theDirID = pb.dirInfo.ioDrDirID;
-               }
-               else
-               {
-                       *theDirID = pb.hFileInfo.ioFlParID;
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpGetDirectoryID(const FSSpec *spec,
-                                                                 long *theDirID,
-                                                                 Boolean *isDirectory)
-{
-       return ( GetDirectoryID(spec->vRefNum, spec->parID, spec->name,
-                        theDirID, isDirectory) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetDirName(short vRefNum,
-                                                  long dirID,
-                                                  Str31 name)
-{
-       CInfoPBRec pb;
-       OSErr error;
-
-       if ( name != NULL )
-       {
-               pb.dirInfo.ioNamePtr = name;
-               pb.dirInfo.ioVRefNum = vRefNum;
-               pb.dirInfo.ioDrDirID = dirID;
-               pb.dirInfo.ioFDirIndex = -1;    /* get information about ioDirID */
-               error = PBGetCatInfoSync(&pb);
-       }
-       else
-       {
-               error = paramErr;
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetIOACUser(short vRefNum,
-                                                       long dirID,
-                                                       ConstStr255Param name,
-                                                       SInt8 *ioACUser)
-{
-       CInfoPBRec pb;
-       OSErr error;
-       
-       /* Clear ioACUser before calling PBGetCatInfo since some file systems
-       ** don't bother to set or clear this field. If ioACUser isn't set by the
-       ** file system, then you'll get the zero value back (full access) which
-       ** is the access you have on volumes that don't support ioACUser.
-       */
-       pb.dirInfo.ioACUser = 0;        /* ioACUser used to be filler2 */
-       error = GetCatInfoNoName(vRefNum, dirID, name, &pb);
-       if ( error == noErr )
-       {
-               if ( (pb.hFileInfo.ioFlAttrib & kioFlAttribDirMask) == 0 )
-               {
-                       /* oops, a file was passed */
-                       error = dirNFErr;
-               }
-               else
-               {
-                       *ioACUser = pb.dirInfo.ioACUser;
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpGetIOACUser(const FSSpec *spec,
-                                                          SInt8 *ioACUser)
-{
-       return ( GetIOACUser(spec->vRefNum, spec->parID, spec->name, ioACUser) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetParentID(short vRefNum,
-                                                       long dirID,
-                                                       ConstStr255Param name,
-                                                       long *parID)
-{
-       CInfoPBRec pb;
-       Str31 tempName;
-       OSErr error;
-       short realVRefNum;
-       
-       /* Protection against File Sharing problem */
-       if ( (name == NULL) || (name[0] == 0) )
-       {
-               tempName[0] = 0;
-               pb.hFileInfo.ioNamePtr = tempName;
-               pb.hFileInfo.ioFDirIndex = -1;  /* use ioDirID */
-       }
-       else
-       {
-               pb.hFileInfo.ioNamePtr = (StringPtr)name;
-               pb.hFileInfo.ioFDirIndex = 0;   /* use ioNamePtr and ioDirID */
-       }
-       pb.hFileInfo.ioVRefNum = vRefNum;
-       pb.hFileInfo.ioDirID = dirID;
-       error = PBGetCatInfoSync(&pb);
-       if ( error == noErr )
-       {
-               /*
-               **      There's a bug in HFS where the wrong parent dir ID can be
-               **      returned if multiple separators are used at the end of a
-               **      pathname. For example, if the pathname:
-               **              'volumeName:System Folder:Extensions::'
-               **      is passed, the directory ID of the Extensions folder is
-               **      returned in the ioFlParID field instead of fsRtDirID. Since
-               **      multiple separators at the end of a pathname always specifies
-               **      a directory, we only need to work-around cases where the
-               **      object is a directory and there are multiple separators at
-               **      the end of the name parameter.
-               */
-               if ( (pb.hFileInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-               {
-                       /* Its a directory */
-                       
-                       /* is there a pathname? */
-                       if ( pb.hFileInfo.ioNamePtr == name )   
-                       {
-                               /* could it contain multiple separators? */
-                               if ( name[0] >= 2 )
-                               {
-                                       /* does it contain multiple separators at the end? */
-                                       if ( (name[name[0]] == ':') && (name[name[0] - 1] == ':') )
-                                       {
-                                               /* OK, then do the extra stuff to get the correct parID */
-                                               
-                                               /* Get the real vRefNum (this should not fail) */
-                                               error = DetermineVRefNum(name, vRefNum, &realVRefNum);
-                                               if ( error == noErr )
-                                               {
-                                                       /* we don't need the parent's name, but add protect against File Sharing problem */
-                                                       tempName[0] = 0;
-                                                       pb.dirInfo.ioNamePtr = tempName;
-                                                       pb.dirInfo.ioVRefNum = realVRefNum;
-                                                       /* pb.dirInfo.ioDrDirID already contains the */
-                                                       /* dirID of the directory object */
-                                                       pb.dirInfo.ioFDirIndex = -1;    /* get information about ioDirID */
-                                                       error = PBGetCatInfoSync(&pb);
-                                                       /* now, pb.dirInfo.ioDrParID contains the correct parID */
-                                               }
-                                       }
-                               }
-                       }
-               }
-               
-               if ( error == noErr )
-               {
-                       /* if no errors, then pb.hFileInfo.ioFlParID (pb.dirInfo.ioDrParID) */
-                       /* contains the parent ID */
-                       *parID = pb.hFileInfo.ioFlParID;
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetFilenameFromPathname(ConstStr255Param pathname,
-                                                                               Str255 filename)
-{
-       short   index;
-       short   nameEnd;
-       OSErr   error;
-
-       /* default to no filename */
-       filename[0] = 0;
-
-       /* check for no pathname */
-       if ( pathname != NULL )
-       {
-               /* get string length */
-               index = pathname[0];
-               
-               /* check for empty string */
-               if ( index != 0 )
-               {
-                       /* skip over last trailing colon (if any) */
-                       if ( pathname[index] == ':' )
-                       {
-                               --index;
-                       }
-
-                       /* save the end of the string */
-                       nameEnd = index;
-
-                       /* if pathname ends with multiple colons, then this pathname refers */
-                       /* to a directory, not a file */
-                       if ( pathname[index] != ':' )
-                       {
-                               /* parse backwards until we find a colon or hit the beginning of the pathname */
-                               while ( (index != 0) && (pathname[index] != ':') )
-                               {
-                                       --index;
-                               }
-                               
-                               /* if we parsed to the beginning of the pathname and the pathname ended */
-                               /* with a colon, then pathname is a full pathname to a volume, not a file */
-                               if ( (index != 0) || (pathname[pathname[0]] != ':') )
-                               {
-                                       /* get the filename and return noErr */
-                                       filename[0] = (char)(nameEnd - index);
-                                       BlockMoveData(&pathname[index+1], &filename[1], nameEnd - index);
-                                       error = noErr;
-                               }
-                               else
-                               {
-                                       /* pathname to a volume, not a file */
-                                       error = notAFileErr;
-                               }
-                       }
-                       else
-                       {
-                               /* directory, not a file */
-                               error = notAFileErr;
-                       }
-               }
-               else
-               {
-                       /* empty string isn't a file */
-                       error = notAFileErr;
-               }
-       }
-       else
-       {
-               /* NULL pathname isn't a file */
-               error = notAFileErr;
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetObjectLocation(short vRefNum,
-                                                                 long dirID,
-                                                                 ConstStr255Param pathname,
-                                                                 short *realVRefNum,
-                                                                 long *realParID,
-                                                                 Str255 realName,
-                                                                 Boolean *isDirectory)
-{
-       OSErr error;
-       CInfoPBRec pb;
-       Str255 tempPathname;
-       
-       /* clear results */
-       *realVRefNum = 0;
-       *realParID = 0;
-       realName[0] = 0;
-       
-       /*
-       **      Get the real vRefNum
-       */
-       error = DetermineVRefNum(pathname, vRefNum, realVRefNum);
-       if ( error == noErr )
-       {
-               /*
-               **      Determine if the object already exists and if so,
-               **      get the real parent directory ID if it's a file
-               */
-               
-               /* Protection against File Sharing problem */
-               if ( (pathname == NULL) || (pathname[0] == 0) )
-               {
-                       tempPathname[0] = 0;
-                       pb.hFileInfo.ioNamePtr = tempPathname;
-                       pb.hFileInfo.ioFDirIndex = -1;  /* use ioDirID */
-               }
-               else
-               {
-                       pb.hFileInfo.ioNamePtr = (StringPtr)pathname;
-                       pb.hFileInfo.ioFDirIndex = 0;   /* use ioNamePtr and ioDirID */
-               }
-               pb.hFileInfo.ioVRefNum = vRefNum;
-               pb.hFileInfo.ioDirID = dirID;
-               error = PBGetCatInfoSync(&pb);
-               if ( error == noErr )
-               {
-                       /*
-                       **      The file system object is present and we have the file's real parID
-                       */
-                       
-                       /*      Is it a directory or a file? */
-                       *isDirectory = (pb.hFileInfo.ioFlAttrib & kioFlAttribDirMask) != 0;
-                       if ( *isDirectory )
-                       {
-                               /*
-                               **      It's a directory, get its name and parent dirID, and then we're done
-                               */
-                               
-                               pb.dirInfo.ioNamePtr = realName;
-                               pb.dirInfo.ioVRefNum = *realVRefNum;
-                               /* pb.dirInfo.ioDrDirID already contains the dirID of the directory object */
-                               pb.dirInfo.ioFDirIndex = -1;    /* get information about ioDirID */
-                               error = PBGetCatInfoSync(&pb);
-                               
-                               /* get the parent ID here, because the file system can return the */
-                               /* wrong parent ID from the last call. */
-                               *realParID = pb.dirInfo.ioDrParID;
-                       }
-                       else
-                       {
-                               /*
-                               **      It's a file - use the parent directory ID from the last call
-                               **      to GetCatInfoparse, get the file name, and then we're done
-                               */
-                               *realParID = pb.hFileInfo.ioFlParID;    
-                               error = GetFilenameFromPathname(pathname, realName);
-                       }
-               }
-               else if ( error == fnfErr )
-               {
-                       /*
-                       **      The file system object is not present - see if its parent is present
-                       */
-                       
-                       /*
-                       **      Parse to get the object name from end of pathname
-                       */
-                       error = GetFilenameFromPathname(pathname, realName);
-                       
-                       /* if we can't get the object name from the end, we can't continue */
-                       if ( error == noErr )
-                       {
-                               /*
-                               **      What we want now is the pathname minus the object name
-                               **      for example:
-                               **      if pathname is 'vol:dir:file' tempPathname becomes 'vol:dir:'
-                               **      if pathname is 'vol:dir:file:' tempPathname becomes 'vol:dir:'
-                               **      if pathname is ':dir:file' tempPathname becomes ':dir:'
-                               **      if pathname is ':dir:file:' tempPathname becomes ':dir:'
-                               **      if pathname is ':file' tempPathname becomes ':'
-                               **      if pathname is 'file or file:' tempPathname becomes ''
-                               */
-                               
-                               /* get a copy of the pathname */
-                               BlockMoveData(pathname, tempPathname, pathname[0] + 1);
-                               
-                               /* remove the object name */
-                               tempPathname[0] -= realName[0];
-                               /* and the trailing colon (if any) */
-                               if ( pathname[pathname[0]] == ':' )
-                               {
-                                       --tempPathname[0];
-                               }
-                               
-                               /* OK, now get the parent's directory ID */
-                               
-                               /* Protection against File Sharing problem */
-                               pb.hFileInfo.ioNamePtr = (StringPtr)tempPathname;
-                               if ( tempPathname[0] != 0 )
-                               {
-                                       pb.hFileInfo.ioFDirIndex = 0;   /* use ioNamePtr and ioDirID */
-                               }
-                               else
-                               {
-                                       pb.hFileInfo.ioFDirIndex = -1;  /* use ioDirID */
-                               }
-                               pb.hFileInfo.ioVRefNum = vRefNum;
-                               pb.hFileInfo.ioDirID = dirID;
-                               error = PBGetCatInfoSync(&pb);
-                               *realParID = pb.dirInfo.ioDrDirID;
-
-                               *isDirectory = false;   /* we don't know what the object is really going to be */
-                       }
-                       
-                       if ( error != noErr )
-                       {
-                               error = dirNFErr;       /* couldn't find parent directory */
-                       }
-                       else
-                       {
-                               error = fnfErr; /* we found the parent, but not the file */
-                       }
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetDirItems(short vRefNum,
-                                                       long dirID,
-                                                       ConstStr255Param name,
-                                                       Boolean getFiles,
-                                                       Boolean getDirectories,
-                                                       FSSpecPtr items,
-                                                       short reqItemCount,
-                                                       short *actItemCount,
-                                                       short *itemIndex) /* start with 1, then use what's returned */
-{
-       CInfoPBRec pb;
-       OSErr error;
-       long theDirID;
-       Boolean isDirectory;
-       FSSpec *endItemsArray;
-       
-       if ( *itemIndex > 0 )
-       {
-               /* NOTE: If I could be sure that the caller passed a real vRefNum and real directory */
-               /* to this routine, I could rip out calls to DetermineVRefNum and GetDirectoryID and this */
-               /* routine would be much faster because of the overhead of DetermineVRefNum and */
-               /* GetDirectoryID and because GetDirectoryID blows away the directory index hint the Macintosh */
-               /* file system keeps for indexed calls. I can't be sure, so for maximum throughput, */
-               /* pass a big array of FSSpecs so you can get the directory's contents with few calls */
-               /* to this routine. */
-               
-               /* get the real volume reference number */
-               error = DetermineVRefNum(name, vRefNum, &pb.hFileInfo.ioVRefNum);
-               if ( error == noErr )
-               {
-                       /* and the real directory ID of this directory (and make sure it IS a directory) */
-                       error = GetDirectoryID(vRefNum, dirID, name, &theDirID, &isDirectory);
-                       if ( error == noErr )
-                       {
-                               if ( isDirectory )
-                               {
-                                       *actItemCount = 0;
-                                       endItemsArray = items + reqItemCount;
-                                       while ( (items < endItemsArray) && (error == noErr) )
-                                       {
-                                               pb.hFileInfo.ioNamePtr = (StringPtr) &items->name;
-                                               pb.hFileInfo.ioDirID = theDirID;
-                                               pb.hFileInfo.ioFDirIndex = *itemIndex;
-                                               error = PBGetCatInfoSync(&pb);
-                                               if ( error == noErr )
-                                               {
-                                                       items->parID = pb.hFileInfo.ioFlParID;  /* return item's parID */
-                                                       items->vRefNum = pb.hFileInfo.ioVRefNum;        /* return item's vRefNum */
-                                                       ++*itemIndex;   /* prepare to get next item in directory */
-                                                       
-                                                       if ( (pb.hFileInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-                                                       {
-                                                               if ( getDirectories )
-                                                               {
-                                                                       ++*actItemCount; /* keep this item */
-                                                                       ++items; /* point to next item */
-                                                               }
-                                                       }
-                                                       else
-                                                       {
-                                                               if ( getFiles )
-                                                               {
-                                                                       ++*actItemCount; /* keep this item */
-                                                                       ++items; /* point to next item */
-                                                               }
-                                                       }
-                                               }
-                                       }
-                               }
-                               else
-                               {
-                                       /* it wasn't a directory */
-                                       error = dirNFErr;
-                               }
-                       }
-               }
-       }
-       else
-       {
-               /* bad itemIndex */
-               error = paramErr;
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-static void    DeleteLevel(long dirToDelete,
-                                                       DeleteEnumGlobalsPtr theGlobals)
-{
-       long savedDir;
-       
-       do
-       {
-               /* prepare to delete directory */
-               theGlobals->myPB.ciPB.dirInfo.ioNamePtr = (StringPtr)&theGlobals->itemName;
-               theGlobals->myPB.ciPB.dirInfo.ioFDirIndex = 1;  /* get first item */
-               theGlobals->myPB.ciPB.dirInfo.ioDrDirID = dirToDelete;  /* in this directory */
-               theGlobals->error = PBGetCatInfoSync(&(theGlobals->myPB.ciPB));
-               if ( theGlobals->error == noErr )
-               {
-                       savedDir = dirToDelete;
-                       /* We have an item.  Is it a file or directory? */
-                       if ( (theGlobals->myPB.ciPB.dirInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-                       {
-                               /* it's a directory */
-                               savedDir = theGlobals->myPB.ciPB.dirInfo.ioDrDirID;     /* save dirID of directory instead */
-                               DeleteLevel(theGlobals->myPB.ciPB.dirInfo.ioDrDirID, theGlobals);       /* Delete its contents */
-                               theGlobals->myPB.ciPB.dirInfo.ioNamePtr = NULL; /* prepare to delete directory */
-                       }
-                       if ( theGlobals->error == noErr )
-                       {
-                               theGlobals->myPB.ciPB.dirInfo.ioDrDirID = savedDir;     /* restore dirID */
-                               theGlobals->myPB.hPB.fileParam.ioFVersNum = 0;  /* just in case it's used on an MFS volume... */
-                               theGlobals->error = PBHDeleteSync(&(theGlobals->myPB.hPB));     /* delete this item */
-                               if ( theGlobals->error == fLckdErr )
-                               {
-                                       (void) PBHRstFLockSync(&(theGlobals->myPB.hPB));        /* unlock it */
-                                       theGlobals->error = PBHDeleteSync(&(theGlobals->myPB.hPB));     /* and try again */
-                               }
-                       }
-               }
-       } while ( theGlobals->error == noErr );
-       
-       if ( theGlobals->error == fnfErr )
-       {
-               theGlobals->error = noErr;
-       }
-}
-
-/*****************************************************************************/
-
-pascal OSErr   DeleteDirectoryContents(short vRefNum,
-                                                                               long dirID,
-                                                                               ConstStr255Param name)
-{
-       DeleteEnumGlobals theGlobals;
-       Boolean isDirectory;
-       OSErr error;
-
-       /*  Get the real dirID and make sure it is a directory. */
-       error = GetDirectoryID(vRefNum, dirID, name, &dirID, &isDirectory);
-       if ( error == noErr )
-       {
-               if ( isDirectory )
-               {
-                       /* Get the real vRefNum */
-                       error = DetermineVRefNum(name, vRefNum, &vRefNum);
-                       if ( error == noErr )
-                       {
-                               /* Set up the globals we need to access from the recursive routine. */
-                               theGlobals.myPB.ciPB.dirInfo.ioVRefNum = vRefNum;
-                                       
-                               /* Here we go into recursion land... */
-                               DeleteLevel(dirID, &theGlobals);
-                               error = theGlobals.error;
-                       }
-               }
-               else
-               {
-                       error = dirNFErr;
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   DeleteDirectory(short vRefNum,
-                                                               long dirID,
-                                                               ConstStr255Param name)
-{
-       OSErr error;
-       
-       /* Make sure a directory was specified and then delete its contents */
-       error = DeleteDirectoryContents(vRefNum, dirID, name);
-       if ( error == noErr )
-       {
-               error = HDelete(vRefNum, dirID, name);
-               if ( error == fLckdErr )
-               {
-                       (void) HRstFLock(vRefNum, dirID, name); /* unlock the directory locked by AppleShare */
-                       error = HDelete(vRefNum, dirID, name);  /* and try again */
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   CheckObjectLock(short vRefNum,
-                                                               long dirID,
-                                                               ConstStr255Param name)
-{
-       CInfoPBRec pb;
-       OSErr error;
-       
-       error = GetCatInfoNoName(vRefNum, dirID, name, &pb);
-       if ( error == noErr )
-       {
-               /* check locked bit */
-               if ( (pb.hFileInfo.ioFlAttrib & kioFlAttribLockedMask) != 0 )
-               {
-                       error = fLckdErr;
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpCheckObjectLock(const FSSpec *spec)
-{
-       return ( CheckObjectLock(spec->vRefNum, spec->parID, spec->name) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetFileSize(short vRefNum,
-                                                       long dirID,
-                                                       ConstStr255Param fileName,
-                                                       long *dataSize,
-                                                       long *rsrcSize)
-{
-       HParamBlockRec pb;
-       OSErr error;
-       
-       pb.fileParam.ioNamePtr = (StringPtr)fileName;
-       pb.fileParam.ioVRefNum = vRefNum;
-       pb.fileParam.ioFVersNum = 0;
-       pb.fileParam.ioDirID = dirID;
-       pb.fileParam.ioFDirIndex = 0;
-       error = PBHGetFInfoSync(&pb);
-       if ( error == noErr )
-       {
-               *dataSize = pb.fileParam.ioFlLgLen;
-               *rsrcSize = pb.fileParam.ioFlRLgLen;
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpGetFileSize(const FSSpec *spec,
-                                                          long *dataSize,
-                                                          long *rsrcSize)
-{
-       return ( GetFileSize(spec->vRefNum, spec->parID, spec->name, dataSize, rsrcSize) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   BumpDate(short vRefNum,
-                                                long dirID,
-                                                ConstStr255Param name)
-/* Given a file or directory, change its modification date to the current date/time. */
-{
-       CInfoPBRec pb;
-       Str31 tempName;
-       OSErr error;
-       unsigned long secs;
-
-       /* Protection against File Sharing problem */
-       if ( (name == NULL) || (name[0] == 0) )
-       {
-               tempName[0] = 0;
-               pb.hFileInfo.ioNamePtr = tempName;
-               pb.hFileInfo.ioFDirIndex = -1;  /* use ioDirID */
-       }
-       else
-       {
-               pb.hFileInfo.ioNamePtr = (StringPtr)name;
-               pb.hFileInfo.ioFDirIndex = 0;   /* use ioNamePtr and ioDirID */
-       }
-       pb.hFileInfo.ioVRefNum = vRefNum;
-       pb.hFileInfo.ioDirID = dirID;
-       error = PBGetCatInfoSync(&pb);
-       if ( error == noErr )
-       {
-               GetDateTime(&secs);
-               /* set mod date to current date, or one second into the future
-                       if mod date = current date */
-               pb.hFileInfo.ioFlMdDat = (secs == pb.hFileInfo.ioFlMdDat) ? (++secs) : (secs);
-               if ( pb.dirInfo.ioNamePtr == tempName )
-               {
-                       pb.hFileInfo.ioDirID = pb.hFileInfo.ioFlParID;
-               }
-               else
-               {
-                       pb.hFileInfo.ioDirID = dirID;
-               }
-               error = PBSetCatInfoSync(&pb);
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpBumpDate(const FSSpec *spec)
-{
-       return ( BumpDate(spec->vRefNum, spec->parID, spec->name) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   ChangeCreatorType(short vRefNum,
-                                                                 long dirID,
-                                                                 ConstStr255Param name,
-                                                                 OSType creator,
-                                                                 OSType fileType)
-{
-       CInfoPBRec pb;
-       OSErr error;
-       short realVRefNum;
-       long parID;
-
-       pb.hFileInfo.ioNamePtr = (StringPtr)name;
-       pb.hFileInfo.ioVRefNum = vRefNum;
-       pb.hFileInfo.ioDirID = dirID;
-       pb.hFileInfo.ioFDirIndex = 0;   /* use ioNamePtr and ioDirID */
-       error = PBGetCatInfoSync(&pb);
-       if ( error == noErr )
-       {
-               if ( (pb.hFileInfo.ioFlAttrib & kioFlAttribDirMask) == 0 )      /* if file */
-               {
-                       parID = pb.hFileInfo.ioFlParID; /* save parent dirID for BumpDate call */
-
-                       /* If creator not 0x00000000, change creator */
-                       if ( creator != (OSType)0x00000000 )
-                       {
-                               pb.hFileInfo.ioFlFndrInfo.fdCreator = creator;
-                       }
-                       
-                       /* If fileType not 0x00000000, change fileType */
-                       if ( fileType != (OSType)0x00000000 )
-                       {
-                               pb.hFileInfo.ioFlFndrInfo.fdType = fileType;
-                       }
-                               
-                       pb.hFileInfo.ioDirID = dirID;
-                       error = PBSetCatInfoSync(&pb);  /* now, save the new information back to disk */
-
-                       if ( (error == noErr) && (parID != fsRtParID) ) /* can't bump fsRtParID */
-                       {
-                               /* get the real vRefNum in case a full pathname was passed */
-                               error = DetermineVRefNum(name, vRefNum, &realVRefNum);
-                               if ( error == noErr )
-                               {
-                                       error = BumpDate(realVRefNum, parID, NULL);
-                                               /* and bump the parent directory's mod date to wake up the Finder */
-                                               /* to the change we just made */
-                               }
-                       }
-               }
-               else
-               {
-                       /* it was a directory, not a file */
-                       error = notAFileErr;
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpChangeCreatorType(const FSSpec *spec,
-                                                                        OSType creator,
-                                                                        OSType fileType)
-{
-       return ( ChangeCreatorType(spec->vRefNum, spec->parID, spec->name, creator, fileType) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   ChangeFDFlags(short vRefNum,
-                                                         long dirID,
-                                                         ConstStr255Param name,
-                                                         Boolean       setBits,
-                                                         unsigned short flagBits)
-{
-       CInfoPBRec pb;
-       Str31 tempName;
-       OSErr error;
-       short realVRefNum;
-       long parID;
-
-       /* Protection against File Sharing problem */
-       if ( (name == NULL) || (name[0] == 0) )
-       {
-               tempName[0] = 0;
-               pb.hFileInfo.ioNamePtr = tempName;
-               pb.hFileInfo.ioFDirIndex = -1;  /* use ioDirID */
-       }
-       else
-       {
-               pb.hFileInfo.ioNamePtr = (StringPtr)name;
-               pb.hFileInfo.ioFDirIndex = 0;   /* use ioNamePtr and ioDirID */
-       }
-       pb.hFileInfo.ioVRefNum = vRefNum;
-       pb.hFileInfo.ioDirID = dirID;
-       error = PBGetCatInfoSync(&pb);
-       if ( error == noErr )
-       {
-               parID = pb.hFileInfo.ioFlParID; /* save parent dirID for BumpDate call */
-               
-               /* set or clear the appropriate bits in the Finder flags */
-               if ( setBits )
-               {
-                       /* OR in the bits */
-                       pb.hFileInfo.ioFlFndrInfo.fdFlags |= flagBits;
-               }
-               else
-               {
-                       /* AND out the bits */
-                       pb.hFileInfo.ioFlFndrInfo.fdFlags &= ~flagBits;
-               }
-                       
-               if ( pb.dirInfo.ioNamePtr == tempName )
-               {
-                       pb.hFileInfo.ioDirID = pb.hFileInfo.ioFlParID;
-               }
-               else
-               {
-                       pb.hFileInfo.ioDirID = dirID;
-               }
-               
-               error = PBSetCatInfoSync(&pb);  /* now, save the new information back to disk */
-
-               if ( (error == noErr) && (parID != fsRtParID) ) /* can't bump fsRtParID */
-               {
-                       /* get the real vRefNum in case a full pathname was passed */
-                       error = DetermineVRefNum(name, vRefNum, &realVRefNum);
-                       if ( error == noErr )
-                       {
-                               error = BumpDate(realVRefNum, parID, NULL);
-                                       /* and bump the parent directory's mod date to wake up the Finder */
-                                       /* to the change we just made */
-                       }
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpChangeFDFlags(const FSSpec *spec,
-                                                                Boolean setBits,
-                                                                unsigned short flagBits)
-{
-       return ( ChangeFDFlags(spec->vRefNum, spec->parID, spec->name, setBits, flagBits) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   SetIsInvisible(short vRefNum,
-                                                          long dirID,
-                                                          ConstStr255Param name)
-       /* Given a file or directory, make it invisible. */
-{
-       return ( ChangeFDFlags(vRefNum, dirID, name, true, kIsInvisible) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpSetIsInvisible(const FSSpec *spec)
-       /* Given a file or directory, make it invisible. */
-{
-       return ( ChangeFDFlags(spec->vRefNum, spec->parID, spec->name, true, kIsInvisible) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   ClearIsInvisible(short vRefNum,
-                                                                long dirID,
-                                                                ConstStr255Param name)
-       /* Given a file or directory, make it visible. */
-{
-       return ( ChangeFDFlags(vRefNum, dirID, name, false, kIsInvisible) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpClearIsInvisible(const FSSpec *spec)
-       /* Given a file or directory, make it visible. */
-{
-       return ( ChangeFDFlags(spec->vRefNum, spec->parID, spec->name, false, kIsInvisible) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   SetNameLocked(short vRefNum,
-                                                         long dirID,
-                                                         ConstStr255Param name)
-       /* Given a file or directory, lock its name. */
-{
-       return ( ChangeFDFlags(vRefNum, dirID, name, true, kNameLocked) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpSetNameLocked(const FSSpec *spec)
-       /* Given a file or directory, lock its name. */
-{
-       return ( ChangeFDFlags(spec->vRefNum, spec->parID, spec->name, true, kNameLocked) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   ClearNameLocked(short vRefNum,
-                                                               long dirID,
-                                                               ConstStr255Param name)
-       /* Given a file or directory, unlock its name. */
-{
-       return ( ChangeFDFlags(vRefNum, dirID, name, false, kNameLocked) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpClearNameLocked(const FSSpec *spec)
-       /* Given a file or directory, unlock its name. */
-{
-       return ( ChangeFDFlags(spec->vRefNum, spec->parID, spec->name, false, kNameLocked) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   SetIsStationery(short vRefNum,
-                                                               long dirID,
-                                                               ConstStr255Param name)
-       /* Given a file, make it a stationery pad. */
-{
-       return ( ChangeFDFlags(vRefNum, dirID, name, true, kIsStationery) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpSetIsStationery(const FSSpec *spec)
-       /* Given a file, make it a stationery pad. */
-{
-       return ( ChangeFDFlags(spec->vRefNum, spec->parID, spec->name, true, kIsStationery) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   ClearIsStationery(short vRefNum,
-                                                                 long dirID,
-                                                                 ConstStr255Param name)
-       /* Given a file, clear the stationery bit. */
-{
-       return ( ChangeFDFlags(vRefNum, dirID, name, false, kIsStationery) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpClearIsStationery(const FSSpec *spec)
-       /* Given a file, clear the stationery bit. */
-{
-       return ( ChangeFDFlags(spec->vRefNum, spec->parID, spec->name, false, kIsStationery) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   SetHasCustomIcon(short vRefNum,
-                                                                long dirID,
-                                                                ConstStr255Param name)
-       /* Given a file or directory, indicate that it has a custom icon. */
-{
-       return ( ChangeFDFlags(vRefNum, dirID, name, true, kHasCustomIcon) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpSetHasCustomIcon(const FSSpec *spec)
-       /* Given a file or directory, indicate that it has a custom icon. */
-{
-       return ( ChangeFDFlags(spec->vRefNum, spec->parID, spec->name, true, kHasCustomIcon) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   ClearHasCustomIcon(short vRefNum,
-                                                                  long dirID,
-                                                                  ConstStr255Param name)
-       /* Given a file or directory, indicate that it does not have a custom icon. */
-{
-       return ( ChangeFDFlags(vRefNum, dirID, name, false, kHasCustomIcon) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpClearHasCustomIcon(const FSSpec *spec)
-       /* Given a file or directory, indicate that it does not have a custom icon. */
-{
-       return ( ChangeFDFlags(spec->vRefNum, spec->parID, spec->name, false, kHasCustomIcon) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   ClearHasBeenInited(short vRefNum,
-                                                                  long dirID,
-                                                                  ConstStr255Param name)
-       /* Given a file, clear its "has been inited" bit. */
-{
-       return ( ChangeFDFlags(vRefNum, dirID, name, false, kHasBeenInited) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpClearHasBeenInited(const FSSpec *spec)
-       /* Given a file, clear its "has been inited" bit. */
-{
-       return ( ChangeFDFlags(spec->vRefNum, spec->parID, spec->name, false, kHasBeenInited) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   CopyFileMgrAttributes(short srcVRefNum,
-                                                                         long srcDirID,
-                                                                         ConstStr255Param srcName,
-                                                                         short dstVRefNum,
-                                                                         long dstDirID,
-                                                                         ConstStr255Param dstName,
-                                                                         Boolean copyLockBit)
-{
-       UniversalFMPB pb;
-       Str31 tempName;
-       OSErr error;
-       Boolean objectIsDirectory;
-
-       pb.ciPB.hFileInfo.ioVRefNum = srcVRefNum;
-       pb.ciPB.hFileInfo.ioDirID = srcDirID;
-
-       /* Protection against File Sharing problem */
-       if ( (srcName == NULL) || (srcName[0] == 0) )
-       {
-               tempName[0] = 0;
-               pb.ciPB.hFileInfo.ioNamePtr = tempName;
-               pb.ciPB.hFileInfo.ioFDirIndex = -1;     /* use ioDirID */
-       }
-       else
-       {
-               pb.ciPB.hFileInfo.ioNamePtr = (StringPtr)srcName;
-               pb.ciPB.hFileInfo.ioFDirIndex = 0;      /* use ioNamePtr and ioDirID */
-       }
-       error = PBGetCatInfoSync(&pb.ciPB);
-       if ( error == noErr )
-       {
-               objectIsDirectory = ( (pb.ciPB.hFileInfo.ioFlAttrib & kioFlAttribDirMask) != 0 );
-               pb.ciPB.hFileInfo.ioVRefNum = dstVRefNum;
-               pb.ciPB.hFileInfo.ioDirID = dstDirID;
-               if ( (dstName != NULL) && (dstName[0] == 0) )
-               {
-                       pb.ciPB.hFileInfo.ioNamePtr = NULL;
-               }
-               else
-               {
-                       pb.ciPB.hFileInfo.ioNamePtr = (StringPtr)dstName;
-               }
-               /* don't copy the hasBeenInited bit */
-               pb.ciPB.hFileInfo.ioFlFndrInfo.fdFlags = ( pb.ciPB.hFileInfo.ioFlFndrInfo.fdFlags & ~kHasBeenInited );
-               error = PBSetCatInfoSync(&pb.ciPB);
-               if ( (error == noErr) && (copyLockBit) && ((pb.ciPB.hFileInfo.ioFlAttrib & kioFlAttribLockedMask) != 0) )
-               {
-                       pb.hPB.fileParam.ioFVersNum = 0;
-                       error = PBHSetFLockSync(&pb.hPB);
-                       if ( (error != noErr) && (objectIsDirectory) )
-                       {
-                               error = noErr; /* ignore lock errors if destination is directory */
-                       }
-               }
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpCopyFileMgrAttributes(const FSSpec *srcSpec,
-                                                                                const FSSpec *dstSpec,
-                                                                                Boolean copyLockBit)
-{
-       return ( CopyFileMgrAttributes(srcSpec->vRefNum, srcSpec->parID, srcSpec->name,
-                                                                  dstSpec->vRefNum, dstSpec->parID, dstSpec->name,
-                                                                  copyLockBit) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   HOpenAware(short vRefNum,
-                                                  long dirID,
-                                                  ConstStr255Param fileName,
-                                                  short denyModes,
-                                                  short *refNum)
-{
-       HParamBlockRec pb;
-       OSErr error;
-       GetVolParmsInfoBuffer volParmsInfo;
-       long infoSize = sizeof(GetVolParmsInfoBuffer);
-
-       pb.ioParam.ioMisc = NULL;
-       pb.fileParam.ioFVersNum = 0;
-       pb.fileParam.ioNamePtr = (StringPtr)fileName;
-       pb.fileParam.ioVRefNum = vRefNum;
-       pb.fileParam.ioDirID = dirID;
-
-       /* get volume attributes */
-       /* this preflighting is needed because Foreign File Access based file systems don't */
-       /* return the correct error result to the OpenDeny call */
-       error = HGetVolParms(fileName, vRefNum, &volParmsInfo, &infoSize);
-       if ( (error == noErr) && hasOpenDeny(&volParmsInfo) )
-       {
-               /* if volume supports OpenDeny, use it and return */
-                       pb.accessParam.ioDenyModes = denyModes;
-                       error = PBHOpenDenySync(&pb);
-                       *refNum = pb.ioParam.ioRefNum;
-       }
-       else if ( (error == noErr) || (error == paramErr) )     /* paramErr is OK, it just means this volume doesn't support GetVolParms */
-       {
-               /* OpenDeny isn't supported, so try File Manager Open functions */
-               
-               /* If request includes write permission, then see if the volume is */
-               /* locked by hardware or software. The HFS file system doesn't check */
-               /* for this when a file is opened - you only find out later when you */
-               /* try to write and the write fails with a wPrErr or a vLckdErr. */
-               
-               if ( (denyModes & dmWr) != 0 )
-               {
-                       error = CheckVolLock(fileName, vRefNum);
-               }
-               else
-               {
-                       error = noErr;
-               }
-               
-               if ( error == noErr )
-               {
-                       /* Set File Manager permissions to closest thing possible */
-                       if ( (denyModes == dmWr) || (denyModes == dmRdWr) )
-                       {
-                               pb.ioParam.ioPermssn = fsRdWrShPerm;
-                       }
-                       else
-                       {
-                               pb.ioParam.ioPermssn = denyModes % 4;
-                       }
-
-                       error = PBHOpenDFSync(&pb);                             /* Try OpenDF */
-                       if ( error == paramErr )
-                       {
-                               error = PBHOpenSync(&pb);                       /* OpenDF not supported, so try Open */
-                       }
-                       *refNum = pb.ioParam.ioRefNum;
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpOpenAware(const FSSpec *spec,
-                                                        short denyModes,
-                                                        short *refNum)
-{
-       return ( HOpenAware(spec->vRefNum, spec->parID, spec->name, denyModes, refNum) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   HOpenRFAware(short vRefNum,
-                                                        long dirID,
-                                                        ConstStr255Param fileName,
-                                                        short denyModes,
-                                                        short *refNum)
-{
-       HParamBlockRec pb;
-       OSErr error;
-       GetVolParmsInfoBuffer volParmsInfo;
-       long infoSize = sizeof(GetVolParmsInfoBuffer);
-
-       pb.ioParam.ioMisc = NULL;
-       pb.fileParam.ioFVersNum = 0;
-       pb.fileParam.ioNamePtr = (StringPtr)fileName;
-       pb.fileParam.ioVRefNum = vRefNum;
-       pb.fileParam.ioDirID = dirID;
-
-       /* get volume attributes */
-       /* this preflighting is needed because Foreign File Access based file systems don't */
-       /* return the correct error result to the OpenRFDeny call */
-       error = HGetVolParms(fileName, vRefNum, &volParmsInfo, &infoSize);
-       if ( (error == noErr) && hasOpenDeny(&volParmsInfo) )
-       {
-               /* if volume supports OpenRFDeny, use it and return */
-               if ( hasOpenDeny(&volParmsInfo) )
-               {
-                       pb.accessParam.ioDenyModes = denyModes;
-                       error = PBHOpenRFDenySync(&pb);
-                       *refNum = pb.ioParam.ioRefNum;
-               }
-       }
-       else if ( (error == noErr) || (error == paramErr) )     /* paramErr is OK, it just means this volume doesn't support GetVolParms */
-       {
-               /* OpenRFDeny isn't supported, so try File Manager OpenRF function */
-               
-               /* If request includes write permission, then see if the volume is */
-               /* locked by hardware or software. The HFS file system doesn't check */
-               /* for this when a file is opened - you only find out later when you */
-               /* try to write and the write fails with a wPrErr or a vLckdErr. */
-               
-               if ( (denyModes & dmWr) != 0 )
-               {
-                       error = CheckVolLock(fileName, vRefNum);
-               }
-               else
-               {
-                       error = noErr;
-               }
-               
-               if ( error == noErr )
-               {
-                       /* Set File Manager permissions to closest thing possible */
-                       if ( (denyModes == dmWr) || (denyModes == dmRdWr) )
-                       {
-                               pb.ioParam.ioPermssn = fsRdWrShPerm;
-                       }
-                       else
-                       {
-                               pb.ioParam.ioPermssn = denyModes % 4;
-                       }
-
-                       error = PBHOpenRFSync(&pb);
-                       *refNum = pb.ioParam.ioRefNum;
-               }
-       }
-
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpOpenRFAware(const FSSpec *spec,
-                                                          short denyModes,
-                                                          short *refNum)
-{
-       return ( HOpenRFAware(spec->vRefNum, spec->parID, spec->name, denyModes, refNum) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSReadNoCache(short refNum,
-                                                         long *count,
-                                                         void *buffPtr)
-{
-       ParamBlockRec pb;
-       OSErr error;
-
-       pb.ioParam.ioRefNum = refNum;
-       pb.ioParam.ioBuffer = (Ptr)buffPtr;
-       pb.ioParam.ioReqCount = *count;
-       pb.ioParam.ioPosMode = fsAtMark + noCacheMask;  /* fsAtMark + noCacheMask */
-       pb.ioParam.ioPosOffset = 0;
-       error = PBReadSync(&pb);
-       *count = pb.ioParam.ioActCount;                         /* always return count */
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSWriteNoCache(short refNum,
-                                                          long *count,
-                                                          const void *buffPtr)
-{
-       ParamBlockRec pb;
-       OSErr error;
-
-       pb.ioParam.ioRefNum = refNum;
-       pb.ioParam.ioBuffer = (Ptr)buffPtr;
-       pb.ioParam.ioReqCount = *count;
-       pb.ioParam.ioPosMode = fsAtMark + noCacheMask;  /* fsAtMark + noCacheMask */
-       pb.ioParam.ioPosOffset = 0;
-       error = PBWriteSync(&pb);
-       *count = pb.ioParam.ioActCount;                         /* always return count */
-       return ( error );
-}
-
-/*****************************************************************************/
-
-/*
-**     See if numBytes bytes of buffer1 are equal to buffer2.
-*/
-static Boolean EqualMemory(const void *buffer1, const void *buffer2, unsigned long numBytes)
-{
-       register unsigned char *b1 = (unsigned char *)buffer1;
-       register unsigned char *b2 = (unsigned char *)buffer2;
-
-       if ( b1 != b2 ) /* if buffer pointers are same, then they are equal */
-       {
-               while ( numBytes > 0 )
-               {
-                       /* compare the bytes and then increment the pointers */
-                       if ( (*b1++ - *b2++) != 0 )
-                       {
-                               return ( false );
-                       }
-                       --numBytes;
-               }
-       }
-       
-       return ( true );
-}
-
-/*****************************************************************************/
-
-/*
-**     Read any number of bytes from an open file using read-verify mode.
-**     The FSReadVerify function reads any number of bytes from an open file
-**     and verifies them against the data in the buffer pointed to by buffPtr.
-**     
-**     Because of a bug in the HFS file system, only non-block aligned parts of
-**     the read are verified against the buffer data and the rest is *copied*
-**     into the buffer.  Thus, you shouldn't verify against your original data;
-**     instead, you should verify against a copy of the original data and then
-**     compare the read-verified copy against the original data after calling
-**     FSReadVerify. That's why this function isn't exported - it needs the
-**     wrapper provided by FSWriteVerify.
-*/
-static OSErr   FSReadVerify(short refNum,
-                                                        long *count,
-                                                        void *buffPtr)
-{
-       ParamBlockRec   pb;
-       OSErr                   result;
-
-       pb.ioParam.ioRefNum = refNum;
-       pb.ioParam.ioBuffer = (Ptr)buffPtr;
-       pb.ioParam.ioReqCount = *count;
-       pb.ioParam.ioPosMode = fsAtMark + rdVerify;
-       pb.ioParam.ioPosOffset = 0;
-       result = PBReadSync(&pb);
-       *count = pb.ioParam.ioActCount;                 /* always return count */
-       return ( result );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSWriteVerify(short refNum,
-                                                         long *count,
-                                                         const void *buffPtr)
-{
-       Ptr             verifyBuffer;
-       long    position;
-       long    bufferSize;
-       long    byteCount;
-       long    bytesVerified;
-       Ptr             startVerify;
-       OSErr   result;
-       
-       /*
-       **      Allocate the verify buffer
-       **      Try to get get a large enough buffer to verify in one pass.
-       **      If that fails, use GetTempBuffer to get a buffer.
-       */
-       bufferSize = *count;
-       verifyBuffer = NewPtr(bufferSize);
-       if ( verifyBuffer == NULL )
-       {
-               verifyBuffer = GetTempBuffer(bufferSize, &bufferSize);
-       }
-       if ( verifyBuffer != NULL )
-       {               
-               /* Save the current position */
-               result = GetFPos(refNum, &position);
-               if ( result == noErr )
-               {
-                       /* Write the data */
-                       result = FSWrite(refNum, count, buffPtr);
-                       if ( result == noErr )
-                       {
-                               /* Restore the original position */
-                               result = SetFPos(refNum, fsFromStart, position);
-                               if ( result == noErr )
-                               {
-                                       /*
-                                       **      *count                  = total number of bytes to verify
-                                       **      bufferSize              = the size of the verify buffer
-                                       **      bytesVerified   = number of bytes verified
-                                       **      byteCount               = number of bytes to verify this pass
-                                       **      startVerify             = position in buffPtr
-                                       */
-                                       bytesVerified = 0;
-                                       startVerify = (Ptr)buffPtr;
-                                       while ( (bytesVerified < *count) && ( result == noErr ) )
-                                       {
-                                               if ( (*count - bytesVerified) > bufferSize )
-                                               {
-                                                       byteCount = bufferSize;
-                                               }
-                                               else
-                                               {
-                                                       byteCount = *count - bytesVerified;
-                                               }
-                                               /*
-                                               **      Copy the write buffer into the verify buffer.
-                                               **      This step is needed because the File Manager
-                                               **      compares the data in any non-block aligned
-                                               **      data at the beginning and end of the read-verify
-                                               **      request back into the file system's cache
-                                               **      to the data in verify Buffer. However, the
-                                               **      File Manager does not compare any full blocks
-                                               **      and instead copies them into the verify buffer
-                                               **      so we still have to compare the buffers again
-                                               **      after the read-verify request completes.
-                                               */
-                                               BlockMoveData(startVerify, verifyBuffer, byteCount);
-                                               
-                                               /* Read-verify the data back into the verify buffer */
-                                               result = FSReadVerify(refNum, &byteCount, verifyBuffer);
-                                               if ( result == noErr )
-                                               {
-                                                       /* See if the buffers are the same */
-                                                       if ( !EqualMemory(verifyBuffer, startVerify, byteCount) )
-                                                       {
-                                                               result = ioErr;
-                                                       }
-                                                       startVerify += byteCount;
-                                                       bytesVerified += byteCount;
-                                               }
-                                       }
-                               }
-                       }
-               }
-               DisposePtr(verifyBuffer);
-       }
-       else
-       {
-               result = memFullErr;
-       }
-       return ( result );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   CopyFork(short srcRefNum,
-                                                short dstRefNum,
-                                                void *copyBufferPtr,
-                                                long copyBufferSize)
-{
-       ParamBlockRec srcPB;
-       ParamBlockRec dstPB;
-       OSErr srcError;
-       OSErr dstError;
-
-       if ( (copyBufferPtr == NULL) || (copyBufferSize == 0) )
-               return ( paramErr );
-       
-       srcPB.ioParam.ioRefNum = srcRefNum;
-       dstPB.ioParam.ioRefNum = dstRefNum;
-
-       /* preallocate the destination fork and */
-       /* ensure the destination fork's EOF is correct after the copy */
-       srcError = PBGetEOFSync(&srcPB);
-       if ( srcError != noErr )
-               return ( srcError );
-       dstPB.ioParam.ioMisc = srcPB.ioParam.ioMisc;
-       dstError = PBSetEOFSync(&dstPB);
-       if ( dstError != noErr )
-               return ( dstError );
-
-       /* reset source fork's mark */
-       srcPB.ioParam.ioPosMode = fsFromStart;
-       srcPB.ioParam.ioPosOffset = 0;
-       srcError = PBSetFPosSync(&srcPB);
-       if ( srcError != noErr )
-               return ( srcError );
-
-       /* reset destination fork's mark */
-       dstPB.ioParam.ioPosMode = fsFromStart;
-       dstPB.ioParam.ioPosOffset = 0;
-       dstError = PBSetFPosSync(&dstPB);
-       if ( dstError != noErr )
-               return ( dstError );
-
-       /* set up fields that won't change in the loop */
-       srcPB.ioParam.ioBuffer = (Ptr)copyBufferPtr;
-       srcPB.ioParam.ioPosMode = fsAtMark + noCacheMask;/* fsAtMark + noCacheMask */
-       /* If copyBufferSize is greater than 512 bytes, make it a multiple of 512 bytes */
-       /* This will make writes on local volumes faster */
-       if ( (copyBufferSize >= 512) && ((copyBufferSize & 0x1ff) != 0) )
-       {
-               srcPB.ioParam.ioReqCount = copyBufferSize & 0xfffffe00;
-       }
-       else
-       {
-               srcPB.ioParam.ioReqCount = copyBufferSize;
-       }
-       dstPB.ioParam.ioBuffer = (Ptr)copyBufferPtr;
-       dstPB.ioParam.ioPosMode = fsAtMark + noCacheMask;/* fsAtMark + noCacheMask */
-
-       while ( (srcError == noErr) && (dstError == noErr) )
-       {
-               srcError = PBReadSync(&srcPB);
-               dstPB.ioParam.ioReqCount = srcPB.ioParam.ioActCount;
-               dstError = PBWriteSync(&dstPB);
-       }
-
-       /* make sure there were no errors at the destination */
-       if ( dstError != noErr )
-               return ( dstError );
-
-       /* make sure the only error at the source was eofErr */
-       if ( srcError != eofErr )
-               return ( srcError );
-
-       return ( noErr );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetFileLocation(short refNum,
-                                                               short *vRefNum,
-                                                               long *dirID,
-                                                               StringPtr fileName)
-{
-       FCBPBRec pb;
-       OSErr error;
-
-       pb.ioNamePtr = fileName;
-       pb.ioVRefNum = 0;
-       pb.ioRefNum = refNum;
-       pb.ioFCBIndx = 0;
-       error = PBGetFCBInfoSync(&pb);
-       if ( error == noErr )
-       {
-               *vRefNum = pb.ioFCBVRefNum;
-               *dirID = pb.ioFCBParID;
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpGetFileLocation(short refNum,
-                                                                  FSSpec *spec)
-{
-       return ( GetFileLocation(refNum, &(spec->vRefNum), &(spec->parID), spec->name) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   CopyDirectoryAccess(short srcVRefNum,
-                                                                       long srcDirID,
-                                                                       ConstStr255Param srcName,
-                                                                       short dstVRefNum,
-                                                                       long dstDirID,
-                                                                       ConstStr255Param dstName)
-{      
-       OSErr error;
-       GetVolParmsInfoBuffer infoBuffer;       /* Where PBGetVolParms dumps its info */
-       long    dstServerAdr;                           /* AppleTalk server address of destination (if any) */
-       long    ownerID, groupID, accessRights;
-       long    tempLong;
-
-       /* See if destination supports directory access control */
-       tempLong = sizeof(infoBuffer);
-       error = HGetVolParms(dstName, dstVRefNum, &infoBuffer, &tempLong);
-       if ( (error == noErr) && hasAccessCntl(&infoBuffer) )
-       {
-               if ( hasAccessCntl(&infoBuffer) )
-               {
-                       dstServerAdr = infoBuffer.vMServerAdr;
-                       
-                       /* See if source supports directory access control and is on same server */
-                       tempLong = sizeof(infoBuffer);
-                       error = HGetVolParms(srcName, srcVRefNum, &infoBuffer, &tempLong);
-                       if ( error == noErr )
-                       {
-                               if ( hasAccessCntl(&infoBuffer) && (dstServerAdr == infoBuffer.vMServerAdr) )
-                               {
-                                       /* both volumes support directory access control and they are */
-                                       /*  on same server, so copy the access information */
-                                       error = HGetDirAccess(srcVRefNum, srcDirID, srcName, &ownerID, &groupID, &accessRights);
-                                       if ( error == noErr )
-                                       {
-                                               error = HSetDirAccess(dstVRefNum, dstDirID, dstName, ownerID, groupID, accessRights);
-                                       }
-                               }
-                               else
-                               {
-                                       /* destination doesn't support directory access control or */
-                                       /* they volumes aren't on the same server */
-                                       error = paramErr;
-                               }
-                       }
-               }
-               else
-               {
-                       /* destination doesn't support directory access control */
-                       error = paramErr;
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpCopyDirectoryAccess(const FSSpec *srcSpec,
-                                                                          const FSSpec *dstSpec)
-{
-       return ( CopyDirectoryAccess(srcSpec->vRefNum, srcSpec->parID, srcSpec->name,
-                                                               dstSpec->vRefNum, dstSpec->parID, dstSpec->name) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   HMoveRenameCompat(short vRefNum,
-                                                                 long srcDirID,
-                                                                 ConstStr255Param srcName,
-                                                                 long dstDirID,
-                                                                 ConstStr255Param dstpathName,
-                                                                 ConstStr255Param copyName)
-{
-       OSErr                                   error;
-       GetVolParmsInfoBuffer   volParmsInfo;
-       long                                    infoSize;
-       short                                   realVRefNum;
-       long                                    realParID;
-       Str31                                   realName;
-       Boolean                                 isDirectory;
-       long                                    tempItemsDirID;
-       long                                    uniqueTempDirID;
-       Str31                                   uniqueTempDirName;
-       unsigned short                  uniqueNameoverflow;
-       
-       /* Get volume attributes */
-       infoSize = sizeof(GetVolParmsInfoBuffer);
-       error = HGetVolParms((StringPtr)srcName, vRefNum, &volParmsInfo, &infoSize);
-       if ( (error == noErr) && hasMoveRename(&volParmsInfo) )
-       {
-               /* If volume supports move and rename, so use it and return */
-               error = HMoveRename(vRefNum, srcDirID, srcName, dstDirID, dstpathName, copyName);
-       }
-       else if ( (error == noErr) || (error == paramErr) ) /* paramErr is OK, it just means this volume doesn't support GetVolParms */
-       {
-               /* MoveRename isn't supported by this volume, so do it by hand */
-               
-               /* If copyName isn't supplied, we can simply CatMove and return */
-               if ( copyName == NULL )
-               {
-                       error = CatMove(vRefNum, srcDirID, srcName, dstDirID, dstpathName);
-               }
-               else
-               {
-                       /* Renaming is required, so we have some work to do... */
-                       
-                       /* Get the object's real name, real parent ID and real vRefNum */
-                       error = GetObjectLocation(vRefNum, srcDirID, (StringPtr)srcName,
-                                                                               &realVRefNum, &realParID, realName, &isDirectory);
-                       if ( error == noErr )
-                       {
-                               /* Find the Temporary Items Folder on that volume */
-                               error = FindFolder(realVRefNum, kTemporaryFolderType, kCreateFolder,
-                                                                       &realVRefNum, &tempItemsDirID);
-                               if ( error == noErr )
-                               {
-                                       /* Create a new uniquely named folder in the temporary items folder. */
-                                       /* This is done to avoid the case where 'realName' or 'copyName' already */
-                                       /* exists in the temporary items folder. */
-                                       
-                                       /* Start with current tick count as uniqueTempDirName */                                        
-                                       NumToString(TickCount(), uniqueTempDirName);
-                                       uniqueNameoverflow = 0;
-                                       do
-                                       {
-                                               error = DirCreate(realVRefNum, tempItemsDirID, uniqueTempDirName, &uniqueTempDirID);
-                                               if ( error == dupFNErr )
-                                               {
-                                                       /* Duplicate name - change the first character to the next ASCII character */
-                                                       ++uniqueTempDirName[1];
-                                                       /* Make sure it isn't a colon! */
-                                                       if ( uniqueTempDirName[1] == ':' )
-                                                       {
-                                                               ++uniqueTempDirName[1];
-                                                       }
-                                                       /* Don't go too far... */
-                                                       ++uniqueNameoverflow;
-                                               }
-                                       } while ( (error == dupFNErr) && (uniqueNameoverflow <= 64) ); /* 64 new files per 1/60th second - not likely! */
-                                       if ( error == noErr )
-                                       {
-                                               /* Move the object to the folder with uniqueTempDirID for renaming */
-                                               error = CatMove(realVRefNum, realParID, realName, uniqueTempDirID, NULL);
-                                               if ( error == noErr )
-                                               {
-                                                       /* Rename the object */ 
-                                                       error = HRename(realVRefNum, uniqueTempDirID, realName, copyName);
-                                                       if ( error == noErr )
-                                                       {
-                                                               /* Move object to its new home */
-                                                               error = CatMove(realVRefNum, uniqueTempDirID, copyName, dstDirID, dstpathName);
-                                                               if ( error != noErr )
-                                                               {
-                                                                       /* Error handling: rename object back to original name - ignore errors */
-                                                                       (void) HRename(realVRefNum, uniqueTempDirID, copyName, realName);
-                                                               }
-                                                       }
-                                                       if ( error != noErr )
-                                                       {
-                                                               /* Error handling: move object back to original location - ignore errors */
-                                                               (void) CatMove(realVRefNum, uniqueTempDirID, realName, realParID, NULL);
-                                                       }
-                                               }
-                                               /* Done with ourTempDir, so delete it - ignore errors */
-                                               (void) HDelete(realVRefNum, uniqueTempDirID, NULL);
-                                       }
-                               }
-                       }
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   FSpMoveRenameCompat(const FSSpec *srcSpec,
-                                                                       const FSSpec *dstSpec,
-                                                                       ConstStr255Param copyName)
-{
-       /* make sure the FSSpecs refer to the same volume */
-       if (srcSpec->vRefNum != dstSpec->vRefNum)
-               return (diffVolErr);
-       return ( HMoveRenameCompat(srcSpec->vRefNum, srcSpec->parID, srcSpec->name,
-                                         dstSpec->parID, dstSpec->name, copyName) );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   BuildAFPVolMountInfo(short flags,
-                                                                        char nbpInterval,
-                                                                        char nbpCount,
-                                                                        short uamType,
-                                                                        Str32 zoneName,
-                                                                        Str32 serverName,
-                                                                        Str27 volName,
-                                                                        Str31 userName,
-                                                                        Str8 userPassword,
-                                                                        Str8 volPassword,
-                                                                        AFPVolMountInfoPtr *afpInfoPtr)
-{
-       MyAFPVolMountInfoPtr    infoPtr;
-       OSErr                                   error;
-       
-       /* Allocate the AFPXVolMountInfo record */
-       infoPtr = (MyAFPVolMountInfoPtr)NewPtrClear(sizeof(MyAFPVolMountInfo));
-       if ( infoPtr != NULL )
-       {
-               /* Fill in an AFPVolMountInfo record that can be passed to VolumeMount */
-               infoPtr->length = sizeof(MyAFPVolMountInfo);
-               infoPtr->media = AppleShareMediaType;
-               infoPtr->flags = flags;
-               infoPtr->nbpInterval = nbpInterval;
-               infoPtr->nbpCount = nbpCount;
-               infoPtr->uamType = uamType;
-               
-               infoPtr->zoneNameOffset = offsetof(MyAFPVolMountInfo, zoneName);
-               infoPtr->serverNameOffset = offsetof(MyAFPVolMountInfo, serverName);
-               infoPtr->volNameOffset = offsetof(MyAFPVolMountInfo, volName);
-               infoPtr->userNameOffset = offsetof(MyAFPVolMountInfo, userName);
-               infoPtr->userPasswordOffset = offsetof(MyAFPVolMountInfo, userPassword);
-               infoPtr->volPasswordOffset = offsetof(MyAFPVolMountInfo, volPassword);
-               
-               BlockMoveData(zoneName, infoPtr->zoneName, sizeof(Str32));
-               BlockMoveData(serverName, infoPtr->serverName, sizeof(Str32));
-               BlockMoveData(volName, infoPtr->volName, sizeof(Str27));
-               BlockMoveData(userName, infoPtr->userName, sizeof(Str31));
-               BlockMoveData(userPassword, infoPtr->userPassword, sizeof(Str8));
-               BlockMoveData(volPassword, infoPtr->volPassword, sizeof(Str8));
-               
-               *afpInfoPtr = (AFPVolMountInfoPtr)infoPtr;
-               error = noErr;
-       }
-       else
-       {
-               error = memFullErr;
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   RetrieveAFPVolMountInfo(AFPVolMountInfoPtr afpInfoPtr,
-                                                                               short *flags,
-                                                                               short *uamType,
-                                                                               StringPtr zoneName,
-                                                                               StringPtr serverName,
-                                                                               StringPtr volName,
-                                                                               StringPtr userName)
-{
-       StringPtr       tempPtr;
-       OSErr           error;
-               
-       /* Retrieve the AFP mounting information from an AFPVolMountInfo record. */
-       if ( afpInfoPtr->media == AppleShareMediaType )
-       {
-               *flags = afpInfoPtr->flags;
-               *uamType = afpInfoPtr->uamType;
-               
-               if ( afpInfoPtr->zoneNameOffset != 0)
-               {
-                       tempPtr = (StringPtr)((long)afpInfoPtr + afpInfoPtr->zoneNameOffset);
-                       BlockMoveData(tempPtr, zoneName, tempPtr[0] + 1);
-               }
-               
-               if ( afpInfoPtr->serverNameOffset != 0)
-               {
-                       tempPtr = (StringPtr)((long)afpInfoPtr + afpInfoPtr->serverNameOffset);
-                       BlockMoveData(tempPtr, serverName, tempPtr[0] + 1);
-               }
-               
-               if ( afpInfoPtr->volNameOffset != 0)
-               {
-                       tempPtr = (StringPtr)((long)afpInfoPtr + afpInfoPtr->volNameOffset);
-                       BlockMoveData(tempPtr, volName, tempPtr[0] + 1);
-               }
-               
-               if ( afpInfoPtr->userNameOffset != 0)
-               {
-                       tempPtr = (StringPtr)((long)afpInfoPtr + afpInfoPtr->userNameOffset);
-                       BlockMoveData(tempPtr, userName, tempPtr[0] + 1);
-               }
-               
-               error = noErr;
-       }
-       else
-       {
-               error = paramErr;
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   BuildAFPXVolMountInfo(short flags,
-                                                                         char nbpInterval,
-                                                                         char nbpCount,
-                                                                         short uamType,
-                                                                         Str32 zoneName,
-                                                                         Str32 serverName,
-                                                                         Str27 volName,
-                                                                         Str31 userName,
-                                                                         Str8 userPassword,
-                                                                         Str8 volPassword,
-                                                                         Str32 uamName,
-                                                                         unsigned long alternateAddressLength,
-                                                                         void *alternateAddress,
-                                                                         AFPXVolMountInfoPtr *afpXInfoPtr)
-{
-       Size                                    infoSize;
-       MyAFPXVolMountInfoPtr   infoPtr;
-       OSErr                                   error;
-       
-       /* Calculate the size of the AFPXVolMountInfo record */
-       infoSize = sizeof(MyAFPXVolMountInfo) + alternateAddressLength - 1;
-       
-       /* Allocate the AFPXVolMountInfo record */
-       infoPtr = (MyAFPXVolMountInfoPtr)NewPtrClear(infoSize);
-       if ( infoPtr != NULL )
-       {
-               /* Fill in an AFPXVolMountInfo record that can be passed to VolumeMount */
-               infoPtr->length = infoSize;
-               infoPtr->media = AppleShareMediaType;
-               infoPtr->flags = flags;
-               if ( alternateAddressLength != 0 )
-               {
-                       /* make sure the volMountExtendedFlagsBit is set if there's extended address info */
-                       infoPtr->flags |= volMountExtendedFlagsMask;
-                       /* and set the only extendedFlags bit we know about */
-                       infoPtr->extendedFlags = kAFPExtendedFlagsAlternateAddressMask;
-               }
-               else
-               {
-                       /* make sure the volMountExtendedFlagsBit is clear if there's no extended address info */
-                       infoPtr->flags &= ~volMountExtendedFlagsMask;
-                       /* and clear the extendedFlags */
-                       infoPtr->extendedFlags = 0;
-               }
-               infoPtr->nbpInterval = nbpInterval;
-               infoPtr->nbpCount = nbpCount;
-               infoPtr->uamType = uamType;
-               
-               infoPtr->zoneNameOffset = offsetof(MyAFPXVolMountInfo, zoneName);               
-               infoPtr->serverNameOffset = offsetof(MyAFPXVolMountInfo, serverName);
-               infoPtr->volNameOffset = offsetof(MyAFPXVolMountInfo, volName);
-               infoPtr->userNameOffset = offsetof(MyAFPXVolMountInfo, userName);
-               infoPtr->userPasswordOffset = offsetof(MyAFPXVolMountInfo, userPassword);
-               infoPtr->volPasswordOffset = offsetof(MyAFPXVolMountInfo, volPassword);
-               infoPtr->uamNameOffset = offsetof(MyAFPXVolMountInfo, uamName);
-               infoPtr->alternateAddressOffset = offsetof(MyAFPXVolMountInfo, alternateAddress);
-               
-               BlockMoveData(zoneName, infoPtr->zoneName, sizeof(Str32));
-               BlockMoveData(serverName, infoPtr->serverName, sizeof(Str32));
-               BlockMoveData(volName, infoPtr->volName, sizeof(Str27));
-               BlockMoveData(userName, infoPtr->userName, sizeof(Str31));
-               BlockMoveData(userPassword, infoPtr->userPassword, sizeof(Str8));
-               BlockMoveData(volPassword, infoPtr->volPassword, sizeof(Str8));
-               BlockMoveData(uamName, infoPtr->uamName, sizeof(Str32));
-               BlockMoveData(alternateAddress, infoPtr->alternateAddress, alternateAddressLength);
-               
-               *afpXInfoPtr = (AFPXVolMountInfoPtr)infoPtr;
-               error = noErr;
-       }
-       else
-       {
-               error = memFullErr;
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   RetrieveAFPXVolMountInfo(AFPXVolMountInfoPtr afpXInfoPtr,
-                                                                                short *flags,
-                                                                                short *uamType,
-                                                                                StringPtr zoneName,
-                                                                                StringPtr serverName,
-                                                                                StringPtr volName,
-                                                                                StringPtr userName,
-                                                                                StringPtr uamName,
-                                                                                unsigned long *alternateAddressLength,
-                                                                                AFPAlternateAddress **alternateAddress)
-{
-       StringPtr       tempPtr;
-       Ptr                     alternateAddressStart;
-       Ptr                     alternateAddressEnd;
-       Size            alternateAddressDataSize;
-       OSErr           error;
-       UInt8           addressCount;
-               
-       /* Retrieve the AFP mounting information from an AFPVolMountInfo record. */
-       if ( afpXInfoPtr->media == AppleShareMediaType )
-       {
-               /* default to noErr */
-               error = noErr;
-               
-               /* Is this an extended record? */
-               if ( (afpXInfoPtr->flags & volMountExtendedFlagsMask) != 0 )
-               {
-                       if ( ((afpXInfoPtr->extendedFlags & kAFPExtendedFlagsAlternateAddressMask) != 0) &&
-                                (afpXInfoPtr->alternateAddressOffset != 0) )
-                       {
-                               
-                               alternateAddressStart = (Ptr)((long)afpXInfoPtr + afpXInfoPtr->alternateAddressOffset);
-                               alternateAddressEnd = alternateAddressStart + 1;        /* skip over alternate address version byte */
-                               addressCount = *(UInt8*)alternateAddressEnd;            /* get the address count */
-                               ++alternateAddressEnd;                                                          /* skip over alternate address count byte */
-                               /* alternateAddressEnd now equals &AFPAlternateAddress.fAddressList[0] */
-                               while ( addressCount != 0 )
-                               {
-                                       /* parse the address list to find the end */
-                                       alternateAddressEnd += *(UInt8*)alternateAddressEnd;    /* add length of each AFPTagData record */
-                                       --addressCount;
-                               }
-                               /* get the size of the alternateAddressData */
-                               alternateAddressDataSize = alternateAddressEnd - alternateAddressStart;
-                               /* allocate memory for it */
-                               *alternateAddress = (AFPAlternateAddress *)NewPtr(alternateAddressDataSize);
-                               if ( *alternateAddress != NULL )
-                               {
-                                       /* and return the data */
-                                       BlockMoveData(alternateAddressStart, *alternateAddress, alternateAddressDataSize);
-                                       *alternateAddressLength = alternateAddressDataSize;
-                               }
-                               else
-                               {
-                                       /* no memory - fail now */
-                                       error = memFullErr;
-                               }
-                       }
-                       
-                       if ( error == noErr )   /* fill in more output parameters if everything is OK */
-                       {
-                               if ( afpXInfoPtr->uamNameOffset != 0 )
-                               {
-                                       tempPtr = (StringPtr)((long)afpXInfoPtr + afpXInfoPtr->uamNameOffset);
-                                       BlockMoveData(tempPtr, uamName, tempPtr[0] + 1);
-                               }
-                       }
-               }
-               
-               if ( error == noErr )   /* fill in more output parameters if everything is OK */
-               {
-                       *flags = afpXInfoPtr->flags;
-                       *uamType = afpXInfoPtr->uamType;
-                       
-                       if ( afpXInfoPtr->zoneNameOffset != 0 )
-                       {
-                               tempPtr = (StringPtr)((long)afpXInfoPtr + afpXInfoPtr->zoneNameOffset);
-                               BlockMoveData(tempPtr, zoneName, tempPtr[0] + 1);
-                       }
-                       
-                       if ( afpXInfoPtr->serverNameOffset != 0 )
-                       {
-                               tempPtr = (StringPtr)((long)afpXInfoPtr + afpXInfoPtr->serverNameOffset);
-                               BlockMoveData(tempPtr, serverName, tempPtr[0] + 1);
-                       }
-                       
-                       if ( afpXInfoPtr->volNameOffset != 0 )
-                       {
-                               tempPtr = (StringPtr)((long)afpXInfoPtr + afpXInfoPtr->volNameOffset);
-                               BlockMoveData(tempPtr, volName, tempPtr[0] + 1);
-                       }
-                       
-                       if ( afpXInfoPtr->userNameOffset != 0 )
-                       {
-                               tempPtr = (StringPtr)((long)afpXInfoPtr + afpXInfoPtr->userNameOffset);
-                               BlockMoveData(tempPtr, userName, tempPtr[0] + 1);
-                       }
-               }
-       }
-       else
-       {
-               error = paramErr;
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   GetUGEntries(short objType,
-                                                        UGEntryPtr entries,
-                                                        long reqEntryCount,
-                                                        long *actEntryCount,
-                                                        long *objID)
-{
-       HParamBlockRec pb;
-       OSErr error = noErr;
-       UGEntry *endEntryArray;
-
-       pb.objParam.ioObjType = objType;
-       *actEntryCount = 0;
-       for ( endEntryArray = entries + reqEntryCount; (entries < endEntryArray) && (error == noErr); ++entries )
-       {
-               pb.objParam.ioObjNamePtr = (StringPtr)entries->name;
-               pb.objParam.ioObjID = *objID;
-               /* Files.h in the universal interfaces, PBGetUGEntrySync takes a CMovePBPtr */
-               /* as the parameter. Inside Macintosh and the original glue used HParmBlkPtr. */
-               /* A CMovePBPtr works OK, but this will be changed in the future  back to */
-               /* HParmBlkPtr, so I'm just casting it here. */
-               error = PBGetUGEntrySync(&pb);
-               if ( error == noErr )
-               {
-                       entries->objID = *objID = pb.objParam.ioObjID;
-                       entries->objType = objType;
-                       ++*actEntryCount;
-               }
-       }
-       
-       return ( error );
-}
-
-/*****************************************************************************/
-
diff --git a/src/mac/morefile/MoreFilesExtras.h b/src/mac/morefile/MoreFilesExtras.h
deleted file mode 100644 (file)
index 285dfa7..0000000
+++ /dev/null
@@ -1,3597 +0,0 @@
-/*
-     File:       MoreFilesExtras.h
-     Contains:   A collection of useful high-level File Manager routines.
-     Version:    Technology: MoreFiles
-                 Release:    1.5.2
-     Copyright:  © 1992-2001 by Apple Computer, Inc., all rights reserved.
-     Bugs?:      For bug reports, consult the following page on
-                 the World Wide Web:
-                     http://developer.apple.com/bugreporter/
-*/
-
-/*
-    You may incorporate this sample code into your applications without
-    restriction, though the sample code has been provided "AS IS" and the
-    responsibility for its operation is 100% yours.  However, what you are
-    not permitted to do is to redistribute the source as "DSC Sample Code"
-    after having made changes. If you're going to re-distribute the source,
-    we require that you make it clear in the source that the code was
-    descended from Apple Sample Code, but that you've made changes.
-*/
-
-#ifndef __MOREFILESEXTRAS__
-#define __MOREFILESEXTRAS__
-
-#ifndef __MACTYPES__
-#include <MacTypes.h>
-#endif
-
-#ifndef __FILES__
-#include <Files.h>
-#endif
-
-#include "Optimization.h"
-
-
-#if PRAGMA_ONCE
-#pragma once
-#endif
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#if PRAGMA_IMPORT
-#pragma import on
-#endif
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=mac68k
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(push, 2)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack(2)
-#endif
-
-/*****************************************************************************/
-
-/*
-**  Bit masks and macros to get common information out of ioACUser returned
-**  by PBGetCatInfo (remember to clear ioACUser before calling PBGetCatInfo
-**  since some file systems don't bother to set this field).
-**
-**  Use the GetDirAccessRestrictions or FSpGetDirAccessRestrictions
-**  functions to retrieve the ioACUser access restrictions byte for
-**  a folder.
-**
-**  Note:   The access restriction byte returned by PBGetCatInfo is the
-**          2's complement of the user's privileges byte returned in
-**          ioACAccess by PBHGetDirAccess.
-*/
-
-enum {
-                                        /* mask for just the access restriction bits */
-  acUserAccessMask              = (kioACUserNoSeeFolderMask + kioACUserNoSeeFilesMask + kioACUserNoMakeChangesMask), /* common access privilege settings */
-  acUserFull                    = 0x00, /* no access restiction bits on */
-  acUserNone                    = acUserAccessMask, /* all access restiction bits on */
-  acUserDropBox                 = kioACUserNoSeeFolderMask + kioACUserNoSeeFilesMask, /* make changes, but not see files or folders */
-  acUserBulletinBoard           = kioACUserNoMakeChangesMask /* see files and folders, but not make changes */
-};
-
-
-/*****************************************************************************/
-
-/*
-**  Deny mode permissions for use with the HOpenAware, HOpenRFAware,
-**  FSpOpenAware, and FSpOpenRFAware functions.
-**  Note: Common settings are the ones with comments.
-*/
-
-enum {
-  dmNone                        = 0x0000,
-  dmNoneDenyRd                  = fsRdDenyPerm,
-  dmNoneDenyWr                  = fsWrDenyPerm,
-  dmNoneDenyRdWr                = (fsRdDenyPerm + fsWrDenyPerm),
-  dmRd                          = fsRdPerm, /* Single writer, multiple readers; the readers */
-  dmRdDenyRd                    = (fsRdPerm + fsRdDenyPerm),
-  dmRdDenyWr                    = (fsRdPerm + fsWrDenyPerm), /* Browsing - equivalent to fsRdPerm */
-  dmRdDenyRdWr                  = (fsRdPerm + fsRdDenyPerm + fsWrDenyPerm),
-  dmWr                          = fsWrPerm,
-  dmWrDenyRd                    = (fsWrPerm + fsRdDenyPerm),
-  dmWrDenyWr                    = (fsWrPerm + fsWrDenyPerm),
-  dmWrDenyRdWr                  = (fsWrPerm + fsRdDenyPerm + fsWrDenyPerm),
-  dmRdWr                        = fsRdWrPerm, /* Shared access - equivalent to fsRdWrShPerm */
-  dmRdWrDenyRd                  = (fsRdWrPerm + fsRdDenyPerm),
-  dmRdWrDenyWr                  = (fsRdWrPerm + fsWrDenyPerm), /* Single writer, multiple readers; the writer */
-  dmRdWrDenyRdWr                = (fsRdWrPerm + fsRdDenyPerm + fsWrDenyPerm) /* Exclusive access - equivalent to fsRdWrPerm */
-};
-
-
-/*****************************************************************************/
-
-/*
-**  For those times where you need to use more than one kind of File Manager parameter
-**  block but don't feel like wasting stack space, here's a parameter block you can reuse.
-*/
-
-
-union UniversalFMPB {
-  ParamBlockRec       PB;
-  CInfoPBRec          ciPB;
-  DTPBRec             dtPB;
-  HParamBlockRec      hPB;
-  CMovePBRec          cmPB;
-  WDPBRec             wdPB;
-  FCBPBRec            fcbPB;
-  XVolumeParam        xPB;
-};
-typedef union UniversalFMPB             UniversalFMPB;
-typedef UniversalFMPB *                 UniversalFMPBPtr;
-typedef UniversalFMPBPtr *              UniversalFMPBHandle;
-
-/*
-**  Used by GetUGEntries to return user or group lists
-*/
-
-struct UGEntry {
-  short               objType;                /* object type: -1 = group; 0 = user */
-  long                objID;                  /* the user or group ID */
-  Str31               name;                   /* the user or group name */
-};
-typedef struct UGEntry                  UGEntry;
-typedef UGEntry *                       UGEntryPtr;
-typedef UGEntryPtr *                    UGEntryHandle;
-
-/*
-**  I use the following records instead of the AFPVolMountInfo and AFPXVolMountInfo structures in Files.h
-*/
-typedef unsigned char                   Str8[9];
-
-struct MyAFPVolMountInfo {
-  short               length;                 /* length of this record */
-  VolumeType          media;                  /* type of media, always AppleShareMediaType */
-  short               flags;                  /* 0 = normal mount; set bit 0 to inhibit greeting messages */
-  char                nbpInterval;            /* NBP interval parameter; 7 is a good choice */
-  char                nbpCount;               /* NBP count parameter; 5 is a good choice */
-  short               uamType;                /* User Authentication Method */
-  short               zoneNameOffset;         /* offset from start of record to zoneName */
-  short               serverNameOffset;       /* offset from start of record to serverName */
-  short               volNameOffset;          /* offset from start of record to volName */
-  short               userNameOffset;         /* offset from start of record to userName */
-  short               userPasswordOffset;     /* offset from start of record to userPassword */
-  short               volPasswordOffset;      /* offset from start of record to volPassword */
-  Str32               zoneName;               /* server's AppleTalk zone name */
-  char                filler1;                /* to word align volPassword */
-  Str32               serverName;             /* server name */
-  char                filler2;                /* to word align volPassword */
-  Str27               volName;                /* volume name */
-  Str31               userName;               /* user name (zero length Pascal string for guest) */
-  Str8                userPassword;           /* user password (zero length Pascal string if no user password) */
-  char                filler3;                /* to word align volPassword */
-  Str8                volPassword;            /* volume password (zero length Pascal string if no volume password) */
-  char                filler4;                /* to end record on word boundry */
-};
-typedef struct MyAFPVolMountInfo        MyAFPVolMountInfo;
-typedef MyAFPVolMountInfo *             MyAFPVolMountInfoPtr;
-typedef MyAFPVolMountInfoPtr *          MyAFPVolMountInfoHandle;
-
-struct MyAFPXVolMountInfo {
-  short               length;                 /* length of this record */
-  VolumeType          media;                  /* type of media, always AppleShareMediaType */
-  short               flags;                  /* bits for no messages, no reconnect, etc */
-  char                nbpInterval;            /* NBP interval parameter; 7 is a good choice */
-  char                nbpCount;               /* NBP count parameter; 5 is a good choice */
-  short               uamType;                /* User Authentication Method */
-  short               zoneNameOffset;         /* offset from start of record to zoneName */
-  short               serverNameOffset;       /* offset from start of record to serverName */
-  short               volNameOffset;          /* offset from start of record to volName */
-  short               userNameOffset;         /* offset from start of record to userName */
-  short               userPasswordOffset;     /* offset from start of record to userPassword */
-  short               volPasswordOffset;      /* offset from start of record to volPassword */
-  short               extendedFlags;          /* extended flags word */
-  short               uamNameOffset;          /* offset to a pascal UAM name string */
-  short               alternateAddressOffset; /* offset to Alternate Addresses in tagged format */
-  Str32               zoneName;               /* server's AppleTalk zone name */
-  char                filler1;                /* to word align volPassword */
-  Str32               serverName;             /* server name */
-  char                filler2;                /* to word align volPassword */
-  Str27               volName;                /* volume name */
-  Str31               userName;               /* user name (zero length Pascal string for guest) */
-  Str8                userPassword;           /* user password (zero length Pascal string if no user password) */
-  char                filler3;                /* to word align volPassword */
-  Str8                volPassword;            /* volume password (zero length Pascal string if no volume password) */
-  char                filler4;                /* to word align uamNameOffset */
-  Str32               uamName;                /* UAM name */
-  char                filler5;                /* to word align alternateAddress */
-  char                alternateAddress[1];    /* AFPAlternateAddress */
-};
-typedef struct MyAFPXVolMountInfo       MyAFPXVolMountInfo;
-typedef MyAFPXVolMountInfo *            MyAFPXVolMountInfoPtr;
-typedef MyAFPXVolMountInfoPtr *         MyAFPXVolMountInfoHandle;
-
-/*****************************************************************************/
-
-/* Functions to get information out of GetVolParmsInfoBuffer. */
-
-/* version 1 field getters */
-
-EXTERN_API( short )
-GetVolParmsInfoVersion(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( long )
-GetVolParmsInfoAttrib(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Handle )
-GetVolParmsInfoLocalHand(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( long )
-GetVolParmsInfoServerAdr(const GetVolParmsInfoBuffer * volParms);
-
-
-
-/* version 2 field getters (assume zero result if version < 2) */
-
-EXTERN_API( long )
-GetVolParmsInfoVolumeGrade(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( long )
-GetVolParmsInfoForeignPrivID(const GetVolParmsInfoBuffer * volParms);
-
-
-
-/* version 3 field getters (assume zero result if version < 3) */
-
-EXTERN_API( long )
-GetVolParmsInfoExtendedAttributes(const GetVolParmsInfoBuffer * volParms);
-
-
-
-/* attribute bits supported by all versions of GetVolParmsInfoBuffer */
-
-EXTERN_API( Boolean )
-isNetworkVolume(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasLimitFCBs(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasLocalWList(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasNoMiniFndr(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasNoVNEdit(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasNoLclSync(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasTrshOffLine(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasNoSwitchTo(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasNoDeskItems(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasNoBootBlks(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasAccessCntl(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasNoSysDir(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasExtFSVol(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasOpenDeny(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasCopyFile(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasMoveRename(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasDesktopMgr(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasShortName(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasFolderLock(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasPersonalAccessPrivileges(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasUserGroupList(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasCatSearch(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasFileIDs(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasBTreeMgr(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-hasBlankAccessPrivileges(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-supportsAsyncRequests(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-supportsTrashVolumeCache(const GetVolParmsInfoBuffer * volParms);
-
-
-
-/* attribute bits supported by version 3 and greater versions of GetVolParmsInfoBuffer */
-
-EXTERN_API( Boolean )
-volIsEjectable(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-volSupportsHFSPlusAPIs(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-volSupportsFSCatalogSearch(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-volSupportsFSExchangeObjects(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-volSupports2TBFiles(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-volSupportsLongNames(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-volSupportsMultiScriptNames(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-volSupportsNamedForks(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-volSupportsSubtreeIterators(const GetVolParmsInfoBuffer * volParms);
-
-
-EXTERN_API( Boolean )
-volL2PCanMapFileBlocks(const GetVolParmsInfoBuffer * volParms);
-
-
-
-/*****************************************************************************/
-
-/* Functions for testing ioACUser bits. */
-
-EXTERN_API( Boolean )
-userIsOwner(SInt8 ioACUser);
-
-
-EXTERN_API( Boolean )
-userHasFullAccess(SInt8 ioACUser);
-
-
-EXTERN_API( Boolean )
-userHasDropBoxAccess(SInt8 ioACUser);
-
-
-EXTERN_API( Boolean )
-userHasBulletinBoard(SInt8 ioACUser);
-
-
-EXTERN_API( Boolean )
-userHasNoAccess(SInt8 ioACUser);
-
-
-
-/*****************************************************************************/
-
-EXTERN_API( void )
-TruncPString(
-  StringPtr          destination,
-  ConstStr255Param   source,
-  short              maxLength);
-
-
-/*
-    The TruncPString function copies up to maxLength characters from
-    the source Pascal string to the destination Pascal string. TruncPString
-    ensures that the truncated string ends on a single-byte character, or on
-    the last byte of a multi-byte character.
-    
-    destination     output: destination Pascal string.
-    source          input:  source Pascal string.
-    maxLength       output: The maximum allowable length of the destination
-                            string.
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( Ptr )
-GetTempBuffer(
-  long    buffReqSize,
-  long *  buffActSize);
-
-
-/*
-    The GetTempBuffer function allocates a temporary buffer for file system
-    operations which is at least 1024 bytes (1K) and a multiple of
-    1024 bytes.
-    
-    buffReqSize     input:  Size you'd like the buffer to be.
-    buffActSize     output: Size of buffer allocated.
-    function result output: Pointer to memory allocated or nil if no memory
-                            was available. The caller is responsible for
-                            disposing of this buffer with DisposePtr.
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetVolumeInfoNoName(
-  ConstStr255Param   pathname,
-  short              vRefNum,
-  HParmBlkPtr        pb);
-
-
-/*
-    GetVolumeInfoNoName uses pathname and vRefNum to call PBHGetVInfoSync
-    in cases where the returned volume name is not needed by the caller.
-    The pathname and vRefNum parameters are not touched, and the pb
-    parameter is initialized by PBHGetVInfoSync except that ioNamePtr in
-    the parameter block is always returned as NULL (since it might point
-    to GetVolumeInfoNoName's local variable tempPathname).
-
-    I noticed using this code in several places, so here it is once.
-    This reduces the code size of MoreFiles.
-
-    pathName    input:  Pointer to a full pathname or nil.  If you pass in a 
-                        partial pathname, it is ignored. A full pathname to a
-                        volume must end with a colon character (:).
-    vRefNum     input:  Volume specification (volume reference number, working
-                        directory number, drive number, or 0).
-    pb          input:  A pointer to HParamBlockRec.
-                output: The parameter block as filled in by PBHGetVInfoSync
-                        except that ioNamePtr will always be NULL.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        paramErr            -50     No default volume, or pb was NULL
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-XGetVolumeInfoNoName(
-  ConstStr255Param   pathname,
-  short              vRefNum,
-  XVolumeParamPtr    pb);
-
-
-/*
-    XGetVolumeInfoNoName uses pathname and vRefNum to call PBXGetVolInfoSync
-    in cases where the returned volume name is not needed by the caller.
-    The pathname and vRefNum parameters are not touched, and the pb
-    parameter is initialized by PBXGetVolInfoSync except that ioNamePtr in
-    the parameter block is always returned as NULL (since it might point
-    to XGetVolumeInfoNoName's local variable tempPathname).
-
-    pathName    input:  Pointer to a full pathname or nil.  If you pass in a 
-                        partial pathname, it is ignored. A full pathname to a
-                        volume must end with a colon character (:).
-    vRefNum     input:  Volume specification (volume reference number, working
-                        directory number, drive number, or 0).
-    pb          input:  A pointer to HParamBlockRec.
-                output: The parameter block as filled in by PBXGetVolInfoSync
-                        except that ioNamePtr will always be NULL.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        paramErr            -50     No default volume, or pb was NULL
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetCatInfoNoName(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  CInfoPBPtr         pb);
-
-
-/*
-    GetCatInfoNoName uses vRefNum, dirID and name to call PBGetCatInfoSync
-    in cases where the returned object is not needed by the caller.
-    The vRefNum, dirID and name parameters are not touched, and the pb
-    parameter is initialized by PBGetCatInfoSync except that ioNamePtr in
-    the parameter block is always returned as NULL (since it might point
-    to GetCatInfoNoName's local variable tempName).
-
-    I noticed using this code in several places, so here it is once.
-    This reduces the code size of MoreFiles.
-
-    vRefNum         input:  Volume specification.
-    dirID           input:  Directory ID.
-    name            input:  Pointer to object name, or nil when dirID
-                            specifies a directory that's the object.
-    pb              input:  A pointer to CInfoPBRec.
-                    output: The parameter block as filled in by
-                            PBGetCatInfoSync except that ioNamePtr will
-                            always be NULL.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-        
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-DetermineVRefNum(
-  ConstStr255Param   pathname,
-  short              vRefNum,
-  short *            realVRefNum);
-
-
-/*
-    The DetermineVRefNum function determines the volume reference number of
-    a volume from a pathname, a volume specification, or a combination
-    of the two.
-    WARNING: Volume names on the Macintosh are *not* unique -- Multiple
-    mounted volumes can have the same name. For this reason, the use of a
-    volume name or full pathname to identify a specific volume may not
-    produce the results you expect.  If more than one volume has the same
-    name and a volume name or full pathname is used, the File Manager
-    currently uses the first volume it finds with a matching name in the
-    volume queue.
-
-    pathName    input:  Pointer to a full pathname or nil.  If you pass in a 
-                        partial pathname, it is ignored. A full pathname to a
-                        volume must end with a colon character (:).
-    vRefNum     input:  Volume specification (volume reference number, working
-                        directory number, drive number, or 0).
-    realVRefNum output: The real volume reference number.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        paramErr            -50     No default volume
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-HGetVInfo(
-  short            volReference,
-  StringPtr        volName,
-  short *          vRefNum,
-  unsigned long *  freeBytes,
-  unsigned long *  totalBytes);
-
-
-/*
-    The HGetVInfo function returns the name, volume reference number,
-    available space (in bytes), and total space (in bytes) for the
-    specified volume. You can specify the volume by providing its drive
-    number, volume reference number, or 0 for the default volume.
-    This routine is compatible with volumes up to 4 gigabytes.
-    
-    volReference    input:  The drive number, volume reference number,
-                            or 0 for the default volume.
-    volName         input:  A pointer to a buffer (minimum Str27) where
-                            the volume name is to be returned or must
-                            be nil.
-                    output: The volume name.
-    vRefNum         output: The volume reference number.
-    freeBytes       output: The number of free bytes on the volume.
-                            freeBytes is an unsigned long value.
-    totalBytes      output: The total number of bytes on the volume.
-                            totalBytes is an unsigned long value.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        paramErr            -50     No default volume
-    
-    __________
-    
-    Also see:   XGetVInfo
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-XGetVInfo(
-  short       volReference,
-  StringPtr   volName,
-  short *     vRefNum,
-  UInt64 *    freeBytes,
-  UInt64 *    totalBytes);
-
-
-/*
-    The XGetVInfo function returns the name, volume reference number,
-    available space (in bytes), and total space (in bytes) for the
-    specified volume. You can specify the volume by providing its drive
-    number, volume reference number, or 0 for the default volume.
-    This routine is compatible with volumes up to 2 terabytes.
-    
-    volReference    input:  The drive number, volume reference number,
-                            or 0 for the default volume.
-    volName         input:  A pointer to a buffer (minimum Str27) where
-                            the volume name is to be returned or must
-                            be nil.
-                    output: The volume name.
-    vRefNum         output: The volume reference number.
-    freeBytes       output: The number of free bytes on the volume.
-                            freeBytes is an UnsignedWide value.
-    totalBytes      output: The total number of bytes on the volume.
-                            totalBytes is an UnsignedWide value.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        paramErr            -50     No default volume
-    
-    __________
-    
-    Also see:   HGetVInfo
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-CheckVolLock(
-  ConstStr255Param   pathname,
-  short              vRefNum);
-
-
-/*
-    The CheckVolLock function determines if a volume is locked - either by
-    hardware or by software. If CheckVolLock returns noErr, then the volume
-    is not locked.
-
-    pathName    input:  Pointer to a full pathname or nil.  If you pass in a 
-                        partial pathname, it is ignored. A full pathname to a
-                        volume must end with a colon character (:).
-    vRefNum     input:  Volume specification (volume reference number, working
-                        directory number, drive number, or 0).
-    
-    Result Codes
-        noErr               0       No error - volume not locked
-        nsvErr              -35     No such volume
-        wPrErr              -44     Volume locked by hardware
-        vLckdErr            -46     Volume locked by software
-        paramErr            -50     No default volume
-*/
-
-/*****************************************************************************/
-/*
-**  The following routines call Mac OS routines that are not supported by
-**  Carbon:
-**  
-**      GetDriverName
-**      FindDrive
-**      GetDiskBlocks
-**      GetVolState
-*/
-
-#if !TARGET_API_MAC_CARBON  //  {
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetDriverName(
-  short    driverRefNum,
-  Str255   driverName);
-
-
-/*
-    The GetDriverName function returns a device driver's name.
-
-    driverRefNum    input:  The driver reference number.
-    driverName      output: The driver's name.
-    
-    Result Codes
-        noErr               0       No error
-        badUnitErr          -21     Bad driver reference number
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FindDrive(
-  ConstStr255Param   pathname,
-  short              vRefNum,
-  DrvQElPtr *        driveQElementPtr);
-
-
-/*
-    The FindDrive function returns a pointer to a mounted volume's
-    drive queue element.
-
-    pathName            input:  Pointer to a full pathname or nil. If you
-                                pass in a partial pathname, it is ignored.
-                                A full pathname to a volume must end with
-                                a colon character (:).
-    vRefNum             input:  Volume specification (volume reference
-                                number, working directory number, drive
-                                number, or 0).
-    driveQElementPtr    output: Pointer to a volume's drive queue element
-                                in the drive queue. DO NOT change the
-                                DrvQEl.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        paramErr            -50     No default volume
-        nsDrvErr            -56     No such drive
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetDiskBlocks(
-  ConstStr255Param   pathname,
-  short              vRefNum,
-  unsigned long *    numBlocks);
-
-
-/*
-    The GetDiskBlocks function returns the number of physical disk
-    blocks on a disk drive. NOTE: This is not the same as volume
-    allocation blocks!
-
-    pathName    input:  Pointer to a full pathname or nil. If you
-                        pass in a partial pathname, it is ignored.
-                        A full pathname to a volume must end with
-                        a colon character (:).
-    vRefNum     input:  Volume specification (volume reference
-                        number, working directory number, drive
-                        number, or 0).
-    numBlocks   output: The number of physical disk blocks on the disk drive.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        paramErr            -50     No default volume, driver reference
-                                    number is zero, ReturnFormatList
-                                    returned zero blocks, DriveStatus
-                                    returned an unknown value, or
-                                    driveQElementPtr->qType is unknown
-        nsDrvErr            -56     No such drive
-        statusErr           Ð18     Driver does not respond to this
-                                    status request
-        badUnitErr          Ð21     Driver reference number does not
-                                    match unit table
-        unitEmptyErr        Ð22     Driver reference number specifies
-                                    a nil handle in unit table
-        abortErr            Ð27     Request aborted by KillIO
-        notOpenErr          Ð28     Driver not open
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetVolState(
-  ConstStr255Param   pathname,
-  short              vRefNum,
-  Boolean *          volumeOnline,
-  Boolean *          volumeEjected,
-  Boolean *          driveEjectable,
-  Boolean *          driverWantsEject);
-
-
-/*
-    The GetVolState function determines if a volume is online or offline,
-    if an offline volume is ejected, and if the volume's driver is
-    ejectable or wants eject calls.
-    
-    pathName            input:  Pointer to a full pathname or nil.
-    vRefNum             input:  Volume specification (volume reference number,
-                                working directory number, drive number, or 0).
-    volumeOnline        output: True if the volume is online;
-                                False if the volume is offline.
-    volumeEjected       output: True if the volume is ejected (ejected
-                                volumes are always offline); False if the
-                                volume is not ejected.
-    driveEjectable      output: True if the volume's drive is ejectable;
-                                False if the volume's drive is not ejectable.
-    driverWantsEject    output: True if the volume's driver wants an Eject
-                                request after unmount (even if the drive
-                                is not ejectable); False if the volume's
-                                driver does not need an eject request.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        paramErr            -50     No default volume, or pb was NULL
-*/
-
-/*****************************************************************************/
-
-#endif  //  }   !TARGET_API_MAC_CARBON
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetVolFileSystemID(
-  ConstStr255Param   pathname,
-  short              vRefNum,
-  short *            fileSystemID);
-
-
-/*
-    The GetVolFileSystemID function returned the file system ID of
-    a mounted volume. The file system ID identifies the file system
-    that handles requests to a particular volume. Here's a partial list
-    of file system ID numbers (only Apple's file systems are listed):
-        FSID    File System
-        -----   -----------------------------------------------------
-        $0000   Macintosh HFS or MFS
-        $0100   ProDOS File System
-        $0101   PowerTalk Mail Enclosures
-        $4147   ISO 9660 File Access (through Foreign File Access)
-        $4242   High Sierra File Access (through Foreign File Access)
-        $464D   QuickTake File System (through Foreign File Access)
-        $4953   Macintosh PC Exchange (MS-DOS)
-        $4A48   Audio CD Access (through Foreign File Access)
-        $4D4B   Apple Photo Access (through Foreign File Access)
-    
-    See the Technical Note "FL 35 - Determining Which File System
-    Is Active" and the "Guide to the File System Manager" for more
-    information.
-    
-    pathName        input:  Pointer to a full pathname or nil.  If you pass
-                            in a partial pathname, it is ignored. A full
-                            pathname to a volume must contain at least
-                            one colon character (:) and must not start with
-                            a colon character.
-    vRefNum         input:  Volume specification (volume reference number,
-                            working directory number, drive number, or 0).
-    fileSystemID    output: The volume's file system ID.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        paramErr            -50     No default volume, or pb was NULL
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-UnmountAndEject(
-  ConstStr255Param   pathname,
-  short              vRefNum);
-
-
-/*
-    The UnmountAndEject function unmounts and ejects a volume. The volume
-    is ejected only if it is ejectable and not already ejected.
-    
-    pathName    input:  Pointer to a full pathname or nil.  If you pass in a 
-                        partial pathname, it is ignored. A full pathname to a
-                        volume must end with a colon character (:).
-    vRefNum     input:  Volume specification (volume reference number, working
-                        directory number, drive number, or 0).
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad volume name
-        fBsyErr             -47     One or more files are open
-        paramErr            -50     No default volume
-        nsDrvErr            -56     No such drive
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-OnLine(
-  FSSpecPtr   volumes,
-  short       reqVolCount,
-  short *     actVolCount,
-  short *     volIndex);
-
-
-/*
-    The OnLine function returns the list of volumes currently mounted in
-    an array of FSSpec records.
-    
-    A noErr result indicates that the volumes array was filled
-    (actVolCount == reqVolCount) and there may be additional volumes
-    mounted. A nsvErr result indicates that the end of the volume list
-    was found and actVolCount volumes were actually found this time.
-
-    volumes     input:  Pointer to array of FSSpec where the volume list
-                        is returned.
-    reqVolCount input:  Maximum number of volumes to return (the number of
-                        elements in the volumes array).
-    actVolCount output: The number of volumes actually returned.
-    volIndex    input:  The current volume index position. Set to 1 to
-                        start with the first volume.
-                output: The volume index position to get the next volume.
-                        Pass this value the next time you call OnLine to
-                        start where you left off.
-    
-    Result Codes
-        noErr               0       No error, but there are more volumes
-                                    to list
-        nsvErr              -35     No more volumes to be listed
-        paramErr            -50     volIndex was <= 0
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-SetDefault(
-  short    newVRefNum,
-  long     newDirID,
-  short *  oldVRefNum,
-  long *   oldDirID);
-
-
-/*
-    The SetDefault function sets the default volume and directory to the
-    volume specified by newVRefNum and the directory specified by newDirID.
-    The current default volume reference number and directory ID are
-    returned in oldVRefNum and oldDir and must be used to restore the
-    default volume and directory to their previous state *as soon as
-    possible* with the RestoreDefault function. These two functions are
-    designed to be used as a wrapper around Standard I/O routines where
-    the location of the file is implied to be the default volume and
-    directory. In other words, this is how you should use these functions:
-    
-        error = SetDefault(newVRefNum, newDirID, &oldVRefNum, &oldDirID);
-        if ( error == noErr )
-        {
-            // call the Stdio functions like remove, rename, tmpfile,
-            // fopen, freopen, etc. or non-ANSI extensions like
-            // fdopen,fsetfileinfo, -- create, open, unlink, etc. here!
-            
-            error = RestoreDefault(oldVRefNum, oldDirID);
-        }
-    
-    By using these functions as a wrapper, you won't need to open a working
-    directory (because SetDefault and RestoreDefault use HSetVol) and you
-    won't have to worry about the effects of using HSetVol (documented in
-    Technical Note "FL 11 - PBHSetVol is Dangerous" and in the
-    Inside Macintosh: Files book in the description of the HSetVol and 
-    PBHSetVol functions) because the default volume/directory is restored
-    before giving up control to code that might be affected by HSetVol.
-    
-    newVRefNum  input:  Volume specification (volume reference number,
-                        working directory number, drive number, or 0) of
-                        the new default volume.
-    newDirID    input:  Directory ID of the new default directory.
-    oldVRefNum  output: The volume specification to save for use with
-                        RestoreDefault.
-    oldDirID    output: The directory ID to save for use with
-                        RestoreDefault.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        bdNamErr            -37     Bad volume name
-        fnfErr              -43     Directory not found
-        paramErr            -50     No default volume
-        afpAccessDenied     -5000   User does not have access to the directory
-    
-    __________
-    
-    Also see:   RestoreDefault
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-RestoreDefault(
-  short   oldVRefNum,
-  long    oldDirID);
-
-
-/*
-    The RestoreDefault function restores the default volume and directory
-    to the volume specified by oldVRefNum and the directory specified by 
-    oldDirID. The oldVRefNum and oldDirID parameters were previously
-    obtained from the SetDefault function. These two functions are designed
-    to be used as a wrapper around Standard C I/O routines where the
-    location of the file is implied to be the default volume and directory.
-    In other words, this is how you should use these functions:
-    
-        error = SetDefault(newVRefNum, newDirID, &oldVRefNum, &oldDirID);
-        if ( error == noErr )
-        {
-            // call the Stdio functions like remove, rename, tmpfile,
-            // fopen, freopen, etc. or non-ANSI extensions like
-            // fdopen,fsetfileinfo, -- create, open, unlink, etc. here!
-            
-            error = RestoreDefault(oldVRefNum, oldDirID);
-        }
-    
-    By using these functions as a wrapper, you won't need to open a working
-    directory (because SetDefault and RestoreDefault use HSetVol) and you
-    won't have to worry about the effects of using HSetVol (documented in
-    Technical Note "FL 11 - PBHSetVol is Dangerous" and in the
-    Inside Macintosh: Files book in the description of the HSetVol and 
-    PBHSetVol functions) because the default volume/directory is restored
-    before giving up control to code that might be affected by HSetVol.
-    
-    oldVRefNum  input: The volume specification to restore.
-    oldDirID    input:  The directory ID to restore.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        bdNamErr            -37     Bad volume name
-        fnfErr              -43     Directory not found
-        paramErr            -50     No default volume
-        rfNumErr            -51     Bad working directory reference number
-        afpAccessDenied     -5000   User does not have access to the directory
-    
-    __________
-    
-    Also see:   SetDefault
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetDInfo(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  DInfo *            fndrInfo);
-
-
-/*
-    The GetDInfo function gets the finder information for a directory.
-
-    vRefNum         input:  Volume specification.
-    dirID           input:  Directory ID.
-    name            input:  Pointer to object name, or nil when dirID
-                            specifies a directory that's the object.
-    fndrInfo        output: If the object is a directory, then its DInfo.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-        
-    __________
-    
-    Also see:   FSpGetDInfo, FSpGetFInfoCompat
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpGetDInfo(
-  const FSSpec *  spec,
-  DInfo *         fndrInfo);
-
-
-/*
-    The FSpGetDInfo function gets the finder information for a directory.
-
-    spec        input:  An FSSpec record specifying the directory.
-    fndrInfo    output: If the object is a directory, then its DInfo.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-        
-    __________
-    
-    Also see:   FSpGetFInfoCompat, GetDInfo
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-SetDInfo(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  const DInfo *      fndrInfo);
-
-
-/*
-    The SetDInfo function sets the finder information for a directory.
-
-    vRefNum         input:  Volume specification.
-    dirID           input:  Directory ID.
-    name            input:  Pointer to object name, or nil when dirID
-                            specifies a directory that's the object.
-    fndrInfo        input:  The DInfo.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    Also see:   FSpSetDInfo, FSpSetFInfoCompat
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpSetDInfo(
-  const FSSpec *  spec,
-  const DInfo *   fndrInfo);
-
-
-/*
-    The FSpSetDInfo function sets the finder information for a directory.
-
-    spec        input:  An FSSpec record specifying the directory.
-    fndrInfo    input:  The DInfo.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    Also see:   FSpSetFInfoCompat, SetDInfo
-*/
-
-/*****************************************************************************/
-
-#if OLDROUTINENAMES
-    #define GetDirID(vRefNum, dirID, name, theDirID, isDirectory) GetDirectoryID(vRefNum, dirID, name, theDirID, isDirectory)
-#endif
-EXTERN_API( OSErr )
-GetDirectoryID(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  long *             theDirID,
-  Boolean *          isDirectory);
-
-
-/*
-    The GetDirectoryID function gets the directory ID number of the
-    directory specified.  If a file is specified, then the parent
-    directory of the file is returned and isDirectory is false.  If
-    a directory is specified, then that directory's ID number is
-    returned and isDirectory is true.
-    WARNING: Volume names on the Macintosh are *not* unique -- Multiple
-    mounted volumes can have the same name. For this reason, the use of a
-    volume name or full pathname to identify a specific volume may not
-    produce the results you expect.  If more than one volume has the same
-    name and a volume name or full pathname is used, the File Manager
-    currently uses the first volume it finds with a matching name in the
-    volume queue.
-    
-    vRefNum         input:  Volume specification.
-    dirID           input:  Directory ID.
-    name            input:  Pointer to object name, or nil when dirID
-                            specifies a directory that's the object.
-    theDirID        output: If the object is a file, then its parent directory
-                            ID. If the object is a directory, then its ID.
-    isDirectory     output: True if object is a directory; false if
-                            object is a file.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-*/
-
-/*****************************************************************************/
-
-#if OLDROUTINENAMES
-    #define DirIDFromFSSpec(spec, theDirID, isDirectory) FSpGetDirectoryID(spec, theDirID, isDirectory)
-#endif
-EXTERN_API( OSErr )
-FSpGetDirectoryID(
-  const FSSpec *  spec,
-  long *          theDirID,
-  Boolean *       isDirectory);
-
-
-/*
-    The FSpGetDirectoryID function gets the directory ID number of the
-    directory specified by spec. If spec is to a file, then the parent
-    directory of the file is returned and isDirectory is false.  If
-    spec is to a directory, then that directory's ID number is
-    returned and isDirectory is true.
-    
-    spec            input:  An FSSpec record specifying the directory.
-    theDirID        output: The directory ID.
-    isDirectory     output: True if object is a directory; false if
-                            object is a file.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetDirName(
-  short   vRefNum,
-  long    dirID,
-  Str31   name);
-
-
-/*
-    The GetDirName function gets the name of a directory from its
-    directory ID.
-
-    vRefNum     input:  Volume specification.
-    dirID       input:  Directory ID.
-    name        output: Points to a Str31 where the directory name is to be
-                        returned.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume or
-                                    name parameter was NULL
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetIOACUser(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  SInt8 *            ioACUser);
-
-
-/*
-    GetIOACUser returns a directory's access restrictions byte.
-    Use the masks and macro defined in MoreFilesExtras to check for
-    specific access priviledges.
-    
-    vRefNum     input:  Volume specification.
-    dirID       input:  Directory ID.
-    name        input:  Pointer to object name, or nil when dirID
-                        specifies a directory that's the object.
-    ioACUser    output: The access restriction byte
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpGetIOACUser(
-  const FSSpec *  spec,
-  SInt8 *         ioACUser);
-
-
-/*
-    FSpGetIOACUser returns a directory's access restrictions byte.
-    Use the masks and macro defined in MoreFilesExtras to check for
-    specific access priviledges.
-    
-    spec        input:  An FSSpec record specifying the directory.
-    ioACUser    output: The access restriction byte
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetParentID(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  long *             parID);
-
-
-/*
-    The GetParentID function gets the parent directory ID number of the
-    specified object.
-    
-    vRefNum     input:  Volume specification.
-    dirID       input:  Directory ID.
-    name        input:  Pointer to object name, or nil when dirID specifies
-                        a directory that's the object.
-    parID       output: The parent directory ID of the specified object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetFilenameFromPathname(
-  ConstStr255Param   pathname,
-  Str255             filename);
-
-
-/*
-    The GetFilenameFromPathname function gets the file (or directory) name
-    from the end of a full or partial pathname. Returns notAFileErr if the
-    pathname is nil, the pathname is empty, or the pathname cannot refer to
-    a filename (with a noErr result, the pathname could still refer to a
-    directory).
-    
-    pathname    input:  A full or partial pathname.
-    filename    output: The file (or directory) name.
-    
-    Result Codes
-        noErr               0       No error
-        notAFileErr         -1302   The pathname is nil, the pathname
-                                    is empty, or the pathname cannot refer
-                                    to a filename
-    
-    __________
-    
-    See also:   GetObjectLocation.
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetObjectLocation(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   pathname,
-  short *            realVRefNum,
-  long *             realParID,
-  Str255             realName,
-  Boolean *          isDirectory);
-
-
-/*
-    The GetObjectLocation function gets a file system object's location -
-    that is, its real volume reference number, real parent directory ID,
-    and name. While we're at it, determine if the object is a file or directory.
-    If GetObjectLocation returns fnfErr, then the location information
-    returned is valid, but it describes an object that doesn't exist.
-    You can use the location information for another operation, such as
-    creating a file or directory.
-    
-    vRefNum     input:  Volume specification.
-    dirID       input:  Directory ID.
-    pathname    input:  Pointer to object name, or nil when dirID specifies
-                        a directory that's the object.
-    realVRefNum output: The real volume reference number.
-    realParID   output: The parent directory ID of the specified object.
-    realName    output: The name of the specified object (the case of the
-                        object name may not be the same as the object's
-                        catalog entry on disk - since the Macintosh file
-                        system is not case sensitive, it shouldn't matter).
-    isDirectory output: True if object is a directory; false if object
-                        is a file.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        notAFileErr         -1302   The pathname is nil, the pathname
-                                    is empty, or the pathname cannot refer
-                                    to a filename
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   FSMakeFSSpecCompat
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetDirItems(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  Boolean            getFiles,
-  Boolean            getDirectories,
-  FSSpecPtr          items,
-  short              reqItemCount,
-  short *            actItemCount,
-  short *            itemIndex);
-
-
-/*
-    The GetDirItems function returns a list of items in the specified
-    directory in an array of FSSpec records. File, subdirectories, or
-    both can be returned in the list.
-    
-    A noErr result indicates that the items array was filled
-    (actItemCount == reqItemCount) and there may be additional items
-    left in the directory. A fnfErr result indicates that the end of
-    the directory list was found and actItemCount items were actually
-    found this time.
-
-    vRefNum         input:  Volume specification.
-    dirID           input:  Directory ID.
-    name            input:  Pointer to object name, or nil when dirID
-                            specifies a directory that's the object.
-    getFiles        input:  Pass true to have files added to the items list.
-    getDirectories  input:  Pass true to have directories added to the
-                            items list.
-    items           input:  Pointer to array of FSSpec where the item list
-                            is returned.
-    reqItemCount    input:  Maximum number of items to return (the number
-                            of elements in the items array).
-    actItemCount    output: The number of items actually returned.
-    itemIndex       input:  The current item index position. Set to 1 to
-                            start with the first item in the directory.
-                    output: The item index position to get the next item.
-                            Pass this value the next time you call
-                            GetDirItems to start where you left off.
-    
-    Result Codes
-        noErr               0       No error, but there are more items
-                                    to list
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found, there are no more items
-                                    to be listed.
-        paramErr            -50     No default volume or itemIndex was <= 0
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-DeleteDirectoryContents(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The DeleteDirectoryContents function deletes the contents of a directory.
-    All files and subdirectories in the specified directory are deleted.
-    If a locked file or directory is encountered, it is unlocked and then
-    deleted.  If any unexpected errors are encountered,
-    DeleteDirectoryContents quits and returns to the caller.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to directory name, or nil when dirID specifies
-                    a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        wPrErr              -44     Hardware volume lock    
-        fLckdErr            -45     File is locked  
-        vLckdErr            -46     Software volume lock    
-        fBsyErr             -47     File busy, directory not empty, or working directory control block open 
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    Also see:   DeleteDirectory
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-DeleteDirectory(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The DeleteDirectory function deletes a directory and its contents.
-    All files and subdirectories in the specified directory are deleted.
-    If a locked file or directory is encountered, it is unlocked and then
-    deleted.  After deleting the directories contents, the directory is
-    deleted. If any unexpected errors are encountered, DeleteDirectory
-    quits and returns to the caller.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to directory name, or nil when dirID specifies
-                    a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        wPrErr              -44     Hardware volume lock
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Software volume lock
-        fBsyErr             -47     File busy, directory not empty, or working directory control block open 
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    Also see:   DeleteDirectoryContents
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-CheckObjectLock(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The CheckObjectLock function determines if a file or directory is locked.
-    If CheckObjectLock returns noErr, then the file or directory
-    is not locked. If CheckObjectLock returns fLckdErr, the it is locked.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to object name, or nil when dirID specifies
-                    a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    Also see:   FSpCheckObjectLock
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpCheckObjectLock(const FSSpec * spec);
-
-
-/*
-    The FSpCheckObjectLock function determines if a file or directory is locked.
-    If FSpCheckObjectLock returns noErr, then the file or directory
-    is not locked.
-    
-    spec    input:  An FSSpec record specifying the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    Also see:   CheckObjectLock
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetFileSize(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   fileName,
-  long *             dataSize,
-  long *             rsrcSize);
-
-
-/*
-    The GetFileSize function returns the logical size of a file's
-    data and resource fork.
-    
-    vRefNum     input:  Volume specification.
-    dirID       input:  Directory ID.
-    name        input:  The name of the file.
-    dataSize    output: The number of bytes in the file's data fork.
-    rsrcSize    output: The number of bytes in the file's resource fork.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume
-        dirNFErrdirNFErr    -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   FSpGetFileSize
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpGetFileSize(
-  const FSSpec *  spec,
-  long *          dataSize,
-  long *          rsrcSize);
-
-
-/*
-    The FSpGetFileSize function returns the logical size of a file's
-    data and resource fork.
-    
-    spec        input:  An FSSpec record specifying the file.
-    dataSize    output: The number of bytes in the file's data fork.
-    rsrcSize    output: The number of bytes in the file's resource fork.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        paramErr            -50     No default volume
-        dirNFErrdirNFErr    -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   GetFileSize
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-BumpDate(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The BumpDate function changes the modification date of a file or
-    directory to the current date/time.  If the modification date is already
-    equal to the current date/time, then add one second to the
-    modification date.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to object name, or nil when dirID specifies
-                    a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   FSpBumpDate
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpBumpDate(const FSSpec * spec);
-
-
-/*
-    The FSpBumpDate function changes the modification date of a file or
-    directory to the current date/time.  If the modification date is already
-    equal to the current date/time, then add one second to the
-    modification date.
-    
-    spec    input:  An FSSpec record specifying the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   BumpDate
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-ChangeCreatorType(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  OSType             creator,
-  OSType             fileType);
-
-
-/*
-    The ChangeCreatorType function changes the creator or file type of a file.
-
-    vRefNum     input:  Volume specification.
-    dirID       input:  Directory ID.
-    name        input:  The name of the file.
-    creator     input:  The new creator type or 0x00000000 to leave
-                        the creator type alone.
-    fileType    input:  The new file type or 0x00000000 to leave the
-                        file type alone.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        notAFileErr         -1302   Name was not a file
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   FSpChangeCreatorType
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpChangeCreatorType(
-  const FSSpec *  spec,
-  OSType          creator,
-  OSType          fileType);
-
-
-/*
-    The FSpChangeCreatorType function changes the creator or file type of a file.
-
-    spec        input:  An FSSpec record specifying the file.
-    creator     input:  The new creator type or 0x00000000 to leave
-                        the creator type alone.
-    fileType    input:  The new file type or 0x00000000 to leave the
-                        file type alone.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        notAFileErr         -1302   Name was not a file
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   ChangeCreatorType
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-ChangeFDFlags(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name,
-  Boolean            setBits,
-  unsigned short     flagBits);
-
-
-/*
-    The ChangeFDFlags function sets or clears Finder Flag bits in the
-    fdFlags field of a file or directory's FInfo record.
-    
-    vRefNum     input:  Volume specification.
-    dirID       input:  Directory ID.
-    name        input:  Pointer to object name, or nil when dirID specifies
-                        a directory that's the object.
-    setBits     input:  If true, then set the bits specified in flagBits.
-                        If false, then clear the bits specified in flagBits.
-    flagBits    input:  The flagBits parameter specifies which Finder Flag
-                        bits to set or clear. If a bit in flagBits is set,
-                        then the same bit in fdFlags is either set or
-                        cleared depending on the state of the setBits
-                        parameter.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   FSpChangeFDFlags
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpChangeFDFlags(
-  const FSSpec *   spec,
-  Boolean          setBits,
-  unsigned short   flagBits);
-
-
-/*
-    The FSpChangeFDFlags function sets or clears Finder Flag bits in the
-    fdFlags field of a file or directory's FInfo record.
-    
-    spec        input:  An FSSpec record specifying the object.
-    setBits     input:  If true, then set the bits specified in flagBits.
-                        If false, then clear the bits specified in flagBits.
-    flagBits    input:  The flagBits parameter specifies which Finder Flag
-                        bits to set or clear. If a bit in flagBits is set,
-                        then the same bit in fdFlags is either set or
-                        cleared depending on the state of the setBits
-                        parameter.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   ChangeFDFlags
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-SetIsInvisible(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The SetIsInvisible function sets the invisible bit in the fdFlags
-    word of the specified file or directory's finder information.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to object name, or nil when dirID specifies
-                    a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   FSpSetIsInvisible, ClearIsInvisible, FSpClearIsInvisible
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpSetIsInvisible(const FSSpec * spec);
-
-
-/*
-    The FSpSetIsInvisible function sets the invisible bit in the fdFlags
-    word of the specified file or directory's finder information.
-    
-    spec    input:  An FSSpec record specifying the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   SetIsInvisible, ClearIsInvisible, FSpClearIsInvisible
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-ClearIsInvisible(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The ClearIsInvisible function clears the invisible bit in the fdFlags
-    word of the specified file or directory's finder information.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to object name, or nil when dirID specifies
-                    a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   SetIsInvisible, FSpSetIsInvisible, FSpClearIsInvisible
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpClearIsInvisible(const FSSpec * spec);
-
-
-/*
-    The FSpClearIsInvisible function clears the invisible bit in the fdFlags
-    word of the specified file or directory's finder information.
-    
-    spec    input:  An FSSpec record specifying the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   SetIsInvisible, FSpSetIsInvisible, ClearIsInvisible
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-SetNameLocked(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The SetNameLocked function sets the nameLocked bit in the fdFlags word
-    of the specified file or directory's finder information.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to object name, or nil when dirID specifies
-                    a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   FSpSetNameLocked, ClearNameLocked, FSpClearNameLocked
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpSetNameLocked(const FSSpec * spec);
-
-
-/*
-    The FSpSetNameLocked function sets the nameLocked bit in the fdFlags word
-    of the specified file or directory's finder information.
-    
-    spec    input:  An FSSpec record specifying the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   SetNameLocked, ClearNameLocked, FSpClearNameLocked
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-ClearNameLocked(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The ClearNameLocked function clears the nameLocked bit in the fdFlags
-    word of the specified file or directory's finder information.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to object name, or nil when dirID specifies
-                    a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   SetNameLocked, FSpSetNameLocked, FSpClearNameLocked
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpClearNameLocked(const FSSpec * spec);
-
-
-/*
-    The FSpClearNameLocked function clears the nameLocked bit in the fdFlags
-    word of the specified file or directory's finder information.
-    
-    spec    input:  An FSSpec record specifying the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   SetNameLocked, FSpSetNameLocked, ClearNameLocked
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-SetIsStationery(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The SetIsStationery function sets the isStationery bit in the
-    fdFlags word of the specified file or directory's finder information.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to object name, or nil when dirID specifies
-                    a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   FSpSetIsStationery, ClearIsStationery, FSpClearIsStationery
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpSetIsStationery(const FSSpec * spec);
-
-
-/*
-    The FSpSetIsStationery function sets the isStationery bit in the
-    fdFlags word of the specified file or directory's finder information.
-    
-    spec    input:  An FSSpec record specifying the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   SetIsStationery, ClearIsStationery, FSpClearIsStationery
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-ClearIsStationery(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The ClearIsStationery function clears the isStationery bit in the
-    fdFlags word of the specified file or directory's finder information.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to object name, or nil when dirID specifies
-                    a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   SetIsStationery, FSpSetIsStationery, FSpClearIsStationery
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpClearIsStationery(const FSSpec * spec);
-
-
-/*
-    The FSpClearIsStationery function clears the isStationery bit in the
-    fdFlags word of the specified file or directory's finder information.
-    
-    spec    input:  An FSSpec record specifying the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   SetIsStationery, FSpSetIsStationery, ClearIsStationery
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-SetHasCustomIcon(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The SetHasCustomIcon function sets the hasCustomIcon bit in the
-    fdFlags word of the specified file or directory's finder information.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to object name, or nil when dirID specifies
-                    a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   FSpSetHasCustomIcon, ClearHasCustomIcon, FSpClearHasCustomIcon
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpSetHasCustomIcon(const FSSpec * spec);
-
-
-/*
-    The FSpSetHasCustomIcon function sets the hasCustomIcon bit in the
-    fdFlags word of the specified file or directory's finder information.
-    
-    spec    input:  An FSSpec record specifying the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   SetHasCustomIcon, ClearHasCustomIcon, FSpClearHasCustomIcon
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-ClearHasCustomIcon(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The ClearHasCustomIcon function clears the hasCustomIcon bit in the
-    fdFlags word of the specified file or directory's finder information.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to object name, or nil when dirID specifies
-                    a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   SetHasCustomIcon, FSpSetHasCustomIcon, FSpClearHasCustomIcon
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpClearHasCustomIcon(const FSSpec * spec);
-
-
-/*
-    The FSpClearHasCustomIcon function clears the hasCustomIcon bit in the
-    fdFlags word of the specified file or directory's finder information.
-    
-    spec    input:  An FSSpec record specifying the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   SetHasCustomIcon, FSpSetHasCustomIcon, ClearHasCustomIcon
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-ClearHasBeenInited(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   name);
-
-
-/*
-    The ClearHasBeenInited function clears the hasBeenInited bit in the
-    fdFlags word of the specified file or directory's finder information.
-    
-    vRefNum input:  Volume specification.
-    dirID   input:  Directory ID.
-    name    input:  Pointer to object name, or nil when dirID specifies
-                    a directory that's the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   FSpClearHasBeenInited
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpClearHasBeenInited(const FSSpec * spec);
-
-
-/*
-    The FSpClearHasBeenInited function clears the hasBeenInited bit in the
-    fdFlags word of the specified file or directory's finder information.
-    
-    spec    input:  An FSSpec record specifying the object.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   ClearHasBeenInited
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-CopyFileMgrAttributes(
-  short              srcVRefNum,
-  long               srcDirID,
-  ConstStr255Param   srcName,
-  short              dstVRefNum,
-  long               dstDirID,
-  ConstStr255Param   dstName,
-  Boolean            copyLockBit);
-
-
-/*
-    The CopyFileMgrAttributes function copies all File Manager attributes
-    from the source file or directory to the destination file or directory.
-    If copyLockBit is true, then set the locked state of the destination
-    to match the source.
-
-    srcVRefNum  input:  Source volume specification.
-    srcDirID    input:  Source directory ID.
-    srcName     input:  Pointer to source object name, or nil when
-                        srcDirID specifies a directory that's the object.
-    dstVRefNum  input:  Destination volume specification.
-    dstDirID    input:  Destination directory ID.
-    dstName     input:  Pointer to destination object name, or nil when
-                        dstDirID specifies a directory that's the object.
-    copyLockBit input:  If true, set the locked state of the destination
-                        to match the source.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   FSpCopyFileMgrAttributes
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpCopyFileMgrAttributes(
-  const FSSpec *  srcSpec,
-  const FSSpec *  dstSpec,
-  Boolean         copyLockBit);
-
-
-/*
-    The FSpCopyFileMgrAttributes function copies all File Manager attributes
-    from the source file or directory to the destination file or directory.
-    If copyLockBit is true, then set the locked state of the destination
-    to match the source.
-
-    srcSpec     input:  An FSSpec record specifying the source object.
-    dstSpec     input:  An FSSpec record specifying the destination object.
-    copyLockBit input:  If true, set the locked state of the destination
-                        to match the source.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename
-        fnfErr              -43     File not found
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     No default volume
-        dirNFErr            -120    Directory not found or incomplete pathname
-        afpAccessDenied     -5000   User does not have the correct access
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-    
-    __________
-    
-    See also:   CopyFileMgrAttributes
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-HOpenAware(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   fileName,
-  short              denyModes,
-  short *            refNum);
-
-
-/*
-    The HOpenAware function opens the data fork of a file using deny mode
-    permissions instead the normal File Manager permissions.  If OpenDeny
-    is not available, then HOpenAware translates the deny modes to the
-    closest File Manager permissions and tries to open the file with
-    OpenDF first, and then Open if OpenDF isn't available. By using
-    HOpenAware with deny mode permissions, a program can be "AppleShare
-    aware" and fall back on the standard File Manager open calls
-    automatically.
-
-    vRefNum     input:  Volume specification.
-    dirID       input:  Directory ID.
-    fileName    input:  The name of the file.
-    denyModes   input:  The deny modes access under which to open the file.
-    refNum      output: The file reference number of the opened file.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        tmfoErr             -42     Too many files open
-        fnfErr              -43     File not found
-        wPrErr              -44     Volume locked by hardware
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        opWrErr             -49     File already open for writing
-        paramErr            -50     No default volume
-        permErr             -54     File is already open and cannot be opened using specified deny modes
-        afpAccessDenied     -5000   User does not have the correct access to the file
-        afpDenyConflict     -5006   Requested access permission not possible
-    
-    __________
-    
-    See also:   FSpOpenAware, HOpenRFAware, FSpOpenRFAware
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpOpenAware(
-  const FSSpec *  spec,
-  short           denyModes,
-  short *         refNum);
-
-
-/*
-    The FSpOpenAware function opens the data fork of a file using deny mode
-    permissions instead the normal File Manager permissions.  If OpenDeny
-    is not available, then FSpOpenAware translates the deny modes to the
-    closest File Manager permissions and tries to open the file with
-    OpenDF first, and then Open if OpenDF isn't available. By using
-    FSpOpenAware with deny mode permissions, a program can be "AppleShare
-    aware" and fall back on the standard File Manager open calls
-    automatically.
-
-    spec        input:  An FSSpec record specifying the file.
-    denyModes   input:  The deny modes access under which to open the file.
-    refNum      output: The file reference number of the opened file.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        tmfoErr             -42     Too many files open
-        fnfErr              -43     File not found
-        wPrErr              -44     Volume locked by hardware
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        opWrErr             -49     File already open for writing
-        paramErr            -50     No default volume
-        permErr             -54     File is already open and cannot be opened using specified deny modes
-        afpAccessDenied     -5000   User does not have the correct access to the file
-        afpDenyConflict     -5006   Requested access permission not possible
-    
-    __________
-    
-    See also:   HOpenAware, HOpenRFAware, FSpOpenRFAware
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-HOpenRFAware(
-  short              vRefNum,
-  long               dirID,
-  ConstStr255Param   fileName,
-  short              denyModes,
-  short *            refNum);
-
-
-/*
-    The HOpenRFAware function opens the resource fork of a file using deny
-    mode permissions instead the normal File Manager permissions.  If
-    OpenRFDeny is not available, then HOpenRFAware translates the deny
-    modes to the closest File Manager permissions and tries to open the
-    file with OpenRF. By using HOpenRFAware with deny mode permissions,
-    a program can be "AppleShare aware" and fall back on the standard
-    File Manager open calls automatically.
-
-    vRefNum     input:  Volume specification.
-    dirID       input:  Directory ID.
-    fileName    input:  The name of the file.
-    denyModes   input:  The deny modes access under which to open the file.
-    refNum      output: The file reference number of the opened file.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        tmfoErr             -42     Too many files open
-        fnfErr              -43     File not found
-        wPrErr              -44     Volume locked by hardware
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        opWrErr             -49     File already open for writing
-        paramErr            -50     No default volume
-        permErr             -54     File is already open and cannot be opened using specified deny modes
-        afpAccessDenied     -5000   User does not have the correct access to the file
-        afpDenyConflict     -5006   Requested access permission not possible
-    
-    __________
-    
-    See also:   HOpenAware, FSpOpenAware, FSpOpenRFAware
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpOpenRFAware(
-  const FSSpec *  spec,
-  short           denyModes,
-  short *         refNum);
-
-
-/*
-    The FSpOpenRFAware function opens the resource fork of a file using deny
-    mode permissions instead the normal File Manager permissions.  If
-    OpenRFDeny is not available, then FSpOpenRFAware translates the deny
-    modes to the closest File Manager permissions and tries to open the
-    file with OpenRF. By using FSpOpenRFAware with deny mode permissions,
-    a program can be "AppleShare aware" and fall back on the standard
-    File Manager open calls automatically.
-
-    spec        input:  An FSSpec record specifying the file.
-    denyModes   input:  The deny modes access under which to open the file.
-    refNum      output: The file reference number of the opened file.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     No such volume
-        tmfoErr             -42     Too many files open
-        fnfErr              -43     File not found
-        wPrErr              -44     Volume locked by hardware
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Volume is locked or read-only
-        opWrErr             -49     File already open for writing
-        paramErr            -50     No default volume
-        permErr             -54     File is already open and cannot be opened using specified deny modes
-        afpAccessDenied     -5000   User does not have the correct access to the file
-        afpDenyConflict     -5006   Requested access permission not possible
-    
-    __________
-    
-    See also:   HOpenAware, FSpOpenAware, HOpenRFAware
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSReadNoCache(
-  short   refNum,
-  long *  count,
-  void *  buffPtr);
-
-
-/*
-    The FSReadNoCache function reads any number of bytes from an open file
-    while asking the file system to bypass its cache mechanism.
-    
-    refNum  input:  The file reference number of an open file.
-    count   input:  The number of bytes to read.
-            output: The number of bytes actually read.
-    buffPtr input:  A pointer to the data buffer into which the bytes are
-                    to be read.
-    
-    Result Codes
-        noErr               0       No error
-        readErr             Ð19     Driver does not respond to read requests
-        badUnitErr          Ð21     Driver reference number does not
-                                    match unit table
-        unitEmptyErr        Ð22     Driver reference number specifies a
-                                    nil handle in unit table
-        abortErr            Ð27     Request aborted by KillIO
-        notOpenErr          Ð28     Driver not open
-        ioErr               Ð36     Data does not match in read-verify mode
-        fnOpnErr            -38     File not open
-        rfNumErr            -51     Bad reference number
-        afpAccessDenied     -5000   User does not have the correct access to
-                                    the file
-
-    __________
-    
-    See also:   FSWriteNoCache
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSWriteNoCache(
-  short         refNum,
-  long *        count,
-  const void *  buffPtr);
-
-
-/*
-    The FSReadNoCache function writes any number of bytes to an open file
-    while asking the file system to bypass its cache mechanism.
-    
-    refNum  input:  The file reference number of an open file.
-    count   input:  The number of bytes to write to the file.
-            output: The number of bytes actually written.
-    buffPtr input:  A pointer to the data buffer from which the bytes are
-                    to be written.
-    
-    Result Codes
-        noErr               0       No error
-        writErr             Ð20     Driver does not respond to write requests
-        badUnitErr          Ð21     Driver reference number does not
-                                    match unit table
-        unitEmptyErr        Ð22     Driver reference number specifies a
-                                    nil handle in unit table
-        abortErr            Ð27     Request aborted by KillIO
-        notOpenErr          Ð28     Driver not open
-        dskFulErr           -34     Disk full   
-        ioErr               Ð36     Data does not match in read-verify mode
-        fnOpnErr            -38     File not open
-        wPrErr              -44     Hardware volume lock    
-        fLckdErr            -45     File is locked  
-        vLckdErr            -46     Software volume lock    
-        rfNumErr            -51     Bad reference number
-        wrPermErr           -61     Read/write permission doesnÕt
-                                    allow writing   
-        afpAccessDenied     -5000   User does not have the correct access to
-                                    the file
-
-    __________
-    
-    See also:   FSReadNoCache
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSWriteVerify(
-  short         refNum,
-  long *        count,
-  const void *  buffPtr);
-
-
-/*
-    The FSWriteVerify function writes any number of bytes to an open file
-    and then verifies that the data was actually written to the device.
-    
-    refNum  input:  The file reference number of an open file.
-    count   input:  The number of bytes to write to the file.
-            output: The number of bytes actually written and verified.
-    buffPtr input:  A pointer to the data buffer from which the bytes are
-                    to be written.
-    
-    Result Codes
-        noErr               0       No error
-        readErr             Ð19     Driver does not respond to read requests
-        writErr             Ð20     Driver does not respond to write requests
-        badUnitErr          Ð21     Driver reference number does not
-                                    match unit table
-        unitEmptyErr        Ð22     Driver reference number specifies a
-                                    nil handle in unit table
-        abortErr            Ð27     Request aborted by KillIO
-        notOpenErr          Ð28     Driver not open
-        dskFulErr           -34     Disk full   
-        ioErr               Ð36     Data does not match in read-verify mode
-        fnOpnErr            -38     File not open
-        eofErr              -39     Logical end-of-file reached
-        posErr              -40     Attempt to position mark before start
-                                    of file
-        wPrErr              -44     Hardware volume lock    
-        fLckdErr            -45     File is locked  
-        vLckdErr            -46     Software volume lock    
-        rfNumErr            -51     Bad reference number
-        gfpErr              -52     Error during GetFPos
-        wrPermErr           -61     Read/write permission doesnÕt
-                                    allow writing   
-        memFullErr          -108    Not enough room in heap zone to allocate
-                                    verify buffer
-        afpAccessDenied     -5000   User does not have the correct access to
-                                    the file
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-CopyFork(
-  short   srcRefNum,
-  short   dstRefNum,
-  void *  copyBufferPtr,
-  long    copyBufferSize);
-
-
-/*
-    The CopyFork function copies all data from the source fork to the
-    destination fork of open file forks and makes sure the destination EOF
-    is equal to the source EOF.
-    
-    srcRefNum       input:  The source file reference number.
-    dstRefNum       input:  The destination file reference number.
-    copyBufferPtr   input:  Pointer to buffer to use during copy. The
-                            buffer should be at least 512-bytes minimum.
-                            The larger the buffer, the faster the copy.
-    copyBufferSize  input:  The size of the copy buffer.
-    
-    Result Codes
-        noErr               0       No error
-        readErr             Ð19     Driver does not respond to read requests
-        writErr             Ð20     Driver does not respond to write requests
-        badUnitErr          Ð21     Driver reference number does not
-                                    match unit table
-        unitEmptyErr        Ð22     Driver reference number specifies a
-                                    nil handle in unit table
-        abortErr            Ð27     Request aborted by KillIO
-        notOpenErr          Ð28     Driver not open
-        dskFulErr           -34     Disk full   
-        ioErr               Ð36     Data does not match in read-verify mode
-        fnOpnErr            -38     File not open
-        wPrErr              -44     Hardware volume lock    
-        fLckdErr            -45     File is locked  
-        vLckdErr            -46     Software volume lock    
-        rfNumErr            -51     Bad reference number
-        wrPermErr           -61     Read/write permission doesnÕt
-                                    allow writing   
-        afpAccessDenied     -5000   User does not have the correct access to
-                                    the file
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetFileLocation(
-  short       refNum,
-  short *     vRefNum,
-  long *      dirID,
-  StringPtr   fileName);
-
-
-/*
-    The GetFileLocation function gets the location (volume reference number,
-    directory ID, and fileName) of an open file.
-
-    refNum      input:  The file reference number of an open file.
-    vRefNum     output: The volume reference number.
-    dirID       output: The parent directory ID.
-    fileName    input:  Points to a buffer (minimum Str63) where the
-                        filename is to be returned or must be nil.
-                output: The filename.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Specified volume doesnÕt exist
-        fnOpnErr            -38     File not open
-        rfNumErr            -51     Reference number specifies nonexistent
-                                    access path
-    
-    __________
-    
-    See also:   FSpGetFileLocation
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpGetFileLocation(
-  short     refNum,
-  FSSpec *  spec);
-
-
-/*
-    The FSpGetFileLocation function gets the location of an open file in
-    an FSSpec record.
-
-    refNum      input:  The file reference number of an open file.
-    spec        output: FSSpec record containing the file name and location.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Specified volume doesnÕt exist
-        fnOpnErr            -38     File not open
-        rfNumErr            -51     Reference number specifies nonexistent
-                                    access path
-    
-    __________
-    
-    See also:   GetFileLocation
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-CopyDirectoryAccess(
-  short              srcVRefNum,
-  long               srcDirID,
-  ConstStr255Param   srcName,
-  short              dstVRefNum,
-  long               dstDirID,
-  ConstStr255Param   dstName);
-
-
-/*
-    The CopyDirectoryAccess function copies the AFP directory access
-    privileges from one directory to another. Both directories must be on
-    the same file server, but not necessarily on the same server volume.
-    
-    srcVRefNum  input:  Source volume specification.
-    srcDirID    input:  Source directory ID.
-    srcName     input:  Pointer to source directory name, or nil when
-                        srcDirID specifies the directory.
-    dstVRefNum  input:  Destination volume specification.
-    dstDirID    input:  Destination directory ID.
-    dstName     input:  Pointer to destination directory name, or nil when
-                        dstDirID specifies the directory.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        fnfErr              -43     Directory not found
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     Volume doesn't support this function
-        afpAccessDenied     -5000   User does not have the correct access
-                                    to the directory
-        afpObjectTypeErr    -5025   Object is a file, not a directory
-    
-    __________
-    
-    See also:   FSpCopyDirectoryAccess
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpCopyDirectoryAccess(
-  const FSSpec *  srcSpec,
-  const FSSpec *  dstSpec);
-
-
-/*
-    The FSpCopyDirectoryAccess function copies the AFP directory access
-    privileges from one directory to another. Both directories must be on
-    the same file server, but not necessarily on the same server volume.
-
-    srcSpec     input:  An FSSpec record specifying the source directory.
-    dstSpec     input:  An FSSpec record specifying the destination directory.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        fnfErr              -43     Directory not found
-        vLckdErr            -46     Volume is locked or read-only
-        paramErr            -50     Volume doesn't support this function
-        afpAccessDenied     -5000   User does not have the correct access
-                                    to the directory
-        afpObjectTypeErr    -5025   Object is a file, not a directory
-    
-    __________
-    
-    See also:   CopyDirectoryAccess
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-HMoveRenameCompat(
-  short              vRefNum,
-  long               srcDirID,
-  ConstStr255Param   srcName,
-  long               dstDirID,
-  ConstStr255Param   dstpathName,
-  ConstStr255Param   copyName);
-
-
-/*
-    The HMoveRenameCompat function moves a file or directory and optionally
-    renames it.  The source and destination locations must be on the same
-    volume. This routine works even if the volume doesn't support MoveRename.
-    
-    vRefNum     input:  Volume specification.
-    srcDirID    input:  Source directory ID.
-    srcName     input:  The source object name.
-    dstDirID    input:  Destination directory ID.
-    dstName     input:  Pointer to destination directory name, or
-                        nil when dstDirID specifies a directory.
-    copyName    input:  Points to the new name if the object is to be
-                        renamed or nil if the object isn't to be renamed.
-    
-    Result Codes
-        noErr               0       No error
-        dirFulErr           -33     File directory full
-        dskFulErr           -34     Disk is full
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename or attempt to move into
-                                    a file
-        fnfErr              -43     Source file or directory not found
-        wPrErr              -44     Hardware volume lock
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Destination volume is read-only
-        fBsyErr             -47     File busy, directory not empty, or
-                                    working directory control block open
-        dupFNErr            -48     Destination already exists
-        paramErr            -50     Volume doesn't support this function,
-                                    no default volume, or source and
-        volOfflinErr        -53     Volume is offline
-        fsRnErr             -59     Problem during rename
-        dirNFErr            -120    Directory not found or incomplete pathname
-        badMovErr           -122    Attempted to move directory into
-                                    offspring
-        wrgVolTypErr        -123    Not an HFS volume (it's a MFS volume)
-        notAFileErr         -1302   The pathname is nil, the pathname
-                                    is empty, or the pathname cannot refer
-                                    to a filename
-        diffVolErr          -1303   Files on different volumes
-        afpAccessDenied     -5000   The user does not have the right to
-                                    move the file  or directory
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-        afpSameObjectErr    -5038   Source and destination files are the same
-    
-    __________
-    
-    See also:   FSpMoveRenameCompat
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-FSpMoveRenameCompat(
-  const FSSpec *     srcSpec,
-  const FSSpec *     dstSpec,
-  ConstStr255Param   copyName);
-
-
-/*
-    The FSpMoveRenameCompat function moves a file or directory and optionally
-    renames it.  The source and destination locations must be on the same
-    volume. This routine works even if the volume doesn't support MoveRename.
-    
-    srcSpec     input:  An FSSpec record specifying the source object.
-    dstSpec     input:  An FSSpec record specifying the destination
-                        directory.
-    copyName    input:  Points to the new name if the object is to be
-                        renamed or nil if the object isn't to be renamed.
-    
-    Result Codes
-        noErr               0       No error
-        dirFulErr           -33     File directory full
-        dskFulErr           -34     Disk is full
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        bdNamErr            -37     Bad filename or attempt to move into
-                                    a file
-        fnfErr              -43     Source file or directory not found
-        wPrErr              -44     Hardware volume lock
-        fLckdErr            -45     File is locked
-        vLckdErr            -46     Destination volume is read-only
-        fBsyErr             -47     File busy, directory not empty, or
-                                    working directory control block open
-        dupFNErr            -48     Destination already exists
-        paramErr            -50     Volume doesn't support this function,
-                                    no default volume, or source and
-        volOfflinErr        -53     Volume is offline
-        fsRnErr             -59     Problem during rename
-        dirNFErr            -120    Directory not found or incomplete pathname
-        badMovErr           -122    Attempted to move directory into
-                                    offspring
-        wrgVolTypErr        -123    Not an HFS volume (it's a MFS volume)
-        notAFileErr         -1302   The pathname is nil, the pathname
-                                    is empty, or the pathname cannot refer
-                                    to a filename
-        diffVolErr          -1303   Files on different volumes
-        afpAccessDenied     -5000   The user does not have the right to
-                                    move the file  or directory
-        afpObjectTypeErr    -5025   Directory not found or incomplete pathname
-        afpSameObjectErr    -5038   Source and destination files are the same
-    
-    __________
-    
-    See also:   HMoveRenameCompat
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-BuildAFPVolMountInfo(
-  short                 flags,
-  char                  nbpInterval,
-  char                  nbpCount,
-  short                 uamType,
-  Str32                 zoneName,
-  Str31                 serverName,
-  Str27                 volName,
-  Str31                 userName,
-  Str8                  userPassword,
-  Str8                  volPassword,
-  AFPVolMountInfoPtr *  afpInfoPtr);
-
-
-/*
-    The BuildAFPVolMountInfo function allocates and initializes the fields
-    of an AFPVolMountInfo record before using that record to call
-    the VolumeMount function.
-    
-    flags           input:  The AFP mounting flags. 0 = normal mount;
-                            set bit 0 to inhibit greeting messages.
-    nbpInterval     input:  The interval used for VolumeMount's
-                            NBP Lookup call. 7 is a good choice.
-    nbpCount        input:  The retry count used for VolumeMount's
-                            NBP Lookup call. 5 is a good choice.
-    uamType         input:  The user authentication method to use.
-    zoneName        input:  The AppleTalk zone name of the server.
-    serverName      input:  The AFP server name.
-    volName         input:  The AFP volume name.
-    userName        input:  The user name (zero length Pascal string for
-                            guest).
-    userPassWord    input:  The user password (zero length Pascal string
-                            if no user password)
-    volPassWord     input:  The volume password (zero length Pascal string
-                            if no volume password)
-    afpInfoPtr      output: A pointer to the newly created and initialized
-                            AFPVolMountInfo record. If the function fails to
-                            create an AFPVolMountInfo record, it sets
-                            afpInfoPtr to NULL and the function result is
-                            memFullErr. Your program is responsible
-                            for disposing of this pointer when it is finished
-                            with it.
-    
-    Result Codes
-        noErr               0       No error
-        memFullErr          -108    memory full error
-    
-    __________
-    
-    Also see:   GetVolMountInfoSize, GetVolMountInfo, VolumeMount,
-                RetrieveAFPVolMountInfo, BuildAFPXVolMountInfo,
-                RetrieveAFPXVolMountInfo
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-RetrieveAFPVolMountInfo(
-  AFPVolMountInfoPtr   afpInfoPtr,
-  short *              flags,
-  short *              uamType,
-  StringPtr            zoneName,
-  StringPtr            serverName,
-  StringPtr            volName,
-  StringPtr            userName);
-
-
-/*
-    The RetrieveAFPVolMountInfo function retrieves the AFP mounting
-    information returned in an AFPVolMountInfo record by the
-    GetVolMountInfo function.
-    
-    afpInfoPtr      input:  Pointer to AFPVolMountInfo record that contains
-                            the AFP mounting information.
-    flags           output: The AFP mounting flags.
-    uamType         output: The user authentication method used.
-    zoneName        output: The AppleTalk zone name of the server.
-    serverName      output: The AFP server name.
-    volName         output: The AFP volume name.
-    userName        output: The user name (zero length Pascal string for
-                            guest).
-    
-    Result Codes
-        noErr               0       No error
-        paramErr            -50     media field in AFP mounting information
-                                    was not AppleShareMediaType
-    
-    __________
-    
-    Also see:   GetVolMountInfoSize, GetVolMountInfo, VolumeMount,
-                BuildAFPVolMountInfo, BuildAFPXVolMountInfo,
-                RetrieveAFPXVolMountInfo
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-BuildAFPXVolMountInfo(
-  short                  flags,
-  char                   nbpInterval,
-  char                   nbpCount,
-  short                  uamType,
-  Str32                  zoneName,
-  Str31                  serverName,
-  Str27                  volName,
-  Str31                  userName,
-  Str8                   userPassword,
-  Str8                   volPassword,
-  Str32                  uamName,
-  unsigned long          alternateAddressLength,
-  void *                 alternateAddress,
-  AFPXVolMountInfoPtr *  afpXInfoPtr);
-
-
-/*
-    The BuildAFPXVolMountInfo function allocates and initializes the fields
-    of an AFPXVolMountInfo record before using that record to call
-    the VolumeMount function.
-    
-    flags                   input:  The AFP mounting flags.
-    nbpInterval             input:  The interval used for VolumeMount's
-                                    NBP Lookup call. 7 is a good choice.
-    nbpCount                input:  The retry count used for VolumeMount's
-                                    NBP Lookup call. 5 is a good choice.
-    uamType                 input:  The user authentication method to use.
-    zoneName                input:  The AppleTalk zone name of the server.
-    serverName              input:  The AFP server name.
-    volName                 input:  The AFP volume name.
-    userName                input:  The user name (zero length Pascal string
-                                    for guest).
-    userPassWord            input:  The user password (zero length Pascal
-                                    string if no user password)
-    volPassWord             input:  The volume password (zero length Pascal
-                                    string if no volume password)
-    uamName                 input:  The User Authentication Method name.
-    alternateAddressLength  input:  Length of alternateAddress data.
-    alternateAddress        input   The AFPAlternateAddress (variable length)
-    afpXInfoPtr             output: A pointer to the newly created and
-                                    initialized AFPVolMountInfo record.
-                                    If the function fails to create an
-                                    AFPVolMountInfo record, it sets
-                                    afpInfoPtr to NULL and the function
-                                    result is memFullErr. Your program is
-                                    responsible for disposing of this pointer
-                                    when it is finished with it.
-    
-    Result Codes
-        noErr               0       No error
-        memFullErr          -108    memory full error
-    
-    __________
-    
-    Also see:   GetVolMountInfoSize, GetVolMountInfo, VolumeMount,
-                BuildAFPVolMountInfo, RetrieveAFPVolMountInfo,
-                RetrieveAFPXVolMountInfo
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-RetrieveAFPXVolMountInfo(
-  AFPXVolMountInfoPtr     afpXInfoPtr,
-  short *                 flags,
-  short *                 uamType,
-  StringPtr               zoneName,
-  StringPtr               serverName,
-  StringPtr               volName,
-  StringPtr               userName,
-  StringPtr               uamName,
-  unsigned long *         alternateAddressLength,
-  AFPAlternateAddress **  alternateAddress);
-
-
-/*
-    The RetrieveAFPXVolMountInfo function retrieves the AFP mounting
-    information returned in an AFPXVolMountInfo record by the
-    GetVolMountInfo function.
-    
-    afpXInfoPtr             input:  Pointer to AFPXVolMountInfo record that
-                                    contains the AFP mounting information.
-    flags                   output: The AFP mounting flags.
-    uamType                 output: The user authentication method used.
-    zoneName                output: The AppleTalk zone name of the server.
-    serverName              output: The AFP server name.
-    volName                 output: The AFP volume name.
-    userName                output: The user name (zero length Pascal
-                                    string for guest).
-    uamName                 output: The User Authentication Method name.
-    alternateAddressLength  output: Length of alternateAddress data returned.
-    alternateAddress:       output: A pointer to the newly created and
-                                    AFPAlternateAddress record (a variable
-                                    length record). If the function fails to
-                                    create an AFPAlternateAddress record,
-                                    it sets alternateAddress to NULL and the
-                                    function result is memFullErr. Your
-                                    program is responsible for disposing of
-                                    this pointer when it is finished with it.
-    
-    Result Codes
-        noErr               0       No error
-        paramErr            -50     media field in AFP mounting information
-                                    was not AppleShareMediaType
-        memFullErr          -108    memory full error
-    
-    __________
-    
-    Also see:   GetVolMountInfoSize, GetVolMountInfo, VolumeMount,
-                BuildAFPVolMountInfo, RetrieveAFXVolMountInfo,
-                BuildAFPXVolMountInfo
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-GetUGEntries(
-  short        objType,
-  UGEntryPtr   entries,
-  long         reqEntryCount,
-  long *       actEntryCount,
-  long *       objID);
-
-
-/*
-    The GetUGEntries functions retrieves a list of user or group entries
-    from the local file server.
-
-    objType         input:  The object type: -1 = group; 0 = user
-    UGEntries       input:  Pointer to array of UGEntry records where the list
-                            is returned.
-    reqEntryCount   input:  The number of elements in the UGEntries array.
-    actEntryCount   output: The number of entries returned.
-    objID           input:  The current index position. Set to 0 to start with
-                            the first entry.
-                    output: The index position to get the next entry. Pass this
-                            value the next time you call GetUGEntries to start
-                            where you left off.
-    
-    Result Codes
-        noErr               0       No error    
-        fnfErr              -43     No more users or groups 
-        paramErr            -50     Function not supported; or, ioObjID is
-                                    negative    
-
-    __________
-    
-    Also see:   GetUGEntry
-*/
-
-/*****************************************************************************/
-
-
-
-#include "OptimizationEnd.h"
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=reset
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(pop)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack()
-#endif
-
-#ifdef PRAGMA_IMPORT_OFF
-#pragma import off
-#elif PRAGMA_IMPORT
-#pragma import reset
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* __MOREFILESEXTRAS__ */
-
diff --git a/src/mac/morefile/Optimization.h b/src/mac/morefile/Optimization.h
deleted file mode 100644 (file)
index d2673f9..0000000
+++ /dev/null
@@ -1,109 +0,0 @@
-/*
-       File:           Optimization.h
-
-       Contains:       Defines that let you make MoreFiles code more efficient.
-
-       Version:        MoreFiles
-
-       Copyright:      © 1992-2001 by Apple Computer, Inc., all rights reserved.
-
-       You may incorporate this sample code into your applications without
-       restriction, though the sample code has been provided "AS IS" and the
-       responsibility for its operation is 100% yours.  However, what you are
-       not permitted to do is to redistribute the source as "DSC Sample Code"
-       after having made changes. If you're going to re-distribute the source,
-       we require that you make it clear in the source that the code was
-       descended from Apple Sample Code, but that you've made changes.
-
-       File Ownership:
-
-               DRI:                            Apple Macintosh Developer Technical Support
-
-               Other Contact:          Apple Macintosh Developer Technical Support
-                                                       <http://developer.apple.com/bugreporter/>
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-
-       Change History (most recent first):
-
-                <1>      2/7/01        JL              first checked in
-*/
-
-/*
-       The Optimization changes to MoreFiles source and header files, along with
-       this file and OptimizationEnd.h, let you optimize the code produced
-       by MoreFiles in several ways.
-       
-       1 -- MoreFiles contains extra code so that many routines can run under
-       Mac OS systems back to System 6. If your program requires a specific
-       version of Mac OS and your program checks for that version before
-       calling MoreFiles routines, then you can remove a lot of compatibility
-       code by defining one of the following to 1:
-       
-               __MACOSSEVENFIVEONEORLATER      // assume Mac OS 7.5.1 or later
-               __MACOSSEVENFIVEORLATER         // assume Mac OS 7.5 or later
-               __MACOSSEVENORLATER                     // assume Mac OS 7.0 or later
-       
-       If you're compiling 68K code, the default is to include all compatibility code.
-       If you're compiling PowerPC code (TARGET_RT_MAC_CFM), the default is __MACOSSEVENORLATER
-       If you're compiling for Carbon code (TARGET_API_MAC_CARBON), the default is __MACOSSEVENFIVEONEORLATER
-       
-       2 -- You may disable Pascal calling conventions in all MoreFiles routines
-       except for system callbacks that require Pascal calling conventions.
-       This will make 68K C programs both smaller and faster. 
-       (PowerPC compilers ignore pascal calling conventions.)
-       Just define __WANTPASCALELIMINATION to be 1 to turn this optimization on
-       when building MoreFiles for use from C programs (you'll need to keep
-       Pascal calling conventions when linking MoreFiles routines with Pascal
-       programs).
-       
-       3 -- If Metrowerks compiler is used, "#pragma internal on" may help produce
-       better code. However, this option can also cause problems if you're
-       trying to build MoreFiles as a shared library, so it is by default not used.
-       Just define __USEPRAGMAINTERNAL to be 1 to turn this optimization on.
-       
-       Original changes supplied by Fabrizio Oddone
-*/
-
-#include <ConditionalMacros.h>
-
-// if we're compiling for Carbon, then we're running on Mac OS 8.1 or later
-#ifndef __MACOSSEVENFIVEONEORLATER
-       #define __MACOSSEVENFIVEONEORLATER TARGET_API_MAC_CARBON
-#endif
-
-#ifndef __MACOSSEVENFIVEORLATER
-       #define __MACOSSEVENFIVEORLATER __MACOSSEVENFIVEONEORLATER
-#endif
-
-#ifndef __MACOSSEVENORLATER
-       #if TARGET_RT_MAC_CFM
-               #define __MACOSSEVENORLATER 1
-       #else
-               #define __MACOSSEVENORLATER __MACOSSEVENFIVEORLATER
-       #endif
-#endif
-
-
-#ifndef        __WANTPASCALELIMINATION
-       #define __WANTPASCALELIMINATION 0
-#endif
-
-#if    __WANTPASCALELIMINATION
-       #define pascal  
-#endif
-
-
-#ifndef __USEPRAGMAINTERNAL
-       #define __USEPRAGMAINTERNAL     0
-#endif
-
-#if    __USEPRAGMAINTERNAL
-       #if defined(__MWERKS__)
-               #pragma internal on
-       #endif
-#endif
diff --git a/src/mac/morefile/OptimizationEnd.h b/src/mac/morefile/OptimizationEnd.h
deleted file mode 100644 (file)
index 10ed025..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-/*
-       File:           OptimizationEnd.h
-
-       Contains:       Defines that let you make MoreFiles code more efficient.
-
-       Version:        MoreFiles
-
-       Copyright:      © 1992-2001 by Apple Computer, Inc., all rights reserved.
-
-       You may incorporate this sample code into your applications without
-       restriction, though the sample code has been provided "AS IS" and the
-       responsibility for its operation is 100% yours.  However, what you are
-       not permitted to do is to redistribute the source as "DSC Sample Code"
-       after having made changes. If you're going to re-distribute the source,
-       we require that you make it clear in the source that the code was
-       descended from Apple Sample Code, but that you've made changes.
-
-       File Ownership:
-
-               DRI:                            Apple Macintosh Developer Technical Support
-
-               Other Contact:          Apple Macintosh Developer Technical Support
-                                                       <http://developer.apple.com/bugreporter/>
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-
-       Change History (most recent first):
-
-                <1>      2/7/01        JL              first checked in
-*/
-
-/*
-       The Optimization changes to MoreFiles source and header files, along with
-       this file and Optimization.h, let you optimize the code produced by MoreFiles
-       in several ways.
-       
-       Original changes supplied by Fabrizio Oddone
-*/
-
-
-#if    __USEPRAGMAINTERNAL
-       #if defined(__MWERKS__)
-               #pragma internal reset
-       #endif
-#endif
-
-
-#if    __WANTPASCALELIMINATION
-       #ifndef __COMPILINGMOREFILES
-               #undef pascal
-       #endif
-#endif
diff --git a/src/mac/morefile/Search.c b/src/mac/morefile/Search.c
deleted file mode 100644 (file)
index d03154a..0000000
+++ /dev/null
@@ -1,1300 +0,0 @@
-/*
-       File:           Search.c
-
-       Contains:       IndexedSearch and the PBCatSearch compatibility function.
-
-       Version:        MoreFiles
-
-       Copyright:      © 1992-2001 by Apple Computer, Inc., all rights reserved.
-
-       You may incorporate this sample code into your applications without
-       restriction, though the sample code has been provided "AS IS" and the
-       responsibility for its operation is 100% yours.  However, what you are
-       not permitted to do is to redistribute the source as "DSC Sample Code"
-       after having made changes. If you're going to re-distribute the source,
-       we require that you make it clear in the source that the code was
-       descended from Apple Sample Code, but that you've made changes.
-
-       File Ownership:
-
-               DRI:                            Jim Luther
-
-               Other Contact:          Apple Macintosh Developer Technical Support
-                                                       <http://developer.apple.com/bugreporter/>
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-
-       Change History (most recent first):
-
-                <2>      2/7/01        JL              Added standard header. Updated names of includes. Updated
-                                                                       various routines to use new calling convention of the
-                                                                       MoreFilesExtras accessor functions. Added TARGET_API_MAC_CARBON
-                                                                       conditional checks around TimeOutTask.
-               <1>             12/06/99        JL              MoreFiles 1.5.
-*/
-
-#include <MacTypes.h>
-#include <Gestalt.h>
-#include <Timer.h>
-#include <MacErrors.h>
-#include <MacMemory.h>
-#include <Files.h>
-#include <TextUtils.h>
-
-#define        __COMPILINGMOREFILES
-
-#include "MoreFiles.h"
-#include "MoreFilesExtras.h"
-
-#include "Search.h"
-
-/*****************************************************************************/
-
-enum
-{
-       /* Number of LevelRecs to add each time the searchStack is grown */
-       /* 20 levels is probably more than reasonable for most volumes. */
-       /* If more are needed, they are allocated 20 levels at a time. */
-       kAdditionalLevelRecs = 20
-};
-
-/*****************************************************************************/
-
-/*
-**     LevelRecs are used to store the directory ID and index whenever
-**     IndexedSearch needs to either scan a sub-directory, or return control
-**     to the caller because the call has timed out or the number of
-**     matches requested has been found. LevelRecs are stored in an array
-**     used as a stack.
-*/
-struct LevelRec
-{
-       long    dirModDate;     /* for detecting most (but not all) catalog changes */
-       long    dirID;
-       short   index;
-};
-typedef struct LevelRec LevelRec;
-typedef LevelRec *LevelRecPtr, **LevelRecHandle;
-
-
-/*
-**     SearchPositionRec is my version of a CatPositionRec. It holds the
-**     information I need to resuming searching.
-*/
-#if PRAGMA_STRUCT_ALIGN
-#pragma options align=mac68k
-#endif
-struct SearchPositionRec
-{
-       long                    initialize;             /* Goofy checksum of volume information used to make */
-                                                                       /* sure we're resuming a search on the same volume. */
-       unsigned short  stackDepth;             /* Current depth on searchStack. */
-       short                   priv[11];               /* For future use... */
-};
-#if PRAGMA_STRUCT_ALIGN
-#pragma options align=reset
-#endif
-typedef struct SearchPositionRec SearchPositionRec;
-typedef SearchPositionRec *SearchPositionRecPtr;
-
-
-/*
-**     ExtendedTMTask is a TMTask record extended to hold the timer flag.
-*/
-#if PRAGMA_STRUCT_ALIGN
-#pragma options align=mac68k
-#endif
-struct ExtendedTMTask
-{
-       TMTask                  theTask;
-       Boolean                 stopSearch;             /* the Time Mgr task will set stopSearch to */
-                                                                       /* true when the timer expires */
-};
-#if PRAGMA_STRUCT_ALIGN
-#pragma options align=reset
-#endif
-typedef struct ExtendedTMTask ExtendedTMTask;
-typedef ExtendedTMTask *ExtendedTMTaskPtr;
-
-/*****************************************************************************/
-
-static OSErr   CheckVol(ConstStr255Param pathname,
-                                                short vRefNum,
-                                                short *realVRefNum,
-                                                long *volID);
-
-static OSErr   CheckStack(unsigned short stackDepth,
-                                                  LevelRecHandle searchStack,
-                                                  Size *searchStackSize);
-
-static OSErr   VerifyUserPB(CSParamPtr userPB,
-                                                        Boolean *includeFiles,
-                                                        Boolean *includeDirs,
-                                                        Boolean *includeNames);
-
-static Boolean IsSubString(ConstStr255Param aStringPtr,
-                                                       ConstStr255Param subStringPtr);
-
-static Boolean CompareMasked(const long *data1,
-                                                         const long *data2,
-                                                         const long *mask,
-                                                         short longsToCompare);
-
-static void    CheckForMatches(CInfoPBPtr cPB,
-                                                               CSParamPtr userPB,
-                                                               const Str63 matchName,
-                                                               Boolean includeFiles,
-                                                               Boolean includeDirs);
-
-#if    __WANTPASCALELIMINATION
-#undef pascal
-#endif
-
-#if TARGET_RT_MAC_CFM || TARGET_API_MAC_CARBON
-
-static pascal  void    TimeOutTask(TMTaskPtr tmTaskPtr);
-
-#else
-
-static pascal  TMTaskPtr       GetTMTaskPtr(void);
-
-static void    TimeOutTask(void);
-
-#endif
-
-#if    __WANTPASCALELIMINATION
-#define        pascal  
-#endif
-
-static long    GetDirModDate(short vRefNum,
-                                                         long dirID);
-
-/*****************************************************************************/
-
-/*
-**     CheckVol gets the volume's real vRefNum and builds a volID. The volID
-**     is used to help insure that calls to resume searching with IndexedSearch
-**     are to the same volume as the last call to IndexedSearch.
-*/
-static OSErr   CheckVol(ConstStr255Param pathname,
-                                                short vRefNum,
-                                                short *realVRefNum,
-                                                long *volID)
-{
-       HParamBlockRec pb;
-       OSErr error;
-
-       error = GetVolumeInfoNoName(pathname, vRefNum, &pb);
-       if ( error == noErr )
-       {
-               /* Return the real vRefNum */
-               *realVRefNum = pb.volumeParam.ioVRefNum;
-
-               /* Add together a bunch of things that aren't supposed to change on */
-               /* a mounted volume that's being searched and that should come up with */
-               /* a fairly unique number */
-               *volID = pb.volumeParam.ioVCrDate +
-                                pb.volumeParam.ioVRefNum +
-                                pb.volumeParam.ioVNmAlBlks +
-                                pb.volumeParam.ioVAlBlkSiz +
-                                pb.volumeParam.ioVFSID;
-       }
-       return ( error );
-}
-
-/*****************************************************************************/
-
-/*
-**     CheckStack checks the size of the search stack (array) to see if there's
-**     room to push another LevelRec. If not, CheckStack grows the stack by
-**     another kAdditionalLevelRecs elements.
-*/
-static OSErr   CheckStack(unsigned short stackDepth,
-                                                  LevelRecHandle searchStack,
-                                                  Size *searchStackSize)
-{
-       OSErr   result;
-       
-       if ( (*searchStackSize / sizeof(LevelRec)) == (stackDepth + 1) )
-       {
-               /* Time to grow stack */
-               SetHandleSize((Handle)searchStack, *searchStackSize + (kAdditionalLevelRecs * sizeof(LevelRec)));
-               result = MemError();    /* should be noErr */
-               *searchStackSize = GetHandleSize((Handle)searchStack);
-       }
-       else
-       {
-               result = noErr;
-       }
-       
-       return ( result );
-}
-
-/*****************************************************************************/
-
-/*
-**     VerifyUserPB makes sure the parameter block passed to IndexedSearch has
-**     valid parameters. By making this check once, we don't have to worry about
-**     things like NULL pointers, strings being too long, etc.
-**     VerifyUserPB also determines if the search includes files and/or
-**     directories, and determines if a full or partial name search was requested.
-*/
-static OSErr   VerifyUserPB(CSParamPtr userPB,
-                                                        Boolean *includeFiles,
-                                                        Boolean *includeDirs,
-                                                        Boolean *includeNames)
-{
-       CInfoPBPtr      searchInfo1;
-       CInfoPBPtr      searchInfo2;
-       
-       searchInfo1 = userPB->ioSearchInfo1;
-       searchInfo2 = userPB->ioSearchInfo2;
-       
-       /* ioMatchPtr cannot be NULL */
-       if ( userPB->ioMatchPtr == NULL )
-       {
-               goto ParamErrExit;
-       }
-       
-       /* ioSearchInfo1 cannot be NULL */
-       if ( searchInfo1 == NULL )
-       {
-               goto ParamErrExit;
-       }
-       
-       /* If any bits except partialName, fullName, or negate are set, then */
-       /* ioSearchInfo2 cannot be NULL because information in ioSearchInfo2 is required  */
-       if ( ((userPB->ioSearchBits & ~(fsSBPartialName | fsSBFullName | fsSBNegate)) != 0) &&
-                ( searchInfo2 == NULL ))
-       {
-               goto ParamErrExit;
-       }
-       
-       *includeFiles = false;
-       *includeDirs = false;
-       *includeNames = false;
-       
-       if ( (userPB->ioSearchBits & (fsSBPartialName | fsSBFullName)) != 0 )
-       {
-               /* If any kind of name matching is requested, then ioNamePtr in */
-               /* ioSearchInfo1 cannot be NULL or a zero-length string */
-               if ( (searchInfo1->hFileInfo.ioNamePtr == NULL) ||
-                        (searchInfo1->hFileInfo.ioNamePtr[0] == 0) ||
-                        (searchInfo1->hFileInfo.ioNamePtr[0] > (sizeof(Str63) - 1)) )
-               {
-                       goto ParamErrExit;
-               }
-               
-               *includeNames = true;
-       }
-       
-       if ( (userPB->ioSearchBits & fsSBFlAttrib) != 0 )
-       {
-               /* The only attributes you can search on are the directory flag */
-               /* and the locked flag. */
-               if ( (searchInfo2->hFileInfo.ioFlAttrib & ~(kioFlAttribDirMask | kioFlAttribLockedMask)) != 0 )
-               {
-                       goto ParamErrExit;
-               }
-               
-               /* interested in the directory bit? */
-               if ( (searchInfo2->hFileInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-               {
-                       /* yes, so do they want just directories or just files? */
-                       if ( (searchInfo1->hFileInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-                       {
-                               *includeDirs = true;
-                       }
-                       else
-                       {
-                               *includeFiles = true;
-                       }
-               }
-               else
-               {
-                       /* no interest in directory bit - get both files and directories */
-                       *includeDirs = true;
-                       *includeFiles = true;
-               }
-       }
-       else
-       {
-               /* no attribute checking - get both files and directories */
-               *includeDirs = true;
-               *includeFiles = true;
-       }
-       
-       /* If directories are included in the search, */
-       /* then the locked attribute cannot be requested. */
-       if ( *includeDirs &&
-                ((userPB->ioSearchBits & fsSBFlAttrib) != 0) &&
-                ((searchInfo2->hFileInfo.ioFlAttrib & kioFlAttribLockedMask) != 0) )
-       {
-               goto ParamErrExit;
-       }
-       
-       /* If files are included in the search, then there cannot be */
-       /* a search on the number of files. */
-       if ( *includeFiles &&
-                ((userPB->ioSearchBits & fsSBDrNmFls) != 0) )
-       {
-               goto ParamErrExit;
-       }
-       
-       /* If directories are included in the search, then there cannot */
-       /* be a search on file lengths. */
-       if ( *includeDirs &&
-                ((userPB->ioSearchBits & (fsSBFlLgLen | fsSBFlPyLen | fsSBFlRLgLen | fsSBFlRPyLen)) != 0) )
-       {
-               goto ParamErrExit;
-       }
-       
-       return ( noErr );
-                
-ParamErrExit:
-       return ( paramErr );
-}
-
-/*****************************************************************************/
-
-/*
-**     IsSubString checks to see if a string is a substring of another string.
-**     Both input strings have already been converted to all uppercase using
-**     UprString (the same non-international call the File Manager uses).
-*/
-static Boolean IsSubString(ConstStr255Param aStringPtr,
-                                                       ConstStr255Param subStringPtr)
-{
-       short   strLength;              /* length of string */
-       short   subStrLength;   /* length of subString */
-       Boolean found;                  /* result of test */
-       short   index;                  /* current index into string */
-       
-       found = false;
-       strLength = aStringPtr[0];
-       subStrLength = subStringPtr[0];
-               
-       if ( subStrLength <= strLength)
-       {
-               register short  count;                  /* search counter */
-               register short  strIndex;               /* running index into string */
-               register short  subStrIndex;    /* running index into subString */
-               
-               /* start looking at first character */
-               index = 1;
-               
-               /* continue looking until remaining string is shorter than substring */
-               count = strLength - subStrLength + 1;
-               
-               do
-               {
-                       strIndex = index;       /* start string index at index */
-                       subStrIndex = 1;        /* start subString index at 1 */
-                       
-                       while ( !found && (aStringPtr[strIndex] == subStringPtr[subStrIndex]) )
-                       {
-                               if ( subStrIndex == subStrLength )
-                               {
-                                       /* all characters in subString were found */
-                                       found = true;
-                               }
-                               else
-                               {
-                                       /* check next character of substring against next character of string */
-                                       ++subStrIndex;
-                                       ++strIndex;
-                               }
-                       }
-                       
-                       if ( !found )
-                       {
-                               /* start substring search again at next string character */
-                               ++index;
-                               --count;
-                       }
-               } while ( count != 0 && (!found) );
-       }
-       
-       return ( found );
-}
-
-/*****************************************************************************/
-
-/*
-**     CompareMasked does a bitwise comparison with mask on 1 or more longs.
-**     data1 and data2 are first exclusive-ORed together resulting with bits set
-**     where they are different. That value is then ANDed with the mask resulting
-**     with bits set if the test fails. true is returned if the tests pass.
-*/
-static Boolean CompareMasked(const long *data1,
-                                                         const long *data2,
-                                                         const long *mask,
-                                                         short longsToCompare)
-{
-       Boolean result = true;
-       
-       while ( (longsToCompare != 0) && (result == true) )
-       {
-               /* (*data1 ^ *data2) = bits that are different, so... */
-               /* ((*data1 ^ *data2) & *mask) = bits that are different that we're interested in */
-               
-               if ( ((*data1 ^ *data2) & *mask) != 0 )
-                       result = false;
-               
-               ++data1;
-               ++data2;
-               ++mask;
-               --longsToCompare;
-       }
-       
-       return ( result );
-}
-
-/*****************************************************************************/
-
-/*
-**     Check for matches compares the search criteria in userPB to the file
-**     system object in cPB. If there's a match, then the information in cPB is
-**     is added to the match array and the actual match count is incremented.
-*/
-static void    CheckForMatches(CInfoPBPtr cPB,
-                                                               CSParamPtr userPB,
-                                                               const Str63 matchName,
-                                                               Boolean includeFiles,
-                                                               Boolean includeDirs)
-{
-       long            searchBits;
-       CInfoPBPtr      searchInfo1;
-       CInfoPBPtr      searchInfo2;
-       Str63           itemName;               /* copy of object's name for partial name matching */
-       Boolean         foundMatch;
-       
-       foundMatch = false;                     /* default to no match */
-       
-       searchBits = userPB->ioSearchBits;
-       searchInfo1 = userPB->ioSearchInfo1;
-       searchInfo2 = userPB->ioSearchInfo2;
-       
-       /* Into the if statements that go on forever... */
-       
-       if ( (cPB->hFileInfo.ioFlAttrib & kioFlAttribDirMask) == 0 )
-       {
-               if (!includeFiles)
-               {
-                       goto Failed;
-               }
-       }
-       else
-       {
-               if (!includeDirs)
-               {
-                       goto Failed;
-               }
-       }
-       
-       if ( (searchBits & fsSBPartialName) != 0 )
-       {
-               if ( (cPB->hFileInfo.ioNamePtr[0] > 0) &&
-                        (cPB->hFileInfo.ioNamePtr[0] <= (sizeof(Str63) - 1)) )
-               {
-                       /* Make uppercase copy of object name */
-                       BlockMoveData(cPB->hFileInfo.ioNamePtr,
-                                                       itemName,
-                                                       cPB->hFileInfo.ioNamePtr[0] + 1);
-                       /* Use the same non-international call the File Manager uses */
-                       UpperString(itemName, true);
-               }
-               else
-               {
-                       goto Failed;
-               }
-               
-               {
-                       if ( !IsSubString(itemName, matchName) )
-                       {
-                               goto Failed;
-                       }
-                       else if ( searchBits == fsSBPartialName )
-                       {
-                               /* optimize for name matching only since it is most common way to search */
-                               goto Hit;
-                       }
-               }
-       }
-       
-       if ( (searchBits & fsSBFullName) != 0 )
-       {
-               /* Use the same non-international call the File Manager uses */
-               if ( !EqualString(cPB->hFileInfo.ioNamePtr, matchName, false, true) )
-               {
-                       goto Failed;
-               }
-               else if ( searchBits == fsSBFullName )
-               {
-                       /* optimize for name matching only since it is most common way to search */
-                       goto Hit;
-               }
-       }
-       
-       if ( (searchBits & fsSBFlParID) != 0 )
-       {
-               if ( ((unsigned long)(cPB->hFileInfo.ioFlParID) < (unsigned long)(searchInfo1->hFileInfo.ioFlParID)) ||
-                        ((unsigned long)(cPB->hFileInfo.ioFlParID) > (unsigned long)(searchInfo2->hFileInfo.ioFlParID)) )
-               {
-                       goto Failed;
-               }
-       }
-       
-       if ( (searchBits & fsSBFlAttrib) != 0 )
-       {
-               if ( ((cPB->hFileInfo.ioFlAttrib ^ searchInfo1->hFileInfo.ioFlAttrib) &
-                         searchInfo2->hFileInfo.ioFlAttrib) != 0 )
-               {
-                       goto Failed;
-               }
-       }
-       
-       if ( (searchBits & fsSBDrNmFls) != 0 )
-       {
-               if ( ((unsigned long)(cPB->dirInfo.ioDrNmFls) < (unsigned long)(searchInfo1->dirInfo.ioDrNmFls)) ||
-                        ((unsigned long)(cPB->dirInfo.ioDrNmFls) > (unsigned long)(searchInfo2->dirInfo.ioDrNmFls)) )
-               {
-                       goto Failed;
-               }
-       }
-
-       if ( (searchBits & fsSBFlFndrInfo) != 0 )       /* fsSBFlFndrInfo is same as fsSBDrUsrWds */
-       {
-               if ( !CompareMasked((long *)&(cPB->hFileInfo.ioFlFndrInfo),
-                                                       (long *)&(searchInfo1->hFileInfo.ioFlFndrInfo),
-                                                       (long *)&(searchInfo2->hFileInfo.ioFlFndrInfo),
-                                                       sizeof(FInfo) / sizeof(long)) )
-               {
-                       goto Failed;
-               }
-       }
-       
-       if ( (searchBits & fsSBFlXFndrInfo) != 0 )      /* fsSBFlXFndrInfo is same as fsSBDrFndrInfo */
-       {
-               if ( !CompareMasked((long *)&(cPB->hFileInfo.ioFlXFndrInfo),
-                                                       (long *)&(searchInfo1->hFileInfo.ioFlXFndrInfo),
-                                                       (long *)&(searchInfo2->hFileInfo.ioFlXFndrInfo),
-                                                       sizeof(FXInfo) / sizeof(long)) )
-               {
-                       goto Failed;
-               }
-       }
-       
-       if ( (searchBits & fsSBFlLgLen) != 0 )
-       {
-               if ( ((unsigned long)(cPB->hFileInfo.ioFlLgLen) < (unsigned long)(searchInfo1->hFileInfo.ioFlLgLen)) ||
-                        ((unsigned long)(cPB->hFileInfo.ioFlLgLen) > (unsigned long)(searchInfo2->hFileInfo.ioFlLgLen)) )
-               {
-                       goto Failed;
-               }
-       }
-
-       if ( (searchBits & fsSBFlPyLen) != 0 )
-       {
-               if ( ((unsigned long)(cPB->hFileInfo.ioFlPyLen) < (unsigned long)(searchInfo1->hFileInfo.ioFlPyLen)) ||
-                        ((unsigned long)(cPB->hFileInfo.ioFlPyLen) > (unsigned long)(searchInfo2->hFileInfo.ioFlPyLen)) )
-               {
-                       goto Failed;
-               }
-       }
-
-       if ( (searchBits & fsSBFlRLgLen) != 0 )
-       {
-               if ( ((unsigned long)(cPB->hFileInfo.ioFlRLgLen) < (unsigned long)(searchInfo1->hFileInfo.ioFlRLgLen)) ||
-                        ((unsigned long)(cPB->hFileInfo.ioFlRLgLen) > (unsigned long)(searchInfo2->hFileInfo.ioFlRLgLen)) )
-               {
-                       goto Failed;
-               }
-       }
-
-       if ( (searchBits & fsSBFlRPyLen) != 0 )
-       {
-               if ( ((unsigned long)(cPB->hFileInfo.ioFlRPyLen) < (unsigned long)(searchInfo1->hFileInfo.ioFlRPyLen)) ||
-                        ((unsigned long)(cPB->hFileInfo.ioFlRPyLen) > (unsigned long)(searchInfo2->hFileInfo.ioFlRPyLen)) )
-               {
-                       goto Failed;
-               }
-       }
-
-       if ( (searchBits & fsSBFlCrDat) != 0 )  /* fsSBFlCrDat is same as fsSBDrCrDat */
-       {
-               if ( ((unsigned long)(cPB->hFileInfo.ioFlCrDat) < (unsigned long)(searchInfo1->hFileInfo.ioFlCrDat)) ||
-                        ((unsigned long)(cPB->hFileInfo.ioFlCrDat) > (unsigned long)(searchInfo2->hFileInfo.ioFlCrDat)) )
-               {
-                       goto Failed;
-               }
-       }
-
-       if ( (searchBits & fsSBFlMdDat) != 0 )  /* fsSBFlMdDat is same as fsSBDrMdDat */
-       {
-               if ( ((unsigned long)(cPB->hFileInfo.ioFlMdDat) < (unsigned long)(searchInfo1->hFileInfo.ioFlMdDat)) ||
-                        ((unsigned long)(cPB->hFileInfo.ioFlMdDat) > (unsigned long)(searchInfo2->hFileInfo.ioFlMdDat)) )
-               {
-                       goto Failed;
-               }
-       }
-
-       if ( (searchBits & fsSBFlBkDat) != 0 )  /* fsSBFlBkDat is same as fsSBDrBkDat */
-       {
-               if ( ((unsigned long)(cPB->hFileInfo.ioFlBkDat) < (unsigned long)(searchInfo1->hFileInfo.ioFlBkDat)) ||
-                        ((unsigned long)(cPB->hFileInfo.ioFlBkDat) > (unsigned long)(searchInfo2->hFileInfo.ioFlBkDat)) )
-               {
-                       goto Failed;
-               }
-       }
-
-       /* Hey, we passed all of the tests! */
-       
-Hit:
-       foundMatch = true;
-
-/* foundMatch is false if code jumps to Failed */
-Failed:
-       /* Do we reverse our findings? */
-       if ( (searchBits & fsSBNegate) != 0 )
-       {
-               foundMatch = !foundMatch;       /* matches are not, not matches are */
-       }
-       
-       if ( foundMatch )
-       {
-
-               /* Move the match into the match buffer */
-               userPB->ioMatchPtr[userPB->ioActMatchCount].vRefNum = cPB->hFileInfo.ioVRefNum;
-               userPB->ioMatchPtr[userPB->ioActMatchCount].parID = cPB->hFileInfo.ioFlParID;
-               if ( cPB->hFileInfo.ioNamePtr[0] > 63 )
-               {
-                       cPB->hFileInfo.ioNamePtr[0] = 63;
-               }
-               BlockMoveData(cPB->hFileInfo.ioNamePtr,
-                                         userPB->ioMatchPtr[userPB->ioActMatchCount].name,
-                                         cPB->hFileInfo.ioNamePtr[0] + 1);
-               
-               /* increment the actual count */
-               ++(userPB->ioActMatchCount);
-       }
-}
-
-/*****************************************************************************/
-
-/*
-**     TimeOutTask is executed when the timer goes off. It simply sets the
-**     stopSearch field to true. After each object is found and possibly added
-**     to the matches buffer, stopSearch is checked to see if the search should
-**     continue.
-*/
-
-#if    __WANTPASCALELIMINATION
-#undef pascal
-#endif
-
-#if TARGET_RT_MAC_CFM || TARGET_API_MAC_CARBON
-
-static pascal  void    TimeOutTask(TMTaskPtr tmTaskPtr)
-{
-       ((ExtendedTMTaskPtr)tmTaskPtr)->stopSearch = true;
-}
-
-#else
-
-static pascal  TMTaskPtr       GetTMTaskPtr(void)
-       ONEWORDINLINE(0x2e89);  /* MOVE.L A1,(SP) */
-       
-static void    TimeOutTask(void)
-{
-       ((ExtendedTMTaskPtr)GetTMTaskPtr())->stopSearch = true;
-}
-
-#endif
-
-#if    __WANTPASCALELIMINATION
-#define        pascal  
-#endif
-
-/*****************************************************************************/
-
-/*
-**     GetDirModDate returns the modification date of a directory. If there is
-**     an error getting the modification date, -1 is returned to indicate
-**     something went wrong.
-*/
-static long    GetDirModDate(short vRefNum,
-                                                         long dirID)
-{
-       CInfoPBRec pb;
-       Str31 tempName;
-       long modDate;
-
-       /* Protection against File Sharing problem */
-       tempName[0] = 0;
-       pb.dirInfo.ioNamePtr = tempName;
-       pb.dirInfo.ioVRefNum = vRefNum;
-       pb.dirInfo.ioDrDirID = dirID;
-       pb.dirInfo.ioFDirIndex = -1;    /* use ioDrDirID */
-       
-       if ( PBGetCatInfoSync(&pb) == noErr )
-       {
-               modDate = pb.dirInfo.ioDrMdDat;
-       }
-       else
-       {
-               modDate = -1;
-       }
-       
-       return ( modDate );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   IndexedSearch(CSParamPtr pb,
-                                                         long dirID)
-{
-       static LevelRecHandle   searchStack = NULL;             /* static handle to LevelRec stack */
-       static Size                             searchStackSize = 0;    /* size of static handle */
-       SearchPositionRecPtr    catPosition;
-       long                                    modDate;
-       short                                   index = -1 ;
-       ExtendedTMTask                  timerTask;
-       OSErr                                   result;
-       short                                   realVRefNum;
-       Str63                                   itemName;
-       CInfoPBRec                              cPB;
-       long                                    tempLong;
-       Boolean                                 includeFiles;
-       Boolean                                 includeDirs;
-       Boolean                                 includeNames;
-       Str63                                   upperName;
-       
-       timerTask.stopSearch = false;   /* don't stop yet! */
-       
-       /* If request has a timeout, install a Time Manager task. */
-       if ( pb->ioSearchTime != 0 )
-       {
-               /* Start timer */
-               timerTask.theTask.tmAddr = NewTimerUPP(TimeOutTask);
-               InsTime((QElemPtr)&(timerTask.theTask));
-               PrimeTime((QElemPtr)&(timerTask.theTask), pb->ioSearchTime);
-       }
-       
-       /* Check the parameter block passed for things that we don't want to assume */
-       /* are OK later in the code. For example, make sure pointers to data structures */
-       /* and buffers are not NULL.  And while we're in there, see if the request */
-       /* specified searching for files, directories, or both, and see if the search */
-       /* was by full or partial name. */
-       result = VerifyUserPB(pb, &includeFiles, &includeDirs, &includeNames);
-       if ( result == noErr )
-       {
-               pb->ioActMatchCount = 0;        /* no matches yet */
-       
-               if ( includeNames )
-               {
-                       /* The search includes seach by full or partial name. */
-                       /* Make an upper case copy of the match string to pass to */
-                       /* CheckForMatches. */
-                       BlockMoveData(pb->ioSearchInfo1->hFileInfo.ioNamePtr,
-                                                       upperName,
-                                                       pb->ioSearchInfo1->hFileInfo.ioNamePtr[0] + 1);
-                       /* Use the same non-international call the File Manager uses */
-                       UpperString(upperName, true);
-               }
-               
-               /* Prevent casting to my type throughout code */
-               catPosition = (SearchPositionRecPtr)&pb->ioCatPosition;
-               
-               /* Create searchStack first time called */
-               if ( searchStack == NULL )
-               {
-                       searchStack = (LevelRecHandle)NewHandle(kAdditionalLevelRecs * sizeof(LevelRec));
-               }
-               
-               /* Make sure searchStack really exists */
-               if ( searchStack != NULL )
-               {
-                       searchStackSize = GetHandleSize((Handle)searchStack);
-                       
-                       /* See if the search is a new search or a resumed search. */
-                       if ( catPosition->initialize == 0 )
-                       {
-                               /* New search. */
-                               
-                               /* Get the real vRefNum and fill in catPosition->initialize. */ 
-                               result = CheckVol(pb->ioNamePtr, pb->ioVRefNum, &realVRefNum, &catPosition->initialize);
-                               if ( result == noErr )
-                               {
-                                       /* clear searchStack */
-                                       catPosition->stackDepth = 0;
-                                       
-                                       /* use dirID parameter passed and... */
-                                       index = -1;     /* start with the passed directory itself! */
-                               }
-                       }
-                       else
-                       {
-                               /* We're resuming a search. */
-       
-                               /* Get the real vRefNum and make sure catPosition->initialize is valid. */ 
-                               result = CheckVol(pb->ioNamePtr, pb->ioVRefNum, &realVRefNum, &tempLong);
-                               if ( result == noErr )
-                               {
-                                       /* Make sure the resumed search is to the same volume! */
-                                       if ( catPosition->initialize == tempLong )
-                                       {
-                                               /* For resume, catPosition->stackDepth > 0 */
-                                               if ( catPosition->stackDepth > 0 )
-                                               {
-                                                       /* Position catPosition->stackDepth to access last saved level */
-                                                       --(catPosition->stackDepth);
-                       
-                                                       /* Get the dirID and index for the next item */
-                                                       dirID = (*searchStack)[catPosition->stackDepth].dirID;
-                                                       index = (*searchStack)[catPosition->stackDepth].index;
-                                                       
-                                                       /* Check the dir's mod date against the saved mode date on our "stack" */
-                                                       modDate = GetDirModDate(realVRefNum, dirID);
-                                                       if ( modDate != (*searchStack)[catPosition->stackDepth].dirModDate )
-                                                       {
-                                                               result = catChangedErr;
-                                                       }
-                                               }
-                                               else
-                                               {
-                                                       /* Invalid catPosition record was passed */
-                                                       result = paramErr;
-                                               }
-                                       }
-                                       else
-                                       {
-                                               /* The volume is not the same */
-                                               result = catChangedErr;
-                                       }
-                               }
-                       }
-                       
-                       if ( result == noErr )
-                       {
-                               /* ioNamePtr and ioVRefNum only need to be set up once. */
-                               cPB.hFileInfo.ioNamePtr = itemName;
-                               cPB.hFileInfo.ioVRefNum = realVRefNum;
-                               
-                               /*
-                               **      Here's the loop that:
-                               **              Finds the next item on the volume.
-                               **              If noErr, calls the code to check for matches and add matches
-                               **                      to the match buffer.
-                               **              Sets up dirID and index for to find the next item on the volume.
-                               **
-                               **      The looping ends when:
-                               **              (a) an unexpected error is returned by PBGetCatInfo. All that
-                               **                      is expected is noErr and fnfErr (after the last item in a
-                               **                      directory is found).
-                               **              (b) the caller specified a timeout and our Time Manager task
-                               **                      has fired.
-                               **              (c) the number of matches requested by the caller has been found.
-                               **              (d) the last item on the volume was found.
-                               */
-                               do
-                               {
-                                       /* get the next item */
-                                       cPB.hFileInfo.ioFDirIndex = index;
-                                       cPB.hFileInfo.ioDirID = dirID;
-                                       result = PBGetCatInfoSync(&cPB);
-                                       if ( index != -1 )
-                                       {
-                                               if ( result == noErr )
-                                               {
-                                                       /* We found something */
-               
-                                                       CheckForMatches(&cPB, pb, upperName, includeFiles, includeDirs);
-                                                       
-                                                       ++index;
-                                                       if ( (cPB.dirInfo.ioFlAttrib & kioFlAttribDirMask) != 0 )
-                                                       {
-                                                               /* It's a directory */
-                                                               
-                                                               result = CheckStack(catPosition->stackDepth, searchStack, &searchStackSize);
-                                                               if ( result == noErr )
-                                                               {
-                                                                       /* Save the current state on the searchStack */
-                                                                       /* when we come back, this is where we'll start */
-                                                                       (*searchStack)[catPosition->stackDepth].dirID = dirID;
-                                                                       (*searchStack)[catPosition->stackDepth].index = index;
-                                                                       (*searchStack)[catPosition->stackDepth].dirModDate = GetDirModDate(realVRefNum, dirID);
-                                                                       
-                                                                       /* position catPosition->stackDepth for next saved level */
-                                                                       ++(catPosition->stackDepth);
-                                                                       
-                                                                       /* The next item to get is the 1st item in the child directory */
-                                                                       dirID = cPB.dirInfo.ioDrDirID;
-                                                                       index = 1;
-                                                               }
-                                                       }
-                                                       /* else do nothing for files */
-                                               }
-                                               else
-                                               {
-                                                       /* End of directory found (or we had some error and that */
-                                                       /* means we have to drop out of this directory). */
-                                                       /* Restore last thing put on stack and */
-                                                       /* see if we need to continue or quit. */
-                                                       if ( catPosition->stackDepth > 0 )
-                                                       {
-                                                               /* position catPosition->stackDepth to access last saved level */
-                                                               --(catPosition->stackDepth);
-                                                               
-                                                               dirID = (*searchStack)[catPosition->stackDepth].dirID;
-                                                               index = (*searchStack)[catPosition->stackDepth].index;
-                                                               
-                                                               /* Check the dir's mod date against the saved mode date on our "stack" */
-                                                               modDate = GetDirModDate(realVRefNum, dirID);
-                                                               if ( modDate != (*searchStack)[catPosition->stackDepth].dirModDate )
-                                                               {
-                                                                       result = catChangedErr;
-                                                               }
-                                                               else
-                                                               {
-                                                                       /* Going back to ancestor directory. */
-                                                                       /* Clear error so we can continue. */
-                                                                       result = noErr;
-                                                               }
-                                                       }
-                                                       else
-                                                       {
-                                                               /* We hit the bottom of the stack, so we'll let the */
-                                                               /* the eofErr drop us out of the loop. */
-                                                               result = eofErr;
-                                                       }
-                                               }
-                                       }
-                                       else
-                                       {
-                                               /* Special case for index == -1; that means that we're starting */
-                                               /* a new search and so the first item to check is the directory */
-                                               /* passed to us. */
-                                               if ( result == noErr )
-                                               {
-                                                       /* We found something */
-               
-                                                       CheckForMatches(&cPB, pb, upperName, includeFiles, includeDirs);
-                                                       
-                                                       /* Now, set the index to 1 and then we're ready to look inside */
-                                                       /* the passed directory. */
-                                                       index = 1;
-                                               }
-                                       }
-                               } while ( (!timerTask.stopSearch) &&    /* timer hasn't fired */
-                                                 (result == noErr) &&                  /* no unexpected errors */
-                                                 (pb->ioReqMatchCount > pb->ioActMatchCount) ); /* we haven't found our limit */
-                               
-                               /* Did we drop out of the loop because of timeout or */
-                               /* ioReqMatchCount was found? */
-                               if ( result == noErr )
-                               {
-                                       result = CheckStack(catPosition->stackDepth, searchStack, &searchStackSize);
-                                       if ( result == noErr )
-                                       {
-                                               /* Either there was a timeout or ioReqMatchCount was reached. */
-                                               /* Save the dirID and index for the next time we're called. */
-                                               
-                                               (*searchStack)[catPosition->stackDepth].dirID = dirID;
-                                               (*searchStack)[catPosition->stackDepth].index = index;
-                                               (*searchStack)[catPosition->stackDepth].dirModDate = GetDirModDate(realVRefNum, dirID);
-                                               
-                                               /* position catPosition->stackDepth for next saved level */
-                                               
-                                               ++(catPosition->stackDepth);
-                                       }
-                               }
-                       }
-               }
-               else
-               {
-                       /* searchStack Handle could not be allocated */
-                       result = memFullErr;
-               }
-       }
-       
-       if ( pb->ioSearchTime != 0 )
-       {
-               /* Stop Time Manager task here if it was installed */
-               RmvTime((QElemPtr)&(timerTask.theTask));
-               DisposeTimerUPP(timerTask.theTask.tmAddr);
-       }
-       
-       return ( result );
-}
-
-/*****************************************************************************/
-
-pascal OSErr PBCatSearchSyncCompat(CSParamPtr paramBlock)
-{
-       OSErr                                   result;
-       Boolean                                 supportsCatSearch;
-       GetVolParmsInfoBuffer   volParmsInfo;
-       long                                    infoSize;
-#if !__MACOSSEVENORLATER
-       static Boolean                  fullExtFSDispatchingtested = false;
-       static Boolean                  hasFullExtFSDispatching = false;
-       long                                    response;
-#endif
-       
-       result = noErr;
-
-#if !__MACOSSEVENORLATER
-       /* See if File Manager will pass CatSearch requests to external file systems */
-       /* we'll store the results in a static variable so we don't have to call Gestalt */
-       /* everytime we're called. (System 7.0 and later always do this) */
-       if ( !fullExtFSDispatchingtested )
-       {
-               fullExtFSDispatchingtested = true;
-               if ( Gestalt(gestaltFSAttr, &response) == noErr )
-               {
-                       hasFullExtFSDispatching = ((response & (1L << gestaltFullExtFSDispatching)) != 0);
-               }
-       }
-#endif
-       
-       /* CatSearch is a per volume attribute, so we have to check each time we're */
-       /* called to see if it is available on the volume specified. */
-       supportsCatSearch = false;
-#if !__MACOSSEVENORLATER
-       if ( hasFullExtFSDispatching )
-#endif
-       {
-               infoSize = sizeof(GetVolParmsInfoBuffer);
-               result = HGetVolParms(paramBlock->ioNamePtr, paramBlock->ioVRefNum,
-                                                       &volParmsInfo, &infoSize);
-               if ( result == noErr )
-               {
-                       supportsCatSearch = hasCatSearch(&volParmsInfo);
-               }
-       }
-       
-       /* noErr or paramErr is OK here. */
-       /* paramErr just means that GetVolParms isn't supported by this volume */
-       if ( (result == noErr) || (result == paramErr) )
-       {
-               if ( supportsCatSearch )
-               {
-                       /* Volume supports CatSearch so use it. */
-                       /* CatSearch is faster than an indexed search. */
-                       result = PBCatSearchSync(paramBlock);
-               }
-               else
-               {
-                       /* Volume doesn't support CatSearch so */
-                       /* search using IndexedSearch from root directory. */
-                       result = IndexedSearch(paramBlock, fsRtDirID);
-               }
-       }
-       
-       return ( result );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   NameFileSearch(ConstStr255Param volName,
-                                                          short vRefNum,
-                                                          ConstStr255Param fileName,
-                                                          FSSpecPtr matches,
-                                                          long reqMatchCount,
-                                                          long *actMatchCount,
-                                                          Boolean newSearch,
-                                                          Boolean partial)
-{
-       CInfoPBRec              searchInfo1, searchInfo2;
-       HParamBlockRec  pb;
-       OSErr                   error;
-       static CatPositionRec catPosition;
-       static short    lastVRefNum = 0;
-       
-       /* get the real volume reference number */
-       error = DetermineVRefNum(volName, vRefNum, &vRefNum);
-       if ( error != noErr )
-               return ( error );
-       
-       pb.csParam.ioNamePtr = NULL;
-       pb.csParam.ioVRefNum = vRefNum;
-       pb.csParam.ioMatchPtr = matches;
-       pb.csParam.ioReqMatchCount = reqMatchCount;
-       if ( partial )  /* tell CatSearch what we're looking for: */
-       {
-               pb.csParam.ioSearchBits = fsSBPartialName + fsSBFlAttrib;       /* partial name file matches or */
-       }
-       else
-       {
-               pb.csParam.ioSearchBits =  fsSBFullName + fsSBFlAttrib;         /* full name file matches */
-       }
-       pb.csParam.ioSearchInfo1 = &searchInfo1;
-       pb.csParam.ioSearchInfo2 = &searchInfo2;
-       pb.csParam.ioSearchTime = 0;
-       if ( (newSearch) ||                             /* If caller specified new search */
-                (lastVRefNum != vRefNum) )     /* or if last search was to another volume, */
-       {
-               catPosition.initialize = 0;     /* then search from beginning of catalog */
-       }
-       pb.csParam.ioCatPosition = catPosition;
-       pb.csParam.ioOptBuffer = GetTempBuffer(0x00004000, &pb.csParam.ioOptBufSize);
-
-       /* search for fileName */
-       searchInfo1.hFileInfo.ioNamePtr = (StringPtr)fileName;
-       searchInfo2.hFileInfo.ioNamePtr = NULL;
-       
-       /* only match files (not directories) */
-       searchInfo1.hFileInfo.ioFlAttrib = 0x00;
-       searchInfo2.hFileInfo.ioFlAttrib = kioFlAttribDirMask;
-
-       error = PBCatSearchSyncCompat((CSParamPtr)&pb);
-       
-       if ( (error == noErr) ||                                                        /* If no errors or the end of catalog was */
-                (error == eofErr) )                                                    /* found, then the call was successful so */
-       {
-               *actMatchCount = pb.csParam.ioActMatchCount;    /* return the match count */
-       }
-       else
-       {
-               *actMatchCount = 0;                                                     /* else no matches found */
-       }
-       
-       if ( (error == noErr) ||                                                /* If no errors */
-                (error == catChangedErr) )                                     /* or there was a change in the catalog */
-       {
-               catPosition = pb.csParam.ioCatPosition;
-               lastVRefNum = vRefNum;
-                       /* we can probably start the next search where we stopped this time */
-       }
-       else
-       {
-               catPosition.initialize = 0;
-                       /* start the next search from beginning of catalog */
-       }
-       
-       if ( pb.csParam.ioOptBuffer != NULL )
-       {
-               DisposePtr(pb.csParam.ioOptBuffer);
-       }
-               
-       return ( error );
-}
-
-/*****************************************************************************/
-
-pascal OSErr   CreatorTypeFileSearch(ConstStr255Param volName,
-                                                                         short vRefNum,
-                                                                         OSType creator,
-                                                                         OSType fileType,
-                                                                         FSSpecPtr matches,
-                                                                         long reqMatchCount,
-                                                                         long *actMatchCount,
-                                                                         Boolean newSearch)
-{
-       CInfoPBRec              searchInfo1, searchInfo2;
-       HParamBlockRec  pb;
-       OSErr                   error;
-       static CatPositionRec catPosition;
-       static short    lastVRefNum = 0;
-       
-       /* get the real volume reference number */
-       error = DetermineVRefNum(volName, vRefNum, &vRefNum);
-       if ( error != noErr )
-               return ( error );
-       
-       pb.csParam.ioNamePtr = NULL;
-       pb.csParam.ioVRefNum = vRefNum;
-       pb.csParam.ioMatchPtr = matches;
-       pb.csParam.ioReqMatchCount = reqMatchCount;
-       pb.csParam.ioSearchBits = fsSBFlAttrib + fsSBFlFndrInfo;        /* Looking for finder info file matches */
-       pb.csParam.ioSearchInfo1 = &searchInfo1;
-       pb.csParam.ioSearchInfo2 = &searchInfo2;
-       pb.csParam.ioSearchTime = 0;
-       if ( (newSearch) ||                             /* If caller specified new search */
-                (lastVRefNum != vRefNum) )     /* or if last search was to another volume, */
-       {
-               catPosition.initialize = 0;     /* then search from beginning of catalog */
-       }
-       pb.csParam.ioCatPosition = catPosition;
-       pb.csParam.ioOptBuffer = GetTempBuffer(0x00004000, &pb.csParam.ioOptBufSize);
-
-       /* no fileName */
-       searchInfo1.hFileInfo.ioNamePtr = NULL;
-       searchInfo2.hFileInfo.ioNamePtr = NULL;
-       
-       /* only match files (not directories) */
-       searchInfo1.hFileInfo.ioFlAttrib = 0x00;
-       searchInfo2.hFileInfo.ioFlAttrib = kioFlAttribDirMask;
-       
-       /* search for creator; if creator = 0x00000000, ignore creator */
-       searchInfo1.hFileInfo.ioFlFndrInfo.fdCreator = creator;
-       if ( creator == (OSType)0x00000000 )
-       {
-               searchInfo2.hFileInfo.ioFlFndrInfo.fdCreator = (OSType)0x00000000;
-       }
-       else
-       {
-               searchInfo2.hFileInfo.ioFlFndrInfo.fdCreator = (OSType)0xffffffff;
-       }
-       
-       /* search for fileType; if fileType = 0x00000000, ignore fileType */
-       searchInfo1.hFileInfo.ioFlFndrInfo.fdType = fileType;
-       if ( fileType == (OSType)0x00000000 )
-       {
-               searchInfo2.hFileInfo.ioFlFndrInfo.fdType = (OSType)0x00000000;
-       }
-       else
-       {
-               searchInfo2.hFileInfo.ioFlFndrInfo.fdType = (OSType)0xffffffff;
-       }
-       
-       /* zero all other FInfo fields */
-       searchInfo1.hFileInfo.ioFlFndrInfo.fdFlags = 0;
-       searchInfo1.hFileInfo.ioFlFndrInfo.fdLocation.v = 0;
-       searchInfo1.hFileInfo.ioFlFndrInfo.fdLocation.h = 0;
-       searchInfo1.hFileInfo.ioFlFndrInfo.fdFldr = 0;
-       
-       searchInfo2.hFileInfo.ioFlFndrInfo.fdFlags = 0;
-       searchInfo2.hFileInfo.ioFlFndrInfo.fdLocation.v = 0;
-       searchInfo2.hFileInfo.ioFlFndrInfo.fdLocation.h = 0;
-       searchInfo2.hFileInfo.ioFlFndrInfo.fdFldr = 0;
-
-       error = PBCatSearchSyncCompat((CSParamPtr)&pb);
-       
-       if ( (error == noErr) ||                                                        /* If no errors or the end of catalog was */
-                (error == eofErr) )                                                    /* found, then the call was successful so */
-       {
-               *actMatchCount = pb.csParam.ioActMatchCount;    /* return the match count */
-       }
-       else
-       {
-               *actMatchCount = 0;                                                     /* else no matches found */
-       }
-       
-       if ( (error == noErr) ||                                                /* If no errors */
-                (error == catChangedErr) )                                     /* or there was a change in the catalog */
-       {
-               catPosition = pb.csParam.ioCatPosition;
-               lastVRefNum = vRefNum;
-                       /* we can probably start the next search where we stopped this time */
-       }
-       else
-       {
-               catPosition.initialize = 0;
-                       /* start the next search from beginning of catalog */
-       }
-       
-       if ( pb.csParam.ioOptBuffer != NULL )
-       {
-               DisposePtr(pb.csParam.ioOptBuffer);
-       }
-               
-       return ( error );
-}
-
-/*****************************************************************************/
diff --git a/src/mac/morefile/Search.h b/src/mac/morefile/Search.h
deleted file mode 100644 (file)
index 3fee03d..0000000
+++ /dev/null
@@ -1,304 +0,0 @@
-/*
-     File:       Search.h
-     Contains:   IndexedSearch and the PBCatSearch compatibility function.
-     Version:    Technology: MoreFiles
-                 Release:    1.5.2
-     Copyright:  © 1992-2001 by Apple Computer, Inc., all rights reserved.
-     Bugs?:      For bug reports, consult the following page on
-                 the World Wide Web:
-                     http://developer.apple.com/bugreporter/
-*/
-
-/*
-    You may incorporate this sample code into your applications without
-    restriction, though the sample code has been provided "AS IS" and the
-    responsibility for its operation is 100% yours.  However, what you are
-    not permitted to do is to redistribute the source as "DSC Sample Code"
-    after having made changes. If you're going to re-distribute the source,
-    we require that you make it clear in the source that the code was
-    descended from Apple Sample Code, but that you've made changes.
-*/
-
-#ifndef __SEARCH__
-#define __SEARCH__
-
-#ifndef __MACTYPES__
-#include <MacTypes.h>
-#endif
-
-#ifndef __FILES__
-#include <Files.h>
-#endif
-
-#include "Optimization.h"
-
-
-#if PRAGMA_ONCE
-#pragma once
-#endif
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#if PRAGMA_IMPORT
-#pragma import on
-#endif
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=mac68k
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(push, 2)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack(2)
-#endif
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-IndexedSearch(
-  CSParamPtr   pb,
-  long         dirID);
-
-
-/*
-    The IndexedSearch function performs an indexed search in and below the
-    specified directory using the same parameters (in pb) as is passed to
-    PBCatSearch. See Inside Macintosh: Files for a description of the
-    parameter block.
-    
-    pb          input:  A CSParamPtr record specifying the volume to search
-                        and the search criteria.
-                output: Fields in the parameter block are returned indicating
-                        the number of matches found, the matches, and if the
-                        search ended with noErr, the CatPosition record that
-                        lets you resume a search where the last search left
-                        off.
-    dirID       input:  The directory to search. If fsRtDirID is passed,
-                        the entire volume is searched.
-    
-    Note:   If you use a high-level debugger and use ioSearchTime to limit
-            the length of time to run the search, you'll want to step over
-            calls to IndexedSearch because it installs a Time Manager task.
-            Most high-level debuggers don't deal gracefully with interrupt
-            driven code.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        eofErr              -39     End of catalog found (this is normal!)
-        paramErr            -50     Parameter block has invalid parameters
-                                    (see source for VerifyUserPB) or
-                                    invalid catPosition record was passed
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        memFullErr          -108    Memory could not be allocated in heap
-        catChangedErr       -1304   Catalog has changed and catalog position
-                                    record may be invalid
-    
-    __________
-    
-    See also:   PBCatSearch, PBCatSearchSyncCompat
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-PBCatSearchSyncCompat(CSParamPtr paramBlock);
-
-
-/*
-    The PBCatSearchSyncCompat function uses PBCatSearch (if available) or
-    IndexedSearch (if PBCatSearch is not available) to search a volume
-    using a set of search criteria that you specify. It builds a list of all
-    files or directories that meet your specifications.
-    
-    pb          input:  A CSParamPtr record specifying the volume to search
-                        and the search criteria.
-                output: Fields in the parameter block are returned indicating
-                        the number of matches found, the matches, and if the
-                        search ended with noErr, the CatPosition record that
-                        lets you resume a search where the last search left
-                        off.
-    
-    Note:   If you use a high-level debugger and use ioSearchTime to limit
-            the length of time to run the search, you'll want to step over
-            calls to PBCatSearchSyncCompat because it calls IndexedSearch
-            which installs a Time Manager task. Most high-level debuggers
-            don't deal gracefully with interrupt driven code.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        eofErr              -39     End of catalog found (this is normal!)
-        paramErr            -50     Parameter block has invalid parameters
-                                    (see source for VerifyUserPB) or
-                                    invalid catPosition record was passed
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        memFullErr          -108    Memory could not be allocated in heap
-        catChangedErr       -1304   Catalog has changed and catalog position
-                                    record may be invalid
-        afpCatalogChanged   -5037   Catalog has changed and search cannot
-                                    be resumed
-    
-    __________
-    
-    See also:   PBCatSearch, IndexedSearch
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-NameFileSearch(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  ConstStr255Param   fileName,
-  FSSpecPtr          matches,
-  long               reqMatchCount,
-  long *             actMatchCount,
-  Boolean            newSearch,
-  Boolean            partial);
-
-
-/*
-    The NameFileSearch function searches for files with a specific file
-    name on a volume that supports PBCatSearch.
-    Note: A result of catChangedErr means the catalog has changed between
-    searches, but the search can be continued with the possiblity that you
-    may miss some matches or get duplicate matches.  For all other results
-    (except for noErr), the search cannot be continued.
-
-    volName         input:  A pointer to the name of a mounted volume
-                            or nil.
-    vRefNum         input:  Volume specification.
-    fileName        input:  The name of the file to search for.
-    matches         input:  Pointer to array of FSSpec where the match list is
-                            returned.
-    reqMatchCount   input:  Maximum number of matches to return (the number of
-                            elements in the matches array).
-    actMatchCount   output: The number of matches actually returned.
-    newSearch       input:  If true, start a new search. If false and if
-                            vRefNum is the same as the last call to
-                            NameFileSearch, then start searching at the
-                            position where the last search left off.
-    partial         input:  If the partial parameter is false, then only files
-                            that exactly match fileName will be found.  If the
-                            partial parameter is true, then all file names that
-                            contain fileName will be found.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        eofErr              -39     End of catalog found (this is normal!)
-        paramErr            -50     Parameter block has invalid parameters
-                                    (see source for VerifyUserPB) or
-                                    invalid catPosition record was passed
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        memFullErr          -108    Memory could not be allocated in heap
-        catChangedErr       -1304   Catalog has changed and catalog position
-                                    record may be invalid
-        afpCatalogChanged   -5037   Catalog has changed and search cannot
-                                    be resumed
-    
-    __________
-    
-    Also see:   CreatorTypeFileSearch
-*/
-
-/*****************************************************************************/
-
-EXTERN_API( OSErr )
-CreatorTypeFileSearch(
-  ConstStr255Param   volName,
-  short              vRefNum,
-  OSType             creator,
-  OSType             fileType,
-  FSSpecPtr          matches,
-  long               reqMatchCount,
-  long *             actMatchCount,
-  Boolean            newSearch);
-
-
-/*
-    The CreatorTypeFileSearch function searches for files with a specific
-    creator or fileType on a volume that supports PBCatSearch.
-    Note: A result of catChangedErr means the catalog has changed between
-    searches, but the search can be continued with the possiblity that you
-    may miss some matches or get duplicate matches.  For all other results
-    (except for noErr), the search cannot be continued.
-
-    volName         input:  A pointer to the name of a mounted volume
-                            or nil.
-    vRefNum         input:  Volume specification.
-    creator         input:  The creator type of the file to search for.
-                            To ignore the creator type, pass 0x00000000 in
-                            this field.
-    fileType        input:  The file type of the file to search for.
-                            To ignore the file type, pass 0x00000000 in
-                            this field.
-    matches         input:  Pointer to array of FSSpec where the match list is
-                            returned.
-    reqMatchCount   input:  Maximum number of matches to return (the number of
-                            elements in the matches array).
-    actMatchCount   output: The number of matches actually returned.
-    newSearch       input:  If true, start a new search. If false and if
-                            vRefNum is the same as the last call to
-                            CreatorTypeFileSearch, then start searching at the
-                            position where the last search left off.
-    
-    Result Codes
-        noErr               0       No error
-        nsvErr              -35     Volume not found
-        ioErr               -36     I/O error
-        eofErr              -39     End of catalog found (this is normal!)
-        paramErr            -50     Parameter block has invalid parameters
-                                    (see source for VerifyUserPB) or
-                                    invalid catPosition record was passed
-        extFSErr            -58     External file system error - no file
-                                    system claimed this call.
-        memFullErr          -108    Memory could not be allocated in heap
-        catChangedErr       -1304   Catalog has changed and catalog position
-                                    record may be invalid
-        afpCatalogChanged   -5037   Catalog has changed and search cannot
-                                    be resumed
-    
-    __________
-    
-    Also see:   NameFileSearch
-*/
-
-/*****************************************************************************/
-
-#include "OptimizationEnd.h"
-
-#if PRAGMA_STRUCT_ALIGN
-    #pragma options align=reset
-#elif PRAGMA_STRUCT_PACKPUSH
-    #pragma pack(pop)
-#elif PRAGMA_STRUCT_PACK
-    #pragma pack()
-#endif
-
-#ifdef PRAGMA_IMPORT_OFF
-#pragma import off
-#elif PRAGMA_IMPORT
-#pragma import reset
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* __SEARCH__ */
-
diff --git a/src/mac/morefilex/MoreFilesX.c b/src/mac/morefilex/MoreFilesX.c
deleted file mode 100644 (file)
index d380e0d..0000000
+++ /dev/null
@@ -1,2770 +0,0 @@
-/*
-       File:           MoreFilesX.c
-
-       Contains:       A collection of useful high-level File Manager routines
-                               which use the HFS Plus APIs wherever possible.
-
-       Version:        MoreFilesX 1.0.1
-
-       Copyright:      © 1992-2002 by Apple Computer, Inc., all rights reserved.
-
-       Disclaimer:     IMPORTANT:  This Apple software is supplied to you by Apple Computer, Inc.
-                               ("Apple") in consideration of your agreement to the following terms, and your
-                               use, installation, modification or redistribution of this Apple software
-                               constitutes acceptance of these terms.  If you do not agree with these terms,
-                               please do not use, install, modify or redistribute this Apple software.
-
-                               In consideration of your agreement to abide by the following terms, and subject
-                               to these terms, Apple grants you a personal, non-exclusive license, under AppleÕs
-                               copyrights in this original Apple software (the "Apple Software"), to use,
-                               reproduce, modify and redistribute the Apple Software, with or without
-                               modifications, in source and/or binary forms; provided that if you redistribute
-                               the Apple Software in its entirety and without modifications, you must retain
-                               this notice and the following text and disclaimers in all such redistributions of
-                               the Apple Software.  Neither the name, trademarks, service marks or logos of
-                               Apple Computer, Inc. may be used to endorse or promote products derived from the
-                               Apple Software without specific prior written permission from Apple.  Except as
-                               expressly stated in this notice, no other rights or licenses, express or implied,
-                               are granted by Apple herein, including but not limited to any patent rights that
-                               may be infringed by your derivative works or by other works in which the Apple
-                               Software may be incorporated.
-
-                               The Apple Software is provided by Apple on an "AS IS" basis.  APPLE MAKES NO
-                               WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED
-                               WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS FOR A PARTICULAR
-                               PURPOSE, REGARDING THE APPLE SOFTWARE OR ITS USE AND OPERATION ALONE OR IN
-                               COMBINATION WITH YOUR PRODUCTS.
-
-                               IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL OR
-                               CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
-                               GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
-                               ARISING IN ANY WAY OUT OF THE USE, REPRODUCTION, MODIFICATION AND/OR DISTRIBUTION
-                               OF THE APPLE SOFTWARE, HOWEVER CAUSED AND WHETHER UNDER THEORY OF CONTRACT, TORT
-                               (INCLUDING NEGLIGENCE), STRICT LIABILITY OR OTHERWISE, EVEN IF APPLE HAS BEEN
-                               ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-
-       File Ownership:
-
-               DRI:                            Apple Macintosh Developer Technical Support
-
-               Other Contact:          For bug reports, consult the following page on
-                                                       the World Wide Web:
-                                                               http://developer.apple.com/bugreporter/
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-
-       Change History (most recent first):
-
-                <4>     8/22/02        JL              [3016251]  Changed FSMoveRenameObjectUnicode to not use
-                                                                       the Temporary folder because it isn't available on
-                                                                       NFS volumes.
-                <3>     4/19/02        JL              [2853905]  Fixed #if test around header includes.
-                <2>     4/19/02        JL              [2850624]  Fixed C++ compile errors and Project Builder
-                                                                       warnings.
-                <2>     4/19/02        JL              [2853901]  Updated standard disclaimer.
-                <1>     1/25/02        JL              MoreFilesX 1.0
-*/
-
-#if defined(__MACH__)
-       #include <Carbon/Carbon.h>
-       #include <string.h>
-#else
-       #include <Carbon.h>
-       #include <string.h>
-#endif
-
-#include "MoreFilesX.h"
-
-/* Set BuildingMoreFilesXForMacOS9 to 1 if building for Mac OS 9 */
-#ifndef BuildingMoreFilesXForMacOS9
-       #define BuildingMoreFilesXForMacOS9 0
-#endif
-
-/*****************************************************************************/
-
-#pragma mark ----- Local type definitions -----
-
-struct FSIterateContainerGlobals
-{
-       IterateContainerFilterProcPtr   iterateFilter;  /* pointer to IterateFilterProc */
-       FSCatalogInfoBitmap                             whichInfo;              /* fields of the CatalogInfo to get */
-       FSCatalogInfo                                   catalogInfo;    /* FSCatalogInfo */
-       FSRef                                                   ref;                    /* FSRef */
-       FSSpec                                                  spec;                   /* FSSpec */
-       FSSpec                                                  *specPtr;               /* pointer to spec field, or NULL */
-       HFSUniStr255                                    name;                   /* HFSUniStr255 */
-       HFSUniStr255                                    *namePtr;               /* pointer to name field, or NULL */
-       void                                                    *yourDataPtr;   /* a pointer to caller supplied data the filter may need to access */
-       ItemCount                                               maxLevels;              /* maximum levels to iterate through */
-       ItemCount                                               currentLevel;   /* the current level FSIterateContainerLevel is on */
-       Boolean                                                 quitFlag;               /* set to true if filter wants to kill interation */
-       Boolean                                                 containerChanged; /* temporary - set to true if the current container changed during iteration */
-       OSErr                                                   result;                 /* result */
-       ItemCount                                               actualObjects;  /* number of objects returned */
-};
-typedef struct FSIterateContainerGlobals FSIterateContainerGlobals;
-
-struct FSDeleteContainerGlobals
-{
-       OSErr                                                   result;                 /* result */
-       ItemCount                                               actualObjects;  /* number of objects returned */
-       FSCatalogInfo                                   catalogInfo;    /* FSCatalogInfo */
-};
-typedef struct FSDeleteContainerGlobals FSDeleteContainerGlobals;
-
-/*****************************************************************************/
-
-#pragma mark ----- Local prototypes -----
-
-static
-void
-FSDeleteContainerLevel(
-       const FSRef *container,
-       FSDeleteContainerGlobals *theGlobals);
-
-static
-void
-FSIterateContainerLevel(
-       FSIterateContainerGlobals *theGlobals);
-
-static
-OSErr
-GenerateUniqueHFSUniStr(
-       long *startSeed,
-       const FSRef *dir1,
-       const FSRef *dir2,
-       HFSUniStr255 *uniqueName);
-
-/*****************************************************************************/
-
-#pragma mark ----- File Access Routines -----
-
-/*****************************************************************************/
-
-OSErr
-FSCopyFork(
-       SInt16 srcRefNum,
-       SInt16 dstRefNum,
-       void *copyBufferPtr,
-       ByteCount copyBufferSize)
-{
-       OSErr           srcResult;
-       OSErr           dstResult;
-       OSErr           result;
-       SInt64          forkSize;
-       ByteCount       readActualCount;
-       
-       /* check input parameters */
-       require_action((NULL != copyBufferPtr) && (0 != copyBufferSize), BadParameter, result = paramErr);
-       
-       /* get source fork size */
-       result = FSGetForkSize(srcRefNum, &forkSize);
-       require_noerr(result, SourceFSGetForkSizeFailed);
-       
-       /* allocate disk space for destination fork */
-       result = FSSetForkSize(dstRefNum, fsFromStart, forkSize);
-       require_noerr(result, DestinationFSSetForkSizeFailed);
-       
-       /* reset source fork's position to 0 */
-       result = FSSetForkPosition(srcRefNum, fsFromStart, 0);
-       require_noerr(result, SourceFSSetForkPositionFailed);
-       
-       /* reset destination fork's position to 0 */
-       result = FSSetForkPosition(dstRefNum, fsFromStart, 0);
-       require_noerr(result, DestinationFSSetForkPositionFailed);
-
-       /* If copyBufferSize is greater than 4K bytes, make it a multiple of 4k bytes */
-       /* This will make writes on local volumes faster */
-       if ( (copyBufferSize >= 0x00001000) && ((copyBufferSize & 0x00000fff) != 0) )
-       {
-               copyBufferSize &= ~(0x00001000 - 1);
-       }
-       
-       /* copy source to destination */
-       srcResult = dstResult = noErr;
-       while ( (noErr == srcResult) && (noErr == dstResult) )
-       {
-               srcResult = FSReadFork(srcRefNum, fsAtMark + noCacheMask, 0, copyBufferSize, copyBufferPtr, &readActualCount);
-               dstResult = FSWriteFork(dstRefNum, fsAtMark + noCacheMask, 0, readActualCount, copyBufferPtr, NULL);
-       }
-       
-       /* make sure there were no errors at the destination */
-       require_noerr_action(dstResult, DestinationFSWriteForkFailed, result = dstResult);
-       
-       /* make sure the error at the source was eofErr */
-       require_action(eofErr == srcResult, SourceResultNotEofErr, result = srcResult);
-       
-       /* everything went as expected */
-       result = noErr;
-
-SourceResultNotEofErr:
-DestinationFSWriteForkFailed:
-DestinationFSSetForkPositionFailed:
-SourceFSSetForkPositionFailed:
-DestinationFSSetForkSizeFailed:
-SourceFSGetForkSizeFailed:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-#pragma mark ----- Volume Access Routines -----
-
-/*****************************************************************************/ 
-
-OSErr
-FSGetVolParms(
-       FSVolumeRefNum volRefNum,
-       UInt32 bufferSize,
-       GetVolParmsInfoBuffer *volParmsInfo,
-       UInt32 *actualInfoSize)
-{
-       OSErr                   result;
-       HParamBlockRec  pb;
-       
-       /* check parameters */
-       require_action((NULL != volParmsInfo) && (NULL != actualInfoSize),
-               BadParameter, result = paramErr);
-       
-       pb.ioParam.ioNamePtr = NULL;
-       pb.ioParam.ioVRefNum = volRefNum;
-       pb.ioParam.ioBuffer = (Ptr)volParmsInfo;
-       pb.ioParam.ioReqCount = (SInt32)bufferSize;
-       result = PBHGetVolParmsSync(&pb);
-       require_noerr(result, PBHGetVolParmsSync);
-       
-       /* return number of bytes the file system returned in volParmsInfo buffer */
-       *actualInfoSize = (UInt32)pb.ioParam.ioActCount;
-       
-PBHGetVolParmsSync:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetVRefNum(
-       const FSRef *ref,
-       FSVolumeRefNum *vRefNum)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       
-       /* check parameters */
-       require_action(NULL != vRefNum, BadParameter, result = paramErr);
-       
-       /* get the volume refNum from the FSRef */
-       result = FSGetCatalogInfo(ref, kFSCatInfoVolume, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* return volume refNum from catalogInfo */
-       *vRefNum = catalogInfo.volume;
-       
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetVInfo(
-       FSVolumeRefNum volume,
-       HFSUniStr255 *volumeName,       /* can be NULL */
-       UInt64 *freeBytes,                      /* can be NULL */
-       UInt64 *totalBytes)                     /* can be NULL */
-{
-       OSErr                           result;
-       FSVolumeInfo            info;
-       
-       /* ask for the volume's sizes only if needed */
-       result = FSGetVolumeInfo(volume, 0, NULL,
-               (((NULL != freeBytes) || (NULL != totalBytes)) ? kFSVolInfoSizes : kFSVolInfoNone),
-               &info, volumeName, NULL);
-       require_noerr(result, FSGetVolumeInfo);
-       
-       if ( NULL != freeBytes )
-       {
-               *freeBytes = info.freeBytes;
-       }
-       if ( NULL != totalBytes )
-       {
-               *totalBytes = info.totalBytes;
-       }
-       
-FSGetVolumeInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetVolFileSystemID(
-       FSVolumeRefNum volume,
-       UInt16 *fileSystemID,   /* can be NULL */
-       UInt16 *signature)              /* can be NULL */
-{
-       OSErr                   result;
-       FSVolumeInfo    info;
-       
-       result = FSGetVolumeInfo(volume, 0, NULL, kFSVolInfoFSInfo, &info, NULL, NULL);
-       require_noerr(result, FSGetVolumeInfo);
-       
-       if ( NULL != fileSystemID )
-       {
-               *fileSystemID = info.filesystemID;
-       }
-       if ( NULL != signature )
-       {
-               *signature = info.signature;
-       }
-       
-FSGetVolumeInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetMountedVolumes(
-       FSRef ***volumeRefsHandle,      /* pointer to handle of FSRefs */
-       ItemCount *numVolumes)
-{
-       OSErr           result;
-       OSErr           memResult;
-       ItemCount       volumeIndex;
-       FSRef           ref;
-       
-       /* check parameters */
-       require_action((NULL != volumeRefsHandle) && (NULL != numVolumes),
-               BadParameter, result = paramErr);
-       
-       /* No volumes yet */
-       *numVolumes = 0;
-       
-       /* Allocate a handle for the results */
-       *volumeRefsHandle = (FSRef **)NewHandle(0);
-       require_action(NULL != *volumeRefsHandle, NewHandle, result = memFullErr);
-       
-       /* Call FSGetVolumeInfo in loop to get all volumes starting with the first */
-       volumeIndex = 1;
-       do
-       {
-               result = FSGetVolumeInfo(0, volumeIndex, NULL, kFSVolInfoNone, NULL, NULL, &ref);
-               if ( noErr == result )
-               {
-                       /* concatenate the FSRef to the end of the handle */
-                       PtrAndHand(&ref, (Handle)*volumeRefsHandle, sizeof(FSRef));
-                       memResult = MemError();
-                       require_noerr_action(memResult, MemoryAllocationFailed, result = memResult);
-                       
-                       ++(*numVolumes);        /* increment the volume count */
-                       ++volumeIndex;          /* and the volumeIndex to get the next volume*/
-               }
-       } while ( noErr == result );
-       
-       /* nsvErr is OK -- it just means there are no more volumes */
-       require(nsvErr == result, FSGetVolumeInfo);
-               
-       return ( noErr );
-       
-       /**********************/
-       
-MemoryAllocationFailed:
-FSGetVolumeInfo:
-
-       /* dispose of handle if already allocated and clear the outputs */
-       if ( NULL != *volumeRefsHandle )
-       {
-               DisposeHandle((Handle)*volumeRefsHandle);
-               *volumeRefsHandle = NULL;
-       }
-       *numVolumes = 0;
-       
-NewHandle:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-#pragma mark ----- FSRef/FSpec/Path/Name Conversion Routines -----
-
-/*****************************************************************************/
-
-OSErr
-FSRefMakeFSSpec(
-       const FSRef *ref,
-       FSSpec *spec)
-{
-       OSErr   result;
-       
-       /* check parameters */
-       require_action(NULL != spec, BadParameter, result = paramErr);
-       
-       result = FSGetCatalogInfo(ref, kFSCatInfoNone, NULL, NULL, spec, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSMakeFSRef(
-       FSVolumeRefNum volRefNum,
-       SInt32 dirID,
-       ConstStr255Param name,
-       FSRef *ref)
-{
-       OSErr           result;
-       FSRefParam      pb;
-       
-       /* check parameters */
-       require_action(NULL != ref, BadParameter, result = paramErr);
-       
-       pb.ioVRefNum = volRefNum;
-       pb.ioDirID = dirID;
-       pb.ioNamePtr = (StringPtr)name;
-       pb.newRef = ref;
-       result = PBMakeFSRefSync(&pb);
-       require_noerr(result, PBMakeFSRefSync);
-       
-PBMakeFSRefSync:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSStatus
-FSMakePath(
-       SInt16 volRefNum,
-       SInt32 dirID,
-       ConstStr255Param name,
-       UInt8 *path,
-       UInt32 maxPathSize)
-{
-       OSStatus        result;
-       FSRef           ref;
-       
-       /* check parameters */
-       require_action(NULL != path, BadParameter, result = paramErr);
-       
-       /* convert the inputs to an FSRef */
-       result = FSMakeFSRef(volRefNum, dirID, name, &ref);
-       require_noerr(result, FSMakeFSRef);
-       
-       /* and then convert the FSRef to a path */
-       result = FSRefMakePath(&ref, path, maxPathSize);
-       require_noerr(result, FSRefMakePath);
-       
-FSRefMakePath:
-FSMakeFSRef:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSStatus
-FSPathMakeFSSpec(
-       const UInt8 *path,
-       FSSpec *spec,
-       Boolean *isDirectory)   /* can be NULL */
-{
-       OSStatus        result;
-       FSRef           ref;
-       
-       /* check parameters */
-       require_action(NULL != spec, BadParameter, result = paramErr);
-       
-       /* convert the POSIX path to an FSRef */
-       result = FSPathMakeRef(path, &ref, isDirectory);
-       require_noerr(result, FSPathMakeRef);
-       
-       /* and then convert the FSRef to an FSSpec */
-       result = FSGetCatalogInfo(&ref, kFSCatInfoNone, NULL, NULL, spec, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-FSGetCatalogInfo:
-FSPathMakeRef:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-UnicodeNameGetHFSName(
-       UniCharCount nameLength,
-       const UniChar *name,
-       TextEncoding textEncodingHint,
-       Boolean isVolumeName,
-       Str31 hfsName)
-{
-       OSStatus                        result;
-       ByteCount                       unicodeByteLength;
-       ByteCount                       unicodeBytesConverted;
-       ByteCount                       actualPascalBytes;
-       UnicodeMapping          uMapping;
-       UnicodeToTextInfo       utInfo;
-       
-       /* check parameters */
-       require_action(NULL != hfsName, BadParameter, result = paramErr);
-       
-       /* make sure output is valid in case we get errors or there's nothing to convert */
-       hfsName[0] = 0;
-       
-       unicodeByteLength = nameLength * sizeof(UniChar);
-       if ( 0 == unicodeByteLength )
-       {
-               /* do nothing */
-               result = noErr;
-       }
-       else
-       {
-               /* if textEncodingHint is kTextEncodingUnknown, get a "default" textEncodingHint */
-               if ( kTextEncodingUnknown == textEncodingHint )
-               {
-                       ScriptCode                      script;
-                       RegionCode                      region;
-                       
-                       script = (ScriptCode)GetScriptManagerVariable(smSysScript);
-                       region = (RegionCode)GetScriptManagerVariable(smRegionCode);
-                       result = UpgradeScriptInfoToTextEncoding(script, kTextLanguageDontCare, region,
-                               NULL, &textEncodingHint );
-                       if ( paramErr == result )
-                       {
-                               /* ok, ignore the region and try again */
-                               result = UpgradeScriptInfoToTextEncoding(script, kTextLanguageDontCare,
-                                       kTextRegionDontCare, NULL, &textEncodingHint );
-                       }
-                       if ( noErr != result )
-                       {
-                               /* ok... try something */
-                               textEncodingHint = kTextEncodingMacRoman;
-                       }
-               }
-               
-               uMapping.unicodeEncoding = CreateTextEncoding(kTextEncodingUnicodeV2_0,
-                       kUnicodeCanonicalDecompVariant, kUnicode16BitFormat);
-               uMapping.otherEncoding = GetTextEncodingBase(textEncodingHint);
-               uMapping.mappingVersion = kUnicodeUseHFSPlusMapping;
-       
-               result = CreateUnicodeToTextInfo(&uMapping, &utInfo);
-               require_noerr(result, CreateUnicodeToTextInfo);
-               
-               result = ConvertFromUnicodeToText(utInfo, unicodeByteLength, name, kUnicodeLooseMappingsMask,
-                       0, NULL, 0, NULL,       /* offsetCounts & offsetArrays */
-                       isVolumeName ? kHFSMaxVolumeNameChars : kHFSMaxFileNameChars,
-                       &unicodeBytesConverted, &actualPascalBytes, &hfsName[1]);
-               require_noerr(result, ConvertFromUnicodeToText);
-               
-               hfsName[0] = (unsigned char)actualPascalBytes;  /* fill in length byte */
-
-ConvertFromUnicodeToText:
-               
-               /* verify the result in debug builds -- there's really not anything you can do if it fails */
-               verify_noerr(DisposeUnicodeToTextInfo(&utInfo));
-       }
-       
-CreateUnicodeToTextInfo:       
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-HFSNameGetUnicodeName(
-       ConstStr31Param hfsName,
-       TextEncoding textEncodingHint,
-       HFSUniStr255 *unicodeName)
-{
-       ByteCount                       unicodeByteLength;
-       OSStatus                        result;
-       UnicodeMapping          uMapping;
-       TextToUnicodeInfo       tuInfo;
-       ByteCount                       pascalCharsRead;
-       
-       /* check parameters */
-       require_action(NULL != unicodeName, BadParameter, result = paramErr);
-       
-       /* make sure output is valid in case we get errors or there's nothing to convert */
-       unicodeName->length = 0;
-       
-       if ( 0 == StrLength(hfsName) )
-       {
-               result = noErr;
-       }
-       else
-       {
-               /* if textEncodingHint is kTextEncodingUnknown, get a "default" textEncodingHint */
-               if ( kTextEncodingUnknown == textEncodingHint )
-               {
-                       ScriptCode                      script;
-                       RegionCode                      region;
-                       
-                       script = GetScriptManagerVariable(smSysScript);
-                       region = GetScriptManagerVariable(smRegionCode);
-                       result = UpgradeScriptInfoToTextEncoding(script, kTextLanguageDontCare, region,
-                               NULL, &textEncodingHint);
-                       if ( paramErr == result )
-                       {
-                               /* ok, ignore the region and try again */
-                               result = UpgradeScriptInfoToTextEncoding(script, kTextLanguageDontCare,
-                                       kTextRegionDontCare, NULL, &textEncodingHint);
-                       }
-                       if ( noErr != result )
-                       {
-                               /* ok... try something */
-                               textEncodingHint = kTextEncodingMacRoman;
-                       }
-               }
-               
-               uMapping.unicodeEncoding = CreateTextEncoding(kTextEncodingUnicodeV2_0,
-                       kUnicodeCanonicalDecompVariant, kUnicode16BitFormat);
-               uMapping.otherEncoding = GetTextEncodingBase(textEncodingHint);
-               uMapping.mappingVersion = kUnicodeUseHFSPlusMapping;
-       
-               result = CreateTextToUnicodeInfo(&uMapping, &tuInfo);
-               require_noerr(result, CreateTextToUnicodeInfo);
-                       
-               result = ConvertFromTextToUnicode(tuInfo, hfsName[0], &hfsName[1],
-                       0,                                                              /* no control flag bits */
-                       0, NULL, 0, NULL,                               /* offsetCounts & offsetArrays */
-                       sizeof(unicodeName->unicode),   /* output buffer size in bytes */
-                       &pascalCharsRead, &unicodeByteLength, unicodeName->unicode);
-               require_noerr(result, ConvertFromTextToUnicode);
-               
-               /* convert from byte count to char count */
-               unicodeName->length = unicodeByteLength / sizeof(UniChar);
-
-ConvertFromTextToUnicode:
-
-               /* verify the result in debug builds -- there's really not anything you can do if it fails */
-               verify_noerr(DisposeTextToUnicodeInfo(&tuInfo));
-       }
-       
-CreateTextToUnicodeInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-#pragma mark ----- File/Directory Manipulation Routines -----
-
-/*****************************************************************************/
-
-Boolean FSRefValid(const FSRef *ref)
-{
-       return ( noErr == FSGetCatalogInfo(ref, kFSCatInfoNone, NULL, NULL, NULL, NULL) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetParentRef(
-       const FSRef *ref,
-       FSRef *parentRef)
-{
-       OSErr   result;
-       FSCatalogInfo   catalogInfo;
-       
-       /* check parameters */
-       require_action(NULL != parentRef, BadParameter, result = paramErr);
-       
-       result = FSGetCatalogInfo(ref, kFSCatInfoNodeID, &catalogInfo, NULL, NULL, parentRef);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /*
-        * Note: FSRefs always point to real file system objects. So, there cannot
-        * be a FSRef to the parent of volume root directories. Early versions of
-        * Mac OS X do not handle this case correctly and incorrectly return a
-        * FSRef for the parent of volume root directories instead of returning an
-        * invalid FSRef (a cleared FSRef is invalid). The next three lines of code
-        * ensure that you won't run into this bug. WW9D!
-        */
-       if ( fsRtDirID == catalogInfo.nodeID )
-       {
-               /* clear parentRef and return noErr which is the proper behavior */
-               memset(parentRef, 0, sizeof(FSRef));
-       }
-
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetFileDirName(
-       const FSRef *ref,
-       HFSUniStr255 *outName)
-{
-       OSErr   result;
-       
-       /* check parameters */
-       require_action(NULL != outName, BadParameter, result = paramErr);
-       
-       result = FSGetCatalogInfo(ref, kFSCatInfoNone, NULL, outName, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetNodeID(
-       const FSRef *ref,
-       long *nodeID,                   /* can be NULL */
-       Boolean *isDirectory)   /* can be NULL */
-{
-       OSErr                           result;
-       FSCatalogInfo           catalogInfo;
-       FSCatalogInfoBitmap whichInfo;
-       
-       /* determine what catalog information to get */
-       whichInfo = kFSCatInfoNone; /* start with none */
-       if ( NULL != nodeID )
-       {
-               whichInfo |= kFSCatInfoNodeID;
-       }
-       if ( NULL != isDirectory )
-       {
-               whichInfo |= kFSCatInfoNodeFlags;
-       }
-       
-       result = FSGetCatalogInfo(ref, whichInfo, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       if ( NULL != nodeID )
-       {
-               *nodeID = catalogInfo.nodeID;
-       }
-       if ( NULL != isDirectory )
-       {
-               *isDirectory = (0 != (kFSNodeIsDirectoryMask & catalogInfo.nodeFlags));
-       }
-       
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetUserPrivilegesPermissions(
-       const FSRef *ref,
-       UInt8 *userPrivileges,          /* can be NULL */
-       UInt32 permissions[4])          /* can be NULL */
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       FSCatalogInfoBitmap whichInfo;
-       
-       /* determine what catalog information to get */
-       whichInfo = kFSCatInfoNone; /* start with none */
-       if ( NULL != userPrivileges )
-       {
-               whichInfo |= kFSCatInfoUserPrivs;
-       }
-       if ( NULL != permissions )
-       {
-               whichInfo |= kFSCatInfoPermissions;
-       }
-       
-       result = FSGetCatalogInfo(ref, whichInfo, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       if ( NULL != userPrivileges )
-       {
-               *userPrivileges = catalogInfo.userPrivileges;
-       }
-       if ( NULL != permissions )
-       {
-               BlockMoveData(&catalogInfo.permissions, permissions, sizeof(UInt32) * 4);
-       }
-       
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSCheckLock(
-       const FSRef *ref)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       FSVolumeInfo    volumeInfo;
-       
-       /* get nodeFlags and vRefNum for container */
-       result = FSGetCatalogInfo(ref, kFSCatInfoNodeFlags + kFSCatInfoVolume, &catalogInfo, NULL, NULL,NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* is file locked? */
-       if ( 0 != (catalogInfo.nodeFlags & kFSNodeLockedMask) )
-       {
-               result = fLckdErr;      /* file is locked */
-       }
-       else
-       {
-               /* file isn't locked, but is volume locked? */
-               
-               /* get volume flags */
-               result = FSGetVolumeInfo(catalogInfo.volume, 0, NULL, kFSVolInfoFlags, &volumeInfo, NULL, NULL);
-               require_noerr(result, FSGetVolumeInfo);
-               
-               if ( 0 != (volumeInfo.flags & kFSVolFlagHardwareLockedMask) )
-               {
-                       result = wPrErr;        /* volume locked by hardware */
-               }
-               else if ( 0 != (volumeInfo.flags & kFSVolFlagSoftwareLockedMask) )
-               {
-                       result = vLckdErr;      /* volume locked by software */
-               }
-       }
-       
-FSGetVolumeInfo:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetForkSizes(
-       const FSRef *ref,
-       UInt64 *dataLogicalSize,        /* can be NULL */
-       UInt64 *rsrcLogicalSize)        /* can be NULL */
-{
-       OSErr                           result;
-       FSCatalogInfoBitmap whichInfo;
-       FSCatalogInfo           catalogInfo;
-       
-       whichInfo = kFSCatInfoNodeFlags;
-       if ( NULL != dataLogicalSize )
-       {
-               /* get data fork size */
-               whichInfo |= kFSCatInfoDataSizes;
-       }
-       if ( NULL != rsrcLogicalSize )
-       {
-               /* get resource fork size */
-               whichInfo |= kFSCatInfoRsrcSizes;
-       }
-
-       /* get nodeFlags and catalog info */
-       result = FSGetCatalogInfo(ref, whichInfo, &catalogInfo, NULL, NULL,NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* make sure FSRef was to a file */
-       require_action(0 == (catalogInfo.nodeFlags & kFSNodeIsDirectoryMask), FSRefNotFile, result = notAFileErr);
-       
-       if ( NULL != dataLogicalSize )
-       {
-               /* return data fork size */
-               *dataLogicalSize = catalogInfo.dataLogicalSize;
-       }
-       if ( NULL != rsrcLogicalSize )
-       {
-               /* return resource fork size */
-               *rsrcLogicalSize = catalogInfo.rsrcLogicalSize;
-       }
-       
-FSRefNotFile:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetTotalForkSizes(
-       const FSRef *ref,
-       UInt64 *totalLogicalSize,       /* can be NULL */
-       UInt64 *totalPhysicalSize,      /* can be NULL */
-       ItemCount *forkCount)           /* can be NULL */
-{
-       OSErr                   result;
-       CatPositionRec  forkIterator;
-       SInt64                  forkSize;
-       SInt64                  *forkSizePtr;
-       UInt64                  forkPhysicalSize;
-       UInt64                  *forkPhysicalSizePtr;
-       
-       /* Determine if forkSize needed */
-       if ( NULL != totalLogicalSize)
-       {
-               *totalLogicalSize = 0;
-               forkSizePtr = &forkSize;
-       }
-       else
-       {
-               forkSizePtr = NULL;
-       }
-       
-       /* Determine if forkPhysicalSize is needed */
-       if ( NULL != totalPhysicalSize )
-       {
-               *totalPhysicalSize = 0;
-               forkPhysicalSizePtr = &forkPhysicalSize;
-       }
-       else
-       {
-               forkPhysicalSizePtr = NULL;
-       }
-       
-       /* zero fork count if returning it */
-       if ( NULL != forkCount )
-       {
-               *forkCount = 0;
-       }
-       
-       /* Iterate through the forks to get the sizes */
-       forkIterator.initialize = 0;
-       do
-       {
-               result = FSIterateForks(ref, &forkIterator, NULL, forkSizePtr, forkPhysicalSizePtr);
-               if ( noErr == result )
-               {
-                       if ( NULL != totalLogicalSize )
-                       {
-                               *totalLogicalSize += forkSize;
-                       }
-                       
-                       if ( NULL != totalPhysicalSize )
-                       {
-                               *totalPhysicalSize += forkPhysicalSize;
-                       }
-                       
-                       if ( NULL != forkCount )
-                       {
-                               ++*forkCount;
-                       }
-               }
-       } while ( noErr == result );
-       
-       /* any error result other than errFSNoMoreItems is serious */
-       require(errFSNoMoreItems == result, FSIterateForks);
-       
-       /* Normal exit */
-       result = noErr;
-
-FSIterateForks:
-       
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSBumpDate(
-       const FSRef *ref)
-{
-       OSStatus                result;
-       FSCatalogInfo   catalogInfo;
-       UTCDateTime             oldDateTime;
-#if !BuildingMoreFilesXForMacOS9
-       FSRef                   parentRef;
-       Boolean                 notifyParent;
-#endif
-
-#if !BuildingMoreFilesXForMacOS9
-       /* Get the node flags, the content modification date and time, and the parent ref */
-       result = FSGetCatalogInfo(ref, kFSCatInfoNodeFlags + kFSCatInfoContentMod, &catalogInfo, NULL, NULL, &parentRef);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* Notify the parent if this is a file */
-       notifyParent = (0 == (catalogInfo.nodeFlags & kFSNodeIsDirectoryMask));
-#else
-       /* Get the content modification date and time */
-       result = FSGetCatalogInfo(ref, kFSCatInfoContentMod, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-#endif
-       
-       oldDateTime = catalogInfo.contentModDate;
-
-       /* Get the current date and time */
-       result = GetUTCDateTime(&catalogInfo.contentModDate, kUTCDefaultOptions);
-       require_noerr(result, GetUTCDateTime);
-       
-       /* if the old date and time is the the same as the current, bump the seconds by one */
-       if ( (catalogInfo.contentModDate.fraction == oldDateTime.fraction) &&
-                (catalogInfo.contentModDate.lowSeconds == oldDateTime.lowSeconds) &&
-                (catalogInfo.contentModDate.highSeconds == oldDateTime.highSeconds) )
-       {
-               ++catalogInfo.contentModDate.lowSeconds;
-               if ( 0 == catalogInfo.contentModDate.lowSeconds )
-               {
-                       ++catalogInfo.contentModDate.highSeconds;
-               }
-       }
-       
-       /* Bump the content modification date and time */
-       result = FSSetCatalogInfo(ref, kFSCatInfoContentMod, &catalogInfo);
-       require_noerr(result, FSSetCatalogInfo);
-
-#if !BuildingMoreFilesXForMacOS9
-       /*
-        * The problem with FNNotify is that it is not available under Mac OS 9
-        * and there's no way to test for that except for looking for the symbol
-        * or something. So, I'll just conditionalize this for those who care
-        * to send a notification.
-        */
-       
-       /* Send a notification for the parent of the file, or for the directory */
-       result = FNNotify(notifyParent ? &parentRef : ref, kFNDirectoryModifiedMessage, kNilOptions);
-       require_noerr(result, FNNotify);
-#endif
-
-       /* ignore errors from FSSetCatalogInfo (volume might be write protected) and FNNotify */
-FNNotify:
-FSSetCatalogInfo:
-       
-       return ( noErr );
-       
-       /**********************/
-       
-GetUTCDateTime:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetFinderInfo(
-       const FSRef *ref,
-       FinderInfo *info,                                       /* can be NULL */
-       ExtendedFinderInfo *extendedInfo,       /* can be NULL */
-       Boolean *isDirectory)                           /* can be NULL */
-{
-       OSErr                           result;
-       FSCatalogInfo           catalogInfo;
-       FSCatalogInfoBitmap whichInfo;
-       
-       /* determine what catalog information is really needed */
-       whichInfo = kFSCatInfoNone;
-       
-       if ( NULL != info )
-       {
-               /* get FinderInfo */
-               whichInfo |= kFSCatInfoFinderInfo;
-       }
-       
-       if ( NULL != extendedInfo )
-       {
-               /* get ExtendedFinderInfo */
-               whichInfo |= kFSCatInfoFinderXInfo;
-       }
-       
-       if ( NULL != isDirectory )
-       {
-               whichInfo |= kFSCatInfoNodeFlags;
-       }
-       
-       result = FSGetCatalogInfo(ref, whichInfo, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* return FinderInfo if requested */
-       if ( NULL != info )
-       {
-               BlockMoveData(catalogInfo.finderInfo, info, sizeof(FinderInfo));
-       }
-       
-       /* return ExtendedFinderInfo if requested */
-       if ( NULL != extendedInfo)
-       {
-               BlockMoveData(catalogInfo.extFinderInfo, extendedInfo, sizeof(ExtendedFinderInfo));
-       }
-       
-       /* set isDirectory Boolean if requested */
-       if ( NULL != isDirectory)
-       {
-               *isDirectory = (0 != (kFSNodeIsDirectoryMask & catalogInfo.nodeFlags));
-       }
-       
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetFinderInfo(
-       const FSRef *ref,
-       const FinderInfo *info,
-       const ExtendedFinderInfo *extendedInfo)
-{
-       OSErr                           result;
-       FSCatalogInfo           catalogInfo;
-       FSCatalogInfoBitmap whichInfo;
-       
-       /* determine what catalog information will be set */
-       whichInfo = kFSCatInfoNone; /* start with none */
-       if ( NULL != info )
-       {
-               /* set FinderInfo */
-               whichInfo |= kFSCatInfoFinderInfo;
-               BlockMoveData(info, catalogInfo.finderInfo, sizeof(FinderInfo));
-       }
-       if ( NULL != extendedInfo )
-       {
-               /* set ExtendedFinderInfo */
-               whichInfo |= kFSCatInfoFinderXInfo;
-               BlockMoveData(extendedInfo, catalogInfo.extFinderInfo, sizeof(ExtendedFinderInfo));
-       }
-       
-       result = FSSetCatalogInfo(ref, whichInfo, &catalogInfo);
-       require_noerr(result, FSGetCatalogInfo);
-       
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSChangeCreatorType(
-       const FSRef *ref,
-       OSType fileCreator,
-       OSType fileType)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       FSRef                   parentRef;
-       
-       /* get nodeFlags, finder info, and parent FSRef */
-       result = FSGetCatalogInfo(ref, kFSCatInfoNodeFlags + kFSCatInfoFinderInfo, &catalogInfo , NULL, NULL, &parentRef);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* make sure FSRef was to a file */
-       require_action(0 == (catalogInfo.nodeFlags & kFSNodeIsDirectoryMask), FSRefNotFile, result = notAFileErr);
-       
-       /* If fileType not 0x00000000, change fileType */
-       if ( fileType != (OSType)0x00000000 )
-       {
-               ((FileInfo *)&catalogInfo.finderInfo)->fileType = fileType;
-       }
-       
-       /* If creator not 0x00000000, change creator */
-       if ( fileCreator != (OSType)0x00000000 )
-       {
-               ((FileInfo *)&catalogInfo.finderInfo)->fileCreator = fileCreator;
-       }
-       
-       /* now, save the new information back to disk */
-       result = FSSetCatalogInfo(ref, kFSCatInfoFinderInfo, &catalogInfo);
-       require_noerr(result, FSSetCatalogInfo);
-       
-       /* and attempt to bump the parent directory's mod date to wake up */
-       /* the Finder to the change we just made (ignore errors from this) */
-       verify_noerr(FSBumpDate(&parentRef));
-       
-FSSetCatalogInfo:
-FSRefNotFile:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSChangeFinderFlags(
-       const FSRef *ref,
-       Boolean setBits,
-       UInt16 flagBits)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       FSRef                   parentRef;
-       
-       /* get the current finderInfo */
-       result = FSGetCatalogInfo(ref, kFSCatInfoFinderInfo, &catalogInfo, NULL, NULL, &parentRef);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* set or clear the appropriate bits in the finderInfo.finderFlags */
-       if ( setBits )
-       {
-               /* OR in the bits */
-               ((FileInfo *)&catalogInfo.finderInfo)->finderFlags |= flagBits;
-       }
-       else
-       {
-               /* AND out the bits */
-               ((FileInfo *)&catalogInfo.finderInfo)->finderFlags &= ~flagBits;
-       }
-       
-       /* save the modified finderInfo */
-       result = FSSetCatalogInfo(ref, kFSCatInfoFinderInfo, &catalogInfo);
-       require_noerr(result, FSSetCatalogInfo);
-       
-       /* and attempt to bump the parent directory's mod date to wake up the Finder */
-       /* to the change we just made (ignore errors from this) */
-       verify_noerr(FSBumpDate(&parentRef));
-       
-FSSetCatalogInfo:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetInvisible(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, true, kIsInvisible) );
-}
-
-OSErr
-FSClearInvisible(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, false, kIsInvisible) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetNameLocked(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, true, kNameLocked) );
-}
-
-OSErr
-FSClearNameLocked(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, false, kNameLocked) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetIsStationery(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, true, kIsStationery) );
-}
-
-OSErr
-FSClearIsStationery(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, false, kIsStationery) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetHasCustomIcon(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, true, kHasCustomIcon) );
-}
-
-OSErr
-FSClearHasCustomIcon(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, false, kHasCustomIcon) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSClearHasBeenInited(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, false, kHasBeenInited) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSCopyFileMgrAttributes(
-       const FSRef *sourceRef,
-       const FSRef *destinationRef,
-       Boolean copyLockBit)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       
-       /* get the source information */
-       result = FSGetCatalogInfo(sourceRef, kFSCatInfoSettableInfo, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* don't copy the hasBeenInited bit; clear it */
-       ((FileInfo *)&catalogInfo.finderInfo)->finderFlags &= ~kHasBeenInited;
-       
-       /* should the locked bit be copied? */
-       if ( !copyLockBit )
-       {
-               /* no, make sure the locked bit is clear */
-               catalogInfo.nodeFlags &= ~kFSNodeLockedMask;
-       }
-               
-       /* set the destination information */
-       result = FSSetCatalogInfo(destinationRef, kFSCatInfoSettableInfo, &catalogInfo);
-       require_noerr(result, FSSetCatalogInfo);
-       
-FSSetCatalogInfo:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSMoveRenameObjectUnicode(
-       const FSRef *ref,
-       const FSRef *destDirectory,
-       UniCharCount nameLength,
-       const UniChar *name,                    /* can be NULL (no rename during move) */
-       TextEncoding textEncodingHint,
-       FSRef *newRef)                                  /* if function fails along the way, newRef is final location of file */
-{
-       OSErr                   result;
-       FSVolumeRefNum  vRefNum;
-       FSCatalogInfo   catalogInfo;
-       FSRef                   originalDirectory;
-       TextEncoding    originalTextEncodingHint;
-       HFSUniStr255    originalName;
-       HFSUniStr255    uniqueName;             /* unique name given to object while moving it to destination */
-       long                    theSeed;                /* the seed for generating unique names */
-       
-       /* check parameters */
-       require_action(NULL != newRef, BadParameter, result = paramErr);
-       
-       /* newRef = input to start with */
-       BlockMoveData(ref, newRef, sizeof(FSRef));
-       
-       /* get destDirectory's vRefNum */
-       result = FSGetCatalogInfo(destDirectory, kFSCatInfoVolume, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, DestinationBad);
-       
-       /* save vRefNum */
-       vRefNum = catalogInfo.volume;
-       
-       /* get ref's vRefNum, TextEncoding, name and parent directory*/
-       result = FSGetCatalogInfo(ref, kFSCatInfoTextEncoding + kFSCatInfoVolume, &catalogInfo, &originalName, NULL, &originalDirectory);
-       require_noerr(result, SourceBad);
-       
-       /* save TextEncoding */
-       originalTextEncodingHint = catalogInfo.textEncodingHint;
-       
-       /* make sure ref and destDirectory are on same volume */
-       require_action(vRefNum == catalogInfo.volume, NotSameVolume, result = diffVolErr);
-       
-       /* Skip a few steps if we're not renaming */
-       if ( NULL != name )
-       {
-               /* generate a name that is unique in both directories */
-               theSeed = 0x4a696d4c;   /* a fine unlikely filename */
-               
-               result = GenerateUniqueHFSUniStr(&theSeed, &originalDirectory, destDirectory, &uniqueName);
-               require_noerr(result, GenerateUniqueHFSUniStrFailed);
-               
-               /* Rename the object to uniqueName */
-               result = FSRenameUnicode(ref, uniqueName.length, uniqueName.unicode, kTextEncodingUnknown, newRef);
-               require_noerr(result, FSRenameUnicodeBeforeMoveFailed);
-               
-               /* Move object to its new home */
-               result = FSMoveObject(newRef, destDirectory, newRef);
-               require_noerr(result, FSMoveObjectAfterRenameFailed);
-               
-               /* Rename the object to new name */
-               result = FSRenameUnicode(ref, nameLength, name, textEncodingHint, newRef);
-               require_noerr(result, FSRenameUnicodeAfterMoveFailed);
-       }
-       else
-       {
-               /* Move object to its new home */
-               result = FSMoveObject(newRef, destDirectory, newRef);
-               require_noerr(result, FSMoveObjectNoRenameFailed);
-       }
-       
-       return ( result );
-       
-       /*************/
-
-/*
- * failure handling code when renaming
- */
-
-FSRenameUnicodeAfterMoveFailed:
-
-       /* Error handling: move object back to original location - ignore errors */
-       verify_noerr(FSMoveObject(newRef, &originalDirectory, newRef));
-       
-FSMoveObjectAfterRenameFailed:
-
-       /* Error handling: rename object back to original name - ignore errors */
-       verify_noerr(FSRenameUnicode(newRef, originalName.length, originalName.unicode, originalTextEncodingHint, newRef));
-       
-FSRenameUnicodeBeforeMoveFailed:
-GenerateUniqueHFSUniStrFailed:
-
-/*
- * failure handling code for renaming or not
- */
-FSMoveObjectNoRenameFailed:
-NotSameVolume:
-SourceBad:
-DestinationBad:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-/*
-       The FSDeleteContainerLevel function deletes the contents of a container
-       directory. All files and subdirectories in the specified container are
-       deleted. If a locked file or directory is encountered, it is unlocked
-       and then deleted. If any unexpected errors are encountered,
-       FSDeleteContainerLevel quits and returns to the caller.
-       
-       container                       --> FSRef to a directory.
-       theGlobals                      --> A pointer to a FSDeleteContainerGlobals struct
-                                                       which contains the variables that do not need to
-                                                       be allocated each time FSDeleteContainerLevel
-                                                       recurses. That lets FSDeleteContainerLevel use
-                                                       less stack space per recursion level.
-*/
-
-static
-void
-FSDeleteContainerLevel(
-       const FSRef *container,
-       FSDeleteContainerGlobals *theGlobals)
-{
-       /* level locals */
-       FSIterator                                      iterator;
-       FSRef                                           itemToDelete;
-       UInt16                                          nodeFlags;
-       
-       /* Open FSIterator for flat access and give delete optimization hint */
-       theGlobals->result = FSOpenIterator(container, kFSIterateFlat + kFSIterateDelete, &iterator);
-       require_noerr(theGlobals->result, FSOpenIterator);
-       
-       /* delete the contents of the directory */
-       do
-       {
-               /* get 1 item to delete */
-               theGlobals->result = FSGetCatalogInfoBulk(iterator, 1, &theGlobals->actualObjects,
-                                                               NULL, kFSCatInfoNodeFlags, &theGlobals->catalogInfo,
-                                                               &itemToDelete, NULL, NULL);
-               if ( (noErr == theGlobals->result) && (1 == theGlobals->actualObjects) )
-               {
-                       /* save node flags in local in case we have to recurse */
-                       nodeFlags = theGlobals->catalogInfo.nodeFlags;
-                       
-                       /* is it a file or directory? */
-                       if ( 0 != (nodeFlags & kFSNodeIsDirectoryMask) )
-                       {
-                               /* it's a directory -- delete its contents before attempting to delete it */
-                               FSDeleteContainerLevel(&itemToDelete, theGlobals);
-                       }
-                       /* are we still OK to delete? */
-                       if ( noErr == theGlobals->result )
-                       {
-                               /* is item locked? */
-                               if ( 0 != (nodeFlags & kFSNodeLockedMask) )
-                               {
-                                       /* then attempt to unlock it (ignore result since FSDeleteObject will set it correctly) */
-                                       theGlobals->catalogInfo.nodeFlags = nodeFlags & ~kFSNodeLockedMask;
-                                       (void) FSSetCatalogInfo(&itemToDelete, kFSCatInfoNodeFlags, &theGlobals->catalogInfo);
-                               }
-                               /* delete the item */
-                               theGlobals->result = FSDeleteObject(&itemToDelete);
-                       }
-               }
-       } while ( noErr == theGlobals->result );
-       
-       /* we found the end of the items normally, so return noErr */
-       if ( errFSNoMoreItems == theGlobals->result )
-       {
-               theGlobals->result = noErr;
-       }
-       
-       /* close the FSIterator (closing an open iterator should never fail) */
-       verify_noerr(FSCloseIterator(iterator));
-
-FSOpenIterator:
-
-       return;
-}
-
-/*****************************************************************************/
-
-OSErr
-FSDeleteContainerContents(
-       const FSRef *container)
-{
-       FSDeleteContainerGlobals        theGlobals;
-       
-       /* delete container's contents */
-       FSDeleteContainerLevel(container, &theGlobals);
-       
-       return ( theGlobals.result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSDeleteContainer(
-       const FSRef *container)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       
-       /* get nodeFlags for container */
-       result = FSGetCatalogInfo(container, kFSCatInfoNodeFlags, &catalogInfo, NULL, NULL,NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* make sure container is a directory */
-       require_action(0 != (catalogInfo.nodeFlags & kFSNodeIsDirectoryMask), ContainerNotDirectory, result = dirNFErr);
-       
-       /* delete container's contents */
-       result = FSDeleteContainerContents(container);
-       require_noerr(result, FSDeleteContainerContents);
-       
-       /* is container locked? */
-       if ( 0 != (catalogInfo.nodeFlags & kFSNodeLockedMask) )
-       {
-               /* then attempt to unlock container (ignore result since FSDeleteObject will set it correctly) */
-               catalogInfo.nodeFlags &= ~kFSNodeLockedMask;
-               (void) FSSetCatalogInfo(container, kFSCatInfoNodeFlags, &catalogInfo);
-       }
-       
-       /* delete the container */
-       result = FSDeleteObject(container);
-       
-FSDeleteContainerContents:
-ContainerNotDirectory:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-/*
-       The FSIterateContainerLevel function iterates the contents of a container
-       directory and calls a IterateContainerFilterProc function once for each
-       file and directory found.
-       
-       theGlobals                      --> A pointer to a FSIterateContainerGlobals struct
-                                                       which contains the variables needed globally by
-                                                       all recusion levels of FSIterateContainerLevel.
-                                                       That makes FSIterateContainer thread safe since
-                                                       each call to it uses its own global world.
-                                                       It also contains the variables that do not need
-                                                       to be allocated each time FSIterateContainerLevel
-                                                       recurses. That lets FSIterateContainerLevel use
-                                                       less stack space per recursion level.
-*/
-
-static
-void
-FSIterateContainerLevel(
-       FSIterateContainerGlobals *theGlobals)
-{      
-       FSIterator      iterator;
-       
-       /* If maxLevels is zero, we aren't checking levels */
-       /* If currentLevel < maxLevels, look at this level */
-       if ( (theGlobals->maxLevels == 0) ||
-                (theGlobals->currentLevel < theGlobals->maxLevels) )
-       {
-               /* Open FSIterator for flat access to theGlobals->ref */
-               theGlobals->result = FSOpenIterator(&theGlobals->ref, kFSIterateFlat, &iterator);
-               require_noerr(theGlobals->result, FSOpenIterator);
-               
-               ++theGlobals->currentLevel; /* Go to next level */
-               
-               /* Call FSGetCatalogInfoBulk in loop to get all items in the container */
-               do
-               {
-                       theGlobals->result = FSGetCatalogInfoBulk(iterator, 1, &theGlobals->actualObjects,
-                               &theGlobals->containerChanged, theGlobals->whichInfo, &theGlobals->catalogInfo,
-                               &theGlobals->ref, theGlobals->specPtr, theGlobals->namePtr);
-                       if ( (noErr == theGlobals->result || errFSNoMoreItems == theGlobals->result) &&
-                               (0 != theGlobals->actualObjects) )
-                       {
-                               /* Call the IterateFilterProc */
-                               theGlobals->quitFlag = CallIterateContainerFilterProc(theGlobals->iterateFilter,
-                                       theGlobals->containerChanged, theGlobals->currentLevel,
-                                       &theGlobals->catalogInfo, &theGlobals->ref,
-                                       theGlobals->specPtr, theGlobals->namePtr, theGlobals->yourDataPtr);
-                               /* Is it a directory? */
-                               if ( 0 != (theGlobals->catalogInfo.nodeFlags & kFSNodeIsDirectoryMask) )
-                               {
-                                       /* Keep going? */
-                                       if ( !theGlobals->quitFlag )
-                                       {
-                                               /* Dive again if the IterateFilterProc didn't say "quit" */
-                                               FSIterateContainerLevel(theGlobals);
-                                       }
-                               }
-                       }
-                       /* time to fall back a level? */
-               } while ( (noErr == theGlobals->result) && (!theGlobals->quitFlag) );
-               
-               /* errFSNoMoreItems is OK - it only means we hit the end of this level */
-               /* afpAccessDenied is OK, too - it only means we cannot see inside a directory */
-               if ( (errFSNoMoreItems == theGlobals->result) ||
-                        (afpAccessDenied == theGlobals->result) )
-               {
-                       theGlobals->result = noErr;
-               }
-               
-               --theGlobals->currentLevel; /* Return to previous level as we leave */
-               
-               /* Close the FSIterator (closing an open iterator should never fail) */
-               verify_noerr(FSCloseIterator(iterator));
-       }
-       
-FSOpenIterator:
-
-       return;
-}
-
-/*****************************************************************************/
-
-OSErr
-FSIterateContainer(
-       const FSRef *container,
-       ItemCount maxLevels,
-       FSCatalogInfoBitmap whichInfo,
-       Boolean wantFSSpec,
-       Boolean wantName,
-       IterateContainerFilterProcPtr iterateFilter,
-       void *yourDataPtr)
-{
-       OSErr                                           result;
-       FSIterateContainerGlobals       theGlobals;
-       
-       /* make sure there is an iterateFilter */
-       require_action(iterateFilter != NULL, NoIterateFilter, result = paramErr);
-       
-       /*
-        * set up the globals we need to access from the recursive routine
-        */
-       theGlobals.iterateFilter = iterateFilter;
-       /* we need the node flags no matter what was requested so we can detect files vs. directories */
-       theGlobals.whichInfo = whichInfo | kFSCatInfoNodeFlags;
-       /* start with input container -- the first OpenIterator will ensure it is a directory */
-       theGlobals.ref = *container;
-       if ( wantFSSpec )
-       {
-               theGlobals.specPtr = &theGlobals.spec;
-       }
-       else
-       {
-               theGlobals.specPtr = NULL;
-       }
-       if ( wantName )
-       {
-               theGlobals.namePtr = &theGlobals.name;
-       }
-       else
-       {
-               theGlobals.namePtr = NULL;
-       }
-       theGlobals.yourDataPtr = yourDataPtr;
-       theGlobals.maxLevels = maxLevels;
-       theGlobals.currentLevel = 0;
-       theGlobals.quitFlag = false;
-       theGlobals.containerChanged = false;
-       theGlobals.result = noErr;
-       theGlobals.actualObjects = 0;
-       
-       /* here we go into recursion land... */
-       FSIterateContainerLevel(&theGlobals);
-       result = theGlobals.result;
-       require_noerr(result, FSIterateContainerLevel);
-       
-FSIterateContainerLevel:
-NoIterateFilter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetDirectoryItems(
-       const FSRef *container,
-       FSRef ***refsHandle,    /* pointer to handle of FSRefs */
-       ItemCount *numRefs,
-       Boolean *containerChanged)
-{
-       /* Grab items 10 at a time. */
-       enum { kMaxItemsPerBulkCall = 10 };
-       
-       OSErr           result;
-       OSErr           memResult;
-       FSIterator      iterator;
-       FSRef           refs[kMaxItemsPerBulkCall];
-       ItemCount       actualObjects;
-       Boolean         changed;
-       
-       /* check parameters */
-       require_action((NULL != refsHandle) && (NULL != numRefs) && (NULL != containerChanged),
-               BadParameter, result = paramErr);
-       
-       *numRefs = 0;
-       *containerChanged = false;
-       *refsHandle = (FSRef **)NewHandle(0);
-       require_action(NULL != *refsHandle, NewHandle, result = memFullErr);
-       
-       /* open an FSIterator */
-       result = FSOpenIterator(container, kFSIterateFlat, &iterator);
-       require_noerr(result, FSOpenIterator);
-       
-       /* Call FSGetCatalogInfoBulk in loop to get all items in the container */
-       do
-       {
-               result = FSGetCatalogInfoBulk(iterator, kMaxItemsPerBulkCall, &actualObjects,
-                                       &changed, kFSCatInfoNone,  NULL,  refs, NULL, NULL);
-               
-               /* if the container changed, set containerChanged for output, but keep going */
-               if ( changed )
-               {
-                       *containerChanged = changed;
-               }
-               
-               /* any result other than noErr and errFSNoMoreItems is serious */
-               require((noErr == result) || (errFSNoMoreItems == result), FSGetCatalogInfoBulk);
-               
-               /* add objects to output array and count */
-               if ( 0 != actualObjects )
-               {
-                       /* concatenate the FSRefs to the end of the      handle */
-                       PtrAndHand(refs, (Handle)*refsHandle, actualObjects * sizeof(FSRef));
-                       memResult = MemError();
-                       require_noerr_action(memResult, MemoryAllocationFailed, result = memResult);
-                       
-                       *numRefs += actualObjects;
-               }
-       } while ( noErr == result );
-       
-       verify_noerr(FSCloseIterator(iterator)); /* closing an open iterator should never fail, but... */
-       
-       return ( noErr );
-       
-       /**********************/
-       
-MemoryAllocationFailed:
-FSGetCatalogInfoBulk:
-
-       /* close the iterator */
-       verify_noerr(FSCloseIterator(iterator));
-
-FSOpenIterator:
-       /* dispose of handle if already allocated and clear the outputs */
-       if ( NULL != *refsHandle )
-       {
-               DisposeHandle((Handle)*refsHandle);
-               *refsHandle = NULL;
-       }
-       *numRefs = 0;
-       
-NewHandle:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-/*
-       The GenerateUniqueName function generates a HFSUniStr255 name that is
-       unique in both dir1 and dir2.
-       
-       startSeed                       -->     A pointer to a long which is used to generate the
-                                                       unique name.
-                                               <--     It is modified on output to a value which should
-                                                       be used to generate the next unique name.
-       dir1                            -->     The first directory.
-       dir2                            -->     The second directory.
-       uniqueName                      <--     A pointer to a HFSUniStr255 where the unique name
-                                                       is to be returned.
-*/
-
-static
-OSErr
-GenerateUniqueHFSUniStr(
-       long *startSeed,
-       const FSRef *dir1,
-       const FSRef *dir2,
-       HFSUniStr255 *uniqueName)
-{
-       OSErr                   result;
-       long                    i;
-       FSRefParam              pb;
-       FSRef                   newRef;
-       unsigned char   hexStr[17] = "0123456789ABCDEF";
-       
-       /* set up the parameter block */
-       pb.name = uniqueName->unicode;
-       pb.nameLength = 8;      /* always 8 characters */
-       pb.textEncodingHint = kTextEncodingUnknown;
-       pb.newRef = &newRef;
-
-       /* loop until we get fnfErr with a filename in both directories */
-       result = noErr;
-       while ( fnfErr != result )
-       {
-               /* convert startSeed to 8 character Unicode string */
-               uniqueName->length = 8;
-               for ( i = 0; i < 8; ++i )
-               {
-                       uniqueName->unicode[i] = hexStr[((*startSeed >> ((7-i)*4)) & 0xf)];
-               }
-               
-               /* try in dir1 */
-               pb.ref = dir1;
-               result = PBMakeFSRefUnicodeSync(&pb);
-               if ( fnfErr == result )
-               {
-                       /* try in dir2 */
-                       pb.ref = dir2;
-                       result = PBMakeFSRefUnicodeSync(&pb);
-                       if ( fnfErr != result )
-                       {
-                               /* exit if anything other than noErr or fnfErr */
-                               require_noerr(result, Dir2PBMakeFSRefUnicodeSyncFailed);
-                       }
-               }
-               else
-               {
-                       /* exit if anything other than noErr or fnfErr */
-                       require_noerr(result, Dir1PBMakeFSRefUnicodeSyncFailed);
-               }
-               
-               /* increment seed for next pass through loop, */
-               /* or for next call to GenerateUniqueHFSUniStr */
-               ++(*startSeed);
-       }
-       
-       /* we have a unique file name which doesn't exist in dir1 or dir2 */
-       result = noErr;
-       
-Dir2PBMakeFSRefUnicodeSyncFailed:
-Dir1PBMakeFSRefUnicodeSyncFailed:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSExchangeObjectsCompat(
-       const FSRef *sourceRef,
-       const FSRef *destRef,
-       FSRef *newSourceRef,
-       FSRef *newDestRef)
-{
-       enum
-       {
-               /* get all settable info except for mod dates, plus the volume refNum and parent directory ID */
-               kGetCatInformationMask = (kFSCatInfoSettableInfo |
-                                                                 kFSCatInfoVolume |
-                                                                 kFSCatInfoParentDirID) &
-                                                                ~(kFSCatInfoContentMod | kFSCatInfoAttrMod),
-               /* set everything possible except for mod dates */
-               kSetCatinformationMask = kFSCatInfoSettableInfo &
-                                                                ~(kFSCatInfoContentMod | kFSCatInfoAttrMod)
-       };
-       
-       OSErr                                   result;
-       GetVolParmsInfoBuffer   volParmsInfo;
-       UInt32                                  infoSize;
-       FSCatalogInfo                   sourceCatalogInfo;      /* source file's catalog information */
-       FSCatalogInfo                   destCatalogInfo;        /* destination file's catalog information */
-       HFSUniStr255                    sourceName;                     /* source file's Unicode name */
-       HFSUniStr255                    destName;                       /* destination file's Unicode name */
-       FSRef                                   sourceCurrentRef;       /* FSRef to current location of source file throughout this function */
-       FSRef                                   destCurrentRef;         /* FSRef to current location of destination file throughout this function */
-       FSRef                                   sourceParentRef;        /* FSRef to parent directory of source file */
-       FSRef                                   destParentRef;          /* FSRef to parent directory of destination file */
-       HFSUniStr255                    sourceUniqueName;       /* unique name given to source file while exchanging it with destination */
-       HFSUniStr255                    destUniqueName;         /* unique name given to destination file while exchanging it with source */
-       long                                    theSeed;                        /* the seed for generating unique names */
-       Boolean                                 sameParentDirs;         /* true if source and destinatin parent directory is the same */
-       
-       /* check parameters */
-       require_action((NULL != newSourceRef) && (NULL != newDestRef), BadParameter, result = paramErr);
-       
-       /* output refs and current refs = input refs to start with */
-       BlockMoveData(sourceRef, newSourceRef, sizeof(FSRef));
-       BlockMoveData(sourceRef, &sourceCurrentRef, sizeof(FSRef));
-       
-       BlockMoveData(destRef, newDestRef, sizeof(FSRef));
-       BlockMoveData(destRef, &destCurrentRef, sizeof(FSRef));
-
-       /* get source volume's vRefNum */
-       result = FSGetCatalogInfo(&sourceCurrentRef, kFSCatInfoVolume, &sourceCatalogInfo, NULL, NULL, NULL);
-       require_noerr(result, DetermineSourceVRefNumFailed);
-       
-       /* see if that volume supports FSExchangeObjects */
-       result = FSGetVolParms(sourceCatalogInfo.volume, sizeof(GetVolParmsInfoBuffer),
-               &volParmsInfo, &infoSize);
-       if ( (noErr == result) && VolSupportsFSExchangeObjects(&volParmsInfo) )
-       {
-               /* yes - use FSExchangeObjects */
-               result = FSExchangeObjects(sourceRef, destRef);
-       }
-       else
-       {
-               /* no - emulate FSExchangeObjects */
-               
-               /* Note: The compatibility case won't work for files with *Btree control blocks. */
-               /* Right now the only *Btree files are created by the system. */
-               
-               /* get all catalog information and Unicode names for each file */
-               result = FSGetCatalogInfo(&sourceCurrentRef, kGetCatInformationMask, &sourceCatalogInfo, &sourceName, NULL, &sourceParentRef);
-               require_noerr(result, SourceFSGetCatalogInfoFailed);
-               
-               result = FSGetCatalogInfo(&destCurrentRef, kGetCatInformationMask, &destCatalogInfo, &destName, NULL, &destParentRef);
-               require_noerr(result, DestFSGetCatalogInfoFailed);
-               
-               /* make sure source and destination are on same volume */
-               require_action(sourceCatalogInfo.volume == destCatalogInfo.volume, NotSameVolume, result = diffVolErr);
-               
-               /* make sure both files are *really* files */
-               require_action((0 == (sourceCatalogInfo.nodeFlags & kFSNodeIsDirectoryMask)) &&
-                                          (0 == (destCatalogInfo.nodeFlags & kFSNodeIsDirectoryMask)), NotAFile, result = notAFileErr);
-               
-               /* generate 2 names that are unique in both directories */
-               theSeed = 0x4a696d4c;   /* a fine unlikely filename */
-               
-               result = GenerateUniqueHFSUniStr(&theSeed, &sourceParentRef, &destParentRef, &sourceUniqueName);
-               require_noerr(result, GenerateUniqueHFSUniStr1Failed);
-               
-               result = GenerateUniqueHFSUniStr(&theSeed, &sourceParentRef, &destParentRef, &destUniqueName);
-               require_noerr(result, GenerateUniqueHFSUniStr2Failed);
-
-               /* rename sourceCurrentRef to sourceUniqueName */
-               result = FSRenameUnicode(&sourceCurrentRef, sourceUniqueName.length, sourceUniqueName.unicode, kTextEncodingUnknown, newSourceRef);
-               require_noerr(result, FSRenameUnicode1Failed);
-               BlockMoveData(newSourceRef, &sourceCurrentRef, sizeof(FSRef));
-               
-               /* rename destCurrentRef to destUniqueName */
-               result = FSRenameUnicode(&destCurrentRef, destUniqueName.length, destUniqueName.unicode, kTextEncodingUnknown, newDestRef);
-               require_noerr(result, FSRenameUnicode2Failed);
-               BlockMoveData(newDestRef, &destCurrentRef, sizeof(FSRef));
-               
-               /* are the source and destination parent directories the same? */
-               sameParentDirs = ( sourceCatalogInfo.parentDirID == destCatalogInfo.parentDirID );
-               if ( !sameParentDirs )
-               {
-                       /* move source file to dest parent directory */
-                       result = FSMoveObject(&sourceCurrentRef, &destParentRef, newSourceRef);
-                       require_noerr(result, FSMoveObject1Failed);
-                       BlockMoveData(newSourceRef, &sourceCurrentRef, sizeof(FSRef));
-                       
-                       /* move dest file to source parent directory */
-                       result = FSMoveObject(&destCurrentRef, &sourceParentRef, newDestRef);
-                       require_noerr(result, FSMoveObject2Failed);
-                       BlockMoveData(newDestRef, &destCurrentRef, sizeof(FSRef));
-               }
-               
-               /* At this point, the files are in their new locations (if they were moved). */
-               /* The source file is named sourceUniqueName and is in the directory referred to */
-               /* by destParentRef. The destination file is named destUniqueName and is in the */
-               /* directory referred to by sourceParentRef. */
-                               
-               /* give source file the dest file's catalog information except for mod dates */
-               result = FSSetCatalogInfo(&sourceCurrentRef, kSetCatinformationMask, &destCatalogInfo);
-               require_noerr(result, FSSetCatalogInfo1Failed);
-               
-               /* give dest file the source file's catalog information except for mod dates */
-               result = FSSetCatalogInfo(&destCurrentRef, kSetCatinformationMask, &sourceCatalogInfo);
-               require_noerr(result, FSSetCatalogInfo2Failed);
-               
-               /* rename source file with dest file's name */
-               result = FSRenameUnicode(&sourceCurrentRef, destName.length, destName.unicode, destCatalogInfo.textEncodingHint, newSourceRef);
-               require_noerr(result, FSRenameUnicode3Failed);
-               BlockMoveData(newSourceRef, &sourceCurrentRef, sizeof(FSRef));
-               
-               /* rename dest file with source file's name */
-               result = FSRenameUnicode(&destCurrentRef, sourceName.length, sourceName.unicode, sourceCatalogInfo.textEncodingHint, newDestRef);
-               require_noerr(result, FSRenameUnicode4Failed);
-               
-               /* we're done with no errors, so swap newSourceRef and newDestRef */
-               BlockMoveData(newDestRef, newSourceRef, sizeof(FSRef));
-               BlockMoveData(&sourceCurrentRef, newDestRef, sizeof(FSRef));
-       }
-       
-       return ( result );
-       
-       /**********************/
-
-/* If there are any failures while emulating FSExchangeObjects, attempt to reverse any steps */
-/* already taken. In any case, newSourceRef and newDestRef will refer to the files in whatever */
-/* state and location they ended up in so that both files can be found by the calling code. */
-       
-FSRenameUnicode4Failed:
-
-       /* attempt to rename source file to sourceUniqueName */
-       if ( noErr == FSRenameUnicode(&sourceCurrentRef, sourceUniqueName.length, sourceUniqueName.unicode, kTextEncodingUnknown, newSourceRef) )
-       {
-               BlockMoveData(newSourceRef, &sourceCurrentRef, sizeof(FSRef));
-       }
-
-FSRenameUnicode3Failed:
-
-       /* attempt to restore dest file's catalog information */
-       verify_noerr(FSSetCatalogInfo(&destCurrentRef, kFSCatInfoSettableInfo, &destCatalogInfo));
-
-FSSetCatalogInfo2Failed:
-
-       /* attempt to restore source file's catalog information */
-       verify_noerr(FSSetCatalogInfo(&sourceCurrentRef, kFSCatInfoSettableInfo, &sourceCatalogInfo));
-
-FSSetCatalogInfo1Failed:
-
-       if ( !sameParentDirs )
-       {
-               /* attempt to move dest file back to dest directory */
-               if ( noErr == FSMoveObject(&destCurrentRef, &destParentRef, newDestRef) )
-               {
-                       BlockMoveData(newDestRef, &destCurrentRef, sizeof(FSRef));
-               }
-       }
-
-FSMoveObject2Failed:
-
-       if ( !sameParentDirs )
-       {
-               /* attempt to move source file back to source directory */
-               if ( noErr == FSMoveObject(&sourceCurrentRef, &sourceParentRef, newSourceRef) )
-               {
-                       BlockMoveData(newSourceRef, &sourceCurrentRef, sizeof(FSRef));
-               }
-       }
-
-FSMoveObject1Failed:
-
-       /* attempt to rename dest file to original name */
-       verify_noerr(FSRenameUnicode(&destCurrentRef, destName.length, destName.unicode, destCatalogInfo.textEncodingHint, newDestRef));
-
-FSRenameUnicode2Failed:
-
-       /* attempt to rename source file to original name */
-       verify_noerr(FSRenameUnicode(&sourceCurrentRef, sourceName.length, sourceName.unicode, sourceCatalogInfo.textEncodingHint, newSourceRef));
-
-FSRenameUnicode1Failed:
-GenerateUniqueHFSUniStr2Failed:
-GenerateUniqueHFSUniStr1Failed:
-NotAFile:
-NotSameVolume:
-DestFSGetCatalogInfoFailed:
-SourceFSGetCatalogInfoFailed:
-DetermineSourceVRefNumFailed:  
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-#pragma mark ----- Shared Environment Routines -----
-
-/*****************************************************************************/
-
-OSErr
-FSLockRange(
-       SInt16 refNum,
-       SInt32 rangeLength,
-       SInt32 rangeStart)
-{
-       OSErr                   result;
-       ParamBlockRec   pb;
-
-       pb.ioParam.ioRefNum = refNum;
-       pb.ioParam.ioReqCount = rangeLength;
-       pb.ioParam.ioPosMode = fsFromStart;
-       pb.ioParam.ioPosOffset = rangeStart;
-       result = PBLockRangeSync(&pb);
-       require_noerr(result, PBLockRangeSync);
-       
-PBLockRangeSync:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSUnlockRange(
-       SInt16 refNum,
-       SInt32 rangeLength,
-       SInt32 rangeStart)
-{
-       OSErr                   result;
-       ParamBlockRec   pb;
-
-       pb.ioParam.ioRefNum = refNum;
-       pb.ioParam.ioReqCount = rangeLength;
-       pb.ioParam.ioPosMode = fsFromStart;
-       pb.ioParam.ioPosOffset = rangeStart;
-       result = PBUnlockRangeSync(&pb);
-       require_noerr(result, PBUnlockRangeSync);
-       
-PBUnlockRangeSync:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetDirAccess(
-       const FSRef *ref,
-       SInt32 *ownerID,                /* can be NULL */
-       SInt32 *groupID,                /* can be NULL */
-       SInt32 *accessRights)   /* can be NULL */
-{
-       OSErr                   result;
-       FSSpec                  spec;
-       HParamBlockRec  pb;
-       
-       /* get FSSpec from FSRef */
-       result = FSGetCatalogInfo(ref, kFSCatInfoNone, NULL, NULL, &spec, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* get directory access info for FSSpec */
-       pb.accessParam.ioNamePtr = (StringPtr)spec.name;
-       pb.accessParam.ioVRefNum = spec.vRefNum;
-       pb.fileParam.ioDirID = spec.parID;
-       result = PBHGetDirAccessSync(&pb);
-       require_noerr(result, PBHGetDirAccessSync);
-       
-       /* return the IDs and access rights */
-       if ( NULL != ownerID )
-       {
-               *ownerID = pb.accessParam.ioACOwnerID;
-       }
-       if ( NULL != groupID )
-       {
-               *groupID = pb.accessParam.ioACGroupID;
-       }
-       if ( NULL != accessRights )
-       {
-               *accessRights = pb.accessParam.ioACAccess;
-       }
-       
-PBHGetDirAccessSync:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetDirAccess(
-       const FSRef *ref,
-       SInt32 ownerID,
-       SInt32 groupID,
-       SInt32 accessRights)
-{
-       OSErr                   result;
-       FSSpec                  spec;
-       HParamBlockRec  pb;
-
-       enum
-       {
-               /* Just the bits that can be set */
-               kSetDirAccessSettableMask = (kioACAccessBlankAccessMask +
-                       kioACAccessEveryoneWriteMask + kioACAccessEveryoneReadMask + kioACAccessEveryoneSearchMask +
-                       kioACAccessGroupWriteMask + kioACAccessGroupReadMask + kioACAccessGroupSearchMask +
-                       kioACAccessOwnerWriteMask + kioACAccessOwnerReadMask + kioACAccessOwnerSearchMask)
-       };
-       
-       /* get FSSpec from FSRef */
-       result = FSGetCatalogInfo(ref, kFSCatInfoNone, NULL, NULL, &spec, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* set directory access info for FSSpec */
-       pb.accessParam.ioNamePtr = (StringPtr)spec.name;
-       pb.accessParam.ioVRefNum = spec.vRefNum;
-       pb.fileParam.ioDirID = spec.parID;
-       pb.accessParam.ioACOwnerID = ownerID;
-       pb.accessParam.ioACGroupID = groupID;
-       pb.accessParam.ioACAccess = accessRights & kSetDirAccessSettableMask;
-       result = PBHSetDirAccessSync(&pb);
-       require_noerr(result, PBHSetDirAccessSync);
-       
-PBHSetDirAccessSync:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetVolMountInfoSize(
-       FSVolumeRefNum volRefNum,
-       SInt16 *size)
-{
-       OSErr                   result;
-       ParamBlockRec   pb;
-
-       /* check parameters */
-       require_action(NULL != size, BadParameter, result = paramErr);
-       
-       pb.ioParam.ioNamePtr = NULL;
-       pb.ioParam.ioVRefNum = volRefNum;
-       pb.ioParam.ioBuffer = (Ptr)size;
-       result = PBGetVolMountInfoSize(&pb);
-       require_noerr(result, PBGetVolMountInfoSize);
-       
-PBGetVolMountInfoSize:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetVolMountInfo(
-       FSVolumeRefNum volRefNum,
-       void *volMountInfo)
-{
-       OSErr                   result;
-       ParamBlockRec   pb;
-
-       /* check parameters */
-       require_action(NULL != volMountInfo, BadParameter, result = paramErr);
-       
-       pb.ioParam.ioNamePtr = NULL;
-       pb.ioParam.ioVRefNum = volRefNum;
-       pb.ioParam.ioBuffer = (Ptr)volMountInfo;
-       result = PBGetVolMountInfo(&pb);
-       require_noerr(result, PBGetVolMountInfo);
-       
-PBGetVolMountInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSVolumeMount(
-       const void *volMountInfo,
-       FSVolumeRefNum *volRefNum)
-{
-       OSErr                   result;
-       ParamBlockRec   pb;
-
-       /* check parameters */
-       require_action(NULL != volRefNum, BadParameter, result = paramErr);
-       
-       pb.ioParam.ioBuffer = (Ptr)volMountInfo;
-       result = PBVolumeMount(&pb);
-       require_noerr(result, PBVolumeMount);
-       
-       /* return the volume reference number */
-       *volRefNum = pb.ioParam.ioVRefNum;
-
-PBVolumeMount:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSMapID(
-       FSVolumeRefNum volRefNum,
-       SInt32 ugID,
-       SInt16 objType,
-       Str31 name)
-{
-       OSErr                   result;
-       HParamBlockRec  pb;
-
-       /* check parameters */
-       require_action(NULL != name, BadParameter, result = paramErr);
-       
-       pb.objParam.ioNamePtr = NULL;
-       pb.objParam.ioVRefNum = volRefNum;
-       pb.objParam.ioObjType = objType;
-       pb.objParam.ioObjNamePtr = name;
-       pb.objParam.ioObjID = ugID;
-       result = PBHMapIDSync(&pb);
-       require_noerr(result, PBHMapIDSync);
-       
-PBHMapIDSync:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSMapName(
-       FSVolumeRefNum volRefNum,
-       ConstStr255Param name,
-       SInt16 objType,
-       SInt32 *ugID)
-{
-       OSErr                   result;
-       HParamBlockRec  pb;
-
-       /* check parameters */
-       require_action(NULL != ugID, BadParameter, result = paramErr);
-       
-       pb.objParam.ioNamePtr = NULL;
-       pb.objParam.ioVRefNum = volRefNum;
-       pb.objParam.ioObjType = objType;
-       pb.objParam.ioObjNamePtr = (StringPtr)name;
-       result = PBHMapNameSync(&pb);
-       require_noerr(result, PBHMapNameSync);
-       
-       /* return the user or group ID */
-       *ugID = pb.objParam.ioObjID;
-       
-PBHMapNameSync:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSCopyFile(
-       const FSRef *srcFileRef,
-       const FSRef *dstDirectoryRef,
-       UniCharCount nameLength,
-       const UniChar *copyName,        /* can be NULL (no rename during copy) */
-       TextEncoding textEncodingHint,
-       FSRef *newRef)                          /* can be NULL */
-{
-       OSErr                                   result;
-       FSSpec                                  srcFileSpec;
-       FSCatalogInfo                   catalogInfo;
-       HParamBlockRec                  pb;
-       Str31                                   hfsName;
-       GetVolParmsInfoBuffer   volParmsInfo;
-       UInt32                                  infoSize;
-       
-       /* get source FSSpec from source FSRef */
-       result = FSGetCatalogInfo(srcFileRef, kFSCatInfoNone, NULL, NULL, &srcFileSpec, NULL);
-       require_noerr(result, FSGetCatalogInfo_srcFileRef);
-       
-       /* Make sure the volume supports CopyFile */
-       result = FSGetVolParms(srcFileSpec.vRefNum, sizeof(GetVolParmsInfoBuffer),
-               &volParmsInfo, &infoSize);
-       require_action((noErr == result) && VolHasCopyFile(&volParmsInfo),
-               NoCopyFileSupport, result = paramErr);
-
-       /* get destination volume reference number and destination directory ID from destination FSRef */
-       result = FSGetCatalogInfo(dstDirectoryRef, kFSCatInfoVolume + kFSCatInfoNodeID,
-               &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo_dstDirectoryRef);
-       
-       /* tell the server to copy the object */
-       pb.copyParam.ioVRefNum = srcFileSpec.vRefNum;
-       pb.copyParam.ioDirID = srcFileSpec.parID;
-       pb.copyParam.ioNamePtr = (StringPtr)srcFileSpec.name;
-       pb.copyParam.ioDstVRefNum = catalogInfo.volume;
-       pb.copyParam.ioNewDirID = (long)catalogInfo.nodeID;
-       pb.copyParam.ioNewName = NULL;
-       if ( NULL != copyName )
-       {
-               result = UnicodeNameGetHFSName(nameLength, copyName, textEncodingHint, false, hfsName);
-               require_noerr(result, UnicodeNameGetHFSName);
-               
-               pb.copyParam.ioCopyName = hfsName;
-       }
-       else
-       {
-               pb.copyParam.ioCopyName = NULL;
-       }
-       result = PBHCopyFileSync(&pb);
-       require_noerr(result, PBHCopyFileSync);
-       
-       if ( NULL != newRef )
-       {
-               verify_noerr(FSMakeFSRef(pb.copyParam.ioDstVRefNum, pb.copyParam.ioNewDirID,
-                       pb.copyParam.ioCopyName, newRef));
-       }
-               
-PBHCopyFileSync:
-UnicodeNameGetHFSName:
-FSGetCatalogInfo_dstDirectoryRef:
-NoCopyFileSupport:
-FSGetCatalogInfo_srcFileRef:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSMoveRename(
-       const FSRef *srcFileRef,
-       const FSRef *dstDirectoryRef,
-       UniCharCount nameLength,
-       const UniChar *moveName,        /* can be NULL (no rename during move) */
-       TextEncoding textEncodingHint,
-       FSRef *newRef)                          /* can be NULL */
-{
-       OSErr                                   result;
-       FSSpec                                  srcFileSpec;
-       FSCatalogInfo                   catalogInfo;
-       HParamBlockRec                  pb;
-       Str31                                   hfsName;
-       GetVolParmsInfoBuffer   volParmsInfo;
-       UInt32                                  infoSize;
-       
-       /* get source FSSpec from source FSRef */
-       result = FSGetCatalogInfo(srcFileRef, kFSCatInfoNone, NULL, NULL, &srcFileSpec, NULL);
-       require_noerr(result, FSGetCatalogInfo_srcFileRef);
-       
-       /* Make sure the volume supports MoveRename */
-       result = FSGetVolParms(srcFileSpec.vRefNum, sizeof(GetVolParmsInfoBuffer),
-               &volParmsInfo, &infoSize);
-       require_action((noErr == result) && VolHasMoveRename(&volParmsInfo),
-               NoMoveRenameSupport, result = paramErr);
-
-       /* get destination volume reference number and destination directory ID from destination FSRef */
-       result = FSGetCatalogInfo(dstDirectoryRef, kFSCatInfoVolume + kFSCatInfoNodeID,
-               &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo_dstDirectoryRef);
-       
-       /* make sure the source and destination are on the same volume */
-       require_action(srcFileSpec.vRefNum == catalogInfo.volume, NotSameVolume, result = diffVolErr);
-       
-       /* tell the server to move and rename the object */
-       pb.copyParam.ioVRefNum = srcFileSpec.vRefNum;
-       pb.copyParam.ioDirID = srcFileSpec.parID;
-       pb.copyParam.ioNamePtr = (StringPtr)srcFileSpec.name;
-       pb.copyParam.ioNewDirID = (long)catalogInfo.nodeID;
-       pb.copyParam.ioNewName = NULL;
-       if ( NULL != moveName )
-       {
-               result = UnicodeNameGetHFSName(nameLength, moveName, textEncodingHint, false, hfsName);
-               require_noerr(result, UnicodeNameGetHFSName);
-               
-               pb.copyParam.ioCopyName = hfsName;
-       }
-       else
-       {
-               pb.copyParam.ioCopyName = NULL;
-       }
-       result = PBHMoveRenameSync(&pb);
-       require_noerr(result, PBHMoveRenameSync);
-       
-       if ( NULL != newRef )
-       {
-               verify_noerr(FSMakeFSRef(pb.copyParam.ioVRefNum, pb.copyParam.ioNewDirID,
-                       pb.copyParam.ioCopyName, newRef));
-       }
-       
-PBHMoveRenameSync:
-UnicodeNameGetHFSName:
-NotSameVolume:
-FSGetCatalogInfo_dstDirectoryRef:
-NoMoveRenameSupport:
-FSGetCatalogInfo_srcFileRef:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-#pragma mark ----- File ID Routines -----
-
-/*****************************************************************************/
-
-OSErr
-FSResolveFileIDRef(
-       FSVolumeRefNum volRefNum,
-       SInt32 fileID,
-       FSRef *ref)
-{
-       OSErr           result;
-       FIDParam        pb;
-       Str255          tempStr;
-       
-       /* check parameters */
-       require_action(NULL != ref, BadParameter, result = paramErr);
-       
-       /* resolve the file ID reference */
-       tempStr[0] = 0;
-       pb.ioNamePtr = tempStr;
-       pb.ioVRefNum = volRefNum;
-       pb.ioFileID = fileID;
-       result = PBResolveFileIDRefSync((HParmBlkPtr)&pb);
-       require_noerr(result, PBResolveFileIDRefSync);
-       
-       /* and then make an FSRef to the file */
-       result = FSMakeFSRef(volRefNum, pb.ioSrcDirID, tempStr, ref);
-       require_noerr(result, FSMakeFSRef);
-       
-FSMakeFSRef:
-PBResolveFileIDRefSync:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSCreateFileIDRef(
-       const FSRef *ref,
-       SInt32 *fileID)
-{
-       OSErr           result;
-       FSSpec          spec;
-       FIDParam        pb;
-       
-       /* check parameters */
-       require_action(NULL != fileID, BadParameter, result = paramErr);
-       
-       /* Get an FSSpec from the FSRef */
-       result = FSGetCatalogInfo(ref, kFSCatInfoNone, NULL, NULL, &spec, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* Create (or get) the file ID reference using the FSSpec */
-       pb.ioNamePtr = (StringPtr)spec.name;
-       pb.ioVRefNum = spec.vRefNum;
-       pb.ioSrcDirID = spec.parID;
-       result = PBCreateFileIDRefSync((HParmBlkPtr)&pb);
-       require((noErr == result) || (fidExists == result) || (afpIDExists == result),
-               PBCreateFileIDRefSync);
-       
-       /* return the file ID reference */
-       *fileID = pb.ioFileID;
-       
-PBCreateFileIDRefSync:
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-#pragma mark ----- Utility Routines -----
-
-/*****************************************************************************/
-
-Ptr
-GetTempBuffer(
-       ByteCount buffReqSize,
-       ByteCount *buffActSize)
-{
-       enum
-       {
-               kSlopMemory = 0x00008000        /* 32K - Amount of free memory to leave when allocating buffers */
-       };
-       
-       Ptr tempPtr;
-       
-       /* check parameters */
-       require_action(NULL != buffActSize, BadParameter, tempPtr = NULL);
-       
-       /* Make request a multiple of 4K bytes */
-       buffReqSize = buffReqSize & 0xfffff000;
-       
-       if ( buffReqSize < 0x00001000 )
-       {
-               /* Request was smaller than 4K bytes - make it 4K */
-               buffReqSize = 0x00001000;
-       }
-       
-       /* Attempt to allocate the memory */
-       tempPtr = NewPtr(buffReqSize);
-       
-       /* If request failed, go to backup plan */
-       if ( (tempPtr == NULL) && (buffReqSize > 0x00001000) )
-       {
-               /*
-               **      Try to get largest 4K byte block available
-               **      leaving some slop for the toolbox if possible
-               */
-               long freeMemory = (FreeMem() - kSlopMemory) & 0xfffff000;
-               
-               buffReqSize = MaxBlock() & 0xfffff000;
-               
-               if ( (long)buffReqSize > freeMemory )
-               {
-                       buffReqSize = freeMemory;
-               }
-               
-               if ( buffReqSize == 0 )
-               {
-                       buffReqSize = 0x00001000;
-               }
-               
-               tempPtr = NewPtr(buffReqSize);
-       }
-       
-       /* Return bytes allocated */
-       if ( tempPtr != NULL )
-       {
-               *buffActSize = buffReqSize;
-       }
-       else
-       {
-               *buffActSize = 0;
-       }
-       
-BadParameter:
-
-       return ( tempPtr );
-}
-
-/*****************************************************************************/
-
-OSErr
-FileRefNumGetFSRef(
-       short refNum,
-       FSRef *ref)
-{
-       return ( FSGetForkCBInfo(refNum, 0, NULL, NULL, NULL, ref, NULL) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetDefault(
-       const FSRef *newDefault,
-       FSRef *oldDefault)
-{
-       OSErr                   result;
-       FSVolumeRefNum  vRefNum;
-       long                    dirID;
-       FSCatalogInfo   catalogInfo;
-       
-       /* check parameters */
-       require_action((NULL != newDefault) && (NULL != oldDefault), BadParameter, result = paramErr);
-       
-       /* Get nodeFlags, vRefNum and dirID (nodeID) of newDefault */
-       result = FSGetCatalogInfo(newDefault,
-               kFSCatInfoNodeFlags + kFSCatInfoVolume + kFSCatInfoNodeID,
-               &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* Make sure newDefault is a directory */
-       require_action(0 != (kFSNodeIsDirectoryMask & catalogInfo.nodeFlags), NewDefaultNotDirectory,
-               result = dirNFErr);
-       
-       /* Get the current working directory. */
-       result = HGetVol(NULL, &vRefNum, &dirID);
-       require_noerr(result, HGetVol);
-       
-       /* Return the oldDefault FSRef */
-       result = FSMakeFSRef(vRefNum, dirID, NULL, oldDefault);
-       require_noerr(result, FSMakeFSRef);
-       
-       /* Set the new current working directory */
-       result = HSetVol(NULL, catalogInfo.volume, catalogInfo.nodeID);
-       require_noerr(result, HSetVol);
-
-HSetVol:
-FSMakeFSRef:
-HGetVol:
-NewDefaultNotDirectory:
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSRestoreDefault(
-       const FSRef *oldDefault)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       
-       /* check parameters */
-       require_action(NULL != oldDefault, BadParameter, result = paramErr);
-       
-       /* Get nodeFlags, vRefNum and dirID (nodeID) of oldDefault */
-       result = FSGetCatalogInfo(oldDefault,
-               kFSCatInfoNodeFlags + kFSCatInfoVolume + kFSCatInfoNodeID,
-               &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* Make sure oldDefault is a directory */
-       require_action(0 != (kFSNodeIsDirectoryMask & catalogInfo.nodeFlags), OldDefaultNotDirectory,
-               result = dirNFErr);
-       
-       /* Set the current working directory to oldDefault */
-       result = HSetVol(NULL, catalogInfo.volume, catalogInfo.nodeID);
-       require_noerr(result, HSetVol);
-
-HSetVol:
-OldDefaultNotDirectory:
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
diff --git a/src/mac/morefilex/MoreFilesX.cpp b/src/mac/morefilex/MoreFilesX.cpp
deleted file mode 100755 (executable)
index 617f492..0000000
+++ /dev/null
@@ -1,2770 +0,0 @@
-/*
-       File:           MoreFilesX.c
-
-       Contains:       A collection of useful high-level File Manager routines
-                               which use the HFS Plus APIs wherever possible.
-
-       Version:        MoreFilesX 1.0.1
-
-       Copyright:      © 1992-2002 by Apple Computer, Inc., all rights reserved.
-
-       Disclaimer:     IMPORTANT:  This Apple software is supplied to you by Apple Computer, Inc.
-                               ("Apple") in consideration of your agreement to the following terms, and your
-                               use, installation, modification or redistribution of this Apple software
-                               constitutes acceptance of these terms.  If you do not agree with these terms,
-                               please do not use, install, modify or redistribute this Apple software.
-
-                               In consideration of your agreement to abide by the following terms, and subject
-                               to these terms, Apple grants you a personal, non-exclusive license, under AppleÕs
-                               copyrights in this original Apple software (the "Apple Software"), to use,
-                               reproduce, modify and redistribute the Apple Software, with or without
-                               modifications, in source and/or binary forms; provided that if you redistribute
-                               the Apple Software in its entirety and without modifications, you must retain
-                               this notice and the following text and disclaimers in all such redistributions of
-                               the Apple Software.  Neither the name, trademarks, service marks or logos of
-                               Apple Computer, Inc. may be used to endorse or promote products derived from the
-                               Apple Software without specific prior written permission from Apple.  Except as
-                               expressly stated in this notice, no other rights or licenses, express or implied,
-                               are granted by Apple herein, including but not limited to any patent rights that
-                               may be infringed by your derivative works or by other works in which the Apple
-                               Software may be incorporated.
-
-                               The Apple Software is provided by Apple on an "AS IS" basis.  APPLE MAKES NO
-                               WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED
-                               WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS FOR A PARTICULAR
-                               PURPOSE, REGARDING THE APPLE SOFTWARE OR ITS USE AND OPERATION ALONE OR IN
-                               COMBINATION WITH YOUR PRODUCTS.
-
-                               IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL OR
-                               CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
-                               GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
-                               ARISING IN ANY WAY OUT OF THE USE, REPRODUCTION, MODIFICATION AND/OR DISTRIBUTION
-                               OF THE APPLE SOFTWARE, HOWEVER CAUSED AND WHETHER UNDER THEORY OF CONTRACT, TORT
-                               (INCLUDING NEGLIGENCE), STRICT LIABILITY OR OTHERWISE, EVEN IF APPLE HAS BEEN
-                               ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-
-       File Ownership:
-
-               DRI:                            Apple Macintosh Developer Technical Support
-
-               Other Contact:          For bug reports, consult the following page on
-                                                       the World Wide Web:
-                                                               http://developer.apple.com/bugreporter/
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-
-       Change History (most recent first):
-
-                <4>     8/22/02        JL              [3016251]  Changed FSMoveRenameObjectUnicode to not use
-                                                                       the Temporary folder because it isn't available on
-                                                                       NFS volumes.
-                <3>     4/19/02        JL              [2853905]  Fixed #if test around header includes.
-                <2>     4/19/02        JL              [2850624]  Fixed C++ compile errors and Project Builder
-                                                                       warnings.
-                <2>     4/19/02        JL              [2853901]  Updated standard disclaimer.
-                <1>     1/25/02        JL              MoreFilesX 1.0
-*/
-
-#if defined(__MACH__)
-       #include <Carbon/Carbon.h>
-       #include <string.h>
-#else
-       #include <Carbon.h>
-       #include <string.h>
-#endif
-
-#include "MoreFilesX.h"
-
-/* Set BuildingMoreFilesXForMacOS9 to 1 if building for Mac OS 9 */
-#ifndef BuildingMoreFilesXForMacOS9
-       #define BuildingMoreFilesXForMacOS9 0
-#endif
-
-/*****************************************************************************/
-
-#pragma mark ----- Local type definitions -----
-
-struct FSIterateContainerGlobals
-{
-       IterateContainerFilterProcPtr   iterateFilter;  /* pointer to IterateFilterProc */
-       FSCatalogInfoBitmap                             whichInfo;              /* fields of the CatalogInfo to get */
-       FSCatalogInfo                                   catalogInfo;    /* FSCatalogInfo */
-       FSRef                                                   ref;                    /* FSRef */
-       FSSpec                                                  spec;                   /* FSSpec */
-       FSSpec                                                  *specPtr;               /* pointer to spec field, or NULL */
-       HFSUniStr255                                    name;                   /* HFSUniStr255 */
-       HFSUniStr255                                    *namePtr;               /* pointer to name field, or NULL */
-       void                                                    *yourDataPtr;   /* a pointer to caller supplied data the filter may need to access */
-       ItemCount                                               maxLevels;              /* maximum levels to iterate through */
-       ItemCount                                               currentLevel;   /* the current level FSIterateContainerLevel is on */
-       Boolean                                                 quitFlag;               /* set to true if filter wants to kill interation */
-       Boolean                                                 containerChanged; /* temporary - set to true if the current container changed during iteration */
-       OSErr                                                   result;                 /* result */
-       ItemCount                                               actualObjects;  /* number of objects returned */
-};
-typedef struct FSIterateContainerGlobals FSIterateContainerGlobals;
-
-struct FSDeleteContainerGlobals
-{
-       OSErr                                                   result;                 /* result */
-       ItemCount                                               actualObjects;  /* number of objects returned */
-       FSCatalogInfo                                   catalogInfo;    /* FSCatalogInfo */
-};
-typedef struct FSDeleteContainerGlobals FSDeleteContainerGlobals;
-
-/*****************************************************************************/
-
-#pragma mark ----- Local prototypes -----
-
-static
-void
-FSDeleteContainerLevel(
-       const FSRef *container,
-       FSDeleteContainerGlobals *theGlobals);
-
-static
-void
-FSIterateContainerLevel(
-       FSIterateContainerGlobals *theGlobals);
-
-static
-OSErr
-GenerateUniqueHFSUniStr(
-       long *startSeed,
-       const FSRef *dir1,
-       const FSRef *dir2,
-       HFSUniStr255 *uniqueName);
-
-/*****************************************************************************/
-
-#pragma mark ----- File Access Routines -----
-
-/*****************************************************************************/
-
-OSErr
-FSCopyFork(
-       SInt16 srcRefNum,
-       SInt16 dstRefNum,
-       void *copyBufferPtr,
-       ByteCount copyBufferSize)
-{
-       OSErr           srcResult;
-       OSErr           dstResult;
-       OSErr           result;
-       SInt64          forkSize;
-       ByteCount       readActualCount;
-       
-       /* check input parameters */
-       require_action((NULL != copyBufferPtr) && (0 != copyBufferSize), BadParameter, result = paramErr);
-       
-       /* get source fork size */
-       result = FSGetForkSize(srcRefNum, &forkSize);
-       require_noerr(result, SourceFSGetForkSizeFailed);
-       
-       /* allocate disk space for destination fork */
-       result = FSSetForkSize(dstRefNum, fsFromStart, forkSize);
-       require_noerr(result, DestinationFSSetForkSizeFailed);
-       
-       /* reset source fork's position to 0 */
-       result = FSSetForkPosition(srcRefNum, fsFromStart, 0);
-       require_noerr(result, SourceFSSetForkPositionFailed);
-       
-       /* reset destination fork's position to 0 */
-       result = FSSetForkPosition(dstRefNum, fsFromStart, 0);
-       require_noerr(result, DestinationFSSetForkPositionFailed);
-
-       /* If copyBufferSize is greater than 4K bytes, make it a multiple of 4k bytes */
-       /* This will make writes on local volumes faster */
-       if ( (copyBufferSize >= 0x00001000) && ((copyBufferSize & 0x00000fff) != 0) )
-       {
-               copyBufferSize &= ~(0x00001000 - 1);
-       }
-       
-       /* copy source to destination */
-       srcResult = dstResult = noErr;
-       while ( (noErr == srcResult) && (noErr == dstResult) )
-       {
-               srcResult = FSReadFork(srcRefNum, fsAtMark + noCacheMask, 0, copyBufferSize, copyBufferPtr, &readActualCount);
-               dstResult = FSWriteFork(dstRefNum, fsAtMark + noCacheMask, 0, readActualCount, copyBufferPtr, NULL);
-       }
-       
-       /* make sure there were no errors at the destination */
-       require_noerr_action(dstResult, DestinationFSWriteForkFailed, result = dstResult);
-       
-       /* make sure the error at the source was eofErr */
-       require_action(eofErr == srcResult, SourceResultNotEofErr, result = srcResult);
-       
-       /* everything went as expected */
-       result = noErr;
-
-SourceResultNotEofErr:
-DestinationFSWriteForkFailed:
-DestinationFSSetForkPositionFailed:
-SourceFSSetForkPositionFailed:
-DestinationFSSetForkSizeFailed:
-SourceFSGetForkSizeFailed:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-#pragma mark ----- Volume Access Routines -----
-
-/*****************************************************************************/ 
-
-OSErr
-FSGetVolParms(
-       FSVolumeRefNum volRefNum,
-       UInt32 bufferSize,
-       GetVolParmsInfoBuffer *volParmsInfo,
-       UInt32 *actualInfoSize)
-{
-       OSErr                   result;
-       HParamBlockRec  pb;
-       
-       /* check parameters */
-       require_action((NULL != volParmsInfo) && (NULL != actualInfoSize),
-               BadParameter, result = paramErr);
-       
-       pb.ioParam.ioNamePtr = NULL;
-       pb.ioParam.ioVRefNum = volRefNum;
-       pb.ioParam.ioBuffer = (Ptr)volParmsInfo;
-       pb.ioParam.ioReqCount = (SInt32)bufferSize;
-       result = PBHGetVolParmsSync(&pb);
-       require_noerr(result, PBHGetVolParmsSync);
-       
-       /* return number of bytes the file system returned in volParmsInfo buffer */
-       *actualInfoSize = (UInt32)pb.ioParam.ioActCount;
-       
-PBHGetVolParmsSync:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetVRefNum(
-       const FSRef *ref,
-       FSVolumeRefNum *vRefNum)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       
-       /* check parameters */
-       require_action(NULL != vRefNum, BadParameter, result = paramErr);
-       
-       /* get the volume refNum from the FSRef */
-       result = FSGetCatalogInfo(ref, kFSCatInfoVolume, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* return volume refNum from catalogInfo */
-       *vRefNum = catalogInfo.volume;
-       
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetVInfo(
-       FSVolumeRefNum volume,
-       HFSUniStr255 *volumeName,       /* can be NULL */
-       UInt64 *freeBytes,                      /* can be NULL */
-       UInt64 *totalBytes)                     /* can be NULL */
-{
-       OSErr                           result;
-       FSVolumeInfo            info;
-       
-       /* ask for the volume's sizes only if needed */
-       result = FSGetVolumeInfo(volume, 0, NULL,
-               (((NULL != freeBytes) || (NULL != totalBytes)) ? kFSVolInfoSizes : kFSVolInfoNone),
-               &info, volumeName, NULL);
-       require_noerr(result, FSGetVolumeInfo);
-       
-       if ( NULL != freeBytes )
-       {
-               *freeBytes = info.freeBytes;
-       }
-       if ( NULL != totalBytes )
-       {
-               *totalBytes = info.totalBytes;
-       }
-       
-FSGetVolumeInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetVolFileSystemID(
-       FSVolumeRefNum volume,
-       UInt16 *fileSystemID,   /* can be NULL */
-       UInt16 *signature)              /* can be NULL */
-{
-       OSErr                   result;
-       FSVolumeInfo    info;
-       
-       result = FSGetVolumeInfo(volume, 0, NULL, kFSVolInfoFSInfo, &info, NULL, NULL);
-       require_noerr(result, FSGetVolumeInfo);
-       
-       if ( NULL != fileSystemID )
-       {
-               *fileSystemID = info.filesystemID;
-       }
-       if ( NULL != signature )
-       {
-               *signature = info.signature;
-       }
-       
-FSGetVolumeInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetMountedVolumes(
-       FSRef ***volumeRefsHandle,      /* pointer to handle of FSRefs */
-       ItemCount *numVolumes)
-{
-       OSErr           result;
-       OSErr           memResult;
-       ItemCount       volumeIndex;
-       FSRef           ref;
-       
-       /* check parameters */
-       require_action((NULL != volumeRefsHandle) && (NULL != numVolumes),
-               BadParameter, result = paramErr);
-       
-       /* No volumes yet */
-       *numVolumes = 0;
-       
-       /* Allocate a handle for the results */
-       *volumeRefsHandle = (FSRef **)NewHandle(0);
-       require_action(NULL != *volumeRefsHandle, NewHandle, result = memFullErr);
-       
-       /* Call FSGetVolumeInfo in loop to get all volumes starting with the first */
-       volumeIndex = 1;
-       do
-       {
-               result = FSGetVolumeInfo(0, volumeIndex, NULL, kFSVolInfoNone, NULL, NULL, &ref);
-               if ( noErr == result )
-               {
-                       /* concatenate the FSRef to the end of the handle */
-                       PtrAndHand(&ref, (Handle)*volumeRefsHandle, sizeof(FSRef));
-                       memResult = MemError();
-                       require_noerr_action(memResult, MemoryAllocationFailed, result = memResult);
-                       
-                       ++(*numVolumes);        /* increment the volume count */
-                       ++volumeIndex;          /* and the volumeIndex to get the next volume*/
-               }
-       } while ( noErr == result );
-       
-       /* nsvErr is OK -- it just means there are no more volumes */
-       require(nsvErr == result, FSGetVolumeInfo);
-               
-       return ( noErr );
-       
-       /**********************/
-       
-MemoryAllocationFailed:
-FSGetVolumeInfo:
-
-       /* dispose of handle if already allocated and clear the outputs */
-       if ( NULL != *volumeRefsHandle )
-       {
-               DisposeHandle((Handle)*volumeRefsHandle);
-               *volumeRefsHandle = NULL;
-       }
-       *numVolumes = 0;
-       
-NewHandle:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-#pragma mark ----- FSRef/FSpec/Path/Name Conversion Routines -----
-
-/*****************************************************************************/
-
-OSErr
-FSRefMakeFSSpec(
-       const FSRef *ref,
-       FSSpec *spec)
-{
-       OSErr   result;
-       
-       /* check parameters */
-       require_action(NULL != spec, BadParameter, result = paramErr);
-       
-       result = FSGetCatalogInfo(ref, kFSCatInfoNone, NULL, NULL, spec, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSMakeFSRef(
-       FSVolumeRefNum volRefNum,
-       SInt32 dirID,
-       ConstStr255Param name,
-       FSRef *ref)
-{
-       OSErr           result;
-       FSRefParam      pb;
-       
-       /* check parameters */
-       require_action(NULL != ref, BadParameter, result = paramErr);
-       
-       pb.ioVRefNum = volRefNum;
-       pb.ioDirID = dirID;
-       pb.ioNamePtr = (StringPtr)name;
-       pb.newRef = ref;
-       result = PBMakeFSRefSync(&pb);
-       require_noerr(result, PBMakeFSRefSync);
-       
-PBMakeFSRefSync:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSStatus
-FSMakePath(
-       SInt16 volRefNum,
-       SInt32 dirID,
-       ConstStr255Param name,
-       UInt8 *path,
-       UInt32 maxPathSize)
-{
-       OSStatus        result;
-       FSRef           ref;
-       
-       /* check parameters */
-       require_action(NULL != path, BadParameter, result = paramErr);
-       
-       /* convert the inputs to an FSRef */
-       result = FSMakeFSRef(volRefNum, dirID, name, &ref);
-       require_noerr(result, FSMakeFSRef);
-       
-       /* and then convert the FSRef to a path */
-       result = FSRefMakePath(&ref, path, maxPathSize);
-       require_noerr(result, FSRefMakePath);
-       
-FSRefMakePath:
-FSMakeFSRef:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSStatus
-FSPathMakeFSSpec(
-       const UInt8 *path,
-       FSSpec *spec,
-       Boolean *isDirectory)   /* can be NULL */
-{
-       OSStatus        result;
-       FSRef           ref;
-       
-       /* check parameters */
-       require_action(NULL != spec, BadParameter, result = paramErr);
-       
-       /* convert the POSIX path to an FSRef */
-       result = FSPathMakeRef(path, &ref, isDirectory);
-       require_noerr(result, FSPathMakeRef);
-       
-       /* and then convert the FSRef to an FSSpec */
-       result = FSGetCatalogInfo(&ref, kFSCatInfoNone, NULL, NULL, spec, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-FSGetCatalogInfo:
-FSPathMakeRef:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-UnicodeNameGetHFSName(
-       UniCharCount nameLength,
-       const UniChar *name,
-       TextEncoding textEncodingHint,
-       Boolean isVolumeName,
-       Str31 hfsName)
-{
-       OSStatus                        result;
-       ByteCount                       unicodeByteLength;
-       ByteCount                       unicodeBytesConverted;
-       ByteCount                       actualPascalBytes;
-       UnicodeMapping          uMapping;
-       UnicodeToTextInfo       utInfo;
-       
-       /* check parameters */
-       require_action(NULL != hfsName, BadParameter, result = paramErr);
-       
-       /* make sure output is valid in case we get errors or there's nothing to convert */
-       hfsName[0] = 0;
-       
-       unicodeByteLength = nameLength * sizeof(UniChar);
-       if ( 0 == unicodeByteLength )
-       {
-               /* do nothing */
-               result = noErr;
-       }
-       else
-       {
-               /* if textEncodingHint is kTextEncodingUnknown, get a "default" textEncodingHint */
-               if ( kTextEncodingUnknown == textEncodingHint )
-               {
-                       ScriptCode                      script;
-                       RegionCode                      region;
-                       
-                       script = (ScriptCode)GetScriptManagerVariable(smSysScript);
-                       region = (RegionCode)GetScriptManagerVariable(smRegionCode);
-                       result = UpgradeScriptInfoToTextEncoding(script, kTextLanguageDontCare, region,
-                               NULL, &textEncodingHint );
-                       if ( paramErr == result )
-                       {
-                               /* ok, ignore the region and try again */
-                               result = UpgradeScriptInfoToTextEncoding(script, kTextLanguageDontCare,
-                                       kTextRegionDontCare, NULL, &textEncodingHint );
-                       }
-                       if ( noErr != result )
-                       {
-                               /* ok... try something */
-                               textEncodingHint = kTextEncodingMacRoman;
-                       }
-               }
-               
-               uMapping.unicodeEncoding = CreateTextEncoding(kTextEncodingUnicodeV2_0,
-                       kUnicodeCanonicalDecompVariant, kUnicode16BitFormat);
-               uMapping.otherEncoding = GetTextEncodingBase(textEncodingHint);
-               uMapping.mappingVersion = kUnicodeUseHFSPlusMapping;
-       
-               result = CreateUnicodeToTextInfo(&uMapping, &utInfo);
-               require_noerr(result, CreateUnicodeToTextInfo);
-               
-               result = ConvertFromUnicodeToText(utInfo, unicodeByteLength, name, kUnicodeLooseMappingsMask,
-                       0, NULL, 0, NULL,       /* offsetCounts & offsetArrays */
-                       isVolumeName ? kHFSMaxVolumeNameChars : kHFSMaxFileNameChars,
-                       &unicodeBytesConverted, &actualPascalBytes, &hfsName[1]);
-               require_noerr(result, ConvertFromUnicodeToText);
-               
-               hfsName[0] = (unsigned char)actualPascalBytes;  /* fill in length byte */
-
-ConvertFromUnicodeToText:
-               
-               /* verify the result in debug builds -- there's really not anything you can do if it fails */
-               verify_noerr(DisposeUnicodeToTextInfo(&utInfo));
-       }
-       
-CreateUnicodeToTextInfo:       
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-HFSNameGetUnicodeName(
-       ConstStr31Param hfsName,
-       TextEncoding textEncodingHint,
-       HFSUniStr255 *unicodeName)
-{
-       ByteCount                       unicodeByteLength;
-       OSStatus                        result;
-       UnicodeMapping          uMapping;
-       TextToUnicodeInfo       tuInfo;
-       ByteCount                       pascalCharsRead;
-       
-       /* check parameters */
-       require_action(NULL != unicodeName, BadParameter, result = paramErr);
-       
-       /* make sure output is valid in case we get errors or there's nothing to convert */
-       unicodeName->length = 0;
-       
-       if ( 0 == StrLength(hfsName) )
-       {
-               result = noErr;
-       }
-       else
-       {
-               /* if textEncodingHint is kTextEncodingUnknown, get a "default" textEncodingHint */
-               if ( kTextEncodingUnknown == textEncodingHint )
-               {
-                       ScriptCode                      script;
-                       RegionCode                      region;
-                       
-                       script = GetScriptManagerVariable(smSysScript);
-                       region = GetScriptManagerVariable(smRegionCode);
-                       result = UpgradeScriptInfoToTextEncoding(script, kTextLanguageDontCare, region,
-                               NULL, &textEncodingHint);
-                       if ( paramErr == result )
-                       {
-                               /* ok, ignore the region and try again */
-                               result = UpgradeScriptInfoToTextEncoding(script, kTextLanguageDontCare,
-                                       kTextRegionDontCare, NULL, &textEncodingHint);
-                       }
-                       if ( noErr != result )
-                       {
-                               /* ok... try something */
-                               textEncodingHint = kTextEncodingMacRoman;
-                       }
-               }
-               
-               uMapping.unicodeEncoding = CreateTextEncoding(kTextEncodingUnicodeV2_0,
-                       kUnicodeCanonicalDecompVariant, kUnicode16BitFormat);
-               uMapping.otherEncoding = GetTextEncodingBase(textEncodingHint);
-               uMapping.mappingVersion = kUnicodeUseHFSPlusMapping;
-       
-               result = CreateTextToUnicodeInfo(&uMapping, &tuInfo);
-               require_noerr(result, CreateTextToUnicodeInfo);
-                       
-               result = ConvertFromTextToUnicode(tuInfo, hfsName[0], &hfsName[1],
-                       0,                                                              /* no control flag bits */
-                       0, NULL, 0, NULL,                               /* offsetCounts & offsetArrays */
-                       sizeof(unicodeName->unicode),   /* output buffer size in bytes */
-                       &pascalCharsRead, &unicodeByteLength, unicodeName->unicode);
-               require_noerr(result, ConvertFromTextToUnicode);
-               
-               /* convert from byte count to char count */
-               unicodeName->length = unicodeByteLength / sizeof(UniChar);
-
-ConvertFromTextToUnicode:
-
-               /* verify the result in debug builds -- there's really not anything you can do if it fails */
-               verify_noerr(DisposeTextToUnicodeInfo(&tuInfo));
-       }
-       
-CreateTextToUnicodeInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-#pragma mark ----- File/Directory Manipulation Routines -----
-
-/*****************************************************************************/
-
-Boolean FSRefValid(const FSRef *ref)
-{
-       return ( noErr == FSGetCatalogInfo(ref, kFSCatInfoNone, NULL, NULL, NULL, NULL) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetParentRef(
-       const FSRef *ref,
-       FSRef *parentRef)
-{
-       OSErr   result;
-       FSCatalogInfo   catalogInfo;
-       
-       /* check parameters */
-       require_action(NULL != parentRef, BadParameter, result = paramErr);
-       
-       result = FSGetCatalogInfo(ref, kFSCatInfoNodeID, &catalogInfo, NULL, NULL, parentRef);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /*
-        * Note: FSRefs always point to real file system objects. So, there cannot
-        * be a FSRef to the parent of volume root directories. Early versions of
-        * Mac OS X do not handle this case correctly and incorrectly return a
-        * FSRef for the parent of volume root directories instead of returning an
-        * invalid FSRef (a cleared FSRef is invalid). The next three lines of code
-        * ensure that you won't run into this bug. WW9D!
-        */
-       if ( fsRtDirID == catalogInfo.nodeID )
-       {
-               /* clear parentRef and return noErr which is the proper behavior */
-               memset(parentRef, 0, sizeof(FSRef));
-       }
-
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetFileDirName(
-       const FSRef *ref,
-       HFSUniStr255 *outName)
-{
-       OSErr   result;
-       
-       /* check parameters */
-       require_action(NULL != outName, BadParameter, result = paramErr);
-       
-       result = FSGetCatalogInfo(ref, kFSCatInfoNone, NULL, outName, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetNodeID(
-       const FSRef *ref,
-       long *nodeID,                   /* can be NULL */
-       Boolean *isDirectory)   /* can be NULL */
-{
-       OSErr                           result;
-       FSCatalogInfo           catalogInfo;
-       FSCatalogInfoBitmap whichInfo;
-       
-       /* determine what catalog information to get */
-       whichInfo = kFSCatInfoNone; /* start with none */
-       if ( NULL != nodeID )
-       {
-               whichInfo |= kFSCatInfoNodeID;
-       }
-       if ( NULL != isDirectory )
-       {
-               whichInfo |= kFSCatInfoNodeFlags;
-       }
-       
-       result = FSGetCatalogInfo(ref, whichInfo, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       if ( NULL != nodeID )
-       {
-               *nodeID = catalogInfo.nodeID;
-       }
-       if ( NULL != isDirectory )
-       {
-               *isDirectory = (0 != (kFSNodeIsDirectoryMask & catalogInfo.nodeFlags));
-       }
-       
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetUserPrivilegesPermissions(
-       const FSRef *ref,
-       UInt8 *userPrivileges,          /* can be NULL */
-       UInt32 permissions[4])          /* can be NULL */
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       FSCatalogInfoBitmap whichInfo;
-       
-       /* determine what catalog information to get */
-       whichInfo = kFSCatInfoNone; /* start with none */
-       if ( NULL != userPrivileges )
-       {
-               whichInfo |= kFSCatInfoUserPrivs;
-       }
-       if ( NULL != permissions )
-       {
-               whichInfo |= kFSCatInfoPermissions;
-       }
-       
-       result = FSGetCatalogInfo(ref, whichInfo, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       if ( NULL != userPrivileges )
-       {
-               *userPrivileges = catalogInfo.userPrivileges;
-       }
-       if ( NULL != permissions )
-       {
-               BlockMoveData(&catalogInfo.permissions, permissions, sizeof(UInt32) * 4);
-       }
-       
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSCheckLock(
-       const FSRef *ref)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       FSVolumeInfo    volumeInfo;
-       
-       /* get nodeFlags and vRefNum for container */
-       result = FSGetCatalogInfo(ref, kFSCatInfoNodeFlags + kFSCatInfoVolume, &catalogInfo, NULL, NULL,NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* is file locked? */
-       if ( 0 != (catalogInfo.nodeFlags & kFSNodeLockedMask) )
-       {
-               result = fLckdErr;      /* file is locked */
-       }
-       else
-       {
-               /* file isn't locked, but is volume locked? */
-               
-               /* get volume flags */
-               result = FSGetVolumeInfo(catalogInfo.volume, 0, NULL, kFSVolInfoFlags, &volumeInfo, NULL, NULL);
-               require_noerr(result, FSGetVolumeInfo);
-               
-               if ( 0 != (volumeInfo.flags & kFSVolFlagHardwareLockedMask) )
-               {
-                       result = wPrErr;        /* volume locked by hardware */
-               }
-               else if ( 0 != (volumeInfo.flags & kFSVolFlagSoftwareLockedMask) )
-               {
-                       result = vLckdErr;      /* volume locked by software */
-               }
-       }
-       
-FSGetVolumeInfo:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetForkSizes(
-       const FSRef *ref,
-       UInt64 *dataLogicalSize,        /* can be NULL */
-       UInt64 *rsrcLogicalSize)        /* can be NULL */
-{
-       OSErr                           result;
-       FSCatalogInfoBitmap whichInfo;
-       FSCatalogInfo           catalogInfo;
-       
-       whichInfo = kFSCatInfoNodeFlags;
-       if ( NULL != dataLogicalSize )
-       {
-               /* get data fork size */
-               whichInfo |= kFSCatInfoDataSizes;
-       }
-       if ( NULL != rsrcLogicalSize )
-       {
-               /* get resource fork size */
-               whichInfo |= kFSCatInfoRsrcSizes;
-       }
-
-       /* get nodeFlags and catalog info */
-       result = FSGetCatalogInfo(ref, whichInfo, &catalogInfo, NULL, NULL,NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* make sure FSRef was to a file */
-       require_action(0 == (catalogInfo.nodeFlags & kFSNodeIsDirectoryMask), FSRefNotFile, result = notAFileErr);
-       
-       if ( NULL != dataLogicalSize )
-       {
-               /* return data fork size */
-               *dataLogicalSize = catalogInfo.dataLogicalSize;
-       }
-       if ( NULL != rsrcLogicalSize )
-       {
-               /* return resource fork size */
-               *rsrcLogicalSize = catalogInfo.rsrcLogicalSize;
-       }
-       
-FSRefNotFile:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetTotalForkSizes(
-       const FSRef *ref,
-       UInt64 *totalLogicalSize,       /* can be NULL */
-       UInt64 *totalPhysicalSize,      /* can be NULL */
-       ItemCount *forkCount)           /* can be NULL */
-{
-       OSErr                   result;
-       CatPositionRec  forkIterator;
-       SInt64                  forkSize;
-       SInt64                  *forkSizePtr;
-       UInt64                  forkPhysicalSize;
-       UInt64                  *forkPhysicalSizePtr;
-       
-       /* Determine if forkSize needed */
-       if ( NULL != totalLogicalSize)
-       {
-               *totalLogicalSize = 0;
-               forkSizePtr = &forkSize;
-       }
-       else
-       {
-               forkSizePtr = NULL;
-       }
-       
-       /* Determine if forkPhysicalSize is needed */
-       if ( NULL != totalPhysicalSize )
-       {
-               *totalPhysicalSize = 0;
-               forkPhysicalSizePtr = &forkPhysicalSize;
-       }
-       else
-       {
-               forkPhysicalSizePtr = NULL;
-       }
-       
-       /* zero fork count if returning it */
-       if ( NULL != forkCount )
-       {
-               *forkCount = 0;
-       }
-       
-       /* Iterate through the forks to get the sizes */
-       forkIterator.initialize = 0;
-       do
-       {
-               result = FSIterateForks(ref, &forkIterator, NULL, forkSizePtr, forkPhysicalSizePtr);
-               if ( noErr == result )
-               {
-                       if ( NULL != totalLogicalSize )
-                       {
-                               *totalLogicalSize += forkSize;
-                       }
-                       
-                       if ( NULL != totalPhysicalSize )
-                       {
-                               *totalPhysicalSize += forkPhysicalSize;
-                       }
-                       
-                       if ( NULL != forkCount )
-                       {
-                               ++*forkCount;
-                       }
-               }
-       } while ( noErr == result );
-       
-       /* any error result other than errFSNoMoreItems is serious */
-       require(errFSNoMoreItems == result, FSIterateForks);
-       
-       /* Normal exit */
-       result = noErr;
-
-FSIterateForks:
-       
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSBumpDate(
-       const FSRef *ref)
-{
-       OSStatus                result;
-       FSCatalogInfo   catalogInfo;
-       UTCDateTime             oldDateTime;
-#if !BuildingMoreFilesXForMacOS9
-       FSRef                   parentRef;
-       Boolean                 notifyParent;
-#endif
-
-#if !BuildingMoreFilesXForMacOS9
-       /* Get the node flags, the content modification date and time, and the parent ref */
-       result = FSGetCatalogInfo(ref, kFSCatInfoNodeFlags + kFSCatInfoContentMod, &catalogInfo, NULL, NULL, &parentRef);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* Notify the parent if this is a file */
-       notifyParent = (0 == (catalogInfo.nodeFlags & kFSNodeIsDirectoryMask));
-#else
-       /* Get the content modification date and time */
-       result = FSGetCatalogInfo(ref, kFSCatInfoContentMod, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-#endif
-       
-       oldDateTime = catalogInfo.contentModDate;
-
-       /* Get the current date and time */
-       result = GetUTCDateTime(&catalogInfo.contentModDate, kUTCDefaultOptions);
-       require_noerr(result, GetUTCDateTime);
-       
-       /* if the old date and time is the the same as the current, bump the seconds by one */
-       if ( (catalogInfo.contentModDate.fraction == oldDateTime.fraction) &&
-                (catalogInfo.contentModDate.lowSeconds == oldDateTime.lowSeconds) &&
-                (catalogInfo.contentModDate.highSeconds == oldDateTime.highSeconds) )
-       {
-               ++catalogInfo.contentModDate.lowSeconds;
-               if ( 0 == catalogInfo.contentModDate.lowSeconds )
-               {
-                       ++catalogInfo.contentModDate.highSeconds;
-               }
-       }
-       
-       /* Bump the content modification date and time */
-       result = FSSetCatalogInfo(ref, kFSCatInfoContentMod, &catalogInfo);
-       require_noerr(result, FSSetCatalogInfo);
-
-#if !BuildingMoreFilesXForMacOS9
-       /*
-        * The problem with FNNotify is that it is not available under Mac OS 9
-        * and there's no way to test for that except for looking for the symbol
-        * or something. So, I'll just conditionalize this for those who care
-        * to send a notification.
-        */
-       
-       /* Send a notification for the parent of the file, or for the directory */
-       result = FNNotify(notifyParent ? &parentRef : ref, kFNDirectoryModifiedMessage, kNilOptions);
-       require_noerr(result, FNNotify);
-#endif
-
-       /* ignore errors from FSSetCatalogInfo (volume might be write protected) and FNNotify */
-FNNotify:
-FSSetCatalogInfo:
-       
-       return ( noErr );
-       
-       /**********************/
-       
-GetUTCDateTime:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetFinderInfo(
-       const FSRef *ref,
-       FinderInfo *info,                                       /* can be NULL */
-       ExtendedFinderInfo *extendedInfo,       /* can be NULL */
-       Boolean *isDirectory)                           /* can be NULL */
-{
-       OSErr                           result;
-       FSCatalogInfo           catalogInfo;
-       FSCatalogInfoBitmap whichInfo;
-       
-       /* determine what catalog information is really needed */
-       whichInfo = kFSCatInfoNone;
-       
-       if ( NULL != info )
-       {
-               /* get FinderInfo */
-               whichInfo |= kFSCatInfoFinderInfo;
-       }
-       
-       if ( NULL != extendedInfo )
-       {
-               /* get ExtendedFinderInfo */
-               whichInfo |= kFSCatInfoFinderXInfo;
-       }
-       
-       if ( NULL != isDirectory )
-       {
-               whichInfo |= kFSCatInfoNodeFlags;
-       }
-       
-       result = FSGetCatalogInfo(ref, whichInfo, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* return FinderInfo if requested */
-       if ( NULL != info )
-       {
-               BlockMoveData(catalogInfo.finderInfo, info, sizeof(FinderInfo));
-       }
-       
-       /* return ExtendedFinderInfo if requested */
-       if ( NULL != extendedInfo)
-       {
-               BlockMoveData(catalogInfo.extFinderInfo, extendedInfo, sizeof(ExtendedFinderInfo));
-       }
-       
-       /* set isDirectory Boolean if requested */
-       if ( NULL != isDirectory)
-       {
-               *isDirectory = (0 != (kFSNodeIsDirectoryMask & catalogInfo.nodeFlags));
-       }
-       
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetFinderInfo(
-       const FSRef *ref,
-       const FinderInfo *info,
-       const ExtendedFinderInfo *extendedInfo)
-{
-       OSErr                           result;
-       FSCatalogInfo           catalogInfo;
-       FSCatalogInfoBitmap whichInfo;
-       
-       /* determine what catalog information will be set */
-       whichInfo = kFSCatInfoNone; /* start with none */
-       if ( NULL != info )
-       {
-               /* set FinderInfo */
-               whichInfo |= kFSCatInfoFinderInfo;
-               BlockMoveData(info, catalogInfo.finderInfo, sizeof(FinderInfo));
-       }
-       if ( NULL != extendedInfo )
-       {
-               /* set ExtendedFinderInfo */
-               whichInfo |= kFSCatInfoFinderXInfo;
-               BlockMoveData(extendedInfo, catalogInfo.extFinderInfo, sizeof(ExtendedFinderInfo));
-       }
-       
-       result = FSSetCatalogInfo(ref, whichInfo, &catalogInfo);
-       require_noerr(result, FSGetCatalogInfo);
-       
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSChangeCreatorType(
-       const FSRef *ref,
-       OSType fileCreator,
-       OSType fileType)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       FSRef                   parentRef;
-       
-       /* get nodeFlags, finder info, and parent FSRef */
-       result = FSGetCatalogInfo(ref, kFSCatInfoNodeFlags + kFSCatInfoFinderInfo, &catalogInfo , NULL, NULL, &parentRef);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* make sure FSRef was to a file */
-       require_action(0 == (catalogInfo.nodeFlags & kFSNodeIsDirectoryMask), FSRefNotFile, result = notAFileErr);
-       
-       /* If fileType not 0x00000000, change fileType */
-       if ( fileType != (OSType)0x00000000 )
-       {
-               ((FileInfo *)&catalogInfo.finderInfo)->fileType = fileType;
-       }
-       
-       /* If creator not 0x00000000, change creator */
-       if ( fileCreator != (OSType)0x00000000 )
-       {
-               ((FileInfo *)&catalogInfo.finderInfo)->fileCreator = fileCreator;
-       }
-       
-       /* now, save the new information back to disk */
-       result = FSSetCatalogInfo(ref, kFSCatInfoFinderInfo, &catalogInfo);
-       require_noerr(result, FSSetCatalogInfo);
-       
-       /* and attempt to bump the parent directory's mod date to wake up */
-       /* the Finder to the change we just made (ignore errors from this) */
-       verify_noerr(FSBumpDate(&parentRef));
-       
-FSSetCatalogInfo:
-FSRefNotFile:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSChangeFinderFlags(
-       const FSRef *ref,
-       Boolean setBits,
-       UInt16 flagBits)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       FSRef                   parentRef;
-       
-       /* get the current finderInfo */
-       result = FSGetCatalogInfo(ref, kFSCatInfoFinderInfo, &catalogInfo, NULL, NULL, &parentRef);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* set or clear the appropriate bits in the finderInfo.finderFlags */
-       if ( setBits )
-       {
-               /* OR in the bits */
-               ((FileInfo *)&catalogInfo.finderInfo)->finderFlags |= flagBits;
-       }
-       else
-       {
-               /* AND out the bits */
-               ((FileInfo *)&catalogInfo.finderInfo)->finderFlags &= ~flagBits;
-       }
-       
-       /* save the modified finderInfo */
-       result = FSSetCatalogInfo(ref, kFSCatInfoFinderInfo, &catalogInfo);
-       require_noerr(result, FSSetCatalogInfo);
-       
-       /* and attempt to bump the parent directory's mod date to wake up the Finder */
-       /* to the change we just made (ignore errors from this) */
-       verify_noerr(FSBumpDate(&parentRef));
-       
-FSSetCatalogInfo:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetInvisible(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, true, kIsInvisible) );
-}
-
-OSErr
-FSClearInvisible(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, false, kIsInvisible) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetNameLocked(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, true, kNameLocked) );
-}
-
-OSErr
-FSClearNameLocked(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, false, kNameLocked) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetIsStationery(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, true, kIsStationery) );
-}
-
-OSErr
-FSClearIsStationery(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, false, kIsStationery) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetHasCustomIcon(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, true, kHasCustomIcon) );
-}
-
-OSErr
-FSClearHasCustomIcon(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, false, kHasCustomIcon) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSClearHasBeenInited(
-       const FSRef *ref)
-{
-       return ( FSChangeFinderFlags(ref, false, kHasBeenInited) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSCopyFileMgrAttributes(
-       const FSRef *sourceRef,
-       const FSRef *destinationRef,
-       Boolean copyLockBit)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       
-       /* get the source information */
-       result = FSGetCatalogInfo(sourceRef, kFSCatInfoSettableInfo, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* don't copy the hasBeenInited bit; clear it */
-       ((FileInfo *)&catalogInfo.finderInfo)->finderFlags &= ~kHasBeenInited;
-       
-       /* should the locked bit be copied? */
-       if ( !copyLockBit )
-       {
-               /* no, make sure the locked bit is clear */
-               catalogInfo.nodeFlags &= ~kFSNodeLockedMask;
-       }
-               
-       /* set the destination information */
-       result = FSSetCatalogInfo(destinationRef, kFSCatInfoSettableInfo, &catalogInfo);
-       require_noerr(result, FSSetCatalogInfo);
-       
-FSSetCatalogInfo:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSMoveRenameObjectUnicode(
-       const FSRef *ref,
-       const FSRef *destDirectory,
-       UniCharCount nameLength,
-       const UniChar *name,                    /* can be NULL (no rename during move) */
-       TextEncoding textEncodingHint,
-       FSRef *newRef)                                  /* if function fails along the way, newRef is final location of file */
-{
-       OSErr                   result;
-       FSVolumeRefNum  vRefNum;
-       FSCatalogInfo   catalogInfo;
-       FSRef                   originalDirectory;
-       TextEncoding    originalTextEncodingHint;
-       HFSUniStr255    originalName;
-       HFSUniStr255    uniqueName;             /* unique name given to object while moving it to destination */
-       long                    theSeed;                /* the seed for generating unique names */
-       
-       /* check parameters */
-       require_action(NULL != newRef, BadParameter, result = paramErr);
-       
-       /* newRef = input to start with */
-       BlockMoveData(ref, newRef, sizeof(FSRef));
-       
-       /* get destDirectory's vRefNum */
-       result = FSGetCatalogInfo(destDirectory, kFSCatInfoVolume, &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, DestinationBad);
-       
-       /* save vRefNum */
-       vRefNum = catalogInfo.volume;
-       
-       /* get ref's vRefNum, TextEncoding, name and parent directory*/
-       result = FSGetCatalogInfo(ref, kFSCatInfoTextEncoding + kFSCatInfoVolume, &catalogInfo, &originalName, NULL, &originalDirectory);
-       require_noerr(result, SourceBad);
-       
-       /* save TextEncoding */
-       originalTextEncodingHint = catalogInfo.textEncodingHint;
-       
-       /* make sure ref and destDirectory are on same volume */
-       require_action(vRefNum == catalogInfo.volume, NotSameVolume, result = diffVolErr);
-       
-       /* Skip a few steps if we're not renaming */
-       if ( NULL != name )
-       {
-               /* generate a name that is unique in both directories */
-               theSeed = 0x4a696d4c;   /* a fine unlikely filename */
-               
-               result = GenerateUniqueHFSUniStr(&theSeed, &originalDirectory, destDirectory, &uniqueName);
-               require_noerr(result, GenerateUniqueHFSUniStrFailed);
-               
-               /* Rename the object to uniqueName */
-               result = FSRenameUnicode(ref, uniqueName.length, uniqueName.unicode, kTextEncodingUnknown, newRef);
-               require_noerr(result, FSRenameUnicodeBeforeMoveFailed);
-               
-               /* Move object to its new home */
-               result = FSMoveObject(newRef, destDirectory, newRef);
-               require_noerr(result, FSMoveObjectAfterRenameFailed);
-               
-               /* Rename the object to new name */
-               result = FSRenameUnicode(ref, nameLength, name, textEncodingHint, newRef);
-               require_noerr(result, FSRenameUnicodeAfterMoveFailed);
-       }
-       else
-       {
-               /* Move object to its new home */
-               result = FSMoveObject(newRef, destDirectory, newRef);
-               require_noerr(result, FSMoveObjectNoRenameFailed);
-       }
-       
-       return ( result );
-       
-       /*************/
-
-/*
- * failure handling code when renaming
- */
-
-FSRenameUnicodeAfterMoveFailed:
-
-       /* Error handling: move object back to original location - ignore errors */
-       verify_noerr(FSMoveObject(newRef, &originalDirectory, newRef));
-       
-FSMoveObjectAfterRenameFailed:
-
-       /* Error handling: rename object back to original name - ignore errors */
-       verify_noerr(FSRenameUnicode(newRef, originalName.length, originalName.unicode, originalTextEncodingHint, newRef));
-       
-FSRenameUnicodeBeforeMoveFailed:
-GenerateUniqueHFSUniStrFailed:
-
-/*
- * failure handling code for renaming or not
- */
-FSMoveObjectNoRenameFailed:
-NotSameVolume:
-SourceBad:
-DestinationBad:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-/*
-       The FSDeleteContainerLevel function deletes the contents of a container
-       directory. All files and subdirectories in the specified container are
-       deleted. If a locked file or directory is encountered, it is unlocked
-       and then deleted. If any unexpected errors are encountered,
-       FSDeleteContainerLevel quits and returns to the caller.
-       
-       container                       --> FSRef to a directory.
-       theGlobals                      --> A pointer to a FSDeleteContainerGlobals struct
-                                                       which contains the variables that do not need to
-                                                       be allocated each time FSDeleteContainerLevel
-                                                       recurses. That lets FSDeleteContainerLevel use
-                                                       less stack space per recursion level.
-*/
-
-static
-void
-FSDeleteContainerLevel(
-       const FSRef *container,
-       FSDeleteContainerGlobals *theGlobals)
-{
-       /* level locals */
-       FSIterator                                      iterator;
-       FSRef                                           itemToDelete;
-       UInt16                                          nodeFlags;
-       
-       /* Open FSIterator for flat access and give delete optimization hint */
-       theGlobals->result = FSOpenIterator(container, kFSIterateFlat + kFSIterateDelete, &iterator);
-       require_noerr(theGlobals->result, FSOpenIterator);
-       
-       /* delete the contents of the directory */
-       do
-       {
-               /* get 1 item to delete */
-               theGlobals->result = FSGetCatalogInfoBulk(iterator, 1, &theGlobals->actualObjects,
-                                                               NULL, kFSCatInfoNodeFlags, &theGlobals->catalogInfo,
-                                                               &itemToDelete, NULL, NULL);
-               if ( (noErr == theGlobals->result) && (1 == theGlobals->actualObjects) )
-               {
-                       /* save node flags in local in case we have to recurse */
-                       nodeFlags = theGlobals->catalogInfo.nodeFlags;
-                       
-                       /* is it a file or directory? */
-                       if ( 0 != (nodeFlags & kFSNodeIsDirectoryMask) )
-                       {
-                               /* it's a directory -- delete its contents before attempting to delete it */
-                               FSDeleteContainerLevel(&itemToDelete, theGlobals);
-                       }
-                       /* are we still OK to delete? */
-                       if ( noErr == theGlobals->result )
-                       {
-                               /* is item locked? */
-                               if ( 0 != (nodeFlags & kFSNodeLockedMask) )
-                               {
-                                       /* then attempt to unlock it (ignore result since FSDeleteObject will set it correctly) */
-                                       theGlobals->catalogInfo.nodeFlags = nodeFlags & ~kFSNodeLockedMask;
-                                       (void) FSSetCatalogInfo(&itemToDelete, kFSCatInfoNodeFlags, &theGlobals->catalogInfo);
-                               }
-                               /* delete the item */
-                               theGlobals->result = FSDeleteObject(&itemToDelete);
-                       }
-               }
-       } while ( noErr == theGlobals->result );
-       
-       /* we found the end of the items normally, so return noErr */
-       if ( errFSNoMoreItems == theGlobals->result )
-       {
-               theGlobals->result = noErr;
-       }
-       
-       /* close the FSIterator (closing an open iterator should never fail) */
-       verify_noerr(FSCloseIterator(iterator));
-
-FSOpenIterator:
-
-       return;
-}
-
-/*****************************************************************************/
-
-OSErr
-FSDeleteContainerContents(
-       const FSRef *container)
-{
-       FSDeleteContainerGlobals        theGlobals;
-       
-       /* delete container's contents */
-       FSDeleteContainerLevel(container, &theGlobals);
-       
-       return ( theGlobals.result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSDeleteContainer(
-       const FSRef *container)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       
-       /* get nodeFlags for container */
-       result = FSGetCatalogInfo(container, kFSCatInfoNodeFlags, &catalogInfo, NULL, NULL,NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* make sure container is a directory */
-       require_action(0 != (catalogInfo.nodeFlags & kFSNodeIsDirectoryMask), ContainerNotDirectory, result = dirNFErr);
-       
-       /* delete container's contents */
-       result = FSDeleteContainerContents(container);
-       require_noerr(result, FSDeleteContainerContents);
-       
-       /* is container locked? */
-       if ( 0 != (catalogInfo.nodeFlags & kFSNodeLockedMask) )
-       {
-               /* then attempt to unlock container (ignore result since FSDeleteObject will set it correctly) */
-               catalogInfo.nodeFlags &= ~kFSNodeLockedMask;
-               (void) FSSetCatalogInfo(container, kFSCatInfoNodeFlags, &catalogInfo);
-       }
-       
-       /* delete the container */
-       result = FSDeleteObject(container);
-       
-FSDeleteContainerContents:
-ContainerNotDirectory:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-/*
-       The FSIterateContainerLevel function iterates the contents of a container
-       directory and calls a IterateContainerFilterProc function once for each
-       file and directory found.
-       
-       theGlobals                      --> A pointer to a FSIterateContainerGlobals struct
-                                                       which contains the variables needed globally by
-                                                       all recusion levels of FSIterateContainerLevel.
-                                                       That makes FSIterateContainer thread safe since
-                                                       each call to it uses its own global world.
-                                                       It also contains the variables that do not need
-                                                       to be allocated each time FSIterateContainerLevel
-                                                       recurses. That lets FSIterateContainerLevel use
-                                                       less stack space per recursion level.
-*/
-
-static
-void
-FSIterateContainerLevel(
-       FSIterateContainerGlobals *theGlobals)
-{      
-       FSIterator      iterator;
-       
-       /* If maxLevels is zero, we aren't checking levels */
-       /* If currentLevel < maxLevels, look at this level */
-       if ( (theGlobals->maxLevels == 0) ||
-                (theGlobals->currentLevel < theGlobals->maxLevels) )
-       {
-               /* Open FSIterator for flat access to theGlobals->ref */
-               theGlobals->result = FSOpenIterator(&theGlobals->ref, kFSIterateFlat, &iterator);
-               require_noerr(theGlobals->result, FSOpenIterator);
-               
-               ++theGlobals->currentLevel; /* Go to next level */
-               
-               /* Call FSGetCatalogInfoBulk in loop to get all items in the container */
-               do
-               {
-                       theGlobals->result = FSGetCatalogInfoBulk(iterator, 1, &theGlobals->actualObjects,
-                               &theGlobals->containerChanged, theGlobals->whichInfo, &theGlobals->catalogInfo,
-                               &theGlobals->ref, theGlobals->specPtr, theGlobals->namePtr);
-                       if ( (noErr == theGlobals->result || errFSNoMoreItems == theGlobals->result) &&
-                               (0 != theGlobals->actualObjects) )
-                       {
-                               /* Call the IterateFilterProc */
-                               theGlobals->quitFlag = CallIterateContainerFilterProc(theGlobals->iterateFilter,
-                                       theGlobals->containerChanged, theGlobals->currentLevel,
-                                       &theGlobals->catalogInfo, &theGlobals->ref,
-                                       theGlobals->specPtr, theGlobals->namePtr, theGlobals->yourDataPtr);
-                               /* Is it a directory? */
-                               if ( 0 != (theGlobals->catalogInfo.nodeFlags & kFSNodeIsDirectoryMask) )
-                               {
-                                       /* Keep going? */
-                                       if ( !theGlobals->quitFlag )
-                                       {
-                                               /* Dive again if the IterateFilterProc didn't say "quit" */
-                                               FSIterateContainerLevel(theGlobals);
-                                       }
-                               }
-                       }
-                       /* time to fall back a level? */
-               } while ( (noErr == theGlobals->result) && (!theGlobals->quitFlag) );
-               
-               /* errFSNoMoreItems is OK - it only means we hit the end of this level */
-               /* afpAccessDenied is OK, too - it only means we cannot see inside a directory */
-               if ( (errFSNoMoreItems == theGlobals->result) ||
-                        (afpAccessDenied == theGlobals->result) )
-               {
-                       theGlobals->result = noErr;
-               }
-               
-               --theGlobals->currentLevel; /* Return to previous level as we leave */
-               
-               /* Close the FSIterator (closing an open iterator should never fail) */
-               verify_noerr(FSCloseIterator(iterator));
-       }
-       
-FSOpenIterator:
-
-       return;
-}
-
-/*****************************************************************************/
-
-OSErr
-FSIterateContainer(
-       const FSRef *container,
-       ItemCount maxLevels,
-       FSCatalogInfoBitmap whichInfo,
-       Boolean wantFSSpec,
-       Boolean wantName,
-       IterateContainerFilterProcPtr iterateFilter,
-       void *yourDataPtr)
-{
-       OSErr                                           result;
-       FSIterateContainerGlobals       theGlobals;
-       
-       /* make sure there is an iterateFilter */
-       require_action(iterateFilter != NULL, NoIterateFilter, result = paramErr);
-       
-       /*
-        * set up the globals we need to access from the recursive routine
-        */
-       theGlobals.iterateFilter = iterateFilter;
-       /* we need the node flags no matter what was requested so we can detect files vs. directories */
-       theGlobals.whichInfo = whichInfo | kFSCatInfoNodeFlags;
-       /* start with input container -- the first OpenIterator will ensure it is a directory */
-       theGlobals.ref = *container;
-       if ( wantFSSpec )
-       {
-               theGlobals.specPtr = &theGlobals.spec;
-       }
-       else
-       {
-               theGlobals.specPtr = NULL;
-       }
-       if ( wantName )
-       {
-               theGlobals.namePtr = &theGlobals.name;
-       }
-       else
-       {
-               theGlobals.namePtr = NULL;
-       }
-       theGlobals.yourDataPtr = yourDataPtr;
-       theGlobals.maxLevels = maxLevels;
-       theGlobals.currentLevel = 0;
-       theGlobals.quitFlag = false;
-       theGlobals.containerChanged = false;
-       theGlobals.result = noErr;
-       theGlobals.actualObjects = 0;
-       
-       /* here we go into recursion land... */
-       FSIterateContainerLevel(&theGlobals);
-       result = theGlobals.result;
-       require_noerr(result, FSIterateContainerLevel);
-       
-FSIterateContainerLevel:
-NoIterateFilter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetDirectoryItems(
-       const FSRef *container,
-       FSRef ***refsHandle,    /* pointer to handle of FSRefs */
-       ItemCount *numRefs,
-       Boolean *containerChanged)
-{
-       /* Grab items 10 at a time. */
-       enum { kMaxItemsPerBulkCall = 10 };
-       
-       OSErr           result;
-       OSErr           memResult;
-       FSIterator      iterator;
-       FSRef           refs[kMaxItemsPerBulkCall];
-       ItemCount       actualObjects;
-       Boolean         changed;
-       
-       /* check parameters */
-       require_action((NULL != refsHandle) && (NULL != numRefs) && (NULL != containerChanged),
-               BadParameter, result = paramErr);
-       
-       *numRefs = 0;
-       *containerChanged = false;
-       *refsHandle = (FSRef **)NewHandle(0);
-       require_action(NULL != *refsHandle, NewHandle, result = memFullErr);
-       
-       /* open an FSIterator */
-       result = FSOpenIterator(container, kFSIterateFlat, &iterator);
-       require_noerr(result, FSOpenIterator);
-       
-       /* Call FSGetCatalogInfoBulk in loop to get all items in the container */
-       do
-       {
-               result = FSGetCatalogInfoBulk(iterator, kMaxItemsPerBulkCall, &actualObjects,
-                                       &changed, kFSCatInfoNone,  NULL,  refs, NULL, NULL);
-               
-               /* if the container changed, set containerChanged for output, but keep going */
-               if ( changed )
-               {
-                       *containerChanged = changed;
-               }
-               
-               /* any result other than noErr and errFSNoMoreItems is serious */
-               require((noErr == result) || (errFSNoMoreItems == result), FSGetCatalogInfoBulk);
-               
-               /* add objects to output array and count */
-               if ( 0 != actualObjects )
-               {
-                       /* concatenate the FSRefs to the end of the      handle */
-                       PtrAndHand(refs, (Handle)*refsHandle, actualObjects * sizeof(FSRef));
-                       memResult = MemError();
-                       require_noerr_action(memResult, MemoryAllocationFailed, result = memResult);
-                       
-                       *numRefs += actualObjects;
-               }
-       } while ( noErr == result );
-       
-       verify_noerr(FSCloseIterator(iterator)); /* closing an open iterator should never fail, but... */
-       
-       return ( noErr );
-       
-       /**********************/
-       
-MemoryAllocationFailed:
-FSGetCatalogInfoBulk:
-
-       /* close the iterator */
-       verify_noerr(FSCloseIterator(iterator));
-
-FSOpenIterator:
-       /* dispose of handle if already allocated and clear the outputs */
-       if ( NULL != *refsHandle )
-       {
-               DisposeHandle((Handle)*refsHandle);
-               *refsHandle = NULL;
-       }
-       *numRefs = 0;
-       
-NewHandle:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-/*
-       The GenerateUniqueName function generates a HFSUniStr255 name that is
-       unique in both dir1 and dir2.
-       
-       startSeed                       -->     A pointer to a long which is used to generate the
-                                                       unique name.
-                                               <--     It is modified on output to a value which should
-                                                       be used to generate the next unique name.
-       dir1                            -->     The first directory.
-       dir2                            -->     The second directory.
-       uniqueName                      <--     A pointer to a HFSUniStr255 where the unique name
-                                                       is to be returned.
-*/
-
-static
-OSErr
-GenerateUniqueHFSUniStr(
-       long *startSeed,
-       const FSRef *dir1,
-       const FSRef *dir2,
-       HFSUniStr255 *uniqueName)
-{
-       OSErr                   result;
-       long                    i;
-       FSRefParam              pb;
-       FSRef                   newRef;
-       unsigned char   hexStr[17] = "0123456789ABCDEF";
-       
-       /* set up the parameter block */
-       pb.name = uniqueName->unicode;
-       pb.nameLength = 8;      /* always 8 characters */
-       pb.textEncodingHint = kTextEncodingUnknown;
-       pb.newRef = &newRef;
-
-       /* loop until we get fnfErr with a filename in both directories */
-       result = noErr;
-       while ( fnfErr != result )
-       {
-               /* convert startSeed to 8 character Unicode string */
-               uniqueName->length = 8;
-               for ( i = 0; i < 8; ++i )
-               {
-                       uniqueName->unicode[i] = hexStr[((*startSeed >> ((7-i)*4)) & 0xf)];
-               }
-               
-               /* try in dir1 */
-               pb.ref = dir1;
-               result = PBMakeFSRefUnicodeSync(&pb);
-               if ( fnfErr == result )
-               {
-                       /* try in dir2 */
-                       pb.ref = dir2;
-                       result = PBMakeFSRefUnicodeSync(&pb);
-                       if ( fnfErr != result )
-                       {
-                               /* exit if anything other than noErr or fnfErr */
-                               require_noerr(result, Dir2PBMakeFSRefUnicodeSyncFailed);
-                       }
-               }
-               else
-               {
-                       /* exit if anything other than noErr or fnfErr */
-                       require_noerr(result, Dir1PBMakeFSRefUnicodeSyncFailed);
-               }
-               
-               /* increment seed for next pass through loop, */
-               /* or for next call to GenerateUniqueHFSUniStr */
-               ++(*startSeed);
-       }
-       
-       /* we have a unique file name which doesn't exist in dir1 or dir2 */
-       result = noErr;
-       
-Dir2PBMakeFSRefUnicodeSyncFailed:
-Dir1PBMakeFSRefUnicodeSyncFailed:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSExchangeObjectsCompat(
-       const FSRef *sourceRef,
-       const FSRef *destRef,
-       FSRef *newSourceRef,
-       FSRef *newDestRef)
-{
-       enum
-       {
-               /* get all settable info except for mod dates, plus the volume refNum and parent directory ID */
-               kGetCatInformationMask = (kFSCatInfoSettableInfo |
-                                                                 kFSCatInfoVolume |
-                                                                 kFSCatInfoParentDirID) &
-                                                                ~(kFSCatInfoContentMod | kFSCatInfoAttrMod),
-               /* set everything possible except for mod dates */
-               kSetCatinformationMask = kFSCatInfoSettableInfo &
-                                                                ~(kFSCatInfoContentMod | kFSCatInfoAttrMod)
-       };
-       
-       OSErr                                   result;
-       GetVolParmsInfoBuffer   volParmsInfo;
-       UInt32                                  infoSize;
-       FSCatalogInfo                   sourceCatalogInfo;      /* source file's catalog information */
-       FSCatalogInfo                   destCatalogInfo;        /* destination file's catalog information */
-       HFSUniStr255                    sourceName;                     /* source file's Unicode name */
-       HFSUniStr255                    destName;                       /* destination file's Unicode name */
-       FSRef                                   sourceCurrentRef;       /* FSRef to current location of source file throughout this function */
-       FSRef                                   destCurrentRef;         /* FSRef to current location of destination file throughout this function */
-       FSRef                                   sourceParentRef;        /* FSRef to parent directory of source file */
-       FSRef                                   destParentRef;          /* FSRef to parent directory of destination file */
-       HFSUniStr255                    sourceUniqueName;       /* unique name given to source file while exchanging it with destination */
-       HFSUniStr255                    destUniqueName;         /* unique name given to destination file while exchanging it with source */
-       long                                    theSeed;                        /* the seed for generating unique names */
-       Boolean                                 sameParentDirs;         /* true if source and destinatin parent directory is the same */
-       
-       /* check parameters */
-       require_action((NULL != newSourceRef) && (NULL != newDestRef), BadParameter, result = paramErr);
-       
-       /* output refs and current refs = input refs to start with */
-       BlockMoveData(sourceRef, newSourceRef, sizeof(FSRef));
-       BlockMoveData(sourceRef, &sourceCurrentRef, sizeof(FSRef));
-       
-       BlockMoveData(destRef, newDestRef, sizeof(FSRef));
-       BlockMoveData(destRef, &destCurrentRef, sizeof(FSRef));
-
-       /* get source volume's vRefNum */
-       result = FSGetCatalogInfo(&sourceCurrentRef, kFSCatInfoVolume, &sourceCatalogInfo, NULL, NULL, NULL);
-       require_noerr(result, DetermineSourceVRefNumFailed);
-       
-       /* see if that volume supports FSExchangeObjects */
-       result = FSGetVolParms(sourceCatalogInfo.volume, sizeof(GetVolParmsInfoBuffer),
-               &volParmsInfo, &infoSize);
-       if ( (noErr == result) && VolSupportsFSExchangeObjects(&volParmsInfo) )
-       {
-               /* yes - use FSExchangeObjects */
-               result = FSExchangeObjects(sourceRef, destRef);
-       }
-       else
-       {
-               /* no - emulate FSExchangeObjects */
-               
-               /* Note: The compatibility case won't work for files with *Btree control blocks. */
-               /* Right now the only *Btree files are created by the system. */
-               
-               /* get all catalog information and Unicode names for each file */
-               result = FSGetCatalogInfo(&sourceCurrentRef, kGetCatInformationMask, &sourceCatalogInfo, &sourceName, NULL, &sourceParentRef);
-               require_noerr(result, SourceFSGetCatalogInfoFailed);
-               
-               result = FSGetCatalogInfo(&destCurrentRef, kGetCatInformationMask, &destCatalogInfo, &destName, NULL, &destParentRef);
-               require_noerr(result, DestFSGetCatalogInfoFailed);
-               
-               /* make sure source and destination are on same volume */
-               require_action(sourceCatalogInfo.volume == destCatalogInfo.volume, NotSameVolume, result = diffVolErr);
-               
-               /* make sure both files are *really* files */
-               require_action((0 == (sourceCatalogInfo.nodeFlags & kFSNodeIsDirectoryMask)) &&
-                                          (0 == (destCatalogInfo.nodeFlags & kFSNodeIsDirectoryMask)), NotAFile, result = notAFileErr);
-               
-               /* generate 2 names that are unique in both directories */
-               theSeed = 0x4a696d4c;   /* a fine unlikely filename */
-               
-               result = GenerateUniqueHFSUniStr(&theSeed, &sourceParentRef, &destParentRef, &sourceUniqueName);
-               require_noerr(result, GenerateUniqueHFSUniStr1Failed);
-               
-               result = GenerateUniqueHFSUniStr(&theSeed, &sourceParentRef, &destParentRef, &destUniqueName);
-               require_noerr(result, GenerateUniqueHFSUniStr2Failed);
-
-               /* rename sourceCurrentRef to sourceUniqueName */
-               result = FSRenameUnicode(&sourceCurrentRef, sourceUniqueName.length, sourceUniqueName.unicode, kTextEncodingUnknown, newSourceRef);
-               require_noerr(result, FSRenameUnicode1Failed);
-               BlockMoveData(newSourceRef, &sourceCurrentRef, sizeof(FSRef));
-               
-               /* rename destCurrentRef to destUniqueName */
-               result = FSRenameUnicode(&destCurrentRef, destUniqueName.length, destUniqueName.unicode, kTextEncodingUnknown, newDestRef);
-               require_noerr(result, FSRenameUnicode2Failed);
-               BlockMoveData(newDestRef, &destCurrentRef, sizeof(FSRef));
-               
-               /* are the source and destination parent directories the same? */
-               sameParentDirs = ( sourceCatalogInfo.parentDirID == destCatalogInfo.parentDirID );
-               if ( !sameParentDirs )
-               {
-                       /* move source file to dest parent directory */
-                       result = FSMoveObject(&sourceCurrentRef, &destParentRef, newSourceRef);
-                       require_noerr(result, FSMoveObject1Failed);
-                       BlockMoveData(newSourceRef, &sourceCurrentRef, sizeof(FSRef));
-                       
-                       /* move dest file to source parent directory */
-                       result = FSMoveObject(&destCurrentRef, &sourceParentRef, newDestRef);
-                       require_noerr(result, FSMoveObject2Failed);
-                       BlockMoveData(newDestRef, &destCurrentRef, sizeof(FSRef));
-               }
-               
-               /* At this point, the files are in their new locations (if they were moved). */
-               /* The source file is named sourceUniqueName and is in the directory referred to */
-               /* by destParentRef. The destination file is named destUniqueName and is in the */
-               /* directory referred to by sourceParentRef. */
-                               
-               /* give source file the dest file's catalog information except for mod dates */
-               result = FSSetCatalogInfo(&sourceCurrentRef, kSetCatinformationMask, &destCatalogInfo);
-               require_noerr(result, FSSetCatalogInfo1Failed);
-               
-               /* give dest file the source file's catalog information except for mod dates */
-               result = FSSetCatalogInfo(&destCurrentRef, kSetCatinformationMask, &sourceCatalogInfo);
-               require_noerr(result, FSSetCatalogInfo2Failed);
-               
-               /* rename source file with dest file's name */
-               result = FSRenameUnicode(&sourceCurrentRef, destName.length, destName.unicode, destCatalogInfo.textEncodingHint, newSourceRef);
-               require_noerr(result, FSRenameUnicode3Failed);
-               BlockMoveData(newSourceRef, &sourceCurrentRef, sizeof(FSRef));
-               
-               /* rename dest file with source file's name */
-               result = FSRenameUnicode(&destCurrentRef, sourceName.length, sourceName.unicode, sourceCatalogInfo.textEncodingHint, newDestRef);
-               require_noerr(result, FSRenameUnicode4Failed);
-               
-               /* we're done with no errors, so swap newSourceRef and newDestRef */
-               BlockMoveData(newDestRef, newSourceRef, sizeof(FSRef));
-               BlockMoveData(&sourceCurrentRef, newDestRef, sizeof(FSRef));
-       }
-       
-       return ( result );
-       
-       /**********************/
-
-/* If there are any failures while emulating FSExchangeObjects, attempt to reverse any steps */
-/* already taken. In any case, newSourceRef and newDestRef will refer to the files in whatever */
-/* state and location they ended up in so that both files can be found by the calling code. */
-       
-FSRenameUnicode4Failed:
-
-       /* attempt to rename source file to sourceUniqueName */
-       if ( noErr == FSRenameUnicode(&sourceCurrentRef, sourceUniqueName.length, sourceUniqueName.unicode, kTextEncodingUnknown, newSourceRef) )
-       {
-               BlockMoveData(newSourceRef, &sourceCurrentRef, sizeof(FSRef));
-       }
-
-FSRenameUnicode3Failed:
-
-       /* attempt to restore dest file's catalog information */
-       verify_noerr(FSSetCatalogInfo(&destCurrentRef, kFSCatInfoSettableInfo, &destCatalogInfo));
-
-FSSetCatalogInfo2Failed:
-
-       /* attempt to restore source file's catalog information */
-       verify_noerr(FSSetCatalogInfo(&sourceCurrentRef, kFSCatInfoSettableInfo, &sourceCatalogInfo));
-
-FSSetCatalogInfo1Failed:
-
-       if ( !sameParentDirs )
-       {
-               /* attempt to move dest file back to dest directory */
-               if ( noErr == FSMoveObject(&destCurrentRef, &destParentRef, newDestRef) )
-               {
-                       BlockMoveData(newDestRef, &destCurrentRef, sizeof(FSRef));
-               }
-       }
-
-FSMoveObject2Failed:
-
-       if ( !sameParentDirs )
-       {
-               /* attempt to move source file back to source directory */
-               if ( noErr == FSMoveObject(&sourceCurrentRef, &sourceParentRef, newSourceRef) )
-               {
-                       BlockMoveData(newSourceRef, &sourceCurrentRef, sizeof(FSRef));
-               }
-       }
-
-FSMoveObject1Failed:
-
-       /* attempt to rename dest file to original name */
-       verify_noerr(FSRenameUnicode(&destCurrentRef, destName.length, destName.unicode, destCatalogInfo.textEncodingHint, newDestRef));
-
-FSRenameUnicode2Failed:
-
-       /* attempt to rename source file to original name */
-       verify_noerr(FSRenameUnicode(&sourceCurrentRef, sourceName.length, sourceName.unicode, sourceCatalogInfo.textEncodingHint, newSourceRef));
-
-FSRenameUnicode1Failed:
-GenerateUniqueHFSUniStr2Failed:
-GenerateUniqueHFSUniStr1Failed:
-NotAFile:
-NotSameVolume:
-DestFSGetCatalogInfoFailed:
-SourceFSGetCatalogInfoFailed:
-DetermineSourceVRefNumFailed:  
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-#pragma mark ----- Shared Environment Routines -----
-
-/*****************************************************************************/
-
-OSErr
-FSLockRange(
-       SInt16 refNum,
-       SInt32 rangeLength,
-       SInt32 rangeStart)
-{
-       OSErr                   result;
-       ParamBlockRec   pb;
-
-       pb.ioParam.ioRefNum = refNum;
-       pb.ioParam.ioReqCount = rangeLength;
-       pb.ioParam.ioPosMode = fsFromStart;
-       pb.ioParam.ioPosOffset = rangeStart;
-       result = PBLockRangeSync(&pb);
-       require_noerr(result, PBLockRangeSync);
-       
-PBLockRangeSync:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSUnlockRange(
-       SInt16 refNum,
-       SInt32 rangeLength,
-       SInt32 rangeStart)
-{
-       OSErr                   result;
-       ParamBlockRec   pb;
-
-       pb.ioParam.ioRefNum = refNum;
-       pb.ioParam.ioReqCount = rangeLength;
-       pb.ioParam.ioPosMode = fsFromStart;
-       pb.ioParam.ioPosOffset = rangeStart;
-       result = PBUnlockRangeSync(&pb);
-       require_noerr(result, PBUnlockRangeSync);
-       
-PBUnlockRangeSync:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetDirAccess(
-       const FSRef *ref,
-       SInt32 *ownerID,                /* can be NULL */
-       SInt32 *groupID,                /* can be NULL */
-       SInt32 *accessRights)   /* can be NULL */
-{
-       OSErr                   result;
-       FSSpec                  spec;
-       HParamBlockRec  pb;
-       
-       /* get FSSpec from FSRef */
-       result = FSGetCatalogInfo(ref, kFSCatInfoNone, NULL, NULL, &spec, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* get directory access info for FSSpec */
-       pb.accessParam.ioNamePtr = (StringPtr)spec.name;
-       pb.accessParam.ioVRefNum = spec.vRefNum;
-       pb.fileParam.ioDirID = spec.parID;
-       result = PBHGetDirAccessSync(&pb);
-       require_noerr(result, PBHGetDirAccessSync);
-       
-       /* return the IDs and access rights */
-       if ( NULL != ownerID )
-       {
-               *ownerID = pb.accessParam.ioACOwnerID;
-       }
-       if ( NULL != groupID )
-       {
-               *groupID = pb.accessParam.ioACGroupID;
-       }
-       if ( NULL != accessRights )
-       {
-               *accessRights = pb.accessParam.ioACAccess;
-       }
-       
-PBHGetDirAccessSync:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetDirAccess(
-       const FSRef *ref,
-       SInt32 ownerID,
-       SInt32 groupID,
-       SInt32 accessRights)
-{
-       OSErr                   result;
-       FSSpec                  spec;
-       HParamBlockRec  pb;
-
-       enum
-       {
-               /* Just the bits that can be set */
-               kSetDirAccessSettableMask = (kioACAccessBlankAccessMask +
-                       kioACAccessEveryoneWriteMask + kioACAccessEveryoneReadMask + kioACAccessEveryoneSearchMask +
-                       kioACAccessGroupWriteMask + kioACAccessGroupReadMask + kioACAccessGroupSearchMask +
-                       kioACAccessOwnerWriteMask + kioACAccessOwnerReadMask + kioACAccessOwnerSearchMask)
-       };
-       
-       /* get FSSpec from FSRef */
-       result = FSGetCatalogInfo(ref, kFSCatInfoNone, NULL, NULL, &spec, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* set directory access info for FSSpec */
-       pb.accessParam.ioNamePtr = (StringPtr)spec.name;
-       pb.accessParam.ioVRefNum = spec.vRefNum;
-       pb.fileParam.ioDirID = spec.parID;
-       pb.accessParam.ioACOwnerID = ownerID;
-       pb.accessParam.ioACGroupID = groupID;
-       pb.accessParam.ioACAccess = accessRights & kSetDirAccessSettableMask;
-       result = PBHSetDirAccessSync(&pb);
-       require_noerr(result, PBHSetDirAccessSync);
-       
-PBHSetDirAccessSync:
-FSGetCatalogInfo:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetVolMountInfoSize(
-       FSVolumeRefNum volRefNum,
-       SInt16 *size)
-{
-       OSErr                   result;
-       ParamBlockRec   pb;
-
-       /* check parameters */
-       require_action(NULL != size, BadParameter, result = paramErr);
-       
-       pb.ioParam.ioNamePtr = NULL;
-       pb.ioParam.ioVRefNum = volRefNum;
-       pb.ioParam.ioBuffer = (Ptr)size;
-       result = PBGetVolMountInfoSize(&pb);
-       require_noerr(result, PBGetVolMountInfoSize);
-       
-PBGetVolMountInfoSize:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSGetVolMountInfo(
-       FSVolumeRefNum volRefNum,
-       void *volMountInfo)
-{
-       OSErr                   result;
-       ParamBlockRec   pb;
-
-       /* check parameters */
-       require_action(NULL != volMountInfo, BadParameter, result = paramErr);
-       
-       pb.ioParam.ioNamePtr = NULL;
-       pb.ioParam.ioVRefNum = volRefNum;
-       pb.ioParam.ioBuffer = (Ptr)volMountInfo;
-       result = PBGetVolMountInfo(&pb);
-       require_noerr(result, PBGetVolMountInfo);
-       
-PBGetVolMountInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSVolumeMount(
-       const void *volMountInfo,
-       FSVolumeRefNum *volRefNum)
-{
-       OSErr                   result;
-       ParamBlockRec   pb;
-
-       /* check parameters */
-       require_action(NULL != volRefNum, BadParameter, result = paramErr);
-       
-       pb.ioParam.ioBuffer = (Ptr)volMountInfo;
-       result = PBVolumeMount(&pb);
-       require_noerr(result, PBVolumeMount);
-       
-       /* return the volume reference number */
-       *volRefNum = pb.ioParam.ioVRefNum;
-
-PBVolumeMount:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSMapID(
-       FSVolumeRefNum volRefNum,
-       SInt32 ugID,
-       SInt16 objType,
-       Str31 name)
-{
-       OSErr                   result;
-       HParamBlockRec  pb;
-
-       /* check parameters */
-       require_action(NULL != name, BadParameter, result = paramErr);
-       
-       pb.objParam.ioNamePtr = NULL;
-       pb.objParam.ioVRefNum = volRefNum;
-       pb.objParam.ioObjType = objType;
-       pb.objParam.ioObjNamePtr = name;
-       pb.objParam.ioObjID = ugID;
-       result = PBHMapIDSync(&pb);
-       require_noerr(result, PBHMapIDSync);
-       
-PBHMapIDSync:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSMapName(
-       FSVolumeRefNum volRefNum,
-       ConstStr255Param name,
-       SInt16 objType,
-       SInt32 *ugID)
-{
-       OSErr                   result;
-       HParamBlockRec  pb;
-
-       /* check parameters */
-       require_action(NULL != ugID, BadParameter, result = paramErr);
-       
-       pb.objParam.ioNamePtr = NULL;
-       pb.objParam.ioVRefNum = volRefNum;
-       pb.objParam.ioObjType = objType;
-       pb.objParam.ioObjNamePtr = (StringPtr)name;
-       result = PBHMapNameSync(&pb);
-       require_noerr(result, PBHMapNameSync);
-       
-       /* return the user or group ID */
-       *ugID = pb.objParam.ioObjID;
-       
-PBHMapNameSync:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSCopyFile(
-       const FSRef *srcFileRef,
-       const FSRef *dstDirectoryRef,
-       UniCharCount nameLength,
-       const UniChar *copyName,        /* can be NULL (no rename during copy) */
-       TextEncoding textEncodingHint,
-       FSRef *newRef)                          /* can be NULL */
-{
-       OSErr                                   result;
-       FSSpec                                  srcFileSpec;
-       FSCatalogInfo                   catalogInfo;
-       HParamBlockRec                  pb;
-       Str31                                   hfsName;
-       GetVolParmsInfoBuffer   volParmsInfo;
-       UInt32                                  infoSize;
-       
-       /* get source FSSpec from source FSRef */
-       result = FSGetCatalogInfo(srcFileRef, kFSCatInfoNone, NULL, NULL, &srcFileSpec, NULL);
-       require_noerr(result, FSGetCatalogInfo_srcFileRef);
-       
-       /* Make sure the volume supports CopyFile */
-       result = FSGetVolParms(srcFileSpec.vRefNum, sizeof(GetVolParmsInfoBuffer),
-               &volParmsInfo, &infoSize);
-       require_action((noErr == result) && VolHasCopyFile(&volParmsInfo),
-               NoCopyFileSupport, result = paramErr);
-
-       /* get destination volume reference number and destination directory ID from destination FSRef */
-       result = FSGetCatalogInfo(dstDirectoryRef, kFSCatInfoVolume + kFSCatInfoNodeID,
-               &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo_dstDirectoryRef);
-       
-       /* tell the server to copy the object */
-       pb.copyParam.ioVRefNum = srcFileSpec.vRefNum;
-       pb.copyParam.ioDirID = srcFileSpec.parID;
-       pb.copyParam.ioNamePtr = (StringPtr)srcFileSpec.name;
-       pb.copyParam.ioDstVRefNum = catalogInfo.volume;
-       pb.copyParam.ioNewDirID = (long)catalogInfo.nodeID;
-       pb.copyParam.ioNewName = NULL;
-       if ( NULL != copyName )
-       {
-               result = UnicodeNameGetHFSName(nameLength, copyName, textEncodingHint, false, hfsName);
-               require_noerr(result, UnicodeNameGetHFSName);
-               
-               pb.copyParam.ioCopyName = hfsName;
-       }
-       else
-       {
-               pb.copyParam.ioCopyName = NULL;
-       }
-       result = PBHCopyFileSync(&pb);
-       require_noerr(result, PBHCopyFileSync);
-       
-       if ( NULL != newRef )
-       {
-               verify_noerr(FSMakeFSRef(pb.copyParam.ioDstVRefNum, pb.copyParam.ioNewDirID,
-                       pb.copyParam.ioCopyName, newRef));
-       }
-               
-PBHCopyFileSync:
-UnicodeNameGetHFSName:
-FSGetCatalogInfo_dstDirectoryRef:
-NoCopyFileSupport:
-FSGetCatalogInfo_srcFileRef:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSMoveRename(
-       const FSRef *srcFileRef,
-       const FSRef *dstDirectoryRef,
-       UniCharCount nameLength,
-       const UniChar *moveName,        /* can be NULL (no rename during move) */
-       TextEncoding textEncodingHint,
-       FSRef *newRef)                          /* can be NULL */
-{
-       OSErr                                   result;
-       FSSpec                                  srcFileSpec;
-       FSCatalogInfo                   catalogInfo;
-       HParamBlockRec                  pb;
-       Str31                                   hfsName;
-       GetVolParmsInfoBuffer   volParmsInfo;
-       UInt32                                  infoSize;
-       
-       /* get source FSSpec from source FSRef */
-       result = FSGetCatalogInfo(srcFileRef, kFSCatInfoNone, NULL, NULL, &srcFileSpec, NULL);
-       require_noerr(result, FSGetCatalogInfo_srcFileRef);
-       
-       /* Make sure the volume supports MoveRename */
-       result = FSGetVolParms(srcFileSpec.vRefNum, sizeof(GetVolParmsInfoBuffer),
-               &volParmsInfo, &infoSize);
-       require_action((noErr == result) && VolHasMoveRename(&volParmsInfo),
-               NoMoveRenameSupport, result = paramErr);
-
-       /* get destination volume reference number and destination directory ID from destination FSRef */
-       result = FSGetCatalogInfo(dstDirectoryRef, kFSCatInfoVolume + kFSCatInfoNodeID,
-               &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo_dstDirectoryRef);
-       
-       /* make sure the source and destination are on the same volume */
-       require_action(srcFileSpec.vRefNum == catalogInfo.volume, NotSameVolume, result = diffVolErr);
-       
-       /* tell the server to move and rename the object */
-       pb.copyParam.ioVRefNum = srcFileSpec.vRefNum;
-       pb.copyParam.ioDirID = srcFileSpec.parID;
-       pb.copyParam.ioNamePtr = (StringPtr)srcFileSpec.name;
-       pb.copyParam.ioNewDirID = (long)catalogInfo.nodeID;
-       pb.copyParam.ioNewName = NULL;
-       if ( NULL != moveName )
-       {
-               result = UnicodeNameGetHFSName(nameLength, moveName, textEncodingHint, false, hfsName);
-               require_noerr(result, UnicodeNameGetHFSName);
-               
-               pb.copyParam.ioCopyName = hfsName;
-       }
-       else
-       {
-               pb.copyParam.ioCopyName = NULL;
-       }
-       result = PBHMoveRenameSync(&pb);
-       require_noerr(result, PBHMoveRenameSync);
-       
-       if ( NULL != newRef )
-       {
-               verify_noerr(FSMakeFSRef(pb.copyParam.ioVRefNum, pb.copyParam.ioNewDirID,
-                       pb.copyParam.ioCopyName, newRef));
-       }
-       
-PBHMoveRenameSync:
-UnicodeNameGetHFSName:
-NotSameVolume:
-FSGetCatalogInfo_dstDirectoryRef:
-NoMoveRenameSupport:
-FSGetCatalogInfo_srcFileRef:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-#pragma mark ----- File ID Routines -----
-
-/*****************************************************************************/
-
-OSErr
-FSResolveFileIDRef(
-       FSVolumeRefNum volRefNum,
-       SInt32 fileID,
-       FSRef *ref)
-{
-       OSErr           result;
-       FIDParam        pb;
-       Str255          tempStr;
-       
-       /* check parameters */
-       require_action(NULL != ref, BadParameter, result = paramErr);
-       
-       /* resolve the file ID reference */
-       tempStr[0] = 0;
-       pb.ioNamePtr = tempStr;
-       pb.ioVRefNum = volRefNum;
-       pb.ioFileID = fileID;
-       result = PBResolveFileIDRefSync((HParmBlkPtr)&pb);
-       require_noerr(result, PBResolveFileIDRefSync);
-       
-       /* and then make an FSRef to the file */
-       result = FSMakeFSRef(volRefNum, pb.ioSrcDirID, tempStr, ref);
-       require_noerr(result, FSMakeFSRef);
-       
-FSMakeFSRef:
-PBResolveFileIDRefSync:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSCreateFileIDRef(
-       const FSRef *ref,
-       SInt32 *fileID)
-{
-       OSErr           result;
-       FSSpec          spec;
-       FIDParam        pb;
-       
-       /* check parameters */
-       require_action(NULL != fileID, BadParameter, result = paramErr);
-       
-       /* Get an FSSpec from the FSRef */
-       result = FSGetCatalogInfo(ref, kFSCatInfoNone, NULL, NULL, &spec, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* Create (or get) the file ID reference using the FSSpec */
-       pb.ioNamePtr = (StringPtr)spec.name;
-       pb.ioVRefNum = spec.vRefNum;
-       pb.ioSrcDirID = spec.parID;
-       result = PBCreateFileIDRefSync((HParmBlkPtr)&pb);
-       require((noErr == result) || (fidExists == result) || (afpIDExists == result),
-               PBCreateFileIDRefSync);
-       
-       /* return the file ID reference */
-       *fileID = pb.ioFileID;
-       
-PBCreateFileIDRefSync:
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-#pragma mark ----- Utility Routines -----
-
-/*****************************************************************************/
-
-Ptr
-GetTempBuffer(
-       ByteCount buffReqSize,
-       ByteCount *buffActSize)
-{
-       enum
-       {
-               kSlopMemory = 0x00008000        /* 32K - Amount of free memory to leave when allocating buffers */
-       };
-       
-       Ptr tempPtr;
-       
-       /* check parameters */
-       require_action(NULL != buffActSize, BadParameter, tempPtr = NULL);
-       
-       /* Make request a multiple of 4K bytes */
-       buffReqSize = buffReqSize & 0xfffff000;
-       
-       if ( buffReqSize < 0x00001000 )
-       {
-               /* Request was smaller than 4K bytes - make it 4K */
-               buffReqSize = 0x00001000;
-       }
-       
-       /* Attempt to allocate the memory */
-       tempPtr = NewPtr(buffReqSize);
-       
-       /* If request failed, go to backup plan */
-       if ( (tempPtr == NULL) && (buffReqSize > 0x00001000) )
-       {
-               /*
-               **      Try to get largest 4K byte block available
-               **      leaving some slop for the toolbox if possible
-               */
-               long freeMemory = (FreeMem() - kSlopMemory) & 0xfffff000;
-               
-               buffReqSize = MaxBlock() & 0xfffff000;
-               
-               if ( buffReqSize > freeMemory )
-               {
-                       buffReqSize = freeMemory;
-               }
-               
-               if ( buffReqSize == 0 )
-               {
-                       buffReqSize = 0x00001000;
-               }
-               
-               tempPtr = NewPtr(buffReqSize);
-       }
-       
-       /* Return bytes allocated */
-       if ( tempPtr != NULL )
-       {
-               *buffActSize = buffReqSize;
-       }
-       else
-       {
-               *buffActSize = 0;
-       }
-       
-BadParameter:
-
-       return ( tempPtr );
-}
-
-/*****************************************************************************/
-
-OSErr
-FileRefNumGetFSRef(
-       short refNum,
-       FSRef *ref)
-{
-       return ( FSGetForkCBInfo(refNum, 0, NULL, NULL, NULL, ref, NULL) );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSSetDefault(
-       const FSRef *newDefault,
-       FSRef *oldDefault)
-{
-       OSErr                   result;
-       FSVolumeRefNum  vRefNum;
-       long                    dirID;
-       FSCatalogInfo   catalogInfo;
-       
-       /* check parameters */
-       require_action((NULL != newDefault) && (NULL != oldDefault), BadParameter, result = paramErr);
-       
-       /* Get nodeFlags, vRefNum and dirID (nodeID) of newDefault */
-       result = FSGetCatalogInfo(newDefault,
-               kFSCatInfoNodeFlags + kFSCatInfoVolume + kFSCatInfoNodeID,
-               &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* Make sure newDefault is a directory */
-       require_action(0 != (kFSNodeIsDirectoryMask & catalogInfo.nodeFlags), NewDefaultNotDirectory,
-               result = dirNFErr);
-       
-       /* Get the current working directory. */
-       result = HGetVol(NULL, &vRefNum, &dirID);
-       require_noerr(result, HGetVol);
-       
-       /* Return the oldDefault FSRef */
-       result = FSMakeFSRef(vRefNum, dirID, NULL, oldDefault);
-       require_noerr(result, FSMakeFSRef);
-       
-       /* Set the new current working directory */
-       result = HSetVol(NULL, catalogInfo.volume, catalogInfo.nodeID);
-       require_noerr(result, HSetVol);
-
-HSetVol:
-FSMakeFSRef:
-HGetVol:
-NewDefaultNotDirectory:
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
-
-OSErr
-FSRestoreDefault(
-       const FSRef *oldDefault)
-{
-       OSErr                   result;
-       FSCatalogInfo   catalogInfo;
-       
-       /* check parameters */
-       require_action(NULL != oldDefault, BadParameter, result = paramErr);
-       
-       /* Get nodeFlags, vRefNum and dirID (nodeID) of oldDefault */
-       result = FSGetCatalogInfo(oldDefault,
-               kFSCatInfoNodeFlags + kFSCatInfoVolume + kFSCatInfoNodeID,
-               &catalogInfo, NULL, NULL, NULL);
-       require_noerr(result, FSGetCatalogInfo);
-       
-       /* Make sure oldDefault is a directory */
-       require_action(0 != (kFSNodeIsDirectoryMask & catalogInfo.nodeFlags), OldDefaultNotDirectory,
-               result = dirNFErr);
-       
-       /* Set the current working directory to oldDefault */
-       result = HSetVol(NULL, catalogInfo.volume, catalogInfo.nodeID);
-       require_noerr(result, HSetVol);
-
-HSetVol:
-OldDefaultNotDirectory:
-FSGetCatalogInfo:
-BadParameter:
-
-       return ( result );
-}
-
-/*****************************************************************************/
diff --git a/src/mac/morefilex/MoreFilesX.h b/src/mac/morefilex/MoreFilesX.h
deleted file mode 100644 (file)
index c73da46..0000000
+++ /dev/null
@@ -1,1825 +0,0 @@
-/*
-       File:           MoreFilesX.h
-
-       Contains:       A collection of useful high-level File Manager routines
-                               which use the HFS Plus APIs wherever possible.
-
-       Version:        MoreFilesX 1.0.1
-
-       Copyright:      © 1992-2002 by Apple Computer, Inc., all rights reserved.
-
-       Disclaimer:     IMPORTANT:  This Apple software is supplied to you by Apple Computer, Inc.
-                               ("Apple") in consideration of your agreement to the following terms, and your
-                               use, installation, modification or redistribution of this Apple software
-                               constitutes acceptance of these terms.  If you do not agree with these terms,
-                               please do not use, install, modify or redistribute this Apple software.
-
-                               In consideration of your agreement to abide by the following terms, and subject
-                               to these terms, Apple grants you a personal, non-exclusive license, under AppleÕs
-                               copyrights in this original Apple software (the "Apple Software"), to use,
-                               reproduce, modify and redistribute the Apple Software, with or without
-                               modifications, in source and/or binary forms; provided that if you redistribute
-                               the Apple Software in its entirety and without modifications, you must retain
-                               this notice and the following text and disclaimers in all such redistributions of
-                               the Apple Software.  Neither the name, trademarks, service marks or logos of
-                               Apple Computer, Inc. may be used to endorse or promote products derived from the
-                               Apple Software without specific prior written permission from Apple.  Except as
-                               expressly stated in this notice, no other rights or licenses, express or implied,
-                               are granted by Apple herein, including but not limited to any patent rights that
-                               may be infringed by your derivative works or by other works in which the Apple
-                               Software may be incorporated.
-
-                               The Apple Software is provided by Apple on an "AS IS" basis.  APPLE MAKES NO
-                               WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED
-                               WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS FOR A PARTICULAR
-                               PURPOSE, REGARDING THE APPLE SOFTWARE OR ITS USE AND OPERATION ALONE OR IN
-                               COMBINATION WITH YOUR PRODUCTS.
-
-                               IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL OR
-                               CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
-                               GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
-                               ARISING IN ANY WAY OUT OF THE USE, REPRODUCTION, MODIFICATION AND/OR DISTRIBUTION
-                               OF THE APPLE SOFTWARE, HOWEVER CAUSED AND WHETHER UNDER THEORY OF CONTRACT, TORT
-                               (INCLUDING NEGLIGENCE), STRICT LIABILITY OR OTHERWISE, EVEN IF APPLE HAS BEEN
-                               ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-
-       File Ownership:
-
-               DRI:                            Apple Macintosh Developer Technical Support
-
-               Other Contact:          For bug reports, consult the following page on
-                                                       the World Wide Web:
-                                                               http://developer.apple.com/bugreporter/
-
-               Technology:                     DTS Sample Code
-
-       Writers:
-
-               (JL)    Jim Luther
-
-       Change History (most recent first):
-
-                <3>     4/19/02        JL              [2853905]  Fixed #if test around header includes.
-                <2>     4/19/02        JL              [2853901]  Updated standard disclaimer.
-                <1>     1/25/02        JL              MoreFilesX 1.0
-       
-       Notes:
-               What do those arrows in the documentation for each routine mean?
-                       
-                       --> The parameter is an input
-                       
-                       <-- The parameter is an output. The pointer to the variable
-                               where the output will be returned (must not be NULL).
-                       
-                       <** The parameter is an optional output. If it is not a
-                               NULL pointer, it points to the variable where the output
-                               will be returned. If it is a NULL pointer, the output will
-                               not be returned and will possibly let the routine and the
-                               File Manager do less work. If you don't need an optional output,
-                               don't ask for it.
-                       **> The parameter is an optional input. If it is not a
-                               NULL pointer, it points to the variable containing the
-                               input data. If it is a NULL pointer, the input is not used
-                               and will possibly let the routine and the File Manager
-                               do less work.
-*/
-
-#ifndef __MOREFILESX__
-#define __MOREFILESX__
-
-#ifndef __CARBON__
-       #if defined(__MACH__)
-               #include <Carbon/Carbon.h>
-       #else
-               #include <Carbon.h>
-       #endif
-#endif
-
-#if PRAGMA_ONCE
-#pragma once
-#endif
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#if PRAGMA_IMPORT
-#pragma import on
-#endif
-
-#if PRAGMA_STRUCT_ALIGN
-       #pragma options align=mac68k
-#elif PRAGMA_STRUCT_PACKPUSH
-       #pragma pack(push, 2)
-#elif PRAGMA_STRUCT_PACK
-       #pragma pack(2)
-#endif
-
-/*****************************************************************************/
-
-#pragma mark ----- FinderInfo and ExtendedFinderInfo -----
-
-/*
- *     FSGetFinderInfo and FSSetFinderInfo use these unions for Finder information.
- */
-
-union FinderInfo
-{
-  FileInfo                             file;
-  FolderInfo                   folder;
-};
-typedef union FinderInfo FinderInfo;
-
-union ExtendedFinderInfo
-{
-  ExtendedFileInfo             file;
-  ExtendedFolderInfo   folder;
-};
-typedef union ExtendedFinderInfo ExtendedFinderInfo;
-
-/*****************************************************************************/
-
-#pragma mark ----- GetVolParmsInfoBuffer Macros -----
-
-/*
- *     Macros to get information out of GetVolParmsInfoBuffer.
- */
-
-/* version 1 field getters */
-#define GetVolParmsInfoVersion(volParms) \
-               ((volParms)->vMVersion)
-#define GetVolParmsInfoAttrib(volParms) \
-               ((volParms)->vMAttrib)
-#define GetVolParmsInfoLocalHand(volParms) \
-               ((volParms)->vMLocalHand)
-#define GetVolParmsInfoServerAdr(volParms) \
-               ((volParms)->vMServerAdr)
-
-/* version 2 field getters (assume zero result if version < 2) */
-#define GetVolParmsInfoVolumeGrade(volParms) \
-               (((volParms)->vMVersion >= 2) ? (volParms)->vMVolumeGrade : 0)
-#define GetVolParmsInfoForeignPrivID(volParms) \
-               (((volParms)->vMVersion >= 2) ? (volParms)->vMForeignPrivID : 0)
-
-/* version 3 field getters (assume zero result if version < 3) */
-#define GetVolParmsInfoExtendedAttributes(volParms) \
-               (((volParms)->vMVersion >= 3) ? (volParms)->vMExtendedAttributes : 0)
-
-/* attribute bits supported by all versions of GetVolParmsInfoBuffer */
-#define VolIsNetworkVolume(volParms) \
-               ((volParms)->vMServerAdr != 0)
-#define VolHasLimitFCBs(volParms) \
-               (((volParms)->vMAttrib & (1L << bLimitFCBs)) != 0)
-#define VolHasLocalWList(volParms) \
-               (((volParms)->vMAttrib & (1L << bLocalWList)) != 0)
-#define VolHasNoMiniFndr(volParms) \
-               (((volParms)->vMAttrib & (1L << bNoMiniFndr)) != 0)
-#define VolHasNoVNEdit(volParms) \
-               (((volParms)->vMAttrib & (1L << bNoVNEdit)) != 0)
-#define VolHasNoLclSync(volParms) \
-               (((volParms)->vMAttrib & (1L << bNoLclSync)) != 0)
-#define VolHasTrshOffLine(volParms) \
-               (((volParms)->vMAttrib & (1L << bTrshOffLine)) != 0)
-#define VolHasNoSwitchTo(volParms) \
-               (((volParms)->vMAttrib & (1L << bNoSwitchTo)) != 0)
-#define VolHasNoDeskItems(volParms) \
-               (((volParms)->vMAttrib & (1L << bNoDeskItems)) != 0)
-#define VolHasNoBootBlks(volParms) \
-               (((volParms)->vMAttrib & (1L << bNoBootBlks)) != 0)
-#define VolHasAccessCntl(volParms) \
-               (((volParms)->vMAttrib & (1L << bAccessCntl)) != 0)
-#define VolHasNoSysDir(volParms) \
-               (((volParms)->vMAttrib & (1L << bNoSysDir)) != 0)
-#define VolHasExtFSVol(volParms) \
-               (((volParms)->vMAttrib & (1L << bHasExtFSVol)) != 0)
-#define VolHasOpenDeny(volParms) \
-               (((volParms)->vMAttrib & (1L << bHasOpenDeny)) != 0)
-#define VolHasCopyFile(volParms) \
-               (((volParms)->vMAttrib & (1L << bHasCopyFile)) != 0)
-#define VolHasMoveRename(volParms) \
-               (((volParms)->vMAttrib & (1L << bHasMoveRename)) != 0)
-#define VolHasDesktopMgr(volParms) \
-               (((volParms)->vMAttrib & (1L << bHasDesktopMgr)) != 0)
-#define VolHasShortName(volParms) \
-               (((volParms)->vMAttrib & (1L << bHasShortName)) != 0)
-#define VolHasFolderLock(volParms) \
-               (((volParms)->vMAttrib & (1L << bHasFolderLock)) != 0)
-#define VolHasPersonalAccessPrivileges(volParms) \
-               (((volParms)->vMAttrib & (1L << bHasPersonalAccessPrivileges)) != 0)
-#define VolHasUserGroupList(volParms) \
-               (((volParms)->vMAttrib & (1L << bHasUserGroupList)) != 0)
-#define VolHasCatSearch(volParms) \
-               (((volParms)->vMAttrib & (1L << bHasCatSearch)) != 0)
-#define VolHasFileIDs(volParms) \
-               (((volParms)->vMAttrib & (1L << bHasFileIDs)) != 0)
-#define VolHasBTreeMgr(volParms) \
-               (((volParms)->vMAttrib & (1L << bHasBTreeMgr)) != 0)
-#define VolHasBlankAccessPrivileges(volParms) \
-               (((volParms)->vMAttrib & (1L << bHasBlankAccessPrivileges)) != 0)
-#define VolSupportsAsyncRequests(volParms) \
-               (((volParms)->vMAttrib & (1L << bSupportsAsyncRequests)) != 0)
-#define VolSupportsTrashVolumeCache(volParms) \
-               (((volParms)->vMAttrib & (1L << bSupportsTrashVolumeCache)) != 0)
-
-/* attribute bits supported by version 3 and greater versions of GetVolParmsInfoBuffer */
-#define VolIsEjectable(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bIsEjectable)) != 0)
-#define VolSupportsHFSPlusAPIs(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsHFSPlusAPIs)) != 0)
-#define VolSupportsFSCatalogSearch(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsFSCatalogSearch)) != 0)
-#define VolSupportsFSExchangeObjects(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsFSExchangeObjects)) != 0)
-#define VolSupports2TBFiles(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupports2TBFiles)) != 0)
-#define VolSupportsLongNames(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsLongNames)) != 0)
-#define VolSupportsMultiScriptNames(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsMultiScriptNames)) != 0)
-#define VolSupportsNamedForks(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsNamedForks)) != 0)
-#define VolSupportsSubtreeIterators(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsSubtreeIterators)) != 0)
-#define VolL2PCanMapFileBlocks(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bL2PCanMapFileBlocks)) != 0)
-#define VolParentModDateChanges(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bParentModDateChanges)) != 0)
-#define VolAncestorModDateChanges(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bAncestorModDateChanges)) != 0)
-#define VolSupportsSymbolicLinks(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bSupportsSymbolicLinks)) != 0)
-#define VolIsAutoMounted(volParms) \
-               ((GetVolParmsInfoExtendedAttributes(volParms) & (1L << bIsAutoMounted)) != 0)
-
-/*****************************************************************************/
-
-#pragma mark ----- userPrivileges Bit Masks and Macros -----
-
-/*
- *     Bit masks and macros to get common information out of userPrivileges byte
- *     returned by FSGetCatalogInfo.
- *
- *     Note:   The userPrivileges byte is the same as the ioACUser byte returned
- *                     by PBGetCatInfo, and is the 1's complement of the user's privileges
- *                     byte returned in ioACAccess by PBHGetDirAccess. That's where the
- *                     ioACUser names came from.
- *
- *                     The userPrivileges are user's effective privileges based on the
- *                     user ID and the groups that user belongs to, and the owner, group,
- *                     and everyone privileges for the given directory.
- */
-
-enum
-{
-       /* mask for just the access restriction bits */
-       kioACUserAccessMask             = (kioACUserNoSeeFolderMask +
-                                                          kioACUserNoSeeFilesMask +
-                                                          kioACUserNoMakeChangesMask),
-       /* common access privilege settings */
-       kioACUserFull                   = 0x00, /* no access restiction bits on */
-       kioACUserNone                   = kioACUserAccessMask, /* all access restiction bits on */
-       kioACUserDropBox                = (kioACUserNoSeeFolderMask +
-                                                          kioACUserNoSeeFilesMask), /* make changes, but not see files or folders */
-       kioACUserBulletinBoard  = kioACUserNoMakeChangesMask /* see files and folders, but not make changes */
-};
-
-
-/* Macros for testing ioACUser bits. */
-
-#define UserIsOwner(userPrivileges) \
-               (((userPrivileges) & kioACUserNotOwnerMask) == 0)
-#define UserHasFullAccess(userPrivileges)      \
-               (((userPrivileges) & (kioACUserAccessMask)) == kioACUserFull)
-#define UserHasDropBoxAccess(userPrivileges)   \
-               (((userPrivileges) & kioACUserAccessMask) == kioACUserDropBox)
-#define UserHasBulletinBoard(userPrivileges)   \
-               (((userPrivileges) & kioACUserAccessMask) == kioACUserBulletinBoard)
-#define UserHasNoAccess(userPrivileges)                \
-               (((userPrivileges) & kioACUserAccessMask) == kioACUserNone)
-
-/*****************************************************************************/
-
-#pragma mark ----- File Access Routines -----
-
-/*****************************************************************************/
-
-#pragma mark FSCopyFork
-
-OSErr
-FSCopyFork(
-       SInt16 srcRefNum,
-       SInt16 dstRefNum,
-       void *copyBufferPtr,
-       ByteCount copyBufferSize);
-
-/*
-       The FSCopyFork function copies all data from the source fork to the
-       destination fork of open file forks and makes sure the destination EOF
-       is equal to the source EOF.
-
-       srcRefNum                       --> The source file reference number.
-       dstRefNum                       --> The destination file reference number.
-       copyBufferPtr           --> Pointer to buffer to use during copy. The
-                                                       buffer should be at least 4K-bytes minimum.
-                                                       The larger the buffer, the faster the copy
-                                                       (up to a point).
-       copyBufferSize          --> The size of the copy buffer.
-*/
-
-/*****************************************************************************/
-
-#pragma mark ----- Volume Access Routines -----
-
-/*****************************************************************************/
-
-#pragma mark FSGetVolParms
-
-OSErr
-FSGetVolParms(
-       FSVolumeRefNum volRefNum,
-       UInt32 bufferSize,
-       GetVolParmsInfoBuffer *volParmsInfo,
-       UInt32 *actualInfoSize);
-
-/*
-       The FSGetVolParms function returns information about the characteristics
-       of a volume. A result of paramErr usually just means the volume doesn't
-       support GetVolParms and the feature you were going to check
-       for isn't available.
-       
-       volRefNum                       --> Volume specification.
-       bufferSize                      --> Size of buffer pointed to by volParmsInfo.
-       volParmsInfo            <-- A GetVolParmsInfoBuffer record where the volume
-                                                       attributes information is returned.
-       actualInfoSize          <-- The number of bytes actually returned
-                                                       in volParmsInfo.
-       
-       __________
-       
-       Also see:       The GetVolParmsInfoBuffer Macros for checking attribute bits
-                               in this file
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetVRefNum
-
-OSErr
-FSGetVRefNum(
-       const FSRef *ref,
-       FSVolumeRefNum *vRefNum);
-
-/*
-       The FSGetVRefNum function determines the volume reference
-       number of a volume from a FSRef.
-
-       ref                                     --> The FSRef.
-       vRefNum                         <-- The volume reference number.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetVInfo
-
-OSErr
-FSGetVInfo(
-       FSVolumeRefNum volume,
-       HFSUniStr255 *volumeName,       /* can be NULL */
-       UInt64 *freeBytes,                      /* can be NULL */
-       UInt64 *totalBytes);            /* can be NULL */
-
-/*
-       The FSGetVInfo function returns the name, available space (in bytes),
-       and total space (in bytes) for the specified volume.
-
-       volume                          --> The volume reference number.
-       volumeName                      <** An optional pointer to a HFSUniStr255.
-                                                       If not NULL, the volume name will be returned in
-                                                       the HFSUniStr255.
-       freeBytes                       <** An optional pointer to a UInt64.
-                                                       If not NULL, the number of free bytes on the
-                                                       volume will be returned in the UInt64.
-       totalBytes                      <** An optional pointer to a UInt64.
-                                                       If not NULL, the total number of bytes on the
-                                                       volume will be returned in the UInt64.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetVolFileSystemID
-
-OSErr
-FSGetVolFileSystemID(
-       FSVolumeRefNum volume,
-       UInt16 *fileSystemID,   /* can be NULL */
-       UInt16 *signature);             /* can be NULL */
-
-/*
-       The FSGetVolFileSystemID function returns the file system ID and signature
-       of a mounted volume. The file system ID identifies the file system
-       that handles requests to a particular volume. The signature identifies the
-       volume type of the volume (for example, FSID 0 is Macintosh HFS Plus, HFS
-       or MFS, where a signature of 0x4244 identifies the volume as HFS).
-       Here's a partial list of file system ID numbers (only Apple's file systems
-       are listed):
-               FSID    File System
-               -----   -----------------------------------------------------
-               $0000   Macintosh HFS Plus, HFS or MFS
-               $0100   ProDOS File System
-               $0101   PowerTalk Mail Enclosures
-               $4147   ISO 9660 File Access (through Foreign File Access)
-               $4242   High Sierra File Access (through Foreign File Access)
-               $464D   QuickTake File System (through Foreign File Access)
-               $4953   Macintosh PC Exchange (MS-DOS)
-               $4A48   Audio CD Access (through Foreign File Access)
-               $4D4B   Apple Photo Access (through Foreign File Access)
-               $6173   AppleShare (later versions of AppleShare only)
-       
-       See the Technical Note "FL 35 - Determining Which File System
-       Is Active" and the "Guide to the File System Manager" for more
-       information.
-       
-       volume                          --> The volume reference number.
-       fileSystemID            <** An optional pointer to a UInt16.
-                                                       If not NULL, the volume's file system ID will
-                                                       be returned in the UInt16.
-       signature                       <** An optional pointer to a UInt16.
-                                                       If not NULL, the volume's signature will
-                                                       be returned in the UInt16.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetMountedVolumes
-
-OSErr
-FSGetMountedVolumes(
-       FSRef ***volumeRefsHandle,      /* pointer to handle of FSRefs */
-       ItemCount *numVolumes);
-
-/*
-       The FSGetMountedVolumes function returns the list of volumes currently
-       mounted in an array of FSRef records. The array of FSRef records is
-       returned in a Handle, volumeRefsHandle, which is allocated by
-       FSGetMountedVolumes. The caller is responsible for disposing of
-       volumeRefsHandle if the FSGetMountedVolumes returns noErr.
-               
-       volumeRefsHandle        <-- Pointer to an FSRef Handle where the array of
-                                                       FSRefs is to be returned.
-       numVolumes                      <-- The number of volumes returned in the array.
-*/
-
-/*****************************************************************************/
-
-#pragma mark ----- FSRef/FSpec/Path/Name Conversion Routines -----
-
-/*****************************************************************************/
-
-#pragma mark FSRefMakeFSSpec
-
-OSErr
-FSRefMakeFSSpec(
-       const FSRef *ref,
-       FSSpec *spec);
-
-/*
-       The FSRefMakeFSSpec function returns an FSSpec for the file or
-       directory specified by the ref parameter.
-
-       ref                                     --> An FSRef specifying the file or directory.
-       spec                            <-- The FSSpec.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSMakeFSRef
-
-OSErr
-FSMakeFSRef(
-       FSVolumeRefNum volRefNum,
-       SInt32 dirID,
-       ConstStr255Param name,
-       FSRef *ref);
-
-/*
-       The FSMakeFSRef function creates an FSRef from the traditional
-       volume reference number, directory ID and pathname inputs. It is
-       functionally equivalent to FSMakeFSSpec followed by FSpMakeFSRef.
-       
-       volRefNum                       --> Volume specification.
-       dirID                           --> Directory specification.
-       name                            --> The file or directory name, or NULL.
-       ref                                     <-- The FSRef.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSMakePath
-
-OSStatus
-FSMakePath(
-       SInt16 vRefNum,
-       SInt32 dirID,
-       ConstStr255Param name,
-       UInt8 *path,
-       UInt32 maxPathSize);
-
-/*
-       The FSMakePath function creates a pathname from the traditional volume reference
-       number, directory ID, and pathname inputs. It is functionally equivalent to
-       FSMakeFSSpec, FSpMakeFSRef, FSRefMakePath.
-       
-       volRefNum                       --> Volume specification.
-       dirID                           --> Directory specification.
-       name                            --> The file or directory name, or NULL.
-       path                            <-- A pointer to a buffer which FSMakePath will
-                                                       fill with a C string representing the pathname
-                                                       to the file or directory specified. The format of
-                                                       the pathname returned can be determined with the
-                                                       Gestalt selector gestaltFSAttr's
-                                                       gestaltFSUsesPOSIXPathsForConversion bit.
-                                                       If the gestaltFSUsesPOSIXPathsForConversion bit is
-                                                       clear, the pathname is a Mac OS File Manager full
-                                                       pathname in a C string, and file or directory names
-                                                       in the pathname may be mangled as returned by
-                                                       the File Manager. If the
-                                                       gestaltFSUsesPOSIXPathsForConversion bit is set,
-                                                       the pathname is a UTF8 encoded POSIX absolute
-                                                       pathname in a C string. In either case, the
-                                                       pathname returned can be passed back to
-                                                       FSPathMakeRef to create an FSRef to the file or
-                                                       directory, or FSPathMakeFSSpec to craete an FSSpec
-                                                       to the file or directory.
-       maxPathSize                     --> The size of the path buffer in bytes. If the path
-                                                       buffer is too small for the pathname string,
-                                                       FSMakePath returns pathTooLongErr or
-                                                       buffersTooSmall.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSPathMakeFSSpec
-
-OSStatus
-FSPathMakeFSSpec(
-       const UInt8 *path,
-       FSSpec *spec,
-       Boolean *isDirectory);  /* can be NULL */
-
-/*
-       The FSPathMakeFSSpec function converts a pathname to an FSSpec.
-       
-       path                            --> A pointer to a C String that is the pathname. The
-                                                       format of the pathname you must supply can be
-                                                       determined with the Gestalt selector gestaltFSAttr's
-                                                       gestaltFSUsesPOSIXPathsForConversion bit.
-                                                       If the gestaltFSUsesPOSIXPathsForConversion bit is
-                                                       clear, the pathname must be a Mac OS File Manager
-                                                       full pathname in a C string. If the
-                                                       gestaltFSUsesPOSIXPathsForConversion bit is set,
-                                                       the pathname must be a UTF8 encoded POSIX absolute
-                                                       pathname in a C string.
-       spec                            <-- The FSSpec.
-       isDirectory                     <** An optional pointer to a Boolean.
-                                                       If not NULL, true will be returned in the Boolean
-                                                       if the specified path is a directory, or false will
-                                                       be returned in the Boolean if the specified path is
-                                                       a file.
-*/
-
-/*****************************************************************************/
-
-#pragma mark UnicodeNameGetHFSName
-
-OSErr
-UnicodeNameGetHFSName(
-       UniCharCount nameLength,
-       const UniChar *name,
-       TextEncoding textEncodingHint,
-       Boolean isVolumeName,
-       Str31 hfsName);
-
-/*
-       The UnicodeNameGetHFSName function converts a Unicode string
-       to a Pascal Str31 (or Str27) string using an algorithm similar to that used
-       by the File Manager. Note that if the name is too long or cannot be converted
-       using the given text encoding hint, you will get an error instead of the
-       mangled name that the File Manager would return.
-       
-       nameLength                      --> Number of UniChar in name parameter.
-       name                            --> The Unicode string to convert.
-       textEncodingHint        --> The text encoding hint used for the conversion.
-                                                       You can pass kTextEncodingUnknown to use the
-                                                       "default" textEncodingHint.
-       isVolumeName            --> If true, the output name will be limited to
-                                                       27 characters (kHFSMaxVolumeNameChars). If false,
-                                                       the output name will be limited to 31 characters
-                                                       (kHFSMaxFileNameChars).
-       hfsName                         <-- The hfsName as a Pascal string.
-       
-       __________
-       
-       Also see:       HFSNameGetUnicodeName
-*/
-
-/*****************************************************************************/
-
-#pragma mark HFSNameGetUnicodeName
-
-OSErr
-HFSNameGetUnicodeName(
-       ConstStr31Param hfsName,
-       TextEncoding textEncodingHint,
-       HFSUniStr255 *unicodeName);
-
-/*
-       The HFSNameGetUnicodeName function converts a Pascal Str31 string to an
-       Unicode HFSUniStr255 string using the same routines as the File Manager.
-       
-       hfsName                         --> The Pascal string to convert.
-       textEncodingHint        --> The text encoding hint used for the conversion.
-                                                       You can pass kTextEncodingUnknown to use the
-                                                       "default" textEncodingHint.
-       unicodeName                     <-- The Unicode string.
-       
-       __________
-       
-       Also see:       UnicodeNameGetHFSName
-*/
-
-/*****************************************************************************/
-
-#pragma mark ----- File/Directory Manipulation Routines -----
-
-/*****************************************************************************/
-
-#pragma mark FSRefValid
-
-Boolean FSRefValid(const FSRef *ref);
-
-/*
-       The FSRefValid function determines if an FSRef is valid. If the result is
-       true, then the FSRef refers to an existing file or directory.
-       
-       ref                                     --> FSRef to a file or directory.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetParentRef
-
-OSErr
-FSGetParentRef(
-       const FSRef *ref,
-       FSRef *parentRef);
-
-/*
-       The FSGetParentRef function gets the parent directory FSRef of the
-       specified object.
-       
-       Note: FSRefs always point to real file system objects. So, there cannot
-       be a FSRef to the parent of volume root directories. If you call
-       FSGetParentRef with a ref to the root directory of a volume, the
-       function result will be noErr and the parentRef will be invalid (using it
-       for other file system requests will fail).
-
-       ref                                     --> FSRef to a file or directory.
-       parentRef                       <-- The parent directory's FSRef.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetFileDirName
-
-OSErr
-FSGetFileDirName(
-       const FSRef *ref,
-       HFSUniStr255 *outName);
-
-/*
-       The FSGetFileDirName function gets the name of the file or directory
-       specified.
-
-       ref                                     --> FSRef to a file or directory.
-       outName                         <-- The file or directory name.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetNodeID
-
-OSErr
-FSGetNodeID(
-       const FSRef *ref,
-       long *nodeID,                   /* can be NULL */
-       Boolean *isDirectory);  /* can be NULL */
-
-/*
-       The GetNodeIDFromFSRef function gets the node ID number of the
-       file or directory specified (note: the node ID is the directory ID
-       for directories).
-
-       ref                                     --> FSRef to a file or directory.
-       nodeID                          <** An optional pointer to a long.
-                                                       If not NULL, the node ID will be returned in
-                                                       the long.
-       isDirectory                     <** An optional pointer to a Boolean.
-                                                       If not NULL, true will be returned in the Boolean
-                                                       if the object is a directory, or false will be
-                                                       returned in the Boolean if object is a file.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetUserPrivilegesPermissions
-
-OSErr
-FSGetUserPrivilegesPermissions(
-       const FSRef *ref,
-       UInt8 *userPrivileges,          /* can be NULL */
-       UInt32 permissions[4]);         /* can be NULL */
-
-/*
-       The FSGetUserPrivilegesPermissions function gets the userPrivileges and/or
-       permissions of the file or directory specified.
-
-       ref                                     --> FSRef to a file or directory.
-       userPrivileges          <** An optional pointer to a UInt8.
-                                                       If not NULL, the userPrivileges will be returned
-                                                       in the UInt8.
-       permissions                     <** An optional pointer to an UInt32[4] array.
-                                                       If not NULL, the permissions will be returned
-                                                       in the UInt32[4] array.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSCheckLock
-
-OSErr
-FSCheckLock(
-       const FSRef *ref);
-
-/*
-       The FSCheckLock function determines if a file or directory is locked.
-       If FSCheckLock returns noErr, then the file or directory is not locked
-       and the volume it is on is not locked either. If FSCheckLock returns
-       fLckdErr, then the file or directory is locked. If FSCheckLock returns
-       wPrErr, then the volume is locked by hardware (i.e., locked tab on
-       removable media). If FSCheckLock returns vLckdErr, then the volume is
-       locked by software.
-       
-       ref                                     --> FSRef to a file or directory.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetForkSizes
-
-OSErr
-FSGetForkSizes(
-       const FSRef *ref,
-       UInt64 *dataLogicalSize,        /* can be NULL */
-       UInt64 *rsrcLogicalSize);       /* can be NULL */
-
-/*
-       The FSGetForkSizes returns the size of the data and/or resource fork for
-       the specified file.
-       
-       ref                                     --> FSRef to a file or directory.
-       dataLogicalSize         <** An optional pointer to a UInt64.
-                                                       If not NULL, the data fork's size will be
-                                                       returned in the UInt64.
-       rsrcLogicalSize         <** An optional pointer to a UInt64.
-                                                       If not NULL, the resource fork's size will be
-                                                       returned in the UInt64.
-       
-       __________
-       
-       Also see:       FSGetTotalForkSizes
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetTotalForkSizes
-
-OSErr
-FSGetTotalForkSizes(
-       const FSRef *ref,
-       UInt64 *totalLogicalSize,       /* can be NULL */
-       UInt64 *totalPhysicalSize,      /* can be NULL */
-       ItemCount *forkCount);          /* can be NULL */
-
-/*
-       The FSGetTotalForkSizes returns the total logical size and/or the total
-       physical size of the specified file (i.e., it adds the sizes of all file
-       forks). It optionally returns the number of file forks.
-       
-       ref                                     --> FSRef to a file or directory.
-       totalLogicalSize        <** An optional pointer to a UInt64.
-                                                       If not NULL, the sum of all fork logical sizes
-                                                       will be returned in the UInt64.
-       totalPhysicalSize       <** An optional pointer to a UInt64.
-                                                       If not NULL, the sum of all fork physical sizes
-                                                       will be returned in the UInt64.
-       forkCount                       <** An optional pointer to a ItemCount.
-                                                       If not NULL, the number of file forks
-                                                       will be returned in the ItemCount.
-       
-       __________
-       
-       Also see:       FSGetForkSizes
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSBumpDate
-
-OSErr
-FSBumpDate(
-       const FSRef *ref);
-
-/*
-       The FSBumpDate function changes the content modification date of a file
-       or directory to the current date/time. If the content modification date
-       is already equal to the current date/time, then add one second to the
-       content modification date.
-
-       ref                                     --> FSRef to a file or directory.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetFinderInfo
-
-OSErr
-FSGetFinderInfo(
-       const FSRef *ref,
-       FinderInfo *info,                                       /* can be NULL */
-       ExtendedFinderInfo *extendedInfo,       /* can be NULL */
-       Boolean *isDirectory);                          /* can be NULL */
-
-/*
-       The FSGetFinderInfo function gets the finder information for a file or
-       directory.
-
-       ref                                     --> FSRef to a file or directory.
-       info                            <** An optional pointer to a FinderInfo.
-                                                       If not NULL, the FileInfo (if ref is a file) or
-                                                       the FolderInfo (if ref is a folder) will be
-                                                       returned in the FinderInfo.
-       extendedInfo            <** An optional pointer to a ExtendedFinderInfo.
-                                                       If not NULL, the ExtendedFileInfo (if ref is a file)
-                                                       or the ExtendedFolderInfo (if ref is a folder) will
-                                                       be returned in the ExtendedFinderInfo.
-       isDirectory                     <** An optional pointer to a Boolean.
-                                                       If not NULL, true will be returned in the Boolean
-                                                       if the object is a directory, or false will be
-                                                       returned in the Boolean if object is a file.
-
-       __________
-
-       Also see:       FSSetFinderInfo
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSSetFinderInfo
-
-OSErr
-FSSetFinderInfo(
-       const FSRef *ref,
-       const FinderInfo *info,                                         /* can be NULL */
-       const ExtendedFinderInfo *extendedInfo);        /* can be NULL */
-
-/*
-       The FSSetFinderInfo function sets the finder information for a file or
-       directory.
-
-       ref                                     --> FSRef to a file or directory.
-       info                            **> A pointer to a FinderInfo record with the new
-                                                       FileInfo (if ref is a file) or new FolderInfo
-                                                       (if ref is a folder), or NULL if the FinderInfo
-                                                       is not to be changed.
-       extendedInfo            **> A pointer to a FinderInfo record with the new
-                                                       ExtendedFileInfo (if ref is a file) or new
-                                                       ExtendedFolderInfo (if ref is a folder), or NULL
-                                                       if the ExtendedFinderInfo is not to be changed.
-               
-       __________
-
-       Also see:       FSGetFinderInfo
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSChangeCreatorType
-
-OSErr
-FSChangeCreatorType(
-       const FSRef *ref,
-       OSType fileCreator,
-       OSType fileType);
-
-/*
-       The FSChangeCreatorType function changes the creator and/or file type of a file.
-
-       ref                                     --> FSRef to a file.
-       creator                         --> The new creator type or 0x00000000 to leave
-                                                       the creator type alone.
-       fileType                        --> The new file type or 0x00000000 to leave the
-                                                       file type alone.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSChangeFinderFlags
-
-OSErr
-FSChangeFinderFlags(
-       const FSRef *ref,
-       Boolean setBits,
-       UInt16 flagBits);
-
-/*
-       The FSChangeFinderFlags function sets or clears flag bits in
-       the finderFlags field of a file's FileInfo record or a
-       directory's FolderInfo record.
-
-       ref                                     --> FSRef to a file or directory.
-       setBits                         --> If true, then set the bits specified in flagBits.
-                                                       If false, then clear the bits specified in flagBits.
-       flagBits                        --> The flagBits parameter specifies which Finder Flag
-                                                       bits to set or clear. If a bit in flagBits is set,
-                                                       then the same bit in fdFlags is either set or
-                                                       cleared depending on the state of the setBits
-                                                       parameter.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSSetInvisible
-
-OSErr
-FSSetInvisible(
-       const FSRef *ref);
-
-#pragma mark FSClearInvisible
-
-OSErr
-FSClearInvisible(
-       const FSRef *ref);
-
-/*
-       The FSSetInvisible and FSClearInvisible functions set or clear the
-       kIsInvisible bit in the finderFlags field of the specified file or
-       directory's finder information.
-
-       ref                                     --> FSRef to a file or directory.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSSetNameLocked
-
-OSErr
-FSSetNameLocked(
-       const FSRef *ref);
-
-#pragma mark FSClearNameLocked
-
-OSErr
-FSClearNameLocked(
-       const FSRef *ref);
-
-/*
-       The FSSetNameLocked and FSClearNameLocked functions set or clear the
-       kNameLocked bit bit in the finderFlags field of the specified file or
-       directory's finder information.
-
-       ref                                     --> FSRef to a file or directory.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSSetIsStationery
-
-OSErr
-FSSetIsStationery(
-       const FSRef *ref);
-
-#pragma mark FSClearIsStationery
-
-OSErr
-FSClearIsStationery(
-       const FSRef *ref);
-
-/*
-       The FSSetIsStationery and FSClearIsStationery functions set or clear the
-       kIsStationery bit bit in the finderFlags field of the specified file or
-       directory's finder information.
-
-       ref                                     --> FSRef to a file or directory.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSSetHasCustomIcon
-
-OSErr
-FSSetHasCustomIcon(
-       const FSRef *ref);
-
-#pragma mark FSClearHasCustomIcon
-
-OSErr
-FSClearHasCustomIcon(
-       const FSRef *ref);
-
-/*
-       The FSSetHasCustomIcon and FSClearHasCustomIcon functions set or clear the
-       kHasCustomIcon bit bit in the finderFlags field of the specified file or
-       directory's finder information.
-
-       ref                                     --> FSRef to a file or directory.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSClearHasBeenInited
-
-OSErr
-FSClearHasBeenInited(
-       const FSRef *ref);
-
-/*
-       The FSClearHasBeenInited function clears the kHasBeenInited bit in the
-       finderFlags field of the specified file or directory's finder information.
-       
-       Note:   There is no FSSetHasBeenInited function because ONLY the Finder
-                       should set the kHasBeenInited bit.
-
-       ref                                     --> FSRef to a file or directory.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSCopyFileMgrAttributes
-
-OSErr
-FSCopyFileMgrAttributes(
-       const FSRef *sourceRef,
-       const FSRef *destinationRef,
-       Boolean copyLockBit);
-
-/*
-       The CopyFileMgrAttributes function copies all File Manager attributes
-       from the source file or directory to the destination file or directory.
-       If copyLockBit is true, then set the locked state of the destination
-       to match the source.
-
-       sourceRef                       --> FSRef to a file or directory.
-       destinationRef          --> FSRef to a file or directory.
-       copyLockBit                     --> If true, set the locked state of the destination
-                                                       to match the source.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSMoveRenameObjectUnicode
-
-OSErr
-FSMoveRenameObjectUnicode(
-       const FSRef *ref,
-       const FSRef *destDirectory,
-       UniCharCount nameLength,
-       const UniChar *name,                    /* can be NULL (no rename during move) */
-       TextEncoding textEncodingHint,
-       FSRef *newRef);                                 /* if function fails along the way, newRef is final location of file */
-
-/*
-       The FSMoveRenameObjectUnicode function moves a file or directory and
-       optionally renames it.  The source and destination locations must be on
-       the same volume.
-       
-       Note:   If the input ref parameter is invalid, this call will fail and
-                       newRef, like ref, will be invalid.
-
-       ref                                     --> FSRef to a file or directory.
-       destDirectory           --> FSRef to the destination directory.
-       nameLength                      --> Number of UniChar in name parameter.
-       name                            --> An Unicode string with the new name for the
-                                                       moved object, or NULL if no rename is wanted.
-       textEncodingHint        --> The text encoding hint used for the rename.
-                                                       You can pass kTextEncodingUnknown to use the
-                                                       "default" textEncodingHint.
-       newRef                          <-- The new FSRef of the object moved. Note that if
-                                                       this function fails at any step along the way,
-                                                       newRef is still then final location of the object.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSDeleteContainerContents
-
-OSErr
-FSDeleteContainerContents(
-       const FSRef *container);
-
-/*
-       The FSDeleteContainerContents function deletes the contents of a container
-       directory. All files and subdirectories in the specified container are
-       deleted. If a locked file or directory is encountered, it is unlocked and
-       then deleted. If any unexpected errors are encountered,
-       FSDeleteContainerContents quits and returns to the caller.
-       
-       container                       --> FSRef to a directory.
-       
-       __________
-       
-       Also see:       FSDeleteContainer
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSDeleteContainer
-
-OSErr
-FSDeleteContainer(
-       const FSRef *container);
-
-/*
-       The FSDeleteContainer function deletes a container directory and its contents.
-       All files and subdirectories in the specified container are deleted.
-       If a locked file or directory is encountered, it is unlocked and then
-       deleted.  After deleting the container's contents, the container is
-       deleted. If any unexpected errors are encountered, FSDeleteContainer
-       quits and returns to the caller.
-       
-       container                       --> FSRef to a directory.
-       
-       __________
-       
-       Also see:       FSDeleteContainerContents
-*/
-
-/*****************************************************************************/
-
-#pragma mark IterateContainerFilterProcPtr
-
-typedef CALLBACK_API( Boolean , IterateContainerFilterProcPtr ) (
-       Boolean containerChanged,
-       ItemCount currentLevel,
-       const FSCatalogInfo *catalogInfo,
-       const FSRef *ref,
-       const FSSpec *spec,
-       const HFSUniStr255 *name,
-       void *yourDataPtr);
-
-/*
-       This is the prototype for the IterateContainerFilterProc function which
-       is called once for each file and directory found by FSIterateContainer.
-       The IterateContainerFilterProc can use the read-only data it receives for
-       whatever it wants.
-
-       The result of the IterateContainerFilterProc function indicates if
-       iteration should be stopped. To stop iteration, return true; to continue
-       iteration, return false.
-
-       The yourDataPtr parameter can point to whatever data structure you might
-       want to access from within the IterateContainerFilterProc.
-
-       containerChanged        --> Set to true if the container's contents changed
-                                                       during iteration.
-       currentLevel            --> The current recursion level into the container.
-                                                       1 = the container, 2 = the container's immediate
-                                                       subdirectories, etc.
-       catalogInfo                     --> The catalog information for the current object.
-                                                       Only the fields requested by the whichInfo
-                                                       parameter passed to FSIterateContainer are valid.
-       ref                                     --> The FSRef to the current object.
-       spec                            --> The FSSpec to the current object if the wantFSSpec
-                                                       parameter passed to FSIterateContainer is true.
-       name                            --> The name of the current object if the wantName
-                                                       parameter passed to FSIterateContainer is true.
-       yourDataPtr                     --> An optional pointer to whatever data structure you
-                                                       might want to access from within the
-                                                       IterateFilterProc.
-       result                          <-- To stop iteration, return true; to continue
-                                                       iteration, return false.
-
-       __________
-
-       Also see:       FSIterateContainer
-*/
-
-/*****************************************************************************/
-
-#pragma mark CallIterateContainerFilterProc
-
-#define CallIterateContainerFilterProc(userRoutine, containerChanged, currentLevel, catalogInfo, ref, spec, name, yourDataPtr) \
-       (*(userRoutine))((containerChanged), (currentLevel), (catalogInfo), (ref), (spec), (name), (yourDataPtr))
-
-/*****************************************************************************/
-
-#pragma mark FSIterateContainer
-
-OSErr
-FSIterateContainer(
-       const FSRef *container,
-       ItemCount maxLevels,
-       FSCatalogInfoBitmap whichInfo,
-       Boolean wantFSSpec,
-       Boolean wantName,
-       IterateContainerFilterProcPtr iterateFilter,
-       void *yourDataPtr);
-
-/*
-       The FSIterateContainer function performs a recursive iteration (scan) of the
-       specified container directory and calls your IterateContainerFilterProc
-       function once for each file and directory found.
-
-       The maxLevels parameter lets you control how deep the recursion goes.
-       If maxLevels is 1, FSIterateContainer only scans the specified directory;
-       if maxLevels is 2, FSIterateContainer scans the specified directory and
-       one subdirectory below the specified directory; etc. Set maxLevels to
-       zero to scan all levels.
-
-       The yourDataPtr parameter can point to whatever data structure you might
-       want to access from within your IterateContainerFilterProc.
-
-       container                       --> The FSRef to the container directory to iterate.
-       maxLevels                       --> Maximum number of directory levels to scan or
-                                                       zero to scan all directory levels.
-       whichInfo                       --> The fields of the FSCatalogInfo you wish to get.
-       wantFSSpec                      --> Set to true if you want the FSSpec to each
-                                                       object passed to your IterateContainerFilterProc.
-       wantName                        --> Set to true if you want the name of each
-                                                       object passed to your IterateContainerFilterProc.
-       iterateFilter           --> A pointer to the IterateContainerFilterProc you
-                                                       want called once for each file and directory found
-                                                       by FSIterateContainer.
-       yourDataPtr                     --> An optional pointer to whatever data structure you
-                                                       might want to access from within the
-                                                       IterateFilterProc.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetDirectoryItems
-
-OSErr
-FSGetDirectoryItems(
-       const FSRef *container,
-       FSRef ***refsHandle,    /* pointer to handle of FSRefs */
-       ItemCount *numRefs,
-       Boolean *containerChanged);
-
-/*
-       The FSGetDirectoryItems function returns the list of items in the specified
-       container. The array of FSRef records is returned in a Handle, refsHandle,
-       which is allocated by FSGetDirectoryItems. The caller is responsible for
-       disposing of refsHandle if the FSGetDirectoryItems returns noErr.
-               
-       container                       --> FSRef to a directory.
-       refsHandle                      <-- Pointer to an FSRef Handle where the array of
-                                                       FSRefs is to be returned.
-       numRefs                         <-- The number of FSRefs returned in the array.
-       containerChanged        <-- Set to true if the container changes while the
-                                                       list of items is being obtained.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSExchangeObjectsCompat
-
-OSErr
-FSExchangeObjectsCompat(
-       const FSRef *sourceRef,
-       const FSRef *destRef,
-       FSRef *newSourceRef,
-       FSRef *newDestRef);
-
-/*
-       The FSExchangeObjectsCompat function exchanges the data between two files.
-       
-       The FSExchangeObjectsCompat function is an enhanced version of
-       FSExchangeObjects function. The two enhancements FSExchangeObjectsCompat
-       provides are:
-       
-       1,      FSExchangeObjectsCompat will work on volumes which do not support
-               FSExchangeObjects. FSExchangeObjectsCompat does this by emulating
-               FSExchangeObjects through a series of File Manager operations. If
-               there is a failure at any step along the way, FSExchangeObjectsCompat
-               attempts to undo any steps already taken to leave the files in their
-               original state in their original locations.
-               
-       2.      FSExchangeObjectsCompat returns new FSRefs to the source and
-               destination files. Note that if this function fails at any step along
-               the way, newSourceRef and newDestRef still give you access to the final
-               locations of the files being exchanged -- even if they are renamed or
-               not in their original locations.
-
-       sourceRef                       --> FSRef to the source file.
-       destRef                         --> FSRef to the destination file.
-       newSourceRef            <-- The new FSRef to the source file.
-       newDestRef                      <-- The new FSRef to the destination file.
-*/
-
-/*****************************************************************************/
-
-#pragma mark ----- Shared Environment Routines -----
-
-/*****************************************************************************/
-
-#pragma mark FSLockRange
-
-OSErr
-FSLockRange(
-       SInt16 refNum,
-       SInt32 rangeLength,
-       SInt32 rangeStart);
-
-/*
-       The LockRange function locks (denies access to) a portion of a file
-       that was opened with shared read/write permission.
-
-       refNum                          --> The file reference number of an open file.
-       rangeLength                     --> The number of bytes in the range.
-       rangeStart                      --> The starting byte in the range to lock.
-
-       __________
-
-       Also see:       UnlockRange
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSUnlockRange
-
-OSErr
-FSUnlockRange(
-       SInt16 refNum,
-       SInt32 rangeLength,
-       SInt32 rangeStart);
-
-/*
-       The UnlockRange function unlocks (allows access to) a previously locked
-       portion of a file that was opened with shared read/write permission.
-
-       refNum                          --> The file reference number of an open file.
-       rangeLength                     --> The number of bytes in the range.
-       rangeStart                      --> The starting byte in the range to unlock.
-
-       __________
-
-       Also see:       LockRange
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetDirAccess
-
-OSErr
-FSGetDirAccess(
-       const FSRef *ref,
-       SInt32 *ownerID,                /* can be NULL */
-       SInt32 *groupID,                /* can be NULL */
-       SInt32 *accessRights);  /* can be NULL */
-
-/*
-       The FSGetDirAccess function retrieves the directory access control
-       information for a directory on a shared volume.
-
-       ref                                     --> An FSRef specifying the directory.
-       ownerID                         <** An optional pointer to a SInt32.
-                                                       If not NULL, the directory's owner ID
-                                                       will be returned in the SInt32.
-       groupID                         <** An optional pointer to a SInt32.
-                                                       If not NULL, the directory's group ID, or 0
-                                                       if no group affiliation, will be returned in
-                                                       the SInt32.
-       accessRights            <** An optional pointer to a SInt32.
-                                                       If not NULL, the directory's access rights
-                                                       will be returned in the SInt32.
-
-       __________
-
-       Also see:       FSSetDirAccess, FSMapID, FSMapName
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSSetDirAccess
-
-OSErr
-FSSetDirAccess(
-       const FSRef *ref,
-       SInt32 ownerID,
-       SInt32 groupID,
-       SInt32 accessRights);
-
-/*
-       The FSpSetDirAccess function changes the directory access control
-       information for a directory on a shared volume. You must be the owner of
-       a directory to change its access control information.
-       
-       ref                                     --> An FSRef specifying the directory.
-       ownerID                         --> The directory's owner ID.
-       groupID                         --> The directory's group ID or 0 if no group affiliation.
-       accessRights            --> The directory's access rights.
-       
-       __________
-       
-       Also see:       FSGetDirAccess, FSMapID, FSMapName
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetVolMountInfoSize
-
-OSErr
-FSGetVolMountInfoSize(
-       FSVolumeRefNum volRefNum,
-       SInt16 *size);
-
-/*
-       The FSGetVolMountInfoSize function determines the how much space the
-       program needs to allocate for a volume mounting information record.
-
-       volRefNum                       --> Volume specification.
-       size                            <-- The space needed (in bytes) of the volume
-                                                       mounting information record.
-
-       __________
-
-       Also see:       FSGetVolMountInfo, VolumeMount
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSGetVolMountInfo
-
-OSErr
-FSGetVolMountInfo(
-       FSVolumeRefNum volRefNum,
-       void *volMountInfo);
-
-/*
-       The FSGetVolMountInfo function retrieves a volume mounting information
-       record containing all the information needed to mount the volume,
-       except for passwords.
-
-       volRefNum                       --> Volume specification.
-       volMountInfo            <-- The volume mounting information.
-
-       __________
-
-       Also see:       FSGetVolMountInfoSize, VolumeMount
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSVolumeMount
-
-OSErr
-FSVolumeMount(
-       const void *volMountInfo,
-       FSVolumeRefNum *volRefNum);
-
-/*
-       The VolumeMount function mounts a volume using a volume mounting
-       information record.
-
-       volMountInfo            --> A volume mounting information record.
-       volRefNum                       <-- The volume reference number.
-
-       __________
-
-       Also see:       FSGetVolMountInfoSize, FSGetVolMountInfo
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSMapID
-
-OSErr
-FSMapID(
-       FSVolumeRefNum volRefNum,
-       SInt32 ugID,
-       SInt16 objType,
-       Str31 name);
-
-/*
-       The FSMapID function determines the name of a user or group if you know
-       the user or group ID.
-
-       volRefNum                       --> Volume specification.
-       objType                         --> The mapping function code:
-                                                       kOwnerID2Name to map a user ID to a user name
-                                                       kGroupID2Name to map a group ID to a group name
-       name                            <** An optional pointer to a buffer (minimum Str31).
-                                                       If not NULL, the user or group name
-                                                       will be returned in the buffer.
-
-       __________
-
-       Also see:       FSGetDirAccess, FSSetDirAccess, FSMapName
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSMapName
-
-OSErr
-FSMapName(
-       FSVolumeRefNum volRefNum,
-       ConstStr255Param name,
-       SInt16 objType,
-       SInt32 *ugID);
-
-/*
-       The FSMapName function determines the user or group ID if you know the
-       user or group name.
-       
-       volRefNum                       --> Volume specification.
-       name                            --> The user or group name.
-       objType                         --> The mapping function code:
-                                                       kOwnerName2ID to map a user name to a user ID
-                                                       kGroupName2ID to map a user name to a group ID
-       ugID                            <-- The user or group ID.
-
-       __________
-       
-       Also see:       FSGetDirAccess, FSSetDirAccess, FSMapID
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSCopyFile
-
-OSErr
-FSCopyFile(
-       const FSRef *srcFileRef,
-       const FSRef *dstDirectoryRef,
-       UniCharCount nameLength,
-       const UniChar *copyName,        /* can be NULL (no rename during copy) */
-       TextEncoding textEncodingHint,
-       FSRef *newRef);                         /* can be NULL */
-
-/*
-       The FSCopyFile function duplicates a file and optionally renames it.
-       The source and destination volumes must be on the same file server.
-       This function instructs the server to copy the file.
-       
-       srcFileRef                      --> An FSRef specifying the source file.
-       dstDirectoryRef         --> An FSRef specifying the destination directory.
-       nameLength                      --> Number of UniChar in copyName parameter (ignored
-                                                       if copyName is NULL).
-       copyName                        --> Points to the new file name if the file is to be
-                                                       renamed, or NULL if the file isn't to be renamed.
-       textEncodingHint        --> The text encoding hint used for the rename.
-                                                       You can pass kTextEncodingUnknown to use the
-                                                       "default" textEncodingHint.
-       newRef                          <** An optional pointer to a FSRef.
-                                                       If not NULL, the FSRef of the duplicated file
-                                                       will be returned in the FSRef.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSMoveRename
-
-OSErr
-FSMoveRename(
-       const FSRef *srcFileRef,
-       const FSRef *dstDirectoryRef,
-       UniCharCount nameLength,
-       const UniChar *moveName,        /* can be NULL (no rename during move) */
-       TextEncoding textEncodingHint,
-       FSRef *newRef);                         /* can be NULL */
-
-/*
-       The FSMoveRename function moves a file or directory (object), and
-       optionally renames it. The source and destination locations must be on
-       the same shared volume.
-       
-       srcFileRef                      --> An FSRef specifying the source file.
-       dstDirectoryRef         --> An FSRef specifying the destination directory.
-       nameLength                      --> Number of UniChar in moveName parameter (ignored
-                                                       if copyName is NULL)
-       moveName                        --> Points to the new object name if the object is to be
-                                                       renamed, or NULL if the object isn't to be renamed.
-       textEncodingHint        --> The text encoding hint used for the rename.
-                                                       You can pass kTextEncodingUnknown to use the
-                                                       "default" textEncodingHint.
-       newRef                          <** An optional pointer to a FSRef.
-                                                       If not NULL, the FSRef of the moved object
-                                                       will be returned in the FSRef.
-*/
-
-/*****************************************************************************/
-
-#pragma mark ----- File ID Routines -----
-
-/*****************************************************************************/
-
-#pragma mark FSResolveFileIDRef
-
-OSErr
-FSResolveFileIDRef(
-       FSVolumeRefNum volRefNum,
-       SInt32 fileID,
-       FSRef *ref);
-
-/*
-       The FSResolveFileIDRef function returns an FSRef for the file with the
-       specified file ID reference.
-
-       volRefNum                       --> Volume specification.
-       fileID                          --> The file ID reference.
-       ref                                     <-- The FSRef for the file ID reference.
-
-       __________
-
-       Also see:       FSCreateFileIDRef, FSDeleteFileIDRef
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSCreateFileIDRef
-
-OSErr
-FSCreateFileIDRef(
-       const FSRef *ref,
-       SInt32 *fileID);
-
-/*
-       The FSCreateFileIDRef function creates a file ID reference for the
-       specified file, or if a file ID reference already exists, supplies
-       the file ID reference and returns the result code fidExists or afpIDExists.
-
-       ref                                     --> The FSRef for the file.
-       fileID                          <-- The file ID reference (if result is noErr,
-                                                       fidExists, or afpIDExists).
-
-       __________
-
-       Also see:       GetFSRefFromFileIDRef, FSDeleteFileIDRef
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSDeleteFileIDRef
-
-/*
-       Why is there no FSDeleteFileIDRef routine? There are two reasons:
-       
-       1.      Since Mac OS 8.1, PBDeleteFileIDRef hasn't deleted file ID references.
-               On HFS volumes, deleting a file ID reference breaks aliases (which
-               use file ID references to track files as they are moved around on a
-               volume) and file ID references are automatically deleted when the file
-               they refer to is deleted. On HFS Plus volumes, file ID references are
-               always created when a file is created, deleted when the file is deleted,
-               and cannot be deleted at any other time.
-               
-       2.      PBDeleteFileIDRef causes a memory access fault under Mac OS X 10.0
-               through 10.1.x. While this will be fixed in a future release, the
-               implementation, like the Mac OS 8/9 implementation, does not delete
-               file ID references.
-               
-       __________
-
-       Also see:       GetFSRefFromFileIDRef, FSCreateFileIDRef
-*/
-
-/*****************************************************************************/
-
-#pragma mark ----- Utility Routines -----
-
-/*****************************************************************************/
-
-#pragma mark GetTempBuffer
-
-Ptr
-GetTempBuffer(
-       ByteCount buffReqSize,
-       ByteCount *buffActSize);
-
-/*
-       The GetTempBuffer function allocates a temporary buffer for file system
-       operations which is at least 4K bytes and a multiple of 4K bytes.
-       
-       buffReqSize                     --> Size you'd like the buffer to be.
-       buffActSize                     <-- The size of the buffer allocated.
-       function result         <-- Pointer to memory allocated, or NULL if no memory
-                                                       was available. The caller is responsible for
-                                                       disposing of this buffer with DisposePtr.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FileRefNumGetFSRef
-
-OSErr
-FileRefNumGetFSRef(
-       short refNum,
-       FSRef *ref);
-
-/*
-       The FileRefNumGetFSRef function gets the FSRef of an open file.
-
-       refNum                          --> The file reference number of an open file.
-       ref                                     <-- The FSRef to the open file.
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSSetDefault
-
-OSErr
-FSSetDefault(
-       const FSRef *newDefault,
-       FSRef *oldDefault);
-
-/*
-       The FSSetDefault function sets the current working directory to the
-       directory specified by newDefault. The previous current working directory
-       is returned in oldDefault and must be used to restore the current working
-       directory to its previous state with the FSRestoreDefault function.
-       These two functions are designed to be used as a wrapper around
-       Standard I/O routines where the location of the file is implied to be the
-       current working directory. This is how you should use these functions:
-       
-               result = FSSetDefault(&newDefault, &oldDefault);
-               if ( noErr == result )
-               {
-                       // call the Stdio functions like remove, rename,
-                       // fopen, freopen, etc here!
-
-                       result = FSRestoreDefault(&oldDefault);
-               }
-       
-       newDefault                      --> An FSRef that specifies the new current working
-                                                       directory.
-       oldDefault                      <-- The previous current working directory's FSRef.
-       
-       __________
-       
-       Also see:       FSRestoreDefault
-*/
-
-/*****************************************************************************/
-
-#pragma mark FSRestoreDefault
-
-OSErr
-FSRestoreDefault(
-       const FSRef *oldDefault);
-
-/*
-       The FSRestoreDefault function restores the current working directory
-       to the directory specified by oldDefault. The oldDefault parameter was
-       previously obtained from the FSSetDefault function.
-       These two functions are designed to be used as a wrapper around
-       Standard I/O routines where the location of the file is implied to be the
-       current working directory. This is how you should use these functions:
-       
-               result = FSSetDefault(&newDefault, &oldDefault);
-               if ( noErr == result )
-               {
-                       // call the Stdio functions like remove, rename,
-                       // fopen, freopen, etc here!
-
-                       result = FSRestoreDefault(&oldDefault);
-               }
-               
-       oldDefault                      --> The FSRef of the location to restore.
-       
-       __________
-       
-       Also see:       FSSetDefault
-*/
-
-/*****************************************************************************/
-
-#if PRAGMA_STRUCT_ALIGN
-       #pragma options align=reset
-#elif PRAGMA_STRUCT_PACKPUSH
-       #pragma pack(pop)
-#elif PRAGMA_STRUCT_PACK
-       #pragma pack()
-#endif
-
-#ifdef PRAGMA_IMPORT_OFF
-#pragma import off
-#elif PRAGMA_IMPORT
-#pragma import reset
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* __MOREFILESX__ */
-
diff --git a/src/mac/morefilex/MoreFilesXReadMe.txt b/src/mac/morefilex/MoreFilesXReadMe.txt
deleted file mode 100644 (file)
index 8f1c21d..0000000
+++ /dev/null
@@ -1,125 +0,0 @@
-MoreFilesX
-
-Copyright (c) 1992-2002 Apple Computer, Inc.
-All rights reserved.
-
-________________________________________________________________________________
-
-About MoreFilesX
-
-MoreFilesX is a collection of useful high-level File Manager routines that use the HFS Plus APIs introduced in Mac OS 9.0 wherever possible.
-
-While many of the routines in MoreFilesX are based on the older MoreFiles sample code (which used the older File Manager APIs), by using the HFS Plus APIs, the routines in MoreFilesX have several advantages over the older MoreFiles code:
-
-¥ The routines are simpler to understand because the high-level HFS Plus APIs are more powerful.
-
-¥ The routines support the features of the HFS Plus volume format such as long Unicode filenames and files larger than 2GB.
-
-¥ In many cases, the routines execute more efficiently than code that uses the older File Manager APIs -- especially on non-HFS volumes.
-
-¥ The routines use Apple's standard exception and assertion macros (the require, check, and verify macros) which improves readability and error handling, and which provides easy debug builds -- just add #define DEBUG 1 and every exception causes an assertion.
-
-¥ The routines are thread safe. There are no global or static variables so multiple program threads can use MoreFilesX routines safely.
-
-If you are writing new Carbon applications for Mac OS X that call the File Manager, you should use MoreFilesX -- not MoreFiles. If you're porting existing applications to Mac OS X and those applications use routines from MoreFiles, you should consider switching to the routines in MoreFilesX.
-
-The routines were designed for applications running in the Mac OS X Carbon environment. All of the routines will work under Mac OS 9 if you define BuildingMoreFilesXForMacOS9 to 1. Doing that removes code that calls Mac OS X only APIs. MoreFilesX cannot be used in pre-Mac OS 9 system releases.
-
-The routines in MoreFilesX have been tested (but not stress-tested) and are fully documented.
-
-________________________________________________________________________________
-
-Files in the MoreFilesX Package
-
-MoreFilesX.c - the source code for MoreFilesX.
-
-MoreFilesX.h - the header files and complete documentation for the routines included in MoreFilesX.
-
-________________________________________________________________________________
-
-How to use MoreFilesX
-
-You can compile the code and link it into your programs. You can cut and paste portions of it into your programs. You can use it as an example. Since MoreFilesX is sample code, many routines are there simply to show you how to use the File Manager APIs. If a routine does more or less than what you want, you can have the source so you can modify it to do exactly you want it to do. Feel free to rip MoreFilesX off and modify its code in whatever ways you find work best for you.
-
-You'll also notice that all routines that make other File Manager calls return an OSErr or OSStatus result. I always check for error results and you should too.
-
-________________________________________________________________________________
-
-Documentation
-
-The documentation for the routines can be found in the header files. There, you'll find function prototypes, and a description of each call that includes a complete listing of all input and output parameters. For example, here's the function prototype and documentation for one of the routines, FSPathMakeFSSpec.
-
-OSStatus
-FSPathMakeFSSpec(
-       UInt8 *path,
-       FSSpec *spec,
-       Boolean *isDirectory);  /* can be NULL */
-
-/*
-       The FSPathMakeFSSpec function converts a pathname to an FSSpec.
-       
-       path                            --> A pointer to a C String that is the pathname. The
-                                                       format of the pathname you must supply can be
-                                                       determined with the Gestalt selector gestaltFSAttr's
-                                                       gestaltFSUsesPOSIXPathsForConversion bit.
-                                                       If the gestaltFSUsesPOSIXPathsForConversion bit is
-                                                       clear, the pathname must be a Mac OS File Manager
-                                                       full pathname in a C string. If the
-                                                       gestaltFSUsesPOSIXPathsForConversion bit is set,
-                                                       the pathname must be a UTF8 encoded POSIX absolute
-                                                       pathname in a C string. In either case, the pathname
-                                                       returned by FSMakePath can be passed to
-                                                       FSPathMakeFSSpec.
-       spec                            <-- The FSSpec.
-       isDirectory                     <** An optional pointer to a Boolean.
-                                                       If not NULL, true will be returned in the Boolean
-                                                       if the specified path is a directory or false will
-                                                       be returned in the Boolean if the specified path is
-                                                       a file.
-*/
-
-What do those arrows in the documentation for each routine mean?
-       
-       --> The parameter is an input
-       
-       <-- The parameter is an output. The pointer to the variable
-               where the output will be returned (must not be NULL).
-       
-       <** The parameter is an optional output. If it is not a
-               NULL pointer, it points to the variable where the output
-               will be returned. If it is a NULL pointer, the output will
-               not be returned and will possibly let the routine and the
-               File Manager do less work. If you don't need an optional output,
-               don't ask for it.
-       **> The parameter is an optional input. If it is not a
-               NULL pointer, it points to the variable containing the
-               input data. If it is a NULL pointer, the input is not used
-               and will possibly let the routine and the File Manager
-               do less work.
-
-While most of the routines in MoreFilesX have plenty of comments to clarify what the code is doing, a few have very few comments in their code because they simply make a single File Manager call. For those routines, the routine description is the comment. If something isn't clear, take a look at File Manager documentation online at <http://developer.apple.com/techpubs/macosx/Carbon/Files/FileManager/File_Manager/index.html>.
-
-The methodology behind Apple's standard exception and assertion macros is clearly explained in Sean Parent's article "Living in an Exceptional World" develop, The Apple Technical Journal, August 1992 <http://developer.apple.com/dev/techsupport/develop/issue11toc.shtml>. Don't let the fact that this article is 10 years old fool you -- this is highly recommended reading.
-
-________________________________________________________________________________
-
-Release Notes
-
-v1.0   Jan 25, 2002
-First Release.
-       
-v1.0.1 Aug 23, 2002
-[2850624]  Fixed C++ compile errors and Project Builder warnings.
-[2853901]  Updated standard disclaimer.
-[2853905]  Fixed #if test around header includes.
-[3016251]  Changed FSMoveRenameObjectUnicode to not use the Temporary folder because it isn't available on NFS volumes.
-
-________________________________________________________________________________
-
-Bug Reports and Enhancement Requests
-
-To file bug reports and enhancement requests, please go to <http://developer.apple.com/bugreporter/> and include "MoreFilesX Sample Code" in the title of your message.
-
-Yes, we know that some of the routines available in MoreFiles still aren't in MoreFilesX. They were omitted due to time constraints.
-
-________________________________________________________________________________
index 5d3f1075717f9e5c0c00e4bcce2a577d60269696..97d16e6c67396c88600c6c421368fb07954a5803 100644 (file)
                        buildSettings = {
                                DYLIB_COMPATIBILITY_VERSION = 2.5;
                                DYLIB_CURRENT_VERSION = 2.5.0;
-                               HEADER_SEARCH_PATHS = "\"${SYMROOT}/include\" ../include mac/morefilex jpeg png regex tiff - \"$(SYSTEM_DEVELOPER_DIR)/Headers/FlatCarbon\" /usr/include";
+                               HEADER_SEARCH_PATHS = "\"${SYMROOT}/include\" ../include mac/carbon/morefilex jpeg png regex tiff - \"$(SYSTEM_DEVELOPER_DIR)/Headers/FlatCarbon\" /usr/include";
                                LIBRARY_SEARCH_PATHS = /usr/lib/gcc/darwin/3.1;
                                LIBRARY_STYLE = DYNAMIC;
                                OPTIMIZATION_CFLAGS = "-O0";
                                DEBUGGING_SYMBOLS = NO;
                                DYLIB_COMPATIBILITY_VERSION = 2.5;
                                DYLIB_CURRENT_VERSION = 2.5.0;
-                               HEADER_SEARCH_PATHS = "\"${SYMROOT}/include\" ../include mac/morefile jpeg png regex tiff - \"$(SYSTEM_DEVELOPER_DIR)/Headers/FlatCarbon\" /usr/include";
+                               HEADER_SEARCH_PATHS = "\"${SYMROOT}/include\" ../include mac/carbon/morefile jpeg png regex tiff - \"$(SYSTEM_DEVELOPER_DIR)/Headers/FlatCarbon\" /usr/include";
                                LIBRARY_STYLE = DYNAMIC;
                                OPTIMIZATION_CFLAGS = "-O3";
                                OTHER_CFLAGS = "-DNO_GCC_PRAGMA -DWXMAKINGDLL -D__WXMAC__ -DwxUSE_BASE=1 -fno-rtti -fno-exceptions -D_FILE_OFFSET_BITS=64 -D_LARGE_FILES";
                        );
                        isa = PBXGroup;
                        name = morefilex;
-                       path = mac/morefilex;
+                       path = mac/carbon/morefilex;
                        refType = 2;
                };
                CADEF54303C8C0A800000133 = {
                                F5A85D8D01FA022B0175ACA7,
                        );
                        isa = PBXGroup;
-                       path = mac;
+                       path = mac/carbon;
                        refType = 4;
                };
                F5A85D3C01FA022B0175ACA7 = {
                                F5A8620A01FA022C0175ACA7,
                        );
                        isa = PBXGroup;
-                       path = mac;
+                       path = mac/carbon;
                        refType = 4;
                };
                F5A8619A01FA022C0175ACA7 = {
                        buildSettings = {
                                DYLIB_COMPATIBILITY_VERSION = 2.5;
                                DYLIB_CURRENT_VERSION = 2.5.0;
-                               HEADER_SEARCH_PATHS = "\"${SYMROOT}/include\" ../include mac/morefilex jpeg png regex tiff - \"$(SYSTEM_DEVELOPER_DIR)/Headers/FlatCarbon\" /usr/include";
+                               HEADER_SEARCH_PATHS = "\"${SYMROOT}/include\" ../include mac/carbon/morefilex jpeg png regex tiff - \"$(SYSTEM_DEVELOPER_DIR)/Headers/FlatCarbon\" /usr/include";
                                LIBRARY_STYLE = STATIC;
                                OPTIMIZATION_CFLAGS = "-O0";
                                OTHER_CFLAGS = "-DNO_GCC_PRAGMA -D__WXDEBUG__ -D__WXMAC__ -DwxUSE_BASE=1 -fno-rtti -fno-exceptions -D_FILE_OFFSET_BITS=64 -D_LARGE_FILES";
                                DEBUGGING_SYMBOLS = NO;
                                DYLIB_COMPATIBILITY_VERSION = 2.5;
                                DYLIB_CURRENT_VERSION = 2.5.0;
-                               HEADER_SEARCH_PATHS = "\"${SYMROOT}/include\" ../include mac/morefile jpeg png regex tiff - \"$(SYSTEM_DEVELOPER_DIR)/Headers/FlatCarbon\" /usr/include";
+                               HEADER_SEARCH_PATHS = "\"${SYMROOT}/include\" ../include mac/carbon/morefile jpeg png regex tiff - \"$(SYSTEM_DEVELOPER_DIR)/Headers/FlatCarbon\" /usr/include";
                                LIBRARY_STYLE = STATIC;
                                OPTIMIZATION_CFLAGS = "-O3";
                                OTHER_CFLAGS = "-DNO_GCC_PRAGMA -D__WXMAC__ -DwxUSE_BASE=1 -fno-rtti -fno-exceptions -D_FILE_OFFSET_BITS=64 -D_LARGE_FILES";