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
| 23 21 2F 62 69 6E 2F 73 68 0A 23 20 43 6F 70 79 72 69 67 68 74 20 28 43 29 20 32 30 30 32 2D 32 30 30 33 20 4D 79 53 51 4C 20 41 42 0A 23 20 0A 23 20 54 68 69 73 20 70 72 6F 67 72 61 6D 20 69 73 20 66 72 65 65 20 73 6F 66 74 77 61 72 65 3B 20 79 6F 75 20 63 61 6E 20 72 65 64 69 73 74 72 69 62 75 74 65 20 69 74 20 61 6E 64 2F 6F 72 20 6D 6F 64 69 66 79 0A 23 20 69 74 20 75 6E 64 65 72 20 74 68 65 20 74 65 72 6D 73 20 6F 66 20 74 68 65 20 47 4E 55 20 47 65 6E 65 72 61 6C 20 50 75 62 6C 69 63 20 4C 69 63 65 6E 73 65 20 61 73 20 70 75 62 6C 69 73 68 65 64 20 62 79 0A 23 20 74 68 65 20 46 72 65 65 20 53 6F 66 74 77 61 72 65 20 46 6F 75 6E 64 61 74 69 6F 6E 3B 20 76 65 72 73 69 6F 6E 20 32 20 6F 66 20 74 68 65 20 4C 69 63 65 6E 73 65 2E 0A 23 20 0A 23 20 54 68 69 73 20 70 72 6F 67 72 61 6D 20 69 73 20 64 69 73 74 72 69 62 75 74 65 64 20 69 6E 20 74 68 65 20 68 6F 70 65 20 74 68 61 74 20 69 74 20 77 69 6C 6C 20 62 65 20 75 73 65 66 75 6C 2C 0A 23 20 62 75 74 20 57 49 54 48 4F 55 54 20 41 4E 59 20 57 41 52 52 41 4E 54 59 3B 20 77 69 74 68 6F 75 74 20 65 76 65 6E 20 74 68 65 20 69 6D 70 6C 69 65 64 20 77 61 72 72 61 6E 74 79 20 6F 66 0A 23 20 4D 45 52 43 48 41 4E 54 41 42 49 4C 49 54 59 20 6F 72 20 46 49 54 4E 45 53 53 20 46 4F 52 20 41 20 50 41 52 54 49 43 55 4C 41 52 20 50 55 52 50 4F 53 45 2E 20 20 53 65 65 20 74 68 65 0A 23 20 47 4E 55 20 47 65 6E 65 72 61 6C 20 50 75 62 6C 69 63 20 4C 69 63 65 6E 73 65 20 66 6F 72 20 6D 6F 72 65 20 64 65 74 61 69 6C 73 2E 0A 23 20 0A 23 20 59 6F 75 20 73 68 6F 75 6C 64 20 68 61 76 65 20 72 65 63 65 69 76 65 64 20 61 20 63 6F 70 79 20 6F 66 20 74 68 65 20 47 4E 55 20 47 65 6E 65 72 61 6C 20 50 75 62 6C 69 63 20 4C 69 63 65 6E 73 65 0A 23 20 61 6C 6F 6E 67 20 77 69 74 68 20 74 68 69 73 20 70 72 6F 67 72 61 6D 3B 20 69 66 20 6E 6F 74 2C 20 77 72 69 74 65 20 74 6F 20 74 68 65 20 46 72 65 65 20 53 6F 66 74 77 61 72 65 0A 23 20 46 6F 75 6E 64 61 74 69 6F 6E 2C 20 49 6E 63 2E 2C 20 35 31 20 46 72 61 6E 6B 6C 69 6E 20 53 74 2C 20 46 69 66 74 68 20 46 6C 6F 6F 72 2C 20 42 6F 73 74 6F 6E 2C 20 4D 41 20 20 30 32 31 31 30 2D 31 33 30 31 20 20 55 53 41 0A 0A 23 20 52 75 6E 73 20 6D 79 73 71 6C 63 68 65 63 6B 20 2D 2D 63 68 65 63 6B 2D 75 70 67 72 61 64 65 20 69 6E 20 63 61 73 65 20 69 74 20 68 61 73 20 6E 6F 74 20 62 65 65 6E 20 64 6F 6E 65 20 6F 6E 20 74 68 69 73 0A 23 20 6D 61 6A 6F 72 20 4D 79 53 51 4C 20 76 65 72 73 69 6F 6E 0A 0A 23 20 54 68 69 73 20 73 63 72 69 70 74 20 73 68 6F 75 6C 64 20 61 6C 77 61 79 73 20 62 65 20 72 75 6E 20 77 68 65 6E 20 75 70 67 72 61 64 69 6E 67 20 66 72 6F 6D 20 6F 6E 65 20 6D 61 6A 6F 72 20 76 65 72 73 69 6F 6E 0A 23 20 74 6F 20 61 6E 6F 74 68 65 72 20 28 69 65 3A 20 34 2E 31 20 2D 3E 20 35 2E 30 20 2D 3E 20 35 2E 31 29 0A 0A 23 0A 23 20 4E 6F 74 65 20 74 68 61 74 20 69 6E 20 6D 6F 73 74 20 63 61 73 65 73 20 6F 6E 65 20 68 61 76 65 20 74 6F 20 75 73 65 20 27 2D 2D 70 61 73 73 77 6F 72 64 27 20 61 73 0A 23 20 61 72 67 75 6D 65 6E 74 73 20 61 73 20 74 68 65 73 65 20 6E 65 65 64 73 20 74 6F 20 62 65 20 70 61 73 73 65 64 20 6F 6E 20 74 6F 20 74 68 65 20 6D 79 73 71 6C 63 68 65 63 6B 20 63 6F 6D 6D 61 6E 64 0A 0A 0A 75 73 65 72 3D 72 6F 6F 74 0A 0A 63 61 73 65 20 22 24 31 22 20 69 6E 0A 20 20 20 20 2D 2D 6E 6F 2D 64 65 66 61 75 6C 74 73 7C 2D 2D 64 65 66 61 75 6C 74 73 2D 66 69 6C 65 3D 2A 7C 2D 2D 64 65 66 61 75 6C 74 73 2D 65 78 74 72 61 2D 66 69 6C 65 3D 2A 29 0A 20 20 20 20 20 20 64 65 66 61 75 6C 74 73 3D 22 24 31 22 3B 20 73 68 69 66 74 0A 20 20 20 20 20 20 3B 3B 0A 65 73 61 63 0A 0A 70 61 72 73 65 5F 61 72 67 75 6D 65 6E 74 73 28 29 20 7B 0A 20 20 23 20 57 65 20 6F 6E 6C 79 20 6E 65 65 64 20 74 6F 20 70 61 73 73 20 61 72 67 75 6D 65 6E 74 73 20 74 68 72 6F 75 67 68 20 74 6F 20 74 68 65 20 73 65 72 76 65 72 20 69 66 20 77 65 20 64 6F 6E 27 74 0A 20 20 23 20 68 61 6E 64 6C 65 20 74 68 65 6D 20 68 65 72 65 2E 20 20 53 6F 2C 20 77 65 20 63 6F 6C 6C 65 63 74 20 75 6E 72 65 63 6F 67 6E 69 7A 65 64 20 6F 70 74 69 6F 6E 73 20 28 70 61 73 73 65 64 20 6F 6E 0A 20 20 23 20 74 68 65 20 63 6F 6D 6D 61 6E 64 20 6C 69 6E 65 29 20 69 6E 74 6F 20 74 68 65 20 61 72 67 73 20 76 61 72 69 61 62 6C 65 2E 0A 20 20 70 69 63 6B 5F 61 72 67 73 3D 0A 20 20 69 66 20 74 65 73 74 20 22 24 31 22 20 3D 20 50 49 43 4B 2D 41 52 47 53 2D 46 52 4F 4D 2D 41 52 47 56 0A 20 20 74 68 65 6E 0A 20 20 20 20 70 69 63 6B 5F 61 72 67 73 3D 31 0A 20 20 20 20 73 68 69 66 74 0A 20 20 66 69 0A 0A 20 20 66 6F 72 20 61 72 67 20 64 6F 0A 20 20 20 20 63 61 73 65 20 22 24 61 72 67 22 20 69 6E 0A 20 20 20 20 20 20 2D 2D 62 61 73 65 64 69 72 3D 2A 29 20 4D 59 5F 42 41 53 45 44 49 52 5F 56 45 52 53 49 4F 4E 3D 60 65 63 68 6F 20 22 24 61 72 67 22 20 7C 20 73 65 64 20 2D 65 20 27 73 2F 5E 5B 5E 3D 5D 2A 3D 2F 2F 27 60 20 3B 3B 0A 20 20 20 20 20 20 2D 2D 75 73 65 72 3D 2A 29 20 75 73 65 72 3D 60 65 63 68 6F 20 22 24 61 72 67 22 20 7C 20 73 65 64 20 2D 65 20 27 73 2F 5E 5B 5E 3D 5D 2A 3D 2F 2F 27 60 20 3B 3B 0A 20 20 20 20 20 20 2D 2D 6C 64 61 74 61 3D 2A 7C 2D 2D 64 61 74 61 3D 2A 7C 2D 2D 64 61 74 61 64 69 72 3D 2A 29 20 44 41 54 41 44 49 52 3D 60 65 63 68 6F 20 22 24 61 72 67 22 20 7C 20 73 65 64 20 2D 65 20 27 73 2F 5E 5B 5E 3D 5D 2A 3D 2F 2F 27 60 20 3B 3B 0A 20 20 20 20 20 20 2D 2D 66 6F 72 63 65 29 20 66 6F 72 63 65 3D 31 20 3B 3B 0A 20 20 20 20 20 20 2D 2D 76 65 72 62 6F 73 65 29 20 76 65 72 62 6F 73 65 3D 31 20 3B 3B 0A 20 20 20 20 20 20 2D 2D 68 65 6C 70 29 20 68 65 6C 70 5F 6F 70 74 69 6F 6E 3D 31 20 3B 3B 0A 20 20 20 20 20 20 2A 29 0A 20 20 20 20 20 20 20 20 69 66 20 74 65 73 74 20 2D 6E 20 22 24 70 69 63 6B 5F 61 72 67 73 22 0A 20 20 20 20 20 20 20 20 74 68 65 6E 0A 20 20 20 20 20 20 20 20 20 20 23 20 54 68 69 73 20 73 65 64 20 63 6F 6D 6D 61 6E 64 20 6D 61 6B 65 73 20 73 75 72 65 20 74 68 61 74 20 61 6E 79 20 73 70 65 63 69 61 6C 20 63 68 61 72 73 20 61 72 65 20 71 75 6F 74 65 64 2C 0A 20 20 20 20 20 20 20 20 20 20 23 20 73 6F 20 74 68 65 20 61 72 67 20 67 65 74 73 20 70 61 73 73 65 64 20 65 78 61 63 74 6C 79 20 74 6F 20 74 68 65 20 73 65 72 76 65 72 2E 0A 20 20 20 20 20 20 20 20 20 20 61 72 67 73 3D 22 24 61 72 67 73 20 22 60 65 63 68 6F 20 22 24 61 72 67 22 20 7C 20 73 65 64 20 2D 65 20 27 73 2C 5C 28 5B 5E 61 2D 7A 41 2D 5A 30 2D 39 5F 2E 3D 2D 5D 5C 29 2C 5C 5C 5C 5C 5C 31 2C 67 27 60 0A 20 20 20 20 20 20 20 20 66 69 0A 20 20 20 20 20 20 20 20 3B 3B 0A 20 20 20 20 65 73 61 63 0A 20 20 64 6F 6E 65 0A 7D 0A 0A 23 0A 23 20 46 69 6E 64 20 77 68 65 72 65 20 6D 79 5F 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 20 69 73 0A 23 0A 0A 66 69 6E 64 5F 6D 79 5F 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 20 28 29 20 7B 0A 20 20 69 66 20 74 65 73 74 20 2D 78 20 2E 2F 62 69 6E 2F 6D 79 5F 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 0A 20 20 74 68 65 6E 0A 20 20 20 20 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 3D 22 2E 2F 62 69 6E 2F 6D 79 5F 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 22 0A 20 20 65 6C 69 66 20 74 65 73 74 20 2D 78 20 2E 2F 65 78 74 72 61 2F 6D 79 5F 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 0A 20 20 74 68 65 6E 0A 20 20 20 20 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 3D 22 2E 2F 65 78 74 72 61 2F 6D 79 5F 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 22 0A 20 20 65 6C 69 66 20 74 65 73 74 20 2D 78 20 2F 75 73 72 2F 62 69 6E 2F 6D 79 5F 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 0A 20 20 74 68 65 6E 0A 20 20 20 20 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 3D 22 2F 75 73 72 2F 62 69 6E 2F 6D 79 5F 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 22 0A 20 20 65 6C 69 66 20 74 65 73 74 20 2D 78 20 2F 75 73 72 2F 62 69 6E 2F 6D 79 73 71 6C 5F 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 0A 20 20 74 68 65 6E 0A 20 20 20 20 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 3D 22 2F 75 73 72 2F 62 69 6E 2F 6D 79 73 71 6C 5F 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 22 0A 20 20 65 6C 73 65 0A 20 20 20 20 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 3D 22 6D 79 5F 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 22 0A 20 20 66 69 0A 7D 0A 0A 66 69 6E 64 5F 6D 79 5F 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 0A 0A 23 20 47 65 74 20 66 69 72 73 74 20 61 72 67 75 6D 65 6E 74 73 20 66 72 6F 6D 20 74 68 65 20 6D 79 2E 63 66 67 20 66 69 6C 65 2C 20 67 72 6F 75 70 73 20 5B 6D 79 73 71 6C 64 5D 20 61 6E 64 0A 23 20 5B 6D 79 73 71 6C 5F 75 70 67 72 61 64 65 5D 2C 20 61 6E 64 20 74 68 65 6E 20 6D 65 72 67 65 20 77 69 74 68 20 74 68 65 20 63 6F 6D 6D 61 6E 64 20 6C 69 6E 65 20 61 72 67 75 6D 65 6E 74 73 0A 0A 61 72 67 73 3D 0A 44 41 54 41 44 49 52 3D 0A 62 69 6E 64 69 72 3D 0A 4D 59 5F 42 41 53 45 44 49 52 5F 56 45 52 53 49 4F 4E 3D 0A 76 65 72 62 6F 73 65 3D 30 0A 66 6F 72 63 65 3D 30 0A 68 65 6C 70 5F 6F 70 74 69 6F 6E 3D 30 0A 0A 70 61 72 73 65 5F 61 72 67 75 6D 65 6E 74 73 20 60 24 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 20 24 64 65 66 61 75 6C 74 73 20 6D 79 73 71 6C 64 20 6D 79 73 71 6C 5F 75 70 67 72 61 64 65 60 0A 70 61 72 73 65 5F 61 72 67 75 6D 65 6E 74 73 20 50 49 43 4B 2D 41 52 47 53 2D 46 52 4F 4D 2D 41 52 47 56 20 22 24 40 22 0A 0A 69 66 20 74 65 73 74 20 24 68 65 6C 70 5F 6F 70 74 69 6F 6E 20 3D 20 31 0A 74 68 65 6E 0A 20 20 65 63 68 6F 20 22 4D 79 53 51 4C 20 75 74 69 6C 69 74 79 20 73 63 72 69 70 74 20 74 6F 20 75 70 67 72 61 64 65 20 64 61 74 61 62 61 73 65 20 74 6F 20 74 68 65 20 63 75 72 72 65 6E 74 20 73 65 72 76 65 72 20 76 65 72 73 69 6F 6E 22 0A 20 20 65 63 68 6F 20 22 22 0A 20 20 65 63 68 6F 20 22 49 74 20 74 61 6B 65 73 20 74 68 65 20 66 6F 6C 6C 6F 77 69 6E 67 20 61 72 67 75 6D 65 6E 74 73 3A 22 0A 20 20 65 63 68 6F 20 22 20 20 2D 2D 68 65 6C 70 20 20 20 20 20 53 68 6F 77 20 74 68 69 73 20 68 65 6C 70 20 6D 65 73 73 61 67 65 22 0A 20 20 65 63 68 6F 20 22 20 20 2D 2D 62 61 73 65 64 69 72 20 20 53 70 65 63 69 66 69 65 73 20 74 68 65 20 64 69 72 65 63 74 6F 72 79 20 77 68 65 72 65 20 4D 79 53 51 4C 20 69 73 20 69 6E 73 74 61 6C 6C 65 64 22 0A 20 20 65 63 68 6F 20 22 20 20 2D 2D 64 61 74 61 64 69 72 20 20 53 70 65 63 69 66 69 65 73 20 74 68 65 20 64 61 74 61 20 64 69 72 65 63 74 6F 72 79 22 0A 20 20 65 63 68 6F 20 22 20 20 2D 2D 66 6F 72 63 65 20 20 20 20 4D 79 73 71 6C 5F 75 70 67 72 61 64 65 2E 69 6E 66 6F 20 66 69 6C 65 20 77 69 6C 6C 20 62 65 20 69 67 6E 6F 72 65 64 22 0A 20 20 65 63 68 6F 20 22 20 20 2D 2D 75 73 65 72 20 20 20 20 20 55 73 65 72 6E 61 6D 65 20 66 6F 72 20 73 65 72 76 65 72 20 6C 6F 67 69 6E 20 69 66 20 6E 6F 74 20 63 75 72 72 65 6E 74 20 75 73 65 72 22 0A 20 20 65 63 68 6F 20 22 20 20 2D 2D 76 65 72 62 6F 73 65 20 20 44 69 73 70 6C 61 79 20 6D 6F 72 65 20 6F 75 74 70 75 74 20 61 62 6F 75 74 20 74 68 65 20 70 72 6F 63 65 73 73 22 0A 20 20 65 63 68 6F 20 22 22 0A 0A 20 20 65 78 69 74 20 30 0A 66 69 0A 0A 23 0A 23 20 54 72 79 20 74 6F 20 66 69 6E 64 20 77 68 65 72 65 20 62 69 6E 61 72 69 65 73 20 61 72 65 20 69 6E 73 74 61 6C 6C 65 64 0A 23 0A 0A 4D 59 5F 50 57 44 3D 60 70 77 64 60 0A 23 20 43 68 65 63 6B 20 66 6F 72 20 74 68 65 20 64 69 72 65 63 74 6F 72 69 65 73 20 77 65 20 77 6F 75 6C 64 20 65 78 70 65 63 74 20 66 72 6F 6D 20 61 20 62 69 6E 61 72 79 20 72 65 6C 65 61 73 65 20 69 6E 73 74 61 6C 6C 0A 69 66 20 74 65 73 74 20 2D 7A 20 22 24 4D 59 5F 42 41 53 45 44 49 52 5F 56 45 52 53 49 4F 4E 22 0A 74 68 65 6E 0A 20 20 69 66 20 74 65 73 74 20 2D 66 20 2E 2F 73 68 61 72 65 2F 6D 79 73 71 6C 2F 65 6E 67 6C 69 73 68 2F 65 72 72 6D 73 67 2E 73 79 73 20 2D 61 20 2D 78 20 2E 2F 62 69 6E 2F 6D 79 73 71 6C 64 0A 20 20 74 68 65 6E 0A 20 20 20 20 4D 59 5F 42 41 53 45 44 49 52 5F 56 45 52 53 49 4F 4E 3D 24 4D 59 5F 50 57 44 20 20 20 20 20 20 20 20 20 20 20 20 23 20 57 68 65 72 65 20 62 69 6E 2C 20 73 68 61 72 65 20 61 6E 64 20 64 61 74 61 20 61 72 65 0A 20 20 20 20 62 69 6E 64 69 72 3D 22 24 4D 59 5F 42 41 53 45 44 49 52 5F 56 45 52 53 49 4F 4E 2F 62 69 6E 22 0A 20 20 23 20 43 68 65 63 6B 20 66 6F 72 20 74 68 65 20 64 69 72 65 63 74 6F 72 69 65 73 20 77 65 20 77 6F 75 6C 64 20 65 78 70 65 63 74 20 66 72 6F 6D 20 61 20 73 6F 75 72 63 65 20 69 6E 73 74 61 6C 6C 0A 20 20 65 6C 69 66 20 74 65 73 74 20 2D 66 20 2E 2F 73 68 61 72 65 2F 6D 79 73 71 6C 2F 65 6E 67 6C 69 73 68 2F 65 72 72 6D 73 67 2E 73 79 73 20 2D 61 20 2D 78 20 2E 2F 6C 69 62 65 78 65 63 2F 6D 79 73 71 6C 64 0A 20 20 74 68 65 6E 0A 20 20 20 20 4D 59 5F 42 41 53 45 44 49 52 5F 56 45 52 53 49 4F 4E 3D 24 4D 59 5F 50 57 44 20 20 20 20 20 20 20 20 20 20 20 20 23 20 57 68 65 72 65 20 6C 69 62 65 78 65 63 2C 20 73 68 61 72 65 20 61 6E 64 20 76 61 72 20 61 72 65 0A 20 20 20 20 62 69 6E 64 69 72 3D 22 24 4D 59 5F 42 41 53 45 44 49 52 5F 56 45 52 53 49 4F 4E 2F 62 69 6E 22 0A 23 20 53 69 6E 63 65 20 77 65 20 64 69 64 6E 27 74 20 66 69 6E 64 20 61 6E 79 74 68 69 6E 67 2C 20 75 73 65 64 20 74 68 65 20 63 6F 6D 70 69 6C 65 64 2D 69 6E 20 64 65 66 61 75 6C 74 73 0A 20 20 65 6C 73 65 0A 20 20 20 20 4D 59 5F 42 41 53 45 44 49 52 5F 56 45 52 53 49 4F 4E 3D 2F 75 73 72 0A 20 20 20 20 62 69 6E 64 69 72 3D 2F 75 73 72 2F 62 69 6E 0A 20 20 66 69 0A 65 6C 73 65 0A 20 20 62 69 6E 64 69 72 3D 22 24 4D 59 5F 42 41 53 45 44 49 52 5F 56 45 52 53 49 4F 4E 2F 62 69 6E 22 0A 66 69 0A 0A 23 0A 23 20 54 72 79 20 74 6F 20 66 69 6E 64 20 74 68 65 20 64 61 74 61 20 64 69 72 65 63 74 6F 72 79 0A 23 0A 0A 69 66 20 74 65 73 74 20 2D 7A 20 22 24 44 41 54 41 44 49 52 22 0A 74 68 65 6E 0A 20 20 23 20 54 72 79 20 77 68 65 72 65 20 74 68 65 20 62 69 6E 61 72 79 20 69 6E 73 74 61 6C 6C 73 20 70 75 74 20 69 74 0A 20 20 69 66 20 74 65 73 74 20 2D 64 20 24 4D 59 5F 42 41 53 45 44 49 52 5F 56 45 52 53 49 4F 4E 2F 64 61 74 61 2F 6D 79 73 71 6C 0A 20 20 74 68 65 6E 0A 20 20 20 20 44 41 54 41 44 49 52 3D 24 4D 59 5F 42 41 53 45 44 49 52 5F 56 45 52 53 49 4F 4E 2F 64 61 74 61 0A 20 20 23 20 4E 65 78 74 20 74 72 79 20 77 68 65 72 65 20 74 68 65 20 73 6F 75 72 63 65 20 69 6E 73 74 61 6C 6C 73 20 70 75 74 20 69 74 0A 20 20 65 6C 69 66 20 74 65 73 74 20 2D 64 20 24 4D 59 5F 42 41 53 45 44 49 52 5F 56 45 52 53 49 4F 4E 2F 76 61 72 2F 6D 79 73 71 6C 0A 20 20 74 68 65 6E 0A 20 20 20 20 44 41 54 41 44 49 52 3D 24 4D 59 5F 42 41 53 45 44 49 52 5F 56 45 52 53 49 4F 4E 2F 76 61 72 0A 20 20 23 20 4F 72 20 6A 75 73 74 20 67 69 76 65 20 75 70 20 61 6E 64 20 75 73 65 20 6F 75 72 20 63 6F 6D 70 69 6C 65 64 2D 69 6E 20 64 65 66 61 75 6C 74 0A 20 20 65 6C 73 65 0A 20 20 20 20 44 41 54 41 44 49 52 3D 2F 76 61 72 2F 6C 69 62 2F 6D 79 73 71 6C 0A 20 20 66 69 0A 66 69 0A 0A 69 66 20 74 65 73 74 20 21 20 2D 78 20 22 24 62 69 6E 64 69 72 2F 6D 79 73 71 6C 63 68 65 63 6B 22 0A 74 68 65 6E 0A 20 20 65 63 68 6F 20 22 43 61 6E 27 74 20 66 69 6E 64 20 70 72 6F 67 72 61 6D 20 27 24 62 69 6E 64 69 72 2F 6D 79 73 71 6C 63 68 65 63 6B 27 22 0A 20 20 65 63 68 6F 20 22 50 6C 65 61 73 65 20 72 65 73 74 61 72 74 20 77 69 74 68 20 2D 2D 62 61 73 65 64 69 72 3D 6D 79 73 71 6C 2D 69 6E 73 74 61 6C 6C 2D 64 69 72 65 63 74 6F 72 79 22 0A 20 20 65 78 69 74 20 31 0A 66 69 0A 0A 69 66 20 74 65 73 74 20 21 20 2D 66 20 22 24 44 41 54 41 44 49 52 2F 6D 79 73 71 6C 2F 75 73 65 72 2E 66 72 6D 22 0A 74 68 65 6E 0A 20 20 65 63 68 6F 20 22 43 61 6E 27 74 20 66 69 6E 64 20 64 61 74 61 20 64 69 72 65 63 74 6F 72 79 2E 20 50 6C 65 61 73 65 20 72 65 73 74 61 72 74 20 77 69 74 68 20 2D 2D 64 61 74 61 64 69 72 3D 70 61 74 68 2D 74 6F 2D 64 61 74 61 2D 64 69 72 22 0A 20 20 65 78 69 74 20 31 0A 66 69 0A 0A 43 48 45 43 4B 5F 46 49 4C 45 3D 24 44 41 54 41 44 49 52 2F 6D 79 73 71 6C 5F 75 70 67 72 61 64 65 2E 69 6E 66 6F 0A 0A 69 66 20 74 65 73 74 20 2D 66 20 24 43 48 45 43 4B 5F 46 49 4C 45 20 2D 61 20 24 66 6F 72 63 65 20 3D 20 30 0A 74 68 65 6E 0A 20 20 76 65 72 73 69 6F 6E 3D 60 63 61 74 20 24 43 48 45 43 4B 5F 46 49 4C 45 60 0A 20 20 69 66 20 74 65 73 74 20 22 24 76 65 72 73 69 6F 6E 22 20 3D 20 22 35 2E 30 22 0A 20 20 74 68 65 6E 0A 20 20 20 20 69 66 20 74 65 73 74 20 24 76 65 72 62 6F 73 65 20 3D 20 31 0A 20 20 20 20 74 68 65 6E 0A 20 20 20 20 20 20 20 65 63 68 6F 20 22 6D 79 73 71 6C 5F 75 70 67 72 61 64 65 20 61 6C 72 65 61 64 79 20 64 6F 6E 65 20 66 6F 72 20 74 68 69 73 20 76 65 72 73 69 6F 6E 22 0A 20 20 20 20 66 69 0A 20 20 20 20 24 62 69 6E 64 69 72 2F 6D 79 73 71 6C 5F 66 69 78 5F 70 72 69 76 69 6C 65 67 65 5F 74 61 62 6C 65 73 20 2D 2D 73 69 6C 65 6E 74 20 24 61 72 67 73 0A 20 20 20 20 65 78 69 74 20 30 0A 20 20 66 69 0A 66 69 0A 0A 23 0A 23 20 52 75 6E 20 74 68 65 20 75 70 67 72 61 64 65 0A 23 0A 0A 63 68 65 63 6B 5F 61 72 67 73 3D 22 2D 2D 63 68 65 63 6B 2D 75 70 67 72 61 64 65 20 2D 2D 61 6C 6C 2D 64 61 74 61 62 61 73 65 73 20 2D 2D 61 75 74 6F 2D 72 65 70 61 69 72 20 2D 2D 75 73 65 72 3D 24 75 73 65 72 22 0A 0A 69 66 20 74 65 73 74 20 24 76 65 72 62 6F 73 65 20 3D 20 31 0A 74 68 65 6E 0A 20 20 65 63 68 6F 20 22 52 75 6E 6E 69 6E 67 20 24 62 69 6E 64 69 72 2F 6D 79 73 71 6C 63 68 65 63 6B 20 24 61 72 67 73 20 24 63 68 65 63 6B 5F 61 72 67 73 22 0A 66 69 0A 0A 24 62 69 6E 64 69 72 2F 6D 79 73 71 6C 63 68 65 63 6B 20 24 63 68 65 63 6B 5F 61 72 67 73 20 24 61 72 67 73 0A 69 66 20 5B 20 24 3F 20 3D 20 30 20 5D 0A 74 68 65 6E 0A 20 20 23 20 52 65 6D 65 6D 62 65 72 20 62 61 73 65 20 76 65 72 73 69 6F 6E 20 73 6F 20 74 68 61 74 20 77 65 20 64 6F 6E 27 74 20 72 75 6E 20 74 68 69 73 20 73 63 72 69 70 74 20 61 67 61 69 6E 20 6F 6E 20 74 68 65 0A 20 20 23 20 73 61 6D 65 20 62 61 73 65 20 76 65 72 73 69 6F 6E 0A 20 20 65 63 68 6F 20 22 35 2E 30 22 20 3E 20 24 43 48 45 43 4B 5F 46 49 4C 45 0A 66 69 0A 0A 24 62 69 6E 64 69 72 2F 6D 79 73 71 6C 5F 66 69 78 5F 70 72 69 76 69 6C 65 67 65 5F 74 61 62 6C 65 73 20 2D 2D 73 69 6C 65 6E 74 20 2D 2D 75 73 65 72 3D 24 75 73 65 72 20 24 61 72 67 73 0A | #!/bin/sh # Copyright (C ) 2002-2003 MySQL AB # # This program is free s oftware; you can redistr ibute it and/or modify # it under the terms of t he GNU General Public Li cense as published by # the Free Software Founda tion; version 2 of the L icense. # # This progra m is distributed in the hope that it will be use ful, # but WITHOUT ANY W ARRANTY; without even th e implied warranty of # MERCHANTABILITY or FITNE SS FOR A PARTICULAR PURP OSE. See the # GNU Gene ral Public License for m ore details. # # You sh ould have received a cop y of the GNU General Pub lic License # along with this program; if not, w rite to the Free Softwar e # Foundation, Inc., 51 Franklin St, Fifth Floo r, Boston, MA 02110-130 1 USA # Runs mysqlchec k --check-upgrade in cas e it has not been done o n this # major MySQL ver sion # This script shou ld always be run when up grading from one major v ersion # to another (ie: 4.1 -> 5.0 -> 5.1) # # Note that in most cases one have to use '--pass word' as # arguments as these needs to be passed on to the mysqlcheck co mmand user=root case "$1" in --no-default s|--defaults-file=*|--de faults-extra-file=*) defaults="$1"; shift ;; esac parse_arg uments() { # We only n eed to pass arguments th rough to the server if w e don't # handle them here. So, we collect un recognized options (pass ed on # the command li ne) into the args variab le. pick_args= if te st "$1" = PICK-ARGS-FROM -ARGV then pick_ar gs=1 shift fi f or arg do case "$arg " in --basedir=*) MY_BASEDIR_VERSION=`echo "$arg" | sed -e 's/^[^= ]*=//'` ;; --user= *) user=`echo "$arg" | s ed -e 's/^[^=]*=//'` ;; --ldata=*|--data=* |--datadir=*) DATADIR=`e cho "$arg" | sed -e 's/^ [^=]*=//'` ;; --fo rce) force=1 ;; -- verbose) verbose=1 ;; --help) help_option= 1 ;; *) if test -n "$pick_args" then # T his sed command makes su re that any special char s are quoted, # so the arg gets passed exactly to the server. args="$args "` echo "$arg" | sed -e 's, \([^a-zA-Z0-9_.=-]\),\\\ \\1,g'` fi ;; esac done } # # Find where my_print _defaults is # find_my_ print_defaults () { if test -x ./bin/my_print_ defaults then prin t_defaults="./bin/my_pri nt_defaults" elif test -x ./extra/my_print_def aults then print_d efaults="./extra/my_prin t_defaults" elif test -x /usr/bin/my_print_def aults then print_d efaults="/usr/bin/my_pri nt_defaults" elif test -x /usr/bin/mysql_print _defaults then pri nt_defaults="/usr/bin/my sql_print_defaults" el se print_defaults="m y_print_defaults" fi } find_my_print_defaults # Get first arguments from the my.cfg file, gr oups [mysqld] and # [mys ql_upgrade], and then me rge with the command lin e arguments args= DATAD IR= bindir= MY_BASEDIR_V ERSION= verbose=0 force= 0 help_option=0 parse_a rguments `$print_default s $defaults mysqld mysql _upgrade` parse_argument s PICK-ARGS-FROM-ARGV "$ @" if test $help_option = 1 then echo "MySQL utility script to upgrad e database to the curren t server version" echo "" echo "It takes the following arguments:" echo " --help Show this help message" ec ho " --basedir Specifi es the directory where M ySQL is installed" ech o " --datadir Specifie s the data directory" echo " --force Mysql _upgrade.info file will be ignored" echo " -- user Username for se rver login if not curren t user" echo " --verb ose Display more output about the process" ec ho "" exit 0 fi # # Try to find where binari es are installed # MY_P WD=`pwd` # Check for the directories we would ex pect from a binary relea se install if test -z "$ MY_BASEDIR_VERSION" then if test -f ./share/my sql/english/errmsg.sys - a -x ./bin/mysqld then MY_BASEDIR_VERSION= $MY_PWD # Whe re bin, share and data a re bindir="$MY_BASED IR_VERSION/bin" # Chec k for the directories we would expect from a sou rce install elif test -f ./share/mysql/english /errmsg.sys -a -x ./libe xec/mysqld then MY _BASEDIR_VERSION=$MY_PWD # Where libe xec, share and var are bindir="$MY_BASEDIR_V ERSION/bin" # Since we d idn't find anything, use d the compiled-in defaul ts else MY_BASEDIR _VERSION=/usr bindir =/usr/bin fi else bi ndir="$MY_BASEDIR_VERSIO N/bin" fi # # Try to fi nd the data directory # if test -z "$DATADIR" t hen # Try where the bi nary installs put it i f test -d $MY_BASEDIR_VE RSION/data/mysql then DATADIR=$MY_BASEDIR_ VERSION/data # Next tr y where the source insta lls put it elif test - d $MY_BASEDIR_VERSION/va r/mysql then DATAD IR=$MY_BASEDIR_VERSION/v ar # Or just give up a nd use our compiled-in d efault else DATADI R=/var/lib/mysql fi fi if test ! -x "$bindir/ mysqlcheck" then echo "Can't find program '$bi ndir/mysqlcheck'" echo "Please restart with -- basedir=mysql-install-di rectory" exit 1 fi if test ! -f "$DATADIR/mys ql/user.frm" then echo "Can't find data direct ory. Please restart with --datadir=path-to-data- dir" exit 1 fi CHECK_ FILE=$DATADIR/mysql_upgr ade.info if test -f $CH ECK_FILE -a $force = 0 t hen version=`cat $CHEC K_FILE` if test "$vers ion" = "5.0" then if test $verbose = 1 then echo "mysql _upgrade already done fo r this version" fi $bindir/mysql_fix_pri vilege_tables --silent $ args exit 0 fi fi # # Run the upgrade # check_args="--check-upgr ade --all-databases --au to-repair --user=$user" if test $verbose = 1 th en echo "Running $bind ir/mysqlcheck $args $che ck_args" fi $bindir/mys qlcheck $check_args $arg s if [ $? = 0 ] then # Remember base version s o that we don't run this script again on the # same base version ech o "5.0" > $CHECK_FILE fi $bindir/mysql_fix_priv ilege_tables --silent -- user=$user $args |