!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.32 GB of 127.8 GB (40.94%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     Tracker.class.php (29.08 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
Information:
Path /var/www/html/phpMyAdmin/libraries/Tracker.class.php
Size 29.08 KB
MD5 853aeed0319a35f0e269446cc5e10ca7
Owner/Group apache/root
Perms-rw-r--r--
Create time 05/09/2012 17:45:15
Access time 31/07/2024 05:02:23
MODIFY time 11/05/2011 17:21:15

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
3C 3F 70 68 70 0A 2F 2A 20 76 69 6D 3A 20 73 65 74 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 20 2A 2F 0A
2F 2A 2A 0A 20 2A 0A 20 2A 20 40 70 61 63 6B 61 67 65 20 70 68 70 4D 79
41 64 6D 69 6E 0A 20 2A 2F 0A 0A 2F 2A 2A 0A 20 2A 20 54 68 69 73 20 63
6C 61 73 73 20 74 72 61 63 6B 73 20 63 68 61 6E 67 65 73 20 6F 6E 20 64
61 74 61 62 61 73 65 73 2C 20 74 61 62 6C 65 73 20 61 6E 64 20 76 69 65
77 73 2E 0A 20 2A 20 46 6F 72 20 6D 6F 72 65 20 69 6E 66 6F 72 6D 61 74
69 6F 6E 20 70 6C 65 61 73 65 20 73 65 65 20 70 68 70 4D 79 41 64 6D 69
6E 2F 44 6F 63 75 6D 65 6E 74 61 74 69 6F 6E 2E 68 74 6D 6C 0A 20 2A 0A
20 2A 20 40 70 61 63 6B 61 67 65 20 70 68 70 4D 79 41 64 6D 69 6E 0A 20
2A 0A 20 2A 20 40 74 6F 64 6F 20 75 73 65 20 73 74 72 69 73 74 72 20 69
6E 73 74 65 61 64 20 6F 66 20 73 74 72 73 74 72 0A 20 2A 2F 0A 63 6C 61
73 73 20 50 4D 41 5F 54 72 61 63 6B 65 72 0A 7B 0A 20 20 20 20 2F 2A 2A
0A 20 20 20 20 20 2A 20 57 68 65 74 68 65 72 20 74 72 61 63 6B 69 6E 67
20 69 73 20 72 65 61 64 79 2E 0A 20 20 20 20 20 2A 2F 0A 20 20 20 20 73
74 61 74 69 63 20 70 72 6F 74 65 63 74 65 64 20 24 65 6E 61 62 6C 65 64
20 3D 20 66 61 6C 73 65 3B 0A 0A 20 20 20 20 2F 2A 2A 0A 20 20 20 20 20
2A 20 44 65 66 69 6E 65 73 20 74 68 65 20 69 6E 74 65 72 6E 61 6C 20 50
4D 41 20 74 61 62 6C 65 20 77 68 69 63 68 20 63 6F 6E 74 61 69 6E 73 20
74 72 61 63 6B 69 6E 67 20 64 61 74 61 2E 0A 20 20 20 20 20 2A 0A 20 20
20 20 20 2A 20 40 61 63 63 65 73 73 20 20 70 72 6F 74 65 63 74 65 64 0A
20 20 20 20 20 2A 20 40 76 61 72 20 73 74 72 69 6E 67 0A 20 20 20 20 20
2A 2F 0A 20 20 20 20 73 74 61 74 69 63 20 70 72 6F 74 65 63 74 65 64 20
24 70 6D 61 5F 74 61 62 6C 65 3B 0A 0A 20 20 20 20 2F 2A 2A 0A 20 20 20
20 20 2A 20 44 65 66 69 6E 65 73 20 74 68 65 20 75 73 61 67 65 20 6F 66
20 44 52 4F 50 20 54 41 42 4C 45 20 73 74 61 74 6D 65 6E 74 20 69 6E 20
53 51 4C 20 64 75 6D 70 73 2E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A
20 40 61 63 63 65 73 73 20 70 72 6F 74 65 63 74 65 64 0A 20 20 20 20 20
2A 20 40 76 61 72 20 62 6F 6F 6C 65 61 6E 0A 20 20 20 20 20 2A 2F 0A 20
20 20 20 73 74 61 74 69 63 20 70 72 6F 74 65 63 74 65 64 20 24 61 64 64
5F 64 72 6F 70 5F 74 61 62 6C 65 3B 0A 0A 20 20 20 20 2F 2A 2A 0A 20 20
20 20 20 2A 20 44 65 66 69 6E 65 73 20 74 68 65 20 75 73 61 67 65 20 6F
66 20 44 52 4F 50 20 56 49 45 57 20 73 74 61 74 6D 65 6E 74 20 69 6E 20
53 51 4C 20 64 75 6D 70 73 2E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A
20 40 61 63 63 65 73 73 20 70 72 6F 74 65 63 74 65 64 0A 20 20 20 20 20
2A 20 40 76 61 72 20 62 6F 6F 6C 65 61 6E 0A 20 20 20 20 20 2A 2F 0A 20
20 20 20 73 74 61 74 69 63 20 70 72 6F 74 65 63 74 65 64 20 24 61 64 64
5F 64 72 6F 70 5F 76 69 65 77 3B 0A 0A 20 20 20 20 2F 2A 2A 0A 20 20 20
20 20 2A 20 44 65 66 69 6E 65 73 20 74 68 65 20 75 73 61 67 65 20 6F 66
20 44 52 4F 50 20 44 41 54 41 42 41 53 45 20 73 74 61 74 6D 65 6E 74 20
69 6E 20 53 51 4C 20 64 75 6D 70 73 2E 0A 20 20 20 20 20 2A 0A 20 20 20
20 20 2A 20 40 61 63 63 65 73 73 20 70 72 6F 74 65 63 74 65 64 0A 20 20
20 20 20 2A 20 40 76 61 72 20 62 6F 6F 6C 65 61 6E 0A 20 20 20 20 20 2A
2F 0A 20 20 20 20 73 74 61 74 69 63 20 70 72 6F 74 65 63 74 65 64 20 24
61 64 64 5F 64 72 6F 70 5F 64 61 74 61 62 61 73 65 3B 0A 0A 20 20 20 20
2F 2A 2A 0A 20 20 20 20 20 2A 20 44 65 66 69 6E 65 73 20 61 75 74 6F 2D
63 72 65 61 74 69 6F 6E 20 6F 66 20 74 72 61 63 6B 69 6E 67 20 76 65 72
73 69 6F 6E 73 2E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 76 61
72 20 62 6F 6F 6C 65 61 6E 0A 20 20 20 20 20 2A 2F 0A 20 20 20 20 73 74
61 74 69 63 20 70 72 6F 74 65 63 74 65 64 20 24 76 65 72 73 69 6F 6E 5F
61 75 74 6F 5F 63 72 65 61 74 65 3B 0A 0A 20 20 20 20 2F 2A 2A 0A 20 20
20 20 20 2A 20 44 65 66 69 6E 65 73 20 74 68 65 20 64 65 66 61 75 6C 74
20 73 65 74 20 6F 66 20 74 72 61 63 6B 65 64 20 73 74 61 74 65 6D 65 6E
74 73 2E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 76 61 72 20 73
74 72 69 6E 67 0A 20 20 20 20 20 2A 2F 0A 20 20 20 20 73 74 61 74 69 63
20 70 72 6F 74 65 63 74 65 64 20 24 64 65 66 61 75 6C 74 5F 74 72 61 63
6B 69 6E 67 5F 73 65 74 3B 0A 0A 20 20 20 20 2F 2A 2A 0A 20 20 20 20 20
2A 20 49 6E 69 74 69 61 6C 69 7A 65 73 20 73 65 74 74 69 6E 67 73 2E 20
53 65 65 20 70 68 70 4D 79 41 64 6D 69 6E 2F 44 6F 63 75 6D 65 6E 74 61
74 69 6F 6E 2E 68 74 6D 6C 2E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A
20 40 73 74 61 74 69 63 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 2F 0A
20 20 20 20 73 74 61 74 69 63 20 70 75 62 6C 69 63 20 66 75 6E 63 74 69
6F 6E 20 69 6E 69 74 28 29 0A 20 20 20 20 7B 0A 20 20 20 20 20 20 20 20
73 65 6C 66 3A 3A 24 70 6D 61 5F 74 61 62 6C 65 20 3D 20 50 4D 41 5F 62
61 63 6B 71 75 6F 74 65 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 70 6D 61 64 62 27 5D 29 20 2E 22 2E
22 2E 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 20 20 20 50 4D 41 5F 62 61 63 6B 71 75 6F 74 65 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 74
72 61 63 6B 69 6E 67 27 5D 29 3B 0A 0A 20 20 20 20 20 20 20 20 73 65 6C
66 3A 3A 24 61 64 64 5F 64 72 6F 70 5F 74 61 62 6C 65 20 3D 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
74 72 61 63 6B 69 6E 67 5F 61 64 64 5F 64 72 6F 70 5F 74 61 62 6C 65 27
5D 3B 0A 0A 20 20 20 20 20 20 20 20 73 65 6C 66 3A 3A 24 61 64 64 5F 64
72 6F 70 5F 76 69 65 77 20 3D 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 74 72 61 63 6B 69 6E 67 5F 61
64 64 5F 64 72 6F 70 5F 76 69 65 77 27 5D 3B 0A 0A 20 20 20 20 20 20 20
20 73 65 6C 66 3A 3A 24 61 64 64 5F 64 72 6F 70 5F 64 61 74 61 62 61 73
65 20 3D 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 74 72 61 63 6B 69 6E 67 5F 61 64 64 5F 64 72 6F 70
5F 64 61 74 61 62 61 73 65 27 5D 3B 0A 0A 20 20 20 20 20 20 20 20 73 65
6C 66 3A 3A 24 64 65 66 61 75 6C 74 5F 74 72 61 63 6B 69 6E 67 5F 73 65
74 20 3D 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 74 72 61 63 6B 69 6E 67 5F 64 65 66 61 75 6C 74 5F
73 74 61 74 65 6D 65 6E 74 73 27 5D 3B 0A 0A 20 20 20 20 20 20 20 20 73
65 6C 66 3A 3A 24 76 65 72 73 69 6F 6E 5F 61 75 74 6F 5F 63 72 65 61 74
65 20 3D 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 74 72 61 63 6B 69 6E 67 5F 76 65 72 73 69 6F 6E 5F
61 75 74 6F 5F 63 72 65 61 74 65 27 5D 3B 0A 0A 20 20 20 20 7D 0A 0A 20
20 20 20 2F 2A 2A 0A 20 20 20 20 20 2A 20 41 63 74 75 61 6C 6C 79 20 65
6E 61 62 6C 65 73 20 74 72 61 63 6B 69 6E 67 2E 20 54 68 69 73 20 6E 65
65 64 73 20 74 6F 20 62 65 20 64 6F 6E 65 20 61 66 74 65 72 20 61 6C 6C
20 0A 20 20 20 20 20 2A 20 75 6E 64 65 72 6C 61 79 69 6E 67 20 63 6F 64
65 20 69 73 20 69 6E 69 74 69 61 6C 69 7A 65 64 2E 0A 20 20 20 20 20 2A
0A 20 20 20 20 20 2A 20 40 73 74 61 74 69 63 0A 20 20 20 20 20 2A 0A 20
20 20 20 20 2A 2F 0A 20 20 20 20 73 74 61 74 69 63 20 70 75 62 6C 69 63
20 66 75 6E 63 74 69 6F 6E 20 65 6E 61 62 6C 65 28 29 0A 20 20 20 20 7B
0A 20 20 20 20 20 20 20 20 73 65 6C 66 3A 3A 24 65 6E 61 62 6C 65 64 20
3D 20 74 72 75 65 3B 0A 20 20 20 20 7D 0A 0A 20 20 20 20 2F 2A 2A 0A 20
20 20 20 20 2A 20 47 65 74 73 20 74 68 65 20 6F 6E 2F 6F 66 66 20 76 61
6C 75 65 20 6F 66 20 74 68 65 20 54 72 61 63 6B 65 72 20 6D 6F 64 75 6C
65 2C 20 73 74 61 72 74 73 20 69 6E 69 74 69 61 6C 69 7A 61 74 69 6F 6E
2E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 73 74 61 74 69 63 0A
20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 72 65 74 75 72 6E 20 62 6F
6F 6C 65 61 6E 20 28 74 72 75 65 3D 6F 6E 7C 66 61 6C 73 65 3D 6F 66 66
29 0A 20 20 20 20 20 2A 2F 0A 20 20 20 20 73 74 61 74 69 63 20 70 75 62
6C 69 63 20 66 75 6E 63 74 69 6F 6E 20 69 73 41 63 74 69 76 65 28 29 0A
20 20 20 20 7B 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 20 73 65 6C 66
3A 3A 24 65 6E 61 62 6C 65 64 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 20 20 20 20 2F 2A 20 57 65 20 6E 65 65 64 20 74 6F 20
61 76 6F 69 64 20 61 74 74 65 6D 70 74 20 74 6F 20 74 72 61 63 6B 20 61
6E 79 20 71 75 65 72 69 65 73 20 66 72 6F 6D 20 50 4D 41 5F 67 65 74 52
65 6C 61 74 69 6F 6E 73 50 61 72 61 6D 20 2A 2F 0A 20 20 20 20 20 20 20
20 73 65 6C 66 3A 3A 24 65 6E 61 62 6C 65 64 20 3D 20 66 61 6C 73 65 3B
0A 20 20 20 20 20 20 20 20 24 63 66 67 52 65 6C 61 74 69 6F 6E 20 3D 20
50 4D 41 5F 67 65 74 52 65 6C 61 74 69 6F 6E 73 50 61 72 61 6D 28 29 3B
0A 20 20 20 20 20 20 20 20 2F 2A 20 52 65 73 74 6F 72 65 20 6F 72 69 67
69 6E 61 6C 20 73 74 61 74 65 20 2A 2F 0A 20 20 20 20 20 20 20 20 73 65
6C 66 3A 3A 24 65 6E 61 62 6C 65 64 20 3D 20 74 72 75 65 3B 0A 20 20 20
20 20 20 20 20 69 66 20 28 21 20 24 63 66 67 52 65 6C 61 74 69 6F 6E 5B
27 74 72 61 63 6B 69 6E 67 77 6F 72 6B 27 5D 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 20 20 20 20 73 65 6C 66 3A 3A 69 6E 69
74 28 29 3B 0A 0A 20 20 20 20 20 20 20 20 69 66 20 28 69 73 73 65 74 28
73 65 6C 66 3A 3A 24 70 6D 61 5F 74 61 62 6C 65 29 29 20 7B 0A 20 20 20
20 20 20 20 20 20 20 20 20 72 65 74 75 72 6E 20 74 72 75 65 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 0A 20 20 20 20 2F 2A 2A 0A 20 20 20 20 20 2A
20 52 65 74 75 72 6E 73 20 61 20 73 69 6D 70 6C 65 20 44 52 4F 50 20 54
41 42 4C 45 20 73 74 61 74 65 6D 65 6E 74 2E 0A 20 20 20 20 20 2A 0A 20
20 20 20 20 2A 20 40 70 61 72 61 6D 20 73 74 72 69 6E 67 20 24 74 61 62
6C 65 6E 61 6D 65 0A 20 20 20 20 20 2A 20 40 72 65 74 75 72 6E 20 73 74
72 69 6E 67 0A 20 20 20 20 20 2A 2F 0A 20 20 20 20 73 74 61 74 69 63 20
70 75 62 6C 69 63 20 66 75 6E 63 74 69 6F 6E 20 67 65 74 53 74 61 74 65
6D 65 6E 74 44 72 6F 70 54 61 62 6C 65 28 24 74 61 62 6C 65 6E 61 6D 65
29 0A 20 20 20 20 7B 0A 20 20 20 20 20 20 20 20 72 65 74 75 72 6E 20 27
44 52 4F 50 20 54 41 42 4C 45 20 49 46 20 45 58 49 53 54 53 20 27 20 2E
20 24 74 61 62 6C 65 6E 61 6D 65 3B 0A 20 20 20 20 7D 0A 0A 20 20 20 20
2F 2A 2A 0A 20 20 20 20 20 2A 20 52 65 74 75 72 6E 73 20 61 20 73 69 6D
70 6C 65 20 44 52 4F 50 20 56 49 45 57 20 73 74 61 74 65 6D 65 6E 74 2E
0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 70 61 72 61 6D 20 73 74
72 69 6E 67 20 24 76 69 65 77 6E 61 6D 65 0A 20 20 20 20 20 2A 20 40 72
65 74 75 72 6E 20 73 74 72 69 6E 67 0A 20 20 20 20 20 2A 2F 0A 20 20 20
20 73 74 61 74 69 63 20 70 75 62 6C 69 63 20 66 75 6E 63 74 69 6F 6E 20
67 65 74 53 74 61 74 65 6D 65 6E 74 44 72 6F 70 56 69 65 77 28 24 76 69
65 77 6E 61 6D 65 29 0A 20 20 20 20 7B 0A 20 20 20 20 20 20 20 20 72 65
74 75 72 6E 20 27 44 52 4F 50 20 56 49 45 57 20 49 46 20 45 58 49 53 54
53 20 27 20 2E 20 24 76 69 65 77 6E 61 6D 65 3B 0A 20 20 20 20 7D 0A 0A
20 20 20 20 2F 2A 2A 0A 20 20 20 20 20 2A 20 52 65 74 75 72 6E 73 20 61
20 73 69 6D 70 6C 65 20 44 52 4F 50 20 44 41 54 41 42 41 53 45 20 73 74
61 74 65 6D 65 6E 74 2E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40
70 61 72 61 6D 20 73 74 72 69 6E 67 20 24 64 62 6E 61 6D 65 0A 20 20 20
20 20 2A 20 40 72 65 74 75 72 6E 20 73 74 72 69 6E 67 0A 20 20 20 20 20
2A 2F 0A 20 20 20 20 73 74 61 74 69 63 20 70 75 62 6C 69 63 20 66 75 6E
63 74 69 6F 6E 20 67 65 74 53 74 61 74 65 6D 65 6E 74 44 72 6F 70 44 61
74 61 62 61 73 65 28 24 64 62 6E 61 6D 65 29 0A 20 20 20 20 7B 0A 20 20
20 20 20 20 20 20 72 65 74 75 72 6E 20 27 44 52 4F 50 20 44 41 54 41 42
41 53 45 20 49 46 20 45 58 49 53 54 53 20 27 20 2E 20 24 64 62 6E 61 6D
65 3B 0A 20 20 20 20 7D 0A 0A 20 20 20 20 2F 2A 2A 0A 20 20 20 20 20 2A
20 50 61 72 73 65 73 20 74 68 65 20 6E 61 6D 65 20 6F 66 20 61 20 74 61
62 6C 65 20 66 72 6F 6D 20 61 20 53 51 4C 20 73 74 61 74 65 6D 65 6E 74
20 73 75 62 73 74 72 69 6E 67 2E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20
2A 20 40 73 74 61 74 69 63 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20
40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 73 74 72 69 6E 67 20 20
20 20 20 20 70 61 72 74 20 6F 66 20 53 51 4C 20 73 74 61 74 65 6D 65 6E
74 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 72 65 74 75 72 6E 20
73 74 72 69 6E 67 20 74 68 65 20 6E 61 6D 65 20 6F 66 20 74 61 62 6C 65
0A 20 20 20 20 20 2A 2F 0A 20 20 20 20 73 74 61 74 69 63 20 70 72 6F 74
65 63 74 65 64 20 66 75 6E 63 74 69 6F 6E 20 67 65 74 54 61 62 6C 65 4E
61 6D 65 28 24 73 74 72 69 6E 67 29 0A 20 20 20 20 7B 0A 20 20 20 20 20
20 20 20 69 66 20 28 73 74 72 73 74 72 28 24 73 74 72 69 6E 67 2C 20 27
2E 27 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 74 65 6D 70
20 3D 20 65 78 70 6C 6F 64 65 28 27 2E 27 2C 20 24 73 74 72 69 6E 67 29
3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 74 61 62 6C 65 6E 61 6D 65
20 3D 20 24 74 65 6D 70 5B 31 5D 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20
20 20 20 20 20 20 20 65 6C 73 65 20 7B 0A 20 20 20 20 20 20 20 20 20 20
20 20 24 74 61 62 6C 65 6E 61 6D 65 20 3D 20 24 73 74 72 69 6E 67 3B 0A
20 20 20 20 20 20 20 20 7D 0A 0A 20 20 20 20 20 20 20 20 24 73 74 72 20
3D 20 65 78 70 6C 6F 64 65 28 22 5C 6E 22 2C 20 24 74 61 62 6C 65 6E 61
6D 65 29 3B 0A 20 20 20 20 20 20 20 20 24 74 61 62 6C 65 6E 61 6D 65 20
3D 20 24 73 74 72 5B 30 5D 3B 0A 0A 20 20 20 20 20 20 20 20 24 74 61 62
6C 65 6E 61 6D 65 20 3D 20 73 74 72 5F 72 65 70 6C 61 63 65 28 27 3B 27
2C 20 27 27 2C 20 24 74 61 62 6C 65 6E 61 6D 65 29 3B 0A 20 20 20 20 20
20 20 20 24 74 61 62 6C 65 6E 61 6D 65 20 3D 20 73 74 72 5F 72 65 70 6C
61 63 65 28 27 60 27 2C 20 27 27 2C 20 24 74 61 62 6C 65 6E 61 6D 65 29
3B 0A 20 20 20 20 20 20 20 20 24 74 61 62 6C 65 6E 61 6D 65 20 3D 20 74
72 69 6D 28 24 74 61 62 6C 65 6E 61 6D 65 29 3B 0A 0A 20 20 20 20 20 20
20 20 72 65 74 75 72 6E 20 24 74 61 62 6C 65 6E 61 6D 65 3B 0A 20 20 20
20 7D 0A 0A 0A 20 20 20 20 2F 2A 2A 0A 20 20 20 20 20 2A 20 47 65 74 73
20 74 68 65 20 74 72 61 63 6B 69 6E 67 20 73 74 61 74 75 73 20 6F 66 20
61 20 74 61 62 6C 65 2C 20 69 73 20 69 74 20 61 63 74 69 76 65 20 6F 72
20 64 65 61 63 74 69 76 65 20 3F 0A 20 20 20 20 20 2A 0A 20 20 20 20 20
2A 20 40 73 74 61 74 69 63 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20
40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 64 62 6E 61 6D 65 20 20
20 20 20 20 6E 61 6D 65 20 6F 66 20 64 61 74 61 62 61 73 65 0A 20 20 20
20 20 2A 20 40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 74 61 62 6C
65 6E 61 6D 65 20 20 20 6E 61 6D 65 20 6F 66 20 74 61 62 6C 65 0A 20 20
20 20 20 2A 0A 20 20 20 20 20 2A 20 40 72 65 74 75 72 6E 20 62 6F 6F 6C
65 61 6E 20 74 72 75 65 20 6F 72 20 66 61 6C 73 65 0A 20 20 20 20 20 2A
2F 0A 20 20 20 20 73 74 61 74 69 63 20 70 75 62 6C 69 63 20 66 75 6E 63
74 69 6F 6E 20 69 73 54 72 61 63 6B 65 64 28 24 64 62 6E 61 6D 65 2C 20
24 74 61 62 6C 65 6E 61 6D 65 29 0A 20 20 20 20 7B 0A 20 20 20 20 20 20
20 20 69 66 20 28 21 20 73 65 6C 66 3A 3A 24 65 6E 61 62 6C 65 64 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 20 20 20 20 2F 2A
20 57 65 20 6E 65 65 64 20 74 6F 20 61 76 6F 69 64 20 61 74 74 65 6D 70
74 20 74 6F 20 74 72 61 63 6B 20 61 6E 79 20 71 75 65 72 69 65 73 20 66
72 6F 6D 20 50 4D 41 5F 67 65 74 52 65 6C 61 74 69 6F 6E 73 50 61 72 61
6D 20 2A 2F 0A 20 20 20 20 20 20 20 20 73 65 6C 66 3A 3A 24 65 6E 61 62
6C 65 64 20 3D 20 66 61 6C 73 65 3B 0A 20 20 20 20 20 20 20 20 24 63 66
67 52 65 6C 61 74 69 6F 6E 20 3D 20 50 4D 41 5F 67 65 74 52 65 6C 61 74
69 6F 6E 73 50 61 72 61 6D 28 29 3B 0A 20 20 20 20 20 20 20 20 2F 2A 20
52 65 73 74 6F 72 65 20 6F 72 69 67 69 6E 61 6C 20 73 74 61 74 65 20 2A
2F 0A 20 20 20 20 20 20 20 20 73 65 6C 66 3A 3A 24 65 6E 61 62 6C 65 64
20 3D 20 74 72 75 65 3B 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 20 24
63 66 67 52 65 6C 61 74 69 6F 6E 5B 27 74 72 61 63 6B 69 6E 67 77 6F 72
6B 27 5D 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 0A 20 20 20 20
20 20 20 20 24 73 71 6C 5F 71 75 65 72 79 20 3D 0A 20 20 20 20 20 20 20
20 22 20 53 45 4C 45 43 54 20 74 72 61 63 6B 69 6E 67 5F 61 63 74 69 76
65 20 46 52 4F 4D 20 22 20 2E 20 73 65 6C 66 3A 3A 24 70 6D 61 5F 74 61
62 6C 65 20 2E 0A 20 20 20 20 20 20 20 20 22 20 57 48 45 52 45 20 22 20
2E 20 50 4D 41 5F 62 61 63 6B 71 75 6F 74 65 28 27 64 62 5F 6E 61 6D 65
27 29 20 2E 20 22 20 3D 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64
73 6C 61 73 68 65 73 28 24 64 62 6E 61 6D 65 29 20 2E 20 22 27 20 22 20
2E 0A 20 20 20 20 20 20 20 20 22 20 41 4E 44 20 22 20 2E 20 50 4D 41 5F
62 61 63 6B 71 75 6F 74 65 28 27 74 61 62 6C 65 5F 6E 61 6D 65 27 29 20
2E 20 22 20 3D 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61
73 68 65 73 28 24 74 61 62 6C 65 6E 61 6D 65 29 20 2E 20 22 27 20 22 20
2E 0A 20 20 20 20 20 20 20 20 22 20 4F 52 44 45 52 20 42 59 20 76 65 72
73 69 6F 6E 20 44 45 53 43 22 3B 0A 0A 20 20 20 20 20 20 20 20 24 72 6F
77 20 3D 20 50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 61 72 72 61 79 28
50 4D 41 5F 71 75 65 72 79 5F 61 73 5F 63 6F 6E 74 72 6F 6C 75 73 65 72
28 24 73 71 6C 5F 71 75 65 72 79 29 29 3B 0A 0A 20 20 20 20 20 20 20 20
69 66 20 28 69 73 73 65 74 28 24 72 6F 77 5B 27 74 72 61 63 6B 69 6E 67
5F 61 63 74 69 76 65 27 5D 29 20 26 26 20 24 72 6F 77 5B 27 74 72 61 63
6B 69 6E 67 5F 61 63 74 69 76 65 27 5D 20 3D 3D 20 31 29 20 7B 0A 20 20
20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6E 20 74 72 75 65 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 0A 20 20 20 20 2F 2A 2A 0A 20 20 20 20 20
2A 20 52 65 74 75 72 6E 73 20 74 68 65 20 63 6F 6D 6D 65 6E 74 20 6C 69
6E 65 20 66 6F 72 20 74 68 65 20 6C 6F 67 2E 0A 20 20 20 20 20 2A 0A 20
20 20 20 20 2A 20 40 72 65 74 75 72 6E 20 73 74 72 69 6E 67 20 43 6F 6D
6D 65 6E 74 2C 20 63 6F 6E 74 61 69 6E 73 20 64 61 74 65 20 61 6E 64 20
75 73 65 72 6E 61 6D 65 0A 20 20 20 20 20 2A 2F 0A 20 20 20 20 73 74 61
74 69 63 20 70 75 62 6C 69 63 20 66 75 6E 63 74 69 6F 6E 20 67 65 74 4C
6F 67 43 6F 6D 6D 65 6E 74 28 29 0A 20 20 20 20 7B 0A 20 20 20 20 20 20
20 20 24 64 61 74 65 20 3D 20 64 61 74 65 28 27 59 2D 6D 2D 64 20 48 3A
69 3A 73 27 29 3B 0A 0A 20 20 20 20 20 20 20 20 72 65 74 75 72 6E 20 22
23 20 6C 6F 67 20 22 20 2E 20 24 64 61 74 65 20 2E 20 22 20 22 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 75 73 65 72 27 5D 20 2E 20 22 5C 6E 22 3B 0A 20 20 20 20 7D 0A
0A 20 20 20 20 2F 2A 2A 0A 20 20 20 20 20 2A 20 43 72 65 61 74 65 73 20
74 72 61 63 6B 69 6E 67 20 76 65 72 73 69 6F 6E 20 6F 66 20 61 20 74 61
62 6C 65 20 2F 20 76 69 65 77 0A 20 20 20 20 20 2A 20 28 69 6E 20 6F 74
68 65 72 20 77 6F 72 64 73 3A 20 63 72 65 61 74 65 20 61 20 6A 6F 62 20
74 6F 20 74 72 61 63 6B 20 66 75 74 75 72 65 20 63 68 61 6E 67 65 73 20
6F 6E 20 74 68 65 20 74 61 62 6C 65 29 2E 0A 20 20 20 20 20 2A 0A 20 20
20 20 20 2A 20 40 73 74 61 74 69 63 0A 20 20 20 20 20 2A 0A 20 20 20 20
20 2A 20 40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 64 62 6E 61 6D
65 20 20 20 20 20 20 20 6E 61 6D 65 20 6F 66 20 64 61 74 61 62 61 73 65
0A 20 20 20 20 20 2A 20 40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24
74 61 62 6C 65 6E 61 6D 65 20 20 20 20 6E 61 6D 65 20 6F 66 20 74 61 62
6C 65 0A 20 20 20 20 20 2A 20 40 70 61 72 61 6D 20 20 73 74 72 69 6E 67
20 24 76 65 72 73 69 6F 6E 20 20 20 20 20 20 76 65 72 73 69 6F 6E 0A 20
20 20 20 20 2A 20 40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 74 72
61 63 6B 69 6E 67 5F 73 65 74 20 73 65 74 20 6F 66 20 74 72 61 63 6B 69
6E 67 20 73 74 61 74 65 6D 65 6E 74 73 0A 20 20 20 20 20 2A 20 40 70 61
72 61 6D 20 20 73 74 72 69 6E 67 20 24 69 73 5F 76 69 65 77 20 20 20 20
20 20 69 66 20 74 61 62 6C 65 20 69 73 20 61 20 76 69 65 77 0A 20 20 20
20 20 2A 0A 20 20 20 20 20 2A 20 40 72 65 74 75 72 6E 20 69 6E 74 20 72
65 73 75 6C 74 20 6F 66 20 76 65 72 73 69 6F 6E 20 69 6E 73 65 72 74 69
6F 6E 0A 20 20 20 20 20 2A 2F 0A 20 20 20 20 73 74 61 74 69 63 20 70 75
62 6C 69 63 20 66 75 6E 63 74 69 6F 6E 20 63 72 65 61 74 65 56 65 72 73
69 6F 6E 28 24 64 62 6E 61 6D 65 2C 20 24 74 61 62 6C 65 6E 61 6D 65 2C
20 24 76 65 72 73 69 6F 6E 2C 20 24 74 72 61 63 6B 69 6E 67 5F 73 65 74
20 3D 20 27 27 2C 20 24 69 73 5F 76 69 65 77 20 3D 20 66 61 6C 73 65 29
0A 20 20 20 20 7B 0A 20 20 20 20 20 20 20 20 67 6C 6F 62 61 6C 20 24 73
71 6C 5F 62 61 63 6B 71 75 6F 74 65 73 3B 0A 0A 20 20 20 20 20 20 20 20
69 66 20 28 24 74 72 61 63 6B 69 6E 67 5F 73 65 74 20 3D 3D 20 27 27 29
20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 74 72 61 63 6B 69 6E 67
5F 73 65 74 20 3D 20 73 65 6C 66 3A 3A 24 64 65 66 61 75 6C 74 5F 74 72
61 63 6B 69 6E 67 5F 73 65 74 3B 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20
20 20 20 20 20 20 20 72 65 71 75 69 72 65 5F 6F 6E 63 65 20 27 2E 2F 6C
69 62 72 61 72 69 65 73 2F 65 78 70 6F 72 74 2F 73 71 6C 2E 70 68 70 27
3B 0A 0A 20 20 20 20 20 20 20 20 24 73 71 6C 5F 62 61 63 6B 71 75 6F 74
65 73 20 3D 20 74 72 75 65 3B 0A 0A 20 20 20 20 20 20 20 20 24 64 61 74
65 20 3D 20 64 61 74 65 28 27 59 2D 6D 2D 64 20 48 3A 69 3A 73 27 29 3B
0A 0A 20 20 20 20 20 20 20 20 2F 2F 20 47 65 74 20 64 61 74 61 20 64 65
66 69 6E 69 74 69 6F 6E 20 73 6E 61 70 73 68 6F 74 20 6F 66 20 74 61 62
6C 65 0A 20 20 20 20 20 20 20 20 24 73 71 6C 5F 71 75 65 72 79 20 3D 20
27 0A 20 20 20 20 20 20 20 20 53 48 4F 57 20 46 55 4C 4C 20 43 4F 4C 55
4D 4E 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 62 6E 61 6D 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 6E 61 6D 65 29 3B 0A 0A
20 20 20 20 20 20 20 20 24 73 71 6C 5F 72 65 73 75 6C 74 20 3D 20 50 4D
41 5F 44 42 49 5F 71 75 65 72 79 28 24 73 71 6C 5F 71 75 65 72 79 29 3B
0A 0A 20 20 20 20 20 20 20 20 77 68 69 6C 65 20 28 24 72 6F 77 20 3D 20
50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 61 72 72 61 79 28 24 73 71 6C
5F 72 65 73 75 6C 74 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20
24 63 6F 6C 75 6D 6E 73 5B 5D 20 3D 20 24 72 6F 77 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 5F 71 75 65 72 79
20 3D 20 27 0A 20 20 20 20 20 20 20 20 53 48 4F 57 20 49 4E 44 45 58 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 62 6E 61 6D 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 6E 61 6D 65 29 3B 0A 0A 20 20 20 20
20 20 20 20 24 73 71 6C 5F 72 65 73 75 6C 74 20 3D 20 50 4D 41 5F 44 42
49 5F 71 75 65 72 79 28 24 73 71 6C 5F 71 75 65 72 79 29 3B 0A 0A 20 20
20 20 20 20 20 20 24 69 6E 64 65 78 65 73 20 3D 20 61 72 72 61 79 28 29
3B 0A 0A 20 20 20 20 20 20 20 20 77 68 69 6C 65 28 24 72 6F 77 20 3D 20
50 4D 41 5F 44 42 49 5F 66 65 74 63 68 5F 61 72 72 61 79 28 24 73 71 6C
5F 72 65 73 75 6C 74 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20
24 69 6E 64 65 78 65 73 5B 5D 20 3D 20 24 72 6F 77 3B 0A 20 20 20 20 20
20 20 20 7D 0A 0A 20 20 20 20 20 20 20 20 24 73 6E 61 70 73 68 6F 74 20
3D 20 61 72 72 61 79 28 27 43 4F 4C 55 4D 4E 53 27 20 3D 3E 20 24 63 6F
6C 75 6D 6E 73 2C 20 27 49 4E 44 45 58 45 53 27 20 3D 3E 20 24 69 6E 64
65 78 65 73 29 3B 0A 20 20 20 20 20 20 20 20 24 73 6E 61 70 73 68 6F 74
20 3D 20 73 65 72 69 61 6C 69 7A 65 28 24 73 6E 61 70 73 68 6F 74 29 3B
0A 0A 20 20 20 20 20 20 20 20 2F 2F 20 47 65 74 20 44 52 4F 50 20 54 41
42 4C 45 20 2F 20 44 52 4F 50 20 56 49 45 57 20 61 6E 64 20 43 52 45 41
54 45 20 54 41 42 4C 45 20 53 51 4C 20 73 74 61 74 65 6D 65 6E 74 73 0A
20 20 20 20 20 20 20 20 24 73 71 6C 5F 62 61 63 6B 71 75 6F 74 65 73 20
3D 20 74 72 75 65 3B 0A 0A 20 20 20 20 20 20 20 20 24 63 72 65 61 74 65
5F 73 71 6C 20 20 3D 20 22 22 3B 0A 0A 20 20 20 20 20 20 20 20 69 66 20
28 73 65 6C 66 3A 3A 24 61 64 64 5F 64 72 6F 70 5F 74 61 62 6C 65 20 3D
3D 20 74 72 75 65 20 26 26 20 24 69 73 5F 76 69 65 77 20 3D 3D 20 66 61
6C 73 65 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 63 72 65 61
74 65 5F 73 71 6C 20 2E 3D 20 73 65 6C 66 3A 3A 67 65 74 4C 6F 67 43 6F
6D 6D 65 6E 74 28 29 20 2E 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 20 20 20 73 65 6C 66 3A 3A 67 65 74 53 74
61 74 65 6D 65 6E 74 44 72 6F 70 54 61 62 6C 65 28 50 4D 41 5F 62 61 63
6B 71 75 6F 74 65 28 24 74 61 62 6C 65 6E 61 6D 65 29 29 20 2E 20 22 3B
5C 6E 22 3B 0A 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20 20 20 20 20 20 20
20 69 66 20 28 73 65 6C 66 3A 3A 24 61 64 64 5F 64 72 6F 70 5F 76 69 65
77 20 3D 3D 20 74 72 75 65 20 26 26 20 24 69 73 5F 76 69 65 77 20 3D 3D
20 74 72 75 65 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 63 72
65 61 74 65 5F 73 71 6C 20 2E 3D 20 73 65 6C 66 3A 3A 67 65 74 4C 6F 67
43 6F 6D 6D 65 6E 74 28 29 20 2E 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 20 20 20 73 65 6C 66 3A 3A 67 65 74
53 74 61 74 65 6D 65 6E 74 44 72 6F 70 56 69 65 77 28 50 4D 41 5F 62 61
63 6B 71 75 6F 74 65 28 24 74 61 62 6C 65 6E 61 6D 65 29 29 20 2E 20 22
3B 5C 6E 22 3B 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20 20 20 20 20 20 20
20 24 63 72 65 61 74 65 5F 73 71 6C 20 2E 3D 20 73 65 6C 66 3A 3A 67 65
74 4C 6F 67 43 6F 6D 6D 65 6E 74 28 29 20 2E 0A 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 50 4D 41 5F 67 65 74 54 61
62 6C 65 44 65 66 28 24 64 62 6E 61 6D 65 2C 20 24 74 61 62 6C 65 6E 61
6D 65 2C 20 22 5C 6E 22 2C 20 22 22 29 3B 0A 0A 20 20 20 20 20 20 20 20
2F 2F 20 53 61 76 65 20 76 65 72 73 69 6F 6E 0A 0A 20 20 20 20 20 20 20
20 24 73 71 6C 5F 71 75 65 72 79 20 3D 0A 20 20 20 20 20 20 20 20 22 2F
2A 4E 4F 54 52 41 43 4B 2A 2F 5C 6E 22 20 2E 0A 20 20 20 20 20 20 20 20
22 49 4E 53 45 52 54 20 49 4E 54 4F 22 20 2E 20 73 65 6C 66 3A 3A 24 70
6D 61 5F 74 61 62 6C 65 20 2E 20 22 20 28 22 20 2E 0A 20 20 20 20 20 20
20 20 22 64 62 5F 6E 61 6D 65 2C 20 22 20 2E 0A 20 20 20 20 20 20 20 20
22 74 61 62 6C 65 5F 6E 61 6D 65 2C 20 22 20 2E 0A 20 20 20 20 20 20 20
20 22 76 65 72 73 69 6F 6E 2C 20 22 20 2E 0A 20 20 20 20 20 20 20 20 22
64 61 74 65 5F 63 72 65 61 74 65 64 2C 20 22 20 2E 0A 20 20 20 20 20 20
20 20 22 64 61 74 65 5F 75 70 64 61 74 65 64 2C 20 22 20 2E 0A 20 20 20
20 20 20 20 20 22 73 63 68 65 6D 61 5F 73 6E 61 70 73 68 6F 74 2C 20 22
20 2E 0A 20 20 20 20 20 20 20 20 22 73 63 68 65 6D 61 5F 73 71 6C 2C 20
22 20 2E 0A 20 20 20 20 20 20 20 20 22 64 61 74 61 5F 73 71 6C 2C 20 22
20 2E 0A 20 20 20 20 20 20 20 20 22 74 72 61 63 6B 69 6E 67 20 22 20 2E
0A 20 20 20 20 20 20 20 20 22 29 20 22 20 2E 0A 20 20 20 20 20 20 20 20
22 76 61 6C 75 65 73 20 28 0A 20 20 20 20 20 20 20 20 27 22 20 2E 20 50
4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24 64 62 6E 61 6D 65
29 20 2E 20 22 27 2C 0A 20 20 20 20 20 20 20 20 27 22 20 2E 20 50 4D 41
5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24 74 61 62 6C 65 6E 61 6D
65 29 20 2E 20 22 27 2C 0A 20 20 20 20 20 20 20 20 27 22 20 2E 20 50 4D
41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24 76 65 72 73 69 6F 6E
29 20 2E 20 22 27 2C 0A 20 20 20 20 20 20 20 20 27 22 20 2E 20 50 4D 41
5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24 64 61 74 65 29 20 2E 20
22 27 2C 0A 20 20 20 20 20 20 20 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C
41 64 64 73 6C 61 73 68 65 73 28 24 64 61 74 65 29 20 2E 20 22 27 2C 0A
20 20 20 20 20 20 20 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73
6C 61 73 68 65 73 28 24 73 6E 61 70 73 68 6F 74 29 20 2E 20 22 27 2C 0A
20 20 20 20 20 20 20 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73
6C 61 73 68 65 73 28 24 63 72 65 61 74 65 5F 73 71 6C 29 20 2E 20 22 27
2C 0A 20 20 20 20 20 20 20 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64
64 73 6C 61 73 68 65 73 28 22 5C 6E 22 29 20 2E 20 22 27 2C 0A 20 20 20
20 20 20 20 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61 73
68 65 73 28 24 74 72 61 63 6B 69 6E 67 5F 73 65 74 29 20 2E 20 22 27 20
29 22 3B 0A 0A 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 20 3D 20 50
4D 41 5F 71 75 65 72 79 5F 61 73 5F 63 6F 6E 74 72 6F 6C 75 73 65 72 28
24 73 71 6C 5F 71 75 65 72 79 29 3B 0A 0A 20 20 20 20 20 20 20 20 69 66
20 28 24 72 65 73 75 6C 74 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20
20 2F 2F 20 44 65 61 63 74 69 76 61 74 65 20 70 72 65 76 69 6F 75 73 20
76 65 72 73 69 6F 6E 0A 20 20 20 20 20 20 20 20 20 20 20 20 73 65 6C 66
3A 3A 64 65 61 63 74 69 76 61 74 65 54 72 61 63 6B 69 6E 67 28 24 64 62
6E 61 6D 65 2C 20 24 74 61 62 6C 65 6E 61 6D 65 2C 20 28 24 76 65 72 73
69 6F 6E 20 2D 20 31 29 29 3B 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20 20
20 20 20 20 20 20 72 65 74 75 72 6E 20 24 72 65 73 75 6C 74 3B 0A 20 20
20 20 7D 0A 0A 0A 20 20 20 20 2F 2A 2A 0A 20 20 20 20 20 2A 20 52 65 6D
6F 76 65 73 20 61 6C 6C 20 74 72 61 63 6B 69 6E 67 20 64 61 74 61 20 66
6F 72 20 61 20 74 61 62 6C 65 20 0A 20 20 20 20 20 2A 0A 20 20 20 20 20
2A 20 40 73 74 61 74 69 63 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20
40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 64 62 6E 61 6D 65 20 20
20 20 20 20 20 6E 61 6D 65 20 6F 66 20 64 61 74 61 62 61 73 65 0A 20 20
20 20 20 2A 20 40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 74 61 62
6C 65 6E 61 6D 65 20 20 20 20 6E 61 6D 65 20 6F 66 20 74 61 62 6C 65 20
0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 72 65 74 75 72 6E 20 69
6E 74 20 72 65 73 75 6C 74 20 6F 66 20 76 65 72 73 69 6F 6E 20 69 6E 73
65 72 74 69 6F 6E 0A 20 20 20 20 20 2A 2F 0A 20 20 20 20 73 74 61 74 69
63 20 70 75 62 6C 69 63 20 66 75 6E 63 74 69 6F 6E 20 64 65 6C 65 74 65
54 72 61 63 6B 69 6E 67 28 24 64 62 6E 61 6D 65 2C 20 24 74 61 62 6C 65
6E 61 6D 65 29 0A 20 20 20 20 7B 0A 20 20 20 20 20 20 20 20 24 73 71 6C
5F 71 75 65 72 79 20 3D 0A 20 20 20 20 20 20 20 20 22 2F 2A 4E 4F 54 52
41 43 4B 2A 2F 5C 6E 22 20 2E 0A 20 20 20 20 20 20 20 20 22 44 45 4C 45
54 45 20 46 52 4F 4D 20 22 20 2E 20 73 65 6C 66 3A 3A 24 70 6D 61 5F 74
61 62 6C 65 20 2E 20 22 20 57 48 45 52 45 20 60 64 62 5F 6E 61 6D 65 60
20 3D 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65
73 28 24 64 62 6E 61 6D 65 29 20 2E 20 22 27 20 41 4E 44 20 60 74 61 62
6C 65 5F 6E 61 6D 65 60 20 3D 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41
64 64 73 6C 61 73 68 65 73 28 24 74 61 62 6C 65 6E 61 6D 65 29 20 2E 20
22 27 22 3B 0A 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 20 3D 20 50
4D 41 5F 71 75 65 72 79 5F 61 73 5F 63 6F 6E 74 72 6F 6C 75 73 65 72 28
24 73 71 6C 5F 71 75 65 72 79 29 3B 0A 0A 20 20 20 20 20 20 20 20 72 65
74 75 72 6E 20 24 72 65 73 75 6C 74 3B 0A 20 20 20 20 7D 0A 0A 20 20 20
20 2F 2A 2A 0A 20 20 20 20 20 2A 20 43 72 65 61 74 65 73 20 74 72 61 63
6B 69 6E 67 20 76 65 72 73 69 6F 6E 20 6F 66 20 61 20 64 61 74 61 62 61
73 65 0A 20 20 20 20 20 2A 20 28 69 6E 20 6F 74 68 65 72 20 77 6F 72 64
73 3A 20 63 72 65 61 74 65 20 61 20 6A 6F 62 20 74 6F 20 74 72 61 63 6B
20 66 75 74 75 72 65 20 63 68 61 6E 67 65 73 20 6F 6E 20 74 68 65 20 64
61 74 61 62 61 73 65 29 2E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20
40 73 74 61 74 69 63 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 70
61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 64 62 6E 61 6D 65 20 20 20 20
20 20 20 6E 61 6D 65 20 6F 66 20 64 61 74 61 62 61 73 65 0A 20 20 20 20
20 2A 20 40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 76 65 72 73 69
6F 6E 20 20 20 20 20 20 76 65 72 73 69 6F 6E 0A 20 20 20 20 20 2A 20 40
70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 71 75 65 72 79 20 20 20 20
20 20 20 20 71 75 65 72 79 0A 20 20 20 20 20 2A 20 40 70 61 72 61 6D 20
20 73 74 72 69 6E 67 20 24 74 72 61 63 6B 69 6E 67 5F 73 65 74 20 73 65
74 20 6F 66 20 74 72 61 63 6B 69 6E 67 20 73 74 61 74 65 6D 65 6E 74 73
0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 72 65 74 75 72 6E 20 69
6E 74 20 72 65 73 75 6C 74 20 6F 66 20 76 65 72 73 69 6F 6E 20 69 6E 73
65 72 74 69 6F 6E 0A 20 20 20 20 20 2A 2F 0A 20 20 20 20 73 74 61 74 69
63 20 70 75 62 6C 69 63 20 66 75 6E 63 74 69 6F 6E 20 63 72 65 61 74 65
44 61 74 61 62 61 73 65 56 65 72 73 69 6F 6E 28 24 64 62 6E 61 6D 65 2C
20 24 76 65 72 73 69 6F 6E 2C 20 24 71 75 65 72 79 2C 20 24 74 72 61 63
6B 69 6E 67 5F 73 65 74 20 3D 20 27 43 52 45 41 54 45 20 44 41 54 41 42
41 53 45 2C 41 4C 54 45 52 20 44 41 54 41 42 41 53 45 2C 44 52 4F 50 20
44 41 54 41 42 41 53 45 27 29 0A 20 20 20 20 7B 0A 20 20 20 20 20 20 20
20 67 6C 6F 62 61 6C 20 24 73 71 6C 5F 62 61 63 6B 71 75 6F 74 65 73 3B
0A 0A 20 20 20 20 20 20 20 20 24 64 61 74 65 20 3D 20 64 61 74 65 28 27
59 2D 6D 2D 64 20 48 3A 69 3A 73 27 29 3B 0A 0A 20 20 20 20 20 20 20 20
69 66 20 28 24 74 72 61 63 6B 69 6E 67 5F 73 65 74 20 3D 3D 20 27 27 29
20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 74 72 61 63 6B 69 6E 67
5F 73 65 74 20 3D 20 73 65 6C 66 3A 3A 24 64 65 66 61 75 6C 74 5F 74 72
61 63 6B 69 6E 67 5F 73 65 74 3B 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20
20 20 20 20 20 20 20 72 65 71 75 69 72 65 5F 6F 6E 63 65 20 27 2E 2F 6C
69 62 72 61 72 69 65 73 2F 65 78 70 6F 72 74 2F 73 71 6C 2E 70 68 70 27
3B 0A 0A 20 20 20 20 20 20 20 20 24 63 72 65 61 74 65 5F 73 71 6C 20 20
3D 20 22 22 3B 0A 0A 20 20 20 20 20 20 20 20 69 66 20 28 73 65 6C 66 3A
3A 24 61 64 64 5F 64 72 6F 70 5F 64 61 74 61 62 61 73 65 20 3D 3D 20 74
72 75 65 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 63 72 65 61
74 65 5F 73 71 6C 20 2E 3D 20 73 65 6C 66 3A 3A 67 65 74 4C 6F 67 43 6F
6D 6D 65 6E 74 28 29 20 2E 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 20 20 20 73 65 6C 66 3A 3A 67 65 74 53 74
61 74 65 6D 65 6E 74 44 72 6F 70 44 61 74 61 62 61 73 65 28 50 4D 41 5F
62 61 63 6B 71 75 6F 74 65 28 24 64 62 6E 61 6D 65 29 29 20 2E 20 22 3B
5C 6E 22 3B 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20 20 20 20 20 20 20 20
24 63 72 65 61 74 65 5F 73 71 6C 20 2E 3D 20 73 65 6C 66 3A 3A 67 65 74
4C 6F 67 43 6F 6D 6D 65 6E 74 28 29 20 2E 20 24 71 75 65 72 79 3B 0A 0A
20 20 20 20 20 20 20 20 2F 2F 20 53 61 76 65 20 76 65 72 73 69 6F 6E 0A
20 20 20 20 20 20 20 20 24 73 71 6C 5F 71 75 65 72 79 20 3D 0A 20 20 20
20 20 20 20 20 22 2F 2A 4E 4F 54 52 41 43 4B 2A 2F 5C 6E 22 20 2E 0A 20
20 20 20 20 20 20 20 22 49 4E 53 45 52 54 20 49 4E 54 4F 22 20 2E 20 73
65 6C 66 3A 3A 24 70 6D 61 5F 74 61 62 6C 65 20 2E 20 22 20 28 22 20 2E
0A 20 20 20 20 20 20 20 20 22 64 62 5F 6E 61 6D 65 2C 20 22 20 2E 0A 20
20 20 20 20 20 20 20 22 74 61 62 6C 65 5F 6E 61 6D 65 2C 20 22 20 2E 0A
20 20 20 20 20 20 20 20 22 76 65 72 73 69 6F 6E 2C 20 22 20 2E 0A 20 20
20 20 20 20 20 20 22 64 61 74 65 5F 63 72 65 61 74 65 64 2C 20 22 20 2E
0A 20 20 20 20 20 20 20 20 22 64 61 74 65 5F 75 70 64 61 74 65 64 2C 20
22 20 2E 0A 20 20 20 20 20 20 20 20 22 73 63 68 65 6D 61 5F 73 6E 61 70
73 68 6F 74 2C 20 22 20 2E 0A 20 20 20 20 20 20 20 20 22 73 63 68 65 6D
61 5F 73 71 6C 2C 20 22 20 2E 0A 20 20 20 20 20 20 20 20 22 64 61 74 61
5F 73 71 6C 2C 20 22 20 2E 0A 20 20 20 20 20 20 20 20 22 74 72 61 63 6B
69 6E 67 20 22 20 2E 0A 20 20 20 20 20 20 20 20 22 29 20 22 20 2E 0A 20
20 20 20 20 20 20 20 22 76 61 6C 75 65 73 20 28 0A 20 20 20 20 20 20 20
20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28
24 64 62 6E 61 6D 65 29 20 2E 20 22 27 2C 0A 20 20 20 20 20 20 20 20 27
22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 27 27
29 20 2E 20 22 27 2C 0A 20 20 20 20 20 20 20 20 27 22 20 2E 20 50 4D 41
5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24 76 65 72 73 69 6F 6E 29
20 2E 20 22 27 2C 0A 20 20 20 20 20 20 20 20 27 22 20 2E 20 50 4D 41 5F
73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24 64 61 74 65 29 20 2E 20 22
27 2C 0A 20 20 20 20 20 20 20 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41
64 64 73 6C 61 73 68 65 73 28 24 64 61 74 65 29 20 2E 20 22 27 2C 0A 20
20 20 20 20 20 20 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C
61 73 68 65 73 28 27 27 29 20 2E 20 22 27 2C 0A 20 20 20 20 20 20 20 20
27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24
63 72 65 61 74 65 5F 73 71 6C 29 20 2E 20 22 27 2C 0A 20 20 20 20 20 20
20 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73
28 22 5C 6E 22 29 20 2E 20 22 27 2C 0A 20 20 20 20 20 20 20 20 27 22 20
2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24 74 72 61
63 6B 69 6E 67 5F 73 65 74 29 20 2E 20 22 27 20 29 22 3B 0A 0A 20 20 20
20 20 20 20 20 24 72 65 73 75 6C 74 20 3D 20 50 4D 41 5F 71 75 65 72 79
5F 61 73 5F 63 6F 6E 74 72 6F 6C 75 73 65 72 28 24 73 71 6C 5F 71 75 65
72 79 29 3B 0A 0A 20 20 20 20 20 20 20 20 72 65 74 75 72 6E 20 24 72 65
73 75 6C 74 3B 0A 20 20 20 20 7D 0A 0A 0A 0A 20 20 20 20 2F 2A 2A 0A 20
20 20 20 20 2A 20 43 68 61 6E 67 65 73 20 74 72 61 63 6B 69 6E 67 20 6F
66 20 61 20 74 61 62 6C 65 2E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A
20 40 73 74 61 74 69 63 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40
70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 64 62 6E 61 6D 65 20 20 20
20 20 20 20 6E 61 6D 65 20 6F 66 20 64 61 74 61 62 61 73 65 0A 20 20 20
20 20 2A 20 40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 74 61 62 6C
65 6E 61 6D 65 20 20 20 20 6E 61 6D 65 20 6F 66 20 74 61 62 6C 65 0A 20
20 20 20 20 2A 20 40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 76 65
72 73 69 6F 6E 20 20 20 20 20 20 76 65 72 73 69 6F 6E 0A 20 20 20 20 20
2A 20 40 70 61 72 61 6D 20 20 69 6E 74 65 67 65 72 20 24 6E 65 77 5F 73
74 61 74 65 20 20 20 74 68 65 20 6E 65 77 20 73 74 61 74 65 20 6F 66 20
74 72 61 63 6B 69 6E 67 20 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20
40 72 65 74 75 72 6E 20 69 6E 74 20 72 65 73 75 6C 74 20 6F 66 20 53 51
4C 20 71 75 65 72 79 0A 20 20 20 20 20 2A 2F 0A 20 20 20 20 73 74 61 74
69 63 20 70 72 69 76 61 74 65 20 66 75 6E 63 74 69 6F 6E 20 63 68 61 6E
67 65 54 72 61 63 6B 69 6E 67 28 24 64 62 6E 61 6D 65 2C 20 24 74 61 62
6C 65 6E 61 6D 65 2C 20 24 76 65 72 73 69 6F 6E 2C 20 24 6E 65 77 5F 73
74 61 74 65 29 0A 20 20 20 20 7B 0A 20 20 20 20 20 20 20 20 24 73 71 6C
5F 71 75 65 72 79 20 3D 0A 20 20 20 20 20 20 20 20 22 20 55 50 44 41 54
45 20 22 20 2E 20 73 65 6C 66 3A 3A 24 70 6D 61 5F 74 61 62 6C 65 20 2E
0A 20 20 20 20 20 20 20 20 22 20 53 45 54 20 60 74 72 61 63 6B 69 6E 67
5F 61 63 74 69 76 65 60 20 3D 20 27 22 20 2E 20 24 6E 65 77 5F 73 74 61
74 65 20 2E 20 22 27 20 22 20 2E 0A 20 20 20 20 20 20 20 20 22 20 57 48
45 52 45 20 60 64 62 5F 6E 61 6D 65 60 20 3D 20 27 22 20 2E 20 50 4D 41
5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24 64 62 6E 61 6D 65 29 20
2E 20 22 27 20 22 20 2E 0A 20 20 20 20 20 20 20 20 22 20 41 4E 44 20 60
74 61 62 6C 65 5F 6E 61 6D 65 60 20 3D 20 27 22 20 2E 20 50 4D 41 5F 73
71 6C 41 64 64 73 6C 61 73 68 65 73 28 24 74 61 62 6C 65 6E 61 6D 65 29
20 2E 20 22 27 20 22 20 2E 0A 20 20 20 20 20 20 20 20 22 20 41 4E 44 20
60 76 65 72 73 69 6F 6E 60 20 3D 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C
41 64 64 73 6C 61 73 68 65 73 28 24 76 65 72 73 69 6F 6E 29 20 2E 20 22
27 20 22 3B 0A 0A 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 20 3D 20
50 4D 41 5F 71 75 65 72 79 5F 61 73 5F 63 6F 6E 74 72 6F 6C 75 73 65 72
28 24 73 71 6C 5F 71 75 65 72 79 29 3B 0A 0A 20 20 20 20 20 20 20 20 72
65 74 75 72 6E 20 24 72 65 73 75 6C 74 3B 0A 20 20 20 20 7D 0A 0A 20 20
20 20 2F 2A 2A 0A 20 20 20 20 20 2A 20 41 63 74 69 76 61 74 65 73 20 74
72 61 63 6B 69 6E 67 20 6F 66 20 61 20 74 61 62 6C 65 2E 0A 20 20 20 20
20 2A 0A 20 20 20 20 20 2A 20 40 73 74 61 74 69 63 0A 20 20 20 20 20 2A
0A 20 20 20 20 20 2A 20 40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24
64 62 6E 61 6D 65 20 20 20 20 20 20 20 6E 61 6D 65 20 6F 66 20 64 61 74
61 62 61 73 65 0A 20 20 20 20 20 2A 20 40 70 61 72 61 6D 20 20 73 74 72
69 6E 67 20 24 74 61 62 6C 65 6E 61 6D 65 20 20 20 20 6E 61 6D 65 20 6F
66 20 74 61 62 6C 65 0A 20 20 20 20 20 2A 20 40 70 61 72 61 6D 20 20 73
74 72 69 6E 67 20 24 76 65 72 73 69 6F 6E 20 20 20 20 20 20 76 65 72 73
69 6F 6E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 72 65 74 75 72
6E 20 69 6E 74 20 72 65 73 75 6C 74 20 6F 66 20 53 51 4C 20 71 75 65 72
79 0A 20 20 20 20 20 2A 2F 0A 20 20 20 20 73 74 61 74 69 63 20 70 75 62
6C 69 63 20 66 75 6E 63 74 69 6F 6E 20 61 63 74 69 76 61 74 65 54 72 61
63 6B 69 6E 67 28 24 64 62 6E 61 6D 65 2C 20 24 74 61 62 6C 65 6E 61 6D
65 2C 20 24 76 65 72 73 69 6F 6E 29 0A 20 20 20 20 7B 0A 20 20 20 20 20
20 20 20 72 65 74 75 72 6E 20 73 65 6C 66 3A 3A 63 68 61 6E 67 65 54 72
61 63 6B 69 6E 67 28 24 64 62 6E 61 6D 65 2C 20 24 74 61 62 6C 65 6E 61
6D 65 2C 20 24 76 65 72 73 69 6F 6E 2C 20 31 29 3B 20 0A 20 20 20 20 7D
0A 0A 0A 20 20 20 20 2F 2A 2A 0A 20 20 20 20 20 2A 20 44 65 61 63 74 69
76 61 74 65 73 20 74 72 61 63 6B 69 6E 67 20 6F 66 20 61 20 74 61 62 6C
65 2E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 73 74 61 74 69 63
0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 70 61 72 61 6D 20 20 73
74 72 69 6E 67 20 24 64 62 6E 61 6D 65 20 20 20 20 20 20 20 6E 61 6D 65
20 6F 66 20 64 61 74 61 62 61 73 65 0A 20 20 20 20 20 2A 20 40 70 61 72
61 6D 20 20 73 74 72 69 6E 67 20 24 74 61 62 6C 65 6E 61 6D 65 20 20 20
20 6E 61 6D 65 20 6F 66 20 74 61 62 6C 65 0A 20 20 20 20 20 2A 20 40 70
61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 76 65 72 73 69 6F 6E 20 20 20
20 20 20 76 65 72 73 69 6F 6E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A
20 40 72 65 74 75 72 6E 20 69 6E 74 20 72 65 73 75 6C 74 20 6F 66 20 53
51 4C 20 71 75 65 72 79 0A 20 20 20 20 20 2A 2F 0A 20 20 20 20 73 74 61
74 69 63 20 70 75 62 6C 69 63 20 66 75 6E 63 74 69 6F 6E 20 64 65 61 63
74 69 76 61 74 65 54 72 61 63 6B 69 6E 67 28 24 64 62 6E 61 6D 65 2C 20
24 74 61 62 6C 65 6E 61 6D 65 2C 20 24 76 65 72 73 69 6F 6E 29 0A 20 20
20 20 7B 0A 20 20 20 20 20 20 20 20 72 65 74 75 72 6E 20 73 65 6C 66 3A
3A 63 68 61 6E 67 65 54 72 61 63 6B 69 6E 67 28 24 64 62 6E 61 6D 65 2C
20 24 74 61 62 6C 65 6E 61 6D 65 2C 20 24 76 65 72 73 69 6F 6E 2C 20 30
29 3B 20 0A 20 20 20 20 7D 0A 0A 0A 20 20 20 20 2F 2A 2A 0A 20 20 20 20
20 2A 20 47 65 74 73 20 74 68 65 20 6E 65 77 65 73 74 20 76 65 72 73 69
6F 6E 20 6F 66 20 61 20 74 72 61 63 6B 69 6E 67 20 6A 6F 62 0A 20 20 20
20 20 2A 20 28 69 6E 20 6F 74 68 65 72 20 77 6F 72 64 73 3A 20 67 65 74
73 20 74 68 65 20 48 45 41 44 20 76 65 72 73 69 6F 6E 29 2E 0A 20 20 20
20 20 2A 0A 20 20 20 20 20 2A 20 40 73 74 61 74 69 63 0A 20 20 20 20 20
2A 0A 20 20 20 20 20 2A 20 40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20
24 64 62 6E 61 6D 65 20 20 20 20 20 20 6E 61 6D 65 20 6F 66 20 64 61 74
61 62 61 73 65 0A 20 20 20 20 20 2A 20 40 70 61 72 61 6D 20 20 73 74 72
69 6E 67 20 24 74 61 62 6C 65 6E 61 6D 65 20 20 20 6E 61 6D 65 20 6F 66
20 74 61 62 6C 65 0A 20 20 20 20 20 2A 20 40 70 61 72 61 6D 20 20 73 74
72 69 6E 67 20 24 73 74 61 74 65 6D 65 6E 74 20 20 20 74 72 61 63 6B 65
64 20 73 74 61 74 65 6D 65 6E 74 0A 20 20 20 20 20 2A 0A 20 20 20 20 20
2A 20 40 72 65 74 75 72 6E 20 69 6E 74 20 28 2D 31 20 69 66 20 6E 6F 20
76 65 72 73 69 6F 6E 20 65 78 69 73 74 73 20 7C 20 3E 20 20 30 20 69 66
20 61 20 76 65 72 73 69 6F 6E 20 65 78 69 73 74 73 29 0A 20 20 20 20 20
2A 2F 0A 20 20 20 20 73 74 61 74 69 63 20 70 75 62 6C 69 63 20 66 75 6E
63 74 69 6F 6E 20 67 65 74 56 65 72 73 69 6F 6E 28 24 64 62 6E 61 6D 65
2C 20 24 74 61 62 6C 65 6E 61 6D 65 2C 20 24 73 74 61 74 65 6D 65 6E 74
20 3D 20 6E 75 6C 6C 29 0A 20 20 20 20 7B 0A 20 20 20 20 20 20 20 20 24
73 71 6C 5F 71 75 65 72 79 20 3D 0A 20 20 20 20 20 20 20 20 22 20 53 45
4C 45 43 54 20 4D 41 58 28 76 65 72 73 69 6F 6E 29 20 46 52 4F 4D 20 22
20 2E 20 73 65 6C 66 3A 3A 24 70 6D 61 5F 74 61 62 6C 65 20 2E 0A 20 20
20 20 20 20 20 20 22 20 57 48 45 52 45 20 60 64 62 5F 6E 61 6D 65 60 20
3D 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73
28 24 64 62 6E 61 6D 65 29 20 2E 20 22 27 20 22 20 2E 0A 20 20 20 20 20
20 20 20 22 20 41 4E 44 20 60 74 61 62 6C 65 5F 6E 61 6D 65 60 20 3D 20
27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24
74 61 62 6C 65 6E 61 6D 65 29 20 2E 20 22 27 20 22 3B 0A 0A 20 20 20 20
20 20 20 20 69 66 20 28 24 73 74 61 74 65 6D 65 6E 74 20 21 3D 20 22 22
29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 73 71 6C 5F 71 75 65
72 79 20 2E 3D 20 22 20 41 4E 44 20 46 49 4E 44 5F 49 4E 5F 53 45 54 28
27 22 20 2E 20 24 73 74 61 74 65 6D 65 6E 74 20 2E 20 22 27 2C 74 72 61
63 6B 69 6E 67 29 20 3E 20 30 22 20 3B 0A 20 20 20 20 20 20 20 20 7D 0A
20 20 20 20 20 20 20 20 24 72 6F 77 20 3D 20 50 4D 41 5F 44 42 49 5F 66
65 74 63 68 5F 61 72 72 61 79 28 50 4D 41 5F 71 75 65 72 79 5F 61 73 5F
63 6F 6E 74 72 6F 6C 75 73 65 72 28 24 73 71 6C 5F 71 75 65 72 79 29 29
3B 0A 20 20 20 20 20 20 20 20 69 66 20 28 69 73 73 65 74 28 24 72 6F 77
5B 30 5D 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 76 65 72
73 69 6F 6E 20 3D 20 24 72 6F 77 5B 30 5D 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 20 69 73 73 65 74 28 24 76
65 72 73 69 6F 6E 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24
76 65 72 73 69 6F 6E 20 3D 20 2D 31 3B 0A 20 20 20 20 20 20 20 20 7D 0A
20 20 20 20 20 20 20 20 72 65 74 75 72 6E 20 24 76 65 72 73 69 6F 6E 3B
0A 20 20 20 20 7D 0A 0A 0A 20 20 20 20 2F 2A 2A 0A 20 20 20 20 20 2A 20
47 65 74 73 20 74 68 65 20 72 65 63 6F 72 64 20 6F 66 20 61 20 74 72 61
63 6B 69 6E 67 20 6A 6F 62 2E 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A
20 40 73 74 61 74 69 63 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40
70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 64 62 6E 61 6D 65 20 20 20
20 20 20 6E 61 6D 65 20 6F 66 20 64 61 74 61 62 61 73 65 0A 20 20 20 20
20 2A 20 40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 74 61 62 6C 65
6E 61 6D 65 20 20 20 6E 61 6D 65 20 6F 66 20 74 61 62 6C 65 0A 20 20 20
20 20 2A 20 40 70 61 72 61 6D 20 20 73 74 72 69 6E 67 20 24 76 65 72 73
69 6F 6E 20 20 20 20 20 76 65 72 73 69 6F 6E 20 6E 75 6D 62 65 72 0A 20
20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 72 65 74 75 72 6E 20 6D 69 78
65 64 20 72 65 63 6F 72 64 20 44 44 4D 20 6C 6F 67 2C 20 44 44 4C 20 6C
6F 67 2C 20 73 74 72 75 63 74 75 72 65 20 73 6E 61 70 73 68 6F 74 2C 20
74 72 61 63 6B 65 64 20 73 74 61 74 65 6D 65 6E 74 73 2E 0A 20 20 20 20
20 2A 2F 0A 20 20 20 20 73 74 61 74 69 63 20 70 75 62 6C 69 63 20 66 75
6E 63 74 69 6F 6E 20 67 65 74 54 72 61 63 6B 65 64 44 61 74 61 28 24 64
62 6E 61 6D 65 2C 20 24 74 61 62 6C 65 6E 61 6D 65 2C 20 24 76 65 72 73
69 6F 6E 29 0A 20 20 20 20 7B 0A 20 20 20 20 20 20 20 20 69 66 20 28 21
20 69 73 73 65 74 28 73 65 6C 66 3A 3A 24 70 6D 61 5F 74 61 62 6C 65 29
29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 73 65 6C 66 3A 3A 69 6E
69 74 28 29 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20 20
24 73 71 6C 5F 71 75 65 72 79 20 3D 20 22 20 53 45 4C 45 43 54 20 2A 20
46 52 4F 4D 20 22 20 2E 20 73 65 6C 66 3A 3A 24 70 6D 61 5F 74 61 62 6C
65 20 2E 0A 20 20 20 20 20 20 20 20 20 20 20 20 22 20 57 48 45 52 45 20
60 64 62 5F 6E 61 6D 65 60 20 3D 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C
41 64 64 73 6C 61 73 68 65 73 28 24 64 62 6E 61 6D 65 29 20 2E 20 22 27
20 22 3B 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 20 65 6D 70 74 79 28
24 74 61 62 6C 65 6E 61 6D 65 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20
20 20 20 24 73 71 6C 5F 71 75 65 72 79 20 2E 3D 20 22 20 41 4E 44 20 60
74 61 62 6C 65 5F 6E 61 6D 65 60 20 3D 20 27 22 20 2E 20 50 4D 41 5F 73
71 6C 41 64 64 73 6C 61 73 68 65 73 28 24 74 61 62 6C 65 6E 61 6D 65 29
20 2E 22 27 20 22 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20
20 20 24 73 71 6C 5F 71 75 65 72 79 20 2E 3D 20 22 20 41 4E 44 20 60 76
65 72 73 69 6F 6E 60 20 3D 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64
64 73 6C 61 73 68 65 73 28 24 76 65 72 73 69 6F 6E 29 20 2E 22 27 20 22
2E 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22
20 4F 52 44 45 52 20 42 59 20 60 76 65 72 73 69 6F 6E 60 20 44 45 53 43
20 22 3B 0A 0A 20 20 20 20 20 20 20 20 24 6D 69 78 65 64 20 3D 20 50 4D
41 5F 44 42 49 5F 66 65 74 63 68 5F 61 72 72 61 79 28 50 4D 41 5F 71 75
65 72 79 5F 61 73 5F 63 6F 6E 74 72 6F 6C 75 73 65 72 28 24 73 71 6C 5F
71 75 65 72 79 29 29 3B 0A 0A 20 20 20 20 20 20 20 20 2F 2F 20 50 61 72
73 65 20 6C 6F 67 0A 20 20 20 20 20 20 20 20 24 6C 6F 67 5F 73 63 68 65
6D 61 5F 65 6E 74 72 69 65 73 20 3D 20 65 78 70 6C 6F 64 65 28 27 23 20
6C 6F 67 20 27 2C 20 20 24 6D 69 78 65 64 5B 27 73 63 68 65 6D 61 5F 73
71 6C 27 5D 29 3B 0A 20 20 20 20 20 20 20 20 24 6C 6F 67 5F 64 61 74 61
5F 65 6E 74 72 69 65 73 20 20 20 3D 20 65 78 70 6C 6F 64 65 28 27 23 20
6C 6F 67 20 27 2C 20 20 24 6D 69 78 65 64 5B 27 64 61 74 61 5F 73 71 6C
27 5D 29 3B 0A 0A 20 20 20 20 20 20 20 20 24 64 64 6C 5F 64 61 74 65 5F
66 72 6F 6D 20 3D 20 24 64 61 74 65 20 3D 20 64 61 74 65 28 27 59 2D 6D
2D 64 20 48 3A 69 3A 73 27 29 3B 0A 0A 20 20 20 20 20 20 20 20 24 64 64
6C 6F 67 20 3D 20 61 72 72 61 79 28 29 3B 0A 20 20 20 20 20 20 20 20 24
69 20 3D 20 30 3B 0A 0A 20 20 20 20 20 20 20 20 2F 2F 20 49 74 65 72 61
74 65 20 74 72 61 63 6B 65 64 20 64 61 74 61 20 64 65 66 69 6E 69 74 69
6F 6E 20 73 74 61 74 65 6D 65 6E 74 73 0A 20 20 20 20 20 20 20 20 2F 2F
20 46 6F 72 20 65 61 63 68 20 6C 6F 67 20 65 6E 74 72 79 20 77 65 20 77
61 6E 74 20 74 6F 20 67 65 74 20 64 61 74 65 2C 20 75 73 65 72 6E 61 6D
65 20 61 6E 64 20 73 74 61 74 65 6D 65 6E 74 0A 20 20 20 20 20 20 20 20
66 6F 72 65 61 63 68 20 28 24 6C 6F 67 5F 73 63 68 65 6D 61 5F 65 6E 74
72 69 65 73 20 61 73 20 24 6C 6F 67 5F 65 6E 74 72 79 29 20 7B 0A 20 20
20 20 20 20 20 20 20 20 20 20 69 66 20 28 74 72 69 6D 28 24 6C 6F 67 5F
65 6E 74 72 79 29 20 21 3D 20 27 27 29 20 7B 0A 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 24 64 61 74 65 20 20 20 20 20 20 3D 20 73 75 62
73 74 72 28 24 6C 6F 67 5F 65 6E 74 72 79 2C 20 30 2C 20 31 39 29 3B 0A
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 75 73 65 72 6E 61 6D
65 20 20 3D 20 73 75 62 73 74 72 28 24 6C 6F 67 5F 65 6E 74 72 79 2C 20
32 30 2C 20 73 74 72 70 6F 73 28 24 6C 6F 67 5F 65 6E 74 72 79 2C 20 22
5C 6E 22 29 20 2D 20 32 30 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 69 66 20 28 24 69 20 3D 3D 20 30 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 64 6C 5F 64 61 74 65
5F 66 72 6F 6D 20 3D 20 24 64 61 74 65 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 73 74 61 74 65 6D 65 6E 74 20 3D 20 72 74 72 69 6D 28 73 74 72 73
74 72 28 24 6C 6F 67 5F 65 6E 74 72 79 2C 20 22 5C 6E 22 29 29 3B 0A 0A
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 64 64 6C 6F 67 5B 5D
20 3D 20 61 72 72 61 79 28 20 27 64 61 74 65 27 20 3D 3E 20 24 64 61 74
65 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 20 20 20 20 20 20 20 20 20 20 27 75 73 65 72 6E 61 6D 65 27 3D
3E 20 24 75 73 65 72 6E 61 6D 65 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 20 20 20 20 20 20 20 20 20 20 27
73 74 61 74 65 6D 65 6E 74 27 20 3D 3E 20 24 73 74 61 74 65 6D 65 6E 74
20 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 69 2B 2B
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 24 64 61 74 65 5F 66 72 6F 6D 20 3D 20
24 64 64 6C 5F 64 61 74 65 5F 66 72 6F 6D 3B 0A 20 20 20 20 20 20 20 20
24 64 61 74 65 5F 74 6F 20 20 20 3D 20 24 64 64 6C 5F 64 61 74 65 5F 74
6F 20 3D 20 24 64 61 74 65 3B 0A 0A 20 20 20 20 20 20 20 20 24 64 6D 6C
5F 64 61 74 65 5F 66 72 6F 6D 20 3D 20 24 64 61 74 65 5F 66 72 6F 6D 3B
0A 0A 20 20 20 20 20 20 20 20 24 64 6D 6C 6F 67 20 3D 20 61 72 72 61 79
28 29 3B 0A 20 20 20 20 20 20 20 20 24 69 20 3D 20 30 3B 0A 0A 20 20 20
20 20 20 20 20 2F 2F 20 49 74 65 72 61 74 65 20 74 72 61 63 6B 65 64 20
64 61 74 61 20 6D 61 6E 69 70 75 6C 61 74 69 6F 6E 20 73 74 61 74 65 6D
65 6E 74 73 0A 20 20 20 20 20 20 20 20 2F 2F 20 46 6F 72 20 65 61 63 68
20 6C 6F 67 20 65 6E 74 72 79 20 77 65 20 77 61 6E 74 20 74 6F 20 67 65
74 20 64 61 74 65 2C 20 75 73 65 72 6E 61 6D 65 20 61 6E 64 20 73 74 61
74 65 6D 65 6E 74 0A 20 20 20 20 20 20 20 20 66 6F 72 65 61 63 68 20 28
24 6C 6F 67 5F 64 61 74 61 5F 65 6E 74 72 69 65 73 20 61 73 20 24 6C 6F
67 5F 65 6E 74 72 79 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 69
66 20 28 74 72 69 6D 28 24 6C 6F 67 5F 65 6E 74 72 79 29 20 21 3D 20 27
27 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61
74 65 20 20 20 20 20 20 3D 20 73 75 62 73 74 72 28 24 6C 6F 67 5F 65 6E
74 72 79 2C 20 30 2C 20 31 39 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 24 75 73 65 72 6E 61 6D 65 20 20 3D 20 73 75 62 73 74 72
28 24 6C 6F 67 5F 65 6E 74 72 79 2C 20 32 30 2C 20 73 74 72 70 6F 73 28
24 6C 6F 67 5F 65 6E 74 72 79 2C 20 22 5C 6E 22 29 20 2D 20 32 30 29 3B
0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 24 69 20
3D 3D 20 30 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 6D 6C 5F 64 61 74 65 5F 66 72 6F 6D 20 3D 20 24 64 61
74 65 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 73 74 61 74 65 6D 65 6E 74
20 3D 20 72 74 72 69 6D 28 73 74 72 73 74 72 28 24 6C 6F 67 5F 65 6E 74
72 79 2C 20 22 5C 6E 22 29 29 3B 0A 0A 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 24 64 6D 6C 6F 67 5B 5D 20 3D 20 61 72 72 61 79 28 20 27
64 61 74 65 27 20 3D 3E 20 24 64 61 74 65 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 20 20 20 20 20 20 20 20
20 20 27 75 73 65 72 6E 61 6D 65 27 20 3D 3E 20 24 75 73 65 72 6E 61 6D
65 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 20 20 20 20 20 20 20 20 20 20 27 73 74 61 74 65 6D 65 6E 74 27
20 3D 3E 20 24 73 74 61 74 65 6D 65 6E 74 20 29 3B 0A 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 24 69 2B 2B 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 24 64 6D 6C 5F 64 61 74 65 5F 74 6F 20 3D 20 24 64 61 74 65 3B 0A 0A
20 20 20 20 20 20 20 20 2F 2F 20 44 65 66 69 6E 65 20 62 65 67 69 6E 20
61 6E 64 20 65 6E 64 20 6F 66 20 64 61 74 65 20 72 61 6E 67 65 20 66 6F
72 20 62 6F 74 68 20 6C 6F 67 73 0A 20 20 20 20 20 20 20 20 69 66 20 28
73 74 72 74 6F 74 69 6D 65 28 24 64 64 6C 5F 64 61 74 65 5F 66 72 6F 6D
29 20 3C 3D 20 73 74 72 74 6F 74 69 6D 65 28 24 64 6D 6C 5F 64 61 74 65
5F 66 72 6F 6D 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 64
61 74 61 5B 27 64 61 74 65 5F 66 72 6F 6D 27 5D 20 3D 20 24 64 64 6C 5F
64 61 74 65 5F 66 72 6F 6D 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 64 61 74 61 5B 27 64
61 74 65 5F 66 72 6F 6D 27 5D 20 3D 20 24 64 6D 6C 5F 64 61 74 65 5F 66
72 6F 6D 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20 20 69
66 20 28 73 74 72 74 6F 74 69 6D 65 28 24 64 64 6C 5F 64 61 74 65 5F 74
6F 29 20 3E 3D 20 73 74 72 74 6F 74 69 6D 65 28 24 64 6D 6C 5F 64 61 74
65 5F 74 6F 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 64 61
74 61 5B 27 64 61 74 65 5F 74 6F 27 5D 20 3D 20 24 64 64 6C 5F 64 61 74
65 5F 74 6F 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 64 61 74 61 5B 27 64 61 74 65 5F 74
6F 27 5D 20 3D 20 24 64 6D 6C 5F 64 61 74 65 5F 74 6F 3B 0A 20 20 20 20
20 20 20 20 7D 0A 20 20 20 20 20 20 20 20 24 64 61 74 61 5B 27 64 64 6C
6F 67 27 5D 20 20 20 20 20 20 20 20 20 20 20 3D 20 24 64 64 6C 6F 67 3B
0A 20 20 20 20 20 20 20 20 24 64 61 74 61 5B 27 64 6D 6C 6F 67 27 5D 20
20 20 20 20 20 20 20 20 20 20 3D 20 24 64 6D 6C 6F 67 3B 0A 20 20 20 20
20 20 20 20 24 64 61 74 61 5B 27 74 72 61 63 6B 69 6E 67 27 5D 20 20 20
20 20 20 20 20 3D 20 24 6D 69 78 65 64 5B 27 74 72 61 63 6B 69 6E 67 27
5D 3B 0A 20 20 20 20 20 20 20 20 24 64 61 74 61 5B 27 73 63 68 65 6D 61
5F 73 6E 61 70 73 68 6F 74 27 5D 20 3D 20 24 6D 69 78 65 64 5B 27 73 63
68 65 6D 61 5F 73 6E 61 70 73 68 6F 74 27 5D 3B 0A 0A 20 20 20 20 20 20
20 20 72 65 74 75 72 6E 20 24 64 61 74 61 3B 0A 20 20 20 20 7D 0A 0A 0A
20 20 20 20 2F 2A 2A 0A 20 20 20 20 20 2A 20 50 61 72 73 65 73 20 61 20
71 75 65 72 79 2E 20 47 65 74 73 0A 20 20 20 20 20 2A 20 20 2D 20 73 74
61 74 65 6D 65 6E 74 20 69 64 65 6E 74 69 66 69 65 72 20 28 55 50 44 41
54 45 2C 20 41 4C 54 45 52 20 54 41 42 4C 45 2C 20 2E 2E 2E 29 0A 20 20
20 20 20 2A 20 20 2D 20 74 79 70 65 20 6F 66 20 73 74 61 74 65 6D 65 6E
74 2C 20 69 73 20 69 74 20 70 61 72 74 20 6F 66 20 44 44 4C 20 6F 72 20
44 4D 4C 20 3F 0A 20 20 20 20 20 2A 20 20 2D 20 74 61 62 6C 65 6E 61 6D
65 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40 73 74 61 74 69 63 0A
20 20 20 20 20 2A 20 40 74 6F 64 6F 3A 20 75 73 69 6E 67 20 50 4D 41 20
53 51 4C 20 50 61 72 73 65 72 20 77 68 65 6E 20 70 6F 73 73 69 62 6C 65
0A 20 20 20 20 20 2A 20 40 74 6F 64 6F 3A 20 73 75 70 70 6F 72 74 20 6D
75 6C 74 69 2D 74 61 62 6C 65 2F 76 69 65 77 20 64 72 6F 70 73 0A 20 20
20 20 20 2A 0A 20 20 20 20 20 2A 20 40 70 61 72 61 6D 20 73 74 72 69 6E
67 20 24 71 75 65 72 79 0A 20 20 20 20 20 2A 0A 20 20 20 20 20 2A 20 40
72 65 74 75 72 6E 20 6D 69 78 65 64 20 41 72 72 61 79 20 63 6F 6E 74 61
69 6E 69 6E 67 20 69 64 65 6E 74 69 66 69 65 72 2C 20 74 79 70 65 20 61
6E 64 20 74 61 62 6C 65 6E 61 6D 65 2E 0A 20 20 20 20 20 2A 0A 20 20 20
20 20 2A 2F 0A 20 20 20 20 73 74 61 74 69 63 20 70 75 62 6C 69 63 20 66
75 6E 63 74 69 6F 6E 20 70 61 72 73 65 51 75 65 72 79 28 24 71 75 65 72
79 29 0A 20 20 20 20 7B 0A 0A 20 20 20 20 20 20 20 20 2F 2F 20 55 73 61
67 65 20 6F 66 20 50 4D 41 5F 53 51 50 20 64 6F 65 73 20 6E 6F 74 20 77
6F 72 6B 20 68 65 72 65 0A 20 20 20 20 20 20 20 20 2F 2F 0A 20 20 20 20
20 20 20 20 2F 2F 20 72 65 71 75 69 72 65 5F 6F 6E 63 65 28 22 6C 69 62
72 61 72 69 65 73 2F 73 71 6C 70 61 72 73 65 72 2E 6C 69 62 2E 70 68 70
22 29 3B 0A 20 20 20 20 20 20 20 20 2F 2F 20 24 70 61 72 73 65 64 5F 73
71 6C 20 3D 20 50 4D 41 5F 53 51 50 5F 70 61 72 73 65 28 24 71 75 65 72
79 29 3B 0A 20 20 20 20 20 20 20 20 2F 2F 20 24 73 71 6C 5F 69 6E 66 6F
20 3D 20 50 4D 41 5F 53 51 50 5F 61 6E 61 6C 79 7A 65 28 24 70 61 72 73
65 64 5F 73 71 6C 29 3B 0A 0A 20 20 20 20 20 20 20 20 24 71 75 65 72 79
20 3D 20 73 74 72 5F 72 65 70 6C 61 63 65 28 22 5C 6E 22 2C 20 22 20 22
2C 20 24 71 75 65 72 79 29 3B 0A 20 20 20 20 20 20 20 20 24 71 75 65 72
79 20 3D 20 73 74 72 5F 72 65 70 6C 61 63 65 28 22 5C 72 22 2C 20 22 20
22 2C 20 24 71 75 65 72 79 29 3B 0A 0A 20 20 20 20 20 20 20 20 24 71 75
65 72 79 20 3D 20 74 72 69 6D 28 24 71 75 65 72 79 29 3B 0A 20 20 20 20
20 20 20 20 24 71 75 65 72 79 20 3D 20 74 72 69 6D 28 24 71 75 65 72 79
2C 20 27 20 2D 27 29 3B 0A 0A 20 20 20 20 20 20 20 20 24 74 6F 6B 65 6E
73 20 3D 20 65 78 70 6C 6F 64 65 28 22 20 22 2C 20 24 71 75 65 72 79 29
3B 0A 20 20 20 20 20 20 20 20 24 74 6F 6B 65 6E 73 20 3D 20 61 72 72 61
79 5F 6D 61 70 28 27 73 74 72 74 6F 75 70 70 65 72 27 2C 20 24 74 6F 6B
65 6E 73 29 3B 0A 0A 20 20 20 20 20 20 20 20 2F 2F 20 50 61 72 73 65 20
55 53 45 20 73 74 61 74 65 6D 65 6E 74 2C 20 6E 65 65 64 20 69 74 20 66
6F 72 20 53 51 4C 20 64 75 6D 70 20 69 6D 70 6F 72 74 73 0A 20 20 20 20
20 20 20 20 69 66 20 28 73 75 62 73 74 72 28 24 71 75 65 72 79 2C 20 30
2C 20 34 29 20 3D 3D 20 27 55 53 45 20 27 29 20 7B 0A 20 20 20 20 20 20
20 20 20 20 20 20 24 70 72 65 66 69 78 20 3D 20 65 78 70 6C 6F 64 65 28
27 55 53 45 20 27 2C 20 24 71 75 65 72 79 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 64 62 27 5D 20 3D 20 73 65
6C 66 3A 3A 67 65 74 54 61 62 6C 65 4E 61 6D 65 28 24 70 72 65 66 69 78
5B 31 5D 29 3B 0A 20 20 20 20 20 20 20 20 7D 0A 0A 20 20 20 20 20 20 20
20 2F 2A 0A 20 20 20 20 20 20 20 20 20 2A 20 44 44 4C 20 73 74 61 74 65
6D 65 6E 74 73 0A 20 20 20 20 20 20 20 20 20 2A 2F 0A 0A 20 20 20 20 20
20 20 20 24 72 65 73 75 6C 74 5B 27 74 79 70 65 27 5D 20 20 20 20 20 20
20 20 20 3D 20 27 44 44 4C 27 3B 0A 0A 20 20 20 20 20 20 20 20 2F 2F 20
50 61 72 73 65 20 43 52 45 41 54 45 20 56 49 45 57 20 73 74 61 74 65 6D
65 6E 74 0A 20 20 20 20 20 20 20 20 69 66 20 28 69 6E 5F 61 72 72 61 79
28 27 43 52 45 41 54 45 27 2C 20 24 74 6F 6B 65 6E 73 29 20 3D 3D 20 74
72 75 65 20 26 26 20 0A 20 20 20 20 20 20 20 20 20 20 20 69 6E 5F 61 72
72 61 79 28 27 56 49 45 57 27 2C 20 24 74 6F 6B 65 6E 73 29 20 3D 3D 20
74 72 75 65 20 26 26 20 0A 20 20 20 20 20 20 20 20 20 20 20 69 6E 5F 61
72 72 61 79 28 27 41 53 27 2C 20 24 74 6F 6B 65 6E 73 29 20 3D 3D 20 74
72 75 65 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73 75
6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 20 3D 20 27 43 52 45 41
54 45 20 56 49 45 57 27 3B 0A 0A 20 20 20 20 20 20 20 20 20 20 20 20 24
69 6E 64 65 78 20 3D 20 61 72 72 61 79 5F 73 65 61 72 63 68 28 27 56 49
45 57 27 2C 20 24 74 6F 6B 65 6E 73 29 3B 0A 0A 20 20 20 20 20 20 20 20
20 20 20 20 24 72 65 73 75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65 27 5D
20 3D 20 73 74 72 74 6F 6C 6F 77 65 72 28 73 65 6C 66 3A 3A 67 65 74 54
61 62 6C 65 4E 61 6D 65 28 24 74 6F 6B 65 6E 73 5B 24 69 6E 64 65 78 20
2B 20 31 5D 29 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 50 61 72 73 65 20 41 4C 54 45 52 20 56 49 45 57 20 73
74 61 74 65 6D 65 6E 74 0A 20 20 20 20 20 20 20 20 69 66 20 28 69 6E 5F
61 72 72 61 79 28 27 41 4C 54 45 52 27 2C 20 24 74 6F 6B 65 6E 73 29 20
3D 3D 20 74 72 75 65 20 26 26 20 0A 20 20 20 20 20 20 20 20 20 20 20 69
6E 5F 61 72 72 61 79 28 27 56 49 45 57 27 2C 20 24 74 6F 6B 65 6E 73 29
20 3D 3D 20 74 72 75 65 20 26 26 20 0A 20 20 20 20 20 20 20 20 20 20 20
69 6E 5F 61 72 72 61 79 28 27 41 53 27 2C 20 24 74 6F 6B 65 6E 73 29 20
3D 3D 20 74 72 75 65 20 26 26 20 0A 20 20 20 20 20 20 20 20 20 20 20 21
20 69 73 73 65 74 28 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69
65 72 27 5D 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65
73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 20 3D 20 27 41 4C
54 45 52 20 56 49 45 57 27 3B 0A 0A 20 20 20 20 20 20 20 20 20 20 20 20
24 69 6E 64 65 78 20 3D 20 61 72 72 61 79 5F 73 65 61 72 63 68 28 27 56
49 45 57 27 2C 20 24 74 6F 6B 65 6E 73 29 3B 0A 0A 20 20 20 20 20 20 20
20 20 20 20 20 24 72 65 73 75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65 27
5D 20 3D 20 73 74 72 74 6F 6C 6F 77 65 72 28 73 65 6C 66 3A 3A 67 65 74
54 61 62 6C 65 4E 61 6D 65 28 24 74 6F 6B 65 6E 73 5B 24 69 6E 64 65 78
20 2B 20 31 5D 29 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 50 61 72 73 65 20 44 52 4F 50 20 56 49 45 57 20 73
74 61 74 65 6D 65 6E 74 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 20 69
73 73 65 74 28 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72
27 5D 29 20 26 26 20 73 75 62 73 74 72 28 24 71 75 65 72 79 2C 20 30 2C
20 31 30 29 20 3D 3D 20 27 44 52 4F 50 20 56 49 45 57 20 27 29 20 7B 0A
20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5B 27 69 64 65
6E 74 69 66 69 65 72 27 5D 20 3D 20 27 44 52 4F 50 20 56 49 45 57 27 3B
0A 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 70 72 65 66 69 78 20 20 3D
20 65 78 70 6C 6F 64 65 28 27 44 52 4F 50 20 56 49 45 57 20 27 2C 20 24
71 75 65 72 79 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 73 74 72
20 3D 20 73 74 72 73 74 72 28 24 70 72 65 66 69 78 5B 31 5D 2C 20 27 49
46 20 45 58 49 53 54 53 27 29 3B 0A 0A 20 20 20 20 20 20 20 20 20 20 20
20 69 66 20 28 24 73 74 72 20 3D 3D 20 46 41 4C 53 45 20 29 20 7B 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 73 74 72 20 3D 20 24 70
72 65 66 69 78 5B 31 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 20 20 20 20 24 72 65 73 75 6C 74 5B 27 74 61 62
6C 65 6E 61 6D 65 27 5D 20 3D 20 73 65 6C 66 3A 3A 67 65 74 54 61 62 6C
65 4E 61 6D 65 28 24 73 74 72 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 50 61 72 73 65 20 43 52 45 41 54 45 20
44 41 54 41 42 41 53 45 20 73 74 61 74 65 6D 65 6E 74 0A 20 20 20 20 20
20 20 20 69 66 20 28 21 20 69 73 73 65 74 28 24 72 65 73 75 6C 74 5B 27
69 64 65 6E 74 69 66 69 65 72 27 5D 29 20 26 26 20 73 75 62 73 74 72 28
24 71 75 65 72 79 2C 20 30 2C 20 31 35 29 20 3D 3D 20 27 43 52 45 41 54
45 20 44 41 54 41 42 41 53 45 27 29 20 7B 0A 20 20 20 20 20 20 20 20 20
20 20 20 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D
20 3D 20 27 43 52 45 41 54 45 20 44 41 54 41 42 41 53 45 27 3B 0A 20 20
20 20 20 20 20 20 20 20 20 20 24 73 74 72 20 3D 20 73 74 72 5F 72 65 70
6C 61 63 65 28 27 43 52 45 41 54 45 20 44 41 54 41 42 41 53 45 27 2C 20
27 27 2C 20 24 71 75 65 72 79 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20
20 24 73 74 72 20 3D 20 73 74 72 5F 72 65 70 6C 61 63 65 28 27 49 46 20
4E 4F 54 20 45 58 49 53 54 53 27 2C 20 27 27 2C 20 24 73 74 72 29 3B 0A
0A 20 20 20 20 20 20 20 20 20 20 20 20 24 70 72 65 66 69 78 20 3D 20 65
78 70 6C 6F 64 65 28 27 44 45 46 41 55 4C 54 20 27 2C 20 24 73 74 72 29
3B 0A 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5B 27
74 61 62 6C 65 6E 61 6D 65 27 5D 20 3D 20 27 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 64 62 27 5D 20 3D 20 73
65 6C 66 3A 3A 67 65 74 54 61 62 6C 65 4E 61 6D 65 28 24 70 72 65 66 69
78 5B 30 5D 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 50 61 72 73 65 20 41 4C 54 45 52 20 44 41 54 41 42 41 53
45 20 73 74 61 74 65 6D 65 6E 74 0A 20 20 20 20 20 20 20 20 69 66 20 28
21 20 69 73 73 65 74 28 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66
69 65 72 27 5D 29 20 26 26 20 73 75 62 73 74 72 28 24 71 75 65 72 79 2C
20 30 2C 20 31 34 29 20 3D 3D 20 27 41 4C 54 45 52 20 44 41 54 41 42 41
53 45 27 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73 75
6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 20 3D 20 27 41 4C 54 45
52 20 44 41 54 41 42 41 53 45 27 3B 0A 20 20 20 20 20 20 20 20 20 20 20
20 24 72 65 73 75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65 27 5D 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 50 61 72 73 65 20 44 52 4F 50 20 44 41 54 41 42 41 53 45 20 73 74
61 74 65 6D 65 6E 74 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 20 69 73
73 65 74 28 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27
5D 29 20 26 26 20 73 75 62 73 74 72 28 24 71 75 65 72 79 2C 20 30 2C 20
31 33 29 20 3D 3D 20 27 44 52 4F 50 20 44 41 54 41 42 41 53 45 27 29 20
7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5B 27 69
64 65 6E 74 69 66 69 65 72 27 5D 20 3D 20 27 44 52 4F 50 20 44 41 54 41
42 41 53 45 27 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 73 74 72 20
3D 20 73 74 72 5F 72 65 70 6C 61 63 65 28 27 44 52 4F 50 20 44 41 54 41
42 41 53 45 27 2C 20 27 27 2C 20 24 71 75 65 72 79 29 3B 0A 20 20 20 20
20 20 20 20 20 20 20 20 24 73 74 72 20 3D 20 73 74 72 5F 72 65 70 6C 61
63 65 28 27 49 46 20 45 58 49 53 54 53 27 2C 20 27 27 2C 20 24 73 74 72
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 64 62 27 5D 20 3D 20 73 65 6C 66 3A 3A 67 65 74 54 61 62 6C 65 4E 61
6D 65 28 24 73 74 72 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 72
65 73 75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65 27 5D 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 50
61 72 73 65 20 43 52 45 41 54 45 20 54 41 42 4C 45 20 73 74 61 74 65 6D
65 6E 74 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 20 69 73 73 65 74 28
24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 29 20 26
26 20 73 75 62 73 74 72 28 24 71 75 65 72 79 2C 20 30 2C 20 31 32 29 20
3D 3D 20 27 43 52 45 41 54 45 20 54 41 42 4C 45 27 20 29 20 7B 0A 20 20
20 20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74
69 66 69 65 72 27 5D 20 3D 20 27 43 52 45 41 54 45 20 54 41 42 4C 45 27
3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 71 75 65 72 79 20 20 20 3D
20 73 74 72 5F 72 65 70 6C 61 63 65 28 27 49 46 20 4E 4F 54 20 45 58 49
53 54 53 27 2C 20 27 27 2C 20 24 71 75 65 72 79 29 3B 0A 20 20 20 20 20
20 20 20 20 20 20 20 24 70 72 65 66 69 78 20 20 3D 20 65 78 70 6C 6F 64
65 28 27 43 52 45 41 54 45 20 54 41 42 4C 45 20 27 2C 20 24 71 75 65 72
79 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 73 75 66 66 69 78 20
20 3D 20 65 78 70 6C 6F 64 65 28 27 28 27 2C 20 24 70 72 65 66 69 78 5B
31 5D 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74
5B 27 74 61 62 6C 65 6E 61 6D 65 27 5D 20 3D 20 73 65 6C 66 3A 3A 67 65
74 54 61 62 6C 65 4E 61 6D 65 28 24 73 75 66 66 69 78 5B 30 5D 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 50 61
72 73 65 20 41 4C 54 45 52 20 54 41 42 4C 45 20 73 74 61 74 65 6D 65 6E
74 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 20 69 73 73 65 74 28 24 72
65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 29 20 26 26 20
73 75 62 73 74 72 28 24 71 75 65 72 79 2C 20 30 2C 20 31 32 29 20 3D 3D
20 27 41 4C 54 45 52 20 54 41 42 4C 45 20 27 29 20 7B 0A 20 20 20 20 20
20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69
65 72 27 5D 20 3D 20 27 41 4C 54 45 52 20 54 41 42 4C 45 27 3B 0A 0A 20
20 20 20 20 20 20 20 20 20 20 20 24 70 72 65 66 69 78 20 20 3D 20 65 78
70 6C 6F 64 65 28 27 41 4C 54 45 52 20 54 41 42 4C 45 20 27 2C 20 24 71
75 65 72 79 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 73 75 66 66
69 78 20 20 3D 20 65 78 70 6C 6F 64 65 28 27 20 27 2C 20 24 70 72 65 66
69 78 5B 31 5D 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73
75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65 27 5D 20 20 3D 20 73 65 6C 66
3A 3A 67 65 74 54 61 62 6C 65 4E 61 6D 65 28 24 73 75 66 66 69 78 5B 30
5D 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 50 61 72 73 65 20 44 52 4F 50 20 54 41 42 4C 45 20 73 74 61 74 65
6D 65 6E 74 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 20 69 73 73 65 74
28 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 29 20
26 26 20 73 75 62 73 74 72 28 24 71 75 65 72 79 2C 20 30 2C 20 31 31 29
20 3D 3D 20 27 44 52 4F 50 20 54 41 42 4C 45 20 27 29 20 7B 0A 20 20 20
20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69
66 69 65 72 27 5D 20 3D 20 27 44 52 4F 50 20 54 41 42 4C 45 27 3B 0A 0A
20 20 20 20 20 20 20 20 20 20 20 20 24 70 72 65 66 69 78 20 20 3D 20 65
78 70 6C 6F 64 65 28 27 44 52 4F 50 20 54 41 42 4C 45 20 27 2C 20 24 71
75 65 72 79 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 73 74 72 20
3D 20 73 74 72 73 74 72 28 24 70 72 65 66 69 78 5B 31 5D 2C 20 27 49 46
20 45 58 49 53 54 53 27 29 3B 0A 0A 20 20 20 20 20 20 20 20 20 20 20 20
69 66 20 28 24 73 74 72 20 3D 3D 20 46 41 4C 53 45 20 29 20 7B 0A 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 73 74 72 20 3D 20 24 70 72
65 66 69 78 5B 31 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 20 20 20 20 24 72 65 73 75 6C 74 5B 27 74 61 62 6C
65 6E 61 6D 65 27 5D 20 3D 20 73 65 6C 66 3A 3A 67 65 74 54 61 62 6C 65
4E 61 6D 65 28 24 73 74 72 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 50 61 72 73 65 20 43 52 45 41 54 45 20 49
4E 44 45 58 20 73 74 61 74 65 6D 65 6E 74 0A 20 20 20 20 20 20 20 20 69
66 20 28 21 20 69 73 73 65 74 28 24 72 65 73 75 6C 74 5B 27 69 64 65 6E
74 69 66 69 65 72 27 5D 29 20 26 26 20 0A 20 20 20 20 20 20 20 20 20 20
20 20 28 20 20 20 73 75 62 73 74 72 28 24 71 75 65 72 79 2C 20 30 2C 20
31 32 29 20 3D 3D 20 27 43 52 45 41 54 45 20 49 4E 44 45 58 27 20 7C 7C
20 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 71 75 65 72 79 2C 20 30 2C 20 31 39 29 20 3D 3D 20 27 43 52 45 41
54 45 20 55 4E 49 51 55 45 20 49 4E 44 45 58 27 20 7C 7C 20 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 71 75 65
72 79 2C 20 30 2C 20 32 30 29 20 3D 3D 20 27 43 52 45 41 54 45 20 53 50
41 54 49 41 4C 20 49 4E 44 45 58 27 0A 20 20 20 20 20 20 20 20 20 20 20
20 29 0A 20 20 20 20 20 20 20 20 29 20 7B 0A 20 20 20 20 20 20 20 20 20
20 20 20 20 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27
5D 20 3D 20 27 43 52 45 41 54 45 20 49 4E 44 45 58 27 3B 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 24 70 72 65 66 69 78 20 3D 20 65 78 70 6C 6F
64 65 28 27 4F 4E 20 27 2C 20 24 71 75 65 72 79 29 3B 0A 20 20 20 20 20
20 20 20 20 20 20 20 20 24 73 75 66 66 69 78 20 3D 20 65 78 70 6C 6F 64
65 28 27 28 27 2C 20 24 70 72 65 66 69 78 5B 31 5D 29 3B 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5B 27 74 61 62 6C 65 6E
61 6D 65 27 5D 20 3D 20 73 65 6C 66 3A 3A 67 65 74 54 61 62 6C 65 4E 61
6D 65 28 24 73 75 66 66 69 78 5B 30 5D 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 50 61 72 73 65 20 44 52 4F 50
20 49 4E 44 45 58 20 73 74 61 74 65 6D 65 6E 74 0A 20 20 20 20 20 20 20
20 69 66 20 28 21 20 69 73 73 65 74 28 24 72 65 73 75 6C 74 5B 27 69 64
65 6E 74 69 66 69 65 72 27 5D 29 20 26 26 20 73 75 62 73 74 72 28 24 71
75 65 72 79 2C 20 30 2C 20 31 30 29 20 3D 3D 20 27 44 52 4F 50 20 49 4E
44 45 58 27 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65
73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 20 3D 20 27 44 52
4F 50 20 49 4E 44 45 58 27 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20
24 70 72 65 66 69 78 20 3D 20 65 78 70 6C 6F 64 65 28 27 4F 4E 20 27 2C
20 24 71 75 65 72 79 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 24
72 65 73 75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65 27 5D 20 3D 20 73 65
6C 66 3A 3A 67 65 74 54 61 62 6C 65 4E 61 6D 65 28 24 70 72 65 66 69 78
5B 31 5D 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 50 61 72 73 65 20 52 45 4E 41 4D 45 20 54 41 42 4C 45 20 73
74 61 74 65 6D 65 6E 74 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 20 69
73 73 65 74 28 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72
27 5D 29 20 26 26 20 73 75 62 73 74 72 28 24 71 75 65 72 79 2C 20 30 2C
20 31 33 29 20 3D 3D 20 27 52 45 4E 41 4D 45 20 54 41 42 4C 45 20 27 29
20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5B 27
69 64 65 6E 74 69 66 69 65 72 27 5D 20 3D 20 27 52 45 4E 41 4D 45 20 54
41 42 4C 45 27 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 70 72 65 66
69 78 20 3D 20 65 78 70 6C 6F 64 65 28 27 52 45 4E 41 4D 45 20 54 41 42
4C 45 20 27 2C 20 24 71 75 65 72 79 29 3B 0A 20 20 20 20 20 20 20 20 20
20 20 20 24 6E 61 6D 65 73 20 20 3D 20 65 78 70 6C 6F 64 65 28 27 20 54
4F 20 27 2C 20 24 70 72 65 66 69 78 5B 31 5D 29 3B 0A 20 20 20 20 20 20
20 20 20 20 20 20 24 72 65 73 75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65
27 5D 20 20 20 20 20 20 3D 20 73 65 6C 66 3A 3A 67 65 74 54 61 62 6C 65
4E 61 6D 65 28 24 6E 61 6D 65 73 5B 30 5D 29 3B 0A 20 20 20 20 20 20 20
20 20 20 20 20 24 72 65 73 75 6C 74 5B 22 74 61 62 6C 65 6E 61 6D 65 5F
61 66 74 65 72 5F 72 65 6E 61 6D 65 22 5D 20 20 3D 20 73 65 6C 66 3A 3A
67 65 74 54 61 62 6C 65 4E 61 6D 65 28 24 6E 61 6D 65 73 5B 31 5D 29 3B
0A 20 20 20 20 20 20 20 20 7D 0A 0A 20 20 20 20 20 20 20 20 2F 2A 0A 20
20 20 20 20 20 20 20 20 2A 20 44 4D 4C 20 73 74 61 74 65 6D 65 6E 74 73
0A 20 20 20 20 20 20 20 20 20 2A 2F 0A 0A 20 20 20 20 20 20 20 20 69 66
20 28 21 20 69 73 73 65 74 28 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74
69 66 69 65 72 27 5D 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20
24 72 65 73 75 6C 74 5B 22 74 79 70 65 22 5D 20 20 20 20 20 20 20 3D 20
27 44 4D 4C 27 3B 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20
20 2F 2F 20 50 61 72 73 65 20 55 50 44 41 54 45 20 73 74 61 74 65 6D 65
6E 74 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 20 69 73 73 65 74 28 24
72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 29 20 26 26
20 73 75 62 73 74 72 28 24 71 75 65 72 79 2C 20 30 2C 20 36 29 20 3D 3D
20 27 55 50 44 41 54 45 27 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20
20 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 20 3D
20 27 55 50 44 41 54 45 27 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24
70 72 65 66 69 78 20 20 3D 20 65 78 70 6C 6F 64 65 28 27 55 50 44 41 54
45 20 27 2C 20 24 71 75 65 72 79 29 3B 0A 20 20 20 20 20 20 20 20 20 20
20 20 24 73 75 66 66 69 78 20 20 3D 20 65 78 70 6C 6F 64 65 28 27 20 27
2C 20 24 70 72 65 66 69 78 5B 31 5D 29 3B 0A 20 20 20 20 20 20 20 20 20
20 20 20 24 72 65 73 75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65 27 5D 20
3D 20 73 65 6C 66 3A 3A 67 65 74 54 61 62 6C 65 4E 61 6D 65 28 24 73 75
66 66 69 78 5B 30 5D 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 50 61 72 73 65 20 49 4E 53 45 52 54 20 49 4E 54
4F 20 73 74 61 74 65 6D 65 6E 74 0A 20 20 20 20 20 20 20 20 69 66 20 28
21 20 69 73 73 65 74 28 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66
69 65 72 27 5D 29 20 26 26 20 73 75 62 73 74 72 28 24 71 75 65 72 79 2C
20 30 2C 20 31 31 20 29 20 3D 3D 20 27 49 4E 53 45 52 54 20 49 4E 54 4F
27 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74
5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 20 3D 20 27 49 4E 53 45 52 54
27 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 70 72 65 66 69 78 20 20
3D 20 65 78 70 6C 6F 64 65 28 27 49 4E 53 45 52 54 20 49 4E 54 4F 27 2C
20 24 71 75 65 72 79 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24 73
75 66 66 69 78 20 20 3D 20 65 78 70 6C 6F 64 65 28 27 28 27 2C 20 24 70
72 65 66 69 78 5B 31 5D 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20 24
72 65 73 75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65 27 5D 20 3D 20 73 65
6C 66 3A 3A 67 65 74 54 61 62 6C 65 4E 61 6D 65 28 24 73 75 66 66 69 78
5B 30 5D 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 50 61 72 73 65 20 44 45 4C 45 54 45 20 73 74 61 74 65 6D 65
6E 74 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 20 69 73 73 65 74 28 24
72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 29 20 26 26
20 73 75 62 73 74 72 28 24 71 75 65 72 79 2C 20 30 2C 20 36 20 29 20 3D
3D 20 27 44 45 4C 45 54 45 27 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20
20 20 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 20
3D 20 27 44 45 4C 45 54 45 27 3B 0A 20 20 20 20 20 20 20 20 20 20 20 20
24 70 72 65 66 69 78 20 20 3D 20 65 78 70 6C 6F 64 65 28 27 46 52 4F 4D
20 27 2C 20 24 71 75 65 72 79 29 3B 0A 20 20 20 20 20 20 20 20 20 20 20
20 24 73 75 66 66 69 78 20 20 3D 20 65 78 70 6C 6F 64 65 28 27 20 27 2C
20 24 70 72 65 66 69 78 5B 31 5D 29 3B 0A 20 20 20 20 20 20 20 20 20 20
20 20 24 72 65 73 75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65 27 5D 20 3D
20 73 65 6C 66 3A 3A 67 65 74 54 61 62 6C 65 4E 61 6D 65 28 24 73 75 66
66 69 78 5B 30 5D 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 50 61 72 73 65 20 54 52 55 4E 43 41 54 45 20 73 74
61 74 65 6D 65 6E 74 0A 20 20 20 20 20 20 20 20 69 66 20 28 21 20 69 73
73 65 74 28 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27
5D 29 20 26 26 20 73 75 62 73 74 72 28 24 71 75 65 72 79 2C 20 30 2C 20
38 20 29 20 3D 3D 20 27 54 52 55 4E 43 41 54 45 27 29 20 7B 0A 20 20 20
20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69
66 69 65 72 27 5D 20 3D 20 27 54 52 55 4E 43 41 54 45 27 3B 0A 20 20 20
20 20 20 20 20 20 20 20 20 24 70 72 65 66 69 78 20 20 3D 20 65 78 70 6C
6F 64 65 28 27 54 52 55 4E 43 41 54 45 27 2C 20 24 71 75 65 72 79 29 3B
0A 20 20 20 20 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 5B 27 74 61
62 6C 65 6E 61 6D 65 27 5D 20 3D 20 73 65 6C 66 3A 3A 67 65 74 54 61 62
6C 65 4E 61 6D 65 28 24 70 72 65 66 69 78 5B 31 5D 29 3B 0A 20 20 20 20
20 20 20 20 7D 0A 0A 20 20 20 20 20 20 20 20 72 65 74 75 72 6E 20 24 72
65 73 75 6C 74 3B 0A 20 20 20 20 7D 0A 0A 0A 20 20 20 20 2F 2A 2A 0A 20
20 20 20 20 2A 20 41 6E 61 6C 79 7A 65 73 20 61 20 67 69 76 65 6E 20 53
51 4C 20 73 74 61 74 65 6D 65 6E 74 20 61 6E 64 20 73 61 76 65 73 20 74
72 61 63 6B 69 6E 67 20 64 61 74 61 2E 0A 20 20 20 20 20 2A 0A 20 20 20
20 20 2A 0A 20 20 20 20 20 2A 20 40 73 74 61 74 69 63 0A 20 20 20 20 20
2A 20 40 70 61 72 61 6D 20 20 20 73 74 72 69 6E 67 20 24 71 75 65 72 79
20 61 20 53 51 4C 20 71 75 65 72 79 0A 20 20 20 20 20 2A 2F 0A 20 20 20
20 73 74 61 74 69 63 20 70 75 62 6C 69 63 20 66 75 6E 63 74 69 6F 6E 20
68 61 6E 64 6C 65 51 75 65 72 79 28 24 71 75 65 72 79 29 0A 20 20 20 20
7B 0A 20 20 20 20 20 20 20 20 2F 2F 20 49 66 20 71 75 65 72 79 20 69 73
20 6D 61 72 6B 65 64 20 61 73 20 75 6E 74 6F 75 63 68 61 62 6C 65 2C 20
6C 65 61 76 65 0A 20 20 20 20 20 20 20 20 69 66 20 28 73 74 72 73 74 72
28 24 71 75 65 72 79 2C 20 22 2F 2A 4E 4F 54 52 41 43 4B 2A 2F 22 29 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 0A 20 20 20 20 20 20 20 20
69 66 20 28 21 20 28 73 75 62 73 74 72 28 24 71 75 65 72 79 2C 20 2D 31
29 20 3D 3D 20 27 3B 27 29 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20
20 24 71 75 65 72 79 20 3D 20 24 71 75 65 72 79 20 2E 20 22 3B 5C 6E 22
3B 0A 20 20 20 20 20 20 20 20 7D 0A 20 20 20 20 20 20 20 20 2F 2F 20 47
65 74 20 73 6F 6D 65 20 69 6E 66 6F 72 6D 61 74 69 6F 6E 20 61 62 6F 75
74 20 71 75 65 72 79 0A 20 20 20 20 20 20 20 20 24 72 65 73 75 6C 74 20
3D 20 73 65 6C 66 3A 3A 70 61 72 73 65 51 75 65 72 79 28 24 71 75 65 72
79 29 3B 0A 0A 20 20 20 20 20 20 20 20 2F 2F 20 47 65 74 20 64 61 74 61
62 61 73 65 20 6E 61 6D 65 0A 20 20 20 20 20 20 20 20 24 64 62 6E 61 6D
65 20 3D 20 74 72 69 6D 28 24 47 4C 4F 42 41 4C 53 5B 27 64 62 27 5D 2C
20 27 60 27 29 3B 0A 20 20 20 20 20 20 20 20 2F 2F 20 24 64 62 6E 61 6D
65 20 63 61 6E 20 62 65 20 65 6D 70 74 79 2C 20 66 6F 72 20 65 78 61 6D
70 6C 65 20 77 68 65 6E 20 63 6F 6D 69 6E 67 20 66 72 6F 6D 20 53 79 6E
63 68 72 6F 6E 69 7A 65 0A 20 20 20 20 20 20 20 20 2F 2F 20 61 6E 64 20
74 68 69 73 20 69 73 20 61 20 71 75 65 72 79 20 66 6F 72 20 74 68 65 20
72 65 6D 6F 74 65 20 73 65 72 76 65 72 0A 20 20 20 20 20 20 20 20 69 66
20 28 65 6D 70 74 79 28 24 64 62 6E 61 6D 65 29 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 0A 20 20 20 20 20 20 20 20 2F 2F 20 49 66 20 77
65 20 66 6F 75 6E 64 20 61 20 76 61 6C 69 64 20 73 74 61 74 65 6D 65 6E
74 0A 20 20 20 20 20 20 20 20 69 66 20 28 69 73 73 65 74 28 24 72 65 73
75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 29 29 20 7B 0A 20 20
20 20 20 20 20 20 20 20 20 20 24 76 65 72 73 69 6F 6E 20 3D 20 73 65 6C
66 3A 3A 67 65 74 56 65 72 73 69 6F 6E 28 24 64 62 6E 61 6D 65 2C 20 24
72 65 73 75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65 27 5D 2C 20 24 72 65
73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 29 3B 0A 0A 20 20
20 20 20 20 20 20 20 20 20 20 2F 2F 20 49 66 20 76 65 72 73 69 6F 6E 20
6E 6F 74 20 65 78 69 73 74 73 20 61 6E 64 20 61 75 74 6F 2D 63 72 65 61
74 69 6F 6E 20 69 73 20 65 6E 61 62 6C 65 64 0A 20 20 20 20 20 20 20 20
20 20 20 20 69 66 20 28 73 65 6C 66 3A 3A 24 76 65 72 73 69 6F 6E 5F 61
75 74 6F 5F 63 72 65 61 74 65 20 3D 3D 20 74 72 75 65 0A 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 26 26 20 73 65 6C 66 3A 3A 69 73 54 72
61 63 6B 65 64 28 24 64 62 6E 61 6D 65 2C 20 24 72 65 73 75 6C 74 5B 27
74 61 62 6C 65 6E 61 6D 65 27 5D 29 20 3D 3D 20 66 61 6C 73 65 20 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 26 26 20 24 76 65 72 73 69
6F 6E 20 3D 3D 20 2D 31 29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 2F 2F 20 43 72 65 61 74 65 20 74 68 65 20 76 65 72 73 69 6F
6E 0A 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 77 69 74 63
68 20 28 24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D
29 20 7B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63 61 73 65
20 27 43 52 45 41 54 45 20 54 41 42 4C 45 27 3A 0A 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 73 65 6C 66 3A 3A 63 72 65 61 74
65 56 65 72 73 69 6F 6E 28 24 64 62 6E 61 6D 65 2C 20 24 72 65 73 75 6C
74 5B 27 74 61 62 6C 65 6E 61 6D 65 27 5D 2C 20 27 31 27 29 3B 0A 20 20
20 20 20 20 20 20 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 20 20 20 20 20 20 20 20 63 61 73 65 20 27 43
52 45 41 54 45 20 56 49 45 57 27 3A 0A 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 20 20 73 65 6C 66 3A 3A 63 72 65 61 74 65 56 65 72
73 69 6F 6E 28 24 64 62 6E 61 6D 65 2C 20 24 72 65 73 75 6C 74 5B 27 74
61 62 6C 65 6E 61 6D 65 27 5D 2C 20 27 31 27 2C 20 27 27 2C 20 74 72 75
65 29 3B 0A 20 20 20 20 20 20 20 20 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 20 20 20 20 20 20 20 20 63
61 73 65 20 27 43 52 45 41 54 45 20 44 41 54 41 42 41 53 45 27 3A 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 65 6C 66 3A
3A 63 72 65 61 74 65 44 61 74 61 62 61 73 65 56 65 72 73 69 6F 6E 28 24
64 62 6E 61 6D 65 2C 20 27 31 27 2C 20 24 71 75 65 72 79 29 3B 0A 20 20
20 20 20 20 20 20 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 20 20 20 20 20 20 20 20 7D 20 2F 2F 20 65 6E
64 20 73 77 69 74 63 68 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 2F 2F 20 49 66 20 76 65 72 73 69 6F
6E 20 65 78 69 73 74 73 0A 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20
28 73 65 6C 66 3A 3A 69 73 54 72 61 63 6B 65 64 28 24 64 62 6E 61 6D 65
2C 20 24 72 65 73 75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65 27 5D 29 20
26 26 20 24 76 65 72 73 69 6F 6E 20 21 3D 20 2D 31 29 20 7B 0A 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 24 72 65 73 75 6C 74
5B 27 74 79 70 65 27 5D 20 3D 3D 20 27 44 44 4C 27 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 73 61 76 65 5F 74
6F 20 3D 20 27 73 63 68 65 6D 61 5F 73 71 6C 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 69 66 20 28 24 72 65 73
75 6C 74 5B 27 74 79 70 65 27 5D 20 3D 3D 20 27 44 4D 4C 27 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 73 61 76
65 5F 74 6F 20 3D 20 27 64 61 74 61 5F 73 71 6C 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 24 73 61 76 65 5F 74 6F
20 3D 20 27 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 20 20 20 20 24 64 61 74 65 20 20
3D 20 64 61 74 65 28 27 59 2D 6D 2D 64 20 48 3A 69 3A 73 27 29 3B 0A 0A
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 43 75 74 20 6F
66 66 20 60 64 62 6E 61 6D 65 60 2E 20 66 72 6F 6D 20 71 75 65 72 79 0A
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 71 75 65 72 79 20 3D
20 70 72 65 67 5F 72 65 70 6C 61 63 65 28 27 2F 60 27 20 2E 20 24 64 62
6E 61 6D 65 20 2E 20 27 60 5C 73 3F 5C 2E 2F 27 2C 20 27 27 2C 20 24 71
75 65 72 79 29 3B 0A 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2F 2F 20 41 64 64 20 6C 6F 67 20 69 6E 66 6F 72 6D 61 74 69 6F 6E 0A 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 71 75 65 72 79 20 3D 20
73 65 6C 66 3A 3A 67 65 74 4C 6F 67 43 6F 6D 6D 65 6E 74 28 29 20 2E 20
24 71 75 65 72 79 20 3B 0A 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 2F 2F 20 4D 61 72 6B 20 69 74 20 61 73 20 75 6E 74 6F 75 63 68 61
62 6C 65 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 24 73 71 6C
5F 71 75 65 72 79 20 3D 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 22 20 2F 2A 4E 4F 54 52 41 43 4B 2A 2F 5C 6E 22 20 2E 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 22 20 55 50 44 41 54 45 20 22 20 2E
20 73 65 6C 66 3A 3A 24 70 6D 61 5F 74 61 62 6C 65 20 2E 0A 20 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 22 20 53 45 54 20 22 20 2E 20 50 4D
41 5F 62 61 63 6B 71 75 6F 74 65 28 24 73 61 76 65 5F 74 6F 29 20 2E 22
20 3D 20 43 4F 4E 43 41 54 28 20 22 20 2E 20 50 4D 41 5F 62 61 63 6B 71
75 6F 74 65 28 24 73 61 76 65 5F 74 6F 29 20 2E 20 22 2C 27 5C 6E 22 20
2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24 71 75 65
72 79 29 20 2E 20 22 27 29 20 2C 22 20 2E 0A 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 22 20 60 64 61 74 65 5F 75 70 64 61 74 65 64 60 20
3D 20 27 22 20 2E 20 24 64 61 74 65 20 2E 20 22 27 20 22 3B 0A 0A 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 49 66 20 74 61 62 6C
65 20 77 61 73 20 72 65 6E 61 6D 65 64 20 77 65 20 68 61 76 65 20 74 6F
20 63 68 61 6E 67 65 20 74 68 65 20 74 61 62 6C 65 6E 61 6D 65 20 61 74
74 72 69 62 75 74 65 20 69 6E 20 70 6D 61 5F 74 72 61 63 6B 69 6E 67 20
74 6F 6F 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28
24 72 65 73 75 6C 74 5B 27 69 64 65 6E 74 69 66 69 65 72 27 5D 20 3D 3D
20 27 52 45 4E 41 4D 45 20 54 41 42 4C 45 27 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 73 71 6C 5F 71 75 65 72
79 20 2E 3D 20 27 2C 20 60 74 61 62 6C 65 5F 6E 61 6D 65 60 20 3D 20 5C
27 27 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24
72 65 73 75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65 5F 61 66 74 65 72 5F
72 65 6E 61 6D 65 27 5D 29 20 2E 20 27 5C 27 20 27 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 53 61 76 65 20 74 68 65 20 74 72 61 63 6B 69
6E 67 20 69 6E 66 6F 72 6D 61 74 69 6F 6E 20 6F 6E 6C 79 20 66 6F 72 0A
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 20 20 20 20 31
2E 20 74 68 65 20 64 61 74 61 62 61 73 65 0A 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 2F 2F 20 20 20 20 20 32 2E 20 74 68 65 20 74 61 62
6C 65 20 2F 20 76 69 65 77 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 2F 2F 20 20 20 20 20 33 2E 20 74 68 65 20 73 74 61 74 65 6D 65 6E
74 73 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2F 2F 20 77 65
20 77 61 6E 74 20 74 6F 20 74 72 61 63 6B 0A 20 20 20 20 20 20 20 20 20
20 20 20 20 20 20 20 24 73 71 6C 5F 71 75 65 72 79 20 2E 3D 0A 20 20 20
20 20 20 20 20 20 20 20 20 20 20 20 20 22 20 57 48 45 52 45 20 46 49 4E
44 5F 49 4E 5F 53 45 54 28 27 22 20 2E 20 24 72 65 73 75 6C 74 5B 27 69
64 65 6E 74 69 66 69 65 72 27 5D 20 2E 20 22 27 2C 74 72 61 63 6B 69 6E
67 29 20 3E 20 30 22 20 2E 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20 20 22 20 41 4E 44 20 60 64 62 5F 6E 61 6D 65 60 20 3D 20 27 22 20 2E
20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24 64 62 6E 61
6D 65 29 20 2E 20 22 27 20 22 20 2E 0A 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 20 22 20 41 4E 44 20 60 74 61 62 6C 65 5F 6E 61 6D 65 60 20
3D 20 27 22 20 2E 20 50 4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73
28 24 72 65 73 75 6C 74 5B 27 74 61 62 6C 65 6E 61 6D 65 27 5D 29 20 2E
20 22 27 20 22 20 2E 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
22 20 41 4E 44 20 60 76 65 72 73 69 6F 6E 60 20 3D 20 27 22 20 2E 20 50
4D 41 5F 73 71 6C 41 64 64 73 6C 61 73 68 65 73 28 24 76 65 72 73 69 6F
6E 29 20 2E 20 22 27 20 22 3B 0A 0A 20 20 20 20 20 20 20 20 20 20 20 20
20 20 20 20 24 72 65 73 75 6C 74 20 3D 20 50 4D 41 5F 71 75 65 72 79 5F
61 73 5F 63 6F 6E 74 72 6F 6C 75 73 65 72 28 24 73 71 6C 5F 71 75 65 72
79 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 7D 0A 3F 3E 0A
<?php /* vim: set expand
tab sw=4 ts=4 sts=4: */ 
/**  *  * @package phpMy
Admin  */  /**  * This c
lass tracks changes on d
atabases, tables and vie
ws.  * For more informat
ion please see phpMyAdmi
n/Documentation.html  * 
 * @package phpMyAdmin  
*  * @todo use stristr i
nstead of strstr  */ cla
ss PMA_Tracker {     /**
      * Whether tracking
 is ready.      */     s
tatic protected $enabled
 = false;      /**      
* Defines the internal P
MA table which contains 
tracking data.      *   
   * @access  protected 
     * @var string      
*/     static protected 
$pma_table;      /**    
  * Defines the usage of
 DROP TABLE statment in 
SQL dumps.      *      *
 @access protected      
* @var boolean      */  
   static protected $add
_drop_table;      /**   
   * Defines the usage o
f DROP VIEW statment in 
SQL dumps.      *      *
 @access protected      
* @var boolean      */  
   static protected $add
_drop_view;      /**    
  * Defines the usage of
 DROP DATABASE statment 
in SQL dumps.      *    
  * @access protected   
   * @var boolean      *
/     static protected $
add_drop_database;      
/**      * Defines auto-
creation of tracking ver
sions.      *      * @va
r boolean      */     st
atic protected $version_
auto_create;      /**   
   * Defines the default
 set of tracked statemen
ts.      *      * @var s
tring      */     static
 protected $default_trac
king_set;      /**      
* Initializes settings. 
See phpMyAdmin/Documenta
tion.html.      *      *
 @static      *      */ 
    static public functi
on init()     {         
self::$pma_table = PMA_b
ackquote($GLOBALS['cfg']
['Server']['pmadb']) .".
".                      
      PMA_backquote($GLO
BALS['cfg']['Server']['t
racking']);          sel
f::$add_drop_table = $GL
OBALS['cfg']['Server']['
tracking_add_drop_table'
];          self::$add_d
rop_view = $GLOBALS['cfg
']['Server']['tracking_a
dd_drop_view'];         
 self::$add_drop_databas
e = $GLOBALS['cfg']['Ser
ver']['tracking_add_drop
_database'];          se
lf::$default_tracking_se
t = $GLOBALS['cfg']['Ser
ver']['tracking_default_
statements'];          s
elf::$version_auto_creat
e = $GLOBALS['cfg']['Ser
ver']['tracking_version_
auto_create'];      }   
   /**      * Actually e
nables tracking. This ne
eds to be done after all
       * underlaying cod
e is initialized.      *
      * @static      *  
    */     static public
 function enable()     {
         self::$enabled 
= true;     }      /**  
    * Gets the on/off va
lue of the Tracker modul
e, starts initialization
.      *      * @static 
     *      * @return bo
olean (true=on|false=off
)      */     static pub
lic function isActive() 
    {         if (! self
::$enabled) {           
  return false;         
}         /* We need to 
avoid attempt to track a
ny queries from PMA_getR
elationsParam */        
 self::$enabled = false;
         $cfgRelation = 
PMA_getRelationsParam();
         /* Restore orig
inal state */         se
lf::$enabled = true;    
     if (! $cfgRelation[
'trackingwork']) {      
       return false;    
     }         self::ini
t();          if (isset(
self::$pma_table)) {    
         return true;   
      } else {          
   return false;        
 }     }      /**      *
 Returns a simple DROP T
ABLE statement.      *  
    * @param string $tab
lename      * @return st
ring      */     static 
public function getState
mentDropTable($tablename
)     {         return '
DROP TABLE IF EXISTS ' .
 $tablename;     }      
/**      * Returns a sim
ple DROP VIEW statement.
      *      * @param st
ring $viewname      * @r
eturn string      */    
 static public function 
getStatementDropView($vi
ewname)     {         re
turn 'DROP VIEW IF EXIST
S ' . $viewname;     }  
    /**      * Returns a
 simple DROP DATABASE st
atement.      *      * @
param string $dbname    
  * @return string      
*/     static public fun
ction getStatementDropDa
tabase($dbname)     {   
      return 'DROP DATAB
ASE IF EXISTS ' . $dbnam
e;     }      /**      *
 Parses the name of a ta
ble from a SQL statement
 substring.      *      
* @static      *      * 
@param  string $string  
    part of SQL statemen
t      *      * @return 
string the name of table
      */     static prot
ected function getTableN
ame($string)     {      
   if (strstr($string, '
.')) {             $temp
 = explode('.', $string)
;             $tablename
 = $temp[1];         }  
       else {           
  $tablename = $string; 
        }          $str 
= explode("\n", $tablena
me);         $tablename 
= $str[0];          $tab
lename = str_replace(';'
, '', $tablename);      
   $tablename = str_repl
ace('`', '', $tablename)
;         $tablename = t
rim($tablename);        
  return $tablename;    
 }       /**      * Gets
 the tracking status of 
a table, is it active or
 deactive ?      *      
* @static      *      * 
@param  string $dbname  
    name of database    
  * @param  string $tabl
ename   name of table   
   *      * @return bool
ean true or false      *
/     static public func
tion isTracked($dbname, 
$tablename)     {       
  if (! self::$enabled) 
{             return fal
se;         }         /*
 We need to avoid attemp
t to track any queries f
rom PMA_getRelationsPara
m */         self::$enab
led = false;         $cf
gRelation = PMA_getRelat
ionsParam();         /* 
Restore original state *
/         self::$enabled
 = true;         if (! $
cfgRelation['trackingwor
k']) {             retur
n false;         }      
    $sql_query =        
 " SELECT tracking_activ
e FROM " . self::$pma_ta
ble .         " WHERE " 
. PMA_backquote('db_name
') . " = '" . PMA_sqlAdd
slashes($dbname) . "' " 
.         " AND " . PMA_
backquote('table_name') 
. " = '" . PMA_sqlAddsla
shes($tablename) . "' " 
.         " ORDER BY ver
sion DESC";          $ro
w = PMA_DBI_fetch_array(
PMA_query_as_controluser
($sql_query));          
if (isset($row['tracking
_active']) && $row['trac
king_active'] == 1) {   
          return true;  
       } else {         
    return false;       
  }     }      /**      
* Returns the comment li
ne for the log.      *  
    * @return string Com
ment, contains date and 
username      */     sta
tic public function getL
ogComment()     {       
  $date = date('Y-m-d H:
i:s');          return "
# log " . $date . " " . 
$GLOBALS['cfg']['Server'
]['user'] . "\n";     } 
     /**      * Creates 
tracking version of a ta
ble / view      * (in ot
her words: create a job 
to track future changes 
on the table).      *   
   * @static      *     
 * @param  string $dbnam
e       name of database
      * @param  string $
tablename    name of tab
le      * @param  string
 $version      version  
    * @param  string $tr
acking_set set of tracki
ng statements      * @pa
ram  string $is_view    
  if table is a view    
  *      * @return int r
esult of version inserti
on      */     static pu
blic function createVers
ion($dbname, $tablename,
 $version, $tracking_set
 = '', $is_view = false)
     {         global $s
ql_backquotes;          
if ($tracking_set == '')
 {             $tracking
_set = self::$default_tr
acking_set;         }   
       require_once './l
ibraries/export/sql.php'
;          $sql_backquot
es = true;          $dat
e = date('Y-m-d H:i:s');
          // Get data de
finition snapshot of tab
le         $sql_query = 
'         SHOW FULL COLU
MNS FROM ' . PMA_backquo
te($dbname) . '.' . PMA_
backquote($tablename);  
        $sql_result = PM
A_DBI_query($sql_query);
          while ($row = 
PMA_DBI_fetch_array($sql
_result)) {             
$columns[] = $row;      
   }          $sql_query
 = '         SHOW INDEX 
FROM ' . PMA_backquote($
dbname) . '.' . PMA_back
quote($tablename);      
    $sql_result = PMA_DB
I_query($sql_query);    
      $indexes = array()
;          while($row = 
PMA_DBI_fetch_array($sql
_result)) {             
$indexes[] = $row;      
   }          $snapshot 
= array('COLUMNS' => $co
lumns, 'INDEXES' => $ind
exes);         $snapshot
 = serialize($snapshot);
          // Get DROP TA
BLE / DROP VIEW and CREA
TE TABLE SQL statements 
        $sql_backquotes 
= true;          $create
_sql  = "";          if 
(self::$add_drop_table =
= true && $is_view == fa
lse) {             $crea
te_sql .= self::getLogCo
mment() .               
             self::getSt
atementDropTable(PMA_bac
kquote($tablename)) . ";
\n";          }         
 if (self::$add_drop_vie
w == true && $is_view ==
 true) {             $cr
eate_sql .= self::getLog
Comment() .             
               self::get
StatementDropView(PMA_ba
ckquote($tablename)) . "
;\n";         }         
 $create_sql .= self::ge
tLogComment() .         
               PMA_getTa
bleDef($dbname, $tablena
me, "\n", "");          
// Save version         
 $sql_query =         "/
*NOTRACK*/\n" .         
"INSERT INTO" . self::$p
ma_table . " (" .       
  "db_name, " .         
"table_name, " .        
 "version, " .         "
date_created, " .       
  "date_updated, " .    
     "schema_snapshot, "
 .         "schema_sql, 
" .         "data_sql, "
 .         "tracking " .
         ") " .         
"values (         '" . P
MA_sqlAddslashes($dbname
) . "',         '" . PMA
_sqlAddslashes($tablenam
e) . "',         '" . PM
A_sqlAddslashes($version
) . "',         '" . PMA
_sqlAddslashes($date) . 
"',         '" . PMA_sql
Addslashes($date) . "', 
        '" . PMA_sqlAdds
lashes($snapshot) . "', 
        '" . PMA_sqlAdds
lashes($create_sql) . "'
,         '" . PMA_sqlAd
dslashes("\n") . "',    
     '" . PMA_sqlAddslas
hes($tracking_set) . "' 
)";          $result = P
MA_query_as_controluser(
$sql_query);          if
 ($result) {            
 // Deactivate previous 
version             self
::deactivateTracking($db
name, $tablename, ($vers
ion - 1));         }    
      return $result;   
  }       /**      * Rem
oves all tracking data f
or a table       *      
* @static      *      * 
@param  string $dbname  
     name of database   
   * @param  string $tab
lename    name of table 
      *      * @return i
nt result of version ins
ertion      */     stati
c public function delete
Tracking($dbname, $table
name)     {         $sql
_query =         "/*NOTR
ACK*/\n" .         "DELE
TE FROM " . self::$pma_t
able . " WHERE `db_name`
 = '" . PMA_sqlAddslashe
s($dbname) . "' AND `tab
le_name` = '" . PMA_sqlA
ddslashes($tablename) . 
"'";         $result = P
MA_query_as_controluser(
$sql_query);          re
turn $result;     }     
 /**      * Creates trac
king version of a databa
se      * (in other word
s: create a job to track
 future changes on the d
atabase).      *      * 
@static      *      * @p
aram  string $dbname    
   name of database     
 * @param  string $versi
on      version      * @
param  string $query    
    query      * @param 
 string $tracking_set se
t of tracking statements
      *      * @return i
nt result of version ins
ertion      */     stati
c public function create
DatabaseVersion($dbname,
 $version, $query, $trac
king_set = 'CREATE DATAB
ASE,ALTER DATABASE,DROP 
DATABASE')     {        
 global $sql_backquotes;
          $date = date('
Y-m-d H:i:s');          
if ($tracking_set == '')
 {             $tracking
_set = self::$default_tr
acking_set;         }   
       require_once './l
ibraries/export/sql.php'
;          $create_sql  
= "";          if (self:
:$add_drop_database == t
rue) {             $crea
te_sql .= self::getLogCo
mment() .               
             self::getSt
atementDropDatabase(PMA_
backquote($dbname)) . ";
\n";         }          
$create_sql .= self::get
LogComment() . $query;  
        // Save version 
        $sql_query =    
     "/*NOTRACK*/\n" .  
       "INSERT INTO" . s
elf::$pma_table . " (" .
         "db_name, " .  
       "table_name, " . 
        "version, " .   
      "date_created, " .
         "date_updated, 
" .         "schema_snap
shot, " .         "schem
a_sql, " .         "data
_sql, " .         "track
ing " .         ") " .  
       "values (        
 '" . PMA_sqlAddslashes(
$dbname) . "',         '
" . PMA_sqlAddslashes(''
) . "',         '" . PMA
_sqlAddslashes($version)
 . "',         '" . PMA_
sqlAddslashes($date) . "
',         '" . PMA_sqlA
ddslashes($date) . "',  
       '" . PMA_sqlAddsl
ashes('') . "',         
'" . PMA_sqlAddslashes($
create_sql) . "',       
  '" . PMA_sqlAddslashes
("\n") . "',         '" 
. PMA_sqlAddslashes($tra
cking_set) . "' )";     
     $result = PMA_query
_as_controluser($sql_que
ry);          return $re
sult;     }        /**  
    * Changes tracking o
f a table.      *      *
 @static      *      * @
param  string $dbname   
    name of database    
  * @param  string $tabl
ename    name of table  
    * @param  string $ve
rsion      version      
* @param  integer $new_s
tate   the new state of 
tracking       *      * 
@return int result of SQ
L query      */     stat
ic private function chan
geTracking($dbname, $tab
lename, $version, $new_s
tate)     {         $sql
_query =         " UPDAT
E " . self::$pma_table .
         " SET `tracking
_active` = '" . $new_sta
te . "' " .         " WH
ERE `db_name` = '" . PMA
_sqlAddslashes($dbname) 
. "' " .         " AND `
table_name` = '" . PMA_s
qlAddslashes($tablename)
 . "' " .         " AND 
`version` = '" . PMA_sql
Addslashes($version) . "
' ";          $result = 
PMA_query_as_controluser
($sql_query);          r
eturn $result;     }    
  /**      * Activates t
racking of a table.     
 *      * @static      *
      * @param  string $
dbname       name of dat
abase      * @param  str
ing $tablename    name o
f table      * @param  s
tring $version      vers
ion      *      * @retur
n int result of SQL quer
y      */     static pub
lic function activateTra
cking($dbname, $tablenam
e, $version)     {      
   return self::changeTr
acking($dbname, $tablena
me, $version, 1);      }
       /**      * Deacti
vates tracking of a tabl
e.      *      * @static
      *      * @param  s
tring $dbname       name
 of database      * @par
am  string $tablename   
 name of table      * @p
aram  string $version   
   version      *      *
 @return int result of S
QL query      */     sta
tic public function deac
tivateTracking($dbname, 
$tablename, $version)   
  {         return self:
:changeTracking($dbname,
 $tablename, $version, 0
);      }       /**     
 * Gets the newest versi
on of a tracking job    
  * (in other words: get
s the HEAD version).    
  *      * @static      
*      * @param  string 
$dbname      name of dat
abase      * @param  str
ing $tablename   name of
 table      * @param  st
ring $statement   tracke
d statement      *      
* @return int (-1 if no 
version exists | >  0 if
 a version exists)      
*/     static public fun
ction getVersion($dbname
, $tablename, $statement
 = null)     {         $
sql_query =         " SE
LECT MAX(version) FROM "
 . self::$pma_table .   
      " WHERE `db_name` 
= '" . PMA_sqlAddslashes
($dbname) . "' " .      
   " AND `table_name` = 
'" . PMA_sqlAddslashes($
tablename) . "' ";      
    if ($statement != ""
) {             $sql_que
ry .= " AND FIND_IN_SET(
'" . $statement . "',tra
cking) > 0" ;         } 
        $row = PMA_DBI_f
etch_array(PMA_query_as_
controluser($sql_query))
;         if (isset($row
[0])) {             $ver
sion = $row[0];         
}         if (! isset($v
ersion)) {             $
version = -1;         } 
        return $version;
     }       /**      * 
Gets the record of a tra
cking job.      *      *
 @static      *      * @
param  string $dbname   
   name of database     
 * @param  string $table
name   name of table    
  * @param  string $vers
ion     version number  
    *      * @return mix
ed record DDM log, DDL l
og, structure snapshot, 
tracked statements.     
 */     static public fu
nction getTrackedData($d
bname, $tablename, $vers
ion)     {         if (!
 isset(self::$pma_table)
) {             self::in
it();         }         
$sql_query = " SELECT * 
FROM " . self::$pma_tabl
e .             " WHERE 
`db_name` = '" . PMA_sql
Addslashes($dbname) . "'
 ";         if (! empty(
$tablename)) {          
   $sql_query .= " AND `
table_name` = '" . PMA_s
qlAddslashes($tablename)
 ."' ";         }       
  $sql_query .= " AND `v
ersion` = '" . PMA_sqlAd
dslashes($version) ."' "
.                      "
 ORDER BY `version` DESC
 ";          $mixed = PM
A_DBI_fetch_array(PMA_qu
ery_as_controluser($sql_
query));          // Par
se log         $log_sche
ma_entries = explode('# 
log ',  $mixed['schema_s
ql']);         $log_data
_entries   = explode('# 
log ',  $mixed['data_sql
']);          $ddl_date_
from = $date = date('Y-m
-d H:i:s');          $dd
log = array();         $
i = 0;          // Itera
te tracked data definiti
on statements         //
 For each log entry we w
ant to get date, usernam
e and statement         
foreach ($log_schema_ent
ries as $log_entry) {   
          if (trim($log_
entry) != '') {         
        $date      = sub
str($log_entry, 0, 19); 
                $usernam
e  = substr($log_entry, 
20, strpos($log_entry, "
\n") - 20);             
    if ($i == 0) {      
               $ddl_date
_from = $date;          
       }                
 $statement = rtrim(strs
tr($log_entry, "\n"));  
                $ddlog[]
 = array( 'date' => $dat
e,                      
             'username'=
> $username,            
                       '
statement' => $statement
 );                 $i++
;             }         
}          $date_from = 
$ddl_date_from;         
$date_to   = $ddl_date_t
o = $date;          $dml
_date_from = $date_from;
          $dmlog = array
();         $i = 0;     
     // Iterate tracked 
data manipulation statem
ents         // For each
 log entry we want to ge
t date, username and sta
tement         foreach (
$log_data_entries as $lo
g_entry) {             i
f (trim($log_entry) != '
') {                 $da
te      = substr($log_en
try, 0, 19);            
     $username  = substr
($log_entry, 20, strpos(
$log_entry, "\n") - 20);
                 if ($i 
== 0) {                 
    $dml_date_from = $da
te;                 }   
              $statement
 = rtrim(strstr($log_ent
ry, "\n"));             
     $dmlog[] = array( '
date' => $date,         
                        
  'username' => $usernam
e,                      
             'statement'
 => $statement );       
          $i++;         
    }         }         
 $dml_date_to = $date;  
        // Define begin 
and end of date range fo
r both logs         if (
strtotime($ddl_date_from
) <= strtotime($dml_date
_from)) {             $d
ata['date_from'] = $ddl_
date_from;         } els
e {             $data['d
ate_from'] = $dml_date_f
rom;         }         i
f (strtotime($ddl_date_t
o) >= strtotime($dml_dat
e_to)) {             $da
ta['date_to'] = $ddl_dat
e_to;         } else {  
           $data['date_t
o'] = $dml_date_to;     
    }         $data['ddl
og']           = $ddlog;
         $data['dmlog'] 
          = $dmlog;     
    $data['tracking']   
     = $mixed['tracking'
];         $data['schema
_snapshot'] = $mixed['sc
hema_snapshot'];        
  return $data;     }   
    /**      * Parses a 
query. Gets      *  - st
atement identifier (UPDA
TE, ALTER TABLE, ...)   
   *  - type of statemen
t, is it part of DDL or 
DML ?      *  - tablenam
e      *      * @static 
     * @todo: using PMA 
SQL Parser when possible
      * @todo: support m
ulti-table/view drops   
   *      * @param strin
g $query      *      * @
return mixed Array conta
ining identifier, type a
nd tablename.      *    
  */     static public f
unction parseQuery($quer
y)     {          // Usa
ge of PMA_SQP does not w
ork here         //     
    // require_once("lib
raries/sqlparser.lib.php
");         // $parsed_s
ql = PMA_SQP_parse($quer
y);         // $sql_info
 = PMA_SQP_analyze($pars
ed_sql);          $query
 = str_replace("\n", " "
, $query);         $quer
y = str_replace("\r", " 
", $query);          $qu
ery = trim($query);     
    $query = trim($query
, ' -');          $token
s = explode(" ", $query)
;         $tokens = arra
y_map('strtoupper', $tok
ens);          // Parse 
USE statement, need it f
or SQL dump imports     
    if (substr($query, 0
, 4) == 'USE ') {       
      $prefix = explode(
'USE ', $query);        
     $GLOBALS['db'] = se
lf::getTableName($prefix
[1]);         }         
 /*          * DDL state
ments          */       
   $result['type']      
   = 'DDL';          // 
Parse CREATE VIEW statem
ent         if (in_array
('CREATE', $tokens) == t
rue &&             in_ar
ray('VIEW', $tokens) == 
true &&             in_a
rray('AS', $tokens) == t
rue) {             $resu
lt['identifier'] = 'CREA
TE VIEW';              $
index = array_search('VI
EW', $tokens);          
    $result['tablename']
 = strtolower(self::getT
ableName($tokens[$index 
+ 1]));         }       
   // Parse ALTER VIEW s
tatement         if (in_
array('ALTER', $tokens) 
== true &&             i
n_array('VIEW', $tokens)
 == true &&             
in_array('AS', $tokens) 
== true &&             !
 isset($result['identifi
er'])) {             $re
sult['identifier'] = 'AL
TER VIEW';              
$index = array_search('V
IEW', $tokens);         
     $result['tablename'
] = strtolower(self::get
TableName($tokens[$index
 + 1]));         }      
    // Parse DROP VIEW s
tatement         if (! i
sset($result['identifier
']) && substr($query, 0,
 10) == 'DROP VIEW ') { 
            $result['ide
ntifier'] = 'DROP VIEW';
              $prefix  =
 explode('DROP VIEW ', $
query);             $str
 = strstr($prefix[1], 'I
F EXISTS');             
 if ($str == FALSE ) {  
               $str = $p
refix[1];             } 
            $result['tab
lename'] = self::getTabl
eName($str);         }  
        // Parse CREATE 
DATABASE statement      
   if (! isset($result['
identifier']) && substr(
$query, 0, 15) == 'CREAT
E DATABASE') {          
   $result['identifier']
 = 'CREATE DATABASE';   
          $str = str_rep
lace('CREATE DATABASE', 
'', $query);            
 $str = str_replace('IF 
NOT EXISTS', '', $str); 
             $prefix = e
xplode('DEFAULT ', $str)
;              $result['
tablename'] = '';       
      $GLOBALS['db'] = s
elf::getTableName($prefi
x[0]);         }        
  // Parse ALTER DATABAS
E statement         if (
! isset($result['identif
ier']) && substr($query,
 0, 14) == 'ALTER DATABA
SE') {             $resu
lt['identifier'] = 'ALTE
R DATABASE';            
 $result['tablename'] = 
'';         }          /
/ Parse DROP DATABASE st
atement         if (! is
set($result['identifier'
]) && substr($query, 0, 
13) == 'DROP DATABASE') 
{             $result['i
dentifier'] = 'DROP DATA
BASE';             $str 
= str_replace('DROP DATA
BASE', '', $query);     
        $str = str_repla
ce('IF EXISTS', '', $str
);             $GLOBALS[
'db'] = self::getTableNa
me($str);             $r
esult['tablename'] = '';
         }          // P
arse CREATE TABLE statem
ent         if (! isset(
$result['identifier']) &
& substr($query, 0, 12) 
== 'CREATE TABLE' ) {   
          $result['ident
ifier'] = 'CREATE TABLE'
;             $query   =
 str_replace('IF NOT EXI
STS', '', $query);      
       $prefix  = explod
e('CREATE TABLE ', $quer
y);             $suffix 
 = explode('(', $prefix[
1]);             $result
['tablename'] = self::ge
tTableName($suffix[0]); 
        }          // Pa
rse ALTER TABLE statemen
t         if (! isset($r
esult['identifier']) && 
substr($query, 0, 12) ==
 'ALTER TABLE ') {      
       $result['identifi
er'] = 'ALTER TABLE';   
           $prefix  = ex
plode('ALTER TABLE ', $q
uery);             $suff
ix  = explode(' ', $pref
ix[1]);             $res
ult['tablename']  = self
::getTableName($suffix[0
]);         }          /
/ Parse DROP TABLE state
ment         if (! isset
($result['identifier']) 
&& substr($query, 0, 11)
 == 'DROP TABLE ') {    
         $result['identi
fier'] = 'DROP TABLE';  
            $prefix  = e
xplode('DROP TABLE ', $q
uery);             $str 
= strstr($prefix[1], 'IF
 EXISTS');              
if ($str == FALSE ) {   
              $str = $pr
efix[1];             }  
           $result['tabl
ename'] = self::getTable
Name($str);         }   
       // Parse CREATE I
NDEX statement         i
f (! isset($result['iden
tifier']) &&            
  (   substr($query, 0, 
12) == 'CREATE INDEX' ||
                  substr
($query, 0, 19) == 'CREA
TE UNIQUE INDEX' ||     
             substr($que
ry, 0, 20) == 'CREATE SP
ATIAL INDEX'            
 )         ) {          
    $result['identifier'
] = 'CREATE INDEX';     
         $prefix = explo
de('ON ', $query);      
        $suffix = explod
e('(', $prefix[1]);     
         $result['tablen
ame'] = self::getTableNa
me($suffix[0]);         
}          // Parse DROP
 INDEX statement        
 if (! isset($result['id
entifier']) && substr($q
uery, 0, 10) == 'DROP IN
DEX') {              $re
sult['identifier'] = 'DR
OP INDEX';              
$prefix = explode('ON ',
 $query);              $
result['tablename'] = se
lf::getTableName($prefix
[1]);         }         
 // Parse RENAME TABLE s
tatement         if (! i
sset($result['identifier
']) && substr($query, 0,
 13) == 'RENAME TABLE ')
 {             $result['
identifier'] = 'RENAME T
ABLE';             $pref
ix = explode('RENAME TAB
LE ', $query);          
   $names  = explode(' T
O ', $prefix[1]);       
      $result['tablename
']      = self::getTable
Name($names[0]);        
     $result["tablename_
after_rename"]  = self::
getTableName($names[1]);
         }          /*  
        * DML statements
          */          if
 (! isset($result['ident
ifier'])) {             
$result["type"]       = 
'DML';         }        
 // Parse UPDATE stateme
nt         if (! isset($
result['identifier']) &&
 substr($query, 0, 6) ==
 'UPDATE') {            
 $result['identifier'] =
 'UPDATE';             $
prefix  = explode('UPDAT
E ', $query);           
  $suffix  = explode(' '
, $prefix[1]);          
   $result['tablename'] 
= self::getTableName($su
ffix[0]);         }     
     // Parse INSERT INT
O statement         if (
! isset($result['identif
ier']) && substr($query,
 0, 11 ) == 'INSERT INTO
') {             $result
['identifier'] = 'INSERT
';             $prefix  
= explode('INSERT INTO',
 $query);             $s
uffix  = explode('(', $p
refix[1]);             $
result['tablename'] = se
lf::getTableName($suffix
[0]);         }         
 // Parse DELETE stateme
nt         if (! isset($
result['identifier']) &&
 substr($query, 0, 6 ) =
= 'DELETE') {           
  $result['identifier'] 
= 'DELETE';             
$prefix  = explode('FROM
 ', $query);            
 $suffix  = explode(' ',
 $prefix[1]);           
  $result['tablename'] =
 self::getTableName($suf
fix[0]);         }      
    // Parse TRUNCATE st
atement         if (! is
set($result['identifier'
]) && substr($query, 0, 
8 ) == 'TRUNCATE') {    
         $result['identi
fier'] = 'TRUNCATE';    
         $prefix  = expl
ode('TRUNCATE', $query);
             $result['ta
blename'] = self::getTab
leName($prefix[1]);     
    }          return $r
esult;     }       /**  
    * Analyzes a given S
QL statement and saves t
racking data.      *    
  *      * @static      
* @param   string $query
 a SQL query      */    
 static public function 
handleQuery($query)     
{         // If query is
 marked as untouchable, 
leave         if (strstr
($query, "/*NOTRACK*/"))
 {             return fa
lse;         }          
if (! (substr($query, -1
) == ';')) {            
 $query = $query . ";\n"
;         }         // G
et some information abou
t query         $result 
= self::parseQuery($quer
y);          // Get data
base name         $dbnam
e = trim($GLOBALS['db'],
 '`');         // $dbnam
e can be empty, for exam
ple when coming from Syn
chronize         // and 
this is a query for the 
remote server         if
 (empty($dbname)) {     
        return false;   
      }          // If w
e found a valid statemen
t         if (isset($res
ult['identifier'])) {   
          $version = sel
f::getVersion($dbname, $
result['tablename'], $re
sult['identifier']);    
          // If version 
not exists and auto-crea
tion is enabled         
    if (self::$version_a
uto_create == true      
           && self::isTr
acked($dbname, $result['
tablename']) == false   
               && $versi
on == -1) {             
    // Create the versio
n                  switc
h ($result['identifier']
) {                 case
 'CREATE TABLE':        
             self::creat
eVersion($dbname, $resul
t['tablename'], '1');   
                  break;
                 case 'C
REATE VIEW':            
         self::createVer
sion($dbname, $result['t
ablename'], '1', '', tru
e);                     
break;                 c
ase 'CREATE DATABASE':  
                   self:
:createDatabaseVersion($
dbname, '1', $query);   
                  break;
                 } // en
d switch             }  
            // If versio
n exists             if 
(self::isTracked($dbname
, $result['tablename']) 
&& $version != -1) {    
             if ($result
['type'] == 'DDL') {    
                 $save_t
o = 'schema_sql';       
          } elseif ($res
ult['type'] == 'DML') { 
                    $sav
e_to = 'data_sql';      
           } else {     
                $save_to
 = '';                 }
                 $date  
= date('Y-m-d H:i:s');  
                // Cut o
ff `dbname`. from query 
                $query =
 preg_replace('/`' . $db
name . '`\s?\./', '', $q
uery);                  
// Add log information  
               $query = 
self::getLogComment() . 
$query ;                
  // Mark it as untoucha
ble                 $sql
_query =                
 " /*NOTRACK*/\n" .     
            " UPDATE " .
 self::$pma_table .     
            " SET " . PM
A_backquote($save_to) ."
 = CONCAT( " . PMA_backq
uote($save_to) . ",'\n" 
. PMA_sqlAddslashes($que
ry) . "') ," .          
       " `date_updated` 
= '" . $date . "' ";    
              // If tabl
e was renamed we have to
 change the tablename at
tribute in pma_tracking 
too                 if (
$result['identifier'] ==
 'RENAME TABLE') {      
               $sql_quer
y .= ', `table_name` = \
'' . PMA_sqlAddslashes($
result['tablename_after_
rename']) . '\' ';      
           }            
      // Save the tracki
ng information only for 
                //     1
. the database          
       //     2. the tab
le / view               
  //     3. the statemen
ts                 // we
 want to track          
       $sql_query .=    
             " WHERE FIN
D_IN_SET('" . $result['i
dentifier'] . "',trackin
g) > 0" .               
  " AND `db_name` = '" .
 PMA_sqlAddslashes($dbna
me) . "' " .            
     " AND `table_name` 
= '" . PMA_sqlAddslashes
($result['tablename']) .
 "' " .                 
" AND `version` = '" . P
MA_sqlAddslashes($versio
n) . "' ";              
    $result = PMA_query_
as_controluser($sql_quer
y);             }       
  }     } } ?> 

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.1305 ]--