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
| 23 21 2F 62 69 6E 2F 62 61 73 68 0A 23 0A 23 20 6D 79 73 71 6C 64 09 54 68 69 73 20 73 68 65 6C 6C 20 73 63 72 69 70 74 20 74 61 6B 65 73 20 63 61 72 65 20 6F 66 20 73 74 61 72 74 69 6E 67 20 61 6E 64 20 73 74 6F 70 70 69 6E 67 0A 23 09 09 74 68 65 20 4D 79 53 51 4C 20 73 75 62 73 79 73 74 65 6D 20 28 6D 79 73 71 6C 64 29 2E 0A 23 0A 23 20 63 68 6B 63 6F 6E 66 69 67 3A 20 2D 20 36 34 20 33 36 0A 23 20 64 65 73 63 72 69 70 74 69 6F 6E 3A 09 4D 79 53 51 4C 20 64 61 74 61 62 61 73 65 20 73 65 72 76 65 72 2E 0A 23 20 70 72 6F 63 65 73 73 6E 61 6D 65 3A 20 6D 79 73 71 6C 64 0A 23 20 63 6F 6E 66 69 67 3A 20 2F 65 74 63 2F 6D 79 2E 63 6E 66 0A 23 20 70 69 64 66 69 6C 65 3A 20 2F 76 61 72 2F 72 75 6E 2F 6D 79 73 71 6C 64 2F 6D 79 73 71 6C 64 2E 70 69 64 0A 0A 23 20 53 6F 75 72 63 65 20 66 75 6E 63 74 69 6F 6E 20 6C 69 62 72 61 72 79 2E 0A 2E 20 2F 65 74 63 2F 72 63 2E 64 2F 69 6E 69 74 2E 64 2F 66 75 6E 63 74 69 6F 6E 73 0A 0A 23 20 53 6F 75 72 63 65 20 6E 65 74 77 6F 72 6B 69 6E 67 20 63 6F 6E 66 69 67 75 72 61 74 69 6F 6E 2E 0A 2E 20 2F 65 74 63 2F 73 79 73 63 6F 6E 66 69 67 2F 6E 65 74 77 6F 72 6B 0A 0A 0A 70 72 6F 67 3D 22 4D 79 53 51 4C 22 0A 0A 23 20 65 78 74 72 61 63 74 20 76 61 6C 75 65 20 6F 66 20 61 20 4D 79 53 51 4C 20 6F 70 74 69 6F 6E 20 66 72 6F 6D 20 63 6F 6E 66 69 67 20 66 69 6C 65 73 0A 23 20 55 73 61 67 65 3A 20 67 65 74 5F 6D 79 73 71 6C 5F 6F 70 74 69 6F 6E 20 53 45 43 54 49 4F 4E 20 56 41 52 4E 41 4D 45 20 44 45 46 41 55 4C 54 0A 23 20 72 65 73 75 6C 74 20 69 73 20 72 65 74 75 72 6E 65 64 20 69 6E 20 24 72 65 73 75 6C 74 0A 23 20 57 65 20 75 73 65 20 6D 79 5F 70 72 69 6E 74 5F 64 65 66 61 75 6C 74 73 20 77 68 69 63 68 20 70 72 69 6E 74 73 20 61 6C 6C 20 6F 70 74 69 6F 6E 73 20 66 72 6F 6D 20 6D 75 6C 74 69 70 6C 65 20 66 69 6C 65 73 2C 0A 23 20 77 69 74 68 20 74 68 65 20 6D 6F 72 65 20 73 70 65 63 69 66 69 63 20 6F 6E 65 73 20 6C 61 74 65 72 3B 20 68 65 6E 63 65 20 74 61 6B 65 20 74 68 65 20 6C 61 73 74 20 6D 61 74 63 68 2E 0A 67 65 74 5F 6D 79 73 71 6C 5F 6F 70 74 69 6F 6E 28 29 7B 0A 09 72 65 73 75 6C 74 3D 60 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 20 22 24 31 22 20 7C 20 73 65 64 20 2D 6E 20 22 73 2F 5E 2D 2D 24 32 3D 2F 2F 70 22 20 7C 20 74 61 69 6C 20 2D 6E 20 31 60 0A 09 69 66 20 5B 20 2D 7A 20 22 24 72 65 73 75 6C 74 22 20 5D 3B 20 74 68 65 6E 0A 09 20 20 20 20 23 20 6E 6F 74 20 66 6F 75 6E 64 2C 20 75 73 65 20 64 65 66 61 75 6C 74 0A 09 20 20 20 20 72 65 73 75 6C 74 3D 22 24 33 22 0A 09 66 69 0A 7D 0A 0A 67 65 74 5F 6D 79 73 71 6C 5F 6F 70 74 69 6F 6E 20 6D 79 73 71 6C 64 20 64 61 74 61 64 69 72 20 22 2F 76 61 72 2F 6C 69 62 2F 6D 79 73 71 6C 22 0A 64 61 74 61 64 69 72 3D 22 24 72 65 73 75 6C 74 22 0A 67 65 74 5F 6D 79 73 71 6C 5F 6F 70 74 69 6F 6E 20 6D 79 73 71 6C 64 20 73 6F 63 6B 65 74 20 22 24 64 61 74 61 64 69 72 2F 6D 79 73 71 6C 2E 73 6F 63 6B 22 0A 73 6F 63 6B 65 74 66 69 6C 65 3D 22 24 72 65 73 75 6C 74 22 0A 67 65 74 5F 6D 79 73 71 6C 5F 6F 70 74 69 6F 6E 20 6D 79 73 71 6C 64 5F 73 61 66 65 20 6C 6F 67 2D 65 72 72 6F 72 20 22 2F 76 61 72 2F 6C 6F 67 2F 6D 79 73 71 6C 64 2E 6C 6F 67 22 0A 65 72 72 6C 6F 67 66 69 6C 65 3D 22 24 72 65 73 75 6C 74 22 0A 67 65 74 5F 6D 79 73 71 6C 5F 6F 70 74 69 6F 6E 20 6D 79 73 71 6C 64 5F 73 61 66 65 20 70 69 64 2D 66 69 6C 65 20 22 2F 76 61 72 2F 72 75 6E 2F 6D 79 73 71 6C 64 2F 6D 79 73 71 6C 64 2E 70 69 64 22 0A 6D 79 70 69 64 66 69 6C 65 3D 22 24 72 65 73 75 6C 74 22 0A 0A 73 74 61 72 74 28 29 7B 0A 09 74 6F 75 63 68 20 22 24 65 72 72 6C 6F 67 66 69 6C 65 22 0A 09 63 68 6F 77 6E 20 6D 79 73 71 6C 3A 6D 79 73 71 6C 20 22 24 65 72 72 6C 6F 67 66 69 6C 65 22 20 0A 09 63 68 6D 6F 64 20 30 36 34 30 20 22 24 65 72 72 6C 6F 67 66 69 6C 65 22 0A 09 5B 20 2D 78 20 2F 73 62 69 6E 2F 72 65 73 74 6F 72 65 63 6F 6E 20 5D 20 26 26 20 2F 73 62 69 6E 2F 72 65 73 74 6F 72 65 63 6F 6E 20 22 24 65 72 72 6C 6F 67 66 69 6C 65 22 0A 09 69 66 20 5B 20 21 20 2D 64 20 22 24 64 61 74 61 64 69 72 2F 6D 79 73 71 6C 22 20 5D 20 3B 20 74 68 65 6E 0A 09 20 20 20 20 61 63 74 69 6F 6E 20 24 22 49 6E 69 74 69 61 6C 69 7A 69 6E 67 20 4D 79 53 51 4C 20 64 61 74 61 62 61 73 65 3A 20 22 20 2F 75 73 72 2F 62 69 6E 2F 6D 79 73 71 6C 5F 69 6E 73 74 61 6C 6C 5F 64 62 20 2D 2D 64 61 74 61 64 69 72 3D 22 24 64 61 74 61 64 69 72 22 20 2D 2D 75 73 65 72 3D 6D 79 73 71 6C 0A 09 20 20 20 20 72 65 74 3D 24 3F 0A 09 20 20 20 20 63 68 6F 77 6E 20 2D 52 20 6D 79 73 71 6C 3A 6D 79 73 71 6C 20 22 24 64 61 74 61 64 69 72 22 0A 09 20 20 20 20 69 66 20 5B 20 24 72 65 74 20 2D 6E 65 20 30 20 5D 20 3B 20 74 68 65 6E 0A 09 09 72 65 74 75 72 6E 20 24 72 65 74 0A 09 20 20 20 20 66 69 0A 09 66 69 0A 09 63 68 6F 77 6E 20 6D 79 73 71 6C 3A 6D 79 73 71 6C 20 22 24 64 61 74 61 64 69 72 22 0A 09 63 68 6D 6F 64 20 30 37 35 35 20 22 24 64 61 74 61 64 69 72 22 0A 09 23 20 50 61 73 73 20 61 6C 6C 20 74 68 65 20 6F 70 74 69 6F 6E 73 20 64 65 74 65 72 6D 69 6E 65 64 20 61 62 6F 76 65 2C 20 74 6F 20 65 6E 73 75 72 65 20 63 6F 6E 73 69 73 74 65 6E 74 20 62 65 68 61 76 69 6F 72 2E 0A 09 23 20 49 6E 20 6D 61 6E 79 20 63 61 73 65 73 20 6D 79 73 71 6C 64 5F 73 61 66 65 20 77 6F 75 6C 64 20 61 72 72 69 76 65 20 61 74 20 74 68 65 20 73 61 6D 65 20 63 6F 6E 63 6C 75 73 69 6F 6E 73 20 61 6E 79 77 61 79 0A 09 23 20 62 75 74 20 77 65 20 6E 65 65 64 20 74 6F 20 62 65 20 73 75 72 65 2E 0A 09 2F 75 73 72 2F 62 69 6E 2F 6D 79 73 71 6C 64 5F 73 61 66 65 20 20 20 2D 2D 64 61 74 61 64 69 72 3D 22 24 64 61 74 61 64 69 72 22 20 2D 2D 73 6F 63 6B 65 74 3D 22 24 73 6F 63 6B 65 74 66 69 6C 65 22 20 5C 0A 09 09 2D 2D 6C 6F 67 2D 65 72 72 6F 72 3D 22 24 65 72 72 6C 6F 67 66 69 6C 65 22 20 2D 2D 70 69 64 2D 66 69 6C 65 3D 22 24 6D 79 70 69 64 66 69 6C 65 22 20 5C 0A 09 09 2D 2D 75 73 65 72 3D 6D 79 73 71 6C 20 3E 2F 64 65 76 2F 6E 75 6C 6C 20 32 3E 26 31 20 26 0A 09 72 65 74 3D 24 3F 0A 09 23 20 53 70 69 6E 20 66 6F 72 20 61 20 6D 61 78 69 6D 75 6D 20 6F 66 20 4E 20 73 65 63 6F 6E 64 73 20 77 61 69 74 69 6E 67 20 66 6F 72 20 74 68 65 20 73 65 72 76 65 72 20 74 6F 20 63 6F 6D 65 20 75 70 2E 0A 09 23 20 52 61 74 68 65 72 20 74 68 61 6E 20 61 73 73 75 6D 69 6E 67 20 77 65 20 6B 6E 6F 77 20 61 20 76 61 6C 69 64 20 75 73 65 72 6E 61 6D 65 2C 20 61 63 63 65 70 74 20 61 6E 20 22 61 63 63 65 73 73 0A 09 23 20 64 65 6E 69 65 64 22 20 72 65 73 70 6F 6E 73 65 20 61 73 20 6D 65 61 6E 69 6E 67 20 74 68 65 20 73 65 72 76 65 72 20 69 73 20 66 75 6E 63 74 69 6F 6E 69 6E 67 2E 0A 09 69 66 20 5B 20 24 72 65 74 20 2D 65 71 20 30 20 5D 3B 20 74 68 65 6E 0A 09 20 20 20 20 53 54 41 52 54 54 49 4D 45 4F 55 54 3D 33 30 0A 09 20 20 20 20 77 68 69 6C 65 20 5B 20 24 53 54 41 52 54 54 49 4D 45 4F 55 54 20 2D 67 74 20 30 20 5D 3B 20 64 6F 0A 09 09 52 45 53 50 4F 4E 53 45 3D 60 2F 75 73 72 2F 62 69 6E 2F 6D 79 73 71 6C 61 64 6D 69 6E 20 2D 2D 73 6F 63 6B 65 74 3D 22 24 73 6F 63 6B 65 74 66 69 6C 65 22 20 2D 2D 75 73 65 72 3D 55 4E 4B 4E 4F 57 4E 5F 4D 59 53 51 4C 5F 55 53 45 52 20 70 69 6E 67 20 32 3E 26 31 60 20 26 26 20 62 72 65 61 6B 0A 09 09 65 63 68 6F 20 22 24 52 45 53 50 4F 4E 53 45 22 20 7C 20 67 72 65 70 20 2D 71 20 22 41 63 63 65 73 73 20 64 65 6E 69 65 64 20 66 6F 72 20 75 73 65 72 22 20 26 26 20 62 72 65 61 6B 0A 09 09 73 6C 65 65 70 20 31 0A 09 09 6C 65 74 20 53 54 41 52 54 54 49 4D 45 4F 55 54 3D 24 7B 53 54 41 52 54 54 49 4D 45 4F 55 54 7D 2D 31 0A 09 20 20 20 20 64 6F 6E 65 0A 09 20 20 20 20 69 66 20 5B 20 24 53 54 41 52 54 54 49 4D 45 4F 55 54 20 2D 65 71 20 30 20 5D 3B 20 74 68 65 6E 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 65 63 68 6F 20 22 54 69 6D 65 6F 75 74 20 65 72 72 6F 72 20 6F 63 63 75 72 72 65 64 20 74 72 79 69 6E 67 20 74 6F 20 73 74 61 72 74 20 4D 79 53 51 4C 20 44 61 65 6D 6F 6E 2E 22 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 61 63 74 69 6F 6E 20 24 22 53 74 61 72 74 69 6E 67 20 24 70 72 6F 67 3A 20 22 20 2F 62 69 6E 2F 66 61 6C 73 65 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 3D 31 0A 20 20 20 20 20 20 20 20 20 20 20 20 65 6C 73 65 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 61 63 74 69 6F 6E 20 24 22 53 74 61 72 74 69 6E 67 20 24 70 72 6F 67 3A 20 22 20 2F 62 69 6E 2F 74 72 75 65 0A 20 20 20 20 20 20 20 20 20 20 20 20 66 69 0A 09 65 6C 73 65 0A 20 20 20 20 09 20 20 20 20 61 63 74 69 6F 6E 20 24 22 53 74 61 72 74 69 6E 67 20 24 70 72 6F 67 3A 20 22 20 2F 62 69 6E 2F 66 61 6C 73 65 0A 09 66 69 0A 09 5B 20 24 72 65 74 20 2D 65 71 20 30 20 5D 20 26 26 20 74 6F 75 63 68 20 2F 76 61 72 2F 6C 6F 63 6B 2F 73 75 62 73 79 73 2F 6D 79 73 71 6C 64 0A 09 72 65 74 75 72 6E 20 24 72 65 74 0A 7D 0A 0A 73 74 6F 70 28 29 7B 0A 20 20 20 20 20 20 20 20 4D 59 53 51 4C 50 49 44 3D 60 63 61 74 20 22 24 6D 79 70 69 64 66 69 6C 65 22 20 20 32 3E 2F 64 65 76 2F 6E 75 6C 6C 20 60 0A 20 20 20 20 20 20 20 20 69 66 20 5B 20 2D 6E 20 22 24 4D 59 53 51 4C 50 49 44 22 20 5D 3B 20 74 68 65 6E 0A 20 20 20 20 20 20 20 20 20 20 20 20 2F 62 69 6E 2F 6B 69 6C 6C 20 22 24 4D 59 53 51 4C 50 49 44 22 20 3E 2F 64 65 76 2F 6E 75 6C 6C 20 32 3E 26 31 0A 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 3D 24 3F 0A 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 5B 20 24 72 65 74 20 2D 65 71 20 30 20 5D 3B 20 74 68 65 6E 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 53 54 4F 50 54 49 4D 45 4F 55 54 3D 36 30 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 77 68 69 6C 65 20 5B 20 24 53 54 4F 50 54 49 4D 45 4F 55 54 20 2D 67 74 20 30 20 5D 3B 20 64 6F 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2F 62 69 6E 2F 6B 69 6C 6C 20 2D 30 20 22 24 4D 59 53 51 4C 50 49 44 22 20 3E 2F 64 65 76 2F 6E 75 6C 6C 20 32 3E 26 31 20 7C 7C 20 62 72 65 61 6B 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 6C 65 65 70 20 31 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6C 65 74 20 53 54 4F 50 54 49 4D 45 4F 55 54 3D 24 7B 53 54 4F 50 54 49 4D 45 4F 55 54 7D 2D 31 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 64 6F 6E 65 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 5B 20 24 53 54 4F 50 54 49 4D 45 4F 55 54 20 2D 65 71 20 30 20 5D 3B 20 74 68 65 6E 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 65 63 68 6F 20 22 54 69 6D 65 6F 75 74 20 65 72 72 6F 72 20 6F 63 63 75 72 72 65 64 20 74 72 79 69 6E 67 20 74 6F 20 73 74 6F 70 20 4D 79 53 51 4C 20 44 61 65 6D 6F 6E 2E 22 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 3D 31 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 61 63 74 69 6F 6E 20 24 22 53 74 6F 70 70 69 6E 67 20 24 70 72 6F 67 3A 20 22 20 2F 62 69 6E 2F 66 61 6C 73 65 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 65 6C 73 65 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72 6D 20 2D 66 20 2F 76 61 72 2F 6C 6F 63 6B 2F 73 75 62 73 79 73 2F 6D 79 73 71 6C 64 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72 6D 20 2D 66 20 22 24 73 6F 63 6B 65 74 66 69 6C 65 22 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 61 63 74 69 6F 6E 20 24 22 53 74 6F 70 70 69 6E 67 20 24 70 72 6F 67 3A 20 22 20 2F 62 69 6E 2F 74 72 75 65 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 66 69 0A 20 20 20 20 20 20 20 20 20 20 20 20 65 6C 73 65 0A 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 61 63 74 69 6F 6E 20 24 22 53 74 6F 70 70 69 6E 67 20 24 70 72 6F 67 3A 20 22 20 2F 62 69 6E 2F 66 61 6C 73 65 0A 20 20 20 20 20 20 20 20 20 20 20 20 66 69 0A 20 20 20 20 20 20 20 20 65 6C 73 65 0A 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 3D 31 0A 20 20 20 20 20 20 20 20 20 20 20 20 61 63 74 69 6F 6E 20 24 22 53 74 6F 70 70 69 6E 67 20 24 70 72 6F 67 3A 20 22 20 2F 62 69 6E 2F 66 61 6C 73 65 0A 20 20 20 20 20 20 20 20 66 69 0A 20 20 20 20 20 20 20 20 72 65 74 75 72 6E 20 24 72 65 74 0A 7D 0A 20 0A 72 65 73 74 61 72 74 28 29 7B 0A 20 20 20 20 73 74 6F 70 0A 20 20 20 20 73 74 61 72 74 0A 7D 0A 0A 63 6F 6E 64 72 65 73 74 61 72 74 28 29 7B 0A 20 20 20 20 5B 20 2D 65 20 2F 76 61 72 2F 6C 6F 63 6B 2F 73 75 62 73 79 73 2F 6D 79 73 71 6C 64 20 5D 20 26 26 20 72 65 73 74 61 72 74 20 7C 7C 20 3A 0A 7D 0A 0A 23 20 53 65 65 20 68 6F 77 20 77 65 20 77 65 72 65 20 63 61 6C 6C 65 64 2E 0A 63 61 73 65 20 22 24 31 22 20 69 6E 0A 20 20 73 74 61 72 74 29 0A 20 20 20 20 73 74 61 72 74 0A 20 20 20 20 3B 3B 0A 20 20 73 74 6F 70 29 0A 20 20 20 20 73 74 6F 70 0A 20 20 20 20 3B 3B 0A 20 20 73 74 61 74 75 73 29 0A 20 20 20 20 73 74 61 74 75 73 20 6D 79 73 71 6C 64 0A 20 20 20 20 3B 3B 0A 20 20 72 65 73 74 61 72 74 29 0A 20 20 20 20 72 65 73 74 61 72 74 0A 20 20 20 20 3B 3B 0A 20 20 63 6F 6E 64 72 65 73 74 61 72 74 29 0A 20 20 20 20 63 6F 6E 64 72 65 73 74 61 72 74 0A 20 20 20 20 3B 3B 0A 20 20 2A 29 0A 20 20 20 20 65 63 68 6F 20 24 22 55 73 61 67 65 3A 20 24 30 20 7B 73 74 61 72 74 7C 73 74 6F 70 7C 73 74 61 74 75 73 7C 63 6F 6E 64 72 65 73 74 61 72 74 7C 72 65 73 74 61 72 74 7D 22 0A 20 20 20 20 65 78 69 74 20 31 0A 65 73 61 63 0A 0A 65 78 69 74 20 24 3F 0A | #!/bin/bash # # mysqld T his shell script takes c are of starting and stop ping # the MySQL subsys tem (mysqld). # # chkcon fig: - 64 36 # descripti on: MySQL database serve r. # processname: mysqld # config: /etc/my.cnf # pidfile: /var/run/mysql d/mysqld.pid # Source f unction library. . /etc/ rc.d/init.d/functions # Source networking confi guration. . /etc/sysconf ig/network prog="MySQL " # extract value of a MySQL option from config files # Usage: get_mysq l_option SECTION VARNAME DEFAULT # result is ret urned in $result # We us e my_print_defaults whic h prints all options fro m multiple files, # with the more specific ones later; hence take the la st match. get_mysql_opti on(){ result=`/usr/bin/ my_print_defaults "$1" | sed -n "s/^--$2=//p" | tail -n 1` if [ -z "$re sult" ]; then # not found, use default result="$3" fi } get_ mysql_option mysqld data dir "/var/lib/mysql" dat adir="$result" get_mysql _option mysqld socket "$ datadir/mysql.sock" sock etfile="$result" get_mys ql_option mysqld_safe lo g-error "/var/log/mysqld .log" errlogfile="$resul t" get_mysql_option mysq ld_safe pid-file "/var/r un/mysqld/mysqld.pid" my pidfile="$result" start (){ touch "$errlogfile" chown mysql:mysql "$er rlogfile" chmod 0640 " $errlogfile" [ -x /sbin /restorecon ] && /sbin/r estorecon "$errlogfile" if [ ! -d "$datadir/mys ql" ] ; then action $"Initializing MySQL da tabase: " /usr/bin/mysql _install_db --datadir="$ datadir" --user=mysql ret=$? chown -R mysql:mysql "$datadir" if [ $ret -ne 0 ] ; then return $ret fi fi chown mysql:mysq l "$datadir" chmod 0755 "$datadir" # Pass all the options determined a bove, to ensure consiste nt behavior. # In many cases mysqld_safe would arrive at the same concl usions anyway # but we need to be sure. /usr/b in/mysqld_safe --datad ir="$datadir" --socket=" $socketfile" \ --log-e rror="$errlogfile" --pid -file="$mypidfile" \ - -user=mysql >/dev/null 2 >&1 & ret=$? # Spin fo r a maximum of N seconds waiting for the server to come up. # Rather th an assuming we know a va lid username, accept an "access # denied" respo nse as meaning the serve r is functioning. if [ $ret -eq 0 ]; then STARTTIMEOUT=30 whi le [ $STARTTIMEOUT -gt 0 ]; do RESPONSE=`/usr/ bin/mysqladmin --socket= "$socketfile" --user=UNK NOWN_MYSQL_USER ping 2>& 1` && break echo "$RES PONSE" | grep -q "Access denied for user" && bre ak sleep 1 let START TIMEOUT=${STARTTIMEOUT}- 1 done if [ $S TARTTIMEOUT -eq 0 ]; the n ec ho "Timeout error occurr ed trying to start MySQL Daemon." action $"Starting $prog: " /bin/false ret=1 else action $"Star ting $prog: " /bin/true fi else action $"Starting $prog: " /bin/false fi [ $ret -eq 0 ] && touch /var/lock/subsys/mysqld return $ret } stop(){ MYSQLPID=`cat " $mypidfile" 2>/dev/null ` if [ -n "$MYS QLPID" ]; then /bin/kill "$MYSQLPID" >/dev/null 2>&1 ret=$? if [ $ret -eq 0 ]; then STOPTIME OUT=60 w hile [ $STOPTIMEOUT -gt 0 ]; do /bin/kill -0 "$MYSQL PID" >/dev/null 2>&1 || break sleep 1 let STOPTIMEOUT=${ STOPTIMEOUT}-1 done if [ $STOPTIMEOUT -e q 0 ]; then echo "Timeout er ror occurred trying to s top MySQL Daemon." ret=1 action $"Stopping $prog: " /bin /false e lse rm -f /var/lock/subsys/m ysqld rm -f "$socketfile" action $"Stopping $prog: " /bi n/true f i else action $"Stop ping $prog: " /bin/false fi else ret=1 action $"Stop ping $prog: " /bin/false fi retu rn $ret } restart(){ stop start } con drestart(){ [ -e /va r/lock/subsys/mysqld ] & & restart || : } # See how we were called. case "$1" in start) st art ;; stop) s top ;; status) status mysqld ;; restart) restart ;; condrestart) c ondrestart ;; *) echo $"Usage: $0 {sta rt|stop|status|condresta rt|restart}" exit 1 esac exit $? |