Ci8qIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tClNvZnR3YXJlIExpY2Vuc2UgZm9yIFRoZSBGcmF1bmhvZmVyIEZESyBBQUMgQ29kZWMgTGlicmFyeSBmb3IgQW5kcm9pZAoKqSBDb3B5cmlnaHQgIDE5OTUgLSAyMDEyIEZyYXVuaG9mZXItR2VzZWxsc2NoYWZ0IHp1ciBG9nJkZXJ1bmcgZGVyIGFuZ2V3YW5kdGVuIEZvcnNjaHVuZyBlLlYuCiAgQWxsIHJpZ2h0cyByZXNlcnZlZC4KCiAxLiAgICBJTlRST0RVQ1RJT04KVGhlIEZyYXVuaG9mZXIgRkRLIEFBQyBDb2RlYyBMaWJyYXJ5IGZvciBBbmRyb2lkICgiRkRLIEFBQyBDb2RlYyIpIGlzIHNvZnR3YXJlIHRoYXQgaW1wbGVtZW50cwp0aGUgTVBFRyBBZHZhbmNlZCBBdWRpbyBDb2RpbmcgKCJBQUMiKSBlbmNvZGluZyBhbmQgZGVjb2Rpbmcgc2NoZW1lIGZvciBkaWdpdGFsIGF1ZGlvLgpUaGlzIEZESyBBQUMgQ29kZWMgc29mdHdhcmUgaXMgaW50ZW5kZWQgdG8gYmUgdXNlZCBvbiBhIHdpZGUgdmFyaWV0eSBvZiBBbmRyb2lkIGRldmljZXMuCgpBQUMncyBIRS1BQUMgYW5kIEhFLUFBQyB2MiB2ZXJzaW9ucyBhcmUgcmVnYXJkZWQgYXMgdG9kYXkncyBtb3N0IGVmZmljaWVudCBnZW5lcmFsIHBlcmNlcHR1YWwKYXVkaW8gY29kZWNzLiBBQUMtRUxEIGlzIGNvbnNpZGVyZWQgdGhlIGJlc3QtcGVyZm9ybWluZyBmdWxsLWJhbmR3aWR0aCBjb21tdW5pY2F0aW9ucyBjb2RlYyBieQppbmRlcGVuZGVudCBzdHVkaWVzIGFuZCBpcyB3aWRlbHkgZGVwbG95ZWQuIEFBQyBoYXMgYmVlbiBzdGFuZGFyZGl6ZWQgYnkgSVNPIGFuZCBJRUMgYXMgcGFydApvZiB0aGUgTVBFRyBzcGVjaWZpY2F0aW9ucy4KClBhdGVudCBsaWNlbnNlcyBmb3IgbmVjZXNzYXJ5IHBhdGVudCBjbGFpbXMgZm9yIHRoZSBGREsgQUFDIENvZGVjIChpbmNsdWRpbmcgdGhvc2Ugb2YgRnJhdW5ob2ZlcikKbWF5IGJlIG9idGFpbmVkIHRocm91Z2ggVmlhIExpY2Vuc2luZyAod3d3LnZpYWxpY2Vuc2luZy5jb20pIG9yIHRocm91Z2ggdGhlIHJlc3BlY3RpdmUgcGF0ZW50IG93bmVycwppbmRpdmlkdWFsbHkgZm9yIHRoZSBwdXJwb3NlIG9mIGVuY29kaW5nIG9yIGRlY29kaW5nIGJpdCBzdHJlYW1zIGluIHByb2R1Y3RzIHRoYXQgYXJlIGNvbXBsaWFudCB3aXRoCnRoZSBJU08vSUVDIE1QRUcgYXVkaW8gc3RhbmRhcmRzLiBQbGVhc2Ugbm90ZSB0aGF0IG1vc3QgbWFudWZhY3R1cmVycyBvZiBBbmRyb2lkIGRldmljZXMgYWxyZWFkeSBsaWNlbnNlCnRoZXNlIHBhdGVudCBjbGFpbXMgdGhyb3VnaCBWaWEgTGljZW5zaW5nIG9yIGRpcmVjdGx5IGZyb20gdGhlIHBhdGVudCBvd25lcnMsIGFuZCB0aGVyZWZvcmUgRkRLIEFBQyBDb2RlYwpzb2Z0d2FyZSBtYXkgYWxyZWFkeSBiZSBjb3ZlcmVkIHVuZGVyIHRob3NlIHBhdGVudCBsaWNlbnNlcyB3aGVuIGl0IGlzIHVzZWQgZm9yIHRob3NlIGxpY2Vuc2VkIHB1cnBvc2VzIG9ubHkuCgpDb21tZXJjaWFsbHktbGljZW5zZWQgQUFDIHNvZnR3YXJlIGxpYnJhcmllcywgaW5jbHVkaW5nIGZsb2F0aW5nLXBvaW50IHZlcnNpb25zIHdpdGggZW5oYW5jZWQgc291bmQgcXVhbGl0eSwKYXJlIGFsc28gYXZhaWxhYmxlIGZyb20gRnJhdW5ob2Zlci4gVXNlcnMgYXJlIGVuY291cmFnZWQgdG8gY2hlY2sgdGhlIEZyYXVuaG9mZXIgd2Vic2l0ZSBmb3IgYWRkaXRpb25hbAphcHBsaWNhdGlvbnMgaW5mb3JtYXRpb24gYW5kIGRvY3VtZW50YXRpb24uCgoyLiAgICBDT1BZUklHSFQgTElDRU5TRQoKUmVkaXN0cmlidXRpb24gYW5kIHVzZSBpbiBzb3VyY2UgYW5kIGJpbmFyeSBmb3Jtcywgd2l0aCBvciB3aXRob3V0IG1vZGlmaWNhdGlvbiwgYXJlIHBlcm1pdHRlZCB3aXRob3V0CnBheW1lbnQgb2YgY29weXJpZ2h0IGxpY2Vuc2UgZmVlcyBwcm92aWRlZCB0aGF0IHlvdSBzYXRpc2Z5IHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczoKCllvdSBtdXN0IHJldGFpbiB0aGUgY29tcGxldGUgdGV4dCBvZiB0aGlzIHNvZnR3YXJlIGxpY2Vuc2UgaW4gcmVkaXN0cmlidXRpb25zIG9mIHRoZSBGREsgQUFDIENvZGVjIG9yCnlvdXIgbW9kaWZpY2F0aW9ucyB0aGVyZXRvIGluIHNvdXJjZSBjb2RlIGZvcm0uCgpZb3UgbXVzdCByZXRhaW4gdGhlIGNvbXBsZXRlIHRleHQgb2YgdGhpcyBzb2Z0d2FyZSBsaWNlbnNlIGluIHRoZSBkb2N1bWVudGF0aW9uIGFuZC9vciBvdGhlciBtYXRlcmlhbHMKcHJvdmlkZWQgd2l0aCByZWRpc3RyaWJ1dGlvbnMgb2YgdGhlIEZESyBBQUMgQ29kZWMgb3IgeW91ciBtb2RpZmljYXRpb25zIHRoZXJldG8gaW4gYmluYXJ5IGZvcm0uCllvdSBtdXN0IG1ha2UgYXZhaWxhYmxlIGZyZWUgb2YgY2hhcmdlIGNvcGllcyBvZiB0aGUgY29tcGxldGUgc291cmNlIGNvZGUgb2YgdGhlIEZESyBBQUMgQ29kZWMgYW5kIHlvdXIKbW9kaWZpY2F0aW9ucyB0aGVyZXRvIHRvIHJlY2lwaWVudHMgb2YgY29waWVzIGluIGJpbmFyeSBmb3JtLgoKVGhlIG5hbWUgb2YgRnJhdW5ob2ZlciBtYXkgbm90IGJlIHVzZWQgdG8gZW5kb3JzZSBvciBwcm9tb3RlIHByb2R1Y3RzIGRlcml2ZWQgZnJvbSB0aGlzIGxpYnJhcnkgd2l0aG91dApwcmlvciB3cml0dGVuIHBlcm1pc3Npb24uCgpZb3UgbWF5IG5vdCBjaGFyZ2UgY29weXJpZ2h0IGxpY2Vuc2UgZmVlcyBmb3IgYW55b25lIHRvIHVzZSwgY29weSBvciBkaXN0cmlidXRlIHRoZSBGREsgQUFDIENvZGVjCnNvZnR3YXJlIG9yIHlvdXIgbW9kaWZpY2F0aW9ucyB0aGVyZXRvLgoKWW91ciBtb2RpZmllZCB2ZXJzaW9ucyBvZiB0aGUgRkRLIEFBQyBDb2RlYyBtdXN0IGNhcnJ5IHByb21pbmVudCBub3RpY2VzIHN0YXRpbmcgdGhhdCB5b3UgY2hhbmdlZCB0aGUgc29mdHdhcmUKYW5kIHRoZSBkYXRlIG9mIGFueSBjaGFuZ2UuIEZvciBtb2RpZmllZCB2ZXJzaW9ucyBvZiB0aGUgRkRLIEFBQyBDb2RlYywgdGhlIHRlcm0KIkZyYXVuaG9mZXIgRkRLIEFBQyBDb2RlYyBMaWJyYXJ5IGZvciBBbmRyb2lkIiBtdXN0IGJlIHJlcGxhY2VkIGJ5IHRoZSB0ZXJtCiJUaGlyZC1QYXJ0eSBNb2RpZmllZCBWZXJzaW9uIG9mIHRoZSBGcmF1bmhvZmVyIEZESyBBQUMgQ29kZWMgTGlicmFyeSBmb3IgQW5kcm9pZC4iCgozLiAgICBOTyBQQVRFTlQgTElDRU5TRQoKTk8gRVhQUkVTUyBPUiBJTVBMSUVEIExJQ0VOU0VTIFRPIEFOWSBQQVRFTlQgQ0xBSU1TLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uIHRoZSBwYXRlbnRzIG9mIEZyYXVuaG9mZXIsCkFSRSBHUkFOVEVEIEJZIFRISVMgU09GVFdBUkUgTElDRU5TRS4gRnJhdW5ob2ZlciBwcm92aWRlcyBubyB3YXJyYW50eSBvZiBwYXRlbnQgbm9uLWluZnJpbmdlbWVudCB3aXRoCnJlc3BlY3QgdG8gdGhpcyBzb2Z0d2FyZS4KCllvdSBtYXkgdXNlIHRoaXMgRkRLIEFBQyBDb2RlYyBzb2Z0d2FyZSBvciBtb2RpZmljYXRpb25zIHRoZXJldG8gb25seSBmb3IgcHVycG9zZXMgdGhhdCBhcmUgYXV0aG9yaXplZApieSBhcHByb3ByaWF0ZSBwYXRlbnQgbGljZW5zZXMuCgo0LiAgICBESVNDTEFJTUVSCgpUaGlzIEZESyBBQUMgQ29kZWMgc29mdHdhcmUgaXMgcHJvdmlkZWQgYnkgRnJhdW5ob2ZlciBvbiBiZWhhbGYgb2YgdGhlIGNvcHlyaWdodCBob2xkZXJzIGFuZCBjb250cmlidXRvcnMKIkFTIElTIiBhbmQgV0lUSE9VVCBBTlkgRVhQUkVTUyBPUiBJTVBMSUVEIFdBUlJBTlRJRVMsIGluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gdGhlIGltcGxpZWQgd2FycmFudGllcwpvZiBtZXJjaGFudGFiaWxpdHkgYW5kIGZpdG5lc3MgZm9yIGEgcGFydGljdWxhciBwdXJwb3NlLiBJTiBOTyBFVkVOVCBTSEFMTCBUSEUgQ09QWVJJR0hUIEhPTERFUiBPUgpDT05UUklCVVRPUlMgQkUgTElBQkxFIGZvciBhbnkgZGlyZWN0LCBpbmRpcmVjdCwgaW5jaWRlbnRhbCwgc3BlY2lhbCwgZXhlbXBsYXJ5LCBvciBjb25zZXF1ZW50aWFsIGRhbWFnZXMsCmluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gcHJvY3VyZW1lbnQgb2Ygc3Vic3RpdHV0ZSBnb29kcyBvciBzZXJ2aWNlczsgbG9zcyBvZiB1c2UsIGRhdGEsIG9yIHByb2ZpdHMsCm9yIGJ1c2luZXNzIGludGVycnVwdGlvbiwgaG93ZXZlciBjYXVzZWQgYW5kIG9uIGFueSB0aGVvcnkgb2YgbGlhYmlsaXR5LCB3aGV0aGVyIGluIGNvbnRyYWN0LCBzdHJpY3QKbGlhYmlsaXR5LCBvciB0b3J0IChpbmNsdWRpbmcgbmVnbGlnZW5jZSksIGFyaXNpbmcgaW4gYW55IHdheSBvdXQgb2YgdGhlIHVzZSBvZiB0aGlzIHNvZnR3YXJlLCBldmVuIGlmCmFkdmlzZWQgb2YgdGhlIHBvc3NpYmlsaXR5IG9mIHN1Y2ggZGFtYWdlLgoKNS4gICAgQ09OVEFDVCBJTkZPUk1BVElPTgoKRnJhdW5ob2ZlciBJbnN0aXR1dGUgZm9yIEludGVncmF0ZWQgQ2lyY3VpdHMgSUlTCkF0dGVudGlvbjogQXVkaW8gYW5kIE11bHRpbWVkaWEgRGVwYXJ0bWVudHMgLSBGREsgQUFDIExMCkFtIFdvbGZzbWFudGVsIDMzCjkxMDU4IEVybGFuZ2VuLCBHZXJtYW55Cgp3d3cuaWlzLmZyYXVuaG9mZXIuZGUvYW1tCmFtbS1pbmZvQGlpcy5mcmF1bmhvZmVyLmRlCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tICovCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiogTVBFRyBBdWRpbyBFbmNvZGVyICoqKioqKioqKioqKioqKioqKioqKioqKioqCgogICBJbml0aWFsIGF1dGhvcjogICAgICAgTS5XZXJuZXIKICAgY29udGVudHMvZGVzY3JpcHRpb246IFF1YW50aXphdGlvbgoKKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwoKI2luY2x1ZGUgInF1YW50aXplLmgiCgojaW5jbHVkZSAiYWFjRW5jX3JvbS5oIgoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCgogICAgZnVuY3Rpb25uYW1lOiBGREthYWNFbmNfcXVhbnRpemVMaW5lcwogICAgZGVzY3JpcHRpb246IHF1YW50aXplcyBzcGVjdHJ1bSBsaW5lcwogICAgcmV0dXJuczoKICAgIGlucHV0OiBnbG9iYWwgZ2FpbiwgbnVtYmVyIG9mIGxpbmVzIHRvIHByb2Nlc3MsIHNwZWN0cmFsIGRhdGEKICAgIG91dHB1dDogcXVhbnRpemVkIHNwZWN0cnVtCgoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kc3RhdGljIHZvaWQgRkRLYWFjRW5jX3F1YW50aXplTGluZXMoSU5UICAgICAgZ2FpbiwKICAgICAgICAgICAgICAgICAgICAgICAgICBJTlQgICAgICBub09mTGluZXMsCiAgICAgICAgICAgICAgICAgICAgICAgICAgRklYUF9EQkwgKm1kY3RTcGVjdHJ1bSwKICAgICAgICAgICAgICAgICAgICAgICAgICBTSE9SVCAgICAgICpxdWFTcGVjdHJ1bSkKewogIGludCAgIGxpbmU7CiAgRklYUF9EQkwgayA9IEZMMkZYQ09OU1RfREJMKC0wLjA5NDZmICsgMC41Zik+PjE2OwogIEZJWFBfUVREIHF1YW50aXplciA9IEZES2FhY0VuY19xdWFudFRhYmxlUVsoLWdhaW4pJjNdOwogIElOVCAgICAgIHF1YW50aXplcnNoaWZ0ID0gKCgtZ2Fpbik+PjIpKzE7CgoKICBmb3IgKGxpbmUgPSAwOyBsaW5lIDwgbm9PZkxpbmVzOyBsaW5lKyspCiAgewogICAgRklYUF9EQkwgYWNjdSA9IGZNdWx0RGl2MihtZGN0U3BlY3RydW1bbGluZV0scXVhbnRpemVyKTsKCiAgICBpZiAoYWNjdSA8IEZMMkZYQ09OU1RfREJMKDAuMGYpKQogICAgewogICAgICBhY2N1PS1hY2N1OwogICAgICAvKiBub3JtYWxpemUgKi8KICAgICAgSU5UICAgYWNjdVNoaWZ0ID0gQ250TGVhZGluZ1plcm9zKGFjY3UpIC0gMTsgIC8qIENvdW50TGVhZGluZ0JpdHMoKSBpcyBub3QgbmVjZXNzYXJ5IGhlcmUgc2luY2UgdGVzdCB2YWx1ZSBpcyBhbHdheXMgPiAwICovCiAgICAgIGFjY3UgPDw9IGFjY3VTaGlmdDsKICAgICAgSU5UIHRhYkluZGV4ID0gKElOVCkoYWNjdT4+KERGUkFDVF9CSVRTLTItTUFOVF9ESUdJVFMpKSYofk1BTlRfU0laRSk7CiAgICAgIElOVCB0b3RhbFNoaWZ0ID0gcXVhbnRpemVyc2hpZnQtYWNjdVNoaWZ0KzE7CiAgICAgIGFjY3UgPSBmTXVsdERpdjIoRkRLYWFjRW5jX21UYWJfM180W3RhYkluZGV4XSxGREthYWNFbmNfcXVhbnRUYWJsZUVbdG90YWxTaGlmdCYzXSk7CiAgICAgIHRvdGFsU2hpZnQgPSAoMTYtNCktKDMqKHRvdGFsU2hpZnQ+PjIpKTsKICAgICAgRkRLX0FTU0VSVCh0b3RhbFNoaWZ0ID49MCk7IC8qIE1BWF9RVUFOVF9WSU9MQVRJT04gKi8KICAgICAgaWYgKHRvdGFsU2hpZnQgPCAzMikKICAgICAgICAgIGFjY3U+Pj10b3RhbFNoaWZ0OwogICAgICBlbHNlCiAgICAgICAgICBhY2N1ID0gMDsKICAgICAgcXVhU3BlY3RydW1bbGluZV0gPSAoU0hPUlQpKC0oKExPTkcpKGsgKyBhY2N1KSA+PiAoREZSQUNUX0JJVFMtMS0xNikpKTsKICAgIH0KICAgIGVsc2UgaWYoYWNjdSA+IEZMMkZYQ09OU1RfREJMKDAuMGYpKQogICAgewogICAgICAvKiBub3JtYWxpemUgKi8KICAgICAgSU5UICAgYWNjdVNoaWZ0ID0gQ250TGVhZGluZ1plcm9zKGFjY3UpIC0gMTsgIC8qIENvdW50TGVhZGluZ0JpdHMoKSBpcyBub3QgbmVjZXNzYXJ5IGhlcmUgc2luY2UgdGVzdCB2YWx1ZSBpcyBhbHdheXMgPiAwICovCiAgICAgIGFjY3UgPDw9IGFjY3VTaGlmdDsKICAgICAgSU5UIHRhYkluZGV4ID0gKElOVCkoYWNjdT4+KERGUkFDVF9CSVRTLTItTUFOVF9ESUdJVFMpKSYofk1BTlRfU0laRSk7CiAgICAgIElOVCB0b3RhbFNoaWZ0ID0gcXVhbnRpemVyc2hpZnQtYWNjdVNoaWZ0KzE7CiAgICAgIGFjY3UgPSBmTXVsdERpdjIoRkRLYWFjRW5jX21UYWJfM180W3RhYkluZGV4XSxGREthYWNFbmNfcXVhbnRUYWJsZUVbdG90YWxTaGlmdCYzXSk7CiAgICAgIHRvdGFsU2hpZnQgPSAoMTYtNCktKDMqKHRvdGFsU2hpZnQ+PjIpKTsKICAgICAgRkRLX0FTU0VSVCh0b3RhbFNoaWZ0ID49MCk7IC8qIE1BWF9RVUFOVF9WSU9MQVRJT04gKi8KICAgICAgaWYgKHRvdGFsU2hpZnQgPCAzMikKICAgICAgICAgIGFjY3U+Pj10b3RhbFNoaWZ0OwogICAgICBlbHNlCiAgICAgICAgICBhY2N1ID0gMDsKICAgICAgcXVhU3BlY3RydW1bbGluZV0gPSAoU0hPUlQpKChMT05HKShrICsgYWNjdSkgPj4gKERGUkFDVF9CSVRTLTEtMTYpKTsKICAgIH0KICAgIGVsc2UKICAgICAgcXVhU3BlY3RydW1bbGluZV09MDsKICB9Cn0KCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKCiAgICBmdW5jdGlvbm5hbWU6aUZES2FhY0VuY19xdWFudGl6ZUxpbmVzCiAgICBkZXNjcmlwdGlvbjogaXF1YW50aXplcyBzcGVjdHJ1bSBsaW5lcwogICAgICAgICAgICAgICAgIG1kY3RTcGVjdHJ1bSA9IGlxdWFTcGVjdHJ1bV40LzMgKjJeKDAuMjUqZ2FpbikKICAgIGlucHV0OiBnbG9iYWwgZ2FpbiwgbnVtYmVyIG9mIGxpbmVzIHRvIHByb2Nlc3MscXVhbnRpemVkIHNwZWN0cnVtCiAgICBvdXRwdXQ6IHNwZWN0cmFsIGRhdGEKCioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwpzdGF0aWMgdm9pZCBGREthYWNFbmNfaW52UXVhbnRpemVMaW5lcyhJTlQgIGdhaW4sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgSU5UICBub09mTGluZXMsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgU0hPUlQgKnF1YW50U3BlY3RydW0sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgRklYUF9EQkwgKm1kY3RTcGVjdHJ1bSkKCnsKICBJTlQgaXF1YW50aXplcm1vZDsKICBJTlQgaXF1YW50aXplcnNoaWZ0OwogIElOVCBsaW5lOwoKICBpcXVhbnRpemVybW9kID0gZ2FpbiYzOwogIGlxdWFudGl6ZXJzaGlmdCA9IGdhaW4+PjI7CgogIGZvciAobGluZSA9IDA7IGxpbmUgPCBub09mTGluZXM7IGxpbmUrKykgewoKICAgIGlmKHF1YW50U3BlY3RydW1bbGluZV0gPCAwKSB7CiAgICAgIEZJWFBfREJMIGFjY3U7CiAgICAgIElOVCBleCxzcGVjRXhwLHRhYkluZGV4OwogICAgICBGSVhQX0RCTCBzLHQ7CgogICAgICBhY2N1ID0gKEZJWFBfREJMKSAtcXVhbnRTcGVjdHJ1bVtsaW5lXTsKCiAgICAgIGV4ID0gQ291bnRMZWFkaW5nQml0cyhhY2N1KTsKICAgICAgYWNjdSA8PD0gZXg7CiAgICAgIHNwZWNFeHAgPSAoREZSQUNUX0JJVFMtMSkgLSBleDsKCiAgICAgIEZES19BU1NFUlQoc3BlY0V4cCA8IDE0KTsgICAgICAgLyogdGhpcyBmYWlscyBpZiBhYnModmFsdWUpID4gODE5MSAqLwoKICAgICAgdGFiSW5kZXggPSAoSU5UKShhY2N1Pj4oREZSQUNUX0JJVFMtMi1NQU5UX0RJR0lUUykpJih+TUFOVF9TSVpFKTsKCiAgICAgIC8qIGNhbGN1bGF0ZSAibWFudGlzc2EiIF40LzMgKi8KICAgICAgcyA9IEZES2FhY0VuY19tVGFiXzRfM0VsY1t0YWJJbmRleF07CgogICAgICAvKiBnZXQgYXBwcm9wZXJpYXRlIGV4cG9uZW50IG11bHRpcGxpZXIgZm9yIHNwZWNFeHBeMy80IGNvbWJpbmVkIHdpdGggc2NmTW9kICovCiAgICAgIHQgPSBGREthYWNFbmNfc3BlY0V4cE1hbnRUYWJsZUNvbWJFbGNbaXF1YW50aXplcm1vZF1bc3BlY0V4cF07CgogICAgICAvKiBtdWx0aXBseSAibWFudGlzc2EiIF40LzMgd2l0aCBleHBvbmVudCBtdWx0aXBsaWVyICovCiAgICAgIGFjY3UgPSBmTXVsdChzLHQpOwoKICAgICAgLyogZ2V0IGFwcHJvcGVyaWF0ZSBleHBvbmVudCBzaGlmdGVyICovCiAgICAgIHNwZWNFeHAgPSBGREthYWNFbmNfc3BlY0V4cFRhYmxlQ29tYltpcXVhbnRpemVybW9kXVtzcGVjRXhwXS0xOyAvKiAtMSB0byBhdm9pZCBvdmVyZmxvd3MgaW4gYWNjdSAqLwoKICAgICAgaWYgKCgtaXF1YW50aXplcnNoaWZ0LXNwZWNFeHApIDwgMCkKICAgICAgICBhY2N1IDw8PSAtKC1pcXVhbnRpemVyc2hpZnQtc3BlY0V4cCk7CiAgICAgIGVsc2UKICAgICAgICBhY2N1ID4+PSAtaXF1YW50aXplcnNoaWZ0LXNwZWNFeHA7CgogICAgICBtZGN0U3BlY3RydW1bbGluZV0gPSAtYWNjdTsKICAgIH0KICAgIGVsc2UgaWYgKHF1YW50U3BlY3RydW1bbGluZV0gPiAwKSB7CiAgICAgIEZJWFBfREJMIGFjY3U7CiAgICAgIElOVCBleCxzcGVjRXhwLHRhYkluZGV4OwogICAgICBGSVhQX0RCTCBzLHQ7CgogICAgICBhY2N1ID0gKEZJWFBfREJMKShJTlQpcXVhbnRTcGVjdHJ1bVtsaW5lXTsKCiAgICAgIGV4ID0gQ291bnRMZWFkaW5nQml0cyhhY2N1KTsKICAgICAgYWNjdSA8PD0gZXg7CiAgICAgIHNwZWNFeHAgPSAoREZSQUNUX0JJVFMtMSkgLSBleDsKCiAgICAgIEZES19BU1NFUlQoc3BlY0V4cCA8IDE0KTsgICAgICAgLyogdGhpcyBmYWlscyBpZiBhYnModmFsdWUpID4gODE5MSAqLwoKICAgICAgdGFiSW5kZXggPSAoSU5UKShhY2N1Pj4oREZSQUNUX0JJVFMtMi1NQU5UX0RJR0lUUykpJih+TUFOVF9TSVpFKTsKCiAgICAgIC8qIGNhbGN1bGF0ZSAibWFudGlzc2EiIF40LzMgKi8KICAgICAgcyA9IEZES2FhY0VuY19tVGFiXzRfM0VsY1t0YWJJbmRleF07CgogICAgICAvKiBnZXQgYXBwcm9wZXJpYXRlIGV4cG9uZW50IG11bHRpcGxpZXIgZm9yIHNwZWNFeHBeMy80IGNvbWJpbmVkIHdpdGggc2NmTW9kICovCiAgICAgIHQgPSBGREthYWNFbmNfc3BlY0V4cE1hbnRUYWJsZUNvbWJFbGNbaXF1YW50aXplcm1vZF1bc3BlY0V4cF07CgogICAgICAvKiBtdWx0aXBseSAibWFudGlzc2EiIF40LzMgd2l0aCBleHBvbmVudCBtdWx0aXBsaWVyICovCiAgICAgIGFjY3UgPSBmTXVsdChzLHQpOwoKICAgICAgLyogZ2V0IGFwcHJvcGVyaWF0ZSBleHBvbmVudCBzaGlmdGVyICovCiAgICAgIHNwZWNFeHAgPSBGREthYWNFbmNfc3BlY0V4cFRhYmxlQ29tYltpcXVhbnRpemVybW9kXVtzcGVjRXhwXS0xOyAvKiAtMSB0byBhdm9pZCBvdmVyZmxvd3MgaW4gYWNjdSAqLwoKICAgICAgaWYgKCggLWlxdWFudGl6ZXJzaGlmdC1zcGVjRXhwKSA8IDApCiAgICAgICAgYWNjdSA8PD0gLSgtaXF1YW50aXplcnNoaWZ0LXNwZWNFeHApOwogICAgICBlbHNlCiAgICAgICAgYWNjdSA+Pj0gLWlxdWFudGl6ZXJzaGlmdC1zcGVjRXhwOwoKICAgICAgbWRjdFNwZWN0cnVtW2xpbmVdID0gYWNjdTsKICAgIH0KICAgIGVsc2UgewogICAgICBtZGN0U3BlY3RydW1bbGluZV0gPSBGTDJGWENPTlNUX0RCTCgwLjBmKTsKICAgIH0KICB9Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgoKICAgIGZ1bmN0aW9ubmFtZTogRkRLYWFjRW5jX1F1YW50aXplU3BlY3RydW0KICAgIGRlc2NyaXB0aW9uOiBxdWFudGl6ZXMgdGhlIGVudGlyZSBzcGVjdHJ1bQogICAgcmV0dXJuczoKICAgIGlucHV0OiBudW1iZXIgb2Ygc2NhbGVmYWN0b3IgYmFuZHMgdG8gYmUgcXVhbnRpemVkLCAuLi4KICAgIG91dHB1dDogcXVhbnRpemVkIHNwZWN0cnVtCgoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kdm9pZCBGREthYWNFbmNfUXVhbnRpemVTcGVjdHJ1bShJTlQgc2ZiQ250LAogICAgICAgICAgICAgICAgICAgICAgSU5UIG1heFNmYlBlckdyb3VwLAogICAgICAgICAgICAgICAgICAgICAgSU5UIHNmYlBlckdyb3VwLAogICAgICAgICAgICAgICAgICAgICAgSU5UICpzZmJPZmZzZXQsCiAgICAgICAgICAgICAgICAgICAgICBGSVhQX0RCTCAqbWRjdFNwZWN0cnVtLAogICAgICAgICAgICAgICAgICAgICAgSU5UIGdsb2JhbEdhaW4sCiAgICAgICAgICAgICAgICAgICAgICBJTlQgKnNjYWxlZmFjdG9ycywKICAgICAgICAgICAgICAgICAgICAgIFNIT1JUICpxdWFudGl6ZWRTcGVjdHJ1bSkKewogIElOVCBzZmJPZmZzLHNmYjsKCiAgLyogaW4gRkRLYWFjRW5jX3F1YW50aXplTGluZXMgcXVhU3BlY3RydW0gaXMgY2FsY3VsYXRlZCB3aXRoOgogICAgICAgIHNwZWNeKDMvNCkgKiAyXigtMy8xNipRU1MpICogMl4oMy80KnNjYWxlKSArIGsKICAgICBzaW1wbGlmeSBzY2FsaW5nIGNhbGN1bGF0aW9uIGFuZCByZWR1Y2UgUVNTIGJlZm9yZToKICAgICAgICBzcGVjXigzLzQpICogMl4oLTMvMTYqKFFTUyAtIDQqc2NhbGUpKSAqLwoKICBmb3Ioc2ZiT2Zmcz0wO3NmYk9mZnM8c2ZiQ250O3NmYk9mZnMrPXNmYlBlckdyb3VwKQogIGZvciAoc2ZiID0gMDsgc2ZiIDwgbWF4U2ZiUGVyR3JvdXA7IHNmYisrKQogIHsKICAgIElOVCBzY2FsZWZhY3RvciA9IHNjYWxlZmFjdG9yc1tzZmJPZmZzK3NmYl0gOwoKICAgIEZES2FhY0VuY19xdWFudGl6ZUxpbmVzKGdsb2JhbEdhaW4gLSBzY2FsZWZhY3RvciwgLyogUVNTICovCiAgICAgICAgICAgICAgICAgIHNmYk9mZnNldFtzZmJPZmZzK3NmYisxXSAtIHNmYk9mZnNldFtzZmJPZmZzK3NmYl0sCiAgICAgICAgICAgICAgICAgIG1kY3RTcGVjdHJ1bSArIHNmYk9mZnNldFtzZmJPZmZzK3NmYl0sCiAgICAgICAgICAgICAgICAgIHF1YW50aXplZFNwZWN0cnVtICsgc2ZiT2Zmc2V0W3NmYk9mZnMrc2ZiXSk7CiAgfQp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKCiAgICBmdW5jdGlvbm5hbWU6IEZES2FhY0VuY19jYWxjU2ZiRGlzdAogICAgZGVzY3JpcHRpb246IGNhbGN1bGF0ZXMgZGlzdG9ydGlvbiBvZiBxdWFudGl6ZWQgdmFsdWVzCiAgICByZXR1cm5zOiBkaXN0b3J0aW9uCiAgICBpbnB1dDogZ2FpbiwgbnVtYmVyIG9mIGxpbmVzIHRvIHByb2Nlc3MsIHNwZWN0cmFsIGRhdGEKICAgIG91dHB1dDoKCioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwpGSVhQX0RCTCBGREthYWNFbmNfY2FsY1NmYkRpc3QoRklYUF9EQkwgKm1kY3RTcGVjdHJ1bSwKICAgICAgICAgICAgICAgICAgICAgU0hPUlQgKnF1YW50U3BlY3RydW0sCiAgICAgICAgICAgICAgICAgICAgIElOVCBub09mTGluZXMsCiAgICAgICAgICAgICAgICAgICAgIElOVCBnYWluCiAgICAgICAgICAgICAgICAgICAgICkKewogIElOVCBpLHNjYWxlOwogIEZJWFBfREJMIHhmc2Y7CiAgRklYUF9EQkwgZGlmZjsKICBGSVhQX0RCTCBpbnZRdWFudFNwZWM7CgogIHhmc2YgPSBGTDJGWENPTlNUX0RCTCgwLjBmKTsKCiAgZm9yIChpPTA7IGk8bm9PZkxpbmVzOyBpKyspIHsKICAgIC8qIHF1YW50aXphdGlvbiAqLwogICAgRkRLYWFjRW5jX3F1YW50aXplTGluZXMoZ2FpbiwKICAgICAgICAgICAgICAgICAgMSwKICAgICAgICAgICAgICAgICAmbWRjdFNwZWN0cnVtW2ldLAogICAgICAgICAgICAgICAgICZxdWFudFNwZWN0cnVtW2ldKTsKCiAgICAvKiBpbnZlcnNlIHF1YW50aXphdGlvbiAqLwogICAgRkRLYWFjRW5jX2ludlF1YW50aXplTGluZXMoZ2FpbiwxLCZxdWFudFNwZWN0cnVtW2ldLCZpbnZRdWFudFNwZWMpOwoKICAgIC8qIGRpc3QgKi8KICAgIGRpZmYgPSBmaXhwX2FicyhmaXhwX2FicyhpbnZRdWFudFNwZWMpIC0gZml4cF9hYnMobWRjdFNwZWN0cnVtW2ldPj4xKSk7CgogICAgc2NhbGUgPSBDb3VudExlYWRpbmdCaXRzKGRpZmYpOwogICAgZGlmZiA9IHNjYWxlVmFsdWUoZGlmZiwgc2NhbGUpOwogICAgZGlmZiA9IGZQb3cyKGRpZmYpOwogICAgc2NhbGUgPSBmaXhNaW4oMiooc2NhbGUtMSksIERGUkFDVF9CSVRTLTEpOwoKICAgIGRpZmYgPSBzY2FsZVZhbHVlKGRpZmYsIC1zY2FsZSk7CgogICAgeGZzZiA9IHhmc2YgKyBkaWZmOwogIH0KCiAgeGZzZiA9IENhbGNMZERhdGEoeGZzZik7CgogIHJldHVybiB4ZnNmOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKCiAgICBmdW5jdGlvbm5hbWU6IEZES2FhY0VuY19jYWxjU2ZiUXVhbnRFbmVyZ3lBbmREaXN0CiAgICBkZXNjcmlwdGlvbjogY2FsY3VsYXRlcyBlbmVyZ3kgYW5kIGRpc3RvcnRpb24gb2YgcXVhbnRpemVkIHZhbHVlcwogICAgcmV0dXJuczoKICAgIGlucHV0OiBnYWluLCBudW1iZXIgb2YgbGluZXMgdG8gcHJvY2VzcywgcXVhbnRpemVkIHNwZWN0cmFsIGRhdGEsCiAgICAgICAgICAgc3BlY3RyYWwgZGF0YQogICAgb3V0cHV0OiBlbmVyZ3ksIGRpc3RvcnRpb24KCioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwp2b2lkIEZES2FhY0VuY19jYWxjU2ZiUXVhbnRFbmVyZ3lBbmREaXN0KEZJWFBfREJMICptZGN0U3BlY3RydW0sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBTSE9SVCAqcXVhbnRTcGVjdHJ1bSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIElOVCBub09mTGluZXMsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBJTlQgZ2FpbiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEZJWFBfREJMICplbiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEZJWFBfREJMICpkaXN0KQp7CiAgSU5UIGksc2NhbGU7CiAgRklYUF9EQkwgaW52UXVhbnRTcGVjOwogIEZJWFBfREJMIGRpZmY7CgogICplbiAgID0gRkwyRlhDT05TVF9EQkwoMC4wZik7CiAgKmRpc3QgPSBGTDJGWENPTlNUX0RCTCgwLjBmKTsKCiAgZm9yIChpPTA7IGk8bm9PZkxpbmVzOyBpKyspIHsKICAgIC8qIGludmVyc2UgcXVhbnRpemF0aW9uICovCiAgICBGREthYWNFbmNfaW52UXVhbnRpemVMaW5lcyhnYWluLDEsJnF1YW50U3BlY3RydW1baV0sJmludlF1YW50U3BlYyk7CgogICAgLyogZW5lcmd5ICovCiAgICAqZW4gKz0gZlBvdzIoaW52UXVhbnRTcGVjKTsKCiAgICAvKiBkaXN0ICovCiAgICBkaWZmID0gZml4cF9hYnMoZml4cF9hYnMoaW52UXVhbnRTcGVjKSAtIGZpeHBfYWJzKG1kY3RTcGVjdHJ1bVtpXT4+MSkpOwoKICAgIHNjYWxlID0gQ291bnRMZWFkaW5nQml0cyhkaWZmKTsKICAgIGRpZmYgPSBzY2FsZVZhbHVlKGRpZmYsIHNjYWxlKTsKICAgIGRpZmYgPSBmUG93MihkaWZmKTsKCiAgICBzY2FsZSA9IGZpeE1pbigyKihzY2FsZS0xKSwgREZSQUNUX0JJVFMtMSk7CgogICAgZGlmZiA9IHNjYWxlVmFsdWUoZGlmZiwgLXNjYWxlKTsKCiAgICAqZGlzdCArPSBkaWZmOwogIH0KCiAgKmVuICAgPSBDYWxjTGREYXRhKCplbikrRkwyRlhDT05TVF9EQkwoMC4wMzEyNWYpOwogICpkaXN0ID0gQ2FsY0xkRGF0YSgqZGlzdCk7Cn0KCg==