!c99Shell v. 1.0 pre-release build #16!

Software: Apache/2.2.3 (CentOS). PHP/5.1.6 

uname -a: Linux mx-ll-110-164-51-230.static.3bb.co.th 2.6.18-194.el5PAE #1 SMP Fri Apr 2 15:37:44
EDT 2010 i686
 

uid=48(apache) gid=48(apache) groups=48(apache) 

Safe-mode: OFF (not secure)

/var/www/html/phpMyAdmin/libraries/   drwxr-xr-x
Free 52.33 GB of 127.8 GB (40.95%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     database_interface.lib.php (39.79 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
Information:
Path /var/www/html/phpMyAdmin/libraries/database_interface.lib.php
Size 39.79 KB
MD5 f1a8469fe8e58efc4773f92a678a8846
Owner/Group apache/root
Perms-rw-r--r--
Create time 05/09/2012 17:45:15
Access time 31/07/2024 03:33:22
MODIFY time 09/03/2006 00:54:29

FULL HEXDUMP
00000000
00000018
00000030
00000048
00000060
00000078
00000090
000000A8
000000C0
000000D8
000000F0
00000108
00000120
00000138
00000150
00000168
00000180
00000198
000001B0
000001C8
000001E0
000001F8
00000210
00000228
00000240
00000258
00000270
00000288
000002A0
000002B8
000002D0
000002E8
00000300
00000318
00000330
00000348
00000360
00000378
00000390
000003A8
000003C0
000003D8
000003F0
00000408
00000420
00000438
00000450
00000468
00000480
00000498
000004B0
000004C8
000004E0
000004F8
00000510
00000528
00000540
00000558
00000570
00000588
000005A0
000005B8
000005D0
000005E8
00000600
00000618
00000630
00000648
00000660
00000678
00000690
000006A8
000006C0
000006D8
000006F0
00000708
00000720
00000738
00000750
00000768
00000780
00000798
000007B0
000007C8
000007E0
000007F8
00000810
00000828
00000840
00000858
00000870
00000888
000008A0
000008B8
000008D0
000008E8
00000900
00000918
00000930
00000948
00000960
00000978
00000990
000009A8
000009C0
000009D8
000009F0
00000A08
00000A20
00000A38
00000A50
00000A68
00000A80
00000A98
00000AB0
00000AC8
00000AE0
00000AF8
00000B10
00000B28
00000B40
00000B58
00000B70
00000B88
00000BA0
00000BB8
00000BD0
00000BE8
00000C00
00000C18
00000C30
00000C48
00000C60
00000C78
00000C90
00000CA8
00000CC0
00000CD8
00000CF0
00000D08
00000D20
00000D38
00000D50
00000D68
00000D80
00000D98
00000DB0
00000DC8
00000DE0
00000DF8
00000E10
00000E28
00000E40
00000E58
00000E70
00000E88
00000EA0
00000EB8
00000ED0
00000EE8
00000F00
00000F18
00000F30
00000F48
00000F60
00000F78
00000F90
00000FA8
00000FC0
00000FD8
00000FF0
00001008
00001020
00001038
00001050
00001068
00001080
00001098
000010B0
000010C8
000010E0
000010F8
00001110
00001128
00001140
00001158
00001170
00001188
000011A0
000011B8
000011D0
000011E8
00001200
00001218
00001230
00001248
00001260
00001278
00001290
000012A8
000012C0
000012D8
000012F0
00001308
00001320
00001338
00001350
00001368
00001380
00001398
000013B0
000013C8
000013E0
000013F8
00001410
00001428
00001440
00001458
00001470
00001488
000014A0
000014B8
000014D0
000014E8
00001500
00001518
00001530
00001548
00001560
00001578
00001590
000015A8
000015C0
000015D8
000015F0
00001608
00001620
00001638
00001650
00001668
00001680
00001698
000016B0
000016C8
000016E0
000016F8
00001710
00001728
00001740
00001758
00001770
00001788
000017A0
000017B8
000017D0
000017E8
00001800
00001818
00001830
00001848
00001860
00001878
00001890
000018A8
000018C0
000018D8
000018F0
00001908
00001920
00001938
00001950
00001968
00001980
00001998
000019B0
000019C8
000019E0
000019F8
00001A10
00001A28
00001A40
00001A58
00001A70
00001A88
00001AA0
00001AB8
00001AD0
00001AE8
00001B00
00001B18
00001B30
00001B48
00001B60
00001B78
00001B90
00001BA8
00001BC0
00001BD8
00001BF0
00001C08
00001C20
00001C38
00001C50
00001C68
00001C80
00001C98
00001CB0
00001CC8
00001CE0
00001CF8
00001D10
00001D28
00001D40
00001D58
00001D70
00001D88
00001DA0
00001DB8
00001DD0
00001DE8
00001E00
00001E18
00001E30
00001E48
00001E60
00001E78
00001E90
00001EA8
00001EC0
00001ED8
00001EF0
00001F08
00001F20
00001F38
00001F50
00001F68
00001F80
00001F98
00001FB0
00001FC8
00001FE0
00001FF8
00002010
00002028
00002040
00002058
00002070
00002088
000020A0
000020B8
000020D0
000020E8
00002100
00002118
00002130
00002148
00002160
00002178
00002190
000021A8
000021C0
000021D8
000021F0
00002208
00002220
00002238
00002250
00002268
00002280
00002298
000022B0
000022C8
000022E0
000022F8
00002310
00002328
00002340
00002358
00002370
00002388
000023A0
000023B8
000023D0
000023E8
00002400
00002418
00002430
00002448
00002460
00002478
00002490
000024A8
000024C0
000024D8
000024F0
00002508
00002520
00002538
00002550
00002568
00002580
00002598
000025B0
000025C8
000025E0
000025F8
00002610
00002628
00002640
00002658
00002670
00002688
000026A0
000026B8
000026D0
000026E8
00002700
00002718
00002730
00002748
00002760
00002778
00002790
000027A8
000027C0
000027D8
000027F0
00002808
00002820
00002838
00002850
00002868
00002880
00002898
000028B0
000028C8
000028E0
000028F8
00002910
00002928
00002940
00002958
00002970
00002988
000029A0
000029B8
000029D0
000029E8
00002A00
00002A18
00002A30
00002A48
00002A60
00002A78
00002A90
00002AA8
00002AC0
00002AD8
00002AF0
00002B08
00002B20
00002B38
00002B50
00002B68
00002B80
00002B98
00002BB0
00002BC8
00002BE0
00002BF8
00002C10
00002C28
00002C40
00002C58
00002C70
00002C88
00002CA0
00002CB8
00002CD0
00002CE8
00002D00
00002D18
00002D30
00002D48
00002D60
00002D78
00002D90
00002DA8
00002DC0
00002DD8
00002DF0
00002E08
00002E20
00002E38
00002E50
00002E68
00002E80
00002E98
00002EB0
00002EC8
00002EE0
00002EF8
00002F10
00002F28
00002F40
00002F58
00002F70
00002F88
00002FA0
00002FB8
00002FD0
00002FE8
00003000
00003018
00003030
00003048
00003060
00003078
00003090
000030A8
000030C0
000030D8
000030F0
00003108
00003120
00003138
00003150
00003168
00003180
00003198
000031B0
000031C8
000031E0
000031F8
00003210
00003228
00003240
00003258
00003270
00003288
000032A0
000032B8
000032D0
000032E8
00003300
00003318
00003330
00003348
00003360
00003378
00003390
000033A8
000033C0
000033D8
000033F0
00003408
00003420
00003438
00003450
00003468
00003480
00003498
000034B0
000034C8
000034E0
000034F8
00003510
00003528
00003540
00003558
00003570
00003588
000035A0
000035B8
000035D0
000035E8
00003600
00003618
00003630
00003648
00003660
00003678
00003690
000036A8
000036C0
000036D8
000036F0
00003708
00003720
00003738
00003750
00003768
00003780
00003798
000037B0
000037C8
000037E0
000037F8
00003810
00003828
00003840
00003858
00003870
00003888
000038A0
000038B8
000038D0
000038E8
00003900
00003918
00003930
00003948
00003960
00003978
00003990
000039A8
000039C0
000039D8
000039F0
00003A08
00003A20
00003A38
00003A50
00003A68
00003A80
00003A98
00003AB0
00003AC8
00003AE0
00003AF8
00003B10
00003B28
00003B40
00003B58
00003B70
00003B88
00003BA0
00003BB8
00003BD0
00003BE8
00003C00
00003C18
00003C30
00003C48
00003C60
00003C78
00003C90
00003CA8
00003CC0
00003CD8
00003CF0
00003D08
00003D20
00003D38
00003D50
00003D68
00003D80
00003D98
00003DB0
00003DC8
00003DE0
00003DF8
00003E10
00003E28
00003E40
00003E58
00003E70
00003E88
00003EA0
00003EB8
00003ED0
00003EE8
00003F00
00003F18
00003F30
00003F48
00003F60
00003F78
00003F90
00003FA8
00003FC0
00003FD8
00003FF0
00004008
00004020
00004038
00004050
00004068
00004080
00004098
000040B0
000040C8
000040E0
000040F8
00004110
00004128
00004140
00004158
00004170
00004188
000041A0
000041B8
000041D0
000041E8
00004200
00004218
00004230
00004248
00004260
00004278
00004290
000042A8
000042C0
000042D8
000042F0
00004308
00004320
00004338
00004350
00004368
00004380
00004398
000043B0
000043C8
000043E0
000043F8
00004410
00004428
00004440
00004458
00004470
00004488
000044A0
000044B8
000044D0
000044E8
00004500
00004518
00004530
00004548
00004560
00004578
00004590
000045A8
000045C0
000045D8
000045F0
00004608
00004620
00004638
00004650
00004668
00004680
00004698
000046B0
000046C8
000046E0
000046F8
00004710
00004728
00004740
00004758
00004770
00004788
000047A0
000047B8
000047D0
000047E8
00004800
00004818
00004830
00004848
00004860
00004878
00004890
000048A8
000048C0
000048D8
000048F0
00004908
00004920
00004938
00004950
00004968
00004980
00004998
000049B0
000049C8
000049E0
000049F8
00004A10
00004A28
00004A40
00004A58
00004A70
00004A88
00004AA0
00004AB8
00004AD0
00004AE8
00004B00
00004B18
00004B30
00004B48
00004B60
00004B78
00004B90
00004BA8
00004BC0
00004BD8
00004BF0
00004C08
00004C20
00004C38
00004C50
00004C68
00004C80
00004C98
00004CB0
00004CC8
00004CE0
00004CF8
00004D10
00004D28
00004D40
00004D58
00004D70
00004D88
00004DA0
00004DB8
00004DD0
00004DE8
00004E00
00004E18
00004E30
00004E48
00004E60
00004E78
00004E90
00004EA8
00004EC0
00004ED8
00004EF0
00004F08
00004F20
00004F38
00004F50
00004F68
00004F80
00004F98
00004FB0
00004FC8
00004FE0
00004FF8
00005010
00005028
00005040
00005058
00005070
00005088
000050A0
000050B8
000050D0
000050E8
00005100
00005118
00005130
00005148
00005160
00005178
00005190
000051A8
000051C0
000051D8
000051F0
00005208
00005220
00005238
00005250
00005268
00005280
00005298
000052B0
000052C8
000052E0
000052F8
00005310
00005328
00005340
00005358
00005370
00005388
000053A0
000053B8
000053D0
000053E8
00005400
00005418
00005430
00005448
00005460
00005478
00005490
000054A8
000054C0
000054D8
000054F0
00005508
00005520
00005538
00005550
00005568
00005580
00005598
000055B0
000055C8
000055E0
000055F8
00005610
00005628
00005640
00005658
00005670
00005688
000056A0
000056B8
000056D0
000056E8
00005700
00005718
00005730
00005748
00005760
00005778
00005790
000057A8
000057C0
000057D8
000057F0
00005808
00005820
00005838
00005850
00005868
00005880
00005898
000058B0
000058C8
000058E0
000058F8
00005910
00005928
00005940
00005958
00005970
00005988
000059A0
000059B8
000059D0
000059E8
00005A00
00005A18
00005A30
00005A48
00005A60
00005A78
00005A90
00005AA8
00005AC0
00005AD8
00005AF0
00005B08
00005B20
00005B38
00005B50
00005B68
00005B80
00005B98
00005BB0
00005BC8
00005BE0
00005BF8
00005C10
00005C28
00005C40
00005C58
00005C70
00005C88
00005CA0
00005CB8
00005CD0
00005CE8
00005D00
00005D18
00005D30
00005D48
00005D60
00005D78
00005D90
00005DA8
00005DC0
00005DD8
00005DF0
00005E08
00005E20
00005E38
00005E50
00005E68
00005E80
00005E98
00005EB0
00005EC8
00005EE0
00005EF8
00005F10
00005F28
00005F40
00005F58
00005F70
00005F88
00005FA0
00005FB8
00005FD0
00005FE8
00006000
00006018
00006030
00006048
00006060
00006078
00006090
000060A8
000060C0
000060D8
000060F0
00006108
00006120
00006138
00006150
00006168
00006180
00006198
000061B0
000061C8
000061E0
000061F8
00006210
00006228
00006240
00006258
00006270
00006288
000062A0
000062B8
000062D0
000062E8
00006300
00006318
00006330
00006348
00006360
00006378
00006390
000063A8
000063C0
000063D8
000063F0
00006408
00006420
00006438
00006450
00006468
00006480
00006498
000064B0
000064C8
000064E0
000064F8
00006510
00006528
00006540
00006558
00006570
00006588
000065A0
000065B8
000065D0
000065E8
00006600
00006618
00006630
00006648
00006660
00006678
00006690
000066A8
000066C0
000066D8
000066F0
00006708
00006720
00006738
00006750
00006768
00006780
00006798
000067B0
000067C8
000067E0
000067F8
00006810
00006828
00006840
00006858
00006870
00006888
000068A0
000068B8
000068D0
000068E8
00006900
00006918
00006930
00006948
00006960
00006978
00006990
000069A8
000069C0
000069D8
000069F0
00006A08
00006A20
00006A38
00006A50
00006A68
00006A80
00006A98
00006AB0
00006AC8
00006AE0
00006AF8
00006B10
00006B28
00006B40
00006B58
00006B70
00006B88
00006BA0
00006BB8
00006BD0
00006BE8
00006C00
00006C18
00006C30
00006C48
00006C60
00006C78
00006C90
00006CA8
00006CC0
00006CD8
00006CF0
00006D08
00006D20
00006D38
00006D50
00006D68
00006D80
00006D98
00006DB0
00006DC8
00006DE0
00006DF8
00006E10
00006E28
00006E40
00006E58
00006E70
00006E88
00006EA0
00006EB8
00006ED0
00006EE8
00006F00
00006F18
00006F30
00006F48
00006F60
00006F78
00006F90
00006FA8
00006FC0
00006FD8
00006FF0
00007008
00007020
00007038
00007050
00007068
00007080
00007098
000070B0
000070C8
000070E0
000070F8
00007110
00007128
00007140
00007158
00007170
00007188
000071A0
000071B8
000071D0
000071E8
00007200
00007218
00007230
00007248
00007260
00007278
00007290
000072A8
000072C0
000072D8
000072F0
00007308
00007320
00007338
00007350
00007368
00007380
00007398
000073B0
000073C8
000073E0
000073F8
00007410
00007428
00007440
00007458
00007470
00007488
000074A0
000074B8
000074D0
000074E8
00007500
00007518
00007530
00007548
00007560
00007578
00007590
000075A8
000075C0
000075D8
000075F0
00007608
00007620
00007638
00007650
00007668
00007680
00007698
000076B0
000076C8
000076E0
000076F8
00007710
00007728
00007740
00007758
00007770
00007788
000077A0
000077B8
000077D0
000077E8
00007800
00007818
00007830
00007848
00007860
00007878
00007890
000078A8
000078C0
000078D8
000078F0
00007908
00007920
00007938
00007950
00007968
00007980
00007998
000079B0
000079C8
000079E0
000079F8
00007A10
00007A28
00007A40
00007A58
00007A70
00007A88
00007AA0
00007AB8
00007AD0
00007AE8
00007B00
00007B18
00007B30
00007B48
00007B60
00007B78
00007B90
00007BA8
00007BC0
00007BD8
00007BF0
00007C08
00007C20
00007C38
00007C50
00007C68
00007C80
00007C98
00007CB0
00007CC8
00007CE0
00007CF8
00007D10
00007D28
00007D40
00007D58
00007D70
00007D88
00007DA0
00007DB8
00007DD0
00007DE8
00007E00
00007E18
00007E30
00007E48
00007E60
00007E78
00007E90
00007EA8
00007EC0
00007ED8
00007EF0
00007F08
00007F20
00007F38
00007F50
00007F68
00007F80
00007F98
00007FB0
00007FC8
00007FE0
00007FF8
00008010
00008028
00008040
00008058
00008070
00008088
000080A0
000080B8
000080D0
000080E8
00008100
00008118
00008130
00008148
00008160
00008178
00008190
000081A8
000081C0
000081D8
000081F0
00008208
00008220
00008238
00008250
00008268
00008280
00008298
000082B0
000082C8
000082E0
000082F8
00008310
00008328
00008340
00008358
00008370
00008388
000083A0
000083B8
000083D0
000083E8
00008400
00008418
00008430
00008448
00008460
00008478
00008490
000084A8
000084C0
000084D8
000084F0
00008508
00008520
00008538
00008550
00008568
00008580
00008598
000085B0
000085C8
000085E0
000085F8
00008610
00008628
00008640
00008658
00008670
00008688
000086A0
000086B8
000086D0
000086E8
00008700
00008718
00008730
00008748
00008760
00008778
00008790
000087A8
000087C0
000087D8
000087F0
00008808
00008820
00008838
00008850
00008868
00008880
00008898
000088B0
000088C8
000088E0
000088F8
00008910
00008928
00008940
00008958
00008970
00008988
000089A0
000089B8
000089D0
000089E8
00008A00
00008A18
00008A30
00008A48
00008A60
00008A78
00008A90
00008AA8
00008AC0
00008AD8
00008AF0
00008B08
00008B20
00008B38
00008B50
00008B68
00008B80
00008B98
00008BB0
00008BC8
00008BE0
00008BF8
00008C10
00008C28
00008C40
00008C58
00008C70
00008C88
00008CA0
00008CB8
00008CD0
00008CE8
00008D00
00008D18
00008D30
00008D48
00008D60
00008D78
00008D90
00008DA8
00008DC0
00008DD8
00008DF0
00008E08
00008E20
00008E38
00008E50
00008E68
00008E80
00008E98
00008EB0
00008EC8
00008EE0
00008EF8
00008F10
00008F28
00008F40
00008F58
00008F70
00008F88
00008FA0
00008FB8
00008FD0
00008FE8
00009000
00009018
00009030
00009048
00009060
00009078
00009090
000090A8
000090C0
000090D8
000090F0
00009108
00009120
00009138
00009150
00009168
00009180
00009198
000091B0
000091C8
000091E0
000091F8
00009210
00009228
00009240
00009258
00009270
00009288
000092A0
000092B8
000092D0
000092E8
00009300
00009318
00009330
00009348
00009360
00009378
00009390
000093A8
000093C0
000093D8
000093F0
00009408
00009420
00009438
00009450
00009468
00009480
00009498
000094B0
000094C8
000094E0
000094F8
00009510
00009528
00009540
00009558
00009570
00009588
000095A0
000095B8
000095D0
000095E8
00009600
00009618
00009630
00009648
00009660
00009678
00009690
000096A8
000096C0
000096D8
000096F0
00009708
00009720
00009738
00009750
00009768
00009780
00009798
000097B0
000097C8
000097E0
000097F8
00009810
00009828
00009840
00009858
00009870
00009888
000098A0
000098B8
000098D0
000098E8
00009900
00009918
00009930
00009948
00009960
00009978
00009990
000099A8
000099C0
000099D8
000099F0
00009A08
00009A20
00009A38
00009A50
00009A68
00009A80
00009A98
00009AB0
00009AC8
00009AE0
00009AF8
00009B10
00009B28
00009B40
00009B58
00009B70
00009B88
00009BA0
00009BB8
00009BD0
00009BE8
00009C00
00009C18
00009C30
00009C48
00009C60
00009C78
00009C90
00009CA8
00009CC0
00009CD8
00009CF0
00009D08
00009D20
00009D38
00009D50
00009D68
00009D80
00009D98
00009DB0
00009DC8
00009DE0
00009DF8
00009E10
00009E28
00009E40
00009E58
00009E70
00009E88
00009EA0
00009EB8
00009ED0
00009EE8
00009F00
00009F18
3C 3F 70 68 70 0A 2F 2A 20 24 49 64 3A 20 64 61 74 61 62 61 73 65 5F 69
6E 74 65 72 66 61 63 65 2E 6C 69 62 2E 70 68 70 2C 76 20 32 2E 33 39 2E
32 2E 32 20 32 30 30 36 2F 30 33 2F 30 38 20 31 37 3A 35 34 3A 32 39 20
6C 65 6D 39 20 45 78 70 20 24 20 2A 2F 0A 2F 2F 20 76 69 6D 3A 20 65 78
70 61 6E 64 74 61 62 20 73 77 3D 34 20 74 73 3D 34 20 73 74 73 3D 34 3A
0A 0A 2F 2A 2A 0A 20 2A 20 43 6F 6D 6D 6F 6E 20 4F 70 74 69 6F 6E 20 43
6F 6E 73 74 61 6E 74 73 20 46 6F 72 20 44 42 49 20 46 75 6E 63 74 69 6F
6E 73 0A 20 2A 2F 0A 2F 2F 20 50 4D 41 5F 44 42 49 5F 74 72 79 5F 71 75
65 72 79 28 29 0A 64 65 66 69 6E 65 28 27 50 4D 41 5F 44 42 49 5F 51 55
45 52 59 5F 53 54 4F 52 45 27 2C 20 20 20 20 20 20 20 31 29 3B 20 20 2F
2F 20 46 6F 72 63 65 20 53 54 4F 52 45 5F 52 45 53 55 4C 54 20 6D 65 74
68 6F 64 2C 20 69 67 6E 6F 72 65 64 20 62 79 20 63 6C 61 73 73 69 63 20
4D 79 53 51 4C 2E 0A 64 65 66 69 6E 65 28 27 50 4D 41 5F 44 42 49 5F 51
55 45 52 59 5F 55 4E 42 55 46 46 45 52 45 44 27 2C 20 20 32 29 3B 20 20
2F 2F 20 44 6F 20 6E 6F 74 20 72 65 61 64 20 77 68 6F 6C 65 20 71 75 65
72 79 0A 2F 2F 20 50 4D 41 5F 44 42 49 5F 67 65 74 5F 76 61 72 69 61 62
6C 65 28 29 0A 64 65 66 69 6E 65 28 27 50 4D 41 5F 44 42 49 5F 47 45 54
56 41 52 5F 53 45 53 53 49 4F 4E 27 2C 20 31 29 3B 0A 64 65 66 69 6E 65
28 27 50 4D 41 5F 44 42 49 5F 47 45 54 56 41 52 5F 47 4C 4F 42 41 4C 27
2C 20 32 29 3B 0A 0A 2F 2A 2A 0A 20 2A 20 4C 6F 61 64 73 20 74 68 65 20
6D 79 73 71 6C 20 65 78 74 65 6E 73 69 6F 6E 73 20 69 66 20 69 74 20 69
73 20 6E 6F 74 20 6C 6F 61 64 65 64 20 79 65 74 0A 20 2A 0A 20 2A 20 40
70 61 72 61 6D 20 20 20 73 74 72 69 6E 67 20 20 24 65 78 74 65 6E 73 69
6F 6E 20 20 6D 79 73 71 6C 20 65 78 74 65 6E 73 69 6F 6E 20 74 6F 20 6C
6F 61 64 0A 20 2A 2F 0A 66 75 6E 63 74 69 6F 6E 20 50 4D 41 5F 44 42 49
5F 63 68 65 63 6B 41 6E 64 4C 6F 61 64 4D 79 73 71 6C 45 78 74 65 6E 73
69 6F 6E 28 20 24 65 78 74 65 6E 73 69 6F 6E 20 3D 20 27 6D 79 73 71 6C
27 20 29 20 7B 0A 20 20 20 20 69 66 20 28 20 21 20 66 75 6E 63 74 69 6F
6E 5F 65 78 69 73 74 73 28 20 24 65 78 74 65 6E 73 69 6F 6E 20 2E 20 27
5F 63 6F 6E 6E 65 63 74 27 20 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20
50 4D 41 5F 64 6C 28 20 24 65 78 74 65 6E 73 69 6F 6E 20 29 3B 0A 20 20
20 20 20 20 20 20 2F 2F 20 63 68 65 63 6B 20 77 68 65 74 68 65 72 20 6D
79 73 71 6C 20 69 73 20 61 76 61 69 6C 61 62 6C 65 0A 20 20 20 20 20 20
20 20 69 66 20 28 20 21 20 66 75 6E 63 74 69 6F 6E 5F 65 78 69 73 74 73
28 20 24 65 78 74 65 6E 73 69 6F 6E 20 2E 20 27 5F 63 6F 6E 6E 65 63 74
27 20 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75
72 6E 20 66 61 6C 73 65 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20
7D 0A 0A 20 20 20 20 72 65 74 75 72 6E 20 74 72 75 65 3B 0A 7D 0A 0A 0A
2F 2A 2A 0A 20 2A 20 63 68 65 63 6B 20 66 6F 72 20 72 65 71 75 65 73 74
65 64 20 65 78 74 65 6E 73 69 6F 6E 0A 20 2A 2F 0A 69 66 20 28 20 21 20
50 4D 41 5F 44 42 49 5F 63 68 65 63 6B 41 6E 64 4C 6F 61 64 4D 79 73 71
6C 45 78 74 65 6E 73 69 6F 6E 28 20 24 47 4C 4F 42 41 4C 53 5B 27 63 66
67 27 5D 5B 27 53 65 72 76 65 72 27 5D 5B 27 65 78 74 65 6E 73 69 6F 6E
27 5D 20 29 20 29 20 7B 0A 0A 20 20 20 20 2F 2F 20 69 66 20 69 74 20 66
61 69 6C 73 20 74 72 79 20 61 6C 74 65 72 6E 61 74 69 76 65 20 65 78 74
65 6E 73 69 6F 6E 20 2E 2E 2E 0A 20 20 20 20 2F 2F 20 61 6E 64 20 64 69
73 70 6C 61 79 20 61 6E 20 65 72 72 6F 72 20 2E 2E 2E 0A 0A 20 20 20 20
2F 2F 20 54 4F 44 4F 20 32 2E 37 2E 31 3A 20 61 64 64 20 64 69 66 66 65
72 65 6E 74 20 6D 65 73 73 61 67 65 73 20 66 6F 72 20 61 6C 74 65 72 6E
61 74 69 76 20 65 78 74 65 6E 73 69 6F 6E 0A 20 20 20 20 2F 2F 20 61 6E
64 20 63 6F 6D 70 6C 65 74 65 20 66 61 69 6C 20 28 6E 6F 20 61 6C 74 65
72 6E 61 74 69 76 20 65 78 74 65 6E 73 69 6F 6E 20 74 6F 6F 29 0A 20 20
20 20 24 47 4C 4F 42 41 4C 53 5B 27 50 4D 41 5F 65 72 72 6F 72 73 27 5D
5B 5D 20 3D 0A 20 20 20 20 20 20 20 20 73 70 72 69 6E 74 66 28 20 50 4D
41 5F 73 61 6E 69 74 69 7A 65 28 20 24 47 4C 4F 42 41 4C 53 5B 27 73 74
72 43 61 6E 74 4C 6F 61 64 27 5D 20 29 2C 0A 20 20 20 20 20 20 20 20 20
20 20 20 24 47 4C 4F 42 41 4C 53 5B 27 63 66 67 27 5D 5B 27 53 65 72 76
65 72 27 5D 5B 27 65 78 74 65 6E 73 69 6F 6E 27 5D 20 29 0A 20 20 20 20
20 20 20 20 2E 27 20 2D 20 3C 61 20 68 72 65 66 3D 22 2E 2F 44 6F 63 75
6D 65 6E 74 61 74 69 6F 6E 2E 68 74 6D 6C 23 66 61 71 6D 79 73 71 6C 22
20 74 61 72 67 65 74 3D 22 64 6F 63 75 6D 65 6E 74 61 74 69 6F 6E 22 3E
27 0A 20 20 20 20 20 20 20 20 2E 24 47 4C 4F 42 41 4C 53 5B 27 73 74 72
44 6F 63 75 27 5D 20 2E 20 27 3C 2F 61 3E 27 3B 0A 0A 20 20 20 20 69 66
20 28 20 24 47 4C 4F 42 41 4C 53 5B 27 63 66 67 27 5D 5B 27 53 65 72 76
65 72 27 5D 5B 27 65 78 74 65 6E 73 69 6F 6E 27 5D 20 3D 3D 3D 20 27 6D
79 73 71 6C 27 20 29 20 7B 0A 20 20 20 20 20 20 20 20 24 61 6C 74 65 72
6E 61 74 69 76 5F 65 78 74 65 6E 73 69 6F 6E 20 3D 20 27 6D 79 73 71 6C
69 27 3B 0A 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20
20 24 61 6C 74 65 72 6E 61 74 69 76 5F 65 78 74 65 6E 73 69 6F 6E 20 3D
20 27 6D 79 73 71 6C 27 3B 0A 20 20 20 20 7D 0A 0A 20 20 20 20 69 66 20
28 20 21 20 50 4D 41 5F 44 42 49 5F 63 68 65 63 6B 41 6E 64 4C 6F 61 64
4D 79 73 71 6C 45 78 74 65 6E 73 69 6F 6E 28 20 24 61 6C 74 65 72 6E 61
74 69 76 5F 65 78 74 65 6E 73 69 6F 6E 20 29 20 29 20 7B 0A 20 20 20 20
20 20 20 20 2F 2F 20 69 66 20 61 6C 74 65 72 6E 61 74 69 76 20 66 61 69
6C 73 20 74 6F 6F 20 2E 2E 2E 0A 20 20 20 20 20 20 20 20 68 65 61 64 65
72 28 20 27 4C 6F 63 61 74 69 6F 6E 3A 20 65 72 72 6F 72 2E 70 68 70 27
0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2E 20 27 3F 6C 61 6E
67 3D 27 20 20 2E 20 75 72 6C 65 6E 63 6F 64 65 28 20 24 61 76 61 69 6C
61 62 6C 65 5F 6C 61 6E 67 75 61 67 65 73 5B 24 6C 61 6E 67 5D 5B 32 5D
20 29 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2E 20 27 26 63
68 61 72 3D 27 20 20 2E 20 75 72 6C 65 6E 63 6F 64 65 28 20 24 63 68 61
72 73 65 74 20 29 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2E
20 27 26 64 69 72 3D 27 20 20 20 2E 20 75 72 6C 65 6E 63 6F 64 65 28 20
24 74 65 78 74 5F 64 69 72 20 29 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 2E 20 27 26 74 79 70 65 3D 27 20 20 2E 20 75 72 6C 65 6E 63
6F 64 65 28 20 24 73 74 72 45 72 72 6F 72 20 29 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 2E 20 27 26 65 72 72 6F 72 3D 27 20 2E 20 75
72 6C 65 6E 63 6F 64 65 28 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 73 70 72 69 6E 74 66 28 20 24 47 4C 4F 42 41 4C 53 5B
27 73 74 72 43 61 6E 74 4C 6F 61 64 27 5D 2C 0A 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 47 4C 4F 42 41 4C 53
5B 27 63 66 67 27 5D 5B 27 53 65 72 76 65 72 27 5D 5B 27 65 78 74 65 6E
73 69 6F 6E 27 5D 20 29 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 2E 27 20 2D 20 5B 61 40 2E 2F 44 6F 63 75 6D 65 6E 74 61
74 69 6F 6E 2E 68 74 6D 6C 23 66 61 71 6D 79 73 71 6C 40 64 6F 63 75 6D
65 6E 74 61 74 69 6F 6E 5D 27 0A 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 2E 24 47 4C 4F 42 41 4C 53 5B 27 73 74 72 44 6F 63
75 27 5D 20 2E 20 27 5B 2F 61 5D 27 20 29 0A 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 2E 20 27 26 27 20 2E 20 53 49 44 0A 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 29 3B 0A 20 20 20 20 20 20 20 20 65
78 69 74 28 29 3B 0A 20 20 20 20 7D 0A 0A 20 20 20 20 24 47 4C 4F 42 41
4C 53 5B 27 63 66 67 27 5D 5B 27 53 65 72 76 65 72 27 5D 5B 27 65 78 74
65 6E 73 69 6F 6E 27 5D 20 3D 20 24 61 6C 74 65 72 6E 61 74 69 76 5F 65
78 74 65 6E 73 69 6F 6E 3B 0A 20 20 20 20 75 6E 73 65 74 28 20 24 61 6C
74 65 72 6E 61 74 69 76 5F 65 78 74 65 6E 73 69 6F 6E 20 29 3B 0A 7D 0A
0A 2F 2A 2A 0A 20 2A 20 49 6E 63 6C 75 64 69 6E 67 20 54 68 65 20 44 42
49 20 50 6C 75 67 69 6E 0A 20 2A 2F 0A 72 65 71 75 69 72 65 5F 6F 6E 63
65 28 27 2E 2F 6C 69 62 72 61 72 69 65 73 2F 64 62 69 2F 27 20 2E 20 24
47 4C 4F 42 41 4C 53 5B 27 63 66 67 27 5D 5B 27 53 65 72 76 65 72 27 5D
5B 27 65 78 74 65 6E 73 69 6F 6E 27 5D 20 2E 20 27 2E 64 62 69 2E 6C 69
62 2E 70 68 70 27 29 3B 0A 0A 2F 2A 2A 0A 20 2A 20 43 6F 6D 6D 6F 6E 20
46 75 6E 63 74 69 6F 6E 73 0A 20 2A 2F 0A 66 75 6E 63 74 69 6F 6E 20 50
4D 41 5F 44 42 49 5F 71 75 65 72 79 28 24 71 75 65 72 79 2C 20 24 6C 69
6E 6B 20 3D 20 6E 75 6C 6C 2C 20 24 6F 70 74 69 6F 6E 73 20 3D 20 30 29
20 7B 0A 20 20 20 20 24 72 65 73 20 3D 20 50 4D 41 5F 44 42 49 5F 74 72
79 5F 71 75 65 72 79 28 24 71 75 65 72 79 2C 20 24 6C 69 6E 6B 2C 20 24
6F 70 74 69 6F 6E 73 29 0A 20 20 20 20 20 20 20 20 6F 72 20 50 4D 41 5F
6D 79 73 71 6C 44 69 65 28 50 4D 41 5F 44 42 49 5F 67 65 74 45 72 72 6F
72 28 24 6C 69 6E 6B 29 2C 20 24 71 75 65 72 79 29 3B 0A 20 20 20 20 72
65 74 75 72 6E 20 24 72 65 73 3B 0A 7D 0A 0A 2F 2A 2A 0A 20 2A 20 63 6F
6E 76 65 72 74 73 20 63 68 61 72 73 65 74 20 6F 66 20 61 20 6D 79 73 71
6C 20 6D 65 73 73 61 67 65 2C 20 75 73 61 6C 6C 79 20 63 6F 6D 69 6E 67
20 66 72 6F 6D 20 6D 79 73 71 6C 5F 65 72 72 6F 72 28 29 2C 0A 20 2A 20
69 6E 74 6F 20 50 4D 41 20 63 68 61 72 73 65 74 2C 20 75 73 61 6C 6C 79
20 55 54 46 2D 38 0A 20 2A 20 75 73 65 73 20 6C 61 6E 67 75 61 67 65 20
74 6F 20 63 68 61 72 73 65 74 20 6D 61 70 70 69 6E 67 20 66 72 6F 6D 20
6D 79 73 71 6C 2F 73 68 61 72 65 2F 65 72 72 6D 73 67 2E 74 78 74 0A 20
2A 20 61 6E 64 20 63 68 61 72 73 65 74 20 6E 61 6D 65 73 20 74 6F 20 49
53 4F 20 63 68 61 72 73 65 74 20 66 72 6F 6D 20 69 6E 66 6F 72 6D 61 74
69 6F 6E 5F 73 63 68 65 6D 61 2E 43 48 41 52 41 43 54 45 52 5F 53 45 54
53 0A 20 2A 0A 20 2A 20 40 75 73 65 73 20 20 20 20 24 47 4C 4F 42 41 4C
53 5B 27 63 66 67 27 5D 5B 27 49 63 6F 6E 76 45 78 74 72 61 50 61 72 61
6D 73 27 5D 0A 20 2A 20 40 75 73 65 73 20 20 20 20 24 47 4C 4F 42 41 4C
53 5B 27 63 68 61 72 73 65 74 27 5D 20 20 20 20 20 61 73 20 74 61 72 67
65 74 20 63 68 61 72 73 65 74 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50
4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 76 61 6C 75 65 28 29 20 20 20 74
6F 20 67 65 74 20 73 65 72 76 65 72 5F 6C 61 6E 67 75 61 67 65 0A 20 2A
20 40 75 73 65 73 20 20 20 20 70 72 65 67 5F 6D 61 74 63 68 28 29 20 20
20 20 20 20 20 20 20 20 20 20 74 6F 20 66 69 6C 74 65 72 20 73 65 72 76
65 72 5F 6C 61 6E 67 75 61 67 65 0A 20 2A 20 40 75 73 65 73 20 20 20 20
69 6E 5F 61 72 72 61 79 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 66
75 6E 63 74 69 6F 6E 5F 65 78 69 73 74 73 28 29 20 20 20 20 20 20 20 74
6F 20 63 68 65 63 6B 20 66 6F 72 20 61 20 63 6F 6E 76 65 72 74 20 66 75
6E 63 74 69 6F 6E 0A 20 2A 20 40 75 73 65 73 20 20 20 20 69 63 6F 6E 76
28 29 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 74 6F 20 63 6F
6E 76 65 72 74 20 6D 65 73 73 61 67 65 0A 20 2A 20 40 75 73 65 73 20 20
20 20 6C 69 62 69 63 6F 6E 76 28 29 20 20 20 20 20 20 20 20 20 20 20 20
20 20 74 6F 20 63 6F 6E 76 65 72 74 20 6D 65 73 73 61 67 65 0A 20 2A 20
40 75 73 65 73 20 20 20 20 72 65 63 6F 64 65 5F 73 74 72 69 6E 67 28 29
20 20 20 20 20 20 20 20 20 74 6F 20 63 6F 6E 76 65 72 74 20 6D 65 73 73
61 67 65 0A 20 2A 20 40 75 73 65 73 20 20 20 20 6D 62 5F 63 6F 6E 76 65
72 74 5F 65 6E 63 6F 64 69 6E 67 28 29 20 20 20 74 6F 20 63 6F 6E 76 65
72 74 20 6D 65 73 73 61 67 65 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 73
74 72 69 6E 67 20 20 24 6D 65 73 73 61 67 65 0A 20 2A 20 40 72 65 74 75
72 6E 20 20 73 74 72 69 6E 67 20 20 24 6D 65 73 73 61 67 65 0A 20 2A 2F
0A 66 75 6E 63 74 69 6F 6E 20 50 4D 41 5F 44 42 49 5F 63 6F 6E 76 65 72
74 5F 6D 65 73 73 61 67 65 28 20 24 6D 65 73 73 61 67 65 20 29 20 7B 0A
20 20 20 20 2F 2F 20 6C 61 74 69 6E 20 61 6C 77 61 79 73 20 6C 61 73 74
21 0A 20 20 20 20 24 65 6E 63 6F 64 69 6E 67 73 20 3D 20 61 72 72 61 79
28 0A 20 20 20 20 20 20 20 20 27 6A 61 70 61 6E 65 73 65 27 20 20 20 20
20 20 3D 3E 20 27 45 55 43 2D 4A 50 27 2C 20 2F 2F 27 75 6A 69 73 27 2C
0A 20 20 20 20 20 20 20 20 27 6A 61 70 61 6E 65 73 65 2D 73 6A 69 73 27
20 3D 3E 20 27 53 68 69 66 74 2D 4A 49 53 27 2C 20 2F 2F 27 73 6A 69 73
27 2C 0A 20 20 20 20 20 20 20 20 27 6B 6F 72 65 61 6E 27 20 20 20 20 20
20 20 20 3D 3E 20 27 45 55 43 2D 4B 52 27 2C 20 2F 2F 27 65 75 63 6B 72
27 2C 0A 20 20 20 20 20 20 20 20 27 72 75 73 73 69 61 6E 27 20 20 20 20
20 20 20 3D 3E 20 27 4B 4F 49 38 2D 52 27 2C 20 2F 2F 27 6B 6F 69 38 72
27 2C 0A 20 20 20 20 20 20 20 20 27 75 6B 72 61 69 6E 69 61 6E 27 20 20
20 20 20 3D 3E 20 27 4B 4F 49 38 2D 55 27 2C 20 2F 2F 27 6B 6F 69 38 75
27 2C 0A 20 20 20 20 20 20 20 20 27 67 72 65 65 6B 27 20 20 20 20 20 20
20 20 20 3D 3E 20 27 49 53 4F 2D 38 38 35 39 2D 37 27 2C 20 2F 2F 27 67
72 65 65 6B 27 2C 0A 20 20 20 20 20 20 20 20 27 73 65 72 62 69 61 6E 27
20 20 20 20 20 20 20 3D 3E 20 27 43 50 31 32 35 30 27 2C 20 2F 2F 27 63
70 31 32 35 30 27 2C 0A 20 20 20 20 20 20 20 20 27 65 73 74 6F 6E 69 61
6E 27 20 20 20 20 20 20 3D 3E 20 27 49 53 4F 2D 38 38 35 39 2D 31 33 27
2C 20 2F 2F 27 6C 61 74 69 6E 37 27 2C 0A 20 20 20 20 20 20 20 20 27 73
6C 6F 76 61 6B 27 20 20 20 20 20 20 20 20 3D 3E 20 27 49 53 4F 2D 38 38
35 39 2D 32 27 2C 20 2F 2F 27 6C 61 74 69 6E 32 27 2C 0A 20 20 20 20 20
20 20 20 27 63 7A 65 63 68 27 20 20 20 20 20 20 20 20 20 3D 3E 20 27 49
53 4F 2D 38 38 35 39 2D 32 27 2C 20 2F 2F 27 6C 61 74 69 6E 32 27 2C 0A
20 20 20 20 20 20 20 20 27 68 75 6E 67 61 72 69 61 6E 27 20 20 20 20 20
3D 3E 20 27 49 53 4F 2D 38 38 35 39 2D 32 27 2C 20 2F 2F 27 6C 61 74 69
6E 32 27 2C 0A 20 20 20 20 20 20 20 20 27 70 6F 6C 69 73 68 27 20 20 20
20 20 20 20 20 3D 3E 20 27 49 53 4F 2D 38 38 35 39 2D 32 27 2C 20 2F 2F
27 6C 61 74 69 6E 32 27 2C 0A 20 20 20 20 20 20 20 20 27 72 6F 6D 61 6E
69 61 6E 27 20 20 20 20 20 20 3D 3E 20 27 49 53 4F 2D 38 38 35 39 2D 32
27 2C 20 2F 2F 27 6C 61 74 69 6E 32 27 2C 0A 20 20 20 20 20 20 20 20 27
73 70 61 6E 69 73 68 27 20 20 20 20 20 20 20 3D 3E 20 27 43 50 31 32 35
32 27 2C 20 2F 2F 27 6C 61 74 69 6E 31 27 2C 0A 20 20 20 20 20 20 20 20
27 73 77 65 64 69 73 68 27 20 20 20 20 20 20 20 3D 3E 20 27 43 50 31 32
35 32 27 2C 20 2F 2F 27 6C 61 74 69 6E 31 27 2C 0A 20 20 20 20 20 20 20
20 27 69 74 61 6C 69 61 6E 27 20 20 20 20 20 20 20 3D 3E 20 27 43 50 31
32 35 32 27 2C 20 2F 2F 27 6C 61 74 69 6E 31 27 2C 0A 20 20 20 20 20 20
20 20 27 6E 6F 72 77 65 67 69 61 6E 2D 6E 79 27 20 20 3D 3E 20 27 43 50
31 32 35 32 27 2C 20 2F 2F 27 6C 61 74 69 6E 31 27 2C 0A 20 20 20 20 20
20 20 20 27 6E 6F 72 77 65 67 69 61 6E 27 20 20 20 20 20 3D 3E 20 27 43
50 31 32 35 32 27 2C 20 2F 2F 27 6C 61 74 69 6E 31 27 2C 0A 20 20 20 20
20 20 20 20 27 70 6F 72 74 75 67 75 65 73 65 27 20 20 20 20 3D 3E 20 27
43 50 31 32 35 32 27 2C 20 2F 2F 27 6C 61 74 69 6E 31 27 2C 0A 20 20 20
20 20 20 20 20 27 64 61 6E 69 73 68 27 20 20 20 20 20 20 20 20 3D 3E 20
27 43 50 31 32 35 32 27 2C 20 2F 2F 27 6C 61 74 69 6E 31 27 2C 0A 20 20
20 20 20 20 20 20 27 64 75 74 63 68 27 20 20 20 20 20 20 20 20 20 3D 3E
20 27 43 50 31 32 35 32 27 2C 20 2F 2F 27 6C 61 74 69 6E 31 27 2C 0A 20
20 20 20 20 20 20 20 27 65 6E 67 6C 69 73 68 27 20 20 20 20 20 20 20 3D
3E 20 27 43 50 31 32 35 32 27 2C 20 2F 2F 27 6C 61 74 69 6E 31 27 2C 0A
20 20 20 20 20 20 20 20 27 66 72 65 6E 63 68 27 20 20 20 20 20 20 20 20
3D 3E 20 27 43 50 31 32 35 32 27 2C 20 2F 2F 27 6C 61 74 69 6E 31 27 2C
0A 20 20 20 20 20 20 20 20 27 67 65 72 6D 61 6E 27 20 20 20 20 20 20 20
20 3D 3E 20 27 43 50 31 32 35 32 27 2C 20 2F 2F 27 6C 61 74 69 6E 31 27
2C 0A 20 20 20 20 29 3B 0A 0A 20 20 20 20 69 66 20 28 20 24 73 65 72 76
65 72 5F 6C 61 6E 67 75 61 67 65 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65
74 63 68 5F 76 61 6C 75 65 28 20 27 53 48 4F 57 20 56 41 52 49 41 42 4C
45 53 20 4C 49 4B 45 20 5C 27 6C 61 6E 67 75 61 67 65 5C 27 3B 27 2C 20
30 2C 20 31 20 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 24 66 6F 75 6E
64 20 3D 20 61 72 72 61 79 28 29 3B 0A 20 20 20 20 20 20 20 20 69 66 20
28 20 70 72 65 67 5F 6D 61 74 63 68 28 20 27 26 28 3F 3A 5C 5C 5C 7C 5C
5C 2F 29 28 5B 5E 5C 5C 5C 5C 5C 2F 5D 2A 29 28 3F 3A 5C 5C 5C 7C 5C 5C
2F 29 24 26 69 27 2C 20 24 73 65 72 76 65 72 5F 6C 61 6E 67 75 61 67 65
2C 20 24 66 6F 75 6E 64 20 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20
20 20 24 73 65 72 76 65 72 5F 6C 61 6E 67 75 61 67 65 20 3D 20 24 66 6F
75 6E 64 5B 31 5D 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 7D 0A
0A 20 20 20 20 69 66 20 28 20 21 20 65 6D 70 74 79 28 20 24 73 65 72 76
65 72 5F 6C 61 6E 67 75 61 67 65 20 29 20 26 26 20 69 73 73 65 74 28 20
24 65 6E 63 6F 64 69 6E 67 73 5B 24 73 65 72 76 65 72 5F 6C 61 6E 67 75
61 67 65 5D 20 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 69 66 20 28 20
66 75 6E 63 74 69 6F 6E 5F 65 78 69 73 74 73 28 20 27 69 63 6F 6E 76 27
20 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 6D 65 73 73
61 67 65 20 3D 20 69 63 6F 6E 76 28 20 24 65 6E 63 6F 64 69 6E 67 73 5B
24 73 65 72 76 65 72 5F 6C 61 6E 67 75 61 67 65 5D 2C 0A 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 24 47 4C 4F 42 41 4C 53 5B 27 63 68 61
72 73 65 74 27 5D 20 2E 20 24 47 4C 4F 42 41 4C 53 5B 27 63 66 67 27 5D
5B 27 49 63 6F 6E 76 45 78 74 72 61 50 61 72 61 6D 73 27 5D 2C 20 24 6D
65 73 73 61 67 65 29 3B 0A 20 20 20 20 20 20 20 20 7D 20 65 6C 73 65 69
66 20 28 20 66 75 6E 63 74 69 6F 6E 5F 65 78 69 73 74 73 28 20 27 72 65
63 6F 64 65 5F 73 74 72 69 6E 67 27 20 29 20 29 20 7B 0A 20 20 20 20 20
20 20 20 20 20 20 20 24 6D 65 73 73 61 67 65 20 3D 20 72 65 63 6F 64 65
5F 73 74 72 69 6E 67 28 20 24 65 6E 63 6F 64 69 6E 67 73 5B 24 73 65 72
76 65 72 5F 6C 61 6E 67 75 61 67 65 5D 20 2E 20 27 2E 2E 27 20 20 2E 20
24 47 4C 4F 42 41 4C 53 5B 27 63 68 61 72 73 65 74 27 5D 2C 0A 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 24 6D 65 73 73 61 67 65 20 29 3B
0A 20 20 20 20 20 20 20 20 7D 20 65 6C 73 65 69 66 20 28 20 66 75 6E 63
74 69 6F 6E 5F 65 78 69 73 74 73 28 20 27 6C 69 62 69 63 6F 6E 76 27 20
29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 6D 65 73 73 61
67 65 20 3D 20 6C 69 62 69 63 6F 6E 76 28 20 24 65 6E 63 6F 64 69 6E 67
73 5B 24 73 65 72 76 65 72 5F 6C 61 6E 67 75 61 67 65 5D 2C 20 24 47 4C
4F 42 41 4C 53 5B 27 63 68 61 72 73 65 74 27 5D 2C 20 24 6D 65 73 73 61
67 65 20 29 3B 0A 20 20 20 20 20 20 20 20 7D 20 65 6C 73 65 69 66 20 28
20 66 75 6E 63 74 69 6F 6E 5F 65 78 69 73 74 73 28 20 27 6D 62 5F 63 6F
6E 76 65 72 74 5F 65 6E 63 6F 64 69 6E 67 27 20 29 20 29 20 7B 0A 20 20
20 20 20 20 20 20 20 20 20 20 2F 2F 20 64 6F 20 6E 6F 74 20 74 72 79 20
75 6E 73 75 70 70 6F 72 74 65 64 20 63 68 61 72 73 65 74 73 0A 20 20 20
20 20 20 20 20 20 20 20 20 69 66 20 28 20 21 20 69 6E 5F 61 72 72 61 79
28 20 24 73 65 72 76 65 72 5F 6C 61 6E 67 75 61 67 65 2C 20 61 72 72 61
79 28 20 27 75 6B 72 61 69 6E 69 61 6E 27 2C 20 27 67 72 65 65 6B 27 2C
20 27 73 65 72 62 69 61 6E 27 20 29 20 29 20 29 20 7B 0A 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 24 6D 65 73 73 61 67 65 20 3D 20 6D 62
5F 63 6F 6E 76 65 72 74 5F 65 6E 63 6F 64 69 6E 67 28 20 24 6D 65 73 73
61 67 65 2C 20 24 47 4C 4F 42 41 4C 53 5B 27 63 68 61 72 73 65 74 27 5D
2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 65
6E 63 6F 64 69 6E 67 73 5B 24 73 65 72 76 65 72 5F 6C 61 6E 67 75 61 67
65 5D 20 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20
20 20 20 20 7D 0A 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20
20 20 20 2F 2F 20 6C 61 6E 67 20 6E 6F 74 20 66 6F 75 6E 64 2C 20 74 72
79 20 61 6C 6C 0A 20 20 20 20 20 20 20 20 2F 2F 20 77 68 61 74 20 54 4F
44 4F 20 3F 0A 20 20 20 20 7D 0A 0A 20 20 20 20 72 65 74 75 72 6E 20 24
6D 65 73 73 61 67 65 3B 0A 7D 0A 0A 2F 2A 2A 0A 20 2A 20 72 65 74 75 72
6E 73 20 61 72 72 61 79 20 77 69 74 68 20 64 61 74 61 62 61 73 65 20 6E
61 6D 65 73 0A 20 2A 0A 20 2A 20 40 72 65 74 75 72 6E 20 20 61 72 72 61
79 20 20 20 24 64 61 74 61 62 61 73 65 73 0A 20 2A 2F 0A 66 75 6E 63 74
69 6F 6E 20 50 4D 41 5F 44 42 49 5F 67 65 74 5F 64 62 6C 69 73 74 28 24
6C 69 6E 6B 20 3D 20 6E 75 6C 6C 29 0A 7B 0A 20 20 20 20 24 64 62 73 5F
61 72 72 61 79 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 72 65
73 75 6C 74 28 27 53 48 4F 57 20 44 41 54 41 42 41 53 45 53 3B 27 2C 20
24 6C 69 6E 6B 29 3B 0A 0A 20 20 20 20 2F 2F 20 42 65 66 6F 72 65 20 4D
79 53 51 4C 20 34 2E 30 2E 32 2C 20 53 48 4F 57 20 44 41 54 41 42 41 53
45 53 20 63 6F 75 6C 64 20 73 65 6E 64 20 74 68 65 0A 20 20 20 20 2F 2F
20 77 68 6F 6C 65 20 6C 69 73 74 2C 20 73 6F 20 63 68 65 63 6B 20 69 66
20 77 65 20 72 65 61 6C 6C 79 20 68 61 76 65 20 61 63 63 65 73 73 3A 0A
20 20 20 20 69 66 20 28 50 4D 41 5F 4D 59 53 51 4C 5F 49 4E 54 5F 56 45
52 53 49 4F 4E 20 3C 20 34 30 30 30 32 20 7C 7C 20 21 65 6D 70 74 79 28
24 47 4C 4F 42 41 4C 53 5B 27 63 66 67 27 5D 5B 27 53 65 72 76 65 72 27
5D 5B 27 68 69 64 65 5F 64 62 27 5D 29 29 20 7B 0A 20 20 20 20 20 20 20
20 66 6F 72 65 61 63 68 20 28 24 64 62 73 5F 61 72 72 61 79 20 61 73 20
24 6B 65 79 20 3D 3E 20 24 64 62 29 20 7B 0A 20 20 20 20 20 20 20 20 20
20 20 20 69 66 20 28 21 40 50 4D 41 5F 44 42 49 5F 73 65 6C 65 63 74 5F
64 62 28 24 64 62 2C 20 24 6C 69 6E 6B 29 20 7C 7C 20 28 21 65 6D 70 74
79 28 24 47 4C 4F 42 41 4C 53 5B 27 63 66 67 27 5D 5B 27 53 65 72 76 65
72 27 5D 5B 27 68 69 64 65 5F 64 62 27 5D 29 20 26 26 20 70 72 65 67 5F
6D 61 74 63 68 28 27 2F 27 20 2E 20 24 47 4C 4F 42 41 4C 53 5B 27 63 66
67 27 5D 5B 27 53 65 72 76 65 72 27 5D 5B 27 68 69 64 65 5F 64 62 27 5D
20 2E 20 27 2F 27 2C 20 24 64 62 29 29 29 20 7B 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 75 6E 73 65 74 28 20 24 64 62 73 5F 61 72 72
61 79 5B 24 6B 65 79 5D 20 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20
7D 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20 20 2F 2F 20 72
65 2D 69 6E 64 65 78 20 76 61 6C 75 65 73 0A 20 20 20 20 20 20 20 20 24
64 62 73 5F 61 72 72 61 79 20 3D 20 61 72 72 61 79 5F 76 61 6C 75 65 73
28 20 24 64 62 73 5F 61 72 72 61 79 20 29 3B 0A 20 20 20 20 7D 0A 0A 20
20 20 20 72 65 74 75 72 6E 20 24 64 62 73 5F 61 72 72 61 79 3B 0A 7D 0A
0A 2F 2A 2A 0A 20 2A 20 72 65 74 75 72 6E 73 20 61 72 72 61 79 20 77 69
74 68 20 74 61 62 6C 65 20 6E 61 6D 65 73 20 66 6F 72 20 67 69 76 65 6E
20 64 62 0A 20 2A 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 73 74 72 69 6E
67 20 20 24 64 61 74 61 62 61 73 65 20 20 20 6E 61 6D 65 20 6F 66 20 64
61 74 61 62 61 73 65 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 6D 69 78 65
64 20 20 20 24 6C 69 6E 6B 20 20 20 20 20 20 20 6D 79 73 71 6C 20 6C 69
6E 6B 20 72 65 73 6F 75 72 63 65 7C 6F 62 6A 65 63 74 0A 20 2A 20 40 72
65 74 75 72 6E 20 20 61 72 72 61 79 20 20 20 74 61 62 6C 65 73 20 6E 61
6D 65 73 0A 20 2A 2F 0A 66 75 6E 63 74 69 6F 6E 20 50 4D 41 5F 44 42 49
5F 67 65 74 5F 74 61 62 6C 65 73 28 24 64 61 74 61 62 61 73 65 2C 20 24
6C 69 6E 6B 20 3D 20 6E 75 6C 6C 29 0A 7B 0A 20 20 20 20 72 65 74 75 72
6E 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 72 65 73 75 6C 74 28 27
53 48 4F 57 20 54 41 42 4C 45 53 20 46 52 4F 4D 20 27 20 2E 20 50 4D 41
5F 62 61 63 6B 71 75 6F 74 65 28 24 64 61 74 61 62 61 73 65 29 20 2E 20
27 3B 27 2C 0A 20 20 20 20 20 20 20 20 6E 75 6C 6C 2C 20 30 2C 20 24 6C
69 6E 6B 2C 20 50 4D 41 5F 44 42 49 5F 51 55 45 52 59 5F 53 54 4F 52 45
29 3B 0A 7D 0A 0A 2F 2A 2A 0A 20 2A 20 72 65 74 75 72 6E 73 20 61 72 72
61 79 20 6F 66 20 61 6C 6C 20 74 61 62 6C 65 73 20 69 6E 20 67 69 76 65
6E 20 64 62 20 6F 72 20 64 62 73 0A 20 2A 20 74 68 69 73 20 66 75 6E 63
74 69 6F 6E 20 65 78 70 65 63 74 73 20 75 6E 71 6F 74 65 64 20 6E 61 6D
65 73 3A 0A 20 2A 20 52 49 47 48 54 3A 20 6D 79 5F 64 61 74 61 62 61 73
65 0A 20 2A 20 57 52 4F 4E 47 3A 20 60 6D 79 5F 64 61 74 61 62 61 73 65
60 0A 20 2A 20 57 52 4F 4E 47 3A 20 6D 79 5C 5F 64 61 74 61 62 61 73 65
0A 20 2A 20 69 66 20 24 74 62 6C 5F 69 73 5F 67 72 6F 75 70 20 69 73 20
74 72 75 65 2C 20 24 74 61 62 6C 65 20 69 73 20 75 73 65 64 20 61 73 20
66 69 6C 74 65 72 20 66 6F 72 20 74 61 62 6C 65 20 6E 61 6D 65 73 0A 20
2A 20 69 66 20 24 74 62 6C 5F 69 73 5F 67 72 6F 75 70 20 69 73 20 27 63
6F 6D 6D 65 6E 74 2C 20 24 74 61 62 6C 65 20 69 73 20 75 73 65 64 20 61
73 20 66 69 6C 74 65 72 20 66 6F 72 20 74 61 62 6C 65 20 63 6F 6D 6D 65
6E 74 73 0A 20 2A 0A 20 2A 20 3C 63 6F 64 65 3E 0A 20 2A 20 50 4D 41 5F
44 42 49 5F 67 65 74 5F 74 61 62 6C 65 73 5F 66 75 6C 6C 28 20 27 6D 79
5F 64 61 74 61 62 61 73 65 27 20 29 3B 0A 20 2A 20 50 4D 41 5F 44 42 49
5F 67 65 74 5F 74 61 62 6C 65 73 5F 66 75 6C 6C 28 20 27 6D 79 5F 64 61
74 61 62 61 73 65 27 2C 20 27 6D 79 5F 74 61 62 6C 65 27 20 29 20 29 3B
0A 20 2A 20 50 4D 41 5F 44 42 49 5F 67 65 74 5F 74 61 62 6C 65 73 5F 66
75 6C 6C 28 20 27 6D 79 5F 64 61 74 61 62 61 73 65 27 2C 20 27 6D 79 5F
74 61 62 6C 65 73 5F 27 2C 20 74 72 75 65 20 29 20 29 3B 0A 20 2A 20 50
4D 41 5F 44 42 49 5F 67 65 74 5F 74 61 62 6C 65 73 5F 66 75 6C 6C 28 20
27 6D 79 5F 64 61 74 61 62 61 73 65 27 2C 20 27 6D 79 5F 74 61 62 6C 65
73 5F 27 2C 20 27 63 6F 6D 6D 65 6E 74 27 20 29 20 29 3B 0A 20 2A 20 3C
2F 63 6F 64 65 3E 0A 20 2A 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50 4D
41 5F 4D 59 53 51 4C 5F 49 4E 54 5F 56 45 52 53 49 4F 4E 0A 20 2A 20 40
75 73 65 73 20 20 20 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 72 65
73 75 6C 74 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50 4D 41 5F 65
73 63 61 70 65 5F 6D 79 73 71 6C 5F 77 69 6C 64 63 61 72 64 73 28 29 0A
20 2A 20 40 75 73 65 73 20 20 20 20 50 4D 41 5F 62 61 63 6B 71 75 6F 74
65 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 69 73 5F 61 72 72 61 79
28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 61 64 64 73 6C 61 73 68 65
73 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 73 74 72 70 6F 73 28 29
0A 20 2A 20 40 75 73 65 73 20 20 20 20 73 74 72 74 6F 75 70 70 65 72 28
29 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 73 74 72 69 6E 67 20 20 20 20
20 20 20 20 20 20 24 64 61 74 61 62 61 73 65 73 20 20 20 20 20 20 64 61
74 61 62 61 73 65 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 73 74 72 69 6E
67 20 20 20 20 20 20 20 20 20 20 24 74 61 62 6C 65 20 20 20 20 20 20 20
20 20 20 74 61 62 6C 65 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 62 6F 6F
6C 65 61 6E 7C 73 74 72 69 6E 67 20 20 24 74 62 6C 5F 69 73 5F 67 72 6F
75 70 20 20 20 24 74 61 62 6C 65 20 69 73 20 61 20 74 61 62 6C 65 20 67
72 6F 75 70 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 72 65 73 6F 75 72 63
65 20 20 20 20 20 20 20 20 24 6C 69 6E 6B 20 20 20 20 20 20 20 20 20 20
20 6D 79 73 71 6C 20 6C 69 6E 6B 0A 20 2A 20 40 72 65 74 75 72 6E 20 20
61 72 72 61 79 20 20 20 20 20 20 20 20 20 20 20 6C 69 73 74 20 6F 66 20
74 62 61 6C 65 73 20 69 6E 20 67 69 76 65 6E 20 64 62 28 73 29 0A 20 2A
2F 0A 66 75 6E 63 74 69 6F 6E 20 50 4D 41 5F 44 42 49 5F 67 65 74 5F 74
61 62 6C 65 73 5F 66 75 6C 6C 28 24 64 61 74 61 62 61 73 65 2C 20 24 74
61 62 6C 65 20 3D 20 66 61 6C 73 65 2C 0A 20 20 20 20 24 74 62 6C 5F 69
73 5F 67 72 6F 75 70 20 3D 20 66 61 6C 73 65 2C 20 24 6C 69 6E 6B 20 3D
20 6E 75 6C 6C 29 0A 7B 0A 20 20 20 20 2F 2F 20 70 72 65 70 61 72 65 20
61 6E 64 20 63 68 65 63 6B 20 70 61 72 61 6D 65 74 65 72 73 0A 20 20 20
20 69 66 20 28 20 21 20 69 73 5F 61 72 72 61 79 28 24 64 61 74 61 62 61
73 65 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 24 64 61 74 61 62 61 73
65 73 20 3D 20 61 72 72 61 79 28 61 64 64 73 6C 61 73 68 65 73 28 24 64
61 74 61 62 61 73 65 29 29 3B 0A 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A
20 20 20 20 20 20 20 20 24 64 61 74 61 62 61 73 65 73 20 3D 20 61 72 72
61 79 5F 6D 61 70 28 27 61 64 64 73 6C 61 73 68 65 73 27 2C 20 24 64 61
74 61 62 61 73 65 29 3B 0A 20 20 20 20 7D 0A 0A 20 20 20 20 24 74 61 62
6C 65 73 20 3D 20 61 72 72 61 79 28 29 3B 0A 0A 20 20 20 20 69 66 20 28
20 50 4D 41 5F 4D 59 53 51 4C 5F 49 4E 54 5F 56 45 52 53 49 4F 4E 20 3E
3D 20 35 30 30 30 32 20 29 20 7B 0A 20 20 20 20 20 20 20 20 2F 2F 20 67
65 74 20 74 61 62 6C 65 20 69 6E 66 6F 72 6D 61 74 69 6F 6E 20 66 72 6F
6D 20 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68 65 6D 61 0A 20 20 20
20 20 20 20 20 69 66 20 28 20 24 74 61 62 6C 65 20 29 20 7B 0A 20 20 20
20 20 20 20 20 20 20 20 20 69 66 20 28 20 74 72 75 65 20 3D 3D 3D 20 24
74 62 6C 5F 69 73 5F 67 72 6F 75 70 20 29 20 7B 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 24 73 71 6C 5F 77 68 65 72 65 5F 74 61 62 6C
65 20 3D 20 27 41 4E 44 20 60 54 41 42 4C 45 5F 4E 41 4D 45 60 20 4C 49
4B 45 20 5C 27 27 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 2E 20 50 4D 41 5F 65 73 63 61 70 65 5F 6D 79 73 71 6C 5F 77 69
6C 64 63 61 72 64 73 28 61 64 64 73 6C 61 73 68 65 73 28 24 74 61 62 6C
65 29 29 20 2E 20 27 25 5C 27 27 3B 0A 20 20 20 20 20 20 20 20 20 20 20
20 7D 20 65 6C 73 65 69 66 20 28 20 27 63 6F 6D 6D 65 6E 74 27 20 3D 3D
3D 20 24 74 62 6C 5F 69 73 5F 67 72 6F 75 70 20 29 20 7B 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 24 73 71 6C 5F 77 68 65 72 65 5F 74
61 62 6C 65 20 3D 20 27 41 4E 44 20 60 54 41 42 4C 45 5F 43 4F 4D 4D 45
4E 54 60 20 4C 49 4B 45 20 5C 27 27 0A 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 2E 20 50 4D 41 5F 65 73 63 61 70 65 5F 6D 79
73 71 6C 5F 77 69 6C 64 63 61 72 64 73 28 61 64 64 73 6C 61 73 68 65 73
28 24 74 61 62 6C 65 29 29 20 2E 20 27 25 5C 27 27 3B 0A 20 20 20 20 20
20 20 20 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 24 73 71 6C 5F 77 68 65 72 65 5F 74 61 62 6C 65
20 3D 20 27 41 4E 44 20 60 54 41 42 4C 45 5F 4E 41 4D 45 60 20 3D 20 5C
27 27 20 2E 20 61 64 64 73 6C 61 73 68 65 73 28 24 74 61 62 6C 65 29 20
2E 20 27 5C 27 27 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 7D 0A 20 20
20 20 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20 20
20 20 20 24 73 71 6C 5F 77 68 65 72 65 5F 74 61 62 6C 65 20 3D 20 27 27
3B 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20 20 20 20 20 20 20 20 2F 2F 20
66 6F 72 20 50 4D 41 20 62 63 3A 0A 20 20 20 20 20 20 20 20 2F 2F 20 60
53 43 48 45 4D 41 5F 46 49 45 4C 44 5F 4E 41 4D 45 60 20 41 53 20 60 53
48 4F 57 5F 54 41 42 4C 45 5F 53 54 41 54 55 53 5F 46 49 45 4C 44 5F 4E
41 4D 45 60 0A 20 20 20 20 20 20 20 20 24 73 71 6C 20 3D 20 27 0A 20 20
20 20 20 20 20 20 20 20 20 20 20 53 45 4C 45 43 54 20 2A 2C 0A 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 60 54 41 42 4C 45 5F
53 43 48 45 4D 41 60 20 20 20 20 20 20 20 41 53 20 60 44 62 60 2C 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 60 54 41 42 4C
45 5F 4E 41 4D 45 60 20 20 20 20 20 20 20 20 20 41 53 20 60 4E 61 6D 65
60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 60
45 4E 47 49 4E 45 60 20 20 20 20 20 20 20 20 20 20 20 20 20 41 53 20 60
45 6E 67 69 6E 65 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 60 45 4E 47 49 4E 45 60 20 20 20 20 20 20 20 20 20 20 20
20 20 41 53 20 60 54 79 70 65 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 60 56 45 52 53 49 4F 4E 60 20 20 20 20 20 20
20 20 20 20 20 20 41 53 20 60 56 65 72 73 69 6F 6E 60 2C 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 60 52 4F 57 5F 46 4F 52
4D 41 54 60 20 20 20 20 20 20 20 20 20 41 53 20 60 52 6F 77 5F 66 6F 72
6D 61 74 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 60 54 41 42 4C 45 5F 52 4F 57 53 60 20 20 20 20 20 20 20 20 20 41
53 20 60 52 6F 77 73 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 60 41 56 47 5F 52 4F 57 5F 4C 45 4E 47 54 48 60 20 20
20 20 20 41 53 20 60 41 76 67 5F 72 6F 77 5F 6C 65 6E 67 74 68 60 2C 0A
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 60 44 41 54
41 5F 4C 45 4E 47 54 48 60 20 20 20 20 20 20 20 20 41 53 20 60 44 61 74
61 5F 6C 65 6E 67 74 68 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 60 4D 41 58 5F 44 41 54 41 5F 4C 45 4E 47 54 48 60
20 20 20 20 41 53 20 60 4D 61 78 5F 64 61 74 61 5F 6C 65 6E 67 74 68 60
2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 60 49
4E 44 45 58 5F 4C 45 4E 47 54 48 60 20 20 20 20 20 20 20 41 53 20 60 49
6E 64 65 78 5F 6C 65 6E 67 74 68 60 2C 0A 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 60 44 41 54 41 5F 46 52 45 45 60 20 20 20
20 20 20 20 20 20 20 41 53 20 60 44 61 74 61 5F 66 72 65 65 60 2C 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 60 41 55 54 4F
5F 49 4E 43 52 45 4D 45 4E 54 60 20 20 20 20 20 41 53 20 60 41 75 74 6F
5F 69 6E 63 72 65 6D 65 6E 74 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 60 43 52 45 41 54 45 5F 54 49 4D 45 60 20 20
20 20 20 20 20 20 41 53 20 60 43 72 65 61 74 65 5F 74 69 6D 65 60 2C 0A
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 60 55 50 44
41 54 45 5F 54 49 4D 45 60 20 20 20 20 20 20 20 20 41 53 20 60 55 70 64
61 74 65 5F 74 69 6D 65 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 60 43 48 45 43 4B 5F 54 49 4D 45 60 20 20 20 20 20
20 20 20 20 41 53 20 60 43 68 65 63 6B 5F 74 69 6D 65 60 2C 0A 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 60 54 41 42 4C 45 5F
43 4F 4C 4C 41 54 49 4F 4E 60 20 20 20 20 41 53 20 60 43 6F 6C 6C 61 74
69 6F 6E 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 60 43 48 45 43 4B 53 55 4D 60 20 20 20 20 20 20 20 20 20 20 20 41
53 20 60 43 68 65 63 6B 73 75 6D 60 2C 0A 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 60 43 52 45 41 54 45 5F 4F 50 54 49 4F 4E
53 60 20 20 20 20 20 41 53 20 60 43 72 65 61 74 65 5F 6F 70 74 69 6F 6E
73 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
60 54 41 42 4C 45 5F 43 4F 4D 4D 45 4E 54 60 20 20 20 20 20 20 41 53 20
60 43 6F 6D 6D 65 6E 74 60 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 46 52 4F 4D 20 60 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68 65 6D
61 60 2E 60 54 41 42 4C 45 53 60 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 57 48 45 52 45 20 60 54 41 42 4C 45 5F 53 43 48 45 4D 41 60 20 49
4E 20 28 5C 27 27 20 2E 20 69 6D 70 6C 6F 64 65 28 22 27 2C 20 27 22 2C
20 24 64 61 74 61 62 61 73 65 73 29 20 2E 20 27 5C 27 29 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 27 20 2E 20 24 73 71 6C 5F 77 68 65
72 65 5F 74 61 62 6C 65 3B 0A 20 20 20 20 20 20 20 20 24 74 61 62 6C 65
73 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 72 65 73 75 6C 74
28 24 73 71 6C 2C 20 61 72 72 61 79 28 27 54 41 42 4C 45 5F 53 43 48 45
4D 41 27 2C 20 27 54 41 42 4C 45 5F 4E 41 4D 45 27 29 2C 0A 20 20 20 20
20 20 20 20 20 20 20 20 6E 75 6C 6C 2C 20 24 6C 69 6E 6B 29 3B 0A 20 20
20 20 20 20 20 20 75 6E 73 65 74 28 20 24 73 71 6C 5F 77 68 65 72 65 5F
74 61 62 6C 65 2C 20 24 73 71 6C 20 29 3B 0A 20 20 20 20 7D 20 65 6C 73
65 20 7B 0A 20 20 20 20 20 20 20 20 66 6F 72 65 61 63 68 20 28 20 24 64
61 74 61 62 61 73 65 73 20 61 73 20 24 65 61 63 68 5F 64 61 74 61 62 61
73 65 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 20
74 72 75 65 20 3D 3D 3D 20 24 74 62 6C 5F 69 73 5F 67 72 6F 75 70 20 29
20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 73 71 6C 20
3D 20 27 53 48 4F 57 20 54 41 42 4C 45 20 53 54 41 54 55 53 20 46 52 4F
4D 20 27 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2E 20 50 4D 41 5F 62 61 63 6B 71 75 6F 74 65 28 24 65 61 63 68 5F 64 61
74 61 62 61 73 65 29 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 2E 27 20 4C 49 4B 45 20 5C 27 27 20 2E 20 50 4D 41 5F 65 73
63 61 70 65 5F 6D 79 73 71 6C 5F 77 69 6C 64 63 61 72 64 73 28 61 64 64
73 6C 61 73 68 65 73 28 24 74 61 62 6C 65 29 29 20 2E 20 27 25 5C 27 27
3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 73 71 6C 20 3D 20 27 53
48 4F 57 20 54 41 42 4C 45 20 53 54 41 54 55 53 20 46 52 4F 4D 20 27 0A
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2E 20 50 4D
41 5F 62 61 63 6B 71 75 6F 74 65 28 24 65 61 63 68 5F 64 61 74 61 62 61
73 65 29 20 2E 20 27 3B 27 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 7D
0A 20 20 20 20 20 20 20 20 20 20 20 20 24 65 61 63 68 5F 74 61 62 6C 65
73 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 72 65 73 75 6C 74
28 24 73 71 6C 2C 20 27 4E 61 6D 65 27 2C 20 6E 75 6C 6C 2C 20 24 6C 69
6E 6B 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 66 6F 72 65 61 63 68
20 28 20 24 65 61 63 68 5F 74 61 62 6C 65 73 20 61 73 20 24 74 61 62 6C
65 5F 6E 61 6D 65 20 3D 3E 20 24 65 61 63 68 5F 74 61 62 6C 65 20 29 20
7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 20 27
63 6F 6D 6D 65 6E 74 27 20 3D 3D 3D 20 24 74 62 6C 5F 69 73 5F 67 72 6F
75 70 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 26 26 20
30 20 3D 3D 3D 20 73 74 72 70 6F 73 28 24 65 61 63 68 5F 74 61 62 6C 65
5B 27 43 6F 6D 6D 65 6E 74 27 5D 2C 20 24 74 61 62 6C 65 29 20 29 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7B 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 72 65 6D 6F 76 65 20 74
61 62 6C 65 20 66 72 6F 6D 20 6C 69 73 74 0A 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 75 6E 73 65 74 28 20 24 65 61 63 68 5F
74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 20 29 3B 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6F 6E 74 69
6E 75 65 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7D 0A 0A
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 20 21 20 69
73 73 65 74 28 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C
65 5F 6E 61 6D 65 5D 5B 27 54 79 70 65 27 5D 20 29 0A 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 26 26 20 69 73 73 65 74 28 20 24 65
61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B
27 45 6E 67 69 6E 65 27 5D 20 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 70 6D 61 20 42 43 2C 20 73
61 6D 65 20 70 61 72 74 73 20 6F 66 20 50 4D 41 20 73 74 69 6C 6C 20 75
73 65 73 20 27 54 79 70 65 27 0A 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62
6C 65 5F 6E 61 6D 65 5D 5B 27 54 79 70 65 27 5D 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3D 26 20 24 65 61 63
68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 45
6E 67 69 6E 65 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 7D 20 65 6C 73 65 69 66 20 28 20 21 20 69 73 73 65 74 28 20 24 65 61
63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27
45 6E 67 69 6E 65 27 5D 20 29 0A 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 26 26 20 69 73 73 65 74 28 20 24 65 61 63 68 5F 74 61 62
6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 54 79 70 65 27 5D
20 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 2F 2F 20 6F 6C 64 20 4D 79 53 51 4C 20 72 65 70 6F 72 74 73 20
54 79 70 65 2C 20 6E 65 77 65 72 20 4D 79 53 51 4C 20 72 65 70 6F 72 74
73 20 45 6E 67 69 6E 65 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65
5F 6E 61 6D 65 5D 5B 27 45 6E 67 69 6E 65 27 5D 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3D 26 20 24 65 61 63
68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 54
79 70 65 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7D
0A 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 4D 79 53
51 4C 20 66 6F 72 77 61 72 64 20 63 6F 6D 70 61 74 69 62 69 6C 69 74 79
0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 73 6F 20 70
6D 61 20 63 6F 75 6C 64 20 75 73 65 20 74 68 69 73 20 61 72 72 61 79 20
61 73 20 69 66 20 65 76 65 72 79 20 73 65 72 76 65 72 20 69 73 20 6F 66
20 76 65 72 73 69 6F 6E 20 3E 35 2E 30 0A 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C
65 5F 6E 61 6D 65 5D 5B 27 54 41 42 4C 45 5F 53 43 48 45 4D 41 27 5D 20
20 20 20 20 20 3D 20 24 65 61 63 68 5F 64 61 74 61 62 61 73 65 3B 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 65 61 63 68 5F 74 61 62
6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 54 41 42 4C 45 5F
4E 41 4D 45 27 5D 20 20 20 20 20 20 20 20 3D 26 20 24 65 61 63 68 5F 74
61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 4E 61 6D 65
27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 65 61 63
68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 45
4E 47 49 4E 45 27 5D 20 20 20 20 20 20 20 20 20 20 20 20 3D 26 20 24 65
61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B
27 45 6E 67 69 6E 65 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E
61 6D 65 5D 5B 27 56 45 52 53 49 4F 4E 27 5D 20 20 20 20 20 20 20 20 20
20 20 3D 26 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65
5F 6E 61 6D 65 5D 5B 27 56 65 72 73 69 6F 6E 27 5D 3B 0A 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B
24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 52 4F 57 5F 46 4F 52 4D 41 54
27 5D 20 20 20 20 20 20 20 20 3D 26 20 24 65 61 63 68 5F 74 61 62 6C 65
73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 52 6F 77 5F 66 6F 72 6D
61 74 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 65
61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B
27 54 41 42 4C 45 5F 52 4F 57 53 27 5D 20 20 20 20 20 20 20 20 3D 26 20
24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65
5D 5B 27 52 6F 77 73 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E
61 6D 65 5D 5B 27 41 56 47 5F 52 4F 57 5F 4C 45 4E 47 54 48 27 5D 20 20
20 20 3D 26 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65
5F 6E 61 6D 65 5D 5B 27 41 76 67 5F 72 6F 77 5F 6C 65 6E 67 74 68 27 5D
3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 65 61 63 68 5F
74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 44 41 54
41 5F 4C 45 4E 47 54 48 27 5D 20 20 20 20 20 20 20 3D 26 20 24 65 61 63
68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 44
61 74 61 5F 6C 65 6E 67 74 68 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C
65 5F 6E 61 6D 65 5D 5B 27 4D 41 58 5F 44 41 54 41 5F 4C 45 4E 47 54 48
27 5D 20 20 20 3D 26 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61
62 6C 65 5F 6E 61 6D 65 5D 5B 27 4D 61 78 5F 64 61 74 61 5F 6C 65 6E 67
74 68 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 65
61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B
27 49 4E 44 45 58 5F 4C 45 4E 47 54 48 27 5D 20 20 20 20 20 20 3D 26 20
24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65
5D 5B 27 49 6E 64 65 78 5F 6C 65 6E 67 74 68 27 5D 3B 0A 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B
24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 44 41 54 41 5F 46 52 45 45 27
5D 20 20 20 20 20 20 20 20 20 3D 26 20 24 65 61 63 68 5F 74 61 62 6C 65
73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 44 61 74 61 5F 66 72 65
65 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 65 61
63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27
41 55 54 4F 5F 49 4E 43 52 45 4D 45 4E 54 27 5D 20 20 20 20 3D 26 20 24
65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D
5B 27 41 75 74 6F 5F 69 6E 63 72 65 6D 65 6E 74 27 5D 3B 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 24 65 61 63 68 5F 74 61 62 6C 65 73
5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 43 52 45 41 54 45 5F 54 49
4D 45 27 5D 20 20 20 20 20 20 20 3D 26 20 24 65 61 63 68 5F 74 61 62 6C
65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 43 72 65 61 74 65 5F
74 69 6D 65 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65
5D 5B 27 55 50 44 41 54 45 5F 54 49 4D 45 27 5D 20 20 20 20 20 20 20 3D
26 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61
6D 65 5D 5B 27 55 70 64 61 74 65 5F 74 69 6D 65 27 5D 3B 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 24 65 61 63 68 5F 74 61 62 6C 65 73
5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 43 48 45 43 4B 5F 54 49 4D
45 27 5D 20 20 20 20 20 20 20 20 3D 26 20 24 65 61 63 68 5F 74 61 62 6C
65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 43 68 65 63 6B 5F 74
69 6D 65 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24
65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D
5B 27 54 41 42 4C 45 5F 43 4F 4C 4C 41 54 49 4F 4E 27 5D 20 20 20 3D 26
20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D
65 5D 5B 27 43 6F 6C 6C 61 74 69 6F 6E 27 5D 3B 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74
61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 43 48 45 43 4B 53 55 4D 27 5D 20 20
20 20 20 20 20 20 20 20 3D 26 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B
24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 43 68 65 63 6B 73 75 6D 27 5D
3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 65 61 63 68 5F
74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 43 52 45
41 54 45 5F 4F 50 54 49 4F 4E 53 27 5D 20 20 20 20 3D 26 20 24 65 61 63
68 5F 74 61 62 6C 65 73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 43
72 65 61 74 65 5F 6F 70 74 69 6F 6E 73 27 5D 3B 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24 74
61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 54 41 42 4C 45 5F 43 4F 4D 4D 45 4E
54 27 5D 20 20 20 20 20 3D 26 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B
24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 43 6F 6D 6D 65 6E 74 27 5D 3B
0A 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 20 73
74 72 74 6F 75 70 70 65 72 28 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B
24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 43 6F 6D 6D 65 6E 74 27 5D 20
29 20 3D 3D 3D 20 27 56 49 45 57 27 20 29 20 7B 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 24 65 61 63 68 5F 74 61 62 6C 65
73 5B 24 74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 54 41 42 4C 45 5F 54 59
50 45 27 5D 20 3D 20 27 56 49 45 57 27 3B 0A 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 54 4F 44 4F 20 64 69 66 66
65 72 65 6E 63 65 20 62 65 74 77 65 65 6E 20 27 54 45 4D 50 4F 52 41 52
59 27 20 61 6E 64 20 27 42 41 53 45 20 54 41 42 4C 45 27 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 62 75 74 20 68
6F 77 20 74 6F 20 64 65 74 65 63 74 3F 0A 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 24 65 61 63 68 5F 74 61 62 6C 65 73 5B 24
74 61 62 6C 65 5F 6E 61 6D 65 5D 5B 27 54 41 42 4C 45 5F 54 59 50 45 27
5D 20 3D 20 27 42 41 53 45 20 54 41 42 4C 45 27 3B 0A 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20 20 20 20 20 20
7D 0A 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 74 61 62 6C 65 73 5B 24
65 61 63 68 5F 64 61 74 61 62 61 73 65 5D 20 3D 20 24 65 61 63 68 5F 74
61 62 6C 65 73 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 7D 0A 0A
20 20 20 20 69 66 20 28 20 24 47 4C 4F 42 41 4C 53 5B 27 63 66 67 27 5D
5B 27 4E 61 74 75 72 61 6C 4F 72 64 65 72 27 5D 20 29 20 7B 0A 20 20 20
20 20 20 20 20 66 6F 72 65 61 63 68 20 28 20 24 74 61 62 6C 65 73 20 61
73 20 24 6B 65 79 20 3D 3E 20 24 76 61 6C 20 29 20 7B 0A 20 20 20 20 20
20 20 20 20 20 20 20 75 6B 73 6F 72 74 28 24 74 61 62 6C 65 73 5B 24 6B
65 79 5D 2C 20 27 73 74 72 6E 61 74 63 61 73 65 63 6D 70 27 29 3B 0A 20
20 20 20 20 20 20 20 7D 0A 20 20 20 20 7D 0A 0A 20 20 20 20 69 66 20 28
21 20 69 73 5F 61 72 72 61 79 28 24 64 61 74 61 62 61 73 65 29 29 20 7B
0A 20 20 20 20 20 20 20 20 69 66 20 28 69 73 73 65 74 28 24 74 61 62 6C
65 73 5B 24 64 61 74 61 62 61 73 65 5D 29 29 20 7B 0A 20 20 20 20 20 20
20 20 20 20 20 20 72 65 74 75 72 6E 20 24 74 61 62 6C 65 73 5B 24 64 61
74 61 62 61 73 65 5D 3B 0A 20 20 20 20 20 20 20 20 7D 20 65 6C 73 65 69
66 20 28 69 73 73 65 74 28 24 74 61 62 6C 65 73 5B 73 74 72 74 6F 6C 6F
77 65 72 28 24 64 61 74 61 62 61 73 65 29 5D 29 29 20 7B 0A 20 20 20 20
20 20 20 20 20 20 20 20 2F 2F 20 6F 6E 20 77 69 6E 64 6F 77 73 20 77 69
74 68 20 6C 6F 77 65 72 5F 63 61 73 65 5F 74 61 62 6C 65 5F 6E 61 6D 65
73 20 3D 20 31 0A 20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 4D 79 53
51 4C 20 72 65 74 75 72 6E 73 0A 20 20 20 20 20 20 20 20 20 20 20 20 2F
2F 20 77 69 74 68 20 53 48 4F 57 20 44 41 54 41 42 41 53 45 53 20 6F 72
20 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68 65 6D 61 2E 53 43 48 45
4D 41 54 41 3A 20 60 54 65 73 74 60 0A 20 20 20 20 20 20 20 20 20 20 20
20 2F 2F 20 62 75 74 20 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68 65
6D 61 2E 54 41 42 4C 45 53 20 67 69 76 65 73 20 60 74 65 73 74 60 0A 20
20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 62 75 67 20 23 31 34 33 36 31
37 31 0A 20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 73 66 2E 6E 65 74
2F 74 72 61 63 6B 65 72 2F 3F 66 75 6E 63 3D 64 65 74 61 69 6C 26 61 69
64 3D 31 34 33 36 31 37 31 26 67 72 6F 75 70 5F 69 64 3D 32 33 30 36 37
26 61 74 69 64 3D 33 37 37 34 30 38 0A 20 20 20 20 20 20 20 20 20 20 20
20 72 65 74 75 72 6E 20 24 74 61 62 6C 65 73 5B 73 74 72 74 6F 6C 6F 77
65 72 28 24 64 61 74 61 62 61 73 65 29 5D 3B 0A 20 20 20 20 20 20 20 20
7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74
75 72 6E 20 24 74 61 62 6C 65 73 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20
20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20 72 65 74 75
72 6E 20 24 74 61 62 6C 65 73 3B 0A 20 20 20 20 7D 0A 7D 0A 0A 2F 2A 2A
0A 20 2A 20 72 65 74 75 72 6E 73 20 61 72 72 61 79 20 77 69 74 68 20 64
61 74 61 62 61 73 65 73 20 63 6F 6E 74 61 69 6E 69 6E 67 20 65 78 74 65
6E 64 65 64 20 69 6E 66 6F 73 20 61 62 6F 75 74 20 74 68 65 6D 0A 20 2A
0A 20 2A 20 40 70 61 72 61 6D 20 20 20 73 74 72 69 6E 67 20 20 20 20 20
20 20 20 20 20 24 64 61 74 61 62 61 73 65 73 20 20 20 20 20 20 64 61 74
61 62 61 73 65 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 62 6F 6F 6C 65 61
6E 20 20 20 20 20 20 20 20 20 24 66 6F 72 63 65 5F 73 74 61 74 73 20 20
20 20 72 65 74 72 69 65 76 65 20 73 74 61 74 73 20 61 6C 73 6F 20 66 6F
72 20 4D 79 53 51 4C 20 3C 20 35 0A 20 2A 20 40 70 61 72 61 6D 20 20 20
72 65 73 6F 75 72 63 65 20 20 20 20 20 20 20 20 24 6C 69 6E 6B 20 20 20
20 20 20 20 20 20 20 20 6D 79 73 71 6C 20 6C 69 6E 6B 0A 20 2A 20 40 72
65 74 75 72 6E 20 20 61 72 72 61 79 20 20 20 20 20 20 20 24 64 61 74 61
62 61 73 65 73 0A 20 2A 2F 0A 66 75 6E 63 74 69 6F 6E 20 50 4D 41 5F 44
42 49 5F 67 65 74 5F 64 61 74 61 62 61 73 65 73 5F 66 75 6C 6C 28 20 24
64 61 74 61 62 61 73 65 20 3D 20 6E 75 6C 6C 2C 20 24 66 6F 72 63 65 5F
73 74 61 74 73 20 3D 20 66 61 6C 73 65 2C 20 24 6C 69 6E 6B 20 3D 20 6E
75 6C 6C 20 29 20 7B 0A 0A 20 20 20 20 2F 2F 20 69 6E 69 74 69 61 6C 69
7A 65 20 74 6F 20 61 76 6F 69 64 20 65 72 72 6F 72 73 20 77 68 65 6E 20
74 68 65 72 65 20 61 72 65 20 6E 6F 20 64 61 74 61 62 61 73 65 73 0A 20
20 20 20 24 64 61 74 61 62 61 73 65 73 20 3D 20 61 72 72 61 79 28 29 3B
0A 0A 20 20 20 20 69 66 20 28 20 50 4D 41 5F 4D 59 53 51 4C 5F 49 4E 54
5F 56 45 52 53 49 4F 4E 20 3E 3D 20 35 30 30 30 32 20 29 20 7B 0A 20 20
20 20 20 20 20 20 2F 2F 20 67 65 74 20 74 61 62 6C 65 20 69 6E 66 6F 72
6D 61 74 69 6F 6E 20 66 72 6F 6D 20 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F
73 63 68 65 6D 61 0A 20 20 20 20 20 20 20 20 69 66 20 28 20 24 64 61 74
61 62 61 73 65 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 73
71 6C 5F 77 68 65 72 65 5F 73 63 68 65 6D 61 20 3D 20 27 57 48 45 52 45
20 60 53 43 48 45 4D 41 5F 4E 41 4D 45 60 20 4C 49 4B 45 20 5C 27 27 0A
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2E 20 61 64 64 73 6C 61
73 68 65 73 28 20 24 64 61 74 61 62 61 73 65 20 29 20 2E 20 27 5C 27 27
3B 0A 20 20 20 20 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20
20 20 20 20 20 20 20 24 73 71 6C 5F 77 68 65 72 65 5F 73 63 68 65 6D 61
20 3D 20 27 27 3B 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20 20 20 20 20 20
20 20 2F 2F 20 66 6F 72 20 50 4D 41 20 62 63 3A 0A 20 20 20 20 20 20 20
20 2F 2F 20 60 53 43 48 45 4D 41 5F 46 49 45 4C 44 5F 4E 41 4D 45 60 20
41 53 20 60 53 48 4F 57 5F 54 41 42 4C 45 5F 53 54 41 54 55 53 5F 46 49
45 4C 44 5F 4E 41 4D 45 60 0A 20 20 20 20 20 20 20 20 24 73 71 6C 20 3D
20 27 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 53 45 4C 45 43 54 20 60
69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68 65 6D 61 60 2E 60 53 43 48
45 4D 41 54 41 60 2E 2A 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 43 4F 55 4E 54 28 60 69 6E 66 6F 72 6D 61 74 69 6F 6E
5F 73 63 68 65 6D 61 60 2E 60 54 41 42 4C 45 53 60 2E 60 54 41 42 4C 45
5F 53 43 48 45 4D 41 60 29 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 41 53 20 60 53 43 48 45 4D 41 5F 54 41 42
4C 45 53 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 53 55 4D 28 60 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68 65 6D
61 60 2E 60 54 41 42 4C 45 53 60 2E 60 54 41 42 4C 45 5F 52 4F 57 53 60
29 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 41 53 20 60 53 43 48 45 4D 41 5F 54 41 42 4C 45 5F 52 4F 57 53 60
2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 53 55
4D 28 60 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68 65 6D 61 60 2E 60
54 41 42 4C 45 53 60 2E 60 44 41 54 41 5F 4C 45 4E 47 54 48 60 29 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 41
53 20 60 53 43 48 45 4D 41 5F 44 41 54 41 5F 4C 45 4E 47 54 48 60 2C 0A
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 53 55 4D 28
60 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68 65 6D 61 60 2E 60 54 41
42 4C 45 53 60 2E 60 4D 41 58 5F 44 41 54 41 5F 4C 45 4E 47 54 48 60 29
0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 41 53 20 60 53 43 48 45 4D 41 5F 4D 41 58 5F 44 41 54 41 5F 4C 45 4E
47 54 48 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 53 55 4D 28 60 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68 65 6D
61 60 2E 60 54 41 42 4C 45 53 60 2E 60 49 4E 44 45 58 5F 4C 45 4E 47 54
48 60 29 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 41 53 20 60 53 43 48 45 4D 41 5F 49 4E 44 45 58 5F 4C 45 4E
47 54 48 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 53 55 4D 28 60 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68 65 6D
61 60 2E 60 54 41 42 4C 45 53 60 2E 60 44 41 54 41 5F 4C 45 4E 47 54 48
60 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2B 20 60 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68 65 6D 61 60 2E 60
54 41 42 4C 45 53 60 2E 60 49 4E 44 45 58 5F 4C 45 4E 47 54 48 60 29 0A
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
41 53 20 60 53 43 48 45 4D 41 5F 4C 45 4E 47 54 48 60 2C 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 53 55 4D 28 60 69 6E 66
6F 72 6D 61 74 69 6F 6E 5F 73 63 68 65 6D 61 60 2E 60 54 41 42 4C 45 53
60 2E 60 44 41 54 41 5F 46 52 45 45 60 29 0A 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 41 53 20 60 53 43 48 45 4D
41 5F 44 41 54 41 5F 46 52 45 45 60 0A 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 46 52 4F 4D 20 60 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63
68 65 6D 61 60 2E 60 53 43 48 45 4D 41 54 41 60 0A 20 20 20 20 20 20 20
20 20 20 4C 45 46 54 20 4A 4F 49 4E 20 60 69 6E 66 6F 72 6D 61 74 69 6F
6E 5F 73 63 68 65 6D 61 60 2E 60 54 41 42 4C 45 53 60 0A 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 4F 4E 20 60 69 6E 66 6F 72 6D 61 74
69 6F 6E 5F 73 63 68 65 6D 61 60 2E 60 54 41 42 4C 45 53 60 2E 60 54 41
42 4C 45 5F 53 43 48 45 4D 41 60 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 3D 20 60 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68
65 6D 61 60 2E 60 53 43 48 45 4D 41 54 41 60 2E 60 53 43 48 45 4D 41 5F
4E 41 4D 45 60 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 27 20 2E 20
24 73 71 6C 5F 77 68 65 72 65 5F 73 63 68 65 6D 61 20 2E 20 27 0A 20 20
20 20 20 20 20 20 20 20 20 47 52 4F 55 50 20 42 59 20 60 69 6E 66 6F 72
6D 61 74 69 6F 6E 5F 73 63 68 65 6D 61 60 2E 60 53 43 48 45 4D 41 54 41
60 2E 60 53 43 48 45 4D 41 5F 4E 41 4D 45 60 27 3B 0A 20 20 20 20 20 20
20 20 24 64 61 74 61 62 61 73 65 73 20 3D 20 50 4D 41 5F 44 42 49 5F 66
65 74 63 68 5F 72 65 73 75 6C 74 28 20 24 73 71 6C 2C 20 27 53 43 48 45
4D 41 5F 4E 41 4D 45 27 2C 20 6E 75 6C 6C 2C 20 24 6C 69 6E 6B 20 29 3B
0A 20 20 20 20 20 20 20 20 75 6E 73 65 74 28 20 24 73 71 6C 5F 77 68 65
72 65 5F 73 63 68 65 6D 61 2C 20 24 73 71 6C 20 29 3B 0A 20 20 20 20 7D
20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20 66 6F 72 65 61 63 68 20
28 20 50 4D 41 5F 44 42 49 5F 67 65 74 5F 64 62 6C 69 73 74 28 20 24 6C
69 6E 6B 20 29 20 61 73 20 24 64 61 74 61 62 61 73 65 5F 6E 61 6D 65 20
29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 4D 79 53 51 4C
20 66 6F 72 77 61 72 64 20 63 6F 6D 70 61 74 69 62 69 6C 69 74 79 0A 20
20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 73 6F 20 70 6D 61 20 63 6F 75
6C 64 20 75 73 65 20 74 68 69 73 20 61 72 72 61 79 20 61 73 20 69 66 20
65 76 65 72 79 20 73 65 72 76 65 72 20 69 73 20 6F 66 20 76 65 72 73 69
6F 6E 20 3E 35 2E 30 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61 74
61 62 61 73 65 73 5B 24 64 61 74 61 62 61 73 65 5F 6E 61 6D 65 5D 5B 27
53 43 48 45 4D 41 5F 4E 41 4D 45 27 5D 20 20 20 20 20 20 3D 20 24 64 61
74 61 62 61 73 65 5F 6E 61 6D 65 3B 0A 0A 20 20 20 20 20 20 20 20 20 20
20 20 69 66 20 28 20 24 66 6F 72 63 65 5F 73 74 61 74 73 20 29 20 7B 0A
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65 71 75 69 72 65 5F
6F 6E 63 65 20 27 6D 79 73 71 6C 5F 63 68 61 72 73 65 74 73 2E 6C 69 62
2E 70 68 70 27 3B 0A 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
24 64 61 74 61 62 61 73 65 73 5B 24 64 61 74 61 62 61 73 65 5F 6E 61 6D
65 5D 5B 27 44 45 46 41 55 4C 54 5F 43 4F 4C 4C 41 54 49 4F 4E 5F 4E 41
4D 45 27 5D 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 3D 20 50 4D 41 5F 67 65 74 44 62 43 6F 6C 6C 61 74 69 6F 6E 28 20 24
64 61 74 61 62 61 73 65 5F 6E 61 6D 65 20 29 3B 0A 0A 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 2F 2F 20 67 65 74 20 61 64 64 69 74 6F 6E
61 6C 20 69 6E 66 6F 20 61 62 6F 75 74 20 74 61 62 6C 65 73 0A 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61 74 61 62 61 73 65 73 5B
24 64 61 74 61 62 61 73 65 5F 6E 61 6D 65 5D 5B 27 53 43 48 45 4D 41 5F
54 41 42 4C 45 53 27 5D 20 20 20 20 20 20 20 20 20 20 3D 20 30 3B 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61 74 61 62 61 73 65
73 5B 24 64 61 74 61 62 61 73 65 5F 6E 61 6D 65 5D 5B 27 53 43 48 45 4D
41 5F 54 41 42 4C 45 5F 52 4F 57 53 27 5D 20 20 20 20 20 20 3D 20 30 3B
0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61 74 61 62 61
73 65 73 5B 24 64 61 74 61 62 61 73 65 5F 6E 61 6D 65 5D 5B 27 53 43 48
45 4D 41 5F 44 41 54 41 5F 4C 45 4E 47 54 48 27 5D 20 20 20 20 20 3D 20
30 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61 74 61
62 61 73 65 73 5B 24 64 61 74 61 62 61 73 65 5F 6E 61 6D 65 5D 5B 27 53
43 48 45 4D 41 5F 4D 41 58 5F 44 41 54 41 5F 4C 45 4E 47 54 48 27 5D 20
3D 20 30 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61
74 61 62 61 73 65 73 5B 24 64 61 74 61 62 61 73 65 5F 6E 61 6D 65 5D 5B
27 53 43 48 45 4D 41 5F 49 4E 44 45 58 5F 4C 45 4E 47 54 48 27 5D 20 20
20 20 3D 20 30 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24
64 61 74 61 62 61 73 65 73 5B 24 64 61 74 61 62 61 73 65 5F 6E 61 6D 65
5D 5B 27 53 43 48 45 4D 41 5F 4C 45 4E 47 54 48 27 5D 20 20 20 20 20 20
20 20 20 20 3D 20 30 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 24 64 61 74 61 62 61 73 65 73 5B 24 64 61 74 61 62 61 73 65 5F 6E 61
6D 65 5D 5B 27 53 43 48 45 4D 41 5F 44 41 54 41 5F 46 52 45 45 27 5D 20
20 20 20 20 20 20 3D 20 30 3B 0A 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 24 72 65 73 20 3D 20 50 4D 41 5F 44 42 49 5F 71 75 65 72 79
28 27 53 48 4F 57 20 54 41 42 4C 45 20 53 54 41 54 55 53 20 46 52 4F 4D
20 27 20 2E 20 50 4D 41 5F 62 61 63 6B 71 75 6F 74 65 28 20 24 64 61 74
61 62 61 73 65 5F 6E 61 6D 65 20 29 20 2E 20 27 3B 27 29 3B 0A 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 77 68 69 6C 65 20 28 20 24 72 6F
77 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 61 73 73 6F 63 28
20 24 72 65 73 20 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 24 64 61 74 61 62 61 73 65 73 5B 24 64 61 74 61
62 61 73 65 5F 6E 61 6D 65 5D 5B 27 53 43 48 45 4D 41 5F 54 41 42 4C 45
53 27 5D 2B 2B 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 24 64 61 74 61 62 61 73 65 73 5B 24 64 61 74 61 62 61 73 65 5F
6E 61 6D 65 5D 5B 27 53 43 48 45 4D 41 5F 54 41 42 4C 45 5F 52 4F 57 53
27 5D 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 2B 3D 20 24 72 6F 77 5B 27 52 6F 77 73 27 5D 3B 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61 74 61 62 61 73
65 73 5B 24 64 61 74 61 62 61 73 65 5F 6E 61 6D 65 5D 5B 27 53 43 48 45
4D 41 5F 44 41 54 41 5F 4C 45 4E 47 54 48 27 5D 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2B 3D 20 24 72 6F 77
5B 27 44 61 74 61 5F 6C 65 6E 67 74 68 27 5D 3B 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61 74 61 62 61 73 65 73 5B
24 64 61 74 61 62 61 73 65 5F 6E 61 6D 65 5D 5B 27 53 43 48 45 4D 41 5F
4D 41 58 5F 44 41 54 41 5F 4C 45 4E 47 54 48 27 5D 0A 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2B 3D 20 24 72 6F
77 5B 27 4D 61 78 5F 64 61 74 61 5F 6C 65 6E 67 74 68 27 5D 3B 0A 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61 74 61 62
61 73 65 73 5B 24 64 61 74 61 62 61 73 65 5F 6E 61 6D 65 5D 5B 27 53 43
48 45 4D 41 5F 49 4E 44 45 58 5F 4C 45 4E 47 54 48 27 5D 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2B 3D 20 24
72 6F 77 5B 27 49 6E 64 65 78 5F 6C 65 6E 67 74 68 27 5D 3B 0A 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61 74 61 62 61
73 65 73 5B 24 64 61 74 61 62 61 73 65 5F 6E 61 6D 65 5D 5B 27 53 43 48
45 4D 41 5F 44 41 54 41 5F 46 52 45 45 27 5D 0A 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2B 3D 20 24 72 6F 77 5B
27 44 61 74 61 5F 66 72 65 65 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 24 64 61 74 61 62 61 73 65 73 5B 24 64 61
74 61 62 61 73 65 5F 6E 61 6D 65 5D 5B 27 53 43 48 45 4D 41 5F 4C 45 4E
47 54 48 27 5D 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 2B 3D 20 24 72 6F 77 5B 27 44 61 74 61 5F 6C 65 6E 67
74 68 27 5D 20 2B 20 24 72 6F 77 5B 27 49 6E 64 65 78 5F 6C 65 6E 67 74
68 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7D 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 50 4D 41 5F 44 42 49 5F 66
72 65 65 5F 72 65 73 75 6C 74 28 20 24 72 65 73 20 29 3B 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 75 6E 73 65 74 28 20 24 72 65 73 20
29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20
20 7D 0A 20 20 20 20 7D 0A 0A 20 20 20 20 69 66 20 28 20 24 47 4C 4F 42
41 4C 53 5B 27 63 66 67 27 5D 5B 27 4E 61 74 75 72 61 6C 4F 72 64 65 72
27 5D 20 29 20 7B 0A 20 20 20 20 20 20 20 20 75 6B 73 6F 72 74 28 20 24
64 61 74 61 62 61 73 65 73 2C 20 27 73 74 72 6E 61 74 63 61 73 65 63 6D
70 27 20 29 3B 0A 20 20 20 20 7D 0A 0A 20 20 20 20 72 65 74 75 72 6E 20
24 64 61 74 61 62 61 73 65 73 3B 0A 7D 0A 0A 2F 2A 2A 0A 20 2A 20 72 65
74 75 72 6E 73 20 64 65 74 61 69 6C 65 64 20 61 72 72 61 79 20 77 69 74
68 20 61 6C 6C 20 63 6F 6C 75 6D 6E 73 20 66 6F 72 20 67 69 76 65 6E 20
74 61 62 6C 65 20 69 6E 20 64 61 74 61 62 61 73 65 2C 0A 20 2A 20 6F 72
20 61 6C 6C 20 74 61 62 6C 65 73 2F 64 61 74 61 62 61 73 65 73 0A 20 2A
0A 20 2A 20 40 70 61 72 61 6D 20 20 20 73 74 72 69 6E 67 20 20 24 64 61
74 61 62 61 73 65 20 20 20 6E 61 6D 65 20 6F 66 20 64 61 74 61 62 61 73
65 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 73 74 72 69 6E 67 20 20 24 74
61 62 6C 65 20 20 20 20 20 20 6E 61 6D 65 20 6F 66 20 74 61 62 6C 65 20
74 6F 20 72 65 74 72 69 65 76 65 20 63 6F 6C 75 6D 6E 73 20 66 72 6F 6D
0A 20 2A 20 40 70 61 72 61 6D 20 20 20 73 74 72 69 6E 67 20 20 24 63 6F
6C 75 6D 6E 20 20 20 20 20 6E 61 6D 65 20 6F 66 20 73 70 65 63 69 66 69
63 20 63 6F 6C 75 6D 6E 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 6D 69 78
65 64 20 20 20 24 6C 69 6E 6B 20 20 20 20 20 20 20 6D 79 73 71 6C 20 6C
69 6E 6B 20 72 65 73 6F 75 72 63 65 0A 20 2A 2F 0A 66 75 6E 63 74 69 6F
6E 20 50 4D 41 5F 44 42 49 5F 67 65 74 5F 63 6F 6C 75 6D 6E 73 5F 66 75
6C 6C 28 24 64 61 74 61 62 61 73 65 20 3D 20 6E 75 6C 6C 2C 20 24 74 61
62 6C 65 20 3D 20 6E 75 6C 6C 2C 0A 20 20 20 20 24 63 6F 6C 75 6D 6E 20
3D 20 6E 75 6C 6C 2C 20 24 6C 69 6E 6B 20 3D 20 6E 75 6C 6C 29 0A 7B 0A
20 20 20 20 24 63 6F 6C 75 6D 6E 73 20 3D 20 61 72 72 61 79 28 29 3B 0A
0A 20 20 20 20 69 66 20 28 20 50 4D 41 5F 4D 59 53 51 4C 5F 49 4E 54 5F
56 45 52 53 49 4F 4E 20 3E 3D 20 35 30 30 30 32 20 29 20 7B 0A 20 20 20
20 20 20 20 20 24 73 71 6C 5F 77 68 65 72 65 73 20 3D 20 61 72 72 61 79
28 29 3B 0A 20 20 20 20 20 20 20 20 24 61 72 72 61 79 5F 6B 65 79 73 20
3D 20 61 72 72 61 79 28 29 3B 0A 0A 20 20 20 20 20 20 20 20 2F 2F 20 67
65 74 20 63 6F 6C 75 6D 6E 73 20 69 6E 66 6F 72 6D 61 74 69 6F 6E 20 66
72 6F 6D 20 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68 65 6D 61 0A 20
20 20 20 20 20 20 20 69 66 20 28 20 6E 75 6C 6C 20 21 3D 3D 20 24 64 61
74 61 62 61 73 65 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24
73 71 6C 5F 77 68 65 72 65 73 5B 5D 20 3D 20 27 60 54 41 42 4C 45 5F 53
43 48 45 4D 41 60 20 3D 20 5C 27 27 20 2E 20 61 64 64 73 6C 61 73 68 65
73 28 24 64 61 74 61 62 61 73 65 29 20 2E 20 27 5C 27 20 27 3B 0A 20 20
20 20 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20 20
20 20 20 24 61 72 72 61 79 5F 6B 65 79 73 5B 5D 20 3D 20 27 54 41 42 4C
45 5F 53 43 48 45 4D 41 27 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20
20 20 20 20 20 69 66 20 28 20 20 6E 75 6C 6C 20 21 3D 3D 20 24 74 61 62
6C 65 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 73 71 6C 5F
77 68 65 72 65 73 5B 5D 20 3D 20 27 60 54 41 42 4C 45 5F 4E 41 4D 45 60
20 3D 20 5C 27 27 20 2E 20 61 64 64 73 6C 61 73 68 65 73 28 24 74 61 62
6C 65 29 20 2E 20 27 5C 27 20 27 3B 0A 20 20 20 20 20 20 20 20 7D 20 65
6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 61 72 72 61 79
5F 6B 65 79 73 5B 5D 20 3D 20 27 54 41 42 4C 45 5F 4E 41 4D 45 27 3B 0A
20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20 20 69 66 20 28 20 20
6E 75 6C 6C 20 21 3D 3D 20 24 63 6F 6C 75 6D 6E 20 29 20 7B 0A 20 20 20
20 20 20 20 20 20 20 20 20 24 73 71 6C 5F 77 68 65 72 65 73 5B 5D 20 3D
20 27 60 43 4F 4C 55 4D 4E 5F 4E 41 4D 45 60 20 3D 20 5C 27 27 20 2E 20
61 64 64 73 6C 61 73 68 65 73 28 24 63 6F 6C 75 6D 6E 29 20 2E 20 27 5C
27 20 27 3B 0A 20 20 20 20 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20
20 20 20 20 20 20 20 20 20 20 24 61 72 72 61 79 5F 6B 65 79 73 5B 5D 20
3D 20 27 43 4F 4C 55 4D 4E 5F 4E 41 4D 45 27 3B 0A 20 20 20 20 20 20 20
20 7D 0A 0A 20 20 20 20 20 20 20 20 2F 2F 20 66 6F 72 20 50 4D 41 20 62
63 3A 0A 20 20 20 20 20 20 20 20 2F 2F 20 60 5B 53 43 48 45 4D 41 5F 46
49 45 4C 44 5F 4E 41 4D 45 5D 60 20 41 53 20 60 5B 53 48 4F 57 5F 46 55
4C 4C 5F 43 4F 4C 55 4D 4E 53 5F 46 49 45 4C 44 5F 4E 41 4D 45 5D 60 0A
20 20 20 20 20 20 20 20 24 73 71 6C 20 3D 20 27 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 53 45 4C 45 43 54 20 2A 2C 0A 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 60 43 4F 4C 55 4D 4E 5F 4E 41 4D 45
60 20 20 20 20 20 20 20 41 53 20 60 46 69 65 6C 64 60 2C 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 60 43 4F 4C 55 4D 4E 5F
54 59 50 45 60 20 20 20 20 20 20 20 41 53 20 60 54 79 70 65 60 2C 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 60 43 4F 4C 4C
41 54 49 4F 4E 5F 4E 41 4D 45 60 20 20 20 20 41 53 20 60 43 6F 6C 6C 61
74 69 6F 6E 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 60 49 53 5F 4E 55 4C 4C 41 42 4C 45 60 20 20 20 20 20 20 20 41
53 20 60 4E 75 6C 6C 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 60 43 4F 4C 55 4D 4E 5F 4B 45 59 60 20 20 20 20 20 20
20 20 41 53 20 60 4B 65 79 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 60 43 4F 4C 55 4D 4E 5F 44 45 46 41 55 4C 54 60
20 20 20 20 41 53 20 60 44 65 66 61 75 6C 74 60 2C 0A 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 60 45 58 54 52 41 60 20 20 20
20 20 20 20 20 20 20 20 20 20 41 53 20 60 45 78 74 72 61 60 2C 0A 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 60 50 52 49 56 49
4C 45 47 45 53 60 20 20 20 20 20 20 20 20 41 53 20 60 50 72 69 76 69 6C
65 67 65 73 60 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 60 43 4F 4C 55 4D 4E 5F 43 4F 4D 4D 45 4E 54 60 20 20 20 20 41
53 20 60 43 6F 6D 6D 65 6E 74 60 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 46 52 4F 4D 20 60 69 6E 66 6F 72 6D 61 74 69 6F 6E 5F 73 63 68
65 6D 61 60 2E 60 43 4F 4C 55 4D 4E 53 60 27 3B 0A 20 20 20 20 20 20 20
20 69 66 20 28 20 63 6F 75 6E 74 28 24 73 71 6C 5F 77 68 65 72 65 73 29
20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 73 71 6C 20 2E 3D
20 22 5C 6E 22 20 2E 20 27 20 57 48 45 52 45 20 27 20 2E 20 69 6D 70 6C
6F 64 65 28 27 20 41 4E 44 20 27 2C 20 24 73 71 6C 5F 77 68 65 72 65 73
29 3B 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20 20 20 20 20 20 20 20 24 63
6F 6C 75 6D 6E 73 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 72
65 73 75 6C 74 28 24 73 71 6C 2C 20 24 61 72 72 61 79 5F 6B 65 79 73 2C
20 6E 75 6C 6C 2C 20 24 6C 69 6E 6B 29 3B 0A 20 20 20 20 20 20 20 20 75
6E 73 65 74 28 20 24 73 71 6C 5F 77 68 65 72 65 73 2C 20 24 73 71 6C 20
29 3B 0A 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20
69 66 20 28 20 6E 75 6C 6C 20 3D 3D 3D 20 24 64 61 74 61 62 61 73 65 20
29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61 74 61 62 61 73
65 73 20 3D 20 50 4D 41 5F 44 42 49 5F 67 65 74 5F 64 62 6C 69 73 74 28
29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 66 6F 72 65 61 63 68 20 28
20 24 64 61 74 61 62 61 73 65 73 20 61 73 20 24 64 61 74 61 62 61 73 65
20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 63 6F
6C 75 6D 6E 73 5B 24 64 61 74 61 62 61 73 65 5D 20 3D 20 50 4D 41 5F 44
42 49 5F 67 65 74 5F 63 6F 6C 75 6D 6E 73 5F 66 75 6C 6C 28 24 64 61 74
61 62 61 73 65 2C 20 6E 75 6C 6C 2C 0A 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 6E 75 6C 6C 2C 20 24 6C 69 6E 6B 29 3B 0A 20
20 20 20 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20 20 20 20 20
20 72 65 74 75 72 6E 20 24 63 6F 6C 75 6D 6E 73 3B 0A 20 20 20 20 20 20
20 20 7D 20 65 6C 73 65 69 66 20 28 20 6E 75 6C 6C 20 3D 3D 3D 20 24 74
61 62 6C 65 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 74 61
62 6C 65 73 20 3D 20 50 4D 41 5F 44 42 49 5F 67 65 74 5F 74 61 62 6C 65
73 28 24 64 61 74 61 62 61 73 65 29 3B 0A 20 20 20 20 20 20 20 20 20 20
20 20 66 6F 72 65 61 63 68 20 28 20 24 74 61 62 6C 65 73 20 61 73 20 24
74 61 62 6C 65 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 24 63 6F 6C 75 6D 6E 73 5B 24 74 61 62 6C 65 5D 20 3D 20 50 4D 41
5F 44 42 49 5F 67 65 74 5F 63 6F 6C 75 6D 6E 73 5F 66 75 6C 6C 28 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61 74 61
62 61 73 65 2C 20 24 74 61 62 6C 65 2C 20 6E 75 6C 6C 2C 20 24 6C 69 6E
6B 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20
20 20 20 20 20 20 72 65 74 75 72 6E 20 24 63 6F 6C 75 6D 6E 73 3B 0A 20
20 20 20 20 20 20 20 7D 0A 0A 20 20 20 20 20 20 20 20 24 73 71 6C 20 3D
20 27 53 48 4F 57 20 46 55 4C 4C 20 43 4F 4C 55 4D 4E 53 20 46 52 4F 4D
20 27 0A 20 20 20 20 20 20 20 20 20 20 20 20 2E 20 50 4D 41 5F 62 61 63
6B 71 75 6F 74 65 28 24 64 61 74 61 62 61 73 65 29 20 2E 20 27 2E 27 20
2E 20 50 4D 41 5F 62 61 63 6B 71 75 6F 74 65 28 24 74 61 62 6C 65 29 3B
0A 20 20 20 20 20 20 20 20 69 66 20 28 20 6E 75 6C 6C 20 21 3D 3D 20 24
63 6F 6C 75 6D 6E 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24
73 71 6C 20 2E 3D 20 22 20 4C 49 4B 45 20 27 22 20 2E 20 24 63 6F 6C 75
6D 6E 20 2E 20 22 27 22 3B 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20 20 20
20 20 20 20 20 24 63 6F 6C 75 6D 6E 73 20 3D 20 50 4D 41 5F 44 42 49 5F
66 65 74 63 68 5F 72 65 73 75 6C 74 28 20 24 73 71 6C 2C 20 27 46 69 65
6C 64 27 2C 20 6E 75 6C 6C 2C 20 24 6C 69 6E 6B 20 29 3B 0A 0A 20 20 20
20 20 20 20 20 24 6F 72 64 69 6E 61 6C 5F 70 6F 73 69 74 69 6F 6E 20 3D
20 31 3B 0A 20 20 20 20 20 20 20 20 66 6F 72 65 61 63 68 20 28 20 24 63
6F 6C 75 6D 6E 73 20 61 73 20 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 20 3D
3E 20 24 65 61 63 68 5F 63 6F 6C 75 6D 6E 20 29 20 7B 0A 0A 20 20 20 20
20 20 20 20 20 20 20 20 2F 2F 20 4D 79 53 51 4C 20 66 6F 72 77 61 72 64
20 63 6F 6D 70 61 74 69 62 69 6C 69 74 79 0A 20 20 20 20 20 20 20 20 20
20 20 20 2F 2F 20 73 6F 20 70 6D 61 20 63 6F 75 6C 64 20 75 73 65 20 74
68 69 73 20 61 72 72 61 79 20 61 73 20 69 66 20 65 76 65 72 79 20 73 65
72 76 65 72 20 69 73 20 6F 66 20 76 65 72 73 69 6F 6E 20 3E 35 2E 30 0A
20 20 20 20 20 20 20 20 20 20 20 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F
6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 43 4F 4C 55 4D 4E 5F 4E 41 4D 45 27
5D 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3D 26 20 24 63 6F
6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 46 69 65
6C 64 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 63 6F 6C 75 6D
6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 43 4F 4C 55 4D 4E
5F 54 59 50 45 27 5D 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
3D 26 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65
5D 5B 27 54 79 70 65 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24
63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 43
4F 4C 4C 41 54 49 4F 4E 5F 4E 41 4D 45 27 5D 20 20 20 20 20 20 20 20 20
20 20 20 20 20 3D 26 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E
5F 6E 61 6D 65 5D 5B 27 43 6F 6C 6C 61 74 69 6F 6E 27 5D 3B 0A 20 20 20
20 20 20 20 20 20 20 20 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D
6E 5F 6E 61 6D 65 5D 5B 27 49 53 5F 4E 55 4C 4C 41 42 4C 45 27 5D 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3D 26 20 24 63 6F 6C 75 6D
6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 4E 75 6C 6C 27 5D
3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 63 6F 6C 75 6D 6E 73 5B 24
63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 43 4F 4C 55 4D 4E 5F 4B 45 59
27 5D 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3D 26 20 24
63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 4B
65 79 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 63 6F 6C 75 6D
6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 43 4F 4C 55 4D 4E
5F 44 45 46 41 55 4C 54 27 5D 20 20 20 20 20 20 20 20 20 20 20 20 20 20
3D 26 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65
5D 5B 27 44 65 66 61 75 6C 74 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20
20 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D
5B 27 45 58 54 52 41 27 5D 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 3D 26 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C
75 6D 6E 5F 6E 61 6D 65 5D 5B 27 45 78 74 72 61 27 5D 3B 0A 20 20 20 20
20 20 20 20 20 20 20 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E
5F 6E 61 6D 65 5D 5B 27 50 52 49 56 49 4C 45 47 45 53 27 5D 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 3D 26 20 24 63 6F 6C 75 6D 6E
73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 50 72 69 76 69 6C 65
67 65 73 27 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 63 6F 6C 75
6D 6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 43 4F 4C 55 4D
4E 5F 43 4F 4D 4D 45 4E 54 27 5D 20 20 20 20 20 20 20 20 20 20 20 20 20
20 3D 26 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D
65 5D 5B 27 43 6F 6D 6D 65 6E 74 27 5D 3B 0A 0A 20 20 20 20 20 20 20 20
20 20 20 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D
65 5D 5B 27 54 41 42 4C 45 5F 43 41 54 41 4C 4F 47 27 5D 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 3D 20 6E 75 6C 6C 3B 0A 20 20 20 20 20 20
20 20 20 20 20 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E
61 6D 65 5D 5B 27 54 41 42 4C 45 5F 53 43 48 45 4D 41 27 5D 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 3D 20 24 64 61 74 61 62 61 73 65 3B
0A 20 20 20 20 20 20 20 20 20 20 20 20 24 63 6F 6C 75 6D 6E 73 5B 24 63
6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 54 41 42 4C 45 5F 4E 41 4D 45 27
5D 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3D 20 24 74 61
62 6C 65 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 63 6F 6C 75 6D 6E
73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 4F 52 44 49 4E 41 4C
5F 50 4F 53 49 54 49 4F 4E 27 5D 20 20 20 20 20 20 20 20 20 20 20 20 3D
20 24 6F 72 64 69 6E 61 6C 5F 70 6F 73 69 74 69 6F 6E 3B 0A 20 20 20 20
20 20 20 20 20 20 20 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E
5F 6E 61 6D 65 5D 5B 27 44 41 54 41 5F 54 59 50 45 27 5D 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 3D 0A 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 73 75 62 73 74 72 28 24 63 6F 6C 75 6D 6E 73 5B
24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 43 4F 4C 55 4D 4E 5F 54 59
50 45 27 5D 2C 20 30 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 73 74 72 70 6F 73 28 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F
6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 43 4F 4C 55 4D 4E 5F 54 59 50 45 27
5D 2C 20 27 28 27 29 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 2F 2F
20 40 54 4F 44 4F 20 67 75 65 73 73 20 43 48 41 52 41 43 54 45 52 5F 4D
41 58 49 4D 55 4D 5F 4C 45 4E 47 54 48 20 66 72 6F 6D 20 43 4F 4C 55 4D
4E 5F 54 59 50 45 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 63 6F 6C 75
6D 6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 43 48 41 52 41
43 54 45 52 5F 4D 41 58 49 4D 55 4D 5F 4C 45 4E 47 54 48 27 5D 20 20 20
20 3D 20 6E 75 6C 6C 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20
40 54 4F 44 4F 20 67 75 65 73 73 20 43 48 41 52 41 43 54 45 52 5F 4F 43
54 45 54 5F 4C 45 4E 47 54 48 20 66 72 6F 6D 20 43 48 41 52 41 43 54 45
52 5F 4D 41 58 49 4D 55 4D 5F 4C 45 4E 47 54 48 0A 20 20 20 20 20 20 20
20 20 20 20 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61
6D 65 5D 5B 27 43 48 41 52 41 43 54 45 52 5F 4F 43 54 45 54 5F 4C 45 4E
47 54 48 27 5D 20 20 20 20 20 20 3D 20 6E 75 6C 6C 3B 0A 20 20 20 20 20
20 20 20 20 20 20 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D 6E 5F
6E 61 6D 65 5D 5B 27 4E 55 4D 45 52 49 43 5F 50 52 45 43 49 53 49 4F 4E
27 5D 20 20 20 20 20 20 20 20 20 20 20 3D 20 6E 75 6C 6C 3B 0A 20 20 20
20 20 20 20 20 20 20 20 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C 75 6D
6E 5F 6E 61 6D 65 5D 5B 27 4E 55 4D 45 52 49 43 5F 53 43 41 4C 45 27 5D
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3D 20 6E 75 6C 6C 3B 0A 20
20 20 20 20 20 20 20 20 20 20 20 24 63 6F 6C 75 6D 6E 73 5B 24 63 6F 6C
75 6D 6E 5F 6E 61 6D 65 5D 5B 27 43 48 41 52 41 43 54 45 52 5F 53 45 54
5F 4E 41 4D 45 27 5D 20 20 20 20 20 20 20 20 20 20 3D 0A 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 73 75 62 73 74 72 28 24 63 6F 6C 75 6D
6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 43 4F 4C 4C 41 54
49 4F 4E 5F 4E 41 4D 45 27 5D 2C 20 30 2C 0A 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 73 74 72 70 6F 73 28 24 63 6F 6C 75 6D
6E 73 5B 24 63 6F 6C 75 6D 6E 5F 6E 61 6D 65 5D 5B 27 43 4F 4C 4C 41 54
49 4F 4E 5F 4E 41 4D 45 27 5D 2C 20 27 5F 27 29 29 3B 0A 0A 20 20 20 20
20 20 20 20 20 20 20 20 24 6F 72 64 69 6E 61 6C 5F 70 6F 73 69 74 69 6F
6E 2B 2B 3B 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20 20 20 20 20 20 20 20
69 66 20 28 20 6E 75 6C 6C 20 21 3D 3D 20 24 63 6F 6C 75 6D 6E 20 29 20
7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 72 65 73 65 74 28 24 63 6F 6C
75 6D 6E 73 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 63 6F 6C 75
6D 6E 73 20 3D 20 63 75 72 72 65 6E 74 28 24 63 6F 6C 75 6D 6E 73 29 3B
0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 7D 0A 0A 20 20 20 20 72 65
74 75 72 6E 20 24 63 6F 6C 75 6D 6E 73 3B 0A 7D 0A 0A 2F 2A 2A 0A 20 2A
20 40 54 4F 44 4F 20 73 68 6F 75 6C 64 20 6F 6E 6C 79 20 72 65 74 75 72
6E 20 63 6F 6C 75 6D 6E 73 20 6E 61 6D 65 73 2C 20 66 6F 72 20 6D 6F 72
65 20 69 6E 66 6F 20 75 73 65 20 50 4D 41 5F 44 42 49 5F 67 65 74 5F 63
6F 6C 75 6D 6E 73 5F 66 75 6C 6C 28 29 0A 20 2A 0A 20 2A 20 40 70 61 72
61 6D 20 20 20 73 74 72 69 6E 67 20 20 24 64 61 74 61 62 61 73 65 20 20
20 6E 61 6D 65 20 6F 66 20 64 61 74 61 62 61 73 65 0A 20 2A 20 40 70 61
72 61 6D 20 20 20 73 74 72 69 6E 67 20 20 24 74 61 62 6C 65 20 20 20 20
20 20 6E 61 6D 65 20 6F 66 20 74 61 62 6C 65 20 74 6F 20 72 65 74 72 69
65 76 65 20 63 6F 6C 75 6D 6E 73 20 66 72 6F 6D 0A 20 2A 20 40 70 61 72
61 6D 20 20 20 6D 69 78 65 64 20 20 20 24 6C 69 6E 6B 20 20 20 20 20 20
20 6D 79 73 71 6C 20 6C 69 6E 6B 20 72 65 73 6F 75 72 63 65 0A 20 2A 2F
0A 66 75 6E 63 74 69 6F 6E 20 50 4D 41 5F 44 42 49 5F 67 65 74 5F 66 69
65 6C 64 73 28 24 64 61 74 61 62 61 73 65 2C 20 24 74 61 62 6C 65 2C 20
24 6C 69 6E 6B 20 3D 20 6E 75 6C 6C 29 0A 7B 0A 20 20 20 20 2F 2F 20 68
65 72 65 20 77 65 20 75 73 65 20 61 20 74 72 79 5F 71 75 65 72 79 20 62
65 63 61 75 73 65 20 77 68 65 6E 20 63 6F 6D 69 6E 67 20 66 72 6F 6D 0A
20 20 20 20 2F 2F 20 74 62 6C 5F 63 72 65 61 74 65 20 2B 20 74 62 6C 5F
70 72 6F 70 65 72 74 69 65 73 2E 69 6E 63 2E 70 68 70 2C 20 74 68 65 20
74 61 62 6C 65 20 64 6F 65 73 20 6E 6F 74 20 65 78 69 73 74 0A 20 20 20
20 24 66 69 65 6C 64 73 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68
5F 72 65 73 75 6C 74 28 0A 20 20 20 20 20 20 20 20 27 53 48 4F 57 20 46
55 4C 4C 20 43 4F 4C 55 4D 4E 53 0A 20 20 20 20 20 20 20 20 46 52 4F 4D
20 27 20 2E 20 50 4D 41 5F 62 61 63 6B 71 75 6F 74 65 28 24 64 61 74 61
62 61 73 65 29 20 2E 20 27 2E 27 20 2E 20 50 4D 41 5F 62 61 63 6B 71 75
6F 74 65 28 24 74 61 62 6C 65 29 2C 0A 20 20 20 20 20 20 20 20 6E 75 6C
6C 2C 20 6E 75 6C 6C 2C 20 24 6C 69 6E 6B 29 3B 0A 20 20 20 20 69 66 20
28 20 21 20 69 73 5F 61 72 72 61 79 28 24 66 69 65 6C 64 73 29 20 7C 7C
20 63 6F 75 6E 74 28 24 66 69 65 6C 64 73 29 20 3C 20 31 20 29 20 7B 0A
20 20 20 20 20 20 20 20 72 65 74 75 72 6E 20 66 61 6C 73 65 3B 0A 20 20
20 20 7D 0A 20 20 20 20 72 65 74 75 72 6E 20 24 66 69 65 6C 64 73 3B 0A
7D 0A 0A 2F 2A 2A 0A 20 2A 20 72 65 74 75 72 6E 73 20 76 61 6C 75 65 20
6F 66 20 67 69 76 65 6E 20 6D 79 73 71 6C 20 73 65 72 76 65 72 20 76 61
72 69 61 62 6C 65 0A 20 2A 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 73 74
72 69 6E 67 20 20 24 76 61 72 20 20 20 20 6D 79 73 71 6C 20 73 65 72 76
65 72 20 76 61 72 69 61 62 6C 65 20 6E 61 6D 65 0A 20 2A 20 40 70 61 72
61 6D 20 20 20 69 6E 74 20 20 20 20 20 24 74 79 70 65 20 20 20 50 4D 41
5F 44 42 49 5F 47 45 54 56 41 52 5F 53 45 53 53 49 4F 4E 7C 50 4D 41 5F
44 42 49 5F 47 45 54 56 41 52 5F 47 4C 4F 42 41 4C 0A 20 2A 20 40 70 61
72 61 6D 20 20 20 6D 69 78 65 64 20 20 20 24 6C 69 6E 6B 20 20 20 6D 79
73 71 6C 20 6C 69 6E 6B 20 72 65 73 6F 75 72 63 65 7C 6F 62 6A 65 63 74
0A 20 2A 20 40 72 65 74 75 72 6E 20 20 6D 69 78 65 64 20 20 20 76 61 6C
75 65 20 66 6F 72 20 6D 79 73 71 6C 20 73 65 72 76 65 72 20 76 61 72 69
61 62 6C 65 0A 20 2A 2F 0A 66 75 6E 63 74 69 6F 6E 20 50 4D 41 5F 44 42
49 5F 67 65 74 5F 76 61 72 69 61 62 6C 65 28 24 76 61 72 2C 20 24 74 79
70 65 20 3D 20 50 4D 41 5F 44 42 49 5F 47 45 54 56 41 52 5F 53 45 53 53
49 4F 4E 2C 20 24 6C 69 6E 6B 20 3D 20 6E 75 6C 6C 29 0A 7B 0A 20 20 20
20 69 66 20 28 24 6C 69 6E 6B 20 3D 3D 3D 20 6E 75 6C 6C 29 20 7B 0A 20
20 20 20 20 20 20 20 69 66 20 28 69 73 73 65 74 28 24 47 4C 4F 42 41 4C
53 5B 27 75 73 65 72 6C 69 6E 6B 27 5D 29 29 20 7B 0A 20 20 20 20 20 20
20 20 20 20 20 20 24 6C 69 6E 6B 20 3D 20 24 47 4C 4F 42 41 4C 53 5B 27
75 73 65 72 6C 69 6E 6B 27 5D 3B 0A 20 20 20 20 20 20 20 20 7D 20 65 6C
73 65 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6E 20
66 61 6C 73 65 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 7D 0A 20
20 20 20 69 66 20 28 50 4D 41 5F 4D 59 53 51 4C 5F 49 4E 54 5F 56 45 52
53 49 4F 4E 20 3C 20 34 30 30 30 32 29 20 7B 0A 20 20 20 20 20 20 20 20
24 74 79 70 65 20 3D 20 30 3B 0A 20 20 20 20 7D 0A 20 20 20 20 73 77 69
74 63 68 20 28 24 74 79 70 65 29 20 7B 0A 20 20 20 20 20 20 20 20 63 61
73 65 20 50 4D 41 5F 44 42 49 5F 47 45 54 56 41 52 5F 53 45 53 53 49 4F
4E 3A 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 6D 6F 64 69 66 69 65 72
20 3D 20 27 20 53 45 53 53 49 4F 4E 27 3B 0A 20 20 20 20 20 20 20 20 20
20 20 20 62 72 65 61 6B 3B 0A 20 20 20 20 20 20 20 20 63 61 73 65 20 50
4D 41 5F 44 42 49 5F 47 45 54 56 41 52 5F 47 4C 4F 42 41 4C 3A 0A 20 20
20 20 20 20 20 20 20 20 20 20 24 6D 6F 64 69 66 69 65 72 20 3D 20 27 20
47 4C 4F 42 41 4C 27 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 62 72 65
61 6B 3B 0A 20 20 20 20 20 20 20 20 64 65 66 61 75 6C 74 3A 0A 20 20 20
20 20 20 20 20 20 20 20 20 24 6D 6F 64 69 66 69 65 72 20 3D 20 27 27 3B
0A 20 20 20 20 7D 0A 20 20 20 20 72 65 74 75 72 6E 20 50 4D 41 5F 44 42
49 5F 66 65 74 63 68 5F 76 61 6C 75 65 28 0A 20 20 20 20 20 20 20 20 27
53 48 4F 57 27 20 2E 20 24 6D 6F 64 69 66 69 65 72 20 2E 20 27 20 56 41
52 49 41 42 4C 45 53 20 4C 49 4B 45 20 5C 27 27 20 2E 20 24 76 61 72 20
2E 20 27 5C 27 3B 27 2C 20 30 2C 20 31 2C 20 24 6C 69 6E 6B 29 3B 0A 7D
0A 0A 2F 2A 2A 0A 20 2A 20 40 75 73 65 73 20 20 20 20 2E 2F 6C 69 62 72
61 72 69 65 73 2F 63 68 61 72 73 65 74 5F 63 6F 6E 76 65 72 73 69 6F 6E
2E 6C 69 62 2E 70 68 70 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50 4D 41
5F 44 42 49 5F 51 55 45 52 59 5F 53 54 4F 52 45 0A 20 2A 20 40 75 73 65
73 20 20 20 20 50 4D 41 5F 52 45 4D 4F 56 45 44 5F 4E 4F 4E 5F 55 54 46
5F 38 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50 4D 41 5F 4D 59 53 51 4C
5F 49 4E 54 5F 56 45 52 53 49 4F 4E 0A 20 2A 20 40 75 73 65 73 20 20 20
20 50 4D 41 5F 4D 59 53 51 4C 5F 53 54 52 5F 56 45 52 53 49 4F 4E 0A 20
2A 20 40 75 73 65 73 20 20 20 20 50 4D 41 5F 44 42 49 5F 47 45 54 56 41
52 5F 53 45 53 53 49 4F 4E 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50 4D
41 5F 44 42 49 5F 66 65 74 63 68 5F 76 61 6C 75 65 28 29 0A 20 2A 20 40
75 73 65 73 20 20 20 20 50 4D 41 5F 44 42 49 5F 71 75 65 72 79 28 29 0A
20 2A 20 40 75 73 65 73 20 20 20 20 50 4D 41 5F 44 42 49 5F 67 65 74 5F
76 61 72 69 61 62 6C 65 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 24
47 4C 4F 42 41 4C 53 5B 27 63 6F 6C 6C 61 74 69 6F 6E 5F 63 6F 6E 6E 65
63 74 69 6F 6E 27 5D 0A 20 2A 20 40 75 73 65 73 20 20 20 20 24 47 4C 4F
42 41 4C 53 5B 27 63 68 61 72 73 65 74 5F 63 6F 6E 6E 65 63 74 69 6F 6E
27 5D 0A 20 2A 20 40 75 73 65 73 20 20 20 20 24 47 4C 4F 42 41 4C 53 5B
27 61 76 61 69 6C 61 62 6C 65 5F 6C 61 6E 67 75 61 67 65 73 27 5D 0A 20
2A 20 40 75 73 65 73 20 20 20 20 24 47 4C 4F 42 41 4C 53 5B 27 6D 79 73
71 6C 5F 63 68 61 72 73 65 74 5F 6D 61 70 27 5D 0A 20 2A 20 40 75 73 65
73 20 20 20 20 24 47 4C 4F 42 41 4C 53 5B 27 63 68 61 72 73 65 74 27 5D
0A 20 2A 20 40 75 73 65 73 20 20 20 20 24 47 4C 4F 42 41 4C 53 5B 27 6C
61 6E 67 27 5D 0A 20 2A 20 40 75 73 65 73 20 20 20 20 24 47 4C 4F 42 41
4C 53 5B 27 63 66 67 27 5D 5B 27 4C 61 6E 67 27 5D 0A 20 2A 20 40 75 73
65 73 20 20 20 20 24 47 4C 4F 42 41 4C 53 5B 27 63 66 67 27 5D 5B 27 43
6F 6C 75 6D 6E 54 79 70 65 73 27 5D 0A 20 2A 20 40 75 73 65 73 20 20 20
20 64 65 66 69 6E 65 64 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 65
78 70 6C 6F 64 65 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 73 70 72
69 6E 74 66 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 69 6E 74 76 61
6C 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 64 65 66 69 6E 65 28 29
0A 20 2A 20 40 75 73 65 73 20 20 20 20 64 65 66 69 6E 65 64 28 29 0A 20
2A 20 40 75 73 65 73 20 20 20 20 73 75 62 73 74 72 28 29 0A 20 2A 20 40
75 73 65 73 20 20 20 20 63 6F 75 6E 74 28 29 0A 20 2A 20 40 70 61 72 61
6D 20 20 20 6D 69 78 65 64 20 20 20 24 6C 69 6E 6B 20 20 20 6D 79 73 71
6C 20 6C 69 6E 6B 20 72 65 73 6F 75 72 63 65 7C 6F 62 6A 65 63 74 0A 20
2A 20 40 70 61 72 61 6D 20 20 20 62 6F 6F 6C 65 61 6E 20 24 69 73 5F 63
6F 6E 74 72 6F 6C 75 73 65 72 0A 20 2A 2F 0A 66 75 6E 63 74 69 6F 6E 20
50 4D 41 5F 44 42 49 5F 70 6F 73 74 43 6F 6E 6E 65 63 74 28 24 6C 69 6E
6B 2C 20 24 69 73 5F 63 6F 6E 74 72 6F 6C 75 73 65 72 20 3D 20 66 61 6C
73 65 29 0A 7B 0A 20 20 20 20 69 66 20 28 21 64 65 66 69 6E 65 64 28 27
50 4D 41 5F 4D 59 53 51 4C 5F 49 4E 54 5F 56 45 52 53 49 4F 4E 27 29 29
20 7B 0A 20 20 20 20 20 20 20 20 24 6D 79 73 71 6C 5F 76 65 72 73 69 6F
6E 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 76 61 6C 75 65 28
0A 20 20 20 20 20 20 20 20 20 20 20 20 27 53 45 4C 45 43 54 20 56 45 52
53 49 4F 4E 28 29 27 2C 20 30 2C 20 30 2C 20 24 6C 69 6E 6B 2C 20 50 4D
41 5F 44 42 49 5F 51 55 45 52 59 5F 53 54 4F 52 45 29 3B 0A 20 20 20 20
20 20 20 20 69 66 20 28 20 24 6D 79 73 71 6C 5F 76 65 72 73 69 6F 6E 20
29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 6D 61 74 63 68 20 3D
20 65 78 70 6C 6F 64 65 28 27 2E 27 2C 20 24 6D 79 73 71 6C 5F 76 65 72
73 69 6F 6E 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 64 65 66 69 6E
65 28 27 50 4D 41 5F 4D 59 53 51 4C 5F 49 4E 54 5F 56 45 52 53 49 4F 4E
27 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 28 69 6E 74 29
20 73 70 72 69 6E 74 66 28 27 25 64 25 30 32 64 25 30 32 64 27 2C 20 24
6D 61 74 63 68 5B 30 5D 2C 20 24 6D 61 74 63 68 5B 31 5D 2C 0A 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 6E 74
76 61 6C 28 24 6D 61 74 63 68 5B 32 5D 29 29 29 3B 0A 20 20 20 20 20 20
20 20 20 20 20 20 64 65 66 69 6E 65 28 27 50 4D 41 5F 4D 59 53 51 4C 5F
53 54 52 5F 56 45 52 53 49 4F 4E 27 2C 20 24 6D 79 73 71 6C 5F 76 65 72
73 69 6F 6E 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 75 6E 73 65 74
28 24 6D 79 73 71 6C 5F 76 65 72 73 69 6F 6E 2C 20 24 6D 61 74 63 68 29
3B 0A 20 20 20 20 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20
20 20 20 20 20 20 20 64 65 66 69 6E 65 28 27 50 4D 41 5F 4D 59 53 51 4C
5F 49 4E 54 5F 56 45 52 53 49 4F 4E 27 2C 20 33 32 33 33 32 29 3B 0A 20
20 20 20 20 20 20 20 20 20 20 20 64 65 66 69 6E 65 28 27 50 4D 41 5F 4D
59 53 51 4C 5F 53 54 52 5F 56 45 52 53 49 4F 4E 27 2C 20 27 33 2E 32 33
2E 33 32 27 29 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 7D 0A 0A
20 20 20 20 69 66 20 28 21 64 65 66 69 6E 65 64 28 27 50 4D 41 5F 45 4E
47 49 4E 45 5F 4B 45 59 57 4F 52 44 27 29 29 20 7B 0A 20 20 20 20 20 20
20 20 69 66 20 28 50 4D 41 5F 4D 59 53 51 4C 5F 49 4E 54 5F 56 45 52 53
49 4F 4E 20 3E 3D 20 34 30 31 30 32 29 20 7B 0A 20 20 20 20 20 20 20 20
20 20 20 20 64 65 66 69 6E 65 28 27 50 4D 41 5F 45 4E 47 49 4E 45 5F 4B
45 59 57 4F 52 44 27 2C 27 45 4E 47 49 4E 45 27 29 3B 0A 20 20 20 20 20
20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20
64 65 66 69 6E 65 28 27 50 4D 41 5F 45 4E 47 49 4E 45 5F 4B 45 59 57 4F
52 44 27 2C 27 54 59 50 45 27 29 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20
20 20 20 7D 0A 0A 20 20 20 20 69 66 20 28 50 4D 41 5F 4D 59 53 51 4C 5F
49 4E 54 5F 56 45 52 53 49 4F 4E 20 3E 3D 20 34 30 31 30 30 29 20 7B 0A
0A 20 20 20 20 20 20 20 20 2F 2F 20 49 66 20 24 6C 61 6E 67 20 69 73 20
64 65 66 69 6E 65 64 20 61 6E 64 20 77 65 20 61 72 65 20 6F 6E 20 4D 79
53 51 4C 20 3E 3D 20 34 2E 31 2E 78 2C 0A 20 20 20 20 20 20 20 20 2F 2F
20 77 65 20 61 75 74 6F 2D 73 77 69 74 63 68 20 74 68 65 20 6C 61 6E 67
20 74 6F 20 69 74 73 20 55 54 46 2D 38 20 76 65 72 73 69 6F 6E 20 28 69
66 20 69 74 20 65 78 69 73 74 73 20 61 6E 64 20 75 73 65 72 0A 20 20 20
20 20 20 20 20 2F 2F 20 64 69 64 6E 27 74 20 66 6F 72 63 65 20 6C 61 6E
67 75 61 67 65 29 0A 20 20 20 20 20 20 20 20 69 66 20 28 20 21 65 6D 70
74 79 28 24 47 4C 4F 42 41 4C 53 5B 27 6C 61 6E 67 27 5D 29 0A 20 20 20
20 20 20 20 20 20 20 26 26 20 28 73 75 62 73 74 72 28 24 47 4C 4F 42 41
4C 53 5B 27 6C 61 6E 67 27 5D 2C 20 2D 35 29 20 21 3D 20 27 75 74 66 2D
38 27 29 0A 20 20 20 20 20 20 20 20 20 20 26 26 20 21 69 73 73 65 74 28
24 47 4C 4F 42 41 4C 53 5B 27 63 66 67 27 5D 5B 27 4C 61 6E 67 27 5D 29
20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 6C 61 6E 67 5F 75
74 66 5F 38 5F 76 65 72 73 69 6F 6E 20 3D 0A 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 73 75 62 73 74 72 28 24 47 4C 4F 42 41 4C 53 5B 27
6C 61 6E 67 27 5D 2C 20 30 2C 20 73 74 72 70 6F 73 28 24 47 4C 4F 42 41
4C 53 5B 27 6C 61 6E 67 27 5D 2C 20 27 2D 27 29 29 0A 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 2E 20 27 2D 75 74 66 2D 38 27 3B 0A 20 20
20 20 20 20 20 20 20 20 20 20 69 66 20 28 21 65 6D 70 74 79 28 24 47 4C
4F 42 41 4C 53 5B 27 61 76 61 69 6C 61 62 6C 65 5F 6C 61 6E 67 75 61 67
65 73 27 5D 5B 24 6C 61 6E 67 5F 75 74 66 5F 38 5F 76 65 72 73 69 6F 6E
5D 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 47
4C 4F 42 41 4C 53 5B 27 6C 61 6E 67 27 5D 20 3D 20 24 6C 61 6E 67 5F 75
74 66 5F 38 5F 76 65 72 73 69 6F 6E 3B 0A 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 24 47 4C 4F 42 41 4C 53 5B 27 63 68 61 72 73 65 74 27
5D 20 3D 20 27 75 74 66 2D 38 27 3B 0A 20 20 20 20 20 20 20 20 20 20 20
20 7D 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20 20 20 20 20 20 20 20 2F 2F
20 61 6E 64 20 77 65 20 72 65 6D 6F 76 65 20 74 68 65 20 6E 6F 6E 2D 55
54 46 2D 38 20 63 68 6F 69 63 65 73 20 74 6F 20 61 76 6F 69 64 20 63 6F
6E 66 75 73 69 6F 6E 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 64 65 66
69 6E 65 64 28 27 50 4D 41 5F 52 45 4D 4F 56 45 44 5F 4E 4F 4E 5F 55 54
46 5F 38 27 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 66 6F 72
65 61 63 68 20 28 20 24 47 4C 4F 42 41 4C 53 5B 27 61 76 61 69 6C 61 62
6C 65 5F 6C 61 6E 67 75 61 67 65 73 27 5D 20 61 73 20 24 65 61 63 68 5F
6C 61 6E 67 20 3D 3E 20 24 64 75 6D 6D 79 20 29 20 7B 0A 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 20 73 75 62 73 74 72 28 24
65 61 63 68 5F 6C 61 6E 67 2C 20 2D 35 29 20 21 3D 20 27 75 74 66 2D 38
27 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 75 6E 73 65 74 28 20 24 47 4C 4F 42 41 4C 53 5B 27 61 76 61 69 6C
61 62 6C 65 5F 6C 61 6E 67 75 61 67 65 73 27 5D 5B 24 65 61 63 68 5F 6C
61 6E 67 5D 20 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
7D 0A 20 20 20 20 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20 20
20 20 20 20 64 65 66 69 6E 65 28 27 50 4D 41 5F 52 45 4D 4F 56 45 44 5F
4E 4F 4E 5F 55 54 46 5F 38 27 2C 20 31 29 3B 0A 20 20 20 20 20 20 20 20
7D 0A 0A 20 20 20 20 20 20 20 20 24 6D 79 73 71 6C 5F 63 68 61 72 73 65
74 20 3D 20 24 47 4C 4F 42 41 4C 53 5B 27 6D 79 73 71 6C 5F 63 68 61 72
73 65 74 5F 6D 61 70 27 5D 5B 24 47 4C 4F 42 41 4C 53 5B 27 63 68 61 72
73 65 74 27 5D 5D 3B 0A 20 20 20 20 20 20 20 20 69 66 20 28 20 24 69 73
5F 63 6F 6E 74 72 6F 6C 75 73 65 72 0A 20 20 20 20 20 20 20 20 20 20 7C
7C 20 65 6D 70 74 79 28 24 47 4C 4F 42 41 4C 53 5B 27 63 6F 6C 6C 61 74
69 6F 6E 5F 63 6F 6E 6E 65 63 74 69 6F 6E 27 5D 29 0A 20 20 20 20 20 20
20 20 20 20 7C 7C 20 28 73 74 72 70 6F 73 28 24 47 4C 4F 42 41 4C 53 5B
27 63 6F 6C 6C 61 74 69 6F 6E 5F 63 6F 6E 6E 65 63 74 69 6F 6E 27 5D 2C
20 27 5F 27 29 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3F 20
73 75 62 73 74 72 28 24 47 4C 4F 42 41 4C 53 5B 27 63 6F 6C 6C 61 74 69
6F 6E 5F 63 6F 6E 6E 65 63 74 69 6F 6E 27 5D 2C 20 30 2C 20 73 74 72 70
6F 73 28 24 47 4C 4F 42 41 4C 53 5B 27 63 6F 6C 6C 61 74 69 6F 6E 5F 63
6F 6E 6E 65 63 74 69 6F 6E 27 5D 2C 20 27 5F 27 29 29 0A 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 3A 20 24 47 4C 4F 42 41 4C 53 5B 27 63
6F 6C 6C 61 74 69 6F 6E 5F 63 6F 6E 6E 65 63 74 69 6F 6E 27 5D 29 20 3D
3D 20 24 6D 79 73 71 6C 5F 63 68 61 72 73 65 74 29 20 7B 0A 0A 20 20 20
20 20 20 20 20 20 20 20 20 50 4D 41 5F 44 42 49 5F 71 75 65 72 79 28 27
53 45 54 20 4E 41 4D 45 53 20 27 20 2E 20 24 6D 79 73 71 6C 5F 63 68 61
72 73 65 74 20 2E 20 27 3B 27 2C 20 24 6C 69 6E 6B 2C 0A 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 50 4D 41 5F 44 42 49 5F 51 55 45 52 59
5F 53 54 4F 52 45 29 3B 0A 20 20 20 20 20 20 20 20 7D 20 65 6C 73 65 20
7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 50 4D 41 5F 44 42 49 5F 71 75
65 72 79 28 27 53 45 54 20 43 48 41 52 41 43 54 45 52 20 53 45 54 20 27
20 2E 20 24 6D 79 73 71 6C 5F 63 68 61 72 73 65 74 20 2E 20 27 3B 27 2C
20 24 6C 69 6E 6B 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
50 4D 41 5F 44 42 49 5F 51 55 45 52 59 5F 53 54 4F 52 45 29 3B 0A 20 20
20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 65 6D 70
74 79 28 24 47 4C 4F 42 41 4C 53 5B 27 63 6F 6C 6C 61 74 69 6F 6E 5F 63
6F 6E 6E 65 63 74 69 6F 6E 27 5D 29 29 20 7B 0A 20 20 20 20 20 20 20 20
20 20 20 20 50 4D 41 5F 44 42 49 5F 71 75 65 72 79 28 27 53 45 54 20 63
6F 6C 6C 61 74 69 6F 6E 5F 63 6F 6E 6E 65 63 74 69 6F 6E 20 3D 20 5C 27
27 20 2E 20 24 47 4C 4F 42 41 4C 53 5B 27 63 6F 6C 6C 61 74 69 6F 6E 5F
63 6F 6E 6E 65 63 74 69 6F 6E 27 5D 20 2E 20 27 5C 27 3B 27 2C 0A 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 6C 69 6E 6B 2C 20 50 4D 41
5F 44 42 49 5F 51 55 45 52 59 5F 53 54 4F 52 45 29 3B 0A 20 20 20 20 20
20 20 20 7D 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 24 69 73 5F 63 6F
6E 74 72 6F 6C 75 73 65 72 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20
20 24 47 4C 4F 42 41 4C 53 5B 27 63 6F 6C 6C 61 74 69 6F 6E 5F 63 6F 6E
6E 65 63 74 69 6F 6E 27 5D 20 3D 20 50 4D 41 5F 44 42 49 5F 67 65 74 5F
76 61 72 69 61 62 6C 65 28 27 63 6F 6C 6C 61 74 69 6F 6E 5F 63 6F 6E 6E
65 63 74 69 6F 6E 27 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 50 4D 41 5F 44 42 49 5F 47 45 54 56 41 52 5F 53 45 53 53 49 4F 4E 2C
20 24 6C 69 6E 6B 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 47 4C
4F 42 41 4C 53 5B 27 63 68 61 72 73 65 74 5F 63 6F 6E 6E 65 63 74 69 6F
6E 27 5D 20 20 20 3D 20 50 4D 41 5F 44 42 49 5F 67 65 74 5F 76 61 72 69
61 62 6C 65 28 27 63 68 61 72 61 63 74 65 72 5F 73 65 74 5F 63 6F 6E 6E
65 63 74 69 6F 6E 27 2C 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 50 4D 41 5F 44 42 49 5F 47 45 54 56 41 52 5F 53 45 53 53 49 4F 4E 2C
20 24 6C 69 6E 6B 29 3B 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20 20 20 20
20 20 20 20 2F 2F 20 41 64 64 20 73 6F 6D 65 20 66 69 65 6C 64 20 74 79
70 65 73 20 74 6F 20 74 68 65 20 6C 69 73 74 2C 20 74 68 69 73 20 6E 65
65 64 73 20 74 6F 20 62 65 20 64 6F 6E 65 20 6F 6E 63 65 20 70 65 72 20
73 65 73 73 69 6F 6E 21 0A 20 20 20 20 20 20 20 20 69 66 20 28 24 47 4C
4F 42 41 4C 53 5B 27 63 66 67 27 5D 5B 27 43 6F 6C 75 6D 6E 54 79 70 65
73 27 5D 5B 63 6F 75 6E 74 28 24 47 4C 4F 42 41 4C 53 5B 27 63 66 67 27
5D 5B 27 43 6F 6C 75 6D 6E 54 79 70 65 73 27 5D 29 20 2D 20 31 5D 20 21
3D 20 27 56 41 52 42 49 4E 41 52 59 27 29 20 7B 0A 20 20 20 20 20 20 20
20 20 20 20 20 24 47 4C 4F 42 41 4C 53 5B 27 63 66 67 27 5D 5B 27 43 6F
6C 75 6D 6E 54 79 70 65 73 27 5D 5B 5D 20 3D 20 27 42 49 4E 41 52 59 27
3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 47 4C 4F 42 41 4C 53 5B 27
63 66 67 27 5D 5B 27 43 6F 6C 75 6D 6E 54 79 70 65 73 27 5D 5B 5D 20 3D
20 27 56 41 52 42 49 4E 41 52 59 27 3B 0A 20 20 20 20 20 20 20 20 7D 0A
0A 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20 72 65
71 75 69 72 65 5F 6F 6E 63 65 28 27 2E 2F 6C 69 62 72 61 72 69 65 73 2F
63 68 61 72 73 65 74 5F 63 6F 6E 76 65 72 73 69 6F 6E 2E 6C 69 62 2E 70
68 70 27 29 3B 0A 20 20 20 20 7D 0A 7D 0A 0A 2F 2A 2A 0A 20 2A 20 72 65
74 75 72 6E 73 20 61 20 73 69 6E 67 6C 65 20 76 61 6C 75 65 20 66 72 6F
6D 20 74 68 65 20 67 69 76 65 6E 20 72 65 73 75 6C 74 20 6F 72 20 71 75
65 72 79 2C 0A 20 2A 20 69 66 20 74 68 65 20 71 75 65 72 79 20 6F 72 20
74 68 65 20 72 65 73 75 6C 74 20 68 61 73 20 6D 6F 72 65 20 74 68 61 6E
20 6F 6E 65 20 72 6F 77 20 6F 72 20 66 69 65 6C 64 0A 20 2A 20 74 68 65
20 66 69 72 73 74 20 66 69 65 6C 64 20 6F 66 20 74 68 65 20 66 69 72 73
74 20 72 6F 77 20 69 73 20 72 65 74 75 72 6E 65 64 0A 20 2A 0A 20 2A 20
3C 63 6F 64 65 3E 0A 20 2A 20 24 73 71 6C 20 3D 20 27 53 45 4C 45 43 54
20 60 6E 61 6D 65 60 20 46 52 4F 4D 20 60 75 73 65 72 60 20 57 48 45 52
45 20 60 69 64 60 20 3D 20 31 32 33 27 3B 0A 20 2A 20 24 75 73 65 72 5F
6E 61 6D 65 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 76 61 6C
75 65 28 20 24 73 71 6C 20 29 3B 0A 20 2A 20 2F 2F 20 70 72 6F 64 75 63
65 73 0A 20 2A 20 2F 2F 20 24 75 73 65 72 5F 6E 61 6D 65 20 3D 20 27 4A
6F 68 6E 20 44 6F 65 27 0A 20 2A 20 3C 2F 63 6F 64 65 3E 0A 20 2A 0A 20
2A 20 40 75 73 65 73 20 20 20 20 69 73 5F 73 74 72 69 6E 67 28 29 0A 20
2A 20 40 75 73 65 73 20 20 20 20 69 73 5F 69 6E 74 28 29 0A 20 2A 20 40
75 73 65 73 20 20 20 20 50 4D 41 5F 44 42 49 5F 74 72 79 5F 71 75 65 72
79 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50 4D 41 5F 44 42 49 5F
6E 75 6D 5F 72 6F 77 73 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50
4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 72 6F 77 28 29 0A 20 2A 20 40 75
73 65 73 20 20 20 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 61 73 73
6F 63 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50 4D 41 5F 44 42 49
5F 66 72 65 65 5F 72 65 73 75 6C 74 28 29 0A 20 2A 20 40 70 61 72 61 6D
20 20 20 73 74 72 69 6E 67 7C 6D 79 73 71 6C 5F 72 65 73 75 6C 74 20 24
72 65 73 75 6C 74 20 71 75 65 72 79 20 6F 72 20 6D 79 73 71 6C 20 72 65
73 75 6C 74 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 69 6E 74 65 67 65 72
20 20 20 20 20 20 20 20 20 20 20 20 20 24 72 6F 77 5F 6E 75 6D 62 65 72
20 72 6F 77 20 74 6F 20 66 65 74 63 68 20 74 68 65 20 76 61 6C 75 65 20
66 72 6F 6D 2C 0A 20 2A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 74
61 72 74 69 6E 67 20 61 74 20 30 2C 20 77 69 74 68 20 30 20 62 65 65 69
6E 67 20 64 65 66 61 75 6C 74 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 69
6E 74 65 67 65 72 7C 73 74 72 69 6E 67 20 20 20 20 20 20 24 66 69 65 6C
64 20 20 66 69 65 6C 64 20 74 6F 20 66 65 74 63 68 20 74 68 65 20 76 61
6C 75 65 20 66 72 6F 6D 2C 0A 20 2A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 73 74 61 72 74 69 6E 67 20 61 74 20 30 2C 20 77 69 74 68 20 30 20
62 65 65 69 6E 67 20 64 65 66 61 75 6C 74 0A 20 2A 20 40 70 61 72 61 6D
20 20 20 72 65 73 6F 75 72 63 65 20 20 20 20 20 20 20 20 20 20 20 20 24
6C 69 6E 6B 20 20 20 6D 79 73 71 6C 20 6C 69 6E 6B 0A 20 2A 20 40 70 61
72 61 6D 20 20 20 6D 69 78 65 64 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 24 6F 70 74 69 6F 6E 73 0A 20 2A 20 40 72 65 74 75 72 6E 20 20 6D
69 78 65 64 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 76 61 6C 75 65
20 6F 66 20 66 69 72 73 74 20 66 69 65 6C 64 20 69 6E 20 66 69 72 73 74
20 72 6F 77 20 66 72 6F 6D 20 72 65 73 75 6C 74 0A 20 2A 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 6F 72 20 66 61 6C 73 65 20 69 66 20 6E 6F 74 20 66 6F 75 6E 64 0A 20
2A 2F 0A 66 75 6E 63 74 69 6F 6E 20 50 4D 41 5F 44 42 49 5F 66 65 74 63
68 5F 76 61 6C 75 65 28 20 24 72 65 73 75 6C 74 2C 20 24 72 6F 77 5F 6E
75 6D 62 65 72 20 3D 20 30 2C 20 24 66 69 65 6C 64 20 3D 20 30 2C 20 24
6C 69 6E 6B 20 3D 20 6E 75 6C 6C 2C 20 24 6F 70 74 69 6F 6E 73 20 3D 20
30 20 29 20 7B 0A 20 20 20 20 24 76 61 6C 75 65 20 3D 20 66 61 6C 73 65
3B 0A 0A 20 20 20 20 69 66 20 28 20 69 73 5F 73 74 72 69 6E 67 28 20 24
72 65 73 75 6C 74 20 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 24 72 65
73 75 6C 74 20 3D 20 50 4D 41 5F 44 42 49 5F 74 72 79 5F 71 75 65 72 79
28 20 24 72 65 73 75 6C 74 2C 20 24 6C 69 6E 6B 2C 20 24 6F 70 74 69 6F
6E 73 20 7C 20 50 4D 41 5F 44 42 49 5F 51 55 45 52 59 5F 53 54 4F 52 45
20 29 3B 0A 20 20 20 20 7D 0A 0A 20 20 20 20 2F 2F 20 72 65 74 75 72 6E
20 66 61 6C 73 65 20 69 66 20 72 65 73 75 6C 74 20 69 73 20 65 6D 70 74
79 20 6F 72 20 66 61 6C 73 65 0A 20 20 20 20 2F 2F 20 6F 72 20 72 65 71
75 65 73 74 65 64 20 72 6F 77 20 69 73 20 6C 61 72 67 65 72 20 74 68 61
6E 20 72 6F 77 73 20 69 6E 20 72 65 73 75 6C 74 0A 20 20 20 20 69 66 20
28 20 50 4D 41 5F 44 42 49 5F 6E 75 6D 5F 72 6F 77 73 28 20 24 72 65 73
75 6C 74 20 29 20 3C 20 28 20 24 72 6F 77 5F 6E 75 6D 62 65 72 20 2B 20
31 20 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 72 65 74 75 72 6E 20 24
76 61 6C 75 65 3B 0A 20 20 20 20 7D 0A 0A 20 20 20 20 2F 2F 20 69 66 20
24 66 69 65 6C 64 20 69 73 20 61 6E 20 69 6E 74 65 67 65 72 20 75 73 65
20 6E 6F 6E 20 61 73 73 6F 63 69 61 74 69 76 65 20 6D 79 73 71 6C 20 66
65 74 63 68 20 66 75 6E 63 74 69 6F 6E 0A 20 20 20 20 69 66 20 28 20 69
73 5F 69 6E 74 28 20 24 66 69 65 6C 64 20 29 20 29 20 7B 0A 20 20 20 20
20 20 20 20 24 66 65 74 63 68 5F 66 75 6E 63 74 69 6F 6E 20 3D 20 27 50
4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 72 6F 77 27 3B 0A 20 20 20 20 7D
20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20 24 66 65 74 63 68 5F 66
75 6E 63 74 69 6F 6E 20 3D 20 27 50 4D 41 5F 44 42 49 5F 66 65 74 63 68
5F 61 73 73 6F 63 27 3B 0A 20 20 20 20 7D 0A 0A 20 20 20 20 2F 2F 20 67
65 74 20 72 65 71 75 65 73 74 65 64 20 72 6F 77 0A 20 20 20 20 66 6F 72
20 28 20 24 69 20 3D 20 30 3B 20 24 69 20 3C 3D 20 24 72 6F 77 5F 6E 75
6D 62 65 72 3B 20 24 69 2B 2B 20 29 20 7B 0A 20 20 20 20 20 20 20 20 24
72 6F 77 20 3D 20 24 66 65 74 63 68 5F 66 75 6E 63 74 69 6F 6E 28 20 24
72 65 73 75 6C 74 20 29 3B 0A 20 20 20 20 7D 0A 20 20 20 20 50 4D 41 5F
44 42 49 5F 66 72 65 65 5F 72 65 73 75 6C 74 28 20 24 72 65 73 75 6C 74
20 29 3B 0A 0A 20 20 20 20 2F 2F 20 72 65 74 75 72 6E 20 72 65 71 75 65
73 74 65 64 20 66 69 65 6C 64 0A 20 20 20 20 69 66 20 28 20 69 73 73 65
74 28 20 24 72 6F 77 5B 24 66 69 65 6C 64 5D 20 29 20 29 20 7B 0A 20 20
20 20 20 20 20 20 24 76 61 6C 75 65 20 3D 20 24 72 6F 77 5B 24 66 69 65
6C 64 5D 3B 0A 20 20 20 20 7D 0A 20 20 20 20 75 6E 73 65 74 28 20 24 72
6F 77 20 29 3B 0A 0A 20 20 20 20 72 65 74 75 72 6E 20 24 76 61 6C 75 65
3B 0A 7D 0A 0A 2F 2A 2A 0A 20 2A 20 72 65 74 75 72 6E 73 20 6F 6E 6C 79
20 74 68 65 20 66 69 72 73 74 20 72 6F 77 20 66 72 6F 6D 20 74 68 65 20
72 65 73 75 6C 74 0A 20 2A 0A 20 2A 20 3C 63 6F 64 65 3E 0A 20 2A 20 24
73 71 6C 20 3D 20 27 53 45 4C 45 43 54 20 2A 20 46 52 4F 4D 20 60 75 73
65 72 60 20 57 48 45 52 45 20 60 69 64 60 20 3D 20 31 32 33 27 3B 0A 20
2A 20 24 75 73 65 72 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F
73 69 6E 67 6C 65 5F 72 6F 77 28 20 24 73 71 6C 20 29 3B 0A 20 2A 20 2F
2F 20 70 72 6F 64 75 63 65 73 0A 20 2A 20 2F 2F 20 24 75 73 65 72 20 3D
20 61 72 72 61 79 28 20 27 69 64 27 20 3D 3E 20 31 32 33 2C 20 27 6E 61
6D 65 27 20 3D 3E 20 27 4A 6F 68 6E 20 44 6F 65 27 20 29 0A 20 2A 20 3C
2F 63 6F 64 65 3E 0A 20 2A 0A 20 2A 20 40 75 73 65 73 20 20 20 20 69 73
5F 73 74 72 69 6E 67 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50 4D
41 5F 44 42 49 5F 74 72 79 5F 71 75 65 72 79 28 29 0A 20 2A 20 40 75 73
65 73 20 20 20 20 50 4D 41 5F 44 42 49 5F 6E 75 6D 5F 72 6F 77 73 28 29
0A 20 2A 20 40 75 73 65 73 20 20 20 20 50 4D 41 5F 44 42 49 5F 66 65 74
63 68 5F 72 6F 77 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50 4D 41
5F 44 42 49 5F 66 65 74 63 68 5F 61 73 73 6F 63 28 29 0A 20 2A 20 40 75
73 65 73 20 20 20 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 61 72 72
61 79 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50 4D 41 5F 44 42 49
5F 66 72 65 65 5F 72 65 73 75 6C 74 28 29 0A 20 2A 20 40 70 61 72 61 6D
20 20 20 73 74 72 69 6E 67 7C 6D 79 73 71 6C 5F 72 65 73 75 6C 74 20 24
72 65 73 75 6C 74 20 71 75 65 72 79 20 6F 72 20 6D 79 73 71 6C 20 72 65
73 75 6C 74 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 73 74 72 69 6E 67 20
20 20 20 20 20 20 20 20 20 20 20 20 20 24 74 79 70 65 20 20 20 4E 55 4D
7C 41 53 53 4F 43 7C 42 4F 54 48 0A 20 2A 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 72 65 74 75 72 6E 65 64 20 61 72 72 61 79 20 73 68 6F 75 6C
64 20 65 69 74 68 65 72 20 6E 75 6D 65 72 69 63 0A 20 2A 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 61 73 73 6F 63 69 61 74 69 76 20 6F 72 20 62
6F 6F 74 68 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 72 65 73 6F 75 72 63
65 20 20 20 20 20 20 20 20 20 20 20 20 24 6C 69 6E 6B 20 20 20 6D 79 73
71 6C 20 6C 69 6E 6B 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 6D 69 78 65
64 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 6F 70 74 69 6F 6E 73
0A 20 2A 20 40 72 65 74 75 72 6E 20 20 61 72 72 61 79 7C 62 6F 6F 6C 65
61 6E 20 20 20 20 20 20 20 66 69 72 73 74 20 72 6F 77 20 66 72 6F 6D 20
72 65 73 75 6C 74 0A 20 2A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6F 72 20 66 61 6C 73 65 20
69 66 20 72 65 73 75 6C 74 20 69 73 20 65 6D 70 74 79 0A 20 2A 2F 0A 66
75 6E 63 74 69 6F 6E 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 73 69
6E 67 6C 65 5F 72 6F 77 28 20 24 72 65 73 75 6C 74 2C 20 24 74 79 70 65
20 3D 20 27 41 53 53 4F 43 27 2C 20 24 6C 69 6E 6B 20 3D 20 6E 75 6C 6C
2C 20 24 6F 70 74 69 6F 6E 73 20 3D 20 30 20 29 20 7B 0A 20 20 20 20 69
66 20 28 20 69 73 5F 73 74 72 69 6E 67 28 20 24 72 65 73 75 6C 74 20 29
20 29 20 7B 0A 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 20 3D 20 50
4D 41 5F 44 42 49 5F 74 72 79 5F 71 75 65 72 79 28 20 24 72 65 73 75 6C
74 2C 20 24 6C 69 6E 6B 2C 20 24 6F 70 74 69 6F 6E 73 20 7C 20 50 4D 41
5F 44 42 49 5F 51 55 45 52 59 5F 53 54 4F 52 45 20 29 3B 0A 20 20 20 20
7D 0A 0A 20 20 20 20 2F 2F 20 72 65 74 75 72 6E 20 6E 75 6C 6C 20 69 66
20 72 65 73 75 6C 74 20 69 73 20 65 6D 70 74 79 20 6F 72 20 66 61 6C 73
65 0A 20 20 20 20 69 66 20 28 20 21 20 50 4D 41 5F 44 42 49 5F 6E 75 6D
5F 72 6F 77 73 28 20 24 72 65 73 75 6C 74 20 29 20 29 20 7B 0A 20 20 20
20 20 20 20 20 72 65 74 75 72 6E 20 66 61 6C 73 65 3B 0A 20 20 20 20 7D
0A 0A 20 20 20 20 73 77 69 74 63 68 20 28 20 24 74 79 70 65 20 29 20 7B
0A 20 20 20 20 20 20 20 20 63 61 73 65 20 27 4E 55 4D 27 20 3A 0A 20 20
20 20 20 20 20 20 20 20 20 20 24 66 65 74 63 68 5F 66 75 6E 63 74 69 6F
6E 20 3D 20 27 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 72 6F 77 27 3B
0A 20 20 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6B 3B 0A 20 20 20 20
20 20 20 20 63 61 73 65 20 27 41 53 53 4F 43 27 20 3A 0A 20 20 20 20 20
20 20 20 20 20 20 20 24 66 65 74 63 68 5F 66 75 6E 63 74 69 6F 6E 20 3D
20 27 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 61 73 73 6F 63 27 3B 0A
20 20 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6B 3B 0A 20 20 20 20 20
20 20 20 63 61 73 65 20 27 42 4F 54 48 27 20 3A 0A 20 20 20 20 20 20 20
20 64 65 66 61 75 6C 74 20 3A 0A 20 20 20 20 20 20 20 20 20 20 20 20 24
66 65 74 63 68 5F 66 75 6E 63 74 69 6F 6E 20 3D 20 27 50 4D 41 5F 44 42
49 5F 66 65 74 63 68 5F 61 72 72 61 79 27 3B 0A 20 20 20 20 20 20 20 20
20 20 20 20 62 72 65 61 6B 3B 0A 20 20 20 20 7D 0A 0A 20 20 20 20 24 72
6F 77 20 3D 20 24 66 65 74 63 68 5F 66 75 6E 63 74 69 6F 6E 28 20 24 72
65 73 75 6C 74 20 29 3B 0A 20 20 20 20 50 4D 41 5F 44 42 49 5F 66 72 65
65 5F 72 65 73 75 6C 74 28 20 24 72 65 73 75 6C 74 20 29 3B 0A 20 20 20
20 72 65 74 75 72 6E 20 24 72 6F 77 3B 0A 7D 0A 0A 2F 2A 2A 0A 20 2A 20
72 65 74 75 72 6E 73 20 61 6C 6C 20 72 6F 77 73 20 69 6E 20 74 68 65 20
72 65 73 75 6C 74 73 65 74 20 69 6E 20 6F 6E 65 20 61 72 72 61 79 0A 20
2A 0A 20 2A 20 3C 63 6F 64 65 3E 0A 20 2A 20 24 73 71 6C 20 3D 20 27 53
45 4C 45 43 54 20 2A 20 46 52 4F 4D 20 60 75 73 65 72 60 27 3B 0A 20 2A
20 24 75 73 65 72 73 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F
72 65 73 75 6C 74 28 20 24 73 71 6C 20 29 3B 0A 20 2A 20 2F 2F 20 70 72
6F 64 75 63 65 73 0A 20 2A 20 2F 2F 20 24 75 73 65 72 73 5B 5D 20 3D 20
61 72 72 61 79 28 20 27 69 64 27 20 3D 3E 20 31 32 33 2C 20 27 6E 61 6D
65 27 20 3D 3E 20 27 4A 6F 68 6E 20 44 6F 65 27 20 29 0A 20 2A 0A 20 2A
20 24 73 71 6C 20 3D 20 27 53 45 4C 45 43 54 20 60 69 64 60 2C 20 60 6E
61 6D 65 60 20 46 52 4F 4D 20 60 75 73 65 72 60 27 3B 0A 20 2A 20 24 75
73 65 72 73 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 72 65 73
75 6C 74 28 20 24 73 71 6C 2C 20 27 69 64 27 20 29 3B 0A 20 2A 20 2F 2F
20 70 72 6F 64 75 63 65 73 0A 20 2A 20 2F 2F 20 24 75 73 65 72 73 5B 27
31 32 33 27 5D 20 3D 20 61 72 72 61 79 28 20 27 69 64 27 20 3D 3E 20 31
32 33 2C 20 27 6E 61 6D 65 27 20 3D 3E 20 27 4A 6F 68 6E 20 44 6F 65 27
20 29 0A 20 2A 0A 20 2A 20 24 73 71 6C 20 3D 20 27 53 45 4C 45 43 54 20
60 69 64 60 2C 20 60 6E 61 6D 65 60 20 46 52 4F 4D 20 60 75 73 65 72 60
27 3B 0A 20 2A 20 24 75 73 65 72 73 20 3D 20 50 4D 41 5F 44 42 49 5F 66
65 74 63 68 5F 72 65 73 75 6C 74 28 20 24 73 71 6C 2C 20 30 20 29 3B 0A
20 2A 20 2F 2F 20 70 72 6F 64 75 63 65 73 0A 20 2A 20 2F 2F 20 24 75 73
65 72 73 5B 27 31 32 33 27 5D 20 3D 20 61 72 72 61 79 28 20 30 20 3D 3E
20 31 32 33 2C 20 31 20 3D 3E 20 27 4A 6F 68 6E 20 44 6F 65 27 20 29 0A
20 2A 0A 20 2A 20 24 73 71 6C 20 3D 20 27 53 45 4C 45 43 54 20 60 69 64
60 2C 20 60 6E 61 6D 65 60 20 46 52 4F 4D 20 60 75 73 65 72 60 27 3B 0A
20 2A 20 24 75 73 65 72 73 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63
68 5F 72 65 73 75 6C 74 28 20 24 73 71 6C 2C 20 27 69 64 27 2C 20 27 6E
61 6D 65 27 20 29 3B 0A 20 2A 20 2F 2F 20 6F 72 0A 20 2A 20 24 75 73 65
72 73 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 72 65 73 75 6C
74 28 20 24 73 71 6C 2C 20 30 2C 20 31 20 29 3B 0A 20 2A 20 2F 2F 20 70
72 6F 64 75 63 65 73 0A 20 2A 20 2F 2F 20 24 75 73 65 72 73 5B 27 31 32
33 27 5D 20 3D 20 27 4A 6F 68 6E 20 44 6F 65 27 0A 20 2A 0A 20 2A 20 24
73 71 6C 20 3D 20 27 53 45 4C 45 43 54 20 60 6E 61 6D 65 60 20 46 52 4F
4D 20 60 75 73 65 72 60 27 3B 0A 20 2A 20 24 75 73 65 72 73 20 3D 20 50
4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 72 65 73 75 6C 74 28 20 24 73 71
6C 20 29 3B 0A 20 2A 20 2F 2F 20 70 72 6F 64 75 63 65 73 0A 20 2A 20 2F
2F 20 24 75 73 65 72 73 5B 5D 20 3D 20 27 4A 6F 68 6E 20 44 6F 65 27 0A
20 2A 20 3C 2F 63 6F 64 65 3E 0A 20 2A 0A 20 2A 20 40 75 73 65 73 20 20
20 20 69 73 5F 73 74 72 69 6E 67 28 29 0A 20 2A 20 40 75 73 65 73 20 20
20 20 69 73 5F 69 6E 74 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50
4D 41 5F 44 42 49 5F 74 72 79 5F 71 75 65 72 79 28 29 0A 20 2A 20 40 75
73 65 73 20 20 20 20 50 4D 41 5F 44 42 49 5F 6E 75 6D 5F 72 6F 77 73 28
29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50 4D 41 5F 44 42 49 5F 6E 75
6D 5F 66 69 65 6C 64 73 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50
4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 72 6F 77 28 29 0A 20 2A 20 40 75
73 65 73 20 20 20 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 61 73 73
6F 63 28 29 0A 20 2A 20 40 75 73 65 73 20 20 20 20 50 4D 41 5F 44 42 49
5F 66 72 65 65 5F 72 65 73 75 6C 74 28 29 0A 20 2A 20 40 70 61 72 61 6D
20 20 20 73 74 72 69 6E 67 7C 6D 79 73 71 6C 5F 72 65 73 75 6C 74 20 24
72 65 73 75 6C 74 20 71 75 65 72 79 20 6F 72 20 6D 79 73 71 6C 20 72 65
73 75 6C 74 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 73 74 72 69 6E 67 7C
69 6E 74 65 67 65 72 20 20 20 20 20 20 24 6B 65 79 20 20 20 20 66 69 65
6C 64 2D 6E 61 6D 65 20 6F 72 20 6F 66 66 73 65 74 0A 20 2A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 75 73 65 64 20 61 73 20 6B 65 79 20 66 6F
72 20 61 72 72 61 79 0A 20 2A 20 40 70 61 72 61 6D 20 20 20 73 74 72 69
6E 67 7C 69 6E 74 65 67 65 72 20 20 20 20 20 20 24 76 61 6C 75 65 20 20
76 61 6C 75 65 2D 6E 61 6D 65 20 6F 72 20 6F 66 66 73 65 74 0A 20 2A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 75 73 65 64 20 61 73 20 76 61 6C
75 65 20 66 6F 72 20 61 72 72 61 79 0A 20 2A 20 40 70 61 72 61 6D 20 20
20 72 65 73 6F 75 72 63 65 20 20 20 20 20 20 20 20 20 20 20 20 24 6C 69
6E 6B 20 20 20 6D 79 73 71 6C 20 6C 69 6E 6B 0A 20 2A 20 40 70 61 72 61
6D 20 20 20 6D 69 78 65 64 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
24 6F 70 74 69 6F 6E 73 0A 20 2A 20 40 72 65 74 75 72 6E 20 20 61 72 72
61 79 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65 73 75 6C 74 72
6F 77 73 20 6F 72 20 76 61 6C 75 65 73 20 69 6E 64 65 78 65 64 20 62 79
20 24 6B 65 79 0A 20 2A 2F 0A 66 75 6E 63 74 69 6F 6E 20 50 4D 41 5F 44
42 49 5F 66 65 74 63 68 5F 72 65 73 75 6C 74 28 20 24 72 65 73 75 6C 74
2C 20 24 6B 65 79 20 3D 20 6E 75 6C 6C 2C 20 24 76 61 6C 75 65 20 3D 20
6E 75 6C 6C 2C 0A 20 20 20 20 24 6C 69 6E 6B 20 3D 20 6E 75 6C 6C 2C 20
24 6F 70 74 69 6F 6E 73 20 3D 20 30 20 29 0A 7B 0A 20 20 20 20 24 72 65
73 75 6C 74 72 6F 77 73 20 3D 20 61 72 72 61 79 28 29 3B 0A 0A 20 20 20
20 69 66 20 28 20 69 73 5F 73 74 72 69 6E 67 28 24 72 65 73 75 6C 74 29
20 29 20 7B 0A 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 20 3D 20 50
4D 41 5F 44 42 49 5F 74 72 79 5F 71 75 65 72 79 28 24 72 65 73 75 6C 74
2C 20 24 6C 69 6E 6B 2C 20 24 6F 70 74 69 6F 6E 73 29 3B 0A 20 20 20 20
7D 0A 0A 20 20 20 20 2F 2F 20 72 65 74 75 72 6E 20 65 6D 70 74 79 20 61
72 72 61 79 20 69 66 20 72 65 73 75 6C 74 20 69 73 20 65 6D 70 74 79 20
6F 72 20 66 61 6C 73 65 0A 20 20 20 20 69 66 20 28 20 21 20 24 72 65 73
75 6C 74 20 29 20 7B 0A 20 20 20 20 20 20 20 20 72 65 74 75 72 6E 20 24
72 65 73 75 6C 74 72 6F 77 73 3B 0A 20 20 20 20 7D 0A 0A 20 20 20 20 24
66 65 74 63 68 5F 66 75 6E 63 74 69 6F 6E 20 3D 20 27 50 4D 41 5F 44 42
49 5F 66 65 74 63 68 5F 61 73 73 6F 63 27 3B 0A 0A 20 20 20 20 2F 2F 20
6E 6F 20 6E 65 73 74 65 64 20 61 72 72 61 79 20 69 66 20 6F 6E 6C 79 20
6F 6E 65 20 66 69 65 6C 64 20 69 73 20 69 6E 20 72 65 73 75 6C 74 0A 20
20 20 20 69 66 20 28 20 6E 75 6C 6C 20 3D 3D 3D 20 24 6B 65 79 20 26 26
20 31 20 3D 3D 3D 20 50 4D 41 5F 44 42 49 5F 6E 75 6D 5F 66 69 65 6C 64
73 28 24 72 65 73 75 6C 74 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 24
76 61 6C 75 65 20 3D 20 30 3B 0A 20 20 20 20 20 20 20 20 24 66 65 74 63
68 5F 66 75 6E 63 74 69 6F 6E 20 3D 20 27 50 4D 41 5F 44 42 49 5F 66 65
74 63 68 5F 72 6F 77 27 3B 0A 20 20 20 20 7D 0A 0A 20 20 20 20 2F 2F 20
69 66 20 24 6B 65 79 20 69 73 20 61 6E 20 69 6E 74 65 67 65 72 20 75 73
65 20 6E 6F 6E 20 61 73 73 6F 63 69 61 74 69 76 65 20 6D 79 73 71 6C 20
66 65 74 63 68 20 66 75 6E 63 74 69 6F 6E 0A 20 20 20 20 69 66 20 28 20
69 73 5F 69 6E 74 28 24 6B 65 79 29 20 29 20 7B 0A 20 20 20 20 20 20 20
20 24 66 65 74 63 68 5F 66 75 6E 63 74 69 6F 6E 20 3D 20 27 50 4D 41 5F
44 42 49 5F 66 65 74 63 68 5F 72 6F 77 27 3B 0A 20 20 20 20 7D 0A 0A 20
20 20 20 69 66 20 28 20 6E 75 6C 6C 20 3D 3D 3D 20 24 6B 65 79 20 26 26
20 6E 75 6C 6C 20 3D 3D 3D 20 24 76 61 6C 75 65 20 29 20 7B 0A 20 20 20
20 20 20 20 20 77 68 69 6C 65 20 28 20 24 72 6F 77 20 3D 20 24 66 65 74
63 68 5F 66 75 6E 63 74 69 6F 6E 28 24 72 65 73 75 6C 74 29 20 29 20 7B
0A 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 72 6F 77 73
5B 5D 20 3D 20 24 72 6F 77 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20
20 7D 20 65 6C 73 65 69 66 20 28 20 6E 75 6C 6C 20 3D 3D 3D 20 24 6B 65
79 20 29 20 7B 0A 20 20 20 20 20 20 20 20 77 68 69 6C 65 20 28 20 24 72
6F 77 20 3D 20 24 66 65 74 63 68 5F 66 75 6E 63 74 69 6F 6E 28 24 72 65
73 75 6C 74 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 72
65 73 75 6C 74 72 6F 77 73 5B 5D 20 3D 20 24 72 6F 77 5B 24 76 61 6C 75
65 5D 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 7D 20 65 6C 73 65
69 66 20 28 20 6E 75 6C 6C 20 3D 3D 3D 20 24 76 61 6C 75 65 20 29 20 7B
0A 20 20 20 20 20 20 20 20 69 66 20 28 20 69 73 5F 61 72 72 61 79 28 24
6B 65 79 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 77 68 69
6C 65 20 28 20 24 72 6F 77 20 3D 20 24 66 65 74 63 68 5F 66 75 6E 63 74
69 6F 6E 28 24 72 65 73 75 6C 74 29 20 29 20 7B 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5F 74 61 72 67 65 74 20
3D 26 20 24 72 65 73 75 6C 74 72 6F 77 73 3B 0A 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 66 6F 72 65 61 63 68 20 28 20 24 6B 65 79 20 61
73 20 24 6B 65 79 5F 69 6E 64 65 78 20 29 20 7B 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 20 21 20 69 73 73 65
74 28 20 24 72 65 73 75 6C 74 5F 74 61 72 67 65 74 5B 24 72 6F 77 5B 24
6B 65 79 5F 69 6E 64 65 78 5D 5D 20 29 20 29 20 7B 0A 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C
74 5F 74 61 72 67 65 74 5B 24 72 6F 77 5B 24 6B 65 79 5F 69 6E 64 65 78
5D 5D 20 3D 20 61 72 72 61 79 28 29 3B 0A 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5F 74 61 72 67 65 74 20 3D
26 20 24 72 65 73 75 6C 74 5F 74 61 72 67 65 74 5B 24 72 6F 77 5B 24 6B
65 79 5F 69 6E 64 65 78 5D 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 7D 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 72
65 73 75 6C 74 5F 74 61 72 67 65 74 20 3D 20 24 72 6F 77 3B 0A 20 20 20
20 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20 20 7D 20 65 6C 73
65 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 77 68 69 6C 65 20 28 20
24 72 6F 77 20 3D 20 24 66 65 74 63 68 5F 66 75 6E 63 74 69 6F 6E 28 24
72 65 73 75 6C 74 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 24 72 65 73 75 6C 74 72 6F 77 73 5B 24 72 6F 77 5B 24 6B 65
79 5D 5D 20 3D 20 24 72 6F 77 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20
7D 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 7D 20 65 6C 73 65 20 7B
0A 20 20 20 20 20 20 20 20 69 66 20 28 20 69 73 5F 61 72 72 61 79 28 24
6B 65 79 29 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 77 68 69
6C 65 20 28 20 24 72 6F 77 20 3D 20 24 66 65 74 63 68 5F 66 75 6E 63 74
69 6F 6E 28 24 72 65 73 75 6C 74 29 20 29 20 7B 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5F 74 61 72 67 65 74 20
3D 26 20 24 72 65 73 75 6C 74 72 6F 77 73 3B 0A 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 66 6F 72 65 61 63 68 20 28 20 24 6B 65 79 20 61
73 20 24 6B 65 79 5F 69 6E 64 65 78 20 29 20 7B 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 20 21 20 69 73 73 65
74 28 20 24 72 65 73 75 6C 74 5F 74 61 72 67 65 74 5B 24 72 6F 77 5B 24
6B 65 79 5F 69 6E 64 65 78 5D 5D 20 29 20 29 20 7B 0A 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C
74 5F 74 61 72 67 65 74 5B 24 72 6F 77 5B 24 6B 65 79 5F 69 6E 64 65 78
5D 5D 20 3D 20 61 72 72 61 79 28 29 3B 0A 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5F 74 61 72 67 65 74 20 3D
26 20 24 72 65 73 75 6C 74 5F 74 61 72 67 65 74 5B 24 72 6F 77 5B 24 6B
65 79 5F 69 6E 64 65 78 5D 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 7D 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 72
65 73 75 6C 74 5F 74 61 72 67 65 74 20 3D 20 24 72 6F 77 5B 24 76 61 6C
75 65 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20
20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20
77 68 69 6C 65 20 28 20 24 72 6F 77 20 3D 20 24 66 65 74 63 68 5F 66 75
6E 63 74 69 6F 6E 28 24 72 65 73 75 6C 74 29 20 29 20 7B 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 72 6F 77 73 5B
24 72 6F 77 5B 24 6B 65 79 5D 5D 20 3D 20 24 72 6F 77 5B 24 76 61 6C 75
65 5D 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20
20 20 7D 0A 20 20 20 20 7D 0A 0A 20 20 20 20 50 4D 41 5F 44 42 49 5F 66
72 65 65 5F 72 65 73 75 6C 74 28 24 72 65 73 75 6C 74 29 3B 0A 20 20 20
20 72 65 74 75 72 6E 20 24 72 65 73 75 6C 74 72 6F 77 73 3B 0A 7D 0A 0A
2F 2A 2A 0A 20 2A 20 72 65 74 75 72 6E 20 64 65 66 61 75 6C 74 20 74 61
62 6C 65 20 65 6E 67 69 6E 65 20 66 6F 72 20 67 69 76 65 6E 20 64 61 74
61 62 61 73 65 0A 20 2A 0A 20 2A 20 40 72 65 74 75 72 6E 20 20 73 74 72
69 6E 67 20 20 64 65 66 61 75 6C 74 20 74 61 62 6C 65 20 65 6E 67 69 6E
65 0A 20 2A 2F 0A 66 75 6E 63 74 69 6F 6E 20 50 4D 41 5F 44 42 49 5F 67
65 74 5F 64 65 66 61 75 6C 74 5F 65 6E 67 69 6E 65 28 29 0A 7B 0A 20 20
20 20 69 66 20 28 20 50 4D 41 5F 4D 59 53 51 4C 5F 49 4E 54 5F 56 45 52
53 49 4F 4E 20 3E 20 35 30 30 30 32 20 29 20 7B 0A 20 20 20 20 20 20 20
20 72 65 74 75 72 6E 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 76 61
6C 75 65 28 20 27 53 48 4F 57 20 56 41 52 49 41 42 4C 45 53 20 4C 49 4B
45 20 5C 27 73 74 6F 72 61 67 65 5F 65 6E 67 69 6E 65 5C 27 3B 27 2C 20
30 2C 20 31 20 29 3B 0A 20 20 20 20 7D 20 65 6C 73 65 20 7B 0A 20 20 20
20 20 20 20 20 72 65 74 75 72 6E 20 50 4D 41 5F 44 42 49 5F 66 65 74 63
68 5F 76 61 6C 75 65 28 20 27 53 48 4F 57 20 56 41 52 49 41 42 4C 45 53
20 4C 49 4B 45 20 5C 27 74 61 62 6C 65 5F 74 79 70 65 5C 27 3B 27 2C 20
30 2C 20 31 20 29 3B 0A 20 20 20 20 7D 0A 7D 0A 0A 3F 3E 0A
<?php /* $Id: database_i
nterface.lib.php,v 2.39.
2.2 2006/03/08 17:54:29 
lem9 Exp $ */ // vim: ex
pandtab sw=4 ts=4 sts=4:
  /**  * Common Option C
onstants For DBI Functio
ns  */ // PMA_DBI_try_qu
ery() define('PMA_DBI_QU
ERY_STORE',       1);  /
/ Force STORE_RESULT met
hod, ignored by classic 
MySQL. define('PMA_DBI_Q
UERY_UNBUFFERED',  2);  
// Do not read whole que
ry // PMA_DBI_get_variab
le() define('PMA_DBI_GET
VAR_SESSION', 1); define
('PMA_DBI_GETVAR_GLOBAL'
, 2);  /**  * Loads the 
mysql extensions if it i
s not loaded yet  *  * @
param   string  $extensi
on  mysql extension to l
oad  */ function PMA_DBI
_checkAndLoadMysqlExtens
ion( $extension = 'mysql
' ) {     if ( ! functio
n_exists( $extension . '
_connect' ) ) {         
PMA_dl( $extension );   
      // check whether m
ysql is available       
  if ( ! function_exists
( $extension . '_connect
' ) ) {             retu
rn false;         }     
}      return true; }   
/**  * check for request
ed extension  */ if ( ! 
PMA_DBI_checkAndLoadMysq
lExtension( $GLOBALS['cf
g']['Server']['extension
'] ) ) {      // if it f
ails try alternative ext
ension ...     // and di
splay an error ...      
// TODO 2.7.1: add diffe
rent messages for altern
ativ extension     // an
d complete fail (no alte
rnativ extension too)   
  $GLOBALS['PMA_errors']
[] =         sprintf( PM
A_sanitize( $GLOBALS['st
rCantLoad'] ),          
   $GLOBALS['cfg']['Serv
er']['extension'] )     
    .' - <a href="./Docu
mentation.html#faqmysql"
 target="documentation">
'         .$GLOBALS['str
Docu'] . '</a>';      if
 ( $GLOBALS['cfg']['Serv
er']['extension'] === 'm
ysql' ) {         $alter
nativ_extension = 'mysql
i';     } else {        
 $alternativ_extension =
 'mysql';     }      if 
( ! PMA_DBI_checkAndLoad
MysqlExtension( $alterna
tiv_extension ) ) {     
    // if alternativ fai
ls too ...         heade
r( 'Location: error.php'
                 . '?lan
g='  . urlencode( $avail
able_languages[$lang][2]
 )                 . '&c
har='  . urlencode( $cha
rset )                 .
 '&dir='   . urlencode( 
$text_dir )             
    . '&type='  . urlenc
ode( $strError )        
         . '&error=' . u
rlencode(               
      sprintf( $GLOBALS[
'strCantLoad'],         
                $GLOBALS
['cfg']['Server']['exten
sion'] )                
     .' - [a@./Documenta
tion.html#faqmysql@docum
entation]'              
       .$GLOBALS['strDoc
u'] . '[/a]' )          
       . '&' . SID      
            );         e
xit();     }      $GLOBA
LS['cfg']['Server']['ext
ension'] = $alternativ_e
xtension;     unset( $al
ternativ_extension ); } 
 /**  * Including The DB
I Plugin  */ require_onc
e('./libraries/dbi/' . $
GLOBALS['cfg']['Server']
['extension'] . '.dbi.li
b.php');  /**  * Common 
Functions  */ function P
MA_DBI_query($query, $li
nk = null, $options = 0)
 {     $res = PMA_DBI_tr
y_query($query, $link, $
options)         or PMA_
mysqlDie(PMA_DBI_getErro
r($link), $query);     r
eturn $res; }  /**  * co
nverts charset of a mysq
l message, usally coming
 from mysql_error(),  * 
into PMA charset, usally
 UTF-8  * uses language 
to charset mapping from 
mysql/share/errmsg.txt  
* and charset names to I
SO charset from informat
ion_schema.CHARACTER_SET
S  *  * @uses    $GLOBAL
S['cfg']['IconvExtraPara
ms']  * @uses    $GLOBAL
S['charset']     as targ
et charset  * @uses    P
MA_DBI_fetch_value()   t
o get server_language  *
 @uses    preg_match()  
          to filter serv
er_language  * @uses    
in_array()  * @uses    f
unction_exists()       t
o check for a convert fu
nction  * @uses    iconv
()                 to co
nvert message  * @uses  
  libiconv()            
  to convert message  * 
@uses    recode_string()
         to convert mess
age  * @uses    mb_conve
rt_encoding()   to conve
rt message  * @param   s
tring  $message  * @retu
rn  string  $message  */
 function PMA_DBI_conver
t_message( $message ) { 
    // latin always last
!     $encodings = array
(         'japanese'    
  => 'EUC-JP', //'ujis',
         'japanese-sjis'
 => 'Shift-JIS', //'sjis
',         'korean'     
   => 'EUC-KR', //'euckr
',         'russian'    
   => 'KOI8-R', //'koi8r
',         'ukrainian'  
   => 'KOI8-U', //'koi8u
',         'greek'      
   => 'ISO-8859-7', //'g
reek',         'serbian'
       => 'CP1250', //'c
p1250',         'estonia
n'      => 'ISO-8859-13'
, //'latin7',         's
lovak'        => 'ISO-88
59-2', //'latin2',      
   'czech'         => 'I
SO-8859-2', //'latin2', 
        'hungarian'     
=> 'ISO-8859-2', //'lati
n2',         'polish'   
     => 'ISO-8859-2', //
'latin2',         'roman
ian'      => 'ISO-8859-2
', //'latin2',         '
spanish'       => 'CP125
2', //'latin1',         
'swedish'       => 'CP12
52', //'latin1',        
 'italian'       => 'CP1
252', //'latin1',       
  'norwegian-ny'  => 'CP
1252', //'latin1',      
   'norwegian'     => 'C
P1252', //'latin1',     
    'portuguese'    => '
CP1252', //'latin1',    
     'danish'        => 
'CP1252', //'latin1',   
      'dutch'         =>
 'CP1252', //'latin1',  
       'english'       =
> 'CP1252', //'latin1', 
        'french'        
=> 'CP1252', //'latin1',
         'german'       
 => 'CP1252', //'latin1'
,     );      if ( $serv
er_language = PMA_DBI_fe
tch_value( 'SHOW VARIABL
ES LIKE \'language\';', 
0, 1 ) ) {         $foun
d = array();         if 
( preg_match( '&(?:\\\|\
\/)([^\\\\\/]*)(?:\\\|\\
/)$&i', $server_language
, $found )) {           
  $server_language = $fo
und[1];         }     } 
     if ( ! empty( $serv
er_language ) && isset( 
$encodings[$server_langu
age] ) ) {         if ( 
function_exists( 'iconv'
 ) ) {             $mess
age = iconv( $encodings[
$server_language],      
           $GLOBALS['cha
rset'] . $GLOBALS['cfg']
['IconvExtraParams'], $m
essage);         } elsei
f ( function_exists( 're
code_string' ) ) {      
       $message = recode
_string( $encodings[$ser
ver_language] . '..'  . 
$GLOBALS['charset'],    
             $message );
         } elseif ( func
tion_exists( 'libiconv' 
) ) {             $messa
ge = libiconv( $encoding
s[$server_language], $GL
OBALS['charset'], $messa
ge );         } elseif (
 function_exists( 'mb_co
nvert_encoding' ) ) {   
          // do not try 
unsupported charsets    
         if ( ! in_array
( $server_language, arra
y( 'ukrainian', 'greek',
 'serbian' ) ) ) {      
           $message = mb
_convert_encoding( $mess
age, $GLOBALS['charset']
,                     $e
ncodings[$server_languag
e] );             }     
    }     } else {      
   // lang not found, tr
y all         // what TO
DO ?     }      return $
message; }  /**  * retur
ns array with database n
ames  *  * @return  arra
y   $databases  */ funct
ion PMA_DBI_get_dblist($
link = null) {     $dbs_
array = PMA_DBI_fetch_re
sult('SHOW DATABASES;', 
$link);      // Before M
ySQL 4.0.2, SHOW DATABAS
ES could send the     //
 whole list, so check if
 we really have access: 
    if (PMA_MYSQL_INT_VE
RSION < 40002 || !empty(
$GLOBALS['cfg']['Server'
]['hide_db'])) {        
 foreach ($dbs_array as 
$key => $db) {          
   if (!@PMA_DBI_select_
db($db, $link) || (!empt
y($GLOBALS['cfg']['Serve
r']['hide_db']) && preg_
match('/' . $GLOBALS['cf
g']['Server']['hide_db']
 . '/', $db))) {        
         unset( $dbs_arr
ay[$key] );             
}         }         // r
e-index values         $
dbs_array = array_values
( $dbs_array );     }   
   return $dbs_array; } 
 /**  * returns array wi
th table names for given
 db  *  * @param   strin
g  $database   name of d
atabase  * @param   mixe
d   $link       mysql li
nk resource|object  * @r
eturn  array   tables na
mes  */ function PMA_DBI
_get_tables($database, $
link = null) {     retur
n PMA_DBI_fetch_result('
SHOW TABLES FROM ' . PMA
_backquote($database) . 
';',         null, 0, $l
ink, PMA_DBI_QUERY_STORE
); }  /**  * returns arr
ay of all tables in give
n db or dbs  * this func
tion expects unqoted nam
es:  * RIGHT: my_databas
e  * WRONG: `my_database
`  * WRONG: my\_database
  * if $tbl_is_group is 
true, $table is used as 
filter for table names  
* if $tbl_is_group is 'c
omment, $table is used a
s filter for table comme
nts  *  * <code>  * PMA_
DBI_get_tables_full( 'my
_database' );  * PMA_DBI
_get_tables_full( 'my_da
tabase', 'my_table' ) );
  * PMA_DBI_get_tables_f
ull( 'my_database', 'my_
tables_', true ) );  * P
MA_DBI_get_tables_full( 
'my_database', 'my_table
s_', 'comment' ) );  * <
/code>  *  * @uses    PM
A_MYSQL_INT_VERSION  * @
uses    PMA_DBI_fetch_re
sult()  * @uses    PMA_e
scape_mysql_wildcards() 
 * @uses    PMA_backquot
e()  * @uses    is_array
()  * @uses    addslashe
s()  * @uses    strpos()
  * @uses    strtoupper(
)  * @param   string    
      $databases      da
tabase  * @param   strin
g          $table       
   table  * @param   boo
lean|string  $tbl_is_gro
up   $table is a table g
roup  * @param   resourc
e        $link          
 mysql link  * @return  
array           list of 
tbales in given db(s)  *
/ function PMA_DBI_get_t
ables_full($database, $t
able = false,     $tbl_i
s_group = false, $link =
 null) {     // prepare 
and check parameters    
 if ( ! is_array($databa
se) ) {         $databas
es = array(addslashes($d
atabase));     } else { 
        $databases = arr
ay_map('addslashes', $da
tabase);     }      $tab
les = array();      if (
 PMA_MYSQL_INT_VERSION >
= 50002 ) {         // g
et table information fro
m information_schema    
     if ( $table ) {    
         if ( true === $
tbl_is_group ) {        
         $sql_where_tabl
e = 'AND `TABLE_NAME` LI
KE \''                  
   . PMA_escape_mysql_wi
ldcards(addslashes($tabl
e)) . '%\'';            
 } elseif ( 'comment' ==
= $tbl_is_group ) {     
            $sql_where_t
able = 'AND `TABLE_COMME
NT` LIKE \''            
         . PMA_escape_my
sql_wildcards(addslashes
($table)) . '%\'';      
       } else {         
        $sql_where_table
 = 'AND `TABLE_NAME` = \
'' . addslashes($table) 
. '\'';             }   
      } else {          
   $sql_where_table = ''
;         }          // 
for PMA bc:         // `
SCHEMA_FIELD_NAME` AS `S
HOW_TABLE_STATUS_FIELD_N
AME`         $sql = '   
           SELECT *,    
                 `TABLE_
SCHEMA`       AS `Db`,  
                   `TABL
E_NAME`         AS `Name
`,                     `
ENGINE`             AS `
Engine`,                
     `ENGINE`           
  AS `Type`,            
         `VERSION`      
      AS `Version`,     
                `ROW_FOR
MAT`         AS `Row_for
mat`,                   
  `TABLE_ROWS`         A
S `Rows`,               
      `AVG_ROW_LENGTH`  
   AS `Avg_row_length`, 
                    `DAT
A_LENGTH`        AS `Dat
a_length`,              
       `MAX_DATA_LENGTH`
    AS `Max_data_length`
,                     `I
NDEX_LENGTH`       AS `I
ndex_length`,           
          `DATA_FREE`   
       AS `Data_free`,  
                   `AUTO
_INCREMENT`     AS `Auto
_increment`,            
         `CREATE_TIME`  
      AS `Create_time`, 
                    `UPD
ATE_TIME`        AS `Upd
ate_time`,              
       `CHECK_TIME`     
    AS `Check_time`,    
                 `TABLE_
COLLATION`    AS `Collat
ion`,                   
  `CHECKSUM`           A
S `Checksum`,           
          `CREATE_OPTION
S`     AS `Create_option
s`,                     
`TABLE_COMMENT`      AS 
`Comment`               
 FROM `information_schem
a`.`TABLES`             
  WHERE `TABLE_SCHEMA` I
N (\'' . implode("', '",
 $databases) . '\')     
            ' . $sql_whe
re_table;         $table
s = PMA_DBI_fetch_result
($sql, array('TABLE_SCHE
MA', 'TABLE_NAME'),     
        null, $link);   
      unset( $sql_where_
table, $sql );     } els
e {         foreach ( $d
atabases as $each_databa
se ) {             if ( 
true === $tbl_is_group )
 {                 $sql 
= 'SHOW TABLE STATUS FRO
M '                     
. PMA_backquote($each_da
tabase)                 
    .' LIKE \'' . PMA_es
cape_mysql_wildcards(add
slashes($table)) . '%\''
;             } else {  
               $sql = 'S
HOW TABLE STATUS FROM ' 
                    . PM
A_backquote($each_databa
se) . ';';             }
             $each_table
s = PMA_DBI_fetch_result
($sql, 'Name', null, $li
nk);             foreach
 ( $each_tables as $tabl
e_name => $each_table ) 
{                 if ( '
comment' === $tbl_is_gro
up                   && 
0 === strpos($each_table
['Comment'], $table) )  
               {        
             // remove t
able from list          
           unset( $each_
tables[$table_name] );  
                   conti
nue;                 }  
                if ( ! i
sset( $each_tables[$tabl
e_name]['Type'] )       
            && isset( $e
ach_tables[$table_name][
'Engine'] ) ) {         
            // pma BC, s
ame parts of PMA still u
ses 'Type'              
       $each_tables[$tab
le_name]['Type']        
                 =& $eac
h_tables[$table_name]['E
ngine'];                
 } elseif ( ! isset( $ea
ch_tables[$table_name]['
Engine'] )              
     && isset( $each_tab
les[$table_name]['Type']
 ) ) {                  
   // old MySQL reports 
Type, newer MySQL report
s Engine                
     $each_tables[$table
_name]['Engine']        
                 =& $eac
h_tables[$table_name]['T
ype'];                 }
                  // MyS
QL forward compatibility
                 // so p
ma could use this array 
as if every server is of
 version >5.0           
      $each_tables[$tabl
e_name]['TABLE_SCHEMA'] 
     = $each_database;  
               $each_tab
les[$table_name]['TABLE_
NAME']        =& $each_t
ables[$table_name]['Name
'];                 $eac
h_tables[$table_name]['E
NGINE']            =& $e
ach_tables[$table_name][
'Engine'];              
   $each_tables[$table_n
ame]['VERSION']         
  =& $each_tables[$table
_name]['Version'];      
           $each_tables[
$table_name]['ROW_FORMAT
']        =& $each_table
s[$table_name]['Row_form
at'];                 $e
ach_tables[$table_name][
'TABLE_ROWS']        =& 
$each_tables[$table_name
]['Rows'];              
   $each_tables[$table_n
ame]['AVG_ROW_LENGTH']  
  =& $each_tables[$table
_name]['Avg_row_length']
;                 $each_
tables[$table_name]['DAT
A_LENGTH']       =& $eac
h_tables[$table_name]['D
ata_length'];           
      $each_tables[$tabl
e_name]['MAX_DATA_LENGTH
']   =& $each_tables[$ta
ble_name]['Max_data_leng
th'];                 $e
ach_tables[$table_name][
'INDEX_LENGTH']      =& 
$each_tables[$table_name
]['Index_length'];      
           $each_tables[
$table_name]['DATA_FREE'
]         =& $each_table
s[$table_name]['Data_fre
e'];                 $ea
ch_tables[$table_name]['
AUTO_INCREMENT']    =& $
each_tables[$table_name]
['Auto_increment'];     
            $each_tables
[$table_name]['CREATE_TI
ME']       =& $each_tabl
es[$table_name]['Create_
time'];                 
$each_tables[$table_name
]['UPDATE_TIME']       =
& $each_tables[$table_na
me]['Update_time'];     
            $each_tables
[$table_name]['CHECK_TIM
E']        =& $each_tabl
es[$table_name]['Check_t
ime'];                 $
each_tables[$table_name]
['TABLE_COLLATION']   =&
 $each_tables[$table_nam
e]['Collation'];        
         $each_tables[$t
able_name]['CHECKSUM']  
        =& $each_tables[
$table_name]['Checksum']
;                 $each_
tables[$table_name]['CRE
ATE_OPTIONS']    =& $eac
h_tables[$table_name]['C
reate_options'];        
         $each_tables[$t
able_name]['TABLE_COMMEN
T']     =& $each_tables[
$table_name]['Comment'];
                  if ( s
trtoupper( $each_tables[
$table_name]['Comment'] 
) === 'VIEW' ) {        
             $each_table
s[$table_name]['TABLE_TY
PE'] = 'VIEW';          
       } else {         
            // TODO diff
erence between 'TEMPORAR
Y' and 'BASE TABLE'     
                // but h
ow to detect?           
          $each_tables[$
table_name]['TABLE_TYPE'
] = 'BASE TABLE';       
          }             
}              $tables[$
each_database] = $each_t
ables;         }     }  
    if ( $GLOBALS['cfg']
['NaturalOrder'] ) {    
     foreach ( $tables a
s $key => $val ) {      
       uksort($tables[$k
ey], 'strnatcasecmp');  
       }     }      if (
! is_array($database)) {
         if (isset($tabl
es[$database])) {       
      return $tables[$da
tabase];         } elsei
f (isset($tables[strtolo
wer($database)])) {     
        // on windows wi
th lower_case_table_name
s = 1             // MyS
QL returns             /
/ with SHOW DATABASES or
 information_schema.SCHE
MATA: `Test`            
 // but information_sche
ma.TABLES gives `test`  
           // bug #14361
71             // sf.net
/tracker/?func=detail&ai
d=1436171&group_id=23067
&atid=377408            
 return $tables[strtolow
er($database)];         
} else {             ret
urn $tables;         }  
   } else {         retu
rn $tables;     } }  /**
  * returns array with d
atabases containing exte
nded infos about them  *
  * @param   string     
     $databases      dat
abase  * @param   boolea
n         $force_stats  
  retrieve stats also fo
r MySQL < 5  * @param   
resource        $link   
        mysql link  * @r
eturn  array       $data
bases  */ function PMA_D
BI_get_databases_full( $
database = null, $force_
stats = false, $link = n
ull ) {      // initiali
ze to avoid errors when 
there are no databases  
   $databases = array();
      if ( PMA_MYSQL_INT
_VERSION >= 50002 ) {   
      // get table infor
mation from information_
schema         if ( $dat
abase ) {             $s
ql_where_schema = 'WHERE
 `SCHEMA_NAME` LIKE \'' 
                . addsla
shes( $database ) . '\''
;         } else {      
       $sql_where_schema
 = '';         }        
  // for PMA bc:        
 // `SCHEMA_FIELD_NAME` 
AS `SHOW_TABLE_STATUS_FI
ELD_NAME`         $sql =
 '              SELECT `
information_schema`.`SCH
EMATA`.*,               
      COUNT(`information
_schema`.`TABLES`.`TABLE
_SCHEMA`)               
          AS `SCHEMA_TAB
LES`,                   
  SUM(`information_schem
a`.`TABLES`.`TABLE_ROWS`
)                       
  AS `SCHEMA_TABLE_ROWS`
,                     SU
M(`information_schema`.`
TABLES`.`DATA_LENGTH`)  
                       A
S `SCHEMA_DATA_LENGTH`, 
                    SUM(
`information_schema`.`TA
BLES`.`MAX_DATA_LENGTH`)
                        
 AS `SCHEMA_MAX_DATA_LEN
GTH`,                   
  SUM(`information_schem
a`.`TABLES`.`INDEX_LENGT
H`)                     
    AS `SCHEMA_INDEX_LEN
GTH`,                   
  SUM(`information_schem
a`.`TABLES`.`DATA_LENGTH
`                       
+ `information_schema`.`
TABLES`.`INDEX_LENGTH`) 
                        
AS `SCHEMA_LENGTH`,     
                SUM(`inf
ormation_schema`.`TABLES
`.`DATA_FREE`)          
               AS `SCHEM
A_DATA_FREE`            
    FROM `information_sc
hema`.`SCHEMATA`        
   LEFT JOIN `informatio
n_schema`.`TABLES`      
            ON `informat
ion_schema`.`TABLES`.`TA
BLE_SCHEMA`             
      = `information_sch
ema`.`SCHEMATA`.`SCHEMA_
NAME`               ' . 
$sql_where_schema . '   
         GROUP BY `infor
mation_schema`.`SCHEMATA
`.`SCHEMA_NAME`';       
  $databases = PMA_DBI_f
etch_result( $sql, 'SCHE
MA_NAME', null, $link );
         unset( $sql_whe
re_schema, $sql );     }
 else {         foreach 
( PMA_DBI_get_dblist( $l
ink ) as $database_name 
) {             // MySQL
 forward compatibility  
           // so pma cou
ld use this array as if 
every server is of versi
on >5.0             $dat
abases[$database_name]['
SCHEMA_NAME']      = $da
tabase_name;            
  if ( $force_stats ) { 
                require_
once 'mysql_charsets.lib
.php';                  
$databases[$database_nam
e]['DEFAULT_COLLATION_NA
ME']                    
 = PMA_getDbCollation( $
database_name );        
          // get additon
al info about tables    
             $databases[
$database_name]['SCHEMA_
TABLES']          = 0;  
               $database
s[$database_name]['SCHEM
A_TABLE_ROWS']      = 0;
                 $databa
ses[$database_name]['SCH
EMA_DATA_LENGTH']     = 
0;                 $data
bases[$database_name]['S
CHEMA_MAX_DATA_LENGTH'] 
= 0;                 $da
tabases[$database_name][
'SCHEMA_INDEX_LENGTH']  
  = 0;                 $
databases[$database_name
]['SCHEMA_LENGTH']      
    = 0;                
 $databases[$database_na
me]['SCHEMA_DATA_FREE'] 
      = 0;              
    $res = PMA_DBI_query
('SHOW TABLE STATUS FROM
 ' . PMA_backquote( $dat
abase_name ) . ';');    
             while ( $ro
w = PMA_DBI_fetch_assoc(
 $res ) ) {             
        $databases[$data
base_name]['SCHEMA_TABLE
S']++;                  
   $databases[$database_
name]['SCHEMA_TABLE_ROWS
']                      
   += $row['Rows'];     
                $databas
es[$database_name]['SCHE
MA_DATA_LENGTH']        
                 += $row
['Data_length'];        
             $databases[
$database_name]['SCHEMA_
MAX_DATA_LENGTH']       
                  += $ro
w['Max_data_length'];   
                  $datab
ases[$database_name]['SC
HEMA_INDEX_LENGTH']     
                    += $
row['Index_length'];    
                 $databa
ses[$database_name]['SCH
EMA_DATA_FREE']         
                += $row[
'Data_free'];           
          $databases[$da
tabase_name]['SCHEMA_LEN
GTH']                   
      += $row['Data_leng
th'] + $row['Index_lengt
h'];                 }  
               PMA_DBI_f
ree_result( $res );     
            unset( $res 
);             }        
 }     }      if ( $GLOB
ALS['cfg']['NaturalOrder
'] ) {         uksort( $
databases, 'strnatcasecm
p' );     }      return 
$databases; }  /**  * re
turns detailed array wit
h all columns for given 
table in database,  * or
 all tables/databases  *
  * @param   string  $da
tabase   name of databas
e  * @param   string  $t
able      name of table 
to retrieve columns from
  * @param   string  $co
lumn     name of specifi
c column  * @param   mix
ed   $link       mysql l
ink resource  */ functio
n PMA_DBI_get_columns_fu
ll($database = null, $ta
ble = null,     $column 
= null, $link = null) { 
    $columns = array(); 
     if ( PMA_MYSQL_INT_
VERSION >= 50002 ) {    
     $sql_wheres = array
();         $array_keys 
= array();          // g
et columns information f
rom information_schema  
       if ( null !== $da
tabase ) {             $
sql_wheres[] = '`TABLE_S
CHEMA` = \'' . addslashe
s($database) . '\' ';   
      } else {          
   $array_keys[] = 'TABL
E_SCHEMA';         }    
     if (  null !== $tab
le ) {             $sql_
wheres[] = '`TABLE_NAME`
 = \'' . addslashes($tab
le) . '\' ';         } e
lse {             $array
_keys[] = 'TABLE_NAME'; 
        }         if (  
null !== $column ) {    
         $sql_wheres[] =
 '`COLUMN_NAME` = \'' . 
addslashes($column) . '\
' ';         } else {   
          $array_keys[] 
= 'COLUMN_NAME';        
 }          // for PMA b
c:         // `[SCHEMA_F
IELD_NAME]` AS `[SHOW_FU
LL_COLUMNS_FIELD_NAME]` 
        $sql = '        
      SELECT *,         
            `COLUMN_NAME
`       AS `Field`,     
                `COLUMN_
TYPE`       AS `Type`,  
                   `COLL
ATION_NAME`    AS `Colla
tion`,                  
   `IS_NULLABLE`       A
S `Null`,               
      `COLUMN_KEY`      
  AS `Key`,             
        `COLUMN_DEFAULT`
    AS `Default`,       
              `EXTRA`   
          AS `Extra`,   
                  `PRIVI
LEGES`        AS `Privil
eges`,                  
   `COLUMN_COMMENT`    A
S `Comment`             
   FROM `information_sch
ema`.`COLUMNS`';        
 if ( count($sql_wheres)
 ) {             $sql .=
 "\n" . ' WHERE ' . impl
ode(' AND ', $sql_wheres
);         }          $c
olumns = PMA_DBI_fetch_r
esult($sql, $array_keys,
 null, $link);         u
nset( $sql_wheres, $sql 
);     } else {         
if ( null === $database 
) {             $databas
es = PMA_DBI_get_dblist(
);             foreach (
 $databases as $database
 ) {                 $co
lumns[$database] = PMA_D
BI_get_columns_full($dat
abase, null,            
         null, $link);  
           }            
 return $columns;       
  } elseif ( null === $t
able ) {             $ta
bles = PMA_DBI_get_table
s($database);           
  foreach ( $tables as $
table ) {               
  $columns[$table] = PMA
_DBI_get_columns_full(  
                   $data
base, $table, null, $lin
k);             }       
      return $columns;  
       }          $sql =
 'SHOW FULL COLUMNS FROM
 '             . PMA_bac
kquote($database) . '.' 
. PMA_backquote($table);
         if ( null !== $
column ) {             $
sql .= " LIKE '" . $colu
mn . "'";         }     
     $columns = PMA_DBI_
fetch_result( $sql, 'Fie
ld', null, $link );     
     $ordinal_position =
 1;         foreach ( $c
olumns as $column_name =
> $each_column ) {      
        // MySQL forward
 compatibility          
   // so pma could use t
his array as if every se
rver is of version >5.0 
            $columns[$co
lumn_name]['COLUMN_NAME'
]                 =& $co
lumns[$column_name]['Fie
ld'];             $colum
ns[$column_name]['COLUMN
_TYPE']                 
=& $columns[$column_name
]['Type'];             $
columns[$column_name]['C
OLLATION_NAME']         
     =& $columns[$column
_name]['Collation'];    
         $columns[$colum
n_name]['IS_NULLABLE']  
               =& $colum
ns[$column_name]['Null']
;             $columns[$
column_name]['COLUMN_KEY
']                  =& $
columns[$column_name]['K
ey'];             $colum
ns[$column_name]['COLUMN
_DEFAULT']              
=& $columns[$column_name
]['Default'];           
  $columns[$column_name]
['EXTRA']               
        =& $columns[$col
umn_name]['Extra'];     
        $columns[$column
_name]['PRIVILEGES']    
              =& $column
s[$column_name]['Privile
ges'];             $colu
mns[$column_name]['COLUM
N_COMMENT']             
 =& $columns[$column_nam
e]['Comment'];          
    $columns[$column_nam
e]['TABLE_CATALOG']     
          = null;       
      $columns[$column_n
ame]['TABLE_SCHEMA']    
            = $database;
             $columns[$c
olumn_name]['TABLE_NAME'
]                  = $ta
ble;             $column
s[$column_name]['ORDINAL
_POSITION']            =
 $ordinal_position;     
        $columns[$column
_name]['DATA_TYPE']     
              =         
        substr($columns[
$column_name]['COLUMN_TY
PE'], 0,                
     strpos($columns[$co
lumn_name]['COLUMN_TYPE'
], '('));             //
 @TODO guess CHARACTER_M
AXIMUM_LENGTH from COLUM
N_TYPE             $colu
mns[$column_name]['CHARA
CTER_MAXIMUM_LENGTH']   
 = null;             // 
@TODO guess CHARACTER_OC
TET_LENGTH from CHARACTE
R_MAXIMUM_LENGTH        
     $columns[$column_na
me]['CHARACTER_OCTET_LEN
GTH']      = null;      
       $columns[$column_
name]['NUMERIC_PRECISION
']           = null;    
         $columns[$colum
n_name]['NUMERIC_SCALE']
               = null;  
           $columns[$col
umn_name]['CHARACTER_SET
_NAME']          =      
           substr($colum
ns[$column_name]['COLLAT
ION_NAME'], 0,          
           strpos($colum
ns[$column_name]['COLLAT
ION_NAME'], '_'));      
        $ordinal_positio
n++;         }          
if ( null !== $column ) 
{             reset($col
umns);             $colu
mns = current($columns);
         }     }      re
turn $columns; }  /**  *
 @TODO should only retur
n columns names, for mor
e info use PMA_DBI_get_c
olumns_full()  *  * @par
am   string  $database  
 name of database  * @pa
ram   string  $table    
  name of table to retri
eve columns from  * @par
am   mixed   $link      
 mysql link resource  */
 function PMA_DBI_get_fi
elds($database, $table, 
$link = null) {     // h
ere we use a try_query b
ecause when coming from 
    // tbl_create + tbl_
properties.inc.php, the 
table does not exist    
 $fields = PMA_DBI_fetch
_result(         'SHOW F
ULL COLUMNS         FROM
 ' . PMA_backquote($data
base) . '.' . PMA_backqu
ote($table),         nul
l, null, $link);     if 
( ! is_array($fields) ||
 count($fields) < 1 ) { 
        return false;   
  }     return $fields; 
}  /**  * returns value 
of given mysql server va
riable  *  * @param   st
ring  $var    mysql serv
er variable name  * @par
am   int     $type   PMA
_DBI_GETVAR_SESSION|PMA_
DBI_GETVAR_GLOBAL  * @pa
ram   mixed   $link   my
sql link resource|object
  * @return  mixed   val
ue for mysql server vari
able  */ function PMA_DB
I_get_variable($var, $ty
pe = PMA_DBI_GETVAR_SESS
ION, $link = null) {    
 if ($link === null) {  
       if (isset($GLOBAL
S['userlink'])) {       
      $link = $GLOBALS['
userlink'];         } el
se {             return 
false;         }     }  
   if (PMA_MYSQL_INT_VER
SION < 40002) {         
$type = 0;     }     swi
tch ($type) {         ca
se PMA_DBI_GETVAR_SESSIO
N:             $modifier
 = ' SESSION';          
   break;         case P
MA_DBI_GETVAR_GLOBAL:   
          $modifier = ' 
GLOBAL';             bre
ak;         default:    
         $modifier = '';
     }     return PMA_DB
I_fetch_value(         '
SHOW' . $modifier . ' VA
RIABLES LIKE \'' . $var 
. '\';', 0, 1, $link); }
  /**  * @uses    ./libr
aries/charset_conversion
.lib.php  * @uses    PMA
_DBI_QUERY_STORE  * @use
s    PMA_REMOVED_NON_UTF
_8  * @uses    PMA_MYSQL
_INT_VERSION  * @uses   
 PMA_MYSQL_STR_VERSION  
* @uses    PMA_DBI_GETVA
R_SESSION  * @uses    PM
A_DBI_fetch_value()  * @
uses    PMA_DBI_query() 
 * @uses    PMA_DBI_get_
variable()  * @uses    $
GLOBALS['collation_conne
ction']  * @uses    $GLO
BALS['charset_connection
']  * @uses    $GLOBALS[
'available_languages']  
* @uses    $GLOBALS['mys
ql_charset_map']  * @use
s    $GLOBALS['charset']
  * @uses    $GLOBALS['l
ang']  * @uses    $GLOBA
LS['cfg']['Lang']  * @us
es    $GLOBALS['cfg']['C
olumnTypes']  * @uses   
 defined()  * @uses    e
xplode()  * @uses    spr
intf()  * @uses    intva
l()  * @uses    define()
  * @uses    defined()  
* @uses    substr()  * @
uses    count()  * @para
m   mixed   $link   mysq
l link resource|object  
* @param   boolean $is_c
ontroluser  */ function 
PMA_DBI_postConnect($lin
k, $is_controluser = fal
se) {     if (!defined('
PMA_MYSQL_INT_VERSION'))
 {         $mysql_versio
n = PMA_DBI_fetch_value(
             'SELECT VER
SION()', 0, 0, $link, PM
A_DBI_QUERY_STORE);     
    if ( $mysql_version 
) {             $match =
 explode('.', $mysql_ver
sion);             defin
e('PMA_MYSQL_INT_VERSION
',                 (int)
 sprintf('%d%02d%02d', $
match[0], $match[1],    
                     int
val($match[2])));       
      define('PMA_MYSQL_
STR_VERSION', $mysql_ver
sion);             unset
($mysql_version, $match)
;         } else {      
       define('PMA_MYSQL
_INT_VERSION', 32332);  
           define('PMA_M
YSQL_STR_VERSION', '3.23
.32');         }     }  
    if (!defined('PMA_EN
GINE_KEYWORD')) {       
  if (PMA_MYSQL_INT_VERS
ION >= 40102) {         
    define('PMA_ENGINE_K
EYWORD','ENGINE');      
   } else {             
define('PMA_ENGINE_KEYWO
RD','TYPE');         }  
   }      if (PMA_MYSQL_
INT_VERSION >= 40100) { 
         // If $lang is 
defined and we are on My
SQL >= 4.1.x,         //
 we auto-switch the lang
 to its UTF-8 version (i
f it exists and user    
     // didn't force lan
guage)         if ( !emp
ty($GLOBALS['lang'])    
       && (substr($GLOBA
LS['lang'], -5) != 'utf-
8')           && !isset(
$GLOBALS['cfg']['Lang'])
 ) {             $lang_u
tf_8_version =          
       substr($GLOBALS['
lang'], 0, strpos($GLOBA
LS['lang'], '-'))       
          . '-utf-8';   
          if (!empty($GL
OBALS['available_languag
es'][$lang_utf_8_version
])) {                 $G
LOBALS['lang'] = $lang_u
tf_8_version;           
      $GLOBALS['charset'
] = 'utf-8';            
 }         }          //
 and we remove the non-U
TF-8 choices to avoid co
nfusion         if (!def
ined('PMA_REMOVED_NON_UT
F_8')) {             for
each ( $GLOBALS['availab
le_languages'] as $each_
lang => $dummy ) {      
           if ( substr($
each_lang, -5) != 'utf-8
' ) {                   
  unset( $GLOBALS['avail
able_languages'][$each_l
ang] );                 
}             }         
    define('PMA_REMOVED_
NON_UTF_8', 1);         
}          $mysql_charse
t = $GLOBALS['mysql_char
set_map'][$GLOBALS['char
set']];         if ( $is
_controluser           |
| empty($GLOBALS['collat
ion_connection'])       
    || (strpos($GLOBALS[
'collation_connection'],
 '_')                 ? 
substr($GLOBALS['collati
on_connection'], 0, strp
os($GLOBALS['collation_c
onnection'], '_'))      
           : $GLOBALS['c
ollation_connection']) =
= $mysql_charset) {     
         PMA_DBI_query('
SET NAMES ' . $mysql_cha
rset . ';', $link,      
           PMA_DBI_QUERY
_STORE);         } else 
{             PMA_DBI_qu
ery('SET CHARACTER SET '
 . $mysql_charset . ';',
 $link,                 
PMA_DBI_QUERY_STORE);   
      }         if (!emp
ty($GLOBALS['collation_c
onnection'])) {         
    PMA_DBI_query('SET c
ollation_connection = \'
' . $GLOBALS['collation_
connection'] . '\';',   
              $link, PMA
_DBI_QUERY_STORE);      
   }         if (!$is_co
ntroluser) {            
 $GLOBALS['collation_con
nection'] = PMA_DBI_get_
variable('collation_conn
ection',                
 PMA_DBI_GETVAR_SESSION,
 $link);             $GL
OBALS['charset_connectio
n']   = PMA_DBI_get_vari
able('character_set_conn
ection',                
 PMA_DBI_GETVAR_SESSION,
 $link);         }      
    // Add some field ty
pes to the list, this ne
eds to be done once per 
session!         if ($GL
OBALS['cfg']['ColumnType
s'][count($GLOBALS['cfg'
]['ColumnTypes']) - 1] !
= 'VARBINARY') {        
     $GLOBALS['cfg']['Co
lumnTypes'][] = 'BINARY'
;             $GLOBALS['
cfg']['ColumnTypes'][] =
 'VARBINARY';         } 
     } else {         re
quire_once('./libraries/
charset_conversion.lib.p
hp');     } }  /**  * re
turns a single value fro
m the given result or qu
ery,  * if the query or 
the result has more than
 one row or field  * the
 first field of the firs
t row is returned  *  * 
<code>  * $sql = 'SELECT
 `name` FROM `user` WHER
E `id` = 123';  * $user_
name = PMA_DBI_fetch_val
ue( $sql );  * // produc
es  * // $user_name = 'J
ohn Doe'  * </code>  *  
* @uses    is_string()  
* @uses    is_int()  * @
uses    PMA_DBI_try_quer
y()  * @uses    PMA_DBI_
num_rows()  * @uses    P
MA_DBI_fetch_row()  * @u
ses    PMA_DBI_fetch_ass
oc()  * @uses    PMA_DBI
_free_result()  * @param
   string|mysql_result $
result query or mysql re
sult  * @param   integer
             $row_number
 row to fetch the value 
from,  *                
                      st
arting at 0, with 0 beei
ng default  * @param   i
nteger|string      $fiel
d  field to fetch the va
lue from,  *            
                        
  starting at 0, with 0 
beeing default  * @param
   resource            $
link   mysql link  * @pa
ram   mixed             
  $options  * @return  m
ixed               value
 of first field in first
 row from result  *     
                        
 or false if not found  
*/ function PMA_DBI_fetc
h_value( $result, $row_n
umber = 0, $field = 0, $
link = null, $options = 
0 ) {     $value = false
;      if ( is_string( $
result ) ) {         $re
sult = PMA_DBI_try_query
( $result, $link, $optio
ns | PMA_DBI_QUERY_STORE
 );     }      // return
 false if result is empt
y or false     // or req
uested row is larger tha
n rows in result     if 
( PMA_DBI_num_rows( $res
ult ) < ( $row_number + 
1 ) ) {         return $
value;     }      // if 
$field is an integer use
 non associative mysql f
etch function     if ( i
s_int( $field ) ) {     
    $fetch_function = 'P
MA_DBI_fetch_row';     }
 else {         $fetch_f
unction = 'PMA_DBI_fetch
_assoc';     }      // g
et requested row     for
 ( $i = 0; $i <= $row_nu
mber; $i++ ) {         $
row = $fetch_function( $
result );     }     PMA_
DBI_free_result( $result
 );      // return reque
sted field     if ( isse
t( $row[$field] ) ) {   
      $value = $row[$fie
ld];     }     unset( $r
ow );      return $value
; }  /**  * returns only
 the first row from the 
result  *  * <code>  * $
sql = 'SELECT * FROM `us
er` WHERE `id` = 123';  
* $user = PMA_DBI_fetch_
single_row( $sql );  * /
/ produces  * // $user =
 array( 'id' => 123, 'na
me' => 'John Doe' )  * <
/code>  *  * @uses    is
_string()  * @uses    PM
A_DBI_try_query()  * @us
es    PMA_DBI_num_rows()
  * @uses    PMA_DBI_fet
ch_row()  * @uses    PMA
_DBI_fetch_assoc()  * @u
ses    PMA_DBI_fetch_arr
ay()  * @uses    PMA_DBI
_free_result()  * @param
   string|mysql_result $
result query or mysql re
sult  * @param   string 
             $type   NUM
|ASSOC|BOTH  *          
                        
    returned array shoul
d either numeric  *     
                        
         associativ or b
ooth  * @param   resourc
e            $link   mys
ql link  * @param   mixe
d               $options
  * @return  array|boole
an       first row from 
result  *               
               or false 
if result is empty  */ f
unction PMA_DBI_fetch_si
ngle_row( $result, $type
 = 'ASSOC', $link = null
, $options = 0 ) {     i
f ( is_string( $result )
 ) {         $result = P
MA_DBI_try_query( $resul
t, $link, $options | PMA
_DBI_QUERY_STORE );     
}      // return null if
 result is empty or fals
e     if ( ! PMA_DBI_num
_rows( $result ) ) {    
     return false;     }
      switch ( $type ) {
         case 'NUM' :   
          $fetch_functio
n = 'PMA_DBI_fetch_row';
             break;     
    case 'ASSOC' :      
       $fetch_function =
 'PMA_DBI_fetch_assoc'; 
            break;      
   case 'BOTH' :        
 default :             $
fetch_function = 'PMA_DB
I_fetch_array';         
    break;     }      $r
ow = $fetch_function( $r
esult );     PMA_DBI_fre
e_result( $result );    
 return $row; }  /**  * 
returns all rows in the 
resultset in one array  
*  * <code>  * $sql = 'S
ELECT * FROM `user`';  *
 $users = PMA_DBI_fetch_
result( $sql );  * // pr
oduces  * // $users[] = 
array( 'id' => 123, 'nam
e' => 'John Doe' )  *  *
 $sql = 'SELECT `id`, `n
ame` FROM `user`';  * $u
sers = PMA_DBI_fetch_res
ult( $sql, 'id' );  * //
 produces  * // $users['
123'] = array( 'id' => 1
23, 'name' => 'John Doe'
 )  *  * $sql = 'SELECT 
`id`, `name` FROM `user`
';  * $users = PMA_DBI_f
etch_result( $sql, 0 ); 
 * // produces  * // $us
ers['123'] = array( 0 =>
 123, 1 => 'John Doe' ) 
 *  * $sql = 'SELECT `id
`, `name` FROM `user`'; 
 * $users = PMA_DBI_fetc
h_result( $sql, 'id', 'n
ame' );  * // or  * $use
rs = PMA_DBI_fetch_resul
t( $sql, 0, 1 );  * // p
roduces  * // $users['12
3'] = 'John Doe'  *  * $
sql = 'SELECT `name` FRO
M `user`';  * $users = P
MA_DBI_fetch_result( $sq
l );  * // produces  * /
/ $users[] = 'John Doe' 
 * </code>  *  * @uses  
  is_string()  * @uses  
  is_int()  * @uses    P
MA_DBI_try_query()  * @u
ses    PMA_DBI_num_rows(
)  * @uses    PMA_DBI_nu
m_fields()  * @uses    P
MA_DBI_fetch_row()  * @u
ses    PMA_DBI_fetch_ass
oc()  * @uses    PMA_DBI
_free_result()  * @param
   string|mysql_result $
result query or mysql re
sult  * @param   string|
integer      $key    fie
ld-name or offset  *    
                        
          used as key fo
r array  * @param   stri
ng|integer      $value  
value-name or offset  * 
                        
             used as val
ue for array  * @param  
 resource            $li
nk   mysql link  * @para
m   mixed               
$options  * @return  arr
ay               resultr
ows or values indexed by
 $key  */ function PMA_D
BI_fetch_result( $result
, $key = null, $value = 
null,     $link = null, 
$options = 0 ) {     $re
sultrows = array();     
 if ( is_string($result)
 ) {         $result = P
MA_DBI_try_query($result
, $link, $options);     
}      // return empty a
rray if result is empty 
or false     if ( ! $res
ult ) {         return $
resultrows;     }      $
fetch_function = 'PMA_DB
I_fetch_assoc';      // 
no nested array if only 
one field is in result  
   if ( null === $key &&
 1 === PMA_DBI_num_field
s($result) ) {         $
value = 0;         $fetc
h_function = 'PMA_DBI_fe
tch_row';     }      // 
if $key is an integer us
e non associative mysql 
fetch function     if ( 
is_int($key) ) {        
 $fetch_function = 'PMA_
DBI_fetch_row';     }   
   if ( null === $key &&
 null === $value ) {    
     while ( $row = $fet
ch_function($result) ) {
             $resultrows
[] = $row;         }    
 } elseif ( null === $ke
y ) {         while ( $r
ow = $fetch_function($re
sult) ) {             $r
esultrows[] = $row[$valu
e];         }     } else
if ( null === $value ) {
         if ( is_array($
key) ) {             whi
le ( $row = $fetch_funct
ion($result) ) {        
         $result_target 
=& $resultrows;         
        foreach ( $key a
s $key_index ) {        
             if ( ! isse
t( $result_target[$row[$
key_index]] ) ) {       
                  $resul
t_target[$row[$key_index
]] = array();           
          }             
        $result_target =
& $result_target[$row[$k
ey_index]];             
    }                 $r
esult_target = $row;    
         }         } els
e {             while ( 
$row = $fetch_function($
result) ) {             
    $resultrows[$row[$ke
y]] = $row;             
}         }     } else {
         if ( is_array($
key) ) {             whi
le ( $row = $fetch_funct
ion($result) ) {        
         $result_target 
=& $resultrows;         
        foreach ( $key a
s $key_index ) {        
             if ( ! isse
t( $result_target[$row[$
key_index]] ) ) {       
                  $resul
t_target[$row[$key_index
]] = array();           
          }             
        $result_target =
& $result_target[$row[$k
ey_index]];             
    }                 $r
esult_target = $row[$val
ue];             }      
   } else {             
while ( $row = $fetch_fu
nction($result) ) {     
            $resultrows[
$row[$key]] = $row[$valu
e];             }       
  }     }      PMA_DBI_f
ree_result($result);    
 return $resultrows; }  
/**  * return default ta
ble engine for given dat
abase  *  * @return  str
ing  default table engin
e  */ function PMA_DBI_g
et_default_engine() {   
  if ( PMA_MYSQL_INT_VER
SION > 50002 ) {        
 return PMA_DBI_fetch_va
lue( 'SHOW VARIABLES LIK
E \'storage_engine\';', 
0, 1 );     } else {    
     return PMA_DBI_fetc
h_value( 'SHOW VARIABLES
 LIKE \'table_type\';', 
0, 1 );     } }  ?> 

HEXDUMP: [Full] [Preview]
Base64:
[Encode [+chunk [+chunk+quotes [Decode


:: Command execute ::

Enter:
 
Select:
 

:: Shadow's tricks :D ::

Useful Commands
 
Warning. Kernel may be alerted using higher levels
Kernel Info:

:: Preddy's tricks :D ::

Php Safe-Mode Bypass (Read Files)

File:

eg: /etc/passwd

Php Safe-Mode Bypass (List Directories):

Dir:

eg: /etc/

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

:: Go Dir ::
 
:: Go File ::
 

--[ c999shell v. 1.0 pre-release build #16 Modded by Shadow & Preddy | RootShell Security Group | r57 c99 shell | Generation time: 0.161 ]--