CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEFwYWNoZSBMaWNlbnNlCiAgICAgICAgICAgICAgICAgICAgICAgICAgIFZlcnNpb24gMi4wLCBKYW51YXJ5IDIwMDQKICAgICAgICAgICAgICAgICAgICAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzLwoKICAgVEVSTVMgQU5EIENPTkRJVElPTlMgRk9SIFVTRSwgUkVQUk9EVUNUSU9OLCBBTkQgRElTVFJJQlVUSU9OCgogICAxLiBEZWZpbml0aW9ucy4KCiAgICAgICJMaWNlbnNlIiBzaGFsbCBtZWFuIHRoZSB0ZXJtcyBhbmQgY29uZGl0aW9ucyBmb3IgdXNlLCByZXByb2R1Y3Rpb24sCiAgICAgIGFuZCBkaXN0cmlidXRpb24gYXMgZGVmaW5lZCBieSBTZWN0aW9ucyAxIHRocm91Z2ggOSBvZiB0aGlzIGRvY3VtZW50LgoKICAgICAgIkxpY2Vuc29yIiBzaGFsbCBtZWFuIHRoZSBjb3B5cmlnaHQgb3duZXIgb3IgZW50aXR5IGF1dGhvcml6ZWQgYnkKICAgICAgdGhlIGNvcHlyaWdodCBvd25lciB0aGF0IGlzIGdyYW50aW5nIHRoZSBMaWNlbnNlLgoKICAgICAgIkxlZ2FsIEVudGl0eSIgc2hhbGwgbWVhbiB0aGUgdW5pb24gb2YgdGhlIGFjdGluZyBlbnRpdHkgYW5kIGFsbAogICAgICBvdGhlciBlbnRpdGllcyB0aGF0IGNvbnRyb2wsIGFyZSBjb250cm9sbGVkIGJ5LCBvciBhcmUgdW5kZXIgY29tbW9uCiAgICAgIGNvbnRyb2wgd2l0aCB0aGF0IGVudGl0eS4gRm9yIHRoZSBwdXJwb3NlcyBvZiB0aGlzIGRlZmluaXRpb24sCiAgICAgICJjb250cm9sIiBtZWFucyAoaSkgdGhlIHBvd2VyLCBkaXJlY3Qgb3IgaW5kaXJlY3QsIHRvIGNhdXNlIHRoZQogICAgICBkaXJlY3Rpb24gb3IgbWFuYWdlbWVudCBvZiBzdWNoIGVudGl0eSwgd2hldGhlciBieSBjb250cmFjdCBvcgogICAgICBvdGhlcndpc2UsIG9yIChpaSkgb3duZXJzaGlwIG9mIGZpZnR5IHBlcmNlbnQgKDUwJSkgb3IgbW9yZSBvZiB0aGUKICAgICAgb3V0c3RhbmRpbmcgc2hhcmVzLCBvciAoaWlpKSBiZW5lZmljaWFsIG93bmVyc2hpcCBvZiBzdWNoIGVudGl0eS4KCiAgICAgICJZb3UiIChvciAiWW91ciIpIHNoYWxsIG1lYW4gYW4gaW5kaXZpZHVhbCBvciBMZWdhbCBFbnRpdHkKICAgICAgZXhlcmNpc2luZyBwZXJtaXNzaW9ucyBncmFudGVkIGJ5IHRoaXMgTGljZW5zZS4KCiAgICAgICJTb3VyY2UiIGZvcm0gc2hhbGwgbWVhbiB0aGUgcHJlZmVycmVkIGZvcm0gZm9yIG1ha2luZyBtb2RpZmljYXRpb25zLAogICAgICBpbmNsdWRpbmcgYnV0IG5vdCBsaW1pdGVkIHRvIHNvZnR3YXJlIHNvdXJjZSBjb2RlLCBkb2N1bWVudGF0aW9uCiAgICAgIHNvdXJjZSwgYW5kIGNvbmZpZ3VyYXRpb24gZmlsZXMuCgogICAgICAiT2JqZWN0IiBmb3JtIHNoYWxsIG1lYW4gYW55IGZvcm0gcmVzdWx0aW5nIGZyb20gbWVjaGFuaWNhbAogICAgICB0cmFuc2Zvcm1hdGlvbiBvciB0cmFuc2xhdGlvbiBvZiBhIFNvdXJjZSBmb3JtLCBpbmNsdWRpbmcgYnV0CiAgICAgIG5vdCBsaW1pdGVkIHRvIGNvbXBpbGVkIG9iamVjdCBjb2RlLCBnZW5lcmF0ZWQgZG9jdW1lbnRhdGlvbiwKICAgICAgYW5kIGNvbnZlcnNpb25zIHRvIG90aGVyIG1lZGlhIHR5cGVzLgoKICAgICAgIldvcmsiIHNoYWxsIG1lYW4gdGhlIHdvcmsgb2YgYXV0aG9yc2hpcCwgd2hldGhlciBpbiBTb3VyY2Ugb3IKICAgICAgT2JqZWN0IGZvcm0sIG1hZGUgYXZhaWxhYmxlIHVuZGVyIHRoZSBMaWNlbnNlLCBhcyBpbmRpY2F0ZWQgYnkgYQogICAgICBjb3B5cmlnaHQgbm90aWNlIHRoYXQgaXMgaW5jbHVkZWQgaW4gb3IgYXR0YWNoZWQgdG8gdGhlIHdvcmsKICAgICAgKGFuIGV4YW1wbGUgaXMgcHJvdmlkZWQgaW4gdGhlIEFwcGVuZGl4IGJlbG93KS4KCiAgICAgICJEZXJpdmF0aXZlIFdvcmtzIiBzaGFsbCBtZWFuIGFueSB3b3JrLCB3aGV0aGVyIGluIFNvdXJjZSBvciBPYmplY3QKICAgICAgZm9ybSwgdGhhdCBpcyBiYXNlZCBvbiAob3IgZGVyaXZlZCBmcm9tKSB0aGUgV29yayBhbmQgZm9yIHdoaWNoIHRoZQogICAgICBlZGl0b3JpYWwgcmV2aXNpb25zLCBhbm5vdGF0aW9ucywgZWxhYm9yYXRpb25zLCBvciBvdGhlciBtb2RpZmljYXRpb25zCiAgICAgIHJlcHJlc2VudCwgYXMgYSB3aG9sZSwgYW4gb3JpZ2luYWwgd29yayBvZiBhdXRob3JzaGlwLiBGb3IgdGhlIHB1cnBvc2VzCiAgICAgIG9mIHRoaXMgTGljZW5zZSwgRGVyaXZhdGl2ZSBXb3JrcyBzaGFsbCBub3QgaW5jbHVkZSB3b3JrcyB0aGF0IHJlbWFpbgogICAgICBzZXBhcmFibGUgZnJvbSwgb3IgbWVyZWx5IGxpbmsgKG9yIGJpbmQgYnkgbmFtZSkgdG8gdGhlIGludGVyZmFjZXMgb2YsCiAgICAgIHRoZSBXb3JrIGFuZCBEZXJpdmF0aXZlIFdvcmtzIHRoZXJlb2YuCgogICAgICAiQ29udHJpYnV0aW9uIiBzaGFsbCBtZWFuIGFueSB3b3JrIG9mIGF1dGhvcnNoaXAsIGluY2x1ZGluZwogICAgICB0aGUgb3JpZ2luYWwgdmVyc2lvbiBvZiB0aGUgV29yayBhbmQgYW55IG1vZGlmaWNhdGlvbnMgb3IgYWRkaXRpb25zCiAgICAgIHRvIHRoYXQgV29yayBvciBEZXJpdmF0aXZlIFdvcmtzIHRoZXJlb2YsIHRoYXQgaXMgaW50ZW50aW9uYWxseQogICAgICBzdWJtaXR0ZWQgdG8gTGljZW5zb3IgZm9yIGluY2x1c2lvbiBpbiB0aGUgV29yayBieSB0aGUgY29weXJpZ2h0IG93bmVyCiAgICAgIG9yIGJ5IGFuIGluZGl2aWR1YWwgb3IgTGVnYWwgRW50aXR5IGF1dGhvcml6ZWQgdG8gc3VibWl0IG9uIGJlaGFsZiBvZgogICAgICB0aGUgY29weXJpZ2h0IG93bmVyLiBGb3IgdGhlIHB1cnBvc2VzIG9mIHRoaXMgZGVmaW5pdGlvbiwgInN1Ym1pdHRlZCIKICAgICAgbWVhbnMgYW55IGZvcm0gb2YgZWxlY3Ryb25pYywgdmVyYmFsLCBvciB3cml0dGVuIGNvbW11bmljYXRpb24gc2VudAogICAgICB0byB0aGUgTGljZW5zb3Igb3IgaXRzIHJlcHJlc2VudGF0aXZlcywgaW5jbHVkaW5nIGJ1dCBub3QgbGltaXRlZCB0bwogICAgICBjb21tdW5pY2F0aW9uIG9uIGVsZWN0cm9uaWMgbWFpbGluZyBsaXN0cywgc291cmNlIGNvZGUgY29udHJvbCBzeXN0ZW1zLAogICAgICBhbmQgaXNzdWUgdHJhY2tpbmcgc3lzdGVtcyB0aGF0IGFyZSBtYW5hZ2VkIGJ5LCBvciBvbiBiZWhhbGYgb2YsIHRoZQogICAgICBMaWNlbnNvciBmb3IgdGhlIHB1cnBvc2Ugb2YgZGlzY3Vzc2luZyBhbmQgaW1wcm92aW5nIHRoZSBXb3JrLCBidXQKICAgICAgZXhjbHVkaW5nIGNvbW11bmljYXRpb24gdGhhdCBpcyBjb25zcGljdW91c2x5IG1hcmtlZCBvciBvdGhlcndpc2UKICAgICAgZGVzaWduYXRlZCBpbiB3cml0aW5nIGJ5IHRoZSBjb3B5cmlnaHQgb3duZXIgYXMgIk5vdCBhIENvbnRyaWJ1dGlvbi4iCgogICAgICAiQ29udHJpYnV0b3IiIHNoYWxsIG1lYW4gTGljZW5zb3IgYW5kIGFueSBpbmRpdmlkdWFsIG9yIExlZ2FsIEVudGl0eQogICAgICBvbiBiZWhhbGYgb2Ygd2hvbSBhIENvbnRyaWJ1dGlvbiBoYXMgYmVlbiByZWNlaXZlZCBieSBMaWNlbnNvciBhbmQKICAgICAgc3Vic2VxdWVudGx5IGluY29ycG9yYXRlZCB3aXRoaW4gdGhlIFdvcmsuCgogICAyLiBHcmFudCBvZiBDb3B5cmlnaHQgTGljZW5zZS4gU3ViamVjdCB0byB0aGUgdGVybXMgYW5kIGNvbmRpdGlvbnMgb2YKICAgICAgdGhpcyBMaWNlbnNlLCBlYWNoIENvbnRyaWJ1dG9yIGhlcmVieSBncmFudHMgdG8gWW91IGEgcGVycGV0dWFsLAogICAgICB3b3JsZHdpZGUsIG5vbi1leGNsdXNpdmUsIG5vLWNoYXJnZSwgcm95YWx0eS1mcmVlLCBpcnJldm9jYWJsZQogICAgICBjb3B5cmlnaHQgbGljZW5zZSB0byByZXByb2R1Y2UsIHByZXBhcmUgRGVyaXZhdGl2ZSBXb3JrcyBvZiwKICAgICAgcHVibGljbHkgZGlzcGxheSwgcHVibGljbHkgcGVyZm9ybSwgc3VibGljZW5zZSwgYW5kIGRpc3RyaWJ1dGUgdGhlCiAgICAgIFdvcmsgYW5kIHN1Y2ggRGVyaXZhdGl2ZSBXb3JrcyBpbiBTb3VyY2Ugb3IgT2JqZWN0IGZvcm0uCgogICAzLiBHcmFudCBvZiBQYXRlbnQgTGljZW5zZS4gU3ViamVjdCB0byB0aGUgdGVybXMgYW5kIGNvbmRpdGlvbnMgb2YKICAgICAgdGhpcyBMaWNlbnNlLCBlYWNoIENvbnRyaWJ1dG9yIGhlcmVieSBncmFudHMgdG8gWW91IGEgcGVycGV0dWFsLAogICAgICB3b3JsZHdpZGUsIG5vbi1leGNsdXNpdmUsIG5vLWNoYXJnZSwgcm95YWx0eS1mcmVlLCBpcnJldm9jYWJsZQogICAgICAoZXhjZXB0IGFzIHN0YXRlZCBpbiB0aGlzIHNlY3Rpb24pIHBhdGVudCBsaWNlbnNlIHRvIG1ha2UsIGhhdmUgbWFkZSwKICAgICAgdXNlLCBvZmZlciB0byBzZWxsLCBzZWxsLCBpbXBvcnQsIGFuZCBvdGhlcndpc2UgdHJhbnNmZXIgdGhlIFdvcmssCiAgICAgIHdoZXJlIHN1Y2ggbGljZW5zZSBhcHBsaWVzIG9ubHkgdG8gdGhvc2UgcGF0ZW50IGNsYWltcyBsaWNlbnNhYmxlCiAgICAgIGJ5IHN1Y2ggQ29udHJpYnV0b3IgdGhhdCBhcmUgbmVjZXNzYXJpbHkgaW5mcmluZ2VkIGJ5IHRoZWlyCiAgICAgIENvbnRyaWJ1dGlvbihzKSBhbG9uZSBvciBieSBjb21iaW5hdGlvbiBvZiB0aGVpciBDb250cmlidXRpb24ocykKICAgICAgd2l0aCB0aGUgV29yayB0byB3aGljaCBzdWNoIENvbnRyaWJ1dGlvbihzKSB3YXMgc3VibWl0dGVkLiBJZiBZb3UKICAgICAgaW5zdGl0dXRlIHBhdGVudCBsaXRpZ2F0aW9uIGFnYWluc3QgYW55IGVudGl0eSAoaW5jbHVkaW5nIGEKICAgICAgY3Jvc3MtY2xhaW0gb3IgY291bnRlcmNsYWltIGluIGEgbGF3c3VpdCkgYWxsZWdpbmcgdGhhdCB0aGUgV29yawogICAgICBvciBhIENvbnRyaWJ1dGlvbiBpbmNvcnBvcmF0ZWQgd2l0aGluIHRoZSBXb3JrIGNvbnN0aXR1dGVzIGRpcmVjdAogICAgICBvciBjb250cmlidXRvcnkgcGF0ZW50IGluZnJpbmdlbWVudCwgdGhlbiBhbnkgcGF0ZW50IGxpY2Vuc2VzCiAgICAgIGdyYW50ZWQgdG8gWW91IHVuZGVyIHRoaXMgTGljZW5zZSBmb3IgdGhhdCBXb3JrIHNoYWxsIHRlcm1pbmF0ZQogICAgICBhcyBvZiB0aGUgZGF0ZSBzdWNoIGxpdGlnYXRpb24gaXMgZmlsZWQuCgogICA0LiBSZWRpc3RyaWJ1dGlvbi4gWW91IG1heSByZXByb2R1Y2UgYW5kIGRpc3RyaWJ1dGUgY29waWVzIG9mIHRoZQogICAgICBXb3JrIG9yIERlcml2YXRpdmUgV29ya3MgdGhlcmVvZiBpbiBhbnkgbWVkaXVtLCB3aXRoIG9yIHdpdGhvdXQKICAgICAgbW9kaWZpY2F0aW9ucywgYW5kIGluIFNvdXJjZSBvciBPYmplY3QgZm9ybSwgcHJvdmlkZWQgdGhhdCBZb3UKICAgICAgbWVldCB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6CgogICAgICAoYSkgWW91IG11c3QgZ2l2ZSBhbnkgb3RoZXIgcmVjaXBpZW50cyBvZiB0aGUgV29yayBvcgogICAgICAgICAgRGVyaXZhdGl2ZSBXb3JrcyBhIGNvcHkgb2YgdGhpcyBMaWNlbnNlOyBhbmQKCiAgICAgIChiKSBZb3UgbXVzdCBjYXVzZSBhbnkgbW9kaWZpZWQgZmlsZXMgdG8gY2FycnkgcHJvbWluZW50IG5vdGljZXMKICAgICAgICAgIHN0YXRpbmcgdGhhdCBZb3UgY2hhbmdlZCB0aGUgZmlsZXM7IGFuZAoKICAgICAgKGMpIFlvdSBtdXN0IHJldGFpbiwgaW4gdGhlIFNvdXJjZSBmb3JtIG9mIGFueSBEZXJpdmF0aXZlIFdvcmtzCiAgICAgICAgICB0aGF0IFlvdSBkaXN0cmlidXRlLCBhbGwgY29weXJpZ2h0LCBwYXRlbnQsIHRyYWRlbWFyaywgYW5kCiAgICAgICAgICBhdHRyaWJ1dGlvbiBub3RpY2VzIGZyb20gdGhlIFNvdXJjZSBmb3JtIG9mIHRoZSBXb3JrLAogICAgICAgICAgZXhjbHVkaW5nIHRob3NlIG5vdGljZXMgdGhhdCBkbyBub3QgcGVydGFpbiB0byBhbnkgcGFydCBvZgogICAgICAgICAgdGhlIERlcml2YXRpdmUgV29ya3M7IGFuZAoKICAgICAgKGQpIElmIHRoZSBXb3JrIGluY2x1ZGVzIGEgIk5PVElDRSIgdGV4dCBmaWxlIGFzIHBhcnQgb2YgaXRzCiAgICAgICAgICBkaXN0cmlidXRpb24sIHRoZW4gYW55IERlcml2YXRpdmUgV29ya3MgdGhhdCBZb3UgZGlzdHJpYnV0ZSBtdXN0CiAgICAgICAgICBpbmNsdWRlIGEgcmVhZGFibGUgY29weSBvZiB0aGUgYXR0cmlidXRpb24gbm90aWNlcyBjb250YWluZWQKICAgICAgICAgIHdpdGhpbiBzdWNoIE5PVElDRSBmaWxlLCBleGNsdWRpbmcgdGhvc2Ugbm90aWNlcyB0aGF0IGRvIG5vdAogICAgICAgICAgcGVydGFpbiB0byBhbnkgcGFydCBvZiB0aGUgRGVyaXZhdGl2ZSBXb3JrcywgaW4gYXQgbGVhc3Qgb25lCiAgICAgICAgICBvZiB0aGUgZm9sbG93aW5nIHBsYWNlczogd2l0aGluIGEgTk9USUNFIHRleHQgZmlsZSBkaXN0cmlidXRlZAogICAgICAgICAgYXMgcGFydCBvZiB0aGUgRGVyaXZhdGl2ZSBXb3Jrczsgd2l0aGluIHRoZSBTb3VyY2UgZm9ybSBvcgogICAgICAgICAgZG9jdW1lbnRhdGlvbiwgaWYgcHJvdmlkZWQgYWxvbmcgd2l0aCB0aGUgRGVyaXZhdGl2ZSBXb3Jrczsgb3IsCiAgICAgICAgICB3aXRoaW4gYSBkaXNwbGF5IGdlbmVyYXRlZCBieSB0aGUgRGVyaXZhdGl2ZSBXb3JrcywgaWYgYW5kCiAgICAgICAgICB3aGVyZXZlciBzdWNoIHRoaXJkLXBhcnR5IG5vdGljZXMgbm9ybWFsbHkgYXBwZWFyLiBUaGUgY29udGVudHMKICAgICAgICAgIG9mIHRoZSBOT1RJQ0UgZmlsZSBhcmUgZm9yIGluZm9ybWF0aW9uYWwgcHVycG9zZXMgb25seSBhbmQKICAgICAgICAgIGRvIG5vdCBtb2RpZnkgdGhlIExpY2Vuc2UuIFlvdSBtYXkgYWRkIFlvdXIgb3duIGF0dHJpYnV0aW9uCiAgICAgICAgICBub3RpY2VzIHdpdGhpbiBEZXJpdmF0aXZlIFdvcmtzIHRoYXQgWW91IGRpc3RyaWJ1dGUsIGFsb25nc2lkZQogICAgICAgICAgb3IgYXMgYW4gYWRkZW5kdW0gdG8gdGhlIE5PVElDRSB0ZXh0IGZyb20gdGhlIFdvcmssIHByb3ZpZGVkCiAgICAgICAgICB0aGF0IHN1Y2ggYWRkaXRpb25hbCBhdHRyaWJ1dGlvbiBub3RpY2VzIGNhbm5vdCBiZSBjb25zdHJ1ZWQKICAgICAgICAgIGFzIG1vZGlmeWluZyB0aGUgTGljZW5zZS4KCiAgICAgIFlvdSBtYXkgYWRkIFlvdXIgb3duIGNvcHlyaWdodCBzdGF0ZW1lbnQgdG8gWW91ciBtb2RpZmljYXRpb25zIGFuZAogICAgICBtYXkgcHJvdmlkZSBhZGRpdGlvbmFsIG9yIGRpZmZlcmVudCBsaWNlbnNlIHRlcm1zIGFuZCBjb25kaXRpb25zCiAgICAgIGZvciB1c2UsIHJlcHJvZHVjdGlvbiwgb3IgZGlzdHJpYnV0aW9uIG9mIFlvdXIgbW9kaWZpY2F0aW9ucywgb3IKICAgICAgZm9yIGFueSBzdWNoIERlcml2YXRpdmUgV29ya3MgYXMgYSB3aG9sZSwgcHJvdmlkZWQgWW91ciB1c2UsCiAgICAgIHJlcHJvZHVjdGlvbiwgYW5kIGRpc3RyaWJ1dGlvbiBvZiB0aGUgV29yayBvdGhlcndpc2UgY29tcGxpZXMgd2l0aAogICAgICB0aGUgY29uZGl0aW9ucyBzdGF0ZWQgaW4gdGhpcyBMaWNlbnNlLgoKICAgNS4gU3VibWlzc2lvbiBvZiBDb250cmlidXRpb25zLiBVbmxlc3MgWW91IGV4cGxpY2l0bHkgc3RhdGUgb3RoZXJ3aXNlLAogICAgICBhbnkgQ29udHJpYnV0aW9uIGludGVudGlvbmFsbHkgc3VibWl0dGVkIGZvciBpbmNsdXNpb24gaW4gdGhlIFdvcmsKICAgICAgYnkgWW91IHRvIHRoZSBMaWNlbnNvciBzaGFsbCBiZSB1bmRlciB0aGUgdGVybXMgYW5kIGNvbmRpdGlvbnMgb2YKICAgICAgdGhpcyBMaWNlbnNlLCB3aXRob3V0IGFueSBhZGRpdGlvbmFsIHRlcm1zIG9yIGNvbmRpdGlvbnMuCiAgICAgIE5vdHdpdGhzdGFuZGluZyB0aGUgYWJvdmUsIG5vdGhpbmcgaGVyZWluIHNoYWxsIHN1cGVyc2VkZSBvciBtb2RpZnkKICAgICAgdGhlIHRlcm1zIG9mIGFueSBzZXBhcmF0ZSBsaWNlbnNlIGFncmVlbWVudCB5b3UgbWF5IGhhdmUgZXhlY3V0ZWQKICAgICAgd2l0aCBMaWNlbnNvciByZWdhcmRpbmcgc3VjaCBDb250cmlidXRpb25zLgoKICAgNi4gVHJhZGVtYXJrcy4gVGhpcyBMaWNlbnNlIGRvZXMgbm90IGdyYW50IHBlcm1pc3Npb24gdG8gdXNlIHRoZSB0cmFkZQogICAgICBuYW1lcywgdHJhZGVtYXJrcywgc2VydmljZSBtYXJrcywgb3IgcHJvZHVjdCBuYW1lcyBvZiB0aGUgTGljZW5zb3IsCiAgICAgIGV4Y2VwdCBhcyByZXF1aXJlZCBmb3IgcmVhc29uYWJsZSBhbmQgY3VzdG9tYXJ5IHVzZSBpbiBkZXNjcmliaW5nIHRoZQogICAgICBvcmlnaW4gb2YgdGhlIFdvcmsgYW5kIHJlcHJvZHVjaW5nIHRoZSBjb250ZW50IG9mIHRoZSBOT1RJQ0UgZmlsZS4KCiAgIDcuIERpc2NsYWltZXIgb2YgV2FycmFudHkuIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvcgogICAgICBhZ3JlZWQgdG8gaW4gd3JpdGluZywgTGljZW5zb3IgcHJvdmlkZXMgdGhlIFdvcmsgKGFuZCBlYWNoCiAgICAgIENvbnRyaWJ1dG9yIHByb3ZpZGVzIGl0cyBDb250cmlidXRpb25zKSBvbiBhbiAiQVMgSVMiIEJBU0lTLAogICAgICBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IKICAgICAgaW1wbGllZCwgaW5jbHVkaW5nLCB3aXRob3V0IGxpbWl0YXRpb24sIGFueSB3YXJyYW50aWVzIG9yIGNvbmRpdGlvbnMKICAgICAgb2YgVElUTEUsIE5PTi1JTkZSSU5HRU1FTlQsIE1FUkNIQU5UQUJJTElUWSwgb3IgRklUTkVTUyBGT1IgQQogICAgICBQQVJUSUNVTEFSIFBVUlBPU0UuIFlvdSBhcmUgc29sZWx5IHJlc3BvbnNpYmxlIGZvciBkZXRlcm1pbmluZyB0aGUKICAgICAgYXBwcm9wcmlhdGVuZXNzIG9mIHVzaW5nIG9yIHJlZGlzdHJpYnV0aW5nIHRoZSBXb3JrIGFuZCBhc3N1bWUgYW55CiAgICAgIHJpc2tzIGFzc29jaWF0ZWQgd2l0aCBZb3VyIGV4ZXJjaXNlIG9mIHBlcm1pc3Npb25zIHVuZGVyIHRoaXMgTGljZW5zZS4KCiAgIDguIExpbWl0YXRpb24gb2YgTGlhYmlsaXR5LiBJbiBubyBldmVudCBhbmQgdW5kZXIgbm8gbGVnYWwgdGhlb3J5LAogICAgICB3aGV0aGVyIGluIHRvcnQgKGluY2x1ZGluZyBuZWdsaWdlbmNlKSwgY29udHJhY3QsIG9yIG90aGVyd2lzZSwKICAgICAgdW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IChzdWNoIGFzIGRlbGliZXJhdGUgYW5kIGdyb3NzbHkKICAgICAgbmVnbGlnZW50IGFjdHMpIG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzaGFsbCBhbnkgQ29udHJpYnV0b3IgYmUKICAgICAgbGlhYmxlIHRvIFlvdSBmb3IgZGFtYWdlcywgaW5jbHVkaW5nIGFueSBkaXJlY3QsIGluZGlyZWN0LCBzcGVjaWFsLAogICAgICBpbmNpZGVudGFsLCBvciBjb25zZXF1ZW50aWFsIGRhbWFnZXMgb2YgYW55IGNoYXJhY3RlciBhcmlzaW5nIGFzIGEKICAgICAgcmVzdWx0IG9mIHRoaXMgTGljZW5zZSBvciBvdXQgb2YgdGhlIHVzZSBvciBpbmFiaWxpdHkgdG8gdXNlIHRoZQogICAgICBXb3JrIChpbmNsdWRpbmcgYnV0IG5vdCBsaW1pdGVkIHRvIGRhbWFnZXMgZm9yIGxvc3Mgb2YgZ29vZHdpbGwsCiAgICAgIHdvcmsgc3RvcHBhZ2UsIGNvbXB1dGVyIGZhaWx1cmUgb3IgbWFsZnVuY3Rpb24sIG9yIGFueSBhbmQgYWxsCiAgICAgIG90aGVyIGNvbW1lcmNpYWwgZGFtYWdlcyBvciBsb3NzZXMpLCBldmVuIGlmIHN1Y2ggQ29udHJpYnV0b3IKICAgICAgaGFzIGJlZW4gYWR2aXNlZCBvZiB0aGUgcG9zc2liaWxpdHkgb2Ygc3VjaCBkYW1hZ2VzLgoKICAgOS4gQWNjZXB0aW5nIFdhcnJhbnR5IG9yIEFkZGl0aW9uYWwgTGlhYmlsaXR5LiBXaGlsZSByZWRpc3RyaWJ1dGluZwogICAgICB0aGUgV29yayBvciBEZXJpdmF0aXZlIFdvcmtzIHRoZXJlb2YsIFlvdSBtYXkgY2hvb3NlIHRvIG9mZmVyLAogICAgICBhbmQgY2hhcmdlIGEgZmVlIGZvciwgYWNjZXB0YW5jZSBvZiBzdXBwb3J0LCB3YXJyYW50eSwgaW5kZW1uaXR5LAogICAgICBvciBvdGhlciBsaWFiaWxpdHkgb2JsaWdhdGlvbnMgYW5kL29yIHJpZ2h0cyBjb25zaXN0ZW50IHdpdGggdGhpcwogICAgICBMaWNlbnNlLiBIb3dldmVyLCBpbiBhY2NlcHRpbmcgc3VjaCBvYmxpZ2F0aW9ucywgWW91IG1heSBhY3Qgb25seQogICAgICBvbiBZb3VyIG93biBiZWhhbGYgYW5kIG9uIFlvdXIgc29sZSByZXNwb25zaWJpbGl0eSwgbm90IG9uIGJlaGFsZgogICAgICBvZiBhbnkgb3RoZXIgQ29udHJpYnV0b3IsIGFuZCBvbmx5IGlmIFlvdSBhZ3JlZSB0byBpbmRlbW5pZnksCiAgICAgIGRlZmVuZCwgYW5kIGhvbGQgZWFjaCBDb250cmlidXRvciBoYXJtbGVzcyBmb3IgYW55IGxpYWJpbGl0eQogICAgICBpbmN1cnJlZCBieSwgb3IgY2xhaW1zIGFzc2VydGVkIGFnYWluc3QsIHN1Y2ggQ29udHJpYnV0b3IgYnkgcmVhc29uCiAgICAgIG9mIHlvdXIgYWNjZXB0aW5nIGFueSBzdWNoIHdhcnJhbnR5IG9yIGFkZGl0aW9uYWwgbGlhYmlsaXR5LgoKICAgRU5EIE9GIFRFUk1TIEFORCBDT05ESVRJT05TCgogICBBUFBFTkRJWDogSG93IHRvIGFwcGx5IHRoZSBBcGFjaGUgTGljZW5zZSB0byB5b3VyIHdvcmsuCgogICAgICBUbyBhcHBseSB0aGUgQXBhY2hlIExpY2Vuc2UgdG8geW91ciB3b3JrLCBhdHRhY2ggdGhlIGZvbGxvd2luZwogICAgICBib2lsZXJwbGF0ZSBub3RpY2UsIHdpdGggdGhlIGZpZWxkcyBlbmNsb3NlZCBieSBicmFja2V0cyAiW10iCiAgICAgIHJlcGxhY2VkIHdpdGggeW91ciBvd24gaWRlbnRpZnlpbmcgaW5mb3JtYXRpb24uIChEb24ndCBpbmNsdWRlCiAgICAgIHRoZSBicmFja2V0cyEpICBUaGUgdGV4dCBzaG91bGQgYmUgZW5jbG9zZWQgaW4gdGhlIGFwcHJvcHJpYXRlCiAgICAgIGNvbW1lbnQgc3ludGF4IGZvciB0aGUgZmlsZSBmb3JtYXQuIFdlIGFsc28gcmVjb21tZW5kIHRoYXQgYQogICAgICBmaWxlIG9yIGNsYXNzIG5hbWUgYW5kIGRlc2NyaXB0aW9uIG9mIHB1cnBvc2UgYmUgaW5jbHVkZWQgb24gdGhlCiAgICAgIHNhbWUgInByaW50ZWQgcGFnZSIgYXMgdGhlIGNvcHlyaWdodCBub3RpY2UgZm9yIGVhc2llcgogICAgICBpZGVudGlmaWNhdGlvbiB3aXRoaW4gdGhpcmQtcGFydHkgYXJjaGl2ZXMuCgogICBDb3B5cmlnaHQgW3l5eXldIFtuYW1lIG9mIGNvcHlyaWdodCBvd25lcl0KCiAgIExpY2Vuc2VkIHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZSAiTGljZW5zZSIpOwogICB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuCiAgIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdAoKICAgICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMAoKICAgVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZQogICBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiAiQVMgSVMiIEJBU0lTLAogICBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC4KICAgU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZAogICBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS4KCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpBUEFDSEUgVFVTQ0FOWSBTVUJDT01QT05FTlRTOiAKClRoZSBBcGFjaGUgVHVzY2FueSBiaW5hcnkgZGlzdHJpYnV0aW9uIGluY2x1ZGVzIGEgbnVtYmVyIG9mIHN1YmNvbXBvbmVudHMKd2l0aCBzZXBhcmF0ZSBjb3B5cmlnaHQgbm90aWNlcyBhbmQgbGljZW5zZSB0ZXJtcy4gWW91ciB1c2Ugb2YgdGhlCmNvZGUgZm9yIHRoZSB0aGVzZSBzdWJjb21wb25lbnRzIGlzIHN1YmplY3QgdG8gdGhlIHRlcm1zIGFuZApjb25kaXRpb25zIG9mIHRoZSBmb2xsb3dpbmcgbGljZW5zZXMuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KVGhlIGZvbGxvd2luZyBjb21wb25lbnRzIGNvbWUgdW5kZXIgQXBhY2hlIFNvZnR3YXJlIExpY2Vuc2UgMi4wCgogY2dsaWItMi4yLmphcgogY29tbW9ucy1jb21wcmVzcy0xLjAuamFyCiBjb21tb25zLWNvbGxlY3Rpb25zLTMuMS5qYXIKIGNvbW1vbnMtY29kZWMtMS4zLmphcgogY29tbW9ucy1maWxldXBsb2FkLTEuMi4xLmphcgogY29tbW9ucy1pby0xLjQuamFyCiBjb21tb25zLWxhbmctMi40LmphcgogY29tbW9ucy1sb2dnaW5nLTEuMS4xLmphcgogZGVyYnktMTAuMi4xLjYuamFyCiBnZXJvbmltby1jb21tb25qXzEuMV9zcGVjLTEuMC5qYXIKIGdlcm9uaW1vLXN0YXgtYXBpXzEuMF9zcGVjLTEuMC4xLmphcgogaHR0cGNsaWVudC00LjAuamFyCiBodHRwY29yZS00LjAuMS5qYXIKIGphYnNvcmItMS4zLjEuamFyCiBqYWNrcmFiYml0LWFwaS0xLjYuMS5qYXIKIGphY2tyYWJiaXQtY29yZS0xLjYuMS5qYXIKIGphY2tyYWJiaXQtamNyLWNvbW1vbnMtMS42LjEuamFyCiBqYWNrcmFiYml0LXNwaS0xLjYuMS5qYXIKIGphY2tyYWJiaXQtc3BpLWNvbW1vbnMtMS42LjEuamFyCiBqYWNrcmFiYml0LXRleHQtZXh0cmFjdG9ycy0xLjYuMS5qYXIKIGpldHRpc29uLTEuMi5qYXIKIGxvZzRqLTEuMi4xNi5qYXIKIGx1Y2VuZS1jb3JlLTIuNC4xLmphcgogbmVrb2h0bWwtMS45LjcuamFyCiBwb2ktMy4yLUZJTkFMLmphcgogcG9pLXNjcmF0Y2hwYWQtMy4yLUZJTkFMLmphcgogc2Fuc2VsYW4tMC45Ny1pbmN1YmF0b3IuamFyCiB0dXNjYW55LWFzc2VtYmx5LTIuMC1NNS4xLmphcgogdHVzY2FueS1hc3NlbWJseS14bWwtMi4wLU01LjEuamFyCiB0dXNjYW55LWFzc2VtYmx5LXhzZC0yLjAtTTUuMS5qYXIKIHR1c2NhbnktYmluZGluZy1odHRwLTIuMC1NNS4xLmphcgogdHVzY2FueS1iaW5kaW5nLWh0dHAtcnVudGltZS0yLjAtTTUuMS5qYXIKIHR1c2NhbnktYmluZGluZy1qc29ucnBjLTIuMC1NNS4xLmphcgogdHVzY2FueS1iaW5kaW5nLWpzb25ycGMtcnVudGltZS0yLjAtTTUuMS5qYXIKIHR1c2NhbnktYmluZGluZy1zY2EtcnVudGltZS0yLjAtTTUuMS5qYXIKIHR1c2NhbnktYnVpbGRlci0yLjAtTTUuMS5qYXIKIHR1c2NhbnktY29tbW9uLWh0dHAtMi4wLU01LjEuamFyCiB0dXNjYW55LWNvbW1vbi1qYXZhLTIuMC1NNS4xLmphcgogdHVzY2FueS1jb21tb24teG1sLTIuMC1NNS4xLmphcgogdHVzY2FueS1jb250cmlidXRpb24tMi4wLU01LjEuamFyCiB0dXNjYW55LWNvcmUtMi4wLU01LjEuamFyCiB0dXNjYW55LWNvcmUtZGF0YWJpbmRpbmctMi4wLU01LjEuamFyCiB0dXNjYW55LWNvcmUtc3BpLTIuMC1NNS4xLmphcgogdHVzY2FueS1kYXRhLWFwaS0yLjAtTTUuMS5qYXIKIHR1c2NhbnktZGF0YWJpbmRpbmctMi4wLU01LjEuamFyCiB0dXNjYW55LWRhdGFiaW5kaW5nLWpheGItMi4wLU01LjEuamFyCiB0dXNjYW55LWRhdGFiaW5kaW5nLWpzb24tMi4wLU01LjEuamFyCiB0dXNjYW55LWRlcGxveW1lbnQtMi4wLU01LjEuamFyCiB0dXNjYW55LWV4dGVuc2liaWxpdHktMi4wLU01LjEuamFyCiB0dXNjYW55LWhvc3QtaHR0cC0yLjAtTTUuMS5qYXIKIHR1c2NhbnktaG9zdC13ZWJhcHAtMi4wLU01LjEuamFyCiB0dXNjYW55LWltcGxlbWVudGF0aW9uLWphdmEtMi4wLU01LjEuamFyCiB0dXNjYW55LWltcGxlbWVudGF0aW9uLWphdmEtcnVudGltZS0yLjAtTTUuMS5qYXIKIHR1c2NhbnktaW50ZXJmYWNlLWphdmEtMi4wLU01LjEuamFyCiB0dXNjYW55LWludGVyZmFjZS1qYXZhLWpheHdzLTIuMC1NNS4xLmphcgogdHVzY2FueS1tb25pdG9yLTIuMC1NNS4xLmphcgogdHVzY2FueS1ub2RlLWFwaS0yLjAtTTUuMS5qYXIKIHR1c2Nhbnktbm9kZS1pbXBsLTIuMC1NNS4xLmphcgogdHVzY2FueS1zY2EtYXBpLTIuMC1NNS4xLmphcgogdHVzY2FueS14c2QtMi4wLU01LjEuamFyCiB3c3R4LWFzbC0zLjIuNC5qYXIKIHhlcmNlc0ltcGwtMi44LjEuamFyCiBYbWxTY2hlbWEtMS40LjMuamFyCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpKUHl0aG9uIDEuMS54IFNvZnR3YXJlIExpY2Vuc2UuCj09PT09PT09PT09PT09PT09PT09PT09PT0KCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX18KCklNUE9SVEFOVDogUExFQVNFIFJFQUQgVEhFIEZPTExPV0lORyBBR1JFRU1FTlQgQ0FSRUZVTExZLgoKQlkgQ0xJQ0tJTkcgT04gVEhFICJBQ0NFUFQiIEJVVFRPTiBXSEVSRSBJTkRJQ0FURUQsIE9SIEJZIElOU1RBTExJTkcsCkNPUFlJTkcgT1IgT1RIRVJXSVNFIFVTSU5HIFRIRSBTT0ZUV0FSRSwgWU9VIEFSRSBERUVNRUQgVE8gSEFWRSBBR1JFRUQgVE8KVEhFIFRFUk1TIEFORCBDT05ESVRJT05TIE9GIFRISVMgQUdSRUVNRU5ULgoKX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXwoKSlB5dGhvbiB2ZXJzaW9uIDEuMS54CgogIDEuIFRoaXMgTElDRU5TRSBBR1JFRU1FTlQgaXMgYmV0d2VlbiB0aGUgQ29ycG9yYXRpb24gZm9yIE5hdGlvbmFsIFJlc2VhcmNoCiAgICAgSW5pdGlhdGl2ZXMsIGhhdmluZyBhbiBvZmZpY2UgYXQgMTg5NSBQcmVzdG9uIFdoaXRlIERyaXZlLCBSZXN0b24sIFZBCiAgICAgMjAxOTEgKCJDTlJJIiksIGFuZCB0aGUgSW5kaXZpZHVhbCBvciBPcmdhbml6YXRpb24gKCJMaWNlbnNlZSIpCiAgICAgYWNjZXNzaW5nIGFuZCB1c2luZyBKUHl0aG9uIHZlcnNpb24gMS4xLnggaW4gc291cmNlIG9yIGJpbmFyeSBmb3JtIGFuZAogICAgIGl0cyBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gYXMgcHJvdmlkZWQgaGVyZWluICgiU29mdHdhcmUiKS4KCiAgMi4gU3ViamVjdCB0byB0aGUgdGVybXMgYW5kIGNvbmRpdGlvbnMgb2YgdGhpcyBMaWNlbnNlIEFncmVlbWVudCwgQ05SSQogICAgIGhlcmVieSBncmFudHMgTGljZW5zZWUgYSBub24tZXhjbHVzaXZlLCBub24tdHJhbnNmZXJhYmxlLCByb3lhbHR5LWZyZWUsCiAgICAgd29ybGQtd2lkZSBsaWNlbnNlIHRvIHJlcHJvZHVjZSwgYW5hbHl6ZSwgdGVzdCwgcGVyZm9ybSBhbmQvb3IgZGlzcGxheQogICAgIHB1YmxpY2x5LCBwcmVwYXJlIGRlcml2YXRpdmUgd29ya3MsIGRpc3RyaWJ1dGUsIGFuZCBvdGhlcndpc2UgdXNlIHRoZQogICAgIFNvZnR3YXJlIGFsb25lIG9yIGluIGFueSBkZXJpdmF0aXZlIHZlcnNpb24sIHByb3ZpZGVkLCBob3dldmVyLCB0aGF0CiAgICAgQ05SSSdzIExpY2Vuc2UgQWdyZWVtZW50IGFuZCBDTlJJJ3Mgbm90aWNlIG9mIGNvcHlyaWdodCwgaS5lLiwKICAgICAiQ29weXJpZ2h0IKkxOTk2LTE5OTkgQ29ycG9yYXRpb24gZm9yIE5hdGlvbmFsIFJlc2VhcmNoIEluaXRpYXRpdmVzOwogICAgIEFsbCBSaWdodHMgUmVzZXJ2ZWQiIGFyZSBib3RoIHJldGFpbmVkIGluIHRoZSBTb2Z0d2FyZSwgYWxvbmUgb3IgaW4gYW55CiAgICAgZGVyaXZhdGl2ZSB2ZXJzaW9uIHByZXBhcmVkIGJ5IExpY2Vuc2VlLgoKICAgICBBbHRlcm5hdGl2ZWx5LCBpbiBsaWV1IG9mIENOUkkncyBMaWNlbnNlIEFncmVlbWVudCwgTGljZW5zZWUgbWF5CiAgICAgc3Vic3RpdHV0ZSB0aGUgZm9sbG93aW5nIHRleHQgKG9taXR0aW5nIHRoZSBxdW90ZXMpLCBwcm92aWRlZCwgaG93ZXZlciwKICAgICB0aGF0IHN1Y2ggdGV4dCBpcyBkaXNwbGF5ZWQgcHJvbWluZW50bHkgaW4gdGhlIFNvZnR3YXJlIGFsb25lIG9yIGluIGFueQogICAgIGRlcml2YXRpdmUgdmVyc2lvbiBwcmVwYXJlZCBieSBMaWNlbnNlZTogIkpQeXRob24gKFZlcnNpb24gMS4xLngpIGlzCiAgICAgbWFkZSBhdmFpbGFibGUgc3ViamVjdCB0byB0aGUgdGVybXMgYW5kIGNvbmRpdGlvbnMgaW4gQ05SSSdzIExpY2Vuc2UKICAgICBBZ3JlZW1lbnQuIFRoaXMgQWdyZWVtZW50IG1heSBiZSBsb2NhdGVkIG9uIHRoZSBJbnRlcm5ldCB1c2luZyB0aGUKICAgICBmb2xsb3dpbmcgdW5pcXVlLCBwZXJzaXN0ZW50IGlkZW50aWZpZXIgKGtub3duIGFzIGEgaGFuZGxlKToKICAgICAxODk1LjIyLzEwMDYuIFRoZSBMaWNlbnNlIG1heSBhbHNvIGJlIG9idGFpbmVkIGZyb20gYSBwcm94eSBzZXJ2ZXIgb24KICAgICB0aGUgV2ViIHVzaW5nIHRoZSBmb2xsb3dpbmcgVVJMOiBodHRwOi8vaGRsLmhhbmRsZS5uZXQvMTg5NS4yMi8xMDA2LiIKCiAgMy4gSW4gdGhlIGV2ZW50IExpY2Vuc2VlIHByZXBhcmVzIGEgZGVyaXZhdGl2ZSB3b3JrIHRoYXQgaXMgYmFzZWQgb24gb3IKICAgICBpbmNvcnBvcmF0ZXMgdGhlIFNvZnR3YXJlIG9yIGFueSBwYXJ0IHRoZXJlb2YsIGFuZCB3YW50cyB0byBtYWtlIHRoZQogICAgIGRlcml2YXRpdmUgd29yayBhdmFpbGFibGUgdG8gdGhlIHB1YmxpYyBhcyBwcm92aWRlZCBoZXJlaW4sIHRoZW4KICAgICBMaWNlbnNlZSBoZXJlYnkgYWdyZWVzIHRvIGluZGljYXRlIGluIGFueSBzdWNoIHdvcmssIGluIGEgcHJvbWluZW50bHkKICAgICB2aXNpYmxlIHdheSwgdGhlIG5hdHVyZSBvZiB0aGUgbW9kaWZpY2F0aW9ucyBtYWRlIHRvIENOUkkncyBTb2Z0d2FyZS4KCiAgNC4gTGljZW5zZWUgbWF5IG5vdCB1c2UgQ05SSSB0cmFkZW1hcmtzIG9yIHRyYWRlIG5hbWUsIGluY2x1ZGluZyBKUHl0aG9uCiAgICAgb3IgQ05SSSwgaW4gYSB0cmFkZW1hcmsgc2Vuc2UgdG8gZW5kb3JzZSBvciBwcm9tb3RlIHByb2R1Y3RzIG9yCiAgICAgc2VydmljZXMgb2YgTGljZW5zZWUsIG9yIGFueSB0aGlyZCBwYXJ0eS4gTGljZW5zZWUgbWF5IHVzZSB0aGUgbWFyawogICAgIEpQeXRob24gaW4gY29ubmVjdGlvbiB3aXRoIExpY2Vuc2VlJ3MgZGVyaXZhdGl2ZSB2ZXJzaW9ucyB0aGF0IGFyZQogICAgIGJhc2VkIG9uIG9yIGluY29ycG9yYXRlIHRoZSBTb2Z0d2FyZSwgYnV0IG9ubHkgaW4gdGhlIGZvcm0KICAgICAiSlB5dGhvbi1iYXNlZCBfX19fX19fX19fX19fX19fX19fLCIgb3IgZXF1aXZhbGVudC4KCiAgNS4gQ05SSSBpcyBtYWtpbmcgdGhlIFNvZnR3YXJlIGF2YWlsYWJsZSB0byBMaWNlbnNlZSBvbiBhbiAiQVMgSVMiIGJhc2lzLgogICAgIENOUkkgTUFLRVMgTk8gUkVQUkVTRU5UQVRJT05TIE9SIFdBUlJBTlRJRVMsIEVYUFJFU1MgT1IgSU1QTElFRC4gQlkgV0FZCiAgICAgT0YgRVhBTVBMRSwgQlVUIE5PVCBMSU1JVEFUSU9OLCBDTlJJIE1BS0VTIE5PIEFORCBESVNDTEFJTVMgQU5ZCiAgICAgUkVQUkVTRU5UQVRJT04gT1IgV0FSUkFOVFkgT0YgTUVSQ0hBTlRBQklMSVRZIE9SIEZJVE5FU1MgRk9SIEFOWQogICAgIFBBUlRJQ1VMQVIgUFVSUE9TRSBPUiBUSEFUIFRIRSBVU0UgT0YgVEhFIFNPRlRXQVJFIFdJTEwgTk9UIElORlJJTkdFCiAgICAgQU5ZIFRISVJEIFBBUlRZIFJJR0hUUy4KCiAgNi4gQ05SSSBTSEFMTCBOT1QgQkUgTElBQkxFIFRPIExJQ0VOU0VFIE9SIE9USEVSIFVTRVJTIE9GIFRIRSBTT0ZUV0FSRSBGT1IKICAgICBBTlkgSU5DSURFTlRBTCwgU1BFQ0lBTCBPUiBDT05TRVFVRU5USUFMIERBTUFHRVMgT1IgTE9TUyBBUyBBIFJFU1VMVCBPRgogICAgIFVTSU5HLCBNT0RJRllJTkcgT1IgRElTVFJJQlVUSU5HIFRIRSBTT0ZUV0FSRSwgT1IgQU5ZIERFUklWQVRJVkUKICAgICBUSEVSRU9GLCBFVkVOIElGIEFEVklTRUQgT0YgVEhFIFBPU1NJQklMSVRZIFRIRVJFT0YuIFNPTUUgU1RBVEVTIERPIE5PVAogICAgIEFMTE9XIFRIRSBMSU1JVEFUSU9OIE9SIEVYQ0xVU0lPTiBPRiBMSUFCSUxJVFkgU08gVEhFIEFCT1ZFIERJU0NMQUlNRVIKICAgICBNQVkgTk9UIEFQUExZIFRPIExJQ0VOU0VFLgoKICA3LiBUaGlzIExpY2Vuc2UgQWdyZWVtZW50IG1heSBiZSB0ZXJtaW5hdGVkIGJ5IENOUkkgKGkpIGltbWVkaWF0ZWx5IHVwb24KICAgICB3cml0dGVuIG5vdGljZSBmcm9tIENOUkkgb2YgYW55IG1hdGVyaWFsIGJyZWFjaCBieSB0aGUgTGljZW5zZWUsIGlmIHRoZQogICAgIG5hdHVyZSBvZiB0aGUgYnJlYWNoIGlzIHN1Y2ggdGhhdCBpdCBjYW5ub3QgYmUgcHJvbXB0bHkgcmVtZWRpZWQ7IG9yCiAgICAgKGlpKSBzaXh0eSAoNjApIGRheXMgZm9sbG93aW5nIG5vdGljZSBmcm9tIENOUkkgdG8gTGljZW5zZWUgb2YgYQogICAgIG1hdGVyaWFsIHJlbWVkaWFibGUgYnJlYWNoLCBpZiBMaWNlbnNlZSBoYXMgbm90IHJlbWVkaWVkIHN1Y2ggYnJlYWNoCiAgICAgd2l0aGluIHRoYXQgc2l4dHktZGF5IHBlcmlvZC4KCiAgOC4gVGhpcyBMaWNlbnNlIEFncmVlbWVudCBzaGFsbCBiZSBnb3Zlcm5lZCBieSBhbmQgaW50ZXJwcmV0ZWQgaW4gYWxsCiAgICAgcmVzcGVjdHMgYnkgdGhlIGxhdyBvZiB0aGUgU3RhdGUgb2YgVmlyZ2luaWEsIGV4Y2x1ZGluZyBjb25mbGljdCBvZiBsYXcKICAgICBwcm92aXNpb25zLiBOb3RoaW5nIGluIHRoaXMgQWdyZWVtZW50IHNoYWxsIGJlIGRlZW1lZCB0byBjcmVhdGUgYW55CiAgICAgcmVsYXRpb25zaGlwIG9mIGFnZW5jeSwgcGFydG5lcnNoaXAsIG9yIGpvaW50IHZlbnR1cmUgYmV0d2VlbiBDTlJJIGFuZAogICAgIExpY2Vuc2VlLgoKICA5LiBCeSBjbGlja2luZyBvbiB0aGUgIkFDQ0VQVCIgYnV0dG9uIHdoZXJlIGluZGljYXRlZCwgb3IgYnkgaW5zdGFsbGluZywKICAgICBjb3B5aW5nIG9yIG90aGVyd2lzZSB1c2luZyB0aGUgU29mdHdhcmUsIExpY2Vuc2VlIGFncmVlcyB0byBiZSBib3VuZCBieQogICAgIHRoZSB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZiB0aGlzIExpY2Vuc2UgQWdyZWVtZW50LgoKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KClRoZSBqYXJzOyAKYWN0aXZhdGlvbi0xLjEuamFyLCAKamF4Yi1hcGktMi4xLmphciwgCmpheGItaW1wbC0yLjEuMTIuamFyLCAKanNyMTgxLWFwaS0xLjAtTVIxLmphciwgCmpzcjI1MC1hcGktMS4wLmphciwgCmpheHdzLWFwaS0yLjEuamFyCgpDT01NT04gREVWRUxPUE1FTlQgQU5EIERJU1RSSUJVVElPTiBMSUNFTlNFIChDRERMKSBWZXJzaW9uIDEuMAoKCiAgICAgIDEuIERlZmluaXRpb25zLgoKICAgICAgICAgICAgMS4xLiAiQ29udHJpYnV0b3IiIG1lYW5zIGVhY2ggaW5kaXZpZHVhbCBvciBlbnRpdHkgdGhhdAogICAgICAgICAgICBjcmVhdGVzIG9yIGNvbnRyaWJ1dGVzIHRvIHRoZSBjcmVhdGlvbiBvZiBNb2RpZmljYXRpb25zLgoKICAgICAgICAgICAgMS4yLiAiQ29udHJpYnV0b3IgVmVyc2lvbiIgbWVhbnMgdGhlIGNvbWJpbmF0aW9uIG9mIHRoZQogICAgICAgICAgICBPcmlnaW5hbCBTb2Z0d2FyZSwgcHJpb3IgTW9kaWZpY2F0aW9ucyB1c2VkIGJ5IGEKICAgICAgICAgICAgQ29udHJpYnV0b3IgKGlmIGFueSksIGFuZCB0aGUgTW9kaWZpY2F0aW9ucyBtYWRlIGJ5IHRoYXQKICAgICAgICAgICAgcGFydGljdWxhciBDb250cmlidXRvci4KCiAgICAgICAgICAgIDEuMy4gIkNvdmVyZWQgU29mdHdhcmUiIG1lYW5zIChhKSB0aGUgT3JpZ2luYWwgU29mdHdhcmUsIG9yCiAgICAgICAgICAgIChiKSBNb2RpZmljYXRpb25zLCBvciAoYykgdGhlIGNvbWJpbmF0aW9uIG9mIGZpbGVzCiAgICAgICAgICAgIGNvbnRhaW5pbmcgT3JpZ2luYWwgU29mdHdhcmUgd2l0aCBmaWxlcyBjb250YWluaW5nCiAgICAgICAgICAgIE1vZGlmaWNhdGlvbnMsIGluIGVhY2ggY2FzZSBpbmNsdWRpbmcgcG9ydGlvbnMgdGhlcmVvZi4KCiAgICAgICAgICAgIDEuNC4gIkV4ZWN1dGFibGUiIG1lYW5zIHRoZSBDb3ZlcmVkIFNvZnR3YXJlIGluIGFueSBmb3JtCiAgICAgICAgICAgIG90aGVyIHRoYW4gU291cmNlIENvZGUuIAoKICAgICAgICAgICAgMS41LiAiSW5pdGlhbCBEZXZlbG9wZXIiIG1lYW5zIHRoZSBpbmRpdmlkdWFsIG9yIGVudGl0eQogICAgICAgICAgICB0aGF0IGZpcnN0IG1ha2VzIE9yaWdpbmFsIFNvZnR3YXJlIGF2YWlsYWJsZSB1bmRlciB0aGlzCiAgICAgICAgICAgIExpY2Vuc2UuIAogICAgICAgICAgICAKICAgICAgICAgICAgMS42LiAiTGFyZ2VyIFdvcmsiIG1lYW5zIGEgd29yayB3aGljaCBjb21iaW5lcyBDb3ZlcmVkCiAgICAgICAgICAgIFNvZnR3YXJlIG9yIHBvcnRpb25zIHRoZXJlb2Ygd2l0aCBjb2RlIG5vdCBnb3Zlcm5lZCBieSB0aGUKICAgICAgICAgICAgdGVybXMgb2YgdGhpcyBMaWNlbnNlLgoKICAgICAgICAgICAgMS43LiAiTGljZW5zZSIgbWVhbnMgdGhpcyBkb2N1bWVudC4KCiAgICAgICAgICAgIDEuOC4gIkxpY2Vuc2FibGUiIG1lYW5zIGhhdmluZyB0aGUgcmlnaHQgdG8gZ3JhbnQsIHRvIHRoZQogICAgICAgICAgICBtYXhpbXVtIGV4dGVudCBwb3NzaWJsZSwgd2hldGhlciBhdCB0aGUgdGltZSBvZiB0aGUgaW5pdGlhbAogICAgICAgICAgICBncmFudCBvciBzdWJzZXF1ZW50bHkgYWNxdWlyZWQsIGFueSBhbmQgYWxsIG9mIHRoZSByaWdodHMKICAgICAgICAgICAgY29udmV5ZWQgaGVyZWluLgogICAgICAgICAgICAKICAgICAgICAgICAgMS45LiAiTW9kaWZpY2F0aW9ucyIgbWVhbnMgdGhlIFNvdXJjZSBDb2RlIGFuZCBFeGVjdXRhYmxlCiAgICAgICAgICAgIGZvcm0gb2YgYW55IG9mIHRoZSBmb2xsb3dpbmc6IAoKICAgICAgICAgICAgICAgICAgQS4gQW55IGZpbGUgdGhhdCByZXN1bHRzIGZyb20gYW4gYWRkaXRpb24gdG8sCiAgICAgICAgICAgICAgICAgIGRlbGV0aW9uIGZyb20gb3IgbW9kaWZpY2F0aW9uIG9mIHRoZSBjb250ZW50cyBvZiBhCiAgICAgICAgICAgICAgICAgIGZpbGUgY29udGFpbmluZyBPcmlnaW5hbCBTb2Z0d2FyZSBvciBwcmV2aW91cwogICAgICAgICAgICAgICAgICBNb2RpZmljYXRpb25zOyAKCiAgICAgICAgICAgICAgICAgIEIuIEFueSBuZXcgZmlsZSB0aGF0IGNvbnRhaW5zIGFueSBwYXJ0IG9mIHRoZQogICAgICAgICAgICAgICAgICBPcmlnaW5hbCBTb2Z0d2FyZSBvciBwcmV2aW91cyBNb2RpZmljYXRpb247IG9yIAoKICAgICAgICAgICAgICAgICAgQy4gQW55IG5ldyBmaWxlIHRoYXQgaXMgY29udHJpYnV0ZWQgb3Igb3RoZXJ3aXNlIG1hZGUKICAgICAgICAgICAgICAgICAgYXZhaWxhYmxlIHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGlzIExpY2Vuc2UuCgogICAgICAgICAgICAxLjEwLiAiT3JpZ2luYWwgU29mdHdhcmUiIG1lYW5zIHRoZSBTb3VyY2UgQ29kZSBhbmQKICAgICAgICAgICAgRXhlY3V0YWJsZSBmb3JtIG9mIGNvbXB1dGVyIHNvZnR3YXJlIGNvZGUgdGhhdCBpcwogICAgICAgICAgICBvcmlnaW5hbGx5IHJlbGVhc2VkIHVuZGVyIHRoaXMgTGljZW5zZS4gCgogICAgICAgICAgICAxLjExLiAiUGF0ZW50IENsYWltcyIgbWVhbnMgYW55IHBhdGVudCBjbGFpbShzKSwgbm93IG93bmVkCiAgICAgICAgICAgIG9yIGhlcmVhZnRlciBhY3F1aXJlZCwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvbiwKICAgICAgICAgICAgbWV0aG9kLCBwcm9jZXNzLCBhbmQgYXBwYXJhdHVzIGNsYWltcywgaW4gYW55IHBhdGVudAogICAgICAgICAgICBMaWNlbnNhYmxlIGJ5IGdyYW50b3IuIAoKICAgICAgICAgICAgMS4xMi4gIlNvdXJjZSBDb2RlIiBtZWFucyAoYSkgdGhlIGNvbW1vbiBmb3JtIG9mIGNvbXB1dGVyCiAgICAgICAgICAgIHNvZnR3YXJlIGNvZGUgaW4gd2hpY2ggbW9kaWZpY2F0aW9ucyBhcmUgbWFkZSBhbmQgKGIpCiAgICAgICAgICAgIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiBpbmNsdWRlZCBpbiBvciB3aXRoIHN1Y2ggY29kZS4KCiAgICAgICAgICAgIDEuMTMuICJZb3UiIChvciAiWW91ciIpIG1lYW5zIGFuIGluZGl2aWR1YWwgb3IgYSBsZWdhbAogICAgICAgICAgICBlbnRpdHkgZXhlcmNpc2luZyByaWdodHMgdW5kZXIsIGFuZCBjb21wbHlpbmcgd2l0aCBhbGwgb2YKICAgICAgICAgICAgdGhlIHRlcm1zIG9mLCB0aGlzIExpY2Vuc2UuIEZvciBsZWdhbCBlbnRpdGllcywgIllvdSIKICAgICAgICAgICAgaW5jbHVkZXMgYW55IGVudGl0eSB3aGljaCBjb250cm9scywgaXMgY29udHJvbGxlZCBieSwgb3IgaXMKICAgICAgICAgICAgdW5kZXIgY29tbW9uIGNvbnRyb2wgd2l0aCBZb3UuIEZvciBwdXJwb3NlcyBvZiB0aGlzCiAgICAgICAgICAgIGRlZmluaXRpb24sICJjb250cm9sIiBtZWFucyAoYSkgdGhlIHBvd2VyLCBkaXJlY3Qgb3IKICAgICAgICAgICAgaW5kaXJlY3QsIHRvIGNhdXNlIHRoZSBkaXJlY3Rpb24gb3IgbWFuYWdlbWVudCBvZiBzdWNoCiAgICAgICAgICAgIGVudGl0eSwgd2hldGhlciBieSBjb250cmFjdCBvciBvdGhlcndpc2UsIG9yIChiKSBvd25lcnNoaXAKICAgICAgICAgICAgb2YgbW9yZSB0aGFuIGZpZnR5IHBlcmNlbnQgKDUwJSkgb2YgdGhlIG91dHN0YW5kaW5nIHNoYXJlcwogICAgICAgICAgICBvciBiZW5lZmljaWFsIG93bmVyc2hpcCBvZiBzdWNoIGVudGl0eS4KCiAgICAgIDIuIExpY2Vuc2UgR3JhbnRzLiAKCiAgICAgICAgICAgIDIuMS4gVGhlIEluaXRpYWwgRGV2ZWxvcGVyIEdyYW50LgoKICAgICAgICAgICAgQ29uZGl0aW9uZWQgdXBvbiBZb3VyIGNvbXBsaWFuY2Ugd2l0aCBTZWN0aW9uIDMuMSBiZWxvdyBhbmQKICAgICAgICAgICAgc3ViamVjdCB0byB0aGlyZCBwYXJ0eSBpbnRlbGxlY3R1YWwgcHJvcGVydHkgY2xhaW1zLCB0aGUKICAgICAgICAgICAgSW5pdGlhbCBEZXZlbG9wZXIgaGVyZWJ5IGdyYW50cyBZb3UgYSB3b3JsZC13aWRlLAogICAgICAgICAgICByb3lhbHR5LWZyZWUsIG5vbi1leGNsdXNpdmUgbGljZW5zZTogCgogICAgICAgICAgICAgICAgICAoYSkgdW5kZXIgaW50ZWxsZWN0dWFsIHByb3BlcnR5IHJpZ2h0cyAob3RoZXIgdGhhbgogICAgICAgICAgICAgICAgICBwYXRlbnQgb3IgdHJhZGVtYXJrKSBMaWNlbnNhYmxlIGJ5IEluaXRpYWwgRGV2ZWxvcGVyLAogICAgICAgICAgICAgICAgICB0byB1c2UsIHJlcHJvZHVjZSwgbW9kaWZ5LCBkaXNwbGF5LCBwZXJmb3JtLAogICAgICAgICAgICAgICAgICBzdWJsaWNlbnNlIGFuZCBkaXN0cmlidXRlIHRoZSBPcmlnaW5hbCBTb2Z0d2FyZSAob3IKICAgICAgICAgICAgICAgICAgcG9ydGlvbnMgdGhlcmVvZiksIHdpdGggb3Igd2l0aG91dCBNb2RpZmljYXRpb25zLAogICAgICAgICAgICAgICAgICBhbmQvb3IgYXMgcGFydCBvZiBhIExhcmdlciBXb3JrOyBhbmQgCgogICAgICAgICAgICAgICAgICAoYikgdW5kZXIgUGF0ZW50IENsYWltcyBpbmZyaW5nZWQgYnkgdGhlIG1ha2luZywKICAgICAgICAgICAgICAgICAgdXNpbmcgb3Igc2VsbGluZyBvZiBPcmlnaW5hbCBTb2Z0d2FyZSwgdG8gbWFrZSwgaGF2ZQogICAgICAgICAgICAgICAgICBtYWRlLCB1c2UsIHByYWN0aWNlLCBzZWxsLCBhbmQgb2ZmZXIgZm9yIHNhbGUsIGFuZC9vcgogICAgICAgICAgICAgICAgICBvdGhlcndpc2UgZGlzcG9zZSBvZiB0aGUgT3JpZ2luYWwgU29mdHdhcmUgKG9yCiAgICAgICAgICAgICAgICAgIHBvcnRpb25zIHRoZXJlb2YpLiAKCiAgICAgICAgICAgICAgICAgIChjKSBUaGUgbGljZW5zZXMgZ3JhbnRlZCBpbiBTZWN0aW9ucyAyLjEoYSkgYW5kIChiKQogICAgICAgICAgICAgICAgICBhcmUgZWZmZWN0aXZlIG9uIHRoZSBkYXRlIEluaXRpYWwgRGV2ZWxvcGVyIGZpcnN0CiAgICAgICAgICAgICAgICAgIGRpc3RyaWJ1dGVzIG9yIG90aGVyd2lzZSBtYWtlcyB0aGUgT3JpZ2luYWwgU29mdHdhcmUKICAgICAgICAgICAgICAgICAgYXZhaWxhYmxlIHRvIGEgdGhpcmQgcGFydHkgdW5kZXIgdGhlIHRlcm1zIG9mIHRoaXMKICAgICAgICAgICAgICAgICAgTGljZW5zZS4gCgogICAgICAgICAgICAgICAgICAoZCkgTm90d2l0aHN0YW5kaW5nIFNlY3Rpb24gMi4xKGIpIGFib3ZlLCBubyBwYXRlbnQKICAgICAgICAgICAgICAgICAgbGljZW5zZSBpcyBncmFudGVkOiAoMSkgZm9yIGNvZGUgdGhhdCBZb3UgZGVsZXRlIGZyb20KICAgICAgICAgICAgICAgICAgdGhlIE9yaWdpbmFsIFNvZnR3YXJlLCBvciAoMikgZm9yIGluZnJpbmdlbWVudHMKICAgICAgICAgICAgICAgICAgY2F1c2VkIGJ5OiAoaSkgdGhlIG1vZGlmaWNhdGlvbiBvZiB0aGUgT3JpZ2luYWwKICAgICAgICAgICAgICAgICAgU29mdHdhcmUsIG9yIChpaSkgdGhlIGNvbWJpbmF0aW9uIG9mIHRoZSBPcmlnaW5hbAogICAgICAgICAgICAgICAgICBTb2Z0d2FyZSB3aXRoIG90aGVyIHNvZnR3YXJlIG9yIGRldmljZXMuIAoKICAgICAgICAgICAgMi4yLiBDb250cmlidXRvciBHcmFudC4KCiAgICAgICAgICAgIENvbmRpdGlvbmVkIHVwb24gWW91ciBjb21wbGlhbmNlIHdpdGggU2VjdGlvbiAzLjEgYmVsb3cgYW5kCiAgICAgICAgICAgIHN1YmplY3QgdG8gdGhpcmQgcGFydHkgaW50ZWxsZWN0dWFsIHByb3BlcnR5IGNsYWltcywgZWFjaAogICAgICAgICAgICBDb250cmlidXRvciBoZXJlYnkgZ3JhbnRzIFlvdSBhIHdvcmxkLXdpZGUsIHJveWFsdHktZnJlZSwKICAgICAgICAgICAgbm9uLWV4Y2x1c2l2ZSBsaWNlbnNlOgoKICAgICAgICAgICAgICAgICAgKGEpIHVuZGVyIGludGVsbGVjdHVhbCBwcm9wZXJ0eSByaWdodHMgKG90aGVyIHRoYW4KICAgICAgICAgICAgICAgICAgcGF0ZW50IG9yIHRyYWRlbWFyaykgTGljZW5zYWJsZSBieSBDb250cmlidXRvciB0bwogICAgICAgICAgICAgICAgICB1c2UsIHJlcHJvZHVjZSwgbW9kaWZ5LCBkaXNwbGF5LCBwZXJmb3JtLCBzdWJsaWNlbnNlCiAgICAgICAgICAgICAgICAgIGFuZCBkaXN0cmlidXRlIHRoZSBNb2RpZmljYXRpb25zIGNyZWF0ZWQgYnkgc3VjaAogICAgICAgICAgICAgICAgICBDb250cmlidXRvciAob3IgcG9ydGlvbnMgdGhlcmVvZiksIGVpdGhlciBvbiBhbgogICAgICAgICAgICAgICAgICB1bm1vZGlmaWVkIGJhc2lzLCB3aXRoIG90aGVyIE1vZGlmaWNhdGlvbnMsIGFzCiAgICAgICAgICAgICAgICAgIENvdmVyZWQgU29mdHdhcmUgYW5kL29yIGFzIHBhcnQgb2YgYSBMYXJnZXIgV29yazsgYW5kCiAgICAgICAgICAgICAgICAgIAoKICAgICAgICAgICAgICAgICAgKGIpIHVuZGVyIFBhdGVudCBDbGFpbXMgaW5mcmluZ2VkIGJ5IHRoZSBtYWtpbmcsCiAgICAgICAgICAgICAgICAgIHVzaW5nLCBvciBzZWxsaW5nIG9mIE1vZGlmaWNhdGlvbnMgbWFkZSBieSB0aGF0CiAgICAgICAgICAgICAgICAgIENvbnRyaWJ1dG9yIGVpdGhlciBhbG9uZSBhbmQvb3IgaW4gY29tYmluYXRpb24gd2l0aAogICAgICAgICAgICAgICAgICBpdHMgQ29udHJpYnV0b3IgVmVyc2lvbiAob3IgcG9ydGlvbnMgb2Ygc3VjaAogICAgICAgICAgICAgICAgICBjb21iaW5hdGlvbiksIHRvIG1ha2UsIHVzZSwgc2VsbCwgb2ZmZXIgZm9yIHNhbGUsCiAgICAgICAgICAgICAgICAgIGhhdmUgbWFkZSwgYW5kL29yIG90aGVyd2lzZSBkaXNwb3NlIG9mOiAoMSkKICAgICAgICAgICAgICAgICAgTW9kaWZpY2F0aW9ucyBtYWRlIGJ5IHRoYXQgQ29udHJpYnV0b3IgKG9yIHBvcnRpb25zCiAgICAgICAgICAgICAgICAgIHRoZXJlb2YpOyBhbmQgKDIpIHRoZSBjb21iaW5hdGlvbiBvZiBNb2RpZmljYXRpb25zCiAgICAgICAgICAgICAgICAgIG1hZGUgYnkgdGhhdCBDb250cmlidXRvciB3aXRoIGl0cyBDb250cmlidXRvciBWZXJzaW9uCiAgICAgICAgICAgICAgICAgIChvciBwb3J0aW9ucyBvZiBzdWNoIGNvbWJpbmF0aW9uKS4gCgogICAgICAgICAgICAgICAgICAoYykgVGhlIGxpY2Vuc2VzIGdyYW50ZWQgaW4gU2VjdGlvbnMgMi4yKGEpIGFuZAogICAgICAgICAgICAgICAgICAyLjIoYikgYXJlIGVmZmVjdGl2ZSBvbiB0aGUgZGF0ZSBDb250cmlidXRvciBmaXJzdAogICAgICAgICAgICAgICAgICBkaXN0cmlidXRlcyBvciBvdGhlcndpc2UgbWFrZXMgdGhlIE1vZGlmaWNhdGlvbnMKICAgICAgICAgICAgICAgICAgYXZhaWxhYmxlIHRvIGEgdGhpcmQgcGFydHkuIAoKICAgICAgICAgICAgICAgICAgKGQpIE5vdHdpdGhzdGFuZGluZyBTZWN0aW9uIDIuMihiKSBhYm92ZSwgbm8gcGF0ZW50CiAgICAgICAgICAgICAgICAgIGxpY2Vuc2UgaXMgZ3JhbnRlZDogKDEpIGZvciBhbnkgY29kZSB0aGF0IENvbnRyaWJ1dG9yCiAgICAgICAgICAgICAgICAgIGhhcyBkZWxldGVkIGZyb20gdGhlIENvbnRyaWJ1dG9yIFZlcnNpb247ICgyKSBmb3IKICAgICAgICAgICAgICAgICAgaW5mcmluZ2VtZW50cyBjYXVzZWQgYnk6IChpKSB0aGlyZCBwYXJ0eQogICAgICAgICAgICAgICAgICBtb2RpZmljYXRpb25zIG9mIENvbnRyaWJ1dG9yIFZlcnNpb24sIG9yIChpaSkgdGhlCiAgICAgICAgICAgICAgICAgIGNvbWJpbmF0aW9uIG9mIE1vZGlmaWNhdGlvbnMgbWFkZSBieSB0aGF0IENvbnRyaWJ1dG9yCiAgICAgICAgICAgICAgICAgIHdpdGggb3RoZXIgc29mdHdhcmUgKGV4Y2VwdCBhcyBwYXJ0IG9mIHRoZQogICAgICAgICAgICAgICAgICBDb250cmlidXRvciBWZXJzaW9uKSBvciBvdGhlciBkZXZpY2VzOyBvciAoMykgdW5kZXIKICAgICAgICAgICAgICAgICAgUGF0ZW50IENsYWltcyBpbmZyaW5nZWQgYnkgQ292ZXJlZCBTb2Z0d2FyZSBpbiB0aGUKICAgICAgICAgICAgICAgICAgYWJzZW5jZSBvZiBNb2RpZmljYXRpb25zIG1hZGUgYnkgdGhhdCBDb250cmlidXRvci4gCgogICAgICAzLiBEaXN0cmlidXRpb24gT2JsaWdhdGlvbnMuCgogICAgICAgICAgICAzLjEuIEF2YWlsYWJpbGl0eSBvZiBTb3VyY2UgQ29kZS4KCiAgICAgICAgICAgIEFueSBDb3ZlcmVkIFNvZnR3YXJlIHRoYXQgWW91IGRpc3RyaWJ1dGUgb3Igb3RoZXJ3aXNlIG1ha2UKICAgICAgICAgICAgYXZhaWxhYmxlIGluIEV4ZWN1dGFibGUgZm9ybSBtdXN0IGFsc28gYmUgbWFkZSBhdmFpbGFibGUgaW4KICAgICAgICAgICAgU291cmNlIENvZGUgZm9ybSBhbmQgdGhhdCBTb3VyY2UgQ29kZSBmb3JtIG11c3QgYmUKICAgICAgICAgICAgZGlzdHJpYnV0ZWQgb25seSB1bmRlciB0aGUgdGVybXMgb2YgdGhpcyBMaWNlbnNlLiBZb3UgbXVzdAogICAgICAgICAgICBpbmNsdWRlIGEgY29weSBvZiB0aGlzIExpY2Vuc2Ugd2l0aCBldmVyeSBjb3B5IG9mIHRoZQogICAgICAgICAgICBTb3VyY2UgQ29kZSBmb3JtIG9mIHRoZSBDb3ZlcmVkIFNvZnR3YXJlIFlvdSBkaXN0cmlidXRlIG9yCiAgICAgICAgICAgIG90aGVyd2lzZSBtYWtlIGF2YWlsYWJsZS4gWW91IG11c3QgaW5mb3JtIHJlY2lwaWVudHMgb2YgYW55CiAgICAgICAgICAgIHN1Y2ggQ292ZXJlZCBTb2Z0d2FyZSBpbiBFeGVjdXRhYmxlIGZvcm0gYXMgdG8gaG93IHRoZXkgY2FuCiAgICAgICAgICAgIG9idGFpbiBzdWNoIENvdmVyZWQgU29mdHdhcmUgaW4gU291cmNlIENvZGUgZm9ybSBpbiBhCiAgICAgICAgICAgIHJlYXNvbmFibGUgbWFubmVyIG9uIG9yIHRocm91Z2ggYSBtZWRpdW0gY3VzdG9tYXJpbHkgdXNlZAogICAgICAgICAgICBmb3Igc29mdHdhcmUgZXhjaGFuZ2UuCgogICAgICAgICAgICAzLjIuIE1vZGlmaWNhdGlvbnMuCgogICAgICAgICAgICBUaGUgTW9kaWZpY2F0aW9ucyB0aGF0IFlvdSBjcmVhdGUgb3IgdG8gd2hpY2ggWW91CiAgICAgICAgICAgIGNvbnRyaWJ1dGUgYXJlIGdvdmVybmVkIGJ5IHRoZSB0ZXJtcyBvZiB0aGlzIExpY2Vuc2UuIFlvdQogICAgICAgICAgICByZXByZXNlbnQgdGhhdCBZb3UgYmVsaWV2ZSBZb3VyIE1vZGlmaWNhdGlvbnMgYXJlIFlvdXIKICAgICAgICAgICAgb3JpZ2luYWwgY3JlYXRpb24ocykgYW5kL29yIFlvdSBoYXZlIHN1ZmZpY2llbnQgcmlnaHRzIHRvCiAgICAgICAgICAgIGdyYW50IHRoZSByaWdodHMgY29udmV5ZWQgYnkgdGhpcyBMaWNlbnNlLgoKICAgICAgICAgICAgMy4zLiBSZXF1aXJlZCBOb3RpY2VzLgoKICAgICAgICAgICAgWW91IG11c3QgaW5jbHVkZSBhIG5vdGljZSBpbiBlYWNoIG9mIFlvdXIgTW9kaWZpY2F0aW9ucwogICAgICAgICAgICB0aGF0IGlkZW50aWZpZXMgWW91IGFzIHRoZSBDb250cmlidXRvciBvZiB0aGUgTW9kaWZpY2F0aW9uLgogICAgICAgICAgICBZb3UgbWF5IG5vdCByZW1vdmUgb3IgYWx0ZXIgYW55IGNvcHlyaWdodCwgcGF0ZW50IG9yCiAgICAgICAgICAgIHRyYWRlbWFyayBub3RpY2VzIGNvbnRhaW5lZCB3aXRoaW4gdGhlIENvdmVyZWQgU29mdHdhcmUsIG9yCiAgICAgICAgICAgIGFueSBub3RpY2VzIG9mIGxpY2Vuc2luZyBvciBhbnkgZGVzY3JpcHRpdmUgdGV4dCBnaXZpbmcKICAgICAgICAgICAgYXR0cmlidXRpb24gdG8gYW55IENvbnRyaWJ1dG9yIG9yIHRoZSBJbml0aWFsIERldmVsb3Blci4KCiAgICAgICAgICAgIDMuNC4gQXBwbGljYXRpb24gb2YgQWRkaXRpb25hbCBUZXJtcy4KCiAgICAgICAgICAgIFlvdSBtYXkgbm90IG9mZmVyIG9yIGltcG9zZSBhbnkgdGVybXMgb24gYW55IENvdmVyZWQKICAgICAgICAgICAgU29mdHdhcmUgaW4gU291cmNlIENvZGUgZm9ybSB0aGF0IGFsdGVycyBvciByZXN0cmljdHMgdGhlCiAgICAgICAgICAgIGFwcGxpY2FibGUgdmVyc2lvbiBvZiB0aGlzIExpY2Vuc2Ugb3IgdGhlIHJlY2lwaWVudHMnCiAgICAgICAgICAgIHJpZ2h0cyBoZXJldW5kZXIuIFlvdSBtYXkgY2hvb3NlIHRvIG9mZmVyLCBhbmQgdG8gY2hhcmdlIGEKICAgICAgICAgICAgZmVlIGZvciwgd2FycmFudHksIHN1cHBvcnQsIGluZGVtbml0eSBvciBsaWFiaWxpdHkKICAgICAgICAgICAgb2JsaWdhdGlvbnMgdG8gb25lIG9yIG1vcmUgcmVjaXBpZW50cyBvZiBDb3ZlcmVkIFNvZnR3YXJlLgogICAgICAgICAgICBIb3dldmVyLCB5b3UgbWF5IGRvIHNvIG9ubHkgb24gWW91ciBvd24gYmVoYWxmLCBhbmQgbm90IG9uCiAgICAgICAgICAgIGJlaGFsZiBvZiB0aGUgSW5pdGlhbCBEZXZlbG9wZXIgb3IgYW55IENvbnRyaWJ1dG9yLiBZb3UKICAgICAgICAgICAgbXVzdCBtYWtlIGl0IGFic29sdXRlbHkgY2xlYXIgdGhhdCBhbnkgc3VjaCB3YXJyYW50eSwKICAgICAgICAgICAgc3VwcG9ydCwgaW5kZW1uaXR5IG9yIGxpYWJpbGl0eSBvYmxpZ2F0aW9uIGlzIG9mZmVyZWQgYnkKICAgICAgICAgICAgWW91IGFsb25lLCBhbmQgWW91IGhlcmVieSBhZ3JlZSB0byBpbmRlbW5pZnkgdGhlIEluaXRpYWwKICAgICAgICAgICAgRGV2ZWxvcGVyIGFuZCBldmVyeSBDb250cmlidXRvciBmb3IgYW55IGxpYWJpbGl0eSBpbmN1cnJlZAogICAgICAgICAgICBieSB0aGUgSW5pdGlhbCBEZXZlbG9wZXIgb3Igc3VjaCBDb250cmlidXRvciBhcyBhIHJlc3VsdCBvZgogICAgICAgICAgICB3YXJyYW50eSwgc3VwcG9ydCwgaW5kZW1uaXR5IG9yIGxpYWJpbGl0eSB0ZXJtcyBZb3Ugb2ZmZXIuCiAgICAgICAgICAKCiAgICAgICAgICAgIDMuNS4gRGlzdHJpYnV0aW9uIG9mIEV4ZWN1dGFibGUgVmVyc2lvbnMuCgogICAgICAgICAgICBZb3UgbWF5IGRpc3RyaWJ1dGUgdGhlIEV4ZWN1dGFibGUgZm9ybSBvZiB0aGUgQ292ZXJlZAogICAgICAgICAgICBTb2Z0d2FyZSB1bmRlciB0aGUgdGVybXMgb2YgdGhpcyBMaWNlbnNlIG9yIHVuZGVyIHRoZSB0ZXJtcwogICAgICAgICAgICBvZiBhIGxpY2Vuc2Ugb2YgWW91ciBjaG9pY2UsIHdoaWNoIG1heSBjb250YWluIHRlcm1zCiAgICAgICAgICAgIGRpZmZlcmVudCBmcm9tIHRoaXMgTGljZW5zZSwgcHJvdmlkZWQgdGhhdCBZb3UgYXJlIGluCiAgICAgICAgICAgIGNvbXBsaWFuY2Ugd2l0aCB0aGUgdGVybXMgb2YgdGhpcyBMaWNlbnNlIGFuZCB0aGF0IHRoZQogICAgICAgICAgICBsaWNlbnNlIGZvciB0aGUgRXhlY3V0YWJsZSBmb3JtIGRvZXMgbm90IGF0dGVtcHQgdG8gbGltaXQKICAgICAgICAgICAgb3IgYWx0ZXIgdGhlIHJlY2lwaWVudCdzIHJpZ2h0cyBpbiB0aGUgU291cmNlIENvZGUgZm9ybQogICAgICAgICAgICBmcm9tIHRoZSByaWdodHMgc2V0IGZvcnRoIGluIHRoaXMgTGljZW5zZS4gSWYgWW91CiAgICAgICAgICAgIGRpc3RyaWJ1dGUgdGhlIENvdmVyZWQgU29mdHdhcmUgaW4gRXhlY3V0YWJsZSBmb3JtIHVuZGVyIGEKICAgICAgICAgICAgZGlmZmVyZW50IGxpY2Vuc2UsIFlvdSBtdXN0IG1ha2UgaXQgYWJzb2x1dGVseSBjbGVhciB0aGF0CiAgICAgICAgICAgIGFueSB0ZXJtcyB3aGljaCBkaWZmZXIgZnJvbSB0aGlzIExpY2Vuc2UgYXJlIG9mZmVyZWQgYnkgWW91CiAgICAgICAgICAgIGFsb25lLCBub3QgYnkgdGhlIEluaXRpYWwgRGV2ZWxvcGVyIG9yIENvbnRyaWJ1dG9yLiBZb3UKICAgICAgICAgICAgaGVyZWJ5IGFncmVlIHRvIGluZGVtbmlmeSB0aGUgSW5pdGlhbCBEZXZlbG9wZXIgYW5kIGV2ZXJ5CiAgICAgICAgICAgIENvbnRyaWJ1dG9yIGZvciBhbnkgbGlhYmlsaXR5IGluY3VycmVkIGJ5IHRoZSBJbml0aWFsCiAgICAgICAgICAgIERldmVsb3BlciBvciBzdWNoIENvbnRyaWJ1dG9yIGFzIGEgcmVzdWx0IG9mIGFueSBzdWNoIHRlcm1zCiAgICAgICAgICAgIFlvdSBvZmZlci4KCiAgICAgICAgICAgIDMuNi4gTGFyZ2VyIFdvcmtzLgoKICAgICAgICAgICAgWW91IG1heSBjcmVhdGUgYSBMYXJnZXIgV29yayBieSBjb21iaW5pbmcgQ292ZXJlZCBTb2Z0d2FyZQogICAgICAgICAgICB3aXRoIG90aGVyIGNvZGUgbm90IGdvdmVybmVkIGJ5IHRoZSB0ZXJtcyBvZiB0aGlzIExpY2Vuc2UKICAgICAgICAgICAgYW5kIGRpc3RyaWJ1dGUgdGhlIExhcmdlciBXb3JrIGFzIGEgc2luZ2xlIHByb2R1Y3QuIEluIHN1Y2gKICAgICAgICAgICAgYSBjYXNlLCBZb3UgbXVzdCBtYWtlIHN1cmUgdGhlIHJlcXVpcmVtZW50cyBvZiB0aGlzIExpY2Vuc2UKICAgICAgICAgICAgYXJlIGZ1bGZpbGxlZCBmb3IgdGhlIENvdmVyZWQgU29mdHdhcmUuIAogICAgICAgICAgICAKICAgICAgNC4gVmVyc2lvbnMgb2YgdGhlIExpY2Vuc2UuIAoKICAgICAgICAgICAgNC4xLiBOZXcgVmVyc2lvbnMuCgogICAgICAgICAgICBTdW4gTWljcm9zeXN0ZW1zLCBJbmMuIGlzIHRoZSBpbml0aWFsIGxpY2Vuc2Ugc3Rld2FyZCBhbmQKICAgICAgICAgICAgbWF5IHB1Ymxpc2ggcmV2aXNlZCBhbmQvb3IgbmV3IHZlcnNpb25zIG9mIHRoaXMgTGljZW5zZQogICAgICAgICAgICBmcm9tIHRpbWUgdG8gdGltZS4gRWFjaCB2ZXJzaW9uIHdpbGwgYmUgZ2l2ZW4gYQogICAgICAgICAgICBkaXN0aW5ndWlzaGluZyB2ZXJzaW9uIG51bWJlci4gRXhjZXB0IGFzIHByb3ZpZGVkIGluCiAgICAgICAgICAgIFNlY3Rpb24gNC4zLCBubyBvbmUgb3RoZXIgdGhhbiB0aGUgbGljZW5zZSBzdGV3YXJkIGhhcyB0aGUKICAgICAgICAgICAgcmlnaHQgdG8gbW9kaWZ5IHRoaXMgTGljZW5zZS4gCgogICAgICAgICAgICA0LjIuIEVmZmVjdCBvZiBOZXcgVmVyc2lvbnMuCgogICAgICAgICAgICBZb3UgbWF5IGFsd2F5cyBjb250aW51ZSB0byB1c2UsIGRpc3RyaWJ1dGUgb3Igb3RoZXJ3aXNlCiAgICAgICAgICAgIG1ha2UgdGhlIENvdmVyZWQgU29mdHdhcmUgYXZhaWxhYmxlIHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUKICAgICAgICAgICAgdmVyc2lvbiBvZiB0aGUgTGljZW5zZSB1bmRlciB3aGljaCBZb3Ugb3JpZ2luYWxseSByZWNlaXZlZAogICAgICAgICAgICB0aGUgQ292ZXJlZCBTb2Z0d2FyZS4gSWYgdGhlIEluaXRpYWwgRGV2ZWxvcGVyIGluY2x1ZGVzIGEKICAgICAgICAgICAgbm90aWNlIGluIHRoZSBPcmlnaW5hbCBTb2Z0d2FyZSBwcm9oaWJpdGluZyBpdCBmcm9tIGJlaW5nCiAgICAgICAgICAgIGRpc3RyaWJ1dGVkIG9yIG90aGVyd2lzZSBtYWRlIGF2YWlsYWJsZSB1bmRlciBhbnkKICAgICAgICAgICAgc3Vic2VxdWVudCB2ZXJzaW9uIG9mIHRoZSBMaWNlbnNlLCBZb3UgbXVzdCBkaXN0cmlidXRlIGFuZAogICAgICAgICAgICBtYWtlIHRoZSBDb3ZlcmVkIFNvZnR3YXJlIGF2YWlsYWJsZSB1bmRlciB0aGUgdGVybXMgb2YgdGhlCiAgICAgICAgICAgIHZlcnNpb24gb2YgdGhlIExpY2Vuc2UgdW5kZXIgd2hpY2ggWW91IG9yaWdpbmFsbHkgcmVjZWl2ZWQKICAgICAgICAgICAgdGhlIENvdmVyZWQgU29mdHdhcmUuIE90aGVyd2lzZSwgWW91IG1heSBhbHNvIGNob29zZSB0bwogICAgICAgICAgICB1c2UsIGRpc3RyaWJ1dGUgb3Igb3RoZXJ3aXNlIG1ha2UgdGhlIENvdmVyZWQgU29mdHdhcmUKICAgICAgICAgICAgYXZhaWxhYmxlIHVuZGVyIHRoZSB0ZXJtcyBvZiBhbnkgc3Vic2VxdWVudCB2ZXJzaW9uIG9mIHRoZQogICAgICAgICAgICBMaWNlbnNlIHB1Ymxpc2hlZCBieSB0aGUgbGljZW5zZSBzdGV3YXJkLiAKCiAgICAgICAgICAgIDQuMy4gTW9kaWZpZWQgVmVyc2lvbnMuCgogICAgICAgICAgICBXaGVuIFlvdSBhcmUgYW4gSW5pdGlhbCBEZXZlbG9wZXIgYW5kIFlvdSB3YW50IHRvIGNyZWF0ZSBhCiAgICAgICAgICAgIG5ldyBsaWNlbnNlIGZvciBZb3VyIE9yaWdpbmFsIFNvZnR3YXJlLCBZb3UgbWF5IGNyZWF0ZSBhbmQKICAgICAgICAgICAgdXNlIGEgbW9kaWZpZWQgdmVyc2lvbiBvZiB0aGlzIExpY2Vuc2UgaWYgWW91OiAoYSkgcmVuYW1lCiAgICAgICAgICAgIHRoZSBsaWNlbnNlIGFuZCByZW1vdmUgYW55IHJlZmVyZW5jZXMgdG8gdGhlIG5hbWUgb2YgdGhlCiAgICAgICAgICAgIGxpY2Vuc2Ugc3Rld2FyZCAoZXhjZXB0IHRvIG5vdGUgdGhhdCB0aGUgbGljZW5zZSBkaWZmZXJzCiAgICAgICAgICAgIGZyb20gdGhpcyBMaWNlbnNlKTsgYW5kIChiKSBvdGhlcndpc2UgbWFrZSBpdCBjbGVhciB0aGF0CiAgICAgICAgICAgIHRoZSBsaWNlbnNlIGNvbnRhaW5zIHRlcm1zIHdoaWNoIGRpZmZlciBmcm9tIHRoaXMgTGljZW5zZS4KICAgICAgICAgICAgCgogICAgICA1LiBESVNDTEFJTUVSIE9GIFdBUlJBTlRZLgoKICAgICAgQ09WRVJFRCBTT0ZUV0FSRSBJUyBQUk9WSURFRCBVTkRFUiBUSElTIExJQ0VOU0UgT04gQU4gIkFTIElTIgogICAgICBCQVNJUywgV0lUSE9VVCBXQVJSQU5UWSBPRiBBTlkgS0lORCwgRUlUSEVSIEVYUFJFU1NFRCBPUiBJTVBMSUVELAogICAgICBJTkNMVURJTkcsIFdJVEhPVVQgTElNSVRBVElPTiwgV0FSUkFOVElFUyBUSEFUIFRIRSBDT1ZFUkVECiAgICAgIFNPRlRXQVJFIElTIEZSRUUgT0YgREVGRUNUUywgTUVSQ0hBTlRBQkxFLCBGSVQgRk9SIEEgUEFSVElDVUxBUgogICAgICBQVVJQT1NFIE9SIE5PTi1JTkZSSU5HSU5HLiBUSEUgRU5USVJFIFJJU0sgQVMgVE8gVEhFIFFVQUxJVFkgQU5ECiAgICAgIFBFUkZPUk1BTkNFIE9GIFRIRSBDT1ZFUkVEIFNPRlRXQVJFIElTIFdJVEggWU9VLiBTSE9VTEQgQU5ZCiAgICAgIENPVkVSRUQgU09GVFdBUkUgUFJPVkUgREVGRUNUSVZFIElOIEFOWSBSRVNQRUNULCBZT1UgKE5PVCBUSEUKICAgICAgSU5JVElBTCBERVZFTE9QRVIgT1IgQU5ZIE9USEVSIENPTlRSSUJVVE9SKSBBU1NVTUUgVEhFIENPU1QgT0YKICAgICAgQU5ZIE5FQ0VTU0FSWSBTRVJWSUNJTkcsIFJFUEFJUiBPUiBDT1JSRUNUSU9OLiBUSElTIERJU0NMQUlNRVIgT0YKICAgICAgV0FSUkFOVFkgQ09OU1RJVFVURVMgQU4gRVNTRU5USUFMIFBBUlQgT0YgVEhJUyBMSUNFTlNFLiBOTyBVU0UgT0YKICAgICAgQU5ZIENPVkVSRUQgU09GVFdBUkUgSVMgQVVUSE9SSVpFRCBIRVJFVU5ERVIgRVhDRVBUIFVOREVSIFRISVMKICAgICAgRElTQ0xBSU1FUi4gCgogICAgICA2LiBURVJNSU5BVElPTi4gCgogICAgICAgICAgICA2LjEuIFRoaXMgTGljZW5zZSBhbmQgdGhlIHJpZ2h0cyBncmFudGVkIGhlcmV1bmRlciB3aWxsCiAgICAgICAgICAgIHRlcm1pbmF0ZSBhdXRvbWF0aWNhbGx5IGlmIFlvdSBmYWlsIHRvIGNvbXBseSB3aXRoIHRlcm1zCiAgICAgICAgICAgIGhlcmVpbiBhbmQgZmFpbCB0byBjdXJlIHN1Y2ggYnJlYWNoIHdpdGhpbiAzMCBkYXlzIG9mCiAgICAgICAgICAgIGJlY29taW5nIGF3YXJlIG9mIHRoZSBicmVhY2guIFByb3Zpc2lvbnMgd2hpY2gsIGJ5IHRoZWlyCiAgICAgICAgICAgIG5hdHVyZSwgbXVzdCByZW1haW4gaW4gZWZmZWN0IGJleW9uZCB0aGUgdGVybWluYXRpb24gb2YKICAgICAgICAgICAgdGhpcyBMaWNlbnNlIHNoYWxsIHN1cnZpdmUuCgogICAgICAgICAgICA2LjIuIElmIFlvdSBhc3NlcnQgYSBwYXRlbnQgaW5mcmluZ2VtZW50IGNsYWltIChleGNsdWRpbmcKICAgICAgICAgICAgZGVjbGFyYXRvcnkganVkZ21lbnQgYWN0aW9ucykgYWdhaW5zdCBJbml0aWFsIERldmVsb3BlciBvcgogICAgICAgICAgICBhIENvbnRyaWJ1dG9yICh0aGUgSW5pdGlhbCBEZXZlbG9wZXIgb3IgQ29udHJpYnV0b3IgYWdhaW5zdAogICAgICAgICAgICB3aG9tIFlvdSBhc3NlcnQgc3VjaCBjbGFpbSBpcyByZWZlcnJlZCB0byBhcyAiUGFydGljaXBhbnQiKQogICAgICAgICAgICBhbGxlZ2luZyB0aGF0IHRoZSBQYXJ0aWNpcGFudCBTb2Z0d2FyZSAobWVhbmluZyB0aGUKICAgICAgICAgICAgQ29udHJpYnV0b3IgVmVyc2lvbiB3aGVyZSB0aGUgUGFydGljaXBhbnQgaXMgYSBDb250cmlidXRvcgogICAgICAgICAgICBvciB0aGUgT3JpZ2luYWwgU29mdHdhcmUgd2hlcmUgdGhlIFBhcnRpY2lwYW50IGlzIHRoZQogICAgICAgICAgICBJbml0aWFsIERldmVsb3BlcikgZGlyZWN0bHkgb3IgaW5kaXJlY3RseSBpbmZyaW5nZXMgYW55CiAgICAgICAgICAgIHBhdGVudCwgdGhlbiBhbnkgYW5kIGFsbCByaWdodHMgZ3JhbnRlZCBkaXJlY3RseSBvcgogICAgICAgICAgICBpbmRpcmVjdGx5IHRvIFlvdSBieSBzdWNoIFBhcnRpY2lwYW50LCB0aGUgSW5pdGlhbAogICAgICAgICAgICBEZXZlbG9wZXIgKGlmIHRoZSBJbml0aWFsIERldmVsb3BlciBpcyBub3QgdGhlIFBhcnRpY2lwYW50KQogICAgICAgICAgICBhbmQgYWxsIENvbnRyaWJ1dG9ycyB1bmRlciBTZWN0aW9ucyAyLjEgYW5kL29yIDIuMiBvZiB0aGlzCiAgICAgICAgICAgIExpY2Vuc2Ugc2hhbGwsIHVwb24gNjAgZGF5cyBub3RpY2UgZnJvbSBQYXJ0aWNpcGFudAogICAgICAgICAgICB0ZXJtaW5hdGUgcHJvc3BlY3RpdmVseSBhbmQgYXV0b21hdGljYWxseSBhdCB0aGUgZXhwaXJhdGlvbgogICAgICAgICAgICBvZiBzdWNoIDYwIGRheSBub3RpY2UgcGVyaW9kLCB1bmxlc3MgaWYgd2l0aGluIHN1Y2ggNjAgZGF5CiAgICAgICAgICAgIHBlcmlvZCBZb3Ugd2l0aGRyYXcgWW91ciBjbGFpbSB3aXRoIHJlc3BlY3QgdG8gdGhlCiAgICAgICAgICAgIFBhcnRpY2lwYW50IFNvZnR3YXJlIGFnYWluc3Qgc3VjaCBQYXJ0aWNpcGFudCBlaXRoZXIKICAgICAgICAgICAgdW5pbGF0ZXJhbGx5IG9yIHB1cnN1YW50IHRvIGEgd3JpdHRlbiBhZ3JlZW1lbnQgd2l0aAogICAgICAgICAgICBQYXJ0aWNpcGFudC4KCiAgICAgICAgICAgIDYuMy4gSW4gdGhlIGV2ZW50IG9mIHRlcm1pbmF0aW9uIHVuZGVyIFNlY3Rpb25zIDYuMSBvciA2LjIKICAgICAgICAgICAgYWJvdmUsIGFsbCBlbmQgdXNlciBsaWNlbnNlcyB0aGF0IGhhdmUgYmVlbiB2YWxpZGx5IGdyYW50ZWQKICAgICAgICAgICAgYnkgWW91IG9yIGFueSBkaXN0cmlidXRvciBoZXJldW5kZXIgcHJpb3IgdG8gdGVybWluYXRpb24KICAgICAgICAgICAgKGV4Y2x1ZGluZyBsaWNlbnNlcyBncmFudGVkIHRvIFlvdSBieSBhbnkgZGlzdHJpYnV0b3IpCiAgICAgICAgICAgIHNoYWxsIHN1cnZpdmUgdGVybWluYXRpb24uCgogICAgICA3LiBMSU1JVEFUSU9OIE9GIExJQUJJTElUWS4KCiAgICAgIFVOREVSIE5PIENJUkNVTVNUQU5DRVMgQU5EIFVOREVSIE5PIExFR0FMIFRIRU9SWSwgV0hFVEhFUiBUT1JUCiAgICAgIChJTkNMVURJTkcgTkVHTElHRU5DRSksIENPTlRSQUNULCBPUiBPVEhFUldJU0UsIFNIQUxMIFlPVSwgVEhFCiAgICAgIElOSVRJQUwgREVWRUxPUEVSLCBBTlkgT1RIRVIgQ09OVFJJQlVUT1IsIE9SIEFOWSBESVNUUklCVVRPUiBPRgogICAgICBDT1ZFUkVEIFNPRlRXQVJFLCBPUiBBTlkgU1VQUExJRVIgT0YgQU5ZIE9GIFNVQ0ggUEFSVElFUywgQkUKICAgICAgTElBQkxFIFRPIEFOWSBQRVJTT04gRk9SIEFOWSBJTkRJUkVDVCwgU1BFQ0lBTCwgSU5DSURFTlRBTCwgT1IKICAgICAgQ09OU0VRVUVOVElBTCBEQU1BR0VTIE9GIEFOWSBDSEFSQUNURVIgSU5DTFVESU5HLCBXSVRIT1VUCiAgICAgIExJTUlUQVRJT04sIERBTUFHRVMgRk9SIExPU1QgUFJPRklUUywgTE9TUyBPRiBHT09EV0lMTCwgV09SSwogICAgICBTVE9QUEFHRSwgQ09NUFVURVIgRkFJTFVSRSBPUiBNQUxGVU5DVElPTiwgT1IgQU5ZIEFORCBBTEwgT1RIRVIKICAgICAgQ09NTUVSQ0lBTCBEQU1BR0VTIE9SIExPU1NFUywgRVZFTiBJRiBTVUNIIFBBUlRZIFNIQUxMIEhBVkUgQkVFTgogICAgICBJTkZPUk1FRCBPRiBUSEUgUE9TU0lCSUxJVFkgT0YgU1VDSCBEQU1BR0VTLiBUSElTIExJTUlUQVRJT04gT0YKICAgICAgTElBQklMSVRZIFNIQUxMIE5PVCBBUFBMWSBUTyBMSUFCSUxJVFkgRk9SIERFQVRIIE9SIFBFUlNPTkFMCiAgICAgIElOSlVSWSBSRVNVTFRJTkcgRlJPTSBTVUNIIFBBUlRZJ1MgTkVHTElHRU5DRSBUTyBUSEUgRVhURU5UCiAgICAgIEFQUExJQ0FCTEUgTEFXIFBST0hJQklUUyBTVUNIIExJTUlUQVRJT04uIFNPTUUgSlVSSVNESUNUSU9OUyBETwogICAgICBOT1QgQUxMT1cgVEhFIEVYQ0xVU0lPTiBPUiBMSU1JVEFUSU9OIE9GIElOQ0lERU5UQUwgT1IKICAgICAgQ09OU0VRVUVOVElBTCBEQU1BR0VTLCBTTyBUSElTIEVYQ0xVU0lPTiBBTkQgTElNSVRBVElPTiBNQVkgTk9UCiAgICAgIEFQUExZIFRPIFlPVS4KCiAgICAgIDguIFUuUy4gR09WRVJOTUVOVCBFTkQgVVNFUlMuCgogICAgICBUaGUgQ292ZXJlZCBTb2Z0d2FyZSBpcyBhICJjb21tZXJjaWFsIGl0ZW0sIiBhcyB0aGF0IHRlcm0gaXMKICAgICAgZGVmaW5lZCBpbiA0OCBDLkYuUi4gMi4xMDEgKE9jdC4gMTk5NSksIGNvbnNpc3Rpbmcgb2YgImNvbW1lcmNpYWwKICAgICAgY29tcHV0ZXIgc29mdHdhcmUiIChhcyB0aGF0IHRlcm0gaXMgZGVmaW5lZCBhdCA0OCBDLkYuUi4gCiAgICAgIDI1Mi4yMjctNzAxNChhKSgxKSkgYW5kICJjb21tZXJjaWFsIGNvbXB1dGVyIHNvZnR3YXJlCiAgICAgIGRvY3VtZW50YXRpb24iIGFzIHN1Y2ggdGVybXMgYXJlIHVzZWQgaW4gNDggQy5GLlIuIDEyLjIxMiAoU2VwdC4KICAgICAgMTk5NSkuIENvbnNpc3RlbnQgd2l0aCA0OCBDLkYuUi4gMTIuMjEyIGFuZCA0OCBDLkYuUi4gMjI3LjcyMDItMQogICAgICB0aHJvdWdoIDIyNy43MjAyLTQgKEp1bmUgMTk5NSksIGFsbCBVLlMuIEdvdmVybm1lbnQgRW5kIFVzZXJzCiAgICAgIGFjcXVpcmUgQ292ZXJlZCBTb2Z0d2FyZSB3aXRoIG9ubHkgdGhvc2UgcmlnaHRzIHNldCBmb3J0aCBoZXJlaW4uCiAgICAgIFRoaXMgVS5TLiBHb3Zlcm5tZW50IFJpZ2h0cyBjbGF1c2UgaXMgaW4gbGlldSBvZiwgYW5kIHN1cGVyc2VkZXMsCiAgICAgIGFueSBvdGhlciBGQVIsIERGQVIsIG9yIG90aGVyIGNsYXVzZSBvciBwcm92aXNpb24gdGhhdCBhZGRyZXNzZXMKICAgICAgR292ZXJubWVudCByaWdodHMgaW4gY29tcHV0ZXIgc29mdHdhcmUgdW5kZXIgdGhpcyBMaWNlbnNlLgoKICAgICAgOS4gTUlTQ0VMTEFORU9VUy4KCiAgICAgIFRoaXMgTGljZW5zZSByZXByZXNlbnRzIHRoZSBjb21wbGV0ZSBhZ3JlZW1lbnQgY29uY2VybmluZyBzdWJqZWN0CiAgICAgIG1hdHRlciBoZXJlb2YuIElmIGFueSBwcm92aXNpb24gb2YgdGhpcyBMaWNlbnNlIGlzIGhlbGQgdG8gYmUKICAgICAgdW5lbmZvcmNlYWJsZSwgc3VjaCBwcm92aXNpb24gc2hhbGwgYmUgcmVmb3JtZWQgb25seSB0byB0aGUKICAgICAgZXh0ZW50IG5lY2Vzc2FyeSB0byBtYWtlIGl0IGVuZm9yY2VhYmxlLiBUaGlzIExpY2Vuc2Ugc2hhbGwgYmUKICAgICAgZ292ZXJuZWQgYnkgdGhlIGxhdyBvZiB0aGUganVyaXNkaWN0aW9uIHNwZWNpZmllZCBpbiBhIG5vdGljZQogICAgICBjb250YWluZWQgd2l0aGluIHRoZSBPcmlnaW5hbCBTb2Z0d2FyZSAoZXhjZXB0IHRvIHRoZSBleHRlbnQKICAgICAgYXBwbGljYWJsZSBsYXcsIGlmIGFueSwgcHJvdmlkZXMgb3RoZXJ3aXNlKSwgZXhjbHVkaW5nIHN1Y2gKICAgICAganVyaXNkaWN0aW9uJ3MgY29uZmxpY3Qtb2YtbGF3IHByb3Zpc2lvbnMuIEFueSBsaXRpZ2F0aW9uCiAgICAgIHJlbGF0aW5nIHRvIHRoaXMgTGljZW5zZSBzaGFsbCBiZSBzdWJqZWN0IHRvIHRoZSBqdXJpc2RpY3Rpb24gb2YKICAgICAgdGhlIGNvdXJ0cyBsb2NhdGVkIGluIHRoZSBqdXJpc2RpY3Rpb24gYW5kIHZlbnVlIHNwZWNpZmllZCBpbiBhCiAgICAgIG5vdGljZSBjb250YWluZWQgd2l0aGluIHRoZSBPcmlnaW5hbCBTb2Z0d2FyZSwgd2l0aCB0aGUgbG9zaW5nCiAgICAgIHBhcnR5IHJlc3BvbnNpYmxlIGZvciBjb3N0cywgaW5jbHVkaW5nLCB3aXRob3V0IGxpbWl0YXRpb24sIGNvdXJ0CiAgICAgIGNvc3RzIGFuZCByZWFzb25hYmxlIGF0dG9ybmV5cycgZmVlcyBhbmQgZXhwZW5zZXMuIFRoZQogICAgICBhcHBsaWNhdGlvbiBvZiB0aGUgVW5pdGVkIE5hdGlvbnMgQ29udmVudGlvbiBvbiBDb250cmFjdHMgZm9yIHRoZQogICAgICBJbnRlcm5hdGlvbmFsIFNhbGUgb2YgR29vZHMgaXMgZXhwcmVzc2x5IGV4Y2x1ZGVkLiBBbnkgbGF3IG9yCiAgICAgIHJlZ3VsYXRpb24gd2hpY2ggcHJvdmlkZXMgdGhhdCB0aGUgbGFuZ3VhZ2Ugb2YgYSBjb250cmFjdCBzaGFsbAogICAgICBiZSBjb25zdHJ1ZWQgYWdhaW5zdCB0aGUgZHJhZnRlciBzaGFsbCBub3QgYXBwbHkgdG8gdGhpcyBMaWNlbnNlLgogICAgICBZb3UgYWdyZWUgdGhhdCBZb3UgYWxvbmUgYXJlIHJlc3BvbnNpYmxlIGZvciBjb21wbGlhbmNlIHdpdGggdGhlCiAgICAgIFVuaXRlZCBTdGF0ZXMgZXhwb3J0IGFkbWluaXN0cmF0aW9uIHJlZ3VsYXRpb25zIChhbmQgdGhlIGV4cG9ydAogICAgICBjb250cm9sIGxhd3MgYW5kIHJlZ3VsYXRpb24gb2YgYW55IG90aGVyIGNvdW50cmllcykgd2hlbiBZb3UgdXNlLAogICAgICBkaXN0cmlidXRlIG9yIG90aGVyd2lzZSBtYWtlIGF2YWlsYWJsZSBhbnkgQ292ZXJlZCBTb2Z0d2FyZS4KCiAgICAgIDEwLiBSRVNQT05TSUJJTElUWSBGT1IgQ0xBSU1TLgoKICAgICAgQXMgYmV0d2VlbiBJbml0aWFsIERldmVsb3BlciBhbmQgdGhlIENvbnRyaWJ1dG9ycywgZWFjaCBwYXJ0eSBpcwogICAgICByZXNwb25zaWJsZSBmb3IgY2xhaW1zIGFuZCBkYW1hZ2VzIGFyaXNpbmcsIGRpcmVjdGx5IG9yCiAgICAgIGluZGlyZWN0bHksIG91dCBvZiBpdHMgdXRpbGl6YXRpb24gb2YgcmlnaHRzIHVuZGVyIHRoaXMgTGljZW5zZQogICAgICBhbmQgWW91IGFncmVlIHRvIHdvcmsgd2l0aCBJbml0aWFsIERldmVsb3BlciBhbmQgQ29udHJpYnV0b3JzIHRvCiAgICAgIGRpc3RyaWJ1dGUgc3VjaCByZXNwb25zaWJpbGl0eSBvbiBhbiBlcXVpdGFibGUgYmFzaXMuIE5vdGhpbmcKICAgICAgaGVyZWluIGlzIGludGVuZGVkIG9yIHNoYWxsIGJlIGRlZW1lZCB0byBjb25zdGl0dXRlIGFueSBhZG1pc3Npb24KICAgICAgb2YgbGlhYmlsaXR5LgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCmRvam90b29sa2l0IFYxLjQuMjoKClRoZSAiTmV3IiBCU0QgTGljZW5zZToKKioqKioqKioqKioqKioqKioqKioqKgoKQ29weXJpZ2h0IChjKSAyMDA1LCBUaGUgRG9qbyBGb3VuZGF0aW9uCkFsbCByaWdodHMgcmVzZXJ2ZWQuCgpSZWRpc3RyaWJ1dGlvbiBhbmQgdXNlIGluIHNvdXJjZSBhbmQgYmluYXJ5IGZvcm1zLCB3aXRoIG9yIHdpdGhvdXQKbW9kaWZpY2F0aW9uLCBhcmUgcGVybWl0dGVkIHByb3ZpZGVkIHRoYXQgdGhlIGZvbGxvd2luZyBjb25kaXRpb25zIGFyZSBtZXQ6CgogICogUmVkaXN0cmlidXRpb25zIG9mIHNvdXJjZSBjb2RlIG11c3QgcmV0YWluIHRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlLCB0aGlzCglsaXN0IG9mIGNvbmRpdGlvbnMgYW5kIHRoZSBmb2xsb3dpbmcgZGlzY2xhaW1lci4KICAqIFJlZGlzdHJpYnV0aW9ucyBpbiBiaW5hcnkgZm9ybSBtdXN0IHJlcHJvZHVjZSB0aGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSwKCXRoaXMgbGlzdCBvZiBjb25kaXRpb25zIGFuZCB0aGUgZm9sbG93aW5nIGRpc2NsYWltZXIgaW4gdGhlIGRvY3VtZW50YXRpb24KCWFuZC9vciBvdGhlciBtYXRlcmlhbHMgcHJvdmlkZWQgd2l0aCB0aGUgZGlzdHJpYnV0aW9uLgogICogTmVpdGhlciB0aGUgbmFtZSBvZiB0aGUgRG9qbyBGb3VuZGF0aW9uIG5vciB0aGUgbmFtZXMgb2YgaXRzIGNvbnRyaWJ1dG9ycwoJbWF5IGJlIHVzZWQgdG8gZW5kb3JzZSBvciBwcm9tb3RlIHByb2R1Y3RzIGRlcml2ZWQgZnJvbSB0aGlzIHNvZnR3YXJlCgl3aXRob3V0IHNwZWNpZmljIHByaW9yIHdyaXR0ZW4gcGVybWlzc2lvbi4KClRISVMgU09GVFdBUkUgSVMgUFJPVklERUQgQlkgVEhFIENPUFlSSUdIVCBIT0xERVJTIEFORCBDT05UUklCVVRPUlMgIkFTIElTIiBBTkQKQU5ZIEVYUFJFU1MgT1IgSU1QTElFRCBXQVJSQU5USUVTLCBJTkNMVURJTkcsIEJVVCBOT1QgTElNSVRFRCBUTywgVEhFIElNUExJRUQKV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFkgQU5EIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFSRQpESVNDTEFJTUVELiAgSU4gTk8gRVZFTlQgU0hBTEwgVEhFIENPUFlSSUdIVCBPV05FUiBPUiBDT05UUklCVVRPUlMgQkUgTElBQkxFCkZPUiBBTlkgRElSRUNULCBJTkRJUkVDVCwgSU5DSURFTlRBTCwgU1BFQ0lBTCwgRVhFTVBMQVJZLCBPUiBDT05TRVFVRU5USUFMCkRBTUFHRVMgKElOQ0xVRElORywgQlVUIE5PVCBMSU1JVEVEIFRPLCBQUk9DVVJFTUVOVCBPRiBTVUJTVElUVVRFIEdPT0RTIE9SClNFUlZJQ0VTOyBMT1NTIE9GIFVTRSwgREFUQSwgT1IgUFJPRklUUzsgT1IgQlVTSU5FU1MgSU5URVJSVVBUSU9OKSBIT1dFVkVSCkNBVVNFRCBBTkQgT04gQU5ZIFRIRU9SWSBPRiBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQ09OVFJBQ1QsIFNUUklDVCBMSUFCSUxJVFksCk9SIFRPUlQgKElOQ0xVRElORyBORUdMSUdFTkNFIE9SIE9USEVSV0lTRSkgQVJJU0lORyBJTiBBTlkgV0FZIE9VVCBPRiBUSEUgVVNFCk9GIFRISVMgU09GVFdBUkUsIEVWRU4gSUYgQURWSVNFRCBPRiBUSEUgUE9TU0lCSUxJVFkgT0YgU1VDSCBEQU1BR0UuCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQpwZGZib3gtMC43LjMuamFyCgpDb3B5cmlnaHQgKGMpIDIwMDMsIHd3dy5wZGZib3gub3JnCkFsbCByaWdodHMgcmVzZXJ2ZWQuCgpSZWRpc3RyaWJ1dGlvbiBhbmQgdXNlIGluIHNvdXJjZSBhbmQgYmluYXJ5IGZvcm1zLCB3aXRoIG9yIHdpdGhvdXQKbW9kaWZpY2F0aW9uLCBhcmUgcGVybWl0dGVkIHByb3ZpZGVkIHRoYXQgdGhlIGZvbGxvd2luZyBjb25kaXRpb25zIGFyZSBtZXQ6CgoxLiBSZWRpc3RyaWJ1dGlvbnMgb2Ygc291cmNlIGNvZGUgbXVzdCByZXRhaW4gdGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UsCiAgIHRoaXMgbGlzdCBvZiBjb25kaXRpb25zIGFuZCB0aGUgZm9sbG93aW5nIGRpc2NsYWltZXIuCjIuIFJlZGlzdHJpYnV0aW9ucyBpbiBiaW5hcnkgZm9ybSBtdXN0IHJlcHJvZHVjZSB0aGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSwKICAgdGhpcyBsaXN0IG9mIGNvbmRpdGlvbnMgYW5kIHRoZSBmb2xsb3dpbmcgZGlzY2xhaW1lciBpbiB0aGUgZG9jdW1lbnRhdGlvbgogICBhbmQvb3Igb3RoZXIgbWF0ZXJpYWxzIHByb3ZpZGVkIHdpdGggdGhlIGRpc3RyaWJ1dGlvbi4KMy4gTmVpdGhlciB0aGUgbmFtZSBvZiBwZGZib3g7IG5vciB0aGUgbmFtZXMgb2YgaXRzCiAgIGNvbnRyaWJ1dG9ycyBtYXkgYmUgdXNlZCB0byBlbmRvcnNlIG9yIHByb21vdGUgcHJvZHVjdHMgZGVyaXZlZCBmcm9tIHRoaXMKICAgc29mdHdhcmUgd2l0aG91dCBzcGVjaWZpYyBwcmlvciB3cml0dGVuIHBlcm1pc3Npb24uCgpUSElTIFNPRlRXQVJFIElTIFBST1ZJREVEIEJZIFRIRSBDT1BZUklHSFQgSE9MREVSUyBBTkQgQ09OVFJJQlVUT1JTICJBUyBJUyIKQU5EIEFOWSBFWFBSRVNTIE9SIElNUExJRUQgV0FSUkFOVElFUywgSU5DTFVESU5HLCBCVVQgTk9UIExJTUlURUQgVE8sIFRIRQpJTVBMSUVEIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZIEFORCBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSBBUkUKRElTQ0xBSU1FRC4gIElOIE5PIEVWRU5UIFNIQUxMIFRIRSBSRUdFTlRTIE9SIENPTlRSSUJVVE9SUyBCRSBMSUFCTEUgRk9SIEFOWQpESVJFQ1QsIElORElSRUNULCBJTkNJREVOVEFMLCBTUEVDSUFMLCBFWEVNUExBUlksIE9SIENPTlNFUVVFTlRJQUwgREFNQUdFUwooSU5DTFVESU5HLCBCVVQgTk9UIExJTUlURUQgVE8sIFBST0NVUkVNRU5UIE9GIFNVQlNUSVRVVEUgR09PRFMgT1IgU0VSVklDRVM7CkxPU1MgT0YgVVNFLCBEQVRBLCBPUiBQUk9GSVRTOyBPUiBCVVNJTkVTUyBJTlRFUlJVUFRJT04pIEhPV0VWRVIgQ0FVU0VEIEFORCBPTgpBTlkgVEhFT1JZIE9GIExJQUJJTElUWSwgV0hFVEhFUiBJTiBDT05UUkFDVCwgU1RSSUNUIExJQUJJTElUWSwgT1IgVE9SVAooSU5DTFVESU5HIE5FR0xJR0VOQ0UgT1IgT1RIRVJXSVNFKSBBUklTSU5HIElOIEFOWSBXQVkgT1VUIE9GIFRIRSBVU0UgT0YgVEhJUwpTT0ZUV0FSRSwgRVZFTiBJRiBBRFZJU0VEIE9GIFRIRSBQT1NTSUJJTElUWSBPRiBTVUNIIERBTUFHRS4KCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpUaGUgdHVzY2FueS1hc3NlbWJseS14c2QgamFyIGluY2x1ZGVzIFhTRCBmaWxlcyB1bmRlciB0aGUgZm9sbG93aW5nIFNDQSBDb2xsYWJvcmF0aW9uIGxpY2Vuc2U6CgpMaWNlbnNlIGZvciB0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIEphdmFEb2MsIEludGVyZmFjZSAKRGVmaW5pdGlvbiBmaWxlcyBhbmQgWFNEIGZpbGVzLgoKVGhlIFNlcnZpY2UgQ29tcG9uZW50IEFyY2hpdGVjdHVyZSBKYXZhRG9jLCBJbnRlcmZhY2UgRGVmaW5pdGlvbiBmaWxlcywgCmFuZCBYU0QgZmlsZXMgYXJlIGJlaW5nIHByb3ZpZGVkIGJ5IHRoZSBjb3B5cmlnaHQgaG9sZGVycyB1bmRlciB0aGUgCmZvbGxvd2luZyBsaWNlbnNlLiBCeSB1c2luZyBhbmQvb3IgY29weWluZyB0aGlzIHdvcmssIHlvdSBhZ3JlZSB0aGF0IAp5b3UgaGF2ZSByZWFkLCB1bmRlcnN0b29kIGFuZCB3aWxsIGNvbXBseSB3aXRoIHRoZSBmb2xsb3dpbmcgdGVybXMgYW5kIApjb25kaXRpb25zOgoKUGVybWlzc2lvbiB0byBjb3B5LCBkaXNwbGF5LCBtYWtlIGRlcml2YXRpdmUgd29ya3Mgb2YsIGFuZCBkaXN0cmlidXRlIAp0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIEphdmFEb2MsIEludGVyZmFjZSBEZWZpbml0aW9uIEZpbGVzIAphbmQgWFNEIGZpbGVzICh0aGUgIkFydGlmYWN0cyIpIGluIGFueSBtZWRpdW0gd2l0aG91dCBmZWUgb3Igcm95YWx0eSBpcyAKaGVyZWJ5IGdyYW50ZWQsIHByb3ZpZGVkIHRoYXQgeW91IGluY2x1ZGUgdGhlIGZvbGxvd2luZyBvbiBBTEwgY29waWVzIApvZiB0aGUgQXJ0aWZhY3RzLCBvciBwb3J0aW9ucyB0aGVyZW9mLCB0aGF0IHlvdSBtYWtlOiAKCjEuIEEgbGluayBvciBVUkwgdG8gdGhlIEFydGlmYWN0cyBhdCB0aGlzIGxvY2F0aW9uOgpodHRwOi8vd3d3Lm9zb2Eub3JnL2Rpc3BsYXkvTWFpbi9TZXJ2aWNlK0NvbXBvbmVudCtBcmNoaXRlY3R1cmUrU3BlY2lmaWNhdGlvbnMgCgoyLiBUaGUgZnVsbCB0ZXh0IG9mIHRoaXMgY29weXJpZ2h0IG5vdGljZSBhcyBzaG93biBpbiB0aGUgQXJ0aWZhY3RzLgoKVEhFIEFSVElGQUNUUyBBUkUgUFJPVklERUQgIkFTIElTLCIgQU5EIFRIRSBBVVRIT1JTIE1BS0UgTk8gClJFUFJFU0VOVEFUSU9OUyBPUiBXQVJSQU5USUVTLCBFWFBSRVNTIE9SIElNUExJRUQsIFJFR0FSRElORyBUSEUgCkFSVElGQUNUUyBBTkQgVEhFIElNUExFTUVOVEFUSU9OIE9GIFRIRUlSIENPTlRFTlRTLCBJTkNMVURJTkcsIEJVVCBOT1QgCkxJTUlURUQgVE8sIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLCBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgClBVUlBPU0UsIE5PTi1JTkZSSU5HRU1FTlQgT1IgVElUTEUuICAKClRIRSBBVVRIT1JTIFdJTEwgTk9UIEJFIExJQUJMRSBGT1IgQU5ZIERJUkVDVCwgSU5ESVJFQ1QsIFNQRUNJQUwsIApJTkNJREVOVEFMIE9SIENPTlNFUVVFTlRJQUwgREFNQUdFUyBBUklTSU5HIE9VVCBPRiBPUiBSRUxBVElORyBUTyBBTlkgClVTRSBPUiBESVNUUklCVVRJT04gT0YgVEhFIEFSVElGQUNUUy4KClRoZSBuYW1lIGFuZCB0cmFkZW1hcmtzIG9mIHRoZSBBdXRob3JzIG1heSBOT1QgYmUgdXNlZCBpbiBhbnkgbWFubmVyLCAKaW5jbHVkaW5nIGFkdmVydGlzaW5nIG9yIHB1YmxpY2l0eSBwZXJ0YWluaW5nIHRvIHRoZSBTZXJ2aWNlIENvbXBvbmVudCAKQXJjaGl0ZWN0dXJlIFNwZWNpZmljYXRpb24gb3IgaXRzIGNvbnRlbnRzIHdpdGhvdXQgc3BlY2lmaWMsIHdyaXR0ZW4gCnByaW9yIHBlcm1pc3Npb24uIFRpdGxlIHRvIGNvcHlyaWdodCBpbiB0aGUgU2VydmljZSBDb21wb25lbnQgCkFyY2hpdGVjdHVyZSBTcGVjaWZpY2F0aW9uIGFuZCB0aGUgSmF2YURvYywgSW50ZXJmYWNlIERlZmluaXRpb24gRmlsZXMgCmFuZCBYU0QgRmlsZXMgd2lsbCBhdCBhbGwgdGltZXMgcmVtYWluIHdpdGggdGhlIEF1dGhvcnMuCgpObyBvdGhlciByaWdodHMgYXJlIGdyYW50ZWQgYnkgaW1wbGljYXRpb24sIGVzdG9wcGVsIG9yIG90aGVyd2lzZS4KClJldmlzaW9uIGxldmVsIDEuMSwgbGFzdCB1cGRhdGVkIG9uIDIwMDcvMTEvMTkKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpUaGUgYXNtLTMuMS5qYXI6CgpDb3B5cmlnaHQgKGMpIDIwMDAtMjAwNSBJTlJJQSwgRnJhbmNlIFRlbGVjb20KQWxsIHJpZ2h0cyByZXNlcnZlZC4KClJlZGlzdHJpYnV0aW9uIGFuZCB1c2UgaW4gc291cmNlIGFuZCBiaW5hcnkgZm9ybXMsIHdpdGggb3Igd2l0aG91dAptb2RpZmljYXRpb24sIGFyZSBwZXJtaXR0ZWQgcHJvdmlkZWQgdGhhdCB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnMKYXJlIG1ldDoKCjEuIFJlZGlzdHJpYnV0aW9ucyBvZiBzb3VyY2UgY29kZSBtdXN0IHJldGFpbiB0aGUgYWJvdmUgY29weXJpZ2h0CiAgIG5vdGljZSwgdGhpcyBsaXN0IG9mIGNvbmRpdGlvbnMgYW5kIHRoZSBmb2xsb3dpbmcgZGlzY2xhaW1lci4KCjIuIFJlZGlzdHJpYnV0aW9ucyBpbiBiaW5hcnkgZm9ybSBtdXN0IHJlcHJvZHVjZSB0aGUgYWJvdmUgY29weXJpZ2h0CiAgIG5vdGljZSwgdGhpcyBsaXN0IG9mIGNvbmRpdGlvbnMgYW5kIHRoZSBmb2xsb3dpbmcgZGlzY2xhaW1lciBpbiB0aGUKICAgZG9jdW1lbnRhdGlvbiBhbmQvb3Igb3RoZXIgbWF0ZXJpYWxzIHByb3ZpZGVkIHdpdGggdGhlIGRpc3RyaWJ1dGlvbi4KCjMuIE5laXRoZXIgdGhlIG5hbWUgb2YgdGhlIGNvcHlyaWdodCBob2xkZXJzIG5vciB0aGUgbmFtZXMgb2YgaXRzCiAgIGNvbnRyaWJ1dG9ycyBtYXkgYmUgdXNlZCB0byBlbmRvcnNlIG9yIHByb21vdGUgcHJvZHVjdHMgZGVyaXZlZCBmcm9tCiAgIHRoaXMgc29mdHdhcmUgd2l0aG91dCBzcGVjaWZpYyBwcmlvciB3cml0dGVuIHBlcm1pc3Npb24uCgpUSElTIFNPRlRXQVJFIElTIFBST1ZJREVEIEJZIFRIRSBDT1BZUklHSFQgSE9MREVSUyBBTkQgQ09OVFJJQlVUT1JTICJBUyBJUyIKQU5EIEFOWSBFWFBSRVNTIE9SIElNUExJRUQgV0FSUkFOVElFUywgSU5DTFVESU5HLCBCVVQgTk9UIExJTUlURUQgVE8sIFRIRQpJTVBMSUVEIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZIEFORCBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRQpBUkUgRElTQ0xBSU1FRC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFIENPUFlSSUdIVCBPV05FUiBPUiBDT05UUklCVVRPUlMgQkUKTElBQkxFIEZPUiBBTlkgRElSRUNULCBJTkRJUkVDVCwgSU5DSURFTlRBTCwgU1BFQ0lBTCwgRVhFTVBMQVJZLCBPUgpDT05TRVFVRU5USUFMIERBTUFHRVMgKElOQ0xVRElORywgQlVUIE5PVCBMSU1JVEVEIFRPLCBQUk9DVVJFTUVOVCBPRgpTVUJTVElUVVRFIEdPT0RTIE9SIFNFUlZJQ0VTOyBMT1NTIE9GIFVTRSwgREFUQSwgT1IgUFJPRklUUzsgT1IgQlVTSU5FU1MKSU5URVJSVVBUSU9OKSBIT1dFVkVSIENBVVNFRCBBTkQgT04gQU5ZIFRIRU9SWSBPRiBMSUFCSUxJVFksIFdIRVRIRVIgSU4KQ09OVFJBQ1QsIFNUUklDVCBMSUFCSUxJVFksIE9SIFRPUlQgKElOQ0xVRElORyBORUdMSUdFTkNFIE9SIE9USEVSV0lTRSkKQVJJU0lORyBJTiBBTlkgV0FZIE9VVCBPRiBUSEUgVVNFIE9GIFRISVMgU09GVFdBUkUsIEVWRU4gSUYgQURWSVNFRCBPRgpUSEUgUE9TU0lCSUxJVFkgT0YgU1VDSCBEQU1BR0UuCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKRm9udEJveCBhbmQgSmVtcEJveCBsaWJyYXJpZXMgKGZvbnRib3gtMC4xLjAuamFyLCBqZW1wYm94LTAuMi4wLmphcikKCiAgICBDb3B5cmlnaHQgKGMpIDIwMDMtMjAwNSwgd3d3LmZvbnRib3gub3JnCiAgICBBbGwgcmlnaHRzIHJlc2VydmVkLgoKICAgIFJlZGlzdHJpYnV0aW9uIGFuZCB1c2UgaW4gc291cmNlIGFuZCBiaW5hcnkgZm9ybXMsIHdpdGggb3Igd2l0aG91dAogICAgbW9kaWZpY2F0aW9uLCBhcmUgcGVybWl0dGVkIHByb3ZpZGVkIHRoYXQgdGhlIGZvbGxvd2luZyBjb25kaXRpb25zIGFyZSBtZXQ6CgogICAgMS4gUmVkaXN0cmlidXRpb25zIG9mIHNvdXJjZSBjb2RlIG11c3QgcmV0YWluIHRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlLAogICAgICAgdGhpcyBsaXN0IG9mIGNvbmRpdGlvbnMgYW5kIHRoZSBmb2xsb3dpbmcgZGlzY2xhaW1lci4KICAgIDIuIFJlZGlzdHJpYnV0aW9ucyBpbiBiaW5hcnkgZm9ybSBtdXN0IHJlcHJvZHVjZSB0aGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSwKICAgICAgIHRoaXMgbGlzdCBvZiBjb25kaXRpb25zIGFuZCB0aGUgZm9sbG93aW5nIGRpc2NsYWltZXIgaW4gdGhlIGRvY3VtZW50YXRpb24KICAgICAgIGFuZC9vciBvdGhlciBtYXRlcmlhbHMgcHJvdmlkZWQgd2l0aCB0aGUgZGlzdHJpYnV0aW9uLgogICAgMy4gTmVpdGhlciB0aGUgbmFtZSBvZiBmb250Ym94OyBub3IgdGhlIG5hbWVzIG9mIGl0cwogICAgICAgY29udHJpYnV0b3JzIG1heSBiZSB1c2VkIHRvIGVuZG9yc2Ugb3IgcHJvbW90ZSBwcm9kdWN0cyBkZXJpdmVkIGZyb20gdGhpcwogICAgICAgc29mdHdhcmUgd2l0aG91dCBzcGVjaWZpYyBwcmlvciB3cml0dGVuIHBlcm1pc3Npb24uCgogICAgVEhJUyBTT0ZUV0FSRSBJUyBQUk9WSURFRCBCWSBUSEUgQ09QWVJJR0hUIEhPTERFUlMgQU5EIENPTlRSSUJVVE9SUyAiQVMgSVMiCiAgICBBTkQgQU5ZIEVYUFJFU1MgT1IgSU1QTElFRCBXQVJSQU5USUVTLCBJTkNMVURJTkcsIEJVVCBOT1QgTElNSVRFRCBUTywgVEhFCiAgICBJTVBMSUVEIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZIEFORCBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRQogICAgQVJFIERJU0NMQUlNRUQuICBJTiBOTyBFVkVOVCBTSEFMTCBUSEUgUkVHRU5UUyBPUiBDT05UUklCVVRPUlMgQkUgTElBQkxFCiAgICBGT1IgQU5ZIERJUkVDVCwgSU5ESVJFQ1QsIElOQ0lERU5UQUwsIFNQRUNJQUwsIEVYRU1QTEFSWSwgT1IgQ09OU0VRVUVOVElBTAogICAgREFNQUdFUyAoSU5DTFVESU5HLCBCVVQgTk9UIExJTUlURUQgVE8sIFBST0NVUkVNRU5UIE9GIFNVQlNUSVRVVEUgR09PRFMKICAgIE9SIFNFUlZJQ0VTOyBMT1NTIE9GIFVTRSwgREFUQSwgT1IgUFJPRklUUzsgT1IgQlVTSU5FU1MgSU5URVJSVVBUSU9OKQogICAgSE9XRVZFUiBDQVVTRUQgQU5EIE9OIEFOWSBUSEVPUlkgT0YgTElBQklMSVRZLCBXSEVUSEVSIElOIENPTlRSQUNULCBTVFJJQ1QKICAgIExJQUJJTElUWSwgT1IgVE9SVCAoSU5DTFVESU5HIE5FR0xJR0VOQ0UgT1IgT1RIRVJXSVNFKSBBUklTSU5HIElOIEFOWSBXQVkKICAgIE9VVCBPRiBUSEUgVVNFIE9GIFRISVMgU09GVFdBUkUsIEVWRU4gSUYgQURWSVNFRCBPRiBUSEUgUE9TU0lCSUxJVFkKICAgIE9GIFNVQ0ggREFNQUdFLgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKVGhlIHNsZjRqLWFwaS0xLjUuMTEuamFyLCBzbGY0ai1qZGsxNC0xLjUuMTEuamFyLCBzbGY0ai1sb2c0ajEyLTEuNS4xMS5qYXIgYXJlIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBsaWNlbnNlOgoKCkNvcHlyaWdodCAoYykgMjAwNC0yMDA4IFFPUy5jaAogQWxsIHJpZ2h0cyByZXNlcnZlZC4KCiBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlICBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nCiBhICBjb3B5ICBvZiB0aGlzICBzb2Z0d2FyZSAgYW5kICBhc3NvY2lhdGVkICBkb2N1bWVudGF0aW9uIGZpbGVzICAodGhlCiAiU29mdHdhcmUiKSwgdG8gIGRlYWwgaW4gIHRoZSBTb2Z0d2FyZSB3aXRob3V0ICByZXN0cmljdGlvbiwgaW5jbHVkaW5nCiB3aXRob3V0IGxpbWl0YXRpb24gIHRoZSByaWdodHMgdG8gIHVzZSwgY29weSwgbW9kaWZ5LCAgbWVyZ2UsIHB1Ymxpc2gsCiBkaXN0cmlidXRlLCAgc3VibGljZW5zZSwgYW5kL29yIHNlbGwgIGNvcGllcyBvZiAgdGhlIFNvZnR3YXJlLCAgYW5kIHRvCiBwZXJtaXQgcGVyc29ucyB0byB3aG9tIHRoZSBTb2Z0d2FyZSAgaXMgZnVybmlzaGVkIHRvIGRvIHNvLCBzdWJqZWN0IHRvCiB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6CiAKIFRoZSAgYWJvdmUgIGNvcHlyaWdodCAgbm90aWNlICBhbmQgIHRoaXMgcGVybWlzc2lvbiAgbm90aWNlICBzaGFsbCAgYmUKIGluY2x1ZGVkIGluIGFsbCBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLgogCiBUSEUgIFNPRlRXQVJFIElTICBQUk9WSURFRCAgIkFTICBJUyIsIFdJVEhPVVQgIFdBUlJBTlRZICBPRiBBTlkgIEtJTkQsCiBFWFBSRVNTIE9SICBJTVBMSUVELCBJTkNMVURJTkcgIEJVVCBOT1QgTElNSVRFRCAgVE8gVEhFICBXQVJSQU5USUVTIE9GCiBNRVJDSEFOVEFCSUxJVFksICAgIEZJVE5FU1MgICAgRk9SICAgIEEgICBQQVJUSUNVTEFSICAgIFBVUlBPU0UgICAgQU5ECiBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRSBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFCiBMSUFCTEUgRk9SIEFOWSBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUiBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OCiBPRiBDT05UUkFDVCwgVE9SVCBPUiBPVEhFUldJU0UsICBBUklTSU5HIEZST00sIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OCiBXSVRIIFRIRSBTT0ZUV0FSRSBPUiBUSEUgVVNFIE9SIE9USEVSIERFQUxJTkdTIElOIFRIRSBTT0ZUV0FSRS4KCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpKQ1IgMS4wIEFQSSAoamNyLTEuMC5qYXIpCgogICAgW0RheSBTcGVjaWZpY2F0aW9uIExpY2Vuc2VdCgogICAgRGF5IE1hbmFnZW1lbnQgQUcgKCJMaWNlbnNvciIpIGlzIHdpbGxpbmcgdG8gbGljZW5zZSB0aGlzIHNwZWNpZmljYXRpb24KICAgIHRvIHlvdSBPTkxZIFVQT04gVEhFIENPTkRJVElPTiBUSEFUIFlPVSBBQ0NFUFQgQUxMIE9GIFRIRSBURVJNUyBDT05UQUlORUQKICAgIElOIFRISVMgTElDRU5TRSBBR1JFRU1FTlQgKCJBZ3JlZW1lbnQiKS4gUGxlYXNlIHJlYWQgdGhlIHRlcm1zIGFuZAogICAgY29uZGl0aW9ucyBvZiB0aGlzIEFncmVlbWVudCBjYXJlZnVsbHkuCgogICAgQ29udGVudCBSZXBvc2l0b3J5IGZvciBKYXZhVE0gVGVjaG5vbG9neSBBUEkgU3BlY2lmaWNhdGlvbiAoIlNwZWNpZmljYXRpb24iKQogICAgVmVyc2lvbjogMS4wCiAgICBTdGF0dXM6IEZDUwogICAgUmVsZWFzZTogMTEgTWF5IDIwMDUKCiAgICBDb3B5cmlnaHQgMjAwNSBEYXkgTWFuYWdlbWVudCBBRwogICAgQmFyZsO8c3NlcnBsYXR6IDYsIDQwMDEgQmFzZWwsIFN3aXR6ZXJsYW5kLgogICAgQWxsIHJpZ2h0cyByZXNlcnZlZC4KCiAgICBOT1RJQ0U7IExJTUlURUQgTElDRU5TRSBHUkFOVFMKCiAgICAxLiBMaWNlbnNlIGZvciBQdXJwb3NlcyBvZiBFdmFsdWF0aW9uIGFuZCBEZXZlbG9waW5nIEFwcGxpY2F0aW9ucy4KICAgIExpY2Vuc29yIGhlcmVieSBncmFudHMgeW91IGEgZnVsbHktcGFpZCwgbm9uLWV4Y2x1c2l2ZSwgbm9uLXRyYW5zZmVyYWJsZSwKICAgIHdvcmxkd2lkZSwgbGltaXRlZCBsaWNlbnNlICh3aXRob3V0IHRoZSByaWdodCB0byBzdWJsaWNlbnNlKSwgdW5kZXIKICAgIExpY2Vuc29yJ3MgYXBwbGljYWJsZSBpbnRlbGxlY3R1YWwgcHJvcGVydHkgcmlnaHRzIHRvIHZpZXcsIGRvd25sb2FkLAogICAgdXNlIGFuZCByZXByb2R1Y2UgdGhlIFNwZWNpZmljYXRpb24gb25seSBmb3IgdGhlIHB1cnBvc2Ugb2YgaW50ZXJuYWwKICAgIGV2YWx1YXRpb24uIFRoaXMgaW5jbHVkZXMgZGV2ZWxvcGluZyBhcHBsaWNhdGlvbnMgaW50ZW5kZWQgdG8gcnVuIG9uIGFuCiAgICBpbXBsZW1lbnRhdGlvbiBvZiB0aGUgU3BlY2lmaWNhdGlvbiBwcm92aWRlZCB0aGF0IHN1Y2ggYXBwbGljYXRpb25zIGRvCiAgICBub3QgdGhlbXNlbHZlcyBpbXBsZW1lbnQgYW55IHBvcnRpb24ocykgb2YgdGhlIFNwZWNpZmljYXRpb24uCgogICAgMi4gTGljZW5zZSBmb3IgdGhlIERpc3RyaWJ1dGlvbiBvZiBDb21wbGlhbnQgSW1wbGVtZW50YXRpb25zLiBMaWNlbnNvcgogICAgYWxzbyBncmFudHMgeW91IGEgcGVycGV0dWFsLCBub24tZXhjbHVzaXZlLCBub24tdHJhbnNmZXJhYmxlLCB3b3JsZHdpZGUsCiAgICBmdWxseSBwYWlkLXVwLCByb3lhbHR5IGZyZWUsIGxpbWl0ZWQgbGljZW5zZSAod2l0aG91dCB0aGUgcmlnaHQgdG8KICAgIHN1YmxpY2Vuc2UpIHVuZGVyIGFueSBhcHBsaWNhYmxlIGNvcHlyaWdodHMgb3IsIHN1YmplY3QgdG8gdGhlIHByb3Zpc2lvbnMKICAgIG9mIHN1YnNlY3Rpb24gNCBiZWxvdywgcGF0ZW50IHJpZ2h0cyBpdCBtYXkgaGF2ZSBjb3ZlcmluZyB0aGUKICAgIFNwZWNpZmljYXRpb24gdG8gY3JlYXRlIGFuZC9vciBkaXN0cmlidXRlIGFuIEluZGVwZW5kZW50IEltcGxlbWVudGF0aW9uCiAgICBvZiB0aGUgU3BlY2lmaWNhdGlvbiB0aGF0OiAoYSkgZnVsbHkgaW1wbGVtZW50cyB0aGUgU3BlY2lmaWNhdGlvbgogICAgaW5jbHVkaW5nIGFsbCBpdHMgcmVxdWlyZWQgaW50ZXJmYWNlcyBhbmQgZnVuY3Rpb25hbGl0eTsgKGIpIGRvZXMgbm90CiAgICBtb2RpZnksIHN1YnNldCwgc3VwZXJzZXQgb3Igb3RoZXJ3aXNlIGV4dGVuZCB0aGUgTGljZW5zb3IgTmFtZSBTcGFjZSwgb3IKICAgIGluY2x1ZGUgYW55IHB1YmxpYyBvciBwcm90ZWN0ZWQgcGFja2FnZXMsIGNsYXNzZXMsIEphdmEgaW50ZXJmYWNlcywgZmllbGRzCiAgICBvciBtZXRob2RzIHdpdGhpbiB0aGUgTGljZW5zb3IgTmFtZSBTcGFjZSBvdGhlciB0aGFuIHRob3NlCiAgICByZXF1aXJlZC9hdXRob3JpemVkIGJ5IHRoZSBTcGVjaWZpY2F0aW9uIG9yIFNwZWNpZmljYXRpb25zIGJlaW5nCiAgICBpbXBsZW1lbnRlZDsgYW5kIChjKSBwYXNzZXMgdGhlIFRlY2hub2xvZ3kgQ29tcGF0aWJpbGl0eSBLaXQgKGluY2x1ZGluZwogICAgc2F0aXNmeWluZyB0aGUgcmVxdWlyZW1lbnRzIG9mIHRoZSBhcHBsaWNhYmxlIFRDSyBVc2VycyBHdWlkZSkgZm9yIHN1Y2gKICAgIFNwZWNpZmljYXRpb24gKCJDb21wbGlhbnQgSW1wbGVtZW50YXRpb24iKS4gSW4gYWRkaXRpb24sIHRoZSBmb3JlZ29pbmcKICAgIGxpY2Vuc2UgaXMgZXhwcmVzc2x5IGNvbmRpdGlvbmVkIG9uIHlvdXIgbm90IGFjdGluZyBvdXRzaWRlIGl0cyBzY29wZS4KICAgIE5vIGxpY2Vuc2UgaXMgZ3JhbnRlZCBoZXJldW5kZXIgZm9yIGFueSBvdGhlciBwdXJwb3NlIChpbmNsdWRpbmcsIGZvcgogICAgZXhhbXBsZSwgbW9kaWZ5aW5nIHRoZSBTcGVjaWZpY2F0aW9uLCBvdGhlciB0aGFuIHRvIHRoZSBleHRlbnQgb2YgeW91cgogICAgZmFpciB1c2UgcmlnaHRzLCBvciBkaXN0cmlidXRpbmcgdGhlIFNwZWNpZmljYXRpb24gdG8gdGhpcmQgcGFydGllcykuCgogICAgMy4gUGFzcy10aHJvdWdoIENvbmRpdGlvbnMuIFlvdSBuZWVkIG5vdCBpbmNsdWRlIGxpbWl0YXRpb25zIChhKS0oYykgZnJvbQogICAgdGhlIHByZXZpb3VzIHBhcmFncmFwaCBvciBhbnkgb3RoZXIgcGFydGljdWxhciAicGFzcyB0aHJvdWdoIiByZXF1aXJlbWVudHMKICAgIGluIGFueSBsaWNlbnNlIFlvdSBncmFudCBjb25jZXJuaW5nIHRoZSB1c2Ugb2YgeW91ciBJbmRlcGVuZGVudAogICAgSW1wbGVtZW50YXRpb24gb3IgcHJvZHVjdHMgZGVyaXZlZCBmcm9tIGl0LiBIb3dldmVyLCBleGNlcHQgd2l0aCByZXNwZWN0CiAgICB0byBJbmRlcGVuZGVudCBJbXBsZW1lbnRhdGlvbnMgKGFuZCBwcm9kdWN0cyBkZXJpdmVkIGZyb20gdGhlbSkgdGhhdAogICAgc2F0aXNmeSBsaW1pdGF0aW9ucyAoYSktKGMpIGZyb20gdGhlIHByZXZpb3VzIHBhcmFncmFwaCwgWW91IG1heSBuZWl0aGVyOgogICAgKGEpIGdyYW50IG9yIG90aGVyd2lzZSBwYXNzIHRocm91Z2ggdG8geW91ciBsaWNlbnNlZXMgYW55IGxpY2Vuc2VzIHVuZGVyCiAgICBMaWNlbnNvcidzIGFwcGxpY2FibGUgaW50ZWxsZWN0dWFsIHByb3BlcnR5IHJpZ2h0czsgbm9yIChiKSBhdXRob3JpemUgeW91cgogICAgbGljZW5zZWVzIHRvIG1ha2UgYW55IGNsYWltcyBjb25jZXJuaW5nIHRoZWlyIGltcGxlbWVudGF0aW9uJ3MgY29tcGxpYW5jZQogICAgd2l0aCB0aGUgU3BlY2lmaWNhdGlvbi4KCiAgICA0LiBSZWNpcHJvY2l0eSBDb25jZXJuaW5nIFBhdGVudCBMaWNlbnNlcy4gV2l0aCByZXNwZWN0IHRvIGFueSBwYXRlbnQKICAgIGNsYWltcyBjb3ZlcmVkIGJ5IHRoZSBsaWNlbnNlIGdyYW50ZWQgdW5kZXIgc3VicGFyYWdyYXBoIDIgYWJvdmUgdGhhdAogICAgd291bGQgYmUgaW5mcmluZ2VkIGJ5IGFsbCB0ZWNobmljYWxseSBmZWFzaWJsZSBpbXBsZW1lbnRhdGlvbnMgb2YgdGhlCiAgICBTcGVjaWZpY2F0aW9uLCBzdWNoIGxpY2Vuc2UgaXMgY29uZGl0aW9uZWQgdXBvbiB5b3VyIG9mZmVyaW5nIG9uIGZhaXIsCiAgICByZWFzb25hYmxlIGFuZCBub24tZGlzY3JpbWluYXRvcnkgdGVybXMsIHRvIGFueSBwYXJ0eSBzZWVraW5nIGl0IGZyb20KICAgIFlvdSwgYSBwZXJwZXR1YWwsIG5vbi1leGNsdXNpdmUsIG5vbi10cmFuc2ZlcmFibGUsIHdvcmxkd2lkZSBsaWNlbnNlCiAgICB1bmRlciBZb3VyIHBhdGVudCByaWdodHMgdGhhdCBhcmUgb3Igd291bGQgYmUgaW5mcmluZ2VkIGJ5IGFsbCB0ZWNobmljYWxseQogICAgZmVhc2libGUgaW1wbGVtZW50YXRpb25zIG9mIHRoZSBTcGVjaWZpY2F0aW9uIHRvIGRldmVsb3AsIGRpc3RyaWJ1dGUgYW5kCiAgICB1c2UgYSBDb21wbGlhbnQgSW1wbGVtZW50YXRpb24uCgogICAgNS4gRGVmaW5pdGlvbnMuIEZvciB0aGUgcHVycG9zZXMgb2YgdGhpcyBBZ3JlZW1lbnQ6ICJJbmRlcGVuZGVudAogICAgSW1wbGVtZW50YXRpb24iIHNoYWxsIG1lYW4gYW4gaW1wbGVtZW50YXRpb24gb2YgdGhlIFNwZWNpZmljYXRpb24gdGhhdAogICAgbmVpdGhlciBkZXJpdmVzIGZyb20gYW55IG9mIExpY2Vuc29yJ3Mgc291cmNlIGNvZGUgb3IgYmluYXJ5IGNvZGUKICAgIG1hdGVyaWFscyBub3IsIGV4Y2VwdCB3aXRoIGFuIGFwcHJvcHJpYXRlIGFuZCBzZXBhcmF0ZSBsaWNlbnNlIGZyb20KICAgIExpY2Vuc29yLCBpbmNsdWRlcyBhbnkgb2YgTGljZW5zb3IncyBzb3VyY2UgY29kZSBvciBiaW5hcnkgY29kZSBtYXRlcmlhbHM7CiAgICAiTGljZW5zb3IgTmFtZSBTcGFjZSIgc2hhbGwgbWVhbiB0aGUgcHVibGljIGNsYXNzIG9yIGludGVyZmFjZQogICAgZGVjbGFyYXRpb25zIHdob3NlIG5hbWVzIGJlZ2luIHdpdGggImphdmEiLCAiamF2YXgiLCAiamF2YXguamNyIiBvciB0aGVpcgogICAgZXF1aXZhbGVudHMgaW4gYW55IHN1YnNlcXVlbnQgbmFtaW5nIGNvbnZlbnRpb24gYWRvcHRlZCBieSBMaWNlbnNvcgogICAgdGhyb3VnaCB0aGUgSmF2YSBDb21tdW5pdHkgUHJvY2Vzcywgb3IgYW55IHJlY29nbml6ZWQgc3VjY2Vzc29ycyBvcgogICAgcmVwbGFjZW1lbnRzIHRoZXJlb2Y7IGFuZCAiVGVjaG5vbG9neSBDb21wYXRpYmlsaXR5IEtpdCIgb3IgIlRDSyIgc2hhbGwKICAgIG1lYW4gdGhlIHRlc3Qgc3VpdGUgYW5kIGFjY29tcGFueWluZyBUQ0sgVXNlcidzIEd1aWRlIHByb3ZpZGVkIGJ5CiAgICBMaWNlbnNvciB3aGljaCBjb3JyZXNwb25kcyB0byB0aGUgcGFydGljdWxhciB2ZXJzaW9uIG9mIHRoZSBTcGVjaWZpY2F0aW9uCiAgICBiZWluZyB0ZXN0ZWQuCgogICAgNi4gVGVybWluYXRpb24uIFRoaXMgQWdyZWVtZW50IHdpbGwgdGVybWluYXRlIGltbWVkaWF0ZWx5IHdpdGhvdXQgbm90aWNlCiAgICBmcm9tIExpY2Vuc29yIGlmIHlvdSBmYWlsIHRvIGNvbXBseSB3aXRoIGFueSBtYXRlcmlhbCBwcm92aXNpb24gb2Ygb3IgYWN0CiAgICBvdXRzaWRlIHRoZSBzY29wZSBvZiB0aGUgbGljZW5zZXMgZ3JhbnRlZCBhYm92ZS4KCiAgICA3LiBUcmFkZW1hcmtzLiBObyByaWdodCwgdGl0bGUsIG9yIGludGVyZXN0IGluIG9yIHRvIGFueSB0cmFkZW1hcmtzLAogICAgc2VydmljZSBtYXJrcywgb3IgdHJhZGUgbmFtZXMgb2YgTGljZW5zb3IgaXMgZ3JhbnRlZCBoZXJldW5kZXIuIEphdmEgaXMKICAgIGEgcmVnaXN0ZXJlZCB0cmFkZW1hcmsgb2YgU3VuIE1pY3Jvc3lzdGVtcywgSW5jLiBpbiB0aGUgVW5pdGVkIFN0YXRlcyBhbmQKICAgIG90aGVyIGNvdW50cmllcy4KCiAgICA4LiBEaXNjbGFpbWVyIG9mIFdhcnJhbnRpZXMuIFRoZSBTcGVjaWZpY2F0aW9uIGlzIHByb3ZpZGVkICJBUyBJUyIuCiAgICBMSUNFTlNPUiBNQUtFUyBOTyBSRVBSRVNFTlRBVElPTlMgT1IgV0FSUkFOVElFUywgRUlUSEVSIEVYUFJFU1MgT1IKICAgIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8sIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLAogICAgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UsIE5PTi1JTkZSSU5HRU1FTlQgKElOQ0xVRElORyBBUyBBCiAgICBDT05TRVFVRU5DRSBPRiBBTlkgUFJBQ1RJQ0UgT1IgSU1QTEVNRU5UQVRJT04gT0YgVEhFIFNQRUNJRklDQVRJT04pLCBPUgogICAgVEhBVCBUSEUgQ09OVEVOVFMgT0YgVEhFIFNQRUNJRklDQVRJT04gQVJFIFNVSVRBQkxFIEZPUiBBTlkgUFVSUE9TRS4KICAgIFRoaXMgZG9jdW1lbnQgZG9lcyBub3QgcmVwcmVzZW50IGFueSBjb21taXRtZW50IHRvIHJlbGVhc2Ugb3IgaW1wbGVtZW50CiAgICBhbnkgcG9ydGlvbiBvZiB0aGUgU3BlY2lmaWNhdGlvbiBpbiBhbnkgcHJvZHVjdC4KCiAgICBUaGUgU3BlY2lmaWNhdGlvbiBjb3VsZCBpbmNsdWRlIHRlY2huaWNhbCBpbmFjY3VyYWNpZXMgb3IgdHlwb2dyYXBoaWNhbAogICAgZXJyb3JzLiBDaGFuZ2VzIGFyZSBwZXJpb2RpY2FsbHkgYWRkZWQgdG8gdGhlIGluZm9ybWF0aW9uIHRoZXJlaW47IHRoZXNlCiAgICBjaGFuZ2VzIHdpbGwgYmUgaW5jb3Jwb3JhdGVkIGludG8gbmV3IHZlcnNpb25zIG9mIHRoZSBTcGVjaWZpY2F0aW9uLCBpZgogICAgYW55LiBMaWNlbnNvciBtYXkgbWFrZSBpbXByb3ZlbWVudHMgYW5kL29yIGNoYW5nZXMgdG8gdGhlIHByb2R1Y3QocykKICAgIGFuZC9vciB0aGUgcHJvZ3JhbShzKSBkZXNjcmliZWQgaW4gdGhlIFNwZWNpZmljYXRpb24gYXQgYW55IHRpbWUuIEFueQogICAgdXNlIG9mIHN1Y2ggY2hhbmdlcyBpbiB0aGUgU3BlY2lmaWNhdGlvbiB3aWxsIGJlIGdvdmVybmVkIGJ5IHRoZQogICAgdGhlbi1jdXJyZW50IGxpY2Vuc2UgZm9yIHRoZSBhcHBsaWNhYmxlIHZlcnNpb24gb2YgdGhlIFNwZWNpZmljYXRpb24uCgogICAgOS4gTGltaXRhdGlvbiBvZiBMaWFiaWxpdHkuIFRPIFRIRSBFWFRFTlQgTk9UIFBST0hJQklURUQgQlkgTEFXLCBJTiBOTwogICAgRVZFTlQgV0lMTCBMSUNFTlNPUiBCRSBMSUFCTEUgRk9SIEFOWSBEQU1BR0VTLCBJTkNMVURJTkcgV0lUSE9VVAogICAgTElNSVRBVElPTiwgTE9TVCBSRVZFTlVFLCBQUk9GSVRTIE9SIERBVEEsIE9SIEZPUiBTUEVDSUFMLCBJTkRJUkVDVCwKICAgIENPTlNFUVVFTlRJQUwsIElOQ0lERU5UQUwgT1IgUFVOSVRJVkUgREFNQUdFUywgSE9XRVZFUiBDQVVTRUQgQU5ECiAgICBSRUdBUkRMRVNTIE9GIFRIRSBUSEVPUlkgT0YgTElBQklMSVRZLCBBUklTSU5HIE9VVCBPRiBPUiBSRUxBVEVEIFRPIEFOWQogICAgRlVSTklTSElORywgUFJBQ1RJQ0lORywgTU9ESUZZSU5HIE9SIEFOWSBVU0UgT0YgVEhFIFNQRUNJRklDQVRJT04sIEVWRU4KICAgIElGIExJQ0VOU09SIEhBUyBCRUVOIEFEVklTRUQgT0YgVEhFIFBPU1NJQklMSVRZIE9GIFNVQ0ggREFNQUdFUy4KCiAgICAxMC4gUmVwb3J0LiBJZiB5b3UgcHJvdmlkZSBMaWNlbnNvciB3aXRoIGFueSBjb21tZW50cyBvciBzdWdnZXN0aW9ucyBpbgogICAgY29ubmVjdGlvbiB3aXRoIHlvdXIgdXNlIG9mIHRoZSBTcGVjaWZpY2F0aW9uICgiRmVlZGJhY2siKSwgeW91IGhlcmVieToKICAgIChpKSBhZ3JlZSB0aGF0IHN1Y2ggRmVlZGJhY2sgaXMgcHJvdmlkZWQgb24gYSBub24tcHJvcHJpZXRhcnkgYW5kCiAgICBub24tY29uZmlkZW50aWFsIGJhc2lzLCBhbmQgKGlpKSBncmFudCBMaWNlbnNvciBhIHBlcnBldHVhbCwKICAgIG5vbi1leGNsdXNpdmUsIHdvcmxkd2lkZSwgZnVsbHkgcGFpZC11cCwgaXJyZXZvY2FibGUgbGljZW5zZSwgd2l0aCB0aGUKICAgIHJpZ2h0IHRvIHN1YmxpY2Vuc2UgdGhyb3VnaCBtdWx0aXBsZSBsZXZlbHMgb2Ygc3VibGljZW5zZWVzLCB0bwogICAgaW5jb3Jwb3JhdGUsIGRpc2Nsb3NlLCBhbmQgdXNlIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgRmVlZGJhY2sgZm9yIGFueQogICAgcHVycG9zZSByZWxhdGVkIHRvIHRoZSBTcGVjaWZpY2F0aW9uIGFuZCBmdXR1cmUgdmVyc2lvbnMsCiAgICBpbXBsZW1lbnRhdGlvbnMsIGFuZCB0ZXN0IHN1aXRlcyB0aGVyZW9mLgoKICAgIFtBZGRlbmR1bSB0byB0aGUgRGF5IFNwZWNpZmljYXRpb24gTGljZW5zZV0KCiAgICBJbiBhZGRpdGlvbiB0byB0aGUgcGVybWlzc2lvbnMgZ3JhbnRlZCB1bmRlciB0aGUgU3BlY2lmaWNhdGlvbgogICAgTGljZW5zZSwgRGF5IE1hbmFnZW1lbnQgQUcgaGVyZWJ5IGdyYW50cyB0byBZb3UgYSBwZXJwZXR1YWwsCiAgICB3b3JsZHdpZGUsIG5vbi1leGNsdXNpdmUsIG5vLWNoYXJnZSwgcm95YWx0eS1mcmVlLCBpcnJldm9jYWJsZQogICAgbGljZW5zZSB0byByZXByb2R1Y2UsIHB1YmxpY2x5IGRpc3BsYXksIHB1YmxpY2x5IHBlcmZvcm0sCiAgICBzdWJsaWNlbnNlLCBhbmQgZGlzdHJpYnV0ZSB1bm1vZGlmaWVkIGNvcGllcyBvZiB0aGUgQ29udGVudAogICAgUmVwb3NpdG9yeSBmb3IgSmF2YSBUZWNobm9sb2d5IEFQSSAoSkNSIDEuMCkgSmF2YSBBcmNoaXZlIChKQVIpCiAgICBmaWxlICgiamNyLTEuMC5qYXIiKSBhbmQgdG8gbWFrZSwgaGF2ZSBtYWRlLCB1c2UsIG9mZmVyIHRvIHNlbGwsCiAgICBzZWxsLCBpbXBvcnQsIGFuZCBvdGhlcndpc2UgdHJhbnNmZXIgc2FpZCBmaWxlIG9uIGl0cyBvd24gb3IKICAgIGFzIHBhcnQgb2YgYSBsYXJnZXIgd29yayB0aGF0IG1ha2VzIHVzZSBvZiB0aGUgSkNSIEFQSS4KCiAgICBXaXRoIHJlc3BlY3QgdG8gYW55IHBhdGVudCBjbGFpbXMgY292ZXJlZCBieSB0aGlzIGxpY2Vuc2UKICAgIHRoYXQgd291bGQgYmUgaW5mcmluZ2VkIGJ5IGFsbCB0ZWNobmljYWxseSBmZWFzaWJsZSBpbXBsZW1lbnRhdGlvbnMKICAgIG9mIHRoZSBTcGVjaWZpY2F0aW9uLCBzdWNoIGxpY2Vuc2UgaXMgY29uZGl0aW9uZWQgdXBvbiB5b3VyCiAgICBvZmZlcmluZyBvbiBmYWlyLCByZWFzb25hYmxlIGFuZCBub24tZGlzY3JpbWluYXRvcnkgdGVybXMsCiAgICB0byBhbnkgcGFydHkgc2Vla2luZyBpdCBmcm9tIFlvdSwgYSBwZXJwZXR1YWwsIG5vbi1leGNsdXNpdmUsCiAgICBub24tdHJhbnNmZXJhYmxlLCB3b3JsZHdpZGUgbGljZW5zZSB1bmRlciBZb3VyIHBhdGVudCByaWdodHMKICAgIHRoYXQgYXJlIG9yIHdvdWxkIGJlIGluZnJpbmdlZCBieSBhbGwgdGVjaG5pY2FsbHkgZmVhc2libGUKICAgIGltcGxlbWVudGF0aW9ucyBvZiB0aGUgU3BlY2lmaWNhdGlvbiB0byBkZXZlbG9wLCBkaXN0cmlidXRlCiAgICBhbmQgdXNlIGEgQ29tcGxpYW50IEltcGxlbWVudGF0aW9uLgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCkNvbmN1cnJlbnQgbGlicmFyeSAoY29uY3VycmVudC0xLjMuNC5qYXIpCgogICAgaHR0cDovL2cub3N3ZWdvLmVkdS9kbC9jbGFzc2VzL0VEVS9vc3dlZ28vY3MvZGwvdXRpbC9jb25jdXJyZW50L2ludHJvLmh0bWwKCiAgICBBbGwgY2xhc3NlcyBhcmUgcmVsZWFzZWQgdG8gdGhlIHB1YmxpYyBkb21haW4gYW5kIG1heSBiZSB1c2VkIGZvciBhbnkKICAgIHB1cnBvc2Ugd2hhdHNvZXZlciB3aXRob3V0IHBlcm1pc3Npb24gb3IgYWNrbm93bGVkZ21lbnQuIFBvcnRpb25zIG9mCiAgICB0aGUgQ29weU9uV3JpdGVBcnJheUxpc3QgYW5kIENvbmN1cnJlbnRSZWFkZXJIYXNoTWFwIGNsYXNzZXMgYXJlIGFkYXB0ZWQKICAgIGZyb20gU3VuIEpESyBzb3VyY2UgY29kZS4gVGhlc2UgYXJlIGNvcHlyaWdodCBvZiBTdW4gTWljcm9zeXN0ZW1zLCBJbmMsCiAgICBhbmQgYXJlIHVzZWQgd2l0aCB0aGVpciBraW5kIHBlcm1pc3Npb24sIGFzIGRlc2NyaWJlZCBpbiB0aGlzIGxpY2Vuc2U6CgogICAgVEVDSE5PTE9HWSBMSUNFTlNFIEZST00gU1VOIE1JQ1JPU1lTVEVNUywgSU5DLiBUTyBET1VHIExFQQoKICAgIFdoZXJlYXMgRG91ZyBMZWEgZGVzaXJlcyB0byB1dGxpemVkIGNlcnRhaW4gSmF2YSBTb2Z0d2FyZSB0ZWNobm9sb2dpZXMKICAgIGluIHRoZSB1dGlsLmNvbmN1cnJlbnQgdGVjaG5vbG9neTsgYW5kIFdoZXJlYXMgU3VuIE1pY3Jvc3lzdGVtcywgSW5jLgogICAgKCJTdW4iKSBkZXNpcmVzIHRoYXQgRG91ZyBMZWEgdXRpbGl6ZSBjZXJ0YWluIEphdmEgU29mdHdhcmUgdGVjaG5vbG9naWVzCiAgICBpbiB0aGUgdXRpbC5jb25jdXJyZW50IHRlY2hub2xvZ3k7CgogICAgVGhlcmVmb3JlIHRoZSBwYXJ0aWVzIGFncmVlIGFzIGZvbGxvd3MsIGVmZmVjdGl2ZSBNYXkgMzEsIDIwMDI6CgogICAgIkphdmEgU29mdHdhcmUgdGVjaG5vbG9naWVzIiBtZWFucwoKICAgICAgICBjbGFzc2VzL2phdmEvdXRpbC9BcnJheUxpc3QuamF2YSwgYW5kCiAgICAgICAgY2xhc3Nlcy9qYXZhL3V0aWwvSGFzaE1hcC5qYXZhLgoKICAgIFRoZSBKYXZhIFNvZnR3YXJlIHRlY2hub2xvZ2llcyBhcmUgQ29weXJpZ2h0IChjKSAxOTk0LTIwMDAgU3VuCiAgICBNaWNyb3N5c3RlbXMsIEluYy4gQWxsIHJpZ2h0cyByZXNlcnZlZC4KCiAgICBTdW4gaGVyZWJ5IGdyYW50cyBEb3VnIExlYSBhIG5vbi1leGNsdXNpdmUsIHdvcmxkd2lkZSwgbm9uLXRyYW5zZmVycmFibGUKICAgIGxpY2Vuc2UgdG8gdXNlLCByZXByb2R1Y2UsIGNyZWF0ZSBkZXJpdmF0ZSB3b3JrcyBvZiwgYW5kIGRpc3RyaWJ1dGUgdGhlCiAgICBKYXZhIFNvZnR3YXJlIGFuZCBkZXJpdmF0aXZlIHdvcmtzIHRoZXJlb2YgaW4gc291cmNlIGFuZCBiaW5hcnkgZm9ybXMKICAgIGFzIHBhcnQgb2YgYSBsYXJnZXIgd29yaywgYW5kIHRvIHN1YmxpY2Vuc2UgdGhlIHJpZ2h0IHRvIHVzZSwgcmVwcm9kdWNlCiAgICBhbmQgZGlzdHJpYnV0ZSB0aGUgSmF2YSBTb2Z0d2FyZSBhbmQgRG91ZyBMZWEncyBkZXJpdmF0aXZlIHdvcmtzIGFzIHRoZQogICAgcGFydCBvZiBsYXJnZXIgd29ya3MgdGhyb3VnaCBtdWx0aXBsZSB0aWVycyBvZiBzdWJsaWNlbnNlZXMgcHJvdmlkZWQgdGhhdAogICAgdGhlIGZvbGxvd2luZyBjb25kaXRpb25zIGFyZSBtZXQ6CgogICAgLU5laXRoZXIgdGhlIG5hbWUgb2Ygb3IgdHJhZGVtYXJrcyBvZiBTdW4gbWF5IGJlIHVzZWQgdG8gZW5kb3JzZSBvcgogICAgcHJvbW90ZSBwcm9kdWN0cyBpbmNsdWRpbmcgb3IgZGVyaXZlZCBmcm9tIHRoZSBKYXZhIFNvZnR3YXJlIHRlY2hub2xvZ3kKICAgIHdpdGhvdXQgc3BlY2lmaWMgcHJpb3Igd3JpdHRlbiBwZXJtaXNzaW9uOyBhbmQKICAgIC1SZWRpc3RyaWJ1dGlvbnMgb2Ygc291cmNlIG9yIGJpbmFyeSBjb2RlIG11c3QgY29udGFpbiB0aGUgYWJvdmUKICAgIGNvcHlyaWdodCBub3RpY2UsIHRoaXMgbm90aWNlIGFuZCBhbmQgdGhlIGZvbGxvd2luZyBkaXNjbGFpbWVyczoKCiAgICBUaGlzIHNvZnR3YXJlIGlzIHByb3ZpZGVkICJBUyBJUywiIHdpdGhvdXQgYSB3YXJyYW50eSBvZiBhbnkga2luZC4KICAgIEFMTCBFWFBSRVNTIE9SIElNUExJRUQgQ09ORElUSU9OUywgUkVQUkVTRU5UQVRJT05TIEFORCBXQVJSQU5USUVTLAogICAgSU5DTFVESU5HIEFOWSBJTVBMSUVEIFdBUlJBTlRZIE9GIE1FUkNIQU5UQUJJTElUWSwgRklUTkVTUyBGT1IgQQogICAgUEFSVElDVUxBUiBQVVJQT1NFIE9SIE5PTi1JTkZSSU5HRU1FTlQsIEFSRSBIRVJFQlkgRVhDTFVERUQuIFNVTgogICAgTUlDUk9TWVNURU1TLCBJTkMuIEFORCBJVFMgTElDRU5TT1JTIFNIQUxMIE5PVCBCRSBMSUFCTEUgRk9SIEFOWSBEQU1BR0VTCiAgICBTVUZGRVJFRCBCWSBMSUNFTlNFRSBBUyBBIFJFU1VMVCBPRiBVU0lORywgTU9ESUZZSU5HIE9SIERJU1RSSUJVVElORwogICAgVEhFIFNPRlRXQVJFIE9SIElUUyBERVJJVkFUSVZFUy4gSU4gTk8gRVZFTlQgV0lMTCBTVU4gTUlDUk9TWVNURU1TLCBJTkMuCiAgICBPUiBJVFMgTElDRU5TT1JTIEJFIExJQUJMRSBGT1IgQU5ZIExPU1QgUkVWRU5VRSwgUFJPRklUIE9SIERBVEEsIE9SIEZPUgogICAgRElSRUNULCBJTkRJUkVDVCwgU1BFQ0lBTCwgQ09OU0VRVUVOVElBTCwgSU5DSURFTlRBTCBPUiBQVU5JVElWRSBEQU1BR0VTLAogICAgSE9XRVZFUiBDQVVTRUQgQU5EIFJFR0FSRExFU1MgT0YgVEhFIFRIRU9SWSBPRiBMSUFCSUxJVFksIEFSSVNJTkcgT1VUIE9GCiAgICBUSEUgVVNFIE9GIE9SIElOQUJJTElUWSBUTyBVU0UgU09GVFdBUkUsIEVWRU4gSUYgU1VOIE1JQ1JPU1lTVEVNUywgSU5DLgogICAgSEFTIEJFRU4gQURWSVNFRCBPRiBUSEUgUE9TU0lCSUxJVFkgT0YgU1VDSCBEQU1BR0VTLgoKICAgIFlvdSBhY2tub3dsZWRnZSB0aGF0IFNvZnR3YXJlIGlzIG5vdCBkZXNpZ25lZCxsaWNlbnNlZCBvciBpbnRlbmRlZCBmb3IKICAgIHVzZSBpbiB0aGUgZGVzaWduLCBjb25zdHJ1Y3Rpb24sIG9wZXJhdGlvbiBvciBtYWludGVuYW5jZSBvZiBhbnkgbnVjbGVhcgogICAgZmFjaWxpdHkuCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKWE1MIEFQSSBsaWJyYXJ5LCBvcmcueG1sLnNheCBjbGFzc2VzICh4bWwtYXBpcy0xLjMuMDMuamFyKQoKICAgIFNBWDIgaXMgRnJlZSEKCiAgICBJIGhlcmVieSBhYmFuZG9uIGFueSBwcm9wZXJ0eSByaWdodHMgdG8gU0FYIDIuMCAodGhlIFNpbXBsZSBBUEkgZm9yCiAgICBYTUwpLCBhbmQgcmVsZWFzZSBhbGwgb2YgdGhlIFNBWCAyLjAgc291cmNlIGNvZGUsIGNvbXBpbGVkIGNvZGUsIGFuZAogICAgZG9jdW1lbnRhdGlvbiBjb250YWluZWQgaW4gdGhpcyBkaXN0cmlidXRpb24gaW50byB0aGUgUHVibGljIERvbWFpbi4KICAgIFNBWCBjb21lcyB3aXRoIE5PIFdBUlJBTlRZIG9yIGd1YXJhbnRlZSBvZiBmaXRuZXNzIGZvciBhbnkgcHVycG9zZS4KCiAgICBEYXZpZCBNZWdnaW5zb24sIGRhdmlkQG1lZ2dpbnNvbi5jb20KICAgIDIwMDAtMDUtMDUKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpUaGUgdHVzY2FueS1ob3N0LXdlYmFwcCBhbmQgdHVzY2FueS1zY2EtYXBpIGphcnMgaW5jbHVkZSBmaWxlcyB1bmRlciB0aGUgZm9sbG93aW5nIGxpY2Vuc2U6CgpQZXJtaXNzaW9uIHRvIGNvcHksIGRpc3BsYXkgYW5kIGRpc3RyaWJ1dGUgdGhlIFNlcnZpY2UgQ29tcG9uZW50IEFyY2hpdGVjdHVyZSBTcGVjaWZpY2F0aW9uIGFuZC9vcgpwb3J0aW9ucyB0aGVyZW9mLCB3aXRob3V0IG1vZGlmaWNhdGlvbiwgaW4gYW55IG1lZGl1bSB3aXRob3V0IGZlZSBvciByb3lhbHR5IGlzIGhlcmVieSBncmFudGVkLCBwcm92aWRlZAp0aGF0IHlvdSBpbmNsdWRlIHRoZSBmb2xsb3dpbmcgb24gQUxMIGNvcGllcyBvZiB0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIFNwZWNpZmljYXRpb24sIG9yCnBvcnRpb25zIHRoZXJlb2YsIHRoYXQgeW91IG1ha2U6CgoxLiBBIGxpbmsgb3IgVVJMIHRvIHRoZSBTZXJ2aWNlIENvbXBvbmVudCBBcmNoaXRlY3R1cmUgU3BlY2lmaWNhdGlvbiBhdCB0aGlzIGxvY2F0aW9uOgq3IGh0dHA6Ly93d3cub3NvYS5vcmcvZGlzcGxheS9NYWluL1NlcnZpY2UrQ29tcG9uZW50K0FyY2hpdGVjdHVyZStTcGVjaWZpY2F0aW9ucwoKMi4gVGhlIGZ1bGwgdGV4dCBvZiB0aGUgY29weXJpZ2h0IG5vdGljZSBhcyBzaG93biBpbiB0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIFNwZWNpZmljYXRpb24uCgpCRUEsIENhcGUgQ2xlYXIsIElCTSwgSW50ZXJmYWNlMjEsIElPTkEsIE9yYWNsZSwgUHJpbWV0b24sIFByb2dyZXNzIFNvZnR3YXJlLCBSZWQgSGF0LCBSb2d1ZSBXYXZlLApTQVAsIFNpZW1lbnMsIFNvZnR3YXJlIEFHLiwgU3VuLCBTeWJhc2UsIFRJQkNPIChjb2xsZWN0aXZlbHksIHRoZSAiQXV0aG9ycyIpIGFncmVlIHRvIGdyYW50IHlvdSBhCnJveWFsdHktZnJlZSBsaWNlbnNlLCB1bmRlciByZWFzb25hYmxlLCBub24tZGlzY3JpbWluYXRvcnkgdGVybXMgYW5kIGNvbmRpdGlvbnMgdG8gcGF0ZW50cyB0aGF0IHRoZXkgZGVlbQpuZWNlc3NhcnkgdG8gaW1wbGVtZW50IHRoZSBTZXJ2aWNlIENvbXBvbmVudCBBcmNoaXRlY3R1cmUgU3BlY2lmaWNhdGlvbi4KVEhFIFNlcnZpY2UgQ29tcG9uZW50IEFyY2hpdGVjdHVyZSBTUEVDSUZJQ0FUSU9OIElTIFBST1ZJREVEICJBUyBJUywiIEFORCBUSEUKQVVUSE9SUyBNQUtFIE5PIFJFUFJFU0VOVEFUSU9OUyBPUiBXQVJSQU5USUVTLCBFWFBSRVNTIE9SIElNUExJRUQsClJFR0FSRElORyBUSElTIFNQRUNJRklDQVRJT04gQU5EIFRIRSBJTVBMRU1FTlRBVElPTiBPRiBJVFMgQ09OVEVOVFMsCklOQ0xVRElORywgQlVUIE5PVCBMSU1JVEVEIFRPLCBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSwgRklUTkVTUyBGT1IgQQpQQVJUSUNVTEFSIFBVUlBPU0UsIE5PTi1JTkZSSU5HRU1FTlQgT1IgVElUTEUuClRIRSBBVVRIT1JTIFdJTEwgTk9UIEJFIExJQUJMRSBGT1IgQU5ZIERJUkVDVCwgSU5ESVJFQ1QsIFNQRUNJQUwsIElOQ0lERU5UQUwKT1IgQ09OU0VRVUVOVElBTCBEQU1BR0VTIEFSSVNJTkcgT1VUIE9GIE9SIFJFTEFUSU5HIFRPIEFOWSBVU0UgT1IKRElTVFJJQlVUSU9OIE9GIFRIRSBTZXJ2aWNlIENvbXBvbmVudHMgQXJjaGl0ZWN0dXJlIFNQRUNJRklDQVRJT04uClRoZSBuYW1lIGFuZCB0cmFkZW1hcmtzIG9mIHRoZSBBdXRob3JzIG1heSBOT1QgYmUgdXNlZCBpbiBhbnkgbWFubmVyLCBpbmNsdWRpbmcgYWR2ZXJ0aXNpbmcgb3IKcHVibGljaXR5IHBlcnRhaW5pbmcgdG8gdGhlIFNlcnZpY2UgQ29tcG9uZW50IEFyY2hpdGVjdHVyZSBTcGVjaWZpY2F0aW9uIG9yIGl0cyBjb250ZW50cyB3aXRob3V0IHNwZWNpZmljLAoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KClRoZSB0dXNjYW55LWFzc2VtYmx5LXhzZCBqYXIgaW5jbHVkZXMgZmlsZXMgdW5kZXIgdGhlIGZvbGxvd2luZyBsaWNlbnNlOgoKVzNDriBTT0ZUV0FSRSBOT1RJQ0UgQU5EIExJQ0VOU0UKaHR0cDovL3d3dy53My5vcmcvQ29uc29ydGl1bS9MZWdhbC8yMDAyL2NvcHlyaWdodC1zb2Z0d2FyZS0yMDAyMTIzMQoKVGhpcyB3b3JrIChhbmQgaW5jbHVkZWQgc29mdHdhcmUsIGRvY3VtZW50YXRpb24gc3VjaCBhcyBSRUFETUVzLCBvciBvdGhlciByZWxhdGVkIGl0ZW1zKSAKaXMgYmVpbmcgcHJvdmlkZWQgYnkgdGhlIGNvcHlyaWdodCBob2xkZXJzIHVuZGVyIHRoZSBmb2xsb3dpbmcgbGljZW5zZS4gQnkgb2J0YWluaW5nLCAKdXNpbmcgYW5kL29yIGNvcHlpbmcgdGhpcyB3b3JrLCB5b3UgKHRoZSBsaWNlbnNlZSkgYWdyZWUgdGhhdCB5b3UgaGF2ZSByZWFkLCB1bmRlcnN0b29kLCAKYW5kIHdpbGwgY29tcGx5IHdpdGggdGhlIGZvbGxvd2luZyB0ZXJtcyBhbmQgY29uZGl0aW9ucy4KClBlcm1pc3Npb24gdG8gY29weSwgbW9kaWZ5LCBhbmQgZGlzdHJpYnV0ZSB0aGlzIHNvZnR3YXJlIGFuZCBpdHMgZG9jdW1lbnRhdGlvbiwgd2l0aCBvciAKd2l0aG91dCBtb2RpZmljYXRpb24sIGZvciBhbnkgcHVycG9zZSBhbmQgd2l0aG91dCBmZWUgb3Igcm95YWx0eSBpcyBoZXJlYnkgZ3JhbnRlZCwgcHJvdmlkZWQgCnRoYXQgeW91IGluY2x1ZGUgdGhlIGZvbGxvd2luZyBvbiBBTEwgY29waWVzIG9mIHRoZSBzb2Z0d2FyZSBhbmQgZG9jdW1lbnRhdGlvbiBvciBwb3J0aW9ucyAKdGhlcmVvZiwgaW5jbHVkaW5nIG1vZGlmaWNhdGlvbnM6CgogICAxLiBUaGUgZnVsbCB0ZXh0IG9mIHRoaXMgTk9USUNFIGluIGEgbG9jYXRpb24gdmlld2FibGUgdG8gdXNlcnMgb2YgdGhlIHJlZGlzdHJpYnV0ZWQgb3IgCiAgICAgIGRlcml2YXRpdmUgd29yay4KICAgMi4gQW55IHByZS1leGlzdGluZyBpbnRlbGxlY3R1YWwgcHJvcGVydHkgZGlzY2xhaW1lcnMsIG5vdGljZXMsIG9yIHRlcm1zIGFuZCBjb25kaXRpb25zLiAKICAgICAgSWYgbm9uZSBleGlzdCwgdGhlIFczQyBTb2Z0d2FyZSBTaG9ydCBOb3RpY2Ugc2hvdWxkIGJlIGluY2x1ZGVkIChoeXBlcnRleHQgaXMgcHJlZmVycmVkLAogICAgICB0ZXh0IGlzIHBlcm1pdHRlZCkgd2l0aGluIHRoZSBib2R5IG9mIGFueSByZWRpc3RyaWJ1dGVkIG9yIGRlcml2YXRpdmUgY29kZS4KICAgMy4gTm90aWNlIG9mIGFueSBjaGFuZ2VzIG9yIG1vZGlmaWNhdGlvbnMgdG8gdGhlIGZpbGVzLCBpbmNsdWRpbmcgdGhlIGRhdGUgY2hhbmdlcyB3ZXJlIAogICAgICBtYWRlLiAoV2UgcmVjb21tZW5kIHlvdSBwcm92aWRlIFVSSXMgdG8gdGhlIGxvY2F0aW9uIGZyb20gd2hpY2ggdGhlIGNvZGUgaXMgZGVyaXZlZC4pCgpUSElTIFNPRlRXQVJFIEFORCBET0NVTUVOVEFUSU9OIElTIFBST1ZJREVEICJBUyBJUywiIEFORCBDT1BZUklHSFQgSE9MREVSUyBNQUtFIE5PIApSRVBSRVNFTlRBVElPTlMgT1IgV0FSUkFOVElFUywgRVhQUkVTUyBPUiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPLCBXQVJSQU5USUVTIApPRiBNRVJDSEFOVEFCSUxJVFkgT1IgRklUTkVTUyBGT1IgQU5ZIFBBUlRJQ1VMQVIgUFVSUE9TRSBPUiBUSEFUIFRIRSBVU0UgT0YgVEhFIFNPRlRXQVJFIE9SIApET0NVTUVOVEFUSU9OIFdJTEwgTk9UIElORlJJTkdFIEFOWSBUSElSRCBQQVJUWSBQQVRFTlRTLCBDT1BZUklHSFRTLCBUUkFERU1BUktTIE9SIE9USEVSIApSSUdIVFMuCgpDT1BZUklHSFQgSE9MREVSUyBXSUxMIE5PVCBCRSBMSUFCTEUgRk9SIEFOWSBESVJFQ1QsIElORElSRUNULCBTUEVDSUFMIE9SIENPTlNFUVVFTlRJQUwgCkRBTUFHRVMgQVJJU0lORyBPVVQgT0YgQU5ZIFVTRSBPRiBUSEUgU09GVFdBUkUgT1IgRE9DVU1FTlRBVElPTi4KClRoZSBuYW1lIGFuZCB0cmFkZW1hcmtzIG9mIGNvcHlyaWdodCBob2xkZXJzIG1heSBOT1QgYmUgdXNlZCBpbiBhZHZlcnRpc2luZyBvciBwdWJsaWNpdHkgCnBlcnRhaW5pbmcgdG8gdGhlIHNvZnR3YXJlIHdpdGhvdXQgc3BlY2lmaWMsIHdyaXR0ZW4gcHJpb3IgcGVybWlzc2lvbi4gVGl0bGUgdG8gY29weXJpZ2h0IAppbiB0aGlzIHNvZnR3YXJlIGFuZCBhbnkgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIHdpbGwgYXQgYWxsIHRpbWVzIHJlbWFpbiB3aXRoIGNvcHlyaWdodCAKaG9sZGVycy4KCg==