TEFURVNUIENIQU5HRVMgQkVUV0VFTiAyLjEuMSBhbmQgMi4xLjAKCiAgSS4gSU1QT1JUQU5UIEJVRyBGSVhFUwoKICAgIC0gTWFueSBmb250IGRyaXZlcnMgZGlkbid0IHNlbGVjdCBhIFVuaWNvZGUgY2hhcm1hcCBieSBkZWZhdWx0IHdoZW4KICAgICAgYSBuZXcgZmFjZSB3YXMgb3BlbmVkICh3aXRoIHRoZSBGVF9DT05GSUdfT1BUSU9OX1VTRV9DTUFQUyBvcHRpb25zCiAgICAgIGVuYWJsZWQpLCBhbmQgdGhpcyBjYXVzZWQgbWFueSBhcHBsaWNhdGlvbiB0byBub3QgYmUgYWJsZSB0bwogICAgICBkaXNwbGF5IHRleHQgY29ycmVjdGx5IHdpdGggdGhlIDIuMS54IHJlbGVhc2VzCiAgICAgIAogICAgLSBUaGUgUEZSIGRyaXZlciBoYWQgYSBidWcgaW4gaXRzIGNvbXBvc2l0ZSBsb2FkaW5nIGNvZGUgdGhhdCBwcm9kdWNlcwogICAgICBpbmNvcnJlY3RseSBwbGFjZWQgYWNjZW50cyB3aXRoIG1hbnkgZm9udHMKICAgICAgCiAgICAtIFRoZSBUeXBlNDIgZHJpdmVyIGNyYXNoZWQgc29tZXRpbWVzIGR1ZSB0byBhIG5hc3R5IGJ1ZwogICAgCiAgICAtIFRoZSBUeXBlIDEgY3VzdG9tIGVuY29kaW5nIGNoYXJtYXAgZGlkbid0IGhhbmRsZSB0aGUgY2FzZSB3ZXJlIHRoZQogICAgICBmaXJzdCBnbHlwaCBpbmRleCB3YXNuJ3QgMAoKICAgIC0gQSBzZXJpb3VzIHR5cG8gaW4gdGhlIFRydWVUeXBlIGNvbXBvc2l0ZSBsb2FkZXIgcHJvZHVjZWQgaW5jb3JyZWN0bHkKICAgICAgcGxhY2VkIGdseXBocyBpbiBmb250cyBsaWtlICJXaW5nZGluZ3MiIGFuZCBhIGZldyBvdGhlcnMuLgoKCiAgSUkuIE1JU0NFTExBTkVPVVMKCiAgICAtIFRoZSBXaW4zMiBWaXN1YWwgQysrIHByb2plY3QgZmlsZSBoYXMgYmVlbiB1cGRhdGVkIHRvIGluY2x1ZGUgdGhlCiAgICAgIFBGUiBkcml2ZXIgYXMgd2VsbAoKICAgIC0gImZyZWV0eXBlLm00IiBpcyBub3cgaW5zdGFsbGVkIGJ5IGRlZmF1bHQgYnkgIm1ha2UgaW5zdGFsbCIgb24gVW5peAogICAgICBzeXN0ZW1zLgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CkxBVEVTVCBDSEFOR0VTIEJFVFdFRU4gMi4xLjEgYW5kIDIuMS4wCgogIEkuIElNUE9SVEFOVCBCVUcgRklYRVMKCiAgICAtIFRoZSBgdmVyc2lvbl9pbmZvJyByZXR1cm5lZCBieSBgZnJlZXR5cGUtY29uZmlnJyBpbiAyLjEuMCByZXR1cm5lZCBhbgogICAgICBpbnZhbGlkIHZhbHVlLiBJdCBub3cgcmV0dXJucyA5OjE6MyAoMi4wLjkgcmV0dXJuZWQgOTowOjMpLgoKICAgIC0gVmVyc2lvbiAyLjEuMCBjb3VsZG4ndCBiZSBsaW5rZWQgYWdhaW5zdCBhcHBsaWNhdGlvbnMgb24gV2luMzIgYW5kCiAgICAgIEFtaWdhIHN5c3RlbXMgZHVlIHRvIGEgbmV3IGRlYnVnIGZ1bmN0aW9uIHRoYXQgd2Fzbid0IHByb3Blcmx5CiAgICAgIHByb3BhZ2F0ZWQgdG8gdGhlIHN5c3RlbS1zcGVjaWZpYyBkaXJlY3RvcnkgaW4gYGJ1aWxkcycuCgogICAgLSBWYXJpb3VzIE1hY09TIGFuZCBNYWMgT1MgWCBzcGVjaWZpYyBmaXhlcy4KCiAgICAtIEZpeGVkIGEgYnVnIGluIHRoZSBUcnVlVHlwZSBjaGFybWFwIHZhbGlkYXRpb24gcm91dGluZXMgdGhhdCBtYWRlCiAgICAgIHZlcnNpb24gMi4xLjAgdG9vIHJlc3RyaWN0aXZlIC0tIG1hbnkgcG9wdWxhciBmb250cyBoYXZlIGJlZW4KICAgICAgcmVqZWN0ZWQuCgogICAgLSBUaGVyZSB3YXMgc3RpbGwgYSB2ZXJ5IHNtYWxsIGRpZmZlcmVuY2UgYmV0d2VlbiB0aGUgbW9ub2Nocm9tZSBnbHlwaAogICAgICBiaXRtYXBzIHByb2R1Y2VkIGJ5IEZyZWVUeXBlIDEueCBhbmQgRnJlZVR5cGUgMi54IHdpdGggdGhlIGJ5dGVjb2RlCiAgICAgIGludGVycHJldGVyIGVuYWJsZWQuICBUaGlzIHdhcyBjYXVzZWQgYnkgYW4gaW52YWxpZCBmbGFnIHNldHRpbmcgaW4KICAgICAgdGhlIFRydWVUeXBlIGdseXBoIGxvYWRlciwgbWFraW5nIHRoZSByYXN0ZXJpemVyIGNoYW5nZSBpdHMgZHJvcC1vdXQKICAgICAgY29udHJvbCBtb2RlLiAgTm93IHRoZXJlc3VsdHMgc2hvdWxkIF9yZWFsbHlfIGJlIGNvbXBsZXRlbHkgaWRlbnRpY2FsLgoKICAgIC0gVGhlIFRydWVUeXBlIG5hbWUgdGFibGUgbG9hZGVyIGhhcyBiZWVuIGltcHJvdmVkIHRvIHN1cHBvcnQgbWFueQogICAgICBwb3B1bGFyIHRob3VnaCBidWdneSBBc2lhbiBmb250cy4gIEl0IG5vdyBpZ25vcmVzIGVtcHR5IG5hbWUgZW50cmllcywKICAgICAgaW52YWxpZCBwb2ludGVyIG9mZnNldHMgYW5kIGEgZmV3IG90aGVyIGluY29ycmVjdCBzdWJ0bGV0aWVzLgogICAgICBNb3Jlb3ZlciwgbmFtZSBzdHJpbmdzIGFyZSBub3cgbG9hZGVkIG9uIGRlbWFuZCwgd2hpY2ggcmVkdWNlcyB0aGUKICAgICAgbWVtb3J5IGxvYWQgb2YgbWFueSBmYWNlcyAoZS5nLiB0aGUgQVJJQUwuVFRGIGZvbnQgZmlsZSBjb250YWlucyBhCiAgICAgIDEwa0J5dGUgbmFtZSB0YWJsZSB3aXRoIDcwIG5hbWVzKS4KCiAgICAtIEZpeGVkIGEgYnVnIGluIHRoZSBQb3N0c2NyaXB0IGhpbnRlciB0aGF0IHByZXZlbnRlZCBmYW1pbHkgYmx1ZXMKICAgICAgc3Vic3RpdHV0aW9uIHRvIGhhcHBlbiBjb3JyZWN0bHkuCgoKICBJSS4gTkVXIEZFQVRVUkVTCgogICAgLSBUaHJlZSBuZXcgZm9udCBkcml2ZXJzIGluIHRoaXMgcmVsZWFzZToKCiAgICAgICogQSBCREYgZm9udCBkcml2ZXIsIGNvbnRyaWJ1dGVkIGJ5IEZyYW5jbyBaYXBwYSBOYXJkZWxsaSwgaGVhdmlseQogICAgICAgIG1vZGlmaWVkIGJ5IFdlcm5lciBMZW1iZXJnLiAgSXQgYWxzbyBzdXBwb3J0cyBhbnRpLWFsaWFzZWQgYml0bWFwcwogICAgICAgICh1c2luZyBhIHNsaWdodGx5IGV4dGVuZGVkIEJERiBmb3JtYXQpLgoKICAgICAgKiBBIFR5cGU0MiBmb250IGRyaXZlciwgY29udHJpYnV0ZWQgYnkgUm9iZXJ0byBBbGFtZWRhLiAgSXQgaXMKICAgICAgICBzdGlsbCBleHBlcmltZW50YWwgYnV0IHNlZW1zIHRvIHdvcmsgcmVsYXRpdmVseSB3ZWxsLgoKICAgICAgKiBBIFBGUiBmb250IGRyaXZlciwgY29udHJpYnV0ZWQgYnkgRGF2aWQgVHVybmVyIGhpbXNlbGYuICBJdCBkb2Vzbid0CiAgICAgICAgc3VwcG9ydCBQRlIgaGludGluZyAtLSBub3RlIHRoYXQgQml0U3RyZWFtIGhhcyBhdCBsZWFzdCB0d28gcGF0ZW50cwogICAgICAgIG9uIHRoaXMgZm9ybWF0IQoKCiAgSUlJLiBNSVNDRUxMQU5FT1VTCgogICAgLSBUaGUgY2FjaGUgc3ViLXN5c3RlbSBoYXMgYmVlbiBvcHRpbWl6ZWQgaW4gaW1wb3J0YW50IHdheXMuICBDYWNoZSBoaXRzCiAgICAgIGFyZSBub3cgc2lnbmlmaWNhbnRseSBmYXN0ZXIuICBGb3IgZXhhbXBsZSwgdXNpbmcgdGhlIENNYXAgY2FjaGUgaXMKICAgICAgYWJvdXQgdHdpY2UgZmFzdGVyIHRoYW4gY2FsbGluZyBGVF9HZXRfQ2hhcl9JbmRleCBvbiBtb3N0IHBsYXRmb3Jtcy4gCiAgICAgIFNpbWlsYXJseSwgdXNpbmcgYW4gU0JpdCBjYWNoZSBpcyBhYm91dCBmaXZlIHRpbWVzIGZhc3RlciB0aGFuIGxvYWRpbmcKICAgICAgdGhlIGJpdG1hcHMgZnJvbSBhIGJpdG1hcCBmaWxlLCBhbmQgMzAwIHRvIDUwMCB0aW1lcyBmYXN0ZXIgdGhhbgogICAgICBnZW5lcmF0aW5nIHRoZW0gZnJvbSBhIHNjYWxhYmxlIGZvcm1hdC4KCiAgICAgIE5vdGUgdGhhdCB5b3Ugc2hvdWxkIHJlY29tcGlsZSB5b3VyIHNvdXJjZXMgaWYgeW91IGRlc2lnbmVkIGEgY3VzdG9tCiAgICAgIGNhY2hlIGNsYXNzIGZvciB0aGUgRlQyIENhY2hlIHN1YnN5c3RlbSwgc2luY2UgdGhlIGNoYW5nZXMgcGVyZm9ybWVkCiAgICAgIGFyZSBzb3VyY2UsIGJ1dCBub3QgYmluYXJ5LCBjb21wYXRpYmxlLgoKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKTEFURVNUIENIQU5HRVMgQkVUV0VFTiAyLjEuMCBhbmQgMi4wLjkKCiAgSS4gSU1QT1JUQU5UIEJVRyBGSVhFUwoKICAgIC0gVGhlIFRydWVUeXBlIGJ5dGVjb2RlIGludGVycHJldGVyIGhhcyBiZWVuIGZpeGVkIHRvIHByb2R1Y2UKICAgICAgX2V4YWN0bHlfIHRoZSBzYW1lIG91dHB1dCBhcyBGcmVlVHlwZSAxLnguICBQcmV2aW91cyBkaWZmZXJlbmNlcwogICAgICB3ZXJlIGR1ZSB0byBzbGlnaHRseSBkaXN0aW5jdCBmaXhlZC1wb2ludCBjb21wdXRhdGlvbiByb3V0aW5lcwogICAgICB1c2VkIHRvIHBlcmZvcm0gZG90IHByb2R1Y3RzIGFuZCB2ZWN0b3IgbGVuZ3RoIG1lYXN1cmVtZW50cy4KCiAgICAgIEl0IHNlZW1zIHRoYXQgbmF0aXZlIFRydWVUeXBlIGhpbnRpbmcgaXMgX2V4dHJlbWVseV8gc2Vuc2l0aXZlCiAgICAgIHRvIHJvdW5kaW5nIGVycm9ycy4gIFRoZSByZXF1aXJlZCB2ZWN0b3IgY29tcHV0YXRpb24gcm91dGluZXMgaGF2ZQogICAgICBiZWVuIG9wdGltaXplZCBhbmQgcGxhY2VkIHdpdGhpbiB0aGUgInR0aW50ZXJwLmMiIGZpbGUuCgogICAgLSBGaXhlZCB0aGUgcGFyc2luZyBvZiBhY2NlbGVyYXRvciB0YWJsZXMgaW4gdGhlIFBDRiBmb250IGRyaXZlci4KCiAgICAtIEZpeGVkIHRoZSBUeXBlMSBnbHlwaCBsb2FkZXIgcm91dGluZSB1c2VkIHRvIGNvbXB1dGUgdGhlIGZvbnQncwogICAgICBtYXhpbXVtIGFkdmFuY2Ugd2lkdGguCgogIElJLiBORVcgRkVBVFVSRVMKCiAgICAtIFRoZSBgY29uZmlndXJlJyBzY3JpcHQgdXNlZCBvbiBVbml4IHN5c3RlbXMgaGFzIGJlZW4gbW9kaWZpZWQgdG8KICAgICAgY2hlY2sgdGhhdCBHTlUgTWFrZSBpcyBiZWluZyB1c2VkIHRvIGJ1aWxkIHRoZSBsaWJyYXJ5LiAgT3RoZXJ3aXNlLAogICAgICBpdCB3aWxsIGRpc3BsYXkgYSBtZXNzYWdlIHByb3Bvc2luZyB0byB1c2UgdGhlIEdOVU1BS0UgZW52aXJvbm1lbnQKICAgICAgdmFyaWFibGUgdG8gbmFtZSBpdC4KCiAgICAgIFRoZSBVbml4LXNwZWNpZmljIGZpbGUgUkVBRE1FLlVOWCBoYXMgYmVlbiBtb2RpZmllZCBhY2NvcmRpbmdseS4KCgogIElJSS4gTUlTQ0VMTEFORU9VUwoKICAgIC0gVGhlIEZyZWVUeXBlIExpY2Vuc2UgaW4gYGRvY3MvRlRMLnR4dCcgaGFzIGJlZW4gdXBkYXRlZCB0byBpbmNsdWRlCiAgICAgIGEgcHJvcG9zZWQgcHJlZmVycmVkIGRpc2NsYWltZXIuICBJZiB5b3UgYXJlIHVzaW5nIEZyZWVUeXBlIGluIHlvdXIKICAgICAgcHJvZHVjdHMsIHlvdSBhcmUgZW5jb3VyYWdlZCAoYnV0IG5vdCBtYW5kYXRlZCkgdG8gdXNlIHRoZSBmb2xsb3dpbmcKICAgICAgdGV4dCBpbiB5b3VyIGRvY3VtZW50YXRpb246CgogICAgICAiIiIKICAgICAgICBQb3J0aW9ucyBvZiB0aGlzIHNvZnR3YXJlIGFyZSBjb3B5cmlnaHQgqSAxOTk2LTIwMDIgVGhlIEZyZWVUeXBlCiAgICAgICAgUHJvamVjdCAod3d3LmZyZWV0eXBlLm9yZykuICBBbGwgcmlnaHRzIHJlc2VydmVkLgogICAgICAiIiIKCiAgICAtIFRoZSBkZWZhdWx0IHNpemUgb2YgdGhlIHJlbmRlciBwb29sIGhhcyBiZWVuIHJlZHVjZWQgdG8gMTZrQnl0ZS4KICAgICAgVGhpcyBzaG91bGRuJ3QgcmVzdWx0IGluIGFueSBub3RpY2VhYmxlIHBlcmZvcm1hbmNlIHBlbmFsdHksIHVubGVzcwogICAgICB5b3UgYXJlIHVzaW5nIHRoZSBlbmdpbmUgYXMtaXMgdG8gcmVuZGVyIHZlcnkgbGFyZ2UgYW5kIGNvbXBsZXgKICAgICAgZ2x5cGhzLgoKICAgIC0gVGhlIEZyZWVUeXBlIDIgcmVkZXNpZ24gaGFzIGJlZ3VuLiAgTW9yZSBpbmZvcm1hdGlvbiBjYW4gYmUgZm91bmQKICAgICAgYXQgdGhpcyBVUkw6CgogICAgICAgIGh0dHA6Ly93d3cuZnJlZXR5cGUub3JnL2ZyZWV0eXBlMi9yZWRlc2lnbi5odG1sCgogICAgICBUaGUgZm9sbG93aW5nIGludGVybmFsIGNoYW5nZXMgaGF2ZSBiZWVuIHBlcmZvcm1lZCB3aXRoaW4gdGhlIHNvdXJjZXMKICAgICAgb2YgdGhpcyByZWxlYXNlOgoKICAgICAgICAtIE1hbnkgaW50ZXJuYWwgdHlwZXMgaGF2ZSBiZWVuIHJlbmFtZWQgdG8gaW5jcmVhc2UgY29uc2lzdGVuY3kuCiAgICAgICAgICBUaGUgZm9sbG93aW5nIHNob3VsZCBiZSB0cnVlLCBleGNlcHQgZm9yIHB1YmxpYyB0eXBlczoKCiAgICAgICAgICAgICogQWxsIHN0cnVjdHVyZSB0eXBlcyBoYXZlIGEgbmFtZSBlbmRpbmcgaW4gIlJlYyIgKHNob3J0IGZvcgogICAgICAgICAgICAgIGByZWNvcmQnKS4KCiAgICAgICAgICAgICogQSBwb2ludGVyLXRvLXN0cnVjdHVyZSB0eXBlIGhhcyB0aGUgc2FtZSBuYW1lIGFzIHRoZQogICAgICAgICAgICAgIHN0cnVjdHVyZSwgX3dpdGhvdXRfIHRoZSAiUmVjIiBzdWZmaXguCgogICAgICAgICAgICAgICAgRXhhbXBsZToKCiAgICAgICAgICAgICAgICAgIHR5cGVkZWYgc3RydWN0IEZvb1JlY18KICAgICAgICAgICAgICAgICAgewogICAgICAgICAgICAgICAgICAgIC4uLgoKICAgICAgICAgICAgICAgICAgfSBGb29SZWMsICpGb287CgogICAgICAgIC0gTWFueSBpbnRlcm5hbCBtYWNyb3MgaGF2ZSBiZWVuIHJlbmFtZWQgdG8gaW5jcmVhc2UgY29uc2lzdGVuY3kuCiAgICAgICAgICBUaGUgZm9sbG93aW5nIHNob3VsZCBiZSB0cnVlOgoKICAgICAgICAgICAgKiBBbGwgbWFjcm9zIGhhdmUgYSBuYW1lIGJlZ2lubmluZyB3aXRoICJGVF8iLiAgVGhpcyByZXF1aXJlZAogICAgICAgICAgICAgIGEgZmV3IGNoYW5nZXMgbGlrZQoKICAgICAgICAgICAgICAgIEFMTE9DICAgPT4gRlRfQUxMT0MKICAgICAgICAgICAgICAgIEZSRUUgICAgPT4gRlRfRlJFRQogICAgICAgICAgICAgICAgUkVBTExPQyA9PiBGVF9SRUFMTE9DCgogICAgICAgICAgICAqIEFsbCBtYWNyb3MgYXJlIGNvbXBsZXRlbHkgVVBQRVJDQVNFLiAgVGhpcyByZXF1aXJlZCBhIGZldwogICAgICAgICAgICAgIGNoYW5nZXMgbGlrZToKCiAgICAgICAgICAgICAgICBSRUFEX1Nob3J0ICA9PiBGVF9SRUFEX1NIT1JUCiAgICAgICAgICAgICAgICBORVhUX1Nob3J0ICA9PiBGVF9ORVhUX1NIT1JUCiAgICAgICAgICAgICAgICBHRVRfVUxvbmdMRSA9PiBGVF9HRVRfVUxPTkdfTEUKICAgICAgICAgICAgICAgIE1FTV9TZXQgICAgID0+IEZUX01FTV9TRVQKICAgICAgICAgICAgICAgIE1FTV9Db3B5ICAgID0+IEZUX01FTV9DT1BZCiAgICAgICAgICAgICAgICBldGMuCgogICAgICAgICAgICAqIFdoZW5ldmVyIHBvc3NpYmxlLCBhbGwgbWFjcm8gbmFtZXMgZm9sbG93IHRoZQogICAgICAgICAgICAgIEZUXzxPQkpFQ1Q+XzxNRVRIT0Q+IHBhdHRlcm4uICBGb3IgZXhhbXBsZQoKICAgICAgICAgICAgICAgIEFDQ0VTU19GcmFtZSAgID0+IEZUX0ZSQU1FX0VOVEVSCiAgICAgICAgICAgICAgICBGT1JHRVRfRnJhbWUgICA9PiBGVF9GUkFNRV9FWElUCiAgICAgICAgICAgICAgICBFWFRSQUNUX0ZyYW1lICA9PiBGVF9GUkFNRV9FWFRSQUNUCiAgICAgICAgICAgICAgICBSRUxFQVNFX0ZyYW1lICA9PiBGVF9GUkFNRV9SRUxFQVNFCgogICAgICAgICAgICAgICAgRklMRV9Qb3MgICAgICAgPT4gRlRfU1RSRUFNX1BPUwogICAgICAgICAgICAgICAgRklMRV9TZWVrICAgICAgPT4gRlRfU1RSRUFNX1NFRUsKICAgICAgICAgICAgICAgIEZJTEVfUmVhZCAgICAgID0+IEZUX1NUUkVBTV9SRUFECiAgICAgICAgICAgICAgICBGSUxFX1JlYWRBdCAgICA9PiBGVF9TVFJFQU1fUkVBRF9BVAogICAgICAgICAgICAgICAgUkVBRF9GaWVsZHMgICAgPT4gRlRfU1RSRUFNX1JFQURfRklFTERTCgogICAgICAgIC0gTWFueSBpbnRlcm5hbCBmdW5jdGlvbnMgaGF2ZSBiZWVuIHJlbmFtZWQgdG8gZm9sbG93IHRoZQogICAgICAgICAgRlRfPE9iamVjdD5fPE1ldGhvZD4gcGF0dGVybi4gIEZvciBleGFtcGxlOgoKICAgICAgICAgICAgRlRfU2Vla19TdHJlYW0gICAgICAgPT4gRlRfU3RyZWFtX1NlZWsKICAgICAgICAgICAgRlRfUmVhZF9TdHJlYW1fQXQgICAgPT4gRlRfU3RyZWFtX1JlYWRBdAogICAgICAgICAgICBGVF9Eb25lX1N0cmVhbSAgICAgICA9PiBGVF9TdHJlYW1fQ2xvc2UKICAgICAgICAgICAgRlRfTmV3X1N0cmVhbSAgICAgICAgPT4gRlRfU3RyZWFtX09wZW4KICAgICAgICAgICAgRlRfTmV3X01lbW9yeV9TdHJlYW0gPT4gRlRfU3RyZWFtX09wZW5NZW1vcnkKICAgICAgICAgICAgRlRfRXh0cmFjdF9GcmFtZSAgICAgPT4gRlRfU3RyZWFtX0V4dHJhY3RGcmFtZQoKICAgICAgICAgIE5vdGUgdGhhdCBtZXRob2QgbmFtZXMgZG8gbm90IGNvbnRhaW4gIl8iLgoKICAgICAgICAtIFRoZSBGVF9BTExPQ19BUlJBWSBhbmQgRlRfUkVBTExPQ19BUlJBWSBoYXZlIGJlZW4gcmVwbGFjZWQKICAgICAgICAgIHdpdGggRlRfTkVXX0FSUkFZIGFuZCBGVF9SRU5FV19BUlJBWSB3aGljaCBkbyBub3QgdGFrZSBhIHR5cGUKICAgICAgICAgIGFzIHRoZSBmb3VydGggYXJndW1lbnQuICBJbnN0ZWFkLCB0aGUgYXJyYXkgZWxlbWVudCB0eXBlIHNpemUKICAgICAgICAgIGlzIGNvbXB1dGVkIGF1dG9tYXRpY2FsbHkgZnJvbSB0aGUgdHlwZSBvZiB0aGUgdGFyZ2V0IHBvaW50ZXIKICAgICAgICAgIHVzZWQuCgogICAgICAgIC0gQSBuZXcgb2JqZWN0IGNsYXNzLCBGVF9DTWFwLCBoYXMgYmVlbiBpbnRyb2R1Y2VkLiAgVGhlc2UKICAgICAgICAgIGludGVybmFsIG9iamVjdHMgYXJlIHVzZWQgdG8gbW9kZWwgY2hhcmFjdGVyIG1hcHMuICBUaGlzIGVhc2VzCiAgICAgICAgICB0aGUgc3VwcG9ydCBvZiBhZGRpdGlvbmFsIGNoYXJtYXAgdHlwZXMgd2l0aGluIHRoZSBlbmdpbmUuCgogICAgICAgIC0gQSBuZXcgY29uZmlndXJhdGlvbiBmaWxlIG5hbWVkICJmdHN0ZGxpYi5oIiBoYXMgYmVlbiBhZGRlZAogICAgICAgICAgdG8gYGluY2x1ZGUvZnJlZXR5cGUvY29uZmlnJy4gIEl0IGlzIHVzZWQgdG8gZGVmaW5lIGFsaWFzZXMKICAgICAgICAgIGZvciBfZXZlcnlfIHJvdXRpbmUgb2YgdGhlIElTTyBDIGxpYnJhcnkgdGhhdCB0aGUgZm9udCBlbmdpbmUKICAgICAgICAgIHVzZXMuICBFYWNoIGFsaWFzZXMgaGFzIGEgImZ0XyIgcHJlZml4IChlLmcuICJmdF9zdHJsZW4iIGlzIGFuCiAgICAgICAgICBhbGlhcyBmb3IgInN0cmxlbiIpLgoKICAgICAgICAgIFRoaXMgaXMgdXNlZCB0byBlYXNlIHRoZSBwb3J0aW5nIG9mIEZyZWVUeXBlIDIgdG8gZXhvdGljIHJ1bnRpbWUKICAgICAgICAgIGVudmlyb25tZW50cyB3aGVyZSB0aGUgSVNPIEMgTGlicmFyeSBpc24ndCBhdmFpbGFibGUgKGUuZy4KICAgICAgICAgIFhGcmVlODYgZXh0ZW5zaW9uIG1vZHVsZXMpLgoKICAgICAgTW9yZSBkZXRhaWxzIGFyZSBhdmFpbGFibGUgaW4gdGhlICJDaGFuZ2VMb2ciIGZpbGUuCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKTEFURVNUIENIQU5HRVMgQkVUV0VFTiAyLjAuOSBhbmQgMi4wLjgKCiAgSS4gSU1QT1JUQU5UIEJVRyBGSVhFUwoKICAgIC0gQ2VydGFpbiBmb250cyBsaWtlICJmb3hqdW1wLnR0ZiIgY29udGFpbiBicm9rZW4gbmFtZSB0YWJsZXMgd2l0aAogICAgICBpbnZhbGlkIGVudHJpZXMgYW5kIHdpbGQgb2Zmc2V0cy4gIFRoaXMgY2F1c2VkIEZyZWVUeXBlIHRvIGNyYXNoIHdoZW4KICAgICAgdHJ5aW5nIHRvIGxvYWQgdGhlbS4KCiAgICAgIFRoZSBTRk5UIGBuYW1lJyB0YWJsZSBsb2FkZXIgaGFzIGJlZW4gZml4ZWQgdG8gYmUgYWJsZSB0byBzdXBwb3J0CiAgICAgIHRoZXNlIHN0cmFuZ2UgZm9udHMuCgogICAgICBNb3Jlb3ZlciwgdGhlIGNvZGUgaW4gY2hhcmdlIG9mIHByb2Nlc3NpbmcgdGhpcyB0YWJsZSBoYXMgYmVlbiBjaGFuZ2VkCiAgICAgIHRvIGFsd2F5cyBmYXZvdXIgV2luZG93cy1mb3JtYXR0ZWQgZW50cmllcyBvdmVyIG90aGVyIG9uZXMuICBIZW5jZSwgYQogICAgICBmb250IHRoYXQgd29ya3Mgb24gV2luZG93cyBidXQgbm90IG9uIHRoZSBNYWMgd2lsbCBsb2FkIGNsZWFubHkgaW4KICAgICAgRnJlZVR5cGUgYW5kIHJlcG9ydCBhY2N1cmF0ZSB2YWx1ZXMgZm9yIEZhbWlseSAmIFBvc3RTY3JpcHQgbmFtZXMuCgogICAgLSBUaGUgQ0lEIGZvbnQgZHJpdmVyIGhhcyBiZWVuIGZpeGVkLiAgSXQgdW5mb3J0dW5hdGVseSByZXR1cm5lZCBhCiAgICAgIFBvc3RzY3JpcHQgRm9udCBuYW1lIHdpdGggYSBsZWFkaW5nIHNsYXNoLCBhcyBpbgogICAgICAiL011bmh3YUdvdGhpYy1SZWd1bGFyIi4KCiAgICAtIEZyZWVUeXBlIDIgc2hvdWxkIG5vdyBjb21waWxlIGZpbmUgb24gQUlYIDQuMy4zIGFzIGEgc2hhcmVkIGxpYnJhcnkuCgogICAgLSBBIGJ1ZyBpbiB0aGUgUG9zdHNjcmlwdCBoaW50ZXIgaGFzIGJlZW4gZm91bmQgYW5kIGZpeGVkLCByZW1vdmluZwogICAgICB1bi1ldmVuIHN0ZW0gd2lkdGhzIGF0IHNtYWxsIHBpeGVsIHNpemVzIChsaWtlIDE0LTE3KS4KCiAgICAgIFRoaXMgaW1wcm92ZXMgdGhlIHF1YWxpdHkgb2YgYSBjZXJ0YWluIG51bWJlciBvZiBQb3N0c2NyaXB0IGZvbnRzLgoKCiAgSUkuIE5FVyBGRUFUVVJFUwoKICAgIC0gQSBuZXcgZnVuY3Rpb24gbmFtZWQgYEZUX0xpYnJhcnlfVmVyc2lvbicgaGFzIGJlZW4gYWRkZWQgdG8gcmV0dXJuCiAgICAgIHRoZSBjdXJyZW50IGxpYnJhcnkncyBtYWpvciwgbWlub3IsIGFuZCBwYXRjaCB2ZXJzaW9uIG51bWJlcnMuICBUaGlzCiAgICAgIGlzIGltcG9ydGFudCBzaW5jZSB0aGUgbWFjcm9zIEZSRUVUWVBFX01BSk9SLCBGUkVFVFlQRV9NSU5PUiwgYW5kCiAgICAgIEZSRUVUWVBFX1BBVENIIGNhbm5vdCBiZSB1c2VkIHdoZW4gdGhlIGxpYnJhcnkgaXMgZHluYW1pY2FsbHkgbGlua2VkCiAgICAgIGJ5IGEgcHJvZ3JhbS4KCiAgICAtIFR3byBuZXcgQVBJcyBoYXZlIGJlZW4gYWRkZWQ6IGBGVF9HZXRfRmlyc3RfQ2hhcicgYW5kCiAgICAgIGBGVF9HZXRfTmV4dF9DaGFyJy4KCiAgICAgIFRvZ2V0aGVyLCB0aGVzZSBjYW4gYmUgdXNlZCB0byBpdGVyYXRlIGVmZmljaWVudGx5IG92ZXIgdGhlIGN1cnJlbnRseQogICAgICBzZWxlY3RlZCBjaGFybWFwIG9mIGEgZ2l2ZW4gZmFjZS4gIFJlYWQgdGhlIEFQSSByZWZlcmVuY2UgZm9yIG1vcmUKICAgICAgZGV0YWlscy4KCgogIElJSS4gTUlTQ0VMTEFORU9VUwoKICAgIC0gVGhlIEZyZWVUeXBlIHNvdXJjZXMgYXJlIHVuZGVyIGhlYXZ5IGludGVybmFsIHJlLWZhY3RvcmluZy4gIEFzIGEKICAgICAgY29uc2VxdWVuY2UsIHdlIGhhdmUgY3JlYXRlZCBhIGJyYW5jaCBuYW1lZCAiU1RBQkxFIiBvbiB0aGUgQ1ZTIHRvCiAgICAgIGhvbGQgYWxsIGZ1dHVyZSByZWxlYXNlcy9maXhlcyBpbiB0aGUgMi4wLnggZmFtaWx5LgoKICAgICAgVGhlIEhFQUQgYnJhbmNoIG5vdyBjb250YWlucyB0aGUgcmUtZmFjdG9yZWQgc291cmNlcyBhbmQgc2hvdWxkbid0IGJlCiAgICAgIHVzZWQgZm9yIHRlc3Rpbmcgb3IgcGFja2FnaW5nIG5ldyByZWxlYXNlcy4gIEluIGNhc2UgeW91IHdvdWxkIGxpa2UKICAgICAgdG8gYWNjZXNzIHRoZSAyLjAuOSBzb3VyY2VzIGZyb20gb3VyIENWUyByZXBvc2l0b3J5LCB1c2UgdGhlIHRhZwogICAgICBgVkVSLTItMC05Jy4KCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpMQVRFU1QgQ0hBTkdFUyBCRVRXRUVOIDIuMC44IGFuZCAyLjAuNwoKICBJLiBJTVBPUlRBTlQgQlVHIEZJWEVTCgogICAgLSBUaGVyZSB3YXMgYSBzbWFsbCBidXQgbmFzdHkgYnVnIGluICJmcmVldHlwZS1jb25maWcuaW4iIHdoaWNoCiAgICAgIGNhdXNlZCB0aGUgImZyZWV0eXBlLWNvbmZpZyIgc2NyaXB0IHRvIGZhaWwgb24gVW5peC4KCiAgICAgIFRoaXMgZGlkbid0IHByZXZlbnQgdGhlIGluc3RhbGxhdGlvbiBvZiB0aGUgbGlicmFyeSBvciBldmVuCiAgICAgIGl0cyBleGVjdXRpb24sIGJ1dCBjYXVzZWQgcHJvYmxlbXMgd2hlbiB0cnlpbmcgdG8gY29tcGlsZSBtYW55CiAgICAgIFVuaXggcGFja2FnZXMgdGhhdCBkZXBlbmQgb24gaXQuCgogICAgLSBTb21lIFRydWVUeXBlIG9yIE9wZW5UeXBlIGZvbnRzIGVtYmVkZGVkIGluIFBERiBkb2N1bWVudHMgZG8KICAgICAgbm90IGhhdmUgYSAnY21hcCcsICdwb3N0JyBhbmQgJ25hbWUnIGFzIGlzIHJlcXVpcmVkIGJ5IHRoZQogICAgICBzcGVjaWZpY2F0aW9uLiAgRnJlZVR5cGUgbm8gbG9uZ2VyIHJlZnVzZXMgdG8gbG9hZCBzdWNoIGZvbnRzLgoKICAgIC0gdmFyaW91cyBmaXhlcyB0byB0aGUgUENGIGZvbnQgZHJpdmVyCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKTEFURVNUIENIQU5HRVMgQkVUV0VFTiAyLjAuNyBhbmQgMi4wLjYKCiAgSS4gSU1QT1JUQU5UIEJVRyBGSVhFUwoKICAgIC0gRml4ZWQgdHdvIGJ1Z3MgaW4gdGhlIFR5cGUgMSBmb250IGRyaXZlci4gIFRoZSBmaXJzdCBvbmUgcmVzdWx0ZWQgaW4gYQogICAgICBtZW1vcnkgbGVhayBpbiBzdWJ0bGUgY2FzZXMuICBUaGUgb3RoZXIgb25lIGNhdXNlZCBGcmVlVHlwZSB0byBjcmFzaAogICAgICB3aGVuIHRyeWluZyB0byBsb2FkICIuZ3NmIiBmaWxlcyAoR2hvc3RzY3JpcHQgc28tY2FsbGVkIFBvc3RzY3JpcHQKICAgICAgZm9udHMpLgoKICAgICAgKFRoaXMgbWFkZSBfbWFueV8gS0RFIGFwcGxpY2F0aW9ucyBjcmFzaCBvbiBjZXJ0YWluIHN5c3RlbXMuICBGcmVlVHlwZQogICAgICAgX2lzXyBiZWNvbWluZyBhIGNyaXRpY2FsIHN5c3RlbSBjb21wb25lbnQgb24gTGludXggOi0pCgogICAgLSBGaXhlZCBhIG1lbW9yeSBsZWFrIGluIHRoZSBDRkYgZm9udCBkcml2ZXIuCgogICAgLSBGaXhlZCBhIG1lbW9yeSBsZWFrIGluIHRoZSBQQ0YgZm9udCBkcml2ZXIuCgogICAgLSBGaXhlZCB0aGUgVmlzdWFsIEMrKyBwcm9qZWN0IGZpbGUgImJ1aWxkcy93aW4zMi92aXN1YWxjL2ZyZWV0eXBlLmRzcCIKICAgICAgc2luY2UgaXQgZGlkbid0IGluY2x1ZGUgdGhlIFBvc3RzY3JpcHQgaGludGVyIGNvbXBvbmVudCwgY2F1c2luZwogICAgICBlcnJvcnMgYXQgYnVpbGQgdGltZS4KCiAgICAtIEZpeGVkIGEgc21hbGwgcmVuZGVyaW5nIGJ1ZyBpbiB0aGUgYW50aS1hbGlhc2VkIHJlbmRlcmVyIHRoYXQgb25seQogICAgICBvY2N1cnJlZCB3aGVuIHRyeWluZyB0byBkcmF3IHRoaW4gKGxlc3MgdGhhbiAxIHBpeGVsKSBzdHJva2VzLgoKICAgIC0gRml4ZWQgImJ1aWxkcy91bml4L2ZyZWV0eXBlMi5hNCIgd2hpY2ggaXMgdXNlZCB0byBnZW5lcmF0ZSBhIHZhbGlkCiAgICAgICJmcmVldHlwZTIubTQiIGZvciB1c2Ugd2l0aCBhdXRvY29uZi4KCiAgICAtIEZpeGVkIHRoZSBPcGVuVk1TIE1ha2VmaWxlcy4KCgogIElJLiBNSVNDRUxMQU5FT1VTCgogICAgLSBBZGRlZCAiY29uZmlndXJlIiBhbmQgImluc3RhbGwiIHNjcmlwdHMgdG8gdGhlIHRvcC1sZXZlbCBkaXJlY3RvcnkuCiAgICAgIEEgR05VLXN0eWxlIGluc3RhbGxhdGlvbiBpcyB0aHVzIG5vdyBlYXNpbHkgcG9zc2libGUgd2l0aAoKICAgICAgICAgIC4vY29uZmlndXJlICA8b3B0aW9ucz4KICAgICAgICAgIG1ha2UKICAgICAgICAgIG1ha2UgaW5zdGFsbAoKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCkxBVEVTVCBDSEFOR0VTIEJFVFdFRU4gMi4wLjYgYW5kIDIuMC41CgogIEkuIElNUE9SVEFOVCBCVUcgRklYRVMKCiAgICAtIEl0IHdhc24ndCBwb3NzaWJsZSB0byBsb2FkIGVtYmVkZGVkIGJpdG1hcHMgd2hlbiB0aGUgYXV0by1oaW50ZXIgd2FzCiAgICAgIHVzZWQuICBUaGlzIGlzIG5vdyBmaXhlZC4KCiAgICAtIFRoZSBUcnVlVHlwZSBmb250IGRyaXZlciBkaWRuJ3QgbG9hZCBzb21lIGNvbXBvc2l0ZXMgcHJvcGVybHkgKHRoZQogICAgICBzdWItZ2x5cGhzIHdlcmUgc2xpZ2h0bHkgc2hpZnRlZCwgYW5kIHRoaXMgd2FzIG9ubHkgbm90aWNlYWJsZSB3aGVuCiAgICAgIHVzaW5nIG1vbm9jaHJvbWUgcmVuZGVyaW5nKS4KCiAgICAtIFZhcmlvdXMgZml4ZXMgdG8gdGhlIGF1dG8taGludGVyLiAgVGhleSBtZXJlbHkgaW1wcm92ZSB0aGUgb3V0cHV0IG9mCiAgICAgIHNhbnMtc2VyaWYgZm9udHMuICBOb3RlIHRoYXQgdGhlcmUgYXJlIHN0aWxsIHByb2JsZW1zIHdpdGggc2VyaWZlZAogICAgICBmb250cyBhbmQgY29tcG9zaXRlcyAoYWNjZW50ZWQgY2hhcmFjdGVycykuCgogICAgLSBBbGwgc2NhbGFibGUgZm9udCBkcml2ZXJzIGVycm9uZW91c2x5IHJldHVybmVkIHVuLWZpdHRlZCBnbHlwaAogICAgICBhZHZhbmNlcyB3aGVuIGhpbnRpbmcgd2FzIHJlcXVlc3RlZC4gIFRoaXMgY3JlYXRlZCBwcm9ibGVtcyBmb3IgYQogICAgICBudW1iZXIgb2YgbGF5b3V0IGFwcGxpY2F0aW9ucy4gIFRoaXMgaXMgYSB2ZXJ5IG9sZCBidWcgdGhhdCBnb3QKICAgICAgdW5kZXRlY3RlZCBtYWlubHkgYmVjYXVzZSBtb3N0IHRlc3QvZGVtbyBwcm9ncmFtIHBlcmZvcm0gcm91bmRpbmcKICAgICAgZXhwbGljaXRseSBvciBpbXBsaWNpdGx5ICh0aHJvdWdoIHRoZSBjYWNoZSkuCgogICAgLSBGVF9HbHlwaF9Ub19CaXRtYXAoKSBkaWQgZXJyb25lb3VzbHkgbW9kaWZ5IHRoZSBzb3VyY2UgZ2x5cGggaW4KICAgICAgY2VydGFpbiBjYXNlcy4KCiAgICAtICJnbG5hbWVzLnB5IiBzdGlsbCBjb250YWluZWQgYSBidWcgdGhhdCBtYWRlIEZyZWVUeXBlIHJldHVybiBpbnZhbGlkCiAgICAgIG5hbWVzIGZvciBjZXJ0YWluIGdseXBocy4KCiAgICAtIFRoZSBsaWJyYXJ5IGNyYXNoZWQgd2hlbiBsb2FkaW5nIGNlcnRhaW4gVHlwZSAxIGZvbnRzIGxpa2UgInNhZG4ucGZiIgogICAgICAoIlN0YWxpbmdyYWQgTm9ybWFsIiksIHdoaWNoIGFwcGVhciB0byBjb250YWluIHBhdGhldGljIGZvbnQgaW5mbwogICAgICBkaWN0aW9uYXJpZXMuCgogICAgLSBUaGUgVHJ1ZVR5cGUgZ2x5cGggbG9hZGVyIGlzIG5vdyBtdWNoIG1vcmUgcGFyYW5vaWQgYW5kIGNoZWNrcyBldmVyeXRoaW5nCiAgICAgIHdoZW4gbG9hZGluZyBhIGdpdmVuIGdseXBoIGltYWdlLiAgVGhpcyB3YXMgbmVjZXNzYXJ5IHRvIGF2b2lkCiAgICAgIHByb2JsZW1zIChjcmFzaGVzIGFuZC9vciBtZW1vcnkgb3ZlcndyaXRlcykgd2l0aCBicm9rZW4gZm9udHMgdGhhdAogICAgICBjYW1lIGZyb20gYSByZWFsbHkgYnVnZ3kgYXV0b21hdGljIGZvbnQgY29udmVydGVyLgoKCiAgSUkuIElNUE9SVEFOVCBVUERBVEVTIEFORCBORVcgRkVBVFVSRVMKCiAgICAtIEltcG9ydGFudCB1cGRhdGVzIHRvIHRoZSBNYWMtc3BlY2lmaWMgcGFydHMgb2YgdGhlIGxpYnJhcnkuCgogICAgLSBUaGUgY2FjaGluZyBzdWItc3lzdGVtIGhhcyBiZWVuIGNvbXBsZXRlbHkgcmUtZGVzaWduZWQsIGFuZCBpdHMgQVBJCiAgICAgIGhhcyBldm9sdmVkICh0aGUgb2xkIG9uZSBpcyBzdGlsbCBzdXBwb3J0ZWQgZm9yIGJhY2t3YXJkcwogICAgICBjb21wYXRpYmlsaXR5KS4KCiAgICAgIFRoZSBkb2N1bWVudGF0aW9uIGZvciBpdCBpcyBub3QgeWV0IGNvbXBsZXRlZCwgc29ycnkuICBGb3Igbm93LCB5b3UKICAgICAgYXJlIGVuY291cmFnZWQgdG8gY29udGludWUgdXNpbmcgdGhlIG9sZCBBUEkuICBIb3dldmVyLCB0aGUgZnR2aWV3CiAgICAgIGRlbW8gcHJvZ3JhbSBpbiB0aGUgZnQyZGVtb3MgcGFja2FnZSBoYXMgYWxyZWFkeSBiZWVuIHVwZGF0ZWQgdG8gdXNlCiAgICAgIHRoZSBuZXcgY2FjaGluZyBmdW5jdGlvbnMuCgogICAgLSBBIG5ldyBjaGFybWFwIGNhY2hlIGlzIHByb3ZpZGVkIHRvby4gIFNlZSBGVENfQ01hcENhY2hlKCkuICBUaGlzIGlzCiAgICAgIHVzZWZ1bCB0byBwZXJmb3JtIGNoYXJhY3RlciBjb2RlIC0+IGdseXBoIGluZGV4IHRyYW5zbGF0aW9ucyBxdWlja2x5LAogICAgICB3aXRob3V0IHRoZSBuZWVkIGZvciBhbiBvcGVuZWQgRlRfRmFjZS4KCiAgICAtIEEgTkVXIFBPU1RTQ1JJUFQgSElOVEVSIG1vZHVsZSBoYXMgYmVlbiBhZGRlZCB0byBzdXBwb3J0IG5hdGl2ZSBoaW50cwogICAgICBpbiB0aGUgZm9sbG93aW5nIGZvcm1hdHM6IFBvc3RTY3JpcHQgVHlwZSAxLCBQb3N0U2NyaXB0IENJRCwgYW5kCiAgICAgIENGRi9DRUYuCgogICAgICBQbGVhc2UgdGVzdCEgIE5vdGUgdGhhdCB0aGUgYXV0by1oaW50ZXIgcHJvZHVjZXMgYmV0dGVyIHJlc3VsdHMgZm9yIGEKICAgICAgbnVtYmVyIG9mIGJhZGx5LWhpbnRlZCBmb250cyAobW9zdGx5IGF1dG8tZ2VuZXJhdGVkIG9uZXMpIHRob3VnaC4KCiAgICAtIEEgbWVtb3J5IGRlYnVnZ2VyIGlzIG5vdyBwYXJ0IG9mIHRoZSBzdGFuZGFyZCBGcmVlVHlwZSBzb3VyY2VzLiAgVG8KICAgICAgZW5hYmxlIGl0LCBkZWZpbmUgRlRfREVCVUdfTUVNT1JZIGluIDxmcmVldHlwZS9jb25maWcvZnRvcHRpb24uaD4sIGFuZAogICAgICByZWNvbXBpbGUgdGhlIGxpYnJhcnkuCgogICAgICBBZGRpdGlvbmFsbHksIGRlZmluZSB0aGUgX2Vudmlyb25tZW50XyB2YXJpYWJsZSBGVF9ERUJVR19NRU1PUlkgYW5kCiAgICAgIHJ1biBhbnkgcHJvZ3JhbSB1c2luZyBGcmVlVHlwZS4gIFdoZW4gdGhlIGxpYnJhcnkgaXMgZXhpdGVkLCBhIHN1bW1hcnkKICAgICAgb2YgbWVtb3J5IGZvb3RwcmludHMgYW5kIHBvc3NpYmxlIGxlYWtzIHdpbGwgYmUgZGlzcGxheWVkLgoKICAgICAgVGhpcyB3b3JrcyB0cmFuc3BhcmVudGx5IHdpdGggX2FueV8gcHJvZ3JhbSB0aGF0IHVzZXMgRnJlZVR5cGUuCiAgICAgIEhvd2V2ZXIsIHlvdSB3aWxsIG5lZWQgYSBsb3Qgb2YgbWVtb3J5IHRvIHVzZSB0aGlzIChhbGxvY2F0ZWQgYmxvY2tzCiAgICAgIGFyZSBuZXZlciByZWxlYXNlZCB0byB0aGUgaGVhcCB0byBkZXRlY3QgZG91YmxlIGRlbGV0ZXMgZWFzaWx5KS4KCgogIElJSS4gTUlTQ0VMTEFORU9VUwoKICAgIC0gV2UgYXJlIGF3YXJlIG9mIHN1YnRsZSBkaWZmZXJlbmNlcyBiZXR3ZWVuIHRoZSBvdXRwdXQgb2YgRnJlZVR5cGUKICAgICAgdmVyc2lvbnMgMSBhbmQgMiB3aGVuIGl0IGNvbWVzIHRvIG1vbm9jaHJvbWUgVHJ1ZVR5cGUtaGludGVkIGdseXBocy4KICAgICAgVGhlc2UgYXJlIG1vc3QgcHJvYmFibHkgZHVlIHRvIHNtYWxsIGRpZmZlcmVuY2VzIGluIHRoZSBtb25vY2hyb21lCiAgICAgIHJhc3Rlcml6ZXJzIGFuZCB3aWxsIGJlIHdvcmtlZCBvdXQgaW4gYW4gdXBjb21pbmcgcmVsZWFzZS4KCiAgICAtIFdlIGhhdmUgZGVjaWRlZCB0byBmb3JrIHRoZSBzb3VyY2VzIGluIGEgInN0YWJsZSIgYnJhbmNoLCBhbmQgYW4KICAgICAgInVuc3RhYmxlIiBvbmUsIHNpbmNlIEZyZWVUeXBlIGlzIGJlY29taW5nIGEgY3JpdGljYWwgY29tcG9uZW50IG9mCiAgICAgIG1hbnkgVW5peCBzeXN0ZW1zLgoKICAgICAgVGhlIG5leHQgYnVnLWZpeCByZWxlYXNlcyBvZiB0aGUgbGlicmFyeSB3aWxsIGJlIG5hbWVkIDIuMC43LCAyLjAuOCwKICAgICAgZXRjLiwgd2hpbGUgdGhlICIyLjEiIGJyYW5jaCB3aWxsIGNvbnRhaW4gYSB2ZXJzaW9uIG9mIHRoZSBzb3VyY2VzCiAgICAgIHdoZXJlIHdlIHdpbGwgc3RhcnQgbWFqb3IgcmV3b3JraW5nIG9mIHRoZSBsaWJyYXJ5J3MgaW50ZXJuYWxzLCBpbgogICAgICBvcmRlciB0byBwcm9kdWNlIEZyZWVUeXBlIDIuMi4wIChvciBldmVuIDMuMCkgaW4gYSBtb3JlIGRpc3RhbnQKICAgICAgZnV0dXJlLgoKICAgICAgV2UgYWxzbyBob3BlIHRoYXQgdGhpcyBzY2hlbWUgd2lsbCBhbGxvdyBtdWNoIG1vcmUgZnJlcXVlbnQgcmVsZWFzZXMKICAgICAgdGhhbiBpbiB0aGUgcGFzdC4KCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpMQVRFU1QgQ0hBTkdFUyBCRVRXRUVOIDIuMC41IGFuZCAyLjAuNAoKICBOT1RFIFRIQVQgMi4wLjUgRE9FUyBOT1QgQ09OVEFJTiBUSEUgUE9TVFNDUklQVCBISU5URVIuICBUSElTIE1PRFVMRSBXSUxMCiAgQkUgUEFSVCBPRiBUSEUgTkVYVCBSRUxFQVNFIChFSVRIRVIgMi4wLjYgb3IgMi4xKQoKICAtIEZpeGVkIGEgYnVnIHRoYXQgbWFkZSBjZXJ0YWluIGdseXBocywgbGlrZSAiQ2FjdXRlIiwgImNhY3V0ZSIgYW5kCiAgICAibHNsYXNoIiB1bmF2YWlsYWJsZSBmcm9tIFVuaWNvZGUgY2hhcm1hcHMgb2YgUG9zdHNjcmlwdCBmb250cy4gIFRoaXMKICAgIHByZXZlbnRlZCB0aGUgY29ycmVjdCBkaXNwbGF5IG9mIFBvbGlzaCB0ZXh0LCBmb3IgZXhhbXBsZS4KCiAgLSBUaGUga2VybmluZyB0YWJsZSBvZiBUeXBlIDEgZm9udHMgd2FzIGxvYWRlZCBieSBGcmVlVHlwZSwgd2hlbiBpdHMgQUZNCiAgICBmaWxlIHdhcyBhdHRhY2hlZCB0byBpdHMgZmFjZSwgYnV0IHRoZSBGVF9GQUNFX0ZMQUdfSEFTX0tFUk5JTkcgYml0CiAgICBmbGFncyB3YXMgbm90IHNldCBjb3JyZWN0bHksIHByZXZlbnRpbmcgRlRfR2V0X0tlcm5pbmcgdG8gcmV0dXJuCiAgICBtZWFuaW5nZnVsIHZhbHVlcy4KCiAgLSBJbXByb3ZlZCBTRk5UIChUcnVlVHlwZSAmIE9wZW5UeXBlKSBjaGFybWFwIHN1cHBvcnQuICBTbGlnaHRseSBiZXR0ZXIKICAgIHBlcmZvcm1hbmNlLCBhcyB3ZWxsIGFzIHN1cHBvcnQgZm9yIHRoZSBuZXcgZm9ybWF0cyBkZWZpbmVkIGJ5IHRoZQogICAgT3BlblR5cGUgMS4zIHNwZWNpZmljYXRpb24gKDgsIDEwLCBhbmQgMTIpCgogIC0gRml4ZWQgYSBzZXJpb3VzIHR5cG8gaW4gInNyYy9iYXNlL2Z0Y2FsYy5jIiB3aGljaCBjYXVzZWQgaW52YWxpZAogICAgY29tcHV0YXRpb25zIGluIGNlcnRhaW4gcmFyZSBjYXNlcywgcHJvZHVjaW5nIHVnbHkgYXJ0ZWZhY3RzLgoKICAtIFRoZSBzaXplIG9mIHRoZSBFTSBzcXVhcmUgaXMgY29tcHV0ZWQgd2l0aCBhIG1vcmUgYWNjdXJhdGUgYWxnb3JpdGhtCiAgICBmb3IgUG9zdHNjcmlwdCBmb250cy4gIFRoZSBvbGQgb25lIGNhdXNlZCBzbGlnaHQgZXJyb3JzIHdpdGggZW1iZWRkZWQKICAgIGZvbnRzIGZvdW5kIGluIFBERiBkb2N1bWVudHMuCgogIC0gRml4ZWQgYSBidWcgaW4gdGhlIGNhY2hlIG1hbmFnZXIgdGhhdCBwcmV2ZW50ZWQgbm9ybWFsIExSVSBiZWhhdmlvdXIKICAgIHdpdGhpbiB0aGUgY2FjaGUgbWFuYWdlciwgY2F1c2luZyB1bm5lY2Vzc2FyeSByZWxvYWRzIChmb3IgRlRfRmFjZSBhbmQKICAgIEZUX1NpemUgb2JqZWN0cyBvbmx5KS4KCiAgLSBBZGRlZCBhIG5ldyBmdW5jdGlvbiBuYW1lZCAiRlRfR2V0X05hbWVfSW5kZXgiIHRvIHJldHJpZXZlIHRoZSBnbHlwaAogICAgaW5kZXggb2YgYSBnaXZlbiBnbHlwaCBuYW1lLCB3aGVuIGZvdW5kIGluIGEgZmFjZS4KCiAgLSBBZGRlZCBhIG5ldyBmdW5jdGlvbiBuYW1lZCAiRlRfR2V0X1Bvc3RzY3JpcHRfTmFtZSIgdG8gcmV0cmlldmUgdGhlCiAgICAidW5pcXVlIiBQb3N0c2NyaXB0IGZvbnQgbmFtZSBvZiBhIGdpdmVuIGZhY2UuCgogIC0gQWRkZWQgYSBuZXcgcHVibGljIGhlYWRlciBzaXplIG5hbWVkIEZUX1NJWkVTX0ggKG9yCiAgICA8ZnJlZXR5cGUvZnRzaXplcy5oPikgcHJvdmlkaW5nIG5ldyBGVF9TaXplLW1hbmFnZW1lbnQgZnVuY3Rpb25zOgogICAgRlRfTmV3X1NpemUsIEZUX0FjdGl2YXRlX1NpemUsIEZUX0RvbmVfU2l6ZS4KCiAgLSBGaXhlZCBhIHJlYWxsb2NhdGlvbiBidWcgdGhhdCBnZW5lcmF0ZWQgYSBkYW5nbGluZyBwb2ludGVyIChhbmQgcG9zc2libHkKICAgIG1lbW9yeSBsZWFrcykgd2l0aCBQb3N0c2NyaXB0IGZvbnRzIChpbiBzcmMvcHNhdXgvcHNvYmpzLmMpLgoKICAtIE1hbnkgZml4ZXMgZm9yIDE2LWJpdCBjb3JyZWN0bmVzcy4KCiAgLSBSZW1vdmVkIG1hbnkgcGVkYW50aWMgY29tcGlsZXIgd2FybmluZ3MgZnJvbSB0aGUgc291cmNlcy4KCiAgLSBBZGRlZCBhbiBBbWlnYSBidWlsZCBkaXJlY3RvcnkgaW4gImJ1aWxkcy9hbWlnYSIuCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpMQVRFU1QgQ0hBTkdFUyBCRVRXRUVOIDIuMC40IGFuZCAyLjAuMwoKICAtIEZpeGVkIGEgcmF0aGVyIGFubm95aW5nIGJ1ZyB0aGF0IHdhcyBpbnRyb2R1Y2VkIGluIDIuMC4zLiAgTmFtZWx5LCB0aGUKICAgIGZvbnQgdHJhbnNmb3JtYXRpb24gc2V0IHRocm91Z2ggRlRfU2V0X1RyYW5zZm9ybSB3YXMgYXBwbGllZCB0d2ljZSB0bwogICAgYXV0by1oaW50ZWQgZ2x5cGhzLCByZXN1bHRpbmcgaW4gaW5jb3JyZWN0bHkgcm90YXRlZCB0ZXh0IG91dHB1dC4KCiAgLSBGaXhlZCBfbWFueV8gY29tcGlsZXIgd2FybmluZ3MuICBGVDIgc2hvdWxkIG5vdyBjb21waWxlIGNsZWFubHkgd2l0aAogICAgVmlzdWFsIEMrKydzIG1vc3QgcGVkYW50aWMgd2FybmluZyBsZXZlbCAoL1c0KS4gIEl0IGFscmVhZHkgY29tcGlsZWQKICAgIGZpbmUgd2l0aCBHQ0MgYW5kIGEgZmV3IG90aGVyIGNvbXBpbGVycy4KCiAgLSBGaXhlZCBhIGJ1ZyB0aGF0IHByZXZlbnRlZCB0aGUgbGluZWFyIGFkdmFuY2Ugd2lkdGggb2YgY29tcG9zaXRlCiAgICBUcnVlVHlwZSBnbHlwaHMgdG8gYmUgY29ycmVjdGx5IHJldHVybmVkLgoKICAtIEZpeGVkIHRoZSBWaXN1YWwgQysrIHByb2plY3QgZmlsZXMgbG9jYXRlZCBpbiAiYnVpbGRzL3dpbjMyL3Zpc3VhbGMiCiAgICAocHJldmlvdXMgdmVyc2lvbnMgdXNlZCBvbGRlciBuYW1lcyBvZiB0aGUgbGlicmFyeSkuCgogIC0gTWFueSAzMi1iaXQgY29uc3RhbnRzIGhhdmUgYW4gIkwiIGFwcGVuZGVkIHRvIHRoZWlyIHZhbHVlLCBpbiBvcmRlcgogICAgdG8gaW1wcm92ZSB0aGUgMTYtYml0bmVzcyBvZiB0aGUgY29kZS4gIFNvbWVvbmUgaXMgYWN0dWFsbHkgdHJ5aW5nIHRvCiAgICB1c2UgRlQyIG9uIGFuIEF0YXJpIFNUIG1hY2hpbmUhCgogIC0gVXBkYXRlZCB0aGUgImJ1aWxkcy9kZXRlY3QubWsiIGZpbGUgaW4gb3JkZXIgdG8gYXV0b21hdGljYWxseSBidWlsZAogICAgRlQyIG9uIEFJWCBzeXN0ZW1zLiAgQUlYIHVzZXMgIi91c3Ivc2Jpbi9pbml0IiBpbnN0ZWFkIG9mICIvc2Jpbi9pbml0IgogICAgYW5kIHdhc24ndCBwcmV2aW91c2x5IGRldGVjdGVkIGFzIGEgVW5peCBwbGF0Zm9ybSBieSB0aGUgRnJlZVR5cGUgYnVpbGQKICAgIHN5c3RlbS4KCiAgLSBVcGRhdGVkIHRoZSBVbml4LXNwZWNpZmljIHBvcnRpb25zIG9mIHRoZSBidWlsZCBzeXN0ZW0gKG5ldyBsaWJ0b29sCiAgICB2ZXJzaW9uLCBldGMuKS4KCiAgLSBUaGUgU0ZOVCBrZXJuaW5nIGxvZGFlciBub3cgZW5zdXJlcyB0aGF0IHRoZSB0YWJsZSBpcyBzb3J0ZWQgKHNpbmNlIHNvbWUKICAgIHByb2JsZW0gZm9udHMgZG8gbm90IG1lZXQgdGhpcyByZXF1aXJlbWVudCkuCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpMQVRFU1QgQ0hBTkdFUyBCRVRXRUVOIDIuMC4zIGFuZCAyLjAuMgoKICBJLiBDSEFOR0VTIFRPIFRIRSBNT0RVTEVTIC8gRk9OVCBEUklWRVJTCgogICAgLSBUSEUgQVVUTy1ISU5URVIgSEFTIEJFRU4gU0xJR0hUTFkgSU1QUk9WRUQsIGluIG9yZGVyIHRvIGZpeCBzZXZlcmFsCiAgICAgIGFubm95aW5nIGFydGVmYWN0cywgbWFpbmx5OgoKICAgICAgICAtIEJsdWUgem9uZSBhbGlnbmVtZW50IG9mIGhvcml6b250YWwgc3RlbXMgd2Fzbid0IHBlcmZvcm1lZAogICAgICAgICAgY29ycmVjdGx5LCByZXN1bHRpbmcgaW4gYXJ0ZWZhY3RzIGxpa2UgdGhlICJkIiBiZWluZyBwbGFjZWQgb25lCiAgICAgICAgICBwaXhlbCBiZWxvdyB0aGUgImIiIGluIHNvbWUgZm9udHMgbGlrZSBUaW1lIE5ldyBSb21hbi4KCiAgICAgICAgLSBPdmVyc2hvb3QgdGhyZXNob2xkaW5nIHdhc24ndCBwZXJmb3JtZWQgY29ycmVjdGx5LCBjcmVhdGluZwogICAgICAgICAgdW5wbGVhc2FudCBhcnRlZmFjdHMgYXQgbGFyZ2UgY2hhcmFjdGVyIHBpeGVsIHNpemVzLgoKICAgICAgICAtIENvbXBvc2l0ZSBnbHlwaCBsb2FkaW5nIGhhcyBiZWVuIHNpbXBsaWZpZWQuICBUaGlzIGdldHMgcmlkCiAgICAgICAgICBvZiB2YXJpb3VzIGFydGVmYWN0cyB3aGVyZSB0aGUgY29tcG9uZW50cyBvZiBhIGNvbXBvc2l0ZSBnbHlwaHMKICAgICAgICAgIHdlcmUgbm90IGNvcnJlY3RseSBzcGFjZWQuCgogICAgICBUaGVzZSBhcmUgdGhlIGxhc3QgY2hhbmdlcyB0byB0aGUgY3VycmVudCBhdXRvLWhpbnRpbmcgbW9kdWxlLiAgQSBuZXcKICAgICAgaGludGluZyBzdWItc3lzdGVtIGlzIGN1cnJlbnRseSBpbiB0aGUgd29yayBpbiBvcmRlciB0byBzdXBwb3J0IG5hdGl2ZQogICAgICBoaW50cyBpbiBUeXBlIDEgLyBDRkYgLyBPcGVuVHlwZSBmb250cywgYXMgd2VsbCBhcyBnbG9iYWxseSBpbXByb3ZlCiAgICAgIHJlbmRlcmluZy4KCiAgICAtIFRoZSBQQ0YgZHJpdmVyIGhhcyBiZWVuIGZpeGVkLiAgSXQgcmVwb3J0ZWQgaW52YWxpZCBnbHlwaCBkaW1lbnNpb25zCiAgICAgIGZvciB0aGUgZm9udHMgYXZhaWxhYmxlIG9uIFNvbGFyaXMuCgogICAgLSBUaGUgVHlwZSAxLCBDSUQgYW5kIENGRiBkcml2ZXJzIGhhdmUgYmVlbiBtb2RpZmllZCB0byBmaXggdGhlCiAgICAgIGNvbXB1dGF0aW9uIG9mIHRoZSBFTSBzaXplLgoKICAgIC0gVGhlIFR5cGUgMSBkcml2ZXIgaGFzIGJlZW4gZml4ZWQgdG8gYXZvaWQgYSBkYW5nZXJvdXMgYnVnIHRoYXQKICAgICAgY3Jhc2hlZCB0aGUgbGlicmFyeSB3aXRoIG5vbi1jb25mb3JtaW5nIGZvbnRzIChpLmUuIG9uZXMgdGhhdCBkbyBub3QKICAgICAgcGxhY2UgdGhlIC5ub3RkZWYgZ2x5cGggYXQgcG9zaXRpb24gMCkuCgogICAgLSBUaGUgVHJ1ZVR5cGUgZHJpdmVyIGhhZCBhIHJhdGhlciBzdWJ0bGUgYnVnIChkYW5nbGluZyBwb2ludGVyIHdoZW4KICAgICAgbG9hZGluZyBjb21wb3NpdGUgZ2x5cGhzKSB0aGF0IGNvdWxkIGNyYXNoIHRoZSBsaWJyYXJ5IGluIHJhcmUKICAgICAgb2NjYXNpb25zIQoKCiAgSUkuIEhJR0gtTEVWRUwgQVBJIENIQU5HRVMKCiAgICAtIFRoZSBlcnJvciBjb2RlIGVudW1lcmF0aW9uIHZhbHVlcyBoYXZlIGJlZW4gY2hhbmdlZC4gIEFuIGVycm9yIHZhbHVlCiAgICAgIGlzIGRlY29tcG9zZWQgaW4gYSBnZW5lcmljIGVycm9yIGNvZGUsIGFuZCBhIG1vZHVsZSBudW1iZXIuICBzZWUKICAgICAgPGZyZWV0eXBlL2Z0ZXJyb3JzLmg+IGZvciBkZXRhaWxzLgoKICAgIC0gQSBuZXcgcHVibGljIGhlYWRlciBmaWxlIGhhcyBiZWVuIGludHJvZHVjZWQsIG5hbWVkIEZUX1RSSUdPTk9NRVRSWV9ICiAgICAgIChpbmNsdWRlL2ZyZWV0eXBlL2Z0dHJpZy5oKSwgcHJvdmlkaW5nIHRyaWdvbm9tZXRyaWMgZnVuY3Rpb25zIHRvCiAgICAgIGNvbXB1dGUgc2luZXMsIGNvc2luZXMsIGFyY3RhbmdlbnRzLCBldGMuIHdpdGggMTYuMTYgZml4ZWQgcHJlY2lzaW9uLgogICAgICBUaGUgaW1wbGVtZW50YXRpb24gaXMgYmFzZWQgb24gdGhlIENPUkRJQyBhbGdvcml0aG0gYW5kIGlzIHZlcnkgZmFzdAogICAgICB3aGlsZSBiZWluZyBzdWZmaWNpZW50bHkgYWNjdXJhdGUuCgoKICBJSUkuIElOVEVSTkFMUwoKICAgIC0gQWRkZWQgQmVPUy1zcGVjaWZpYyBmaWxlcyBpbiB0aGUgb2xkIGJ1aWxkIHN1Yi1zeXN0ZW0uICBOb3RlIHRoYXQKICAgICAgbm8gY2hhbmdlcyB3ZXJlIHJlcXVpcmVkIHRvIGNvbXBpbGUgdGhlIGxpYnJhcnkgd2l0aCBKYW0uCgogICAgLSBUaGUgY29uZmlndXJhdGlvbiBpcyBub3cgY2FwYWJsZSBvZiBhdXRvbWF0aWNhbGx5IGRldGVjdGluZyA2NC1iaXQKICAgICAgaW50ZWdlcnMgb24gYSBzZXQgb2YgcHJlZGVmaW5lZCBjb21waWxlcnMgKEdDQywgVmlzdWFsIEMrKywgQm9ybGFuZAogICAgICBDKyspIGFuZCB3aWxsIHVzZSB0aGVtIGJ5IGRlZmF1bHQuICBUaGlzIHByb3ZpZGVzIGEgc21hbGwgcGVyZm9ybWFuY2UKICAgICAgYm9vc3QuCgogICAgLSBBIHNtYWxsIG1lbW9yeSBsZWFrIHRoYXQgaGFwcGVuZWQgd2hlbiBvcGVuaW5nIDAtc2l6ZWQgZmlsZXMgKGR1aCEpCiAgICAgIGhhdmUgYmVlbiBmaXhlZC4KCiAgICAtIEZpeGVkIGJlemllciBzdGFjayBkZXB0aCBidWcgaW4gdGhlIHJvdXRpbmVzIHByb3ZpZGVkIGJ5IHRoZQogICAgICBGVF9CQk9YX0ggaGVhZGVyIGZpbGUuICBBbHNvIGZpeGVkIHNpbWlsYXIgYnVncyBpbiB0aGUgcmFzdGVyaXplcnMuCgogICAgLSBUaGUgb3V0bGluZSBib3VuZGluZyBib3ggY29kZSBoYXMgYmVlbiByZXdyaXR0ZW4gdG8gdXNlIGRpcmVjdAogICAgICBjb21wdXRhdGlvbnMsIGluc3RlYWQgb2YgYmV6aWVyIHN1Yi1kaXZpc2lvbiwgdG8gY29tcHV0ZSB0aGUgZXhhY3QKICAgICAgYm91bmRpbmcgYm94IG9mIGdseXBocy4gIFRoaXMgaXMgc2xpZ2h0bHkgc2xvd2VyIGJ1dCBtb3JlIGFjY3VyYXRlLgoKICAgIC0gVGhlIGJ1aWxkIHN5c3RlbSBoYXMgYmVlbiBpbXByb3ZlZCBhbmQgZml4ZWQsIG1haW5seSB0byBzdXBwb3J0ICJtYWtlIgogICAgICBvbiBXaW5kb3dzIDIwMDAgY29ycmVjdGx5LCBhdm9pZCBwcm9ibGVtcyB3aXRoICJtYWtlIGRpc3RjbGVhbiIgb24gbm9uCiAgICAgIFVuaXggc3lzdGVtcywgZXRjLgoKICAgIC0gSGV4YWRlY2ltYWwgY29uc3RhbnRzIGhhdmUgYmVlbiBzdWZmaXhlZCB3aXRoICJVIiB0byBhdm9pZCBwcm9ibGVtcwogICAgICB3aXRoIGNlcnRhaW4gY29tcGlsZXJzIG9uIDY0LWJpdCBwbGF0Zm9ybXMuCgogICAgLSBBIG5ldyBkaXJlY3RvcnkgbmFtZWQgInNyYy90b29scyIgaGFzIGJlZW4gY3JlYXRlZC4gIEl0IGNvbnRhaW5zCiAgICAgIFB5dGhvbiBzY3JpcHRzIGFuZCBzaW1wbGUgdW5pdCB0ZXN0IHByb2dyYW1zIHVzZWQgdG8gZGV2ZWxvcCB0aGUKICAgICAgbGlicmFyeS4KCiAgICAtIFRoZSBEb2NNYWtlciB0b29sIGhhcyBiZWVuIG1vdmVkIGZyb20gImRvY3MiIHRvICJzcmMvdG9vbHMiIGFuZAogICAgICBoYXMgYmVlbiB1cGRhdGVkIHdpdGggdGhlIGZvbGxvd2luZzoKCiAgICAgICAgIC0gTm93IGFjY2VwdHMgdGhlICItLXRpdGxlPVhYWFgiIG9yICItdCBYWFhYIiBvcHRpb24gZnJvbSB0aGUKICAgICAgICAgICBjb21tYW5kIGxpbmUgdG8gc2V0IHRoZSBwcm9qZWN0J3MgbmFtZSBpbiB0aGUgZ2VuZXJhdGVkIEFQSQogICAgICAgICAgIHJlZmVyZW5jZS4KCiAgICAgICAgIC0gTm93IGFjY2VwdHMgdGhlICItLW91dHB1dD1ESVIiIG9yICItbyBESVIiIG9wdGlvbiBmcm9tIHRoZQogICAgICAgICAgIGNvbW1hbmQgbGluZSB0byBzZXQgdGhlIG91dHB1dCBkaXJlY3RvcnkgZm9yIGFsbCBnZW5lcmF0ZWQgSFRNTAogICAgICAgICAgIGZpbGVzLgoKICAgICAgICAgLSBOb3cgYWNjZXB0cyB0aGUgIi0tcHJlZml4PVhYWFgiIG9yICItcCBYWFgiIG9wdGlvbiBmcm9tIHRoZQogICAgICAgICAgIGNvbW1hbmQgbGluZSB0byBzZXQgdGhlIGZpbGUgcHJlZml4IHRvIHVzZSBmb3IgYWxsIGdlbmVyYXRlZCBIVE1MCiAgICAgICAgICAgZmlsZXMuCgogICAgICAgICAtIE5vdyBnZW5lcmF0ZXMgdGhlIGN1cnJlbnQgdGltZS9kYXRhIG9uIGVhY2ggZ2VuZXJhdGVkIHBhZ2UKICAgICAgICAgICBpbiBvcmRlciB0byBkaXN0aW5ndWlzaCBiZXR3ZWVuIHZlcnNpb25zLgoKICAgICAgRG9jTWFrZXIgY2FuIGJlIHVzZWQgd2l0aCBvdGhlciBwcm9qZWN0cyBub3csIG5vdCBvbmx5IEZUMiAoZS5nLiBNTGliLAogICAgICBGVExheW91dCwgZXRjLikuCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCkxBVEVTVCBDSEFOR0VTIEJFVFdFRU4gMi4wLjIgYW5kIDIuMC4xCgoKICBJLiBDSEFOR0VTIFRPIFRIRSBNT0RVTEVTIC8gRk9OVCBEUklWRVJTCgogICAgLSBUSEUgVFJVRVRZUEUgQllURUNPREUgSU5URVJQUkVURVIgSVMgTk9XIFRVUk5FRCBPRkYsIGluIG9yZGVyIHRvCiAgICAgIGF2b2lkIGxlZ2FsIHByb2JsZW1zICB3aXRoIHRoZSBBcHBsZSBwYXRlbnRzLiAgSXQgIHNlZW1zIHRoYXQgd2UKICAgICAgbWlzdGFrZW5seSAgdHVybmVkIHRoaXMgb3B0aW9uICBvbiBpbiAgcHJldmlvdXMgcmVsZWFzZXMgIG9mIHRoZQogICAgICBidWlsZC4KCiAgICAgIE5vdGUgdGhhdCBpZiAgeW91IHdhbnQgdG8gdXNlIHRoZSAgYnl0ZWNvZGUgaW50ZXJwcmV0ZXIgaW4gb3JkZXIKICAgICAgdG8gZ2V0IGhpZ2gtcXVhbGl0eSBUcnVlVHlwZSAgcmVuZGVyaW5nLCB5b3Ugd2lsbCBuZWVkIHRvIHRvZ2dsZQogICAgICBieSAgICAgICAgaGFuZCAgICAgICAgdGhlICAgICAgICBkZWZpbml0aW9uICAgICAgICBvZiAgICAgICAgdGhlCiAgICAgIFRUX0NPTkZJR19PUFRJT05fQllURUNPREVfSU5URVJQUkVURVIgICBtYWNybyAgICBpbiAgIHRoZSAgIGZpbGUKICAgICAgImluY2x1ZGUvZnJlZXR5cGUvY29uZmlnL2Z0b3B0aW9uLmgiLgoKICAgIC0gVGhlIENGRiBkcml2ZXIgaGFzIGJlZW4gaW1wcm92ZWQgYnkgVG9tIEthY3ZpbnNreSBhbmQgU2FuZGVyIHZhbgogICAgICBkZXIgV2FsOgoKICAgICAgKiBTdXBwb3J0IGZvciAic2VhYyIgZW11bGF0aW9uLgogICAgICAqIFN1cHBvcnQgZm9yICJkb3RzZWN0aW9uIi4KICAgICAgKiBTdXBwb3J0IGZvciByZXRyaWV2aW5nIGdseXBoIG5hbWVzIHRocm91Z2gKICAgICAgICAiRlRfR2V0X0dseXBoX05hbWUiLgoKICAgICAgVGhlIGZpcnN0IHR3byBpdGVtcyBhcmUgbmVjZXNzYXJ5IHRvIGNvcnJlY3RseSBhIGxhcmdlIG51bWJlciBvZgogICAgICBUeXBlIDEgZm9udHMgY29udmVydGVkIHRvIHRoZSBDRkYgZm9ybWF0cyBieSBBZG9iZSBBY3JvYmF0LgoKICAgIC0gVGhlIFR5cGUgMSBkcml2ZXIgd2FzIGFsc28gaW1wcm92ZWQgYnkgVG9tICYgb3RoZXJzOgoKICAgICAgKiBCZXR0ZXIgRU0gc2l6ZSBjb21wdXRhdGlvbi4KICAgICAgKiBCZXR0ZXIgc3VwcG9ydCBmb3Igc3ludGhldGljICh0cmFuc2Zvcm1lZCkgZm9udHMuCiAgICAgICogVGhlICBUeXBlIDEgIGRyaXZlciByZXR1cm5zICB0aGUgY2hhcnN0cmluZ3MgIGNvcnJlc3BvbmRpbmcgdG8KICAgICAgICBlYWNoIGdseXBoIGluIHRoZSAgImdseXBoLT5jb250cm9sX2RhdGEiIGZpZWxkIGFmdGVyIGEgY2FsbCB0bwogICAgICAgICJGVF9Mb2FkX0dseXBoIiAodGhhbmtzIEhhIFNoYW8pLgoKICAgIC0gVmFyaW91cyBvdGhlciBidWdmaXhlcywgaW5jbHVkaW5nIHRoZSBmb2xsb3dpbmc6CgogICAgICAqIEZpeGVkIGEgbmFzdHkgbWVtb3J5IGxlYWsgaW4gdGhlIFR5cGUgMSBkcml2ZXIuCiAgICAgICogVGhlIGF1dG9oaW50ZXIgIGFuZCB0aGUgcGNmICBkcml2ZXIgdXNlZCBzdGF0aWMgIHdyaXRhYmxlIGRhdGEKICAgICAgICB3aGVuIHRoZXkgc2hvdWxkbid0LgogICAgICAqIE1hbnkgY2FzdHMgd2VyZSBhZGRlZCB0byAgbWFrZSB0aGUgY29kZSBtb3JlIDY0LWJpdHMgc2FmZS4gIEl0CiAgICAgICAgYWxzbyBub3cgY29tcGlsZXMgb24gV2luZG93cyBYUCA2NC1iaXRzIHdpdGhvdXQgd2FybmluZ3MuCiAgICAgICogU29tZSBpbmNvcnJlY3Qgd3JpdGFibGUgc3RhdGljcyB3ZXJlIHJlbW92ZWQgaW4gdGhlICJhdXRvaGludCIKICAgICAgICBhbmQgInBjZiIgZHJpdmVycy4gIEZyZWVUeXBlIDIgbm93IGNvbXBpbGVzIG9uIEVwb2MgYWdhaW4uCgoKICBJSS4gQ0hBTkdFUyBUTyBUSEUgSElHSC1MRVZFTCBBUEkKCiAgICAtIFRoZSBsaWJyYXJ5IGhlYWRlciBmaWxlcyBpbmNsdXNpb24gc2NoZW1lIGhhcyBiZWVuIGNoYW5nZWQuICBUaGUKICAgICAgb2xkIHNjaGVtZSBsb29rZWQgbGlrZToKCiAgICAgICAgI2luY2x1ZGUgPGZyZWV0eXBlL2ZyZWV0eXBlLmg+CiAgICAgICAgI2luY2x1ZGUgPGZyZWV0eXBlL2Z0Z2x5cGguaD4KICAgICAgICAjaW5jbHVkZSA8ZnJlZXR5cGUvZnRjYWNoZS5oPgogICAgICAgICNpbmNsdWRlIDxmcmVldHlwZS9jYWNoZS9mdGltYWdlLmg+CgogICAgICBOb3cgeW91IHNob3VsZCB1c2U6CgogICAgICAgICNpbmNsdWRlIDxmdDJidWlsZC5oPgogICAgICAgICNpbmNsdWRlIEZUX0ZSRUVUWVBFX0gKICAgICAgICAjaW5jbHVkZSBGVF9HTFlQSF9ICiAgICAgICAgI2luY2x1ZGUgRlRfQ0FDSEVfSAogICAgICAgICNpbmNsdWRlIEZUX0NBQ0hFX0lNQUdFX0gKCiAgICAgIE5PVEUgVEhBVCAgVEhFIE9MRCAgSU5DTFVTSU9OIFNDSEVNRSBXSUxMICBTVElMTCBXT1JLICBXSVRIIFRISVMKICAgICAgUkVMRUFTRS4gIEhPV0VWRVIsIFdFICBETyBOT1QgR1VBUkFOVEVFIFRIQVQgVEhJUyAgV0lMTCBTVElMTCBCRQogICAgICBUUlVFIElOIFRIRSBORVhUIE9ORSAoQS5LLkEuIEZSRUVUWVBFIDIuMSkuCgogICAgICBUaGUgIGZpbGUgPGZ0MmJ1aWxkLmg+ICBpcyB1c2VkICB0byBkZWZpbmUgIHRoZSAgaGVhZGVyIGZpbGVuYW1lCiAgICAgIG1hY3Jvcy4gIFRoZSBjb21wbGV0ZSBhbmQgIGNvbW1lbnRlZCBsaXN0IG9mIG1hY3JvcyBpcyBhdmFpbGFibGUKICAgICAgaW4gdGhlIEFQSSByZWZlcmVuY2UgdW5kZXIgdGhlIHNlY3Rpb24gbmFtZSAiSGVhZGVyIEZpbGUgTWFjcm9zIgogICAgICBpbiBDaGFwdGVyIEkuCgogICAgICBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIHNlY3Rpb24gSSBvZiB0aGUgZm9sbG93aW5nIGRvY3VtZW50OgoKICAgICAgICBodHRwOi8vd3d3LmZyZWV0eXBlLm9yZy8KICAgICAgICAgIGZyZWV0eXBlMi9kb2NzL3R1dG9yaWFsL3N0ZXAxLmh0bWwKCiAgICAgIG9yCgogICAgICAgIGh0dHA6Ly9mcmVldHlwZS5zb3VyY2Vmb3JnZS5uZXQvCiAgICAgICAgICBmcmVldHlwZTIvZG9jcy90dXRvcmlhbC9zdGVwMS5odG1sCgogICAgLSBNYW55LCBtYW55IGNvbW1lbnRzIGhhdmUgYmVlbiBhZGRlZCB0byB0aGUgcHVibGljIHNvdXJjZSBmaWxlIGluCiAgICAgIG9yZGVyIHRvICBhdXRvbWF0aWNhbGx5IGdlbmVyYXRlICB0aGUgQVBJIFJlZmVyZW5jZSAgdGhyb3VnaCB0aGUKICAgICAgImRvY21ha2VyLnB5IiBQeXRob24gc2NyaXB0LgoKICAgICAgVGhlIGxhdHRlciBoYXMgYmVlbiB1cGRhdGVkICB0byBzdXBwb3J0IHRoZSBncm91cGluZyBvZiBzZWN0aW9ucwogICAgICBpbiBjaGFwdGVycyBhbmQgYmV0dGVyIGluZGV4IHNvcnQuICBTZWU6CgogICAgICAgIGh0dHA6Ly93d3cuZnJlZXR5cGUub3JnL2ZyZWV0eXBlMi9kb2NzL3JlZmVyZW5jZS9mdDItdG9jLmh0bWwKCgogIElJSS4gQ0hBTkdFUyBUTyBUSEUgQlVJTEQgUFJPQ0VTUwoKICAgIC0gSWYgeW91ICBhcmUgbm90ICBidWlsZGluZyBGcmVlVHlwZSAyICB3aXRoIGl0cyBvd24gIGJ1aWxkIHN5c3RlbQogICAgICAoYnV0IHdpdGggeW91ciBvd24gTWFrZWZpbGVzIG9yIHByb2plY3QgZmlsZXMpLCB5b3Ugd2lsbCBuZWVkIHRvCiAgICAgIGJlICBhd2FyZSB0aGF0ICB0aGUgIGJ1aWxkICBwcm9jZXNzIGhhcyAgY2hhbmdlZCAgYSBsaXR0bGUgIGJpdC4KCiAgICAgIFlvdSBkb24ndCAgbmVlZCB0byBwdXQgdGhlICAic3JjIiBkaXJlY3RvcnkgaW4gIHRoZSBpbmNsdWRlIHBhdGgKICAgICAgd2hlbiAgY29tcGlsaW5nICBhbnkgRlQyICBjb21wb25lbnQuICAgSW5zdGVhZCwgIHNpbXBseSBwdXQgIHRoZQogICAgICBjb21wb25lbnQncyBkaXJlY3RvcnkgaW4gdGhlIGN1cnJlbnQgaW5jbHVkZSBwYXRoLgoKICAgICAgU28sIGlmIHlvdSB3ZXJlIGRvaW5nIHNvbWV0aGluZyBsaWtlOgoKICAgICAgICBjYyAtYyAtSWluY2x1ZGUgLUlzcmMgc3JjL2Jhc2UvZnRiYXNlLmMKCiAgICAgIGNoYW5nZSB0aGUgbGluZSB0bzoKCiAgICAgICAgY2MgLWMgLUlpbmNsdWRlIC1Jc3JjL2Jhc2Ugc3JjL2Jhc2UvZnRiYXNlLmMKCiAgICAgIElmIHlvdSB3ZXJlIGRvaW5nIHNvbWV0aGluZyBsaWtlOgoKICAgICAgICBjZCBzcmMvYmFzZQogICAgICAgIGNjIC1jIC1JLi4vLi4vaW5jbHVkZSAtSS4uIGZ0YmFzZS5jCgogICAgICBjaGFuZ2UgaXQgdG86CgogICAgICAgIGNkIHNyYy9iYXNlCiAgICAgICAgY2MgLWMgLUkuLi8uLi9pbmNsdWRlIGZ0YmFzZS5jCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKTEFURVNUIENIQU5HRVMgQkVUV0VFTiAyLjAuMSBhbmQgMi4wCgogIDIuMC4xIGludHJvZHVjZXMgYSBmZXcgY2hhbmdlczoKCiAgICAtIEZpeGVkIG1hbnkgYnVncyByZWxhdGVkIHRvICB0aGUgc3VwcG9ydCBvZiBDRkYgLyBPcGVuVHlwZSBmb250cy4KICAgICAgVGhlc2UgIGZvcm1hdHMgYXJlICBub3cgbXVjaCAgYmV0dGVyIHN1cHBvcnRlZCAgdGhvdWdoICB0aGVyZSBpcwogICAgICBzdGlsbCB3b3JrIHBsYW5uZWQgdG8gIGRlYWwgd2l0aCBjaGFyc2V0IHRhYmxlcyBhbmQgUERGLWVtYmVkZGVkCiAgICAgIENGRiBmaWxlcyB0aGF0IHVzZSB0aGUgb2xkICJzZWFjIiBjb21tYW5kLgoKICAgIC0gVGhlICBsaWJyYXJ5IGNvdWxkIG5vdCAgYmUgY29tcGlsZWQgIGluIGRlYnVnICBtb2RlIHdpdGggIGEgdmVyeQogICAgICBzbWFsbCAgbnVtYmVyICAgb2YgIEMgIGNvbXBpbGVycyAgIHdob3NlICBwcmUtcHJvY2Vzc29ycyAgZGlkbid0CiAgICAgIGltcGxlbWVudCB0aGUgIiMjIiAgZGlyZWN0aXZlIGNvcnJlY3RseSAoaS5lLiBwZXIgc2UgIHRoZSBBTlNJIEMKICAgICAgc3BlY2lmaWNhdGlvbiEpICBBbiBlbGVnYW50IGZpeCB3YXMgZm91bmQuCgogICAgLSBBZGRlZCAgc3VwcG9ydCBmb3IgIHRoZSAgZnJlZSBCb3JsYW5kICBjb21tYW5kLWxpbmUgQysrICBCdWlsZGVyCiAgICAgIGNvbXBpbGVyLiAgIFVzZSAibWFrZSAgc2V0dXAgYmNjMzIiLiAgIEFsc28gZml4ZWQgIGEgIGZldyBzb3VyY2UKICAgICAgbGluZXMgdGhhdCBnZW5lcmF0ZWQgbmV3IHdhcm5pbmdzIHdpdGggQkNDMzIuCgogICAgLSBGaXhlZCBhIGJ1ZyBpbiBGVF9PdXRsaW5lX0dldF9CQm94IHdoZW4gY29tcHV0aW5nIHRoZSBleHRyZW1hIG9mCiAgICAgIGEgY29uaWMgQmV6aWVyIGFyYy4KCiAgICAtIFVwZGF0ZWQgdGhlIElOU1RBTEwgZmlsZSB0byBhZGQgSURFIGNvbXBpbGF0aW9uLgoKICAgIC0gT3RoZXIgIG1pbm9yIGJ1ZyAgZml4ZXMsICBmcm9tICBpbnZhbGlkIFR5cGUgIDEgIHN0eWxlIGZsYWdzICB0bwogICAgICBjb3JyZWN0ICAgc3VwcG9ydCAgIG9mICBzeW50aGV0aWMgICAob2JsaXF1ZWQpICAgZm9udHMgIGluICAgdGhlCiAgICAgIGF1dG8taGludGVyLCBiZXR0ZXIgc3VwcG9ydCBmb3IgZW1iZWRkZWQgYml0bWFwcyBpbiBhIFNGTlQgZm9udC4KCiAgICAtIEZpeGVkIHNvbWUgcHJvYmxlbXMgd2l0aCAiZnJlZXR5cGUtY29uZmlnIi4KCiAgRmluYWxseSwgdGhlICJzdGFuZGFyZCIgc2NoZW1lIGZvciBpbmNsdWRpbmcgRnJlZVR5cGUgaGVhZGVycyBpcyBub3cKICBncmFkdWFsbHkgY2hhbmdpbmcsICBidXQgdGhpcyB3aWxsICBiZSBleHBsYWluZWQgaW4gYSAgbGF0ZXIgcmVsZWFzZQogIChwcm9iYWJseSAyLjAuMikuCgogIEFuZCB2ZXJ5ICBzcGVjaWFsIHRoYW5rcyB0byBUb20gS2Fjdmluc2t5ICBhbmQgWUFNQU5PLVVDSEkgSGlkZXRvc2hpCiAgZm9yIHRoZWlyIGNvbnRyaWJ1dGlvbnMhCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKQ0hBTkdFUyBCRVRXRUVOIGJldGE4IGFuZCAyLjAKCiAgLSBDaGFuZ2VkICB0aGUgZGVmYXVsdCAgaW5zdGFsbGF0aW9uICBwYXRoIGZvciAgcHVibGljIGhlYWRlcnMgIGZyb20KICAgICJpbmNsdWRlL2ZyZWV0eXBlIiB0byAiaW5jbHVkZS9mcmVldHlwZTIiLgoKICAgIEFsc28gYWRkZWQgYSBuZXcgImZyZWV0eXBlLWNvbmZpZyIgdGhhdCBpcyBhdXRvbWF0aWNhbGx5IGdlbmVyYXRlZAogICAgYW5kIGluc3RhbGxlZCAgb24gVW5peCBhbmQgIEN5Z3dpbiBzeXN0ZW1zLiAgVGhlIHNjcmlwdCAgaXRzZWxmIGlzCiAgICB1c2VkIHRvIHJldHJpZXZlIHRoZSBjdXJyZW50ICBpbnN0YWxsIHBhdGgsIEMgY29tcGlsYXRpb24gZmxhZ3MgYXMKICAgIHdlbGwgYXMgbGlua2VyIGZsYWdzLgoKICAtIEZpeGVkIHNldmVyYWwgc21hbGwgYnVnczoKCiAgICAqIEluY29ycmVjdCBtYXggYWR2YW5jZSB3aWR0aCBmb3IgZml4ZWQtcGl0Y2ggVHlwZSAxIGZvbnRzLgogICAgKiBJbmNvcnJlY3QgZ2x5cGggbmFtZXMgZm9yIGNlcnRhaW4gVHJ1ZVR5cGUgZm9udHMuCiAgICAqIFRoZSAgZ2x5cGggYWR2YW5jZSAgd2FzIG5vdCAgY29waWVkIHdoZW4gIEZUX0dseXBoX1RvX0JpdG1hcCB3YXMKICAgICAgY2FsbGVkLgogICAgKiBUaGUgIGxpbmVhckhvcmlBZHZhbmNlICBhbmQgIGxpbmVyVmVydEFkdmFuY2UgIGZpZWxkcyAgd2VyZSAgbm90CiAgICAgIGNvcnJlY3RseSByZXR1cm5lZCBmb3IgZ2x5cGhzIHByb2Nlc3NlZCBieSB0aGUgYXV0by1oaW50ZXIuCiAgICAqICJ0eXBlMXoiICByZW5hbWVkIGJhY2sgdG8gICJ0eXBlMSI7IHRoZSAgb2xkICJ0eXBlMSIgIG1vZHVsZSBoYXMKICAgICAgYmVlbiByZW1vdmVkLgoKICAtIFJldmFtcGVkIHRoZSAgYnVpbGQgc3lzdGVtICB0byBtYWtlIGl0ICBhIGxvdCBtb3JlICBnZW5lcmljLiAgVGhpcwogICAgd2lsbCAgYWxsb3cgdXMgIHRvICByZS11c2UgIG5lYXJseSB1bi1tb2RpZmllZCAgaW4gIGxvdHMgb2YgIG90aGVyCiAgICBwcm9qZWN0cyAoaW5jbHVkaW5nIEZyZWVUeXBlIExheW91dCkuCgogIC0gQ2hhbmdlZCAiY2lkIiB0byB1c2UgInBzYXV4IiB0b28uCgogIC0gQWRkZWQgdGhlICBjYWNoZSBzdWItc3lzdGVtLiAgU2VlIDxmcmVldHlwZS9mdGNhY2hlLmg+ICBhcyB3ZWxsIGFzCiAgICB0aGUgc291cmNlcyAgaW4gInNyYy9jYWNoZSIuICBOb3RlICB0aGF0IGl0IGNvbXBpbGVzIGJ1dCAgaXMgc3RpbGwKICAgIHVudGVzdGVkIGZvciBub3cuCgogIC0gVXBkYXRlZCAiZG9jcy9kb2NtYWtlci5weSIsIGEgZHJhZnQgIEFQSSByZWZlcmVuY2UgaXMgYXZhaWxhYmxlIGF0CiAgICBodHRwOi8vd3d3LmZyZWV0eXBlLm9yZy9mdDJhcGkuaHRtbC4KCiAgLSBDaGFuZ2VkICJ0eXBlMSIgdG8gdXNlICJwc2F1eCIuCgogIC0gQ3JlYXRlZCBhICBuZXcgbW9kdWxlIG5hbWVkICAicHNhdXgiIHRvIGhvbGQgIHRoZSBUeXBlIDEgJiAgVHlwZSAyCiAgICBwYXJzaW5nIHJvdXRpbmVzLiAgSXQgc2hvdWxkIGJlICB1c2VkIGJ5ICJ0eXBlMSIsICJjaWQiLCBhbmQgImNmZiIKICAgIGluIHRoZSBmdXR1cmUuCgogIC0gRml4ZWQgYW4gaW1wb3J0YW50IGJ1ZyBpbiAiRlRfR2x5cGhfR2V0X0NCb3giLgoKICAtIEZpeGVkICBzb21lIGNvbXBpbGVyICB3YXJuaW5ncyAgdGhhdCBoYXBwZW5lZCAgc2luY2UgdGhlICBUcnVlVHlwZQogICAgYnl0ZWNvZGUgZGVjb2RlciB3YXMgZGVhY3RpdmF0ZWQgYnkgZGVmYXVsdC4KCiAgLSBGaXhlZCB0d28gbWVtb3J5IGxlYWtzOgoKICAgICogVGhlICAgIG1lbW9yeSAgIG1hbmFnZXIgICAoMTYgICAgYnl0ZXMpICAgaXNuJ3QgICAgcmVsZWFzZWQgICBpbgogICAgICBGVF9Eb25lX0ZyZWVUeXBlIQogICAgKiBVc2luZyBjdXN0b20gaW5wdXQgc3RyZWFtcywgdGhlICBjb3B5IG9mIHRoZSBvcmlnaW5hbCBzdHJlYW0gd2FzCiAgICAgIG5ldmVyIHJlbGVhc2VkLgoKICAtIEZpeGVkIHRoZSAgYXV0by1oaW50ZXIgYnkgcGVyZm9ybWluZyBhdXRvbWF0aWMgIGNvbXB1dGF0aW9uIG9mIHRoZQogICAgImZpbGxpbmcgZGlyZWN0aW9uIiBvZiBlYWNoIGdseXBoLiAgIFRoaXMgaXMgZG9uZSB0aHJvdWdoIGEgc2ltcGxlCiAgICBhbmQgIGZhc3QgYXBwcm94aW1hdGlvbiwgYW5kICBzZWVtcyB0byAgd29yayAocHJvYmxlbXMgIHNwb3R0ZWQgYnkKICAgIFdlcm5lciB0aG91Z2gpLiAgVGhlIEFycGhpYyBmb250cyBhcmUgYSBsb3QgbmljZXIgdGhvdWdoIHRoZXJlIGFyZQogICAgc3RpbGwgYSBsb3Qgb2YgdGhpbmdzIHRvIGRvIHRvIGhhbmRsZSBBc2lhbiBmb250cyBjb3JyZWN0bHkuCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKQkVUQS04IChSRUxFQVNFIENBTkRJREFURSkgQ0hBTkdFUwoKICAtIERlYWN0aXZhdGVkIHRoZSBUcnVlVHlwZSBieXRlY29kZSBpbnRlcnByZXRlciBieSBkZWZhdWx0LgoKICAtIERlYWN0aXZhdGVkIHRoZSAic3JjL3R5cGUxIiBmb250IGRyaXZlci4gIE5vdyAic3JjL3R5cGUxeiIgaXMgdXNlZAogICAgYnkgZGVmYXVsdC4KCiAgLSBVcGRhdGVzIHRvIHRoZSBidWlsZCBzeXN0ZW0uICBXZSBub3cgY29tcGlsZSB0aGUgbGlicmFyeSBjb3JyZWN0bHkKICAgIHVuZGVyICBVbml4ICBzeXN0ZW0gIHRocm91Z2ggICJjb25maWd1cmUiIHdoaWNoICBpcyAgYXV0b21hdGljYWxseQogICAgY2FsbGVkIG9uIHRoZSBmaXJzdCAibWFrZSIgaW52b2NhdGlvbi4KCiAgLSBBZGRlZCB0aGUgYXV0by1oaW50aW5nIG1vZHVsZSEgIEZpeGluZyBzb21lIGJ1Z3MgaGVyZSBhbmQgdGhlcmUuCgogIC0gRm91bmQgc29tZSBidWdzIGluIHRoZSAgY29tcG9zaXRlIGxvYWRlciAoc2VhYykgb2YgdGhlIFR5cGUxLWJhc2VkCiAgICBmb250IGRyaXZlcnMuCgogIC0gUmVuYW1lZCB0aGUgZGlyZWN0b3J5ICJmcmVldHlwZTIvY29uZmlnIiB0byAiZnJlZXR5cGUyL2J1aWxkcyIgYW5kCiAgICB1cGRhdGVkIGFsbCByZWxldmFudCBmaWxlcy4KCiAgLSBGb3VuZCBhIG1lbW9yeSBsZWFrIGluIHRoZSAidHlwZTEiIGRyaXZlci4KCiAgLSBJbmNvcnBvcmF0ZWQgVG9tJ3MgcGF0Y2hlcyB0byAgc3VwcG9ydCBmbGV4IG9wZXJhdG9ycyBjb3JyZWN0bHkgaW4KICAgIE9wZW5UeXBlL0NGRiBmb250cy4gIE5vdyBhbGwgSSBuZWVkIGlzIHRvIHN1cHBvcnQgcHVyZSBDRkYgYW5kIENFRgogICAgZm9udHMgdG8gYmUgZG9uZSB3aXRoIHRoaXMgZHJpdmVyIDotKQoKICAtIEFkZGVkIHRoZSAgV2luZG93cyBGTlQvRk9OIGRyaXZlciBpbiAic3JjL3dpbmZvbnRzIi4gICBGb3Igbm93LCBpdAogICAgYWx3YXlzICAic2ltdWxhdGVzIiAgIGEgIFVuaWNvZGUgIGNoYXJtYXAsICBzbyAgIGl0ICBzaG91bGRuJ3QgIGJlCiAgICBjb25zaWRlcmVkIGNvbXBsZXRlZCByaWdodCBub3cuCgogICAgSXQgIGlzIHRoZXJlICB0byBiZSAgbW9yZSBhICBwcm9vZiBvZiAgY29uY2VwdCB0aGFuICBhbnl0aGluZyBlbHNlCiAgICBhbnl3YXkuICBUaGUgZHJpdmVyIGlzIGEgc2luZ2xlICBDIHNvdXJjZSBmaWxlLCB0aGF0IGNvbXBpbGVzIHRvIDMKICAgIEtiIG9mIGNvZGUuCgogICAgSSdtICBzdGlsbCB3b3JraW5nIG9uICB0aGUgUENGL0JERiAgZHJpdmVycywgYnV0ICBJJ20gdG9vICBsYXp5IHRvCiAgICBmaW5pc2ggdGhlbSBub3cuCgogIC0gQ0hBTkdFUyBUTyBUSEUgSElHSC1MRVZFTCBBUEkKCiAgICAqIEZUX0dldF9LZXJuaW5nIGhhcyBhIG5ldyBwYXJhbWV0ZXIgdGhhdCBhbGxvd3MgeW91IHRvIHNlbGVjdCB0aGUKICAgICAgY29vcmRpbmF0ZXMgb2YgdGhlIGtlcm5pbmcgIHZlY3RvciAoZm9udCB1bml0cywgc2NhbGVkLCBzY2FsZWQgKwogICAgICBncmlkLWZpdHRlZCkuCiAgICAqIFRoZSAgb3V0bGluZSBmdW5jdGlvbnMgYXJlICBub3cgaW4gPGZyZWV0eXBlL2Z0b3V0bG4uaD4gIGFuZCBub3QKICAgICAgcGFydCBvZiA8ZnJlZXR5cGUvZnJlZXR5cGUuaD4gYW55bW9yZS4KICAgICogPGZyZWV0eXBlL2Z0bW9kdWxlLmg+ICAgIG5vdyAgICAgY29udGFpbnMgICAgZGVjbGFyYXRpb25zICAgIGZvcgogICAgICAgRlRfTmV3X0xpYnJhcnksIEZUX0RvbmVfTGlicmFyeSwgRlRfQWRkX0RlZmF1bHRfTW9kdWxlcy4KICAgICogVGhlIHNvLWNhbGxlZCBjb252ZW5pZW5jZSAgZnVuY3Rpb25zIGhhdmUgbW92ZWQgZnJvbSAiZnRvdXRsbi5jIgogICAgICB0byAgImZ0Z2x5cGguYyIsICBhbmQgIGFyZSAgdGh1cyBhdmFpbGFibGUgIHdpdGggIHRoaXMgIG9wdGlvbmFsCiAgICAgIGNvbXBvbmVudCAgICBvZiAgIHRoZSAgIGxpYnJhcnkuICAgICBUaGV5ICAgYXJlICAgIGRlY2xhcmVkICAgaW4KICAgICAgPGZyZWV0eXBlL2Z0Z2x5cGguaD4gbm93LgogICAgKiBBbnRpLWFsaWFzZWQgIHJlbmRlcmluZyBpcyBub3cgIHRoZSBkZWZhdWx0ICBmb3IgRlRfUmVuZGVyX0dseXBoCiAgICAgIChpLmUuIGNvcnJlc3BvbmRzIHRvIHJlbmRlcl9tb2RlID09IDAgPT0gZnRfcmVuZGVyX21vZGVfbm9ybWFsKS4KICAgICAgVG8gZ2VuZXJhdGUgYSBtb25vY2hyb21lIGJpdG1hcCwgdXNlIGZ0X3JlbmRlcl9tb2RlX21vbm8sIG9yIHRoZQogICAgICBGVF9MT0FEX01PTk9DSFJPTUUgICAgIGZsYWcgICAgaW4gICAgRlRfTG9hZF9HbHlwaC9GVF9Mb2FkX0NoYXIuCiAgICAgIEZUX0xPQURfQU5USV9BTElBUyBpcyBzdGlsbCBkZWZpbmVkLCBidXQgdmFsdWVzIHRvIDAuCiAgICAqIDxmcmVldHlwZS9mcmVldHlwZS5oPiAgbm93IGluY2x1ZGUgPGZyZWV0eXBlL2NvbmZpZy9mdGNvbmZpZy5oPiwKICAgICAgc29sdmluZyBhIGZldyBoZWFkYWNoZXMgOi0pCiAgICAqIFRoZSB0eXBlIEZUX0dseXBoU2xvdFJlYyBoYXMgbm93IGEgImxpYnJhcnkiIGZpZWxkLgoKICAtIENIQU5HRVMgVE8gVEhFICJmdGdseXBoLmgiIEFQSQoKICAgIFRoaXMgQVBJIGhhcyAgYmVlbiBzZXZlcmVseSBtb2RpZmllZCBpbiBvcmRlciAgdG8gbWFrZSBpdCBzaW1wbGVyLAogICAgY2xlYXJlciwgYW5kIG1vcmUgIGVmZmljaWVudC4gIEl0IGNlcnRhaW5seSBub3cgbG9va3MgIGxpa2UgYSByZWFsCiAgICAiZ2x5cGggZmFjdG9yeSIgIG9iamVjdCwgYW5kIGFsbG93cyBjbGllbnQgIGFwcGxpY2F0aW9ucyB0byBtYW5hZ2UKICAgIChpLmUuICB0cmFuc2Zvcm0sICBiYm94ICBhbmQgIHJlbmRlcikgZ2x5cGggIGltYWdlcyAgd2l0aG91dCAgZXZlcgogICAga25vd2luZyB0aGVpciBvcmlnaW5hbCBmb3JtYXQuCgogIC0gQWRkZWQgIHN1cHBvcnQgIGZvciBDSUQta2V5ZWQgIGZvbnRzICB0byAgdGhlICBDRkYgZHJpdmVyLiAgIE1heWJlCiAgICBzdXBwb3J0IGZvciBwdXJlIENGRiArIENFRiBmb250cyBzaG91bGQgY29tZSBpbj8KCiAgLSBDbGVhbmVkIHVwICBzb3VyY2UgY29kZSBpbiBvcmRlciAgdG8gYXZvaWQgdHdvICBmdW5jdGlvbnMgd2l0aCB0aGUKICAgIHNhbWUgbmFtZS4gIEFsc28gIGNoYW5nZWQgdGhlIG5hbWVzIG9mIHRoZSAgZmlsZXMgaW4gInR5cGUxeiIgZnJvbQogICAgInQxWFhYWCIgdG8gInoxWFhYWCIgaW4gb3JkZXIgdG8gYXZvaWQgYW55IGNvbmZsaWN0cy4KCiAgICAibWFrZSBtdWx0aSIgbm93IHdvcmtzIHdlbGwgOi0pCgogICAgQWxzbyByZW1vdmVkIHRoZSB1c2Ugb2YgImNpZGFmbSIgZm9yIG5vdywgZXZlbiBpZiB0aGUgc291cmNlIGZpbGVzCiAgICBhcmUgIHN0aWxsIHRoZXJlLiAgVGhpcyAgZnVuY3Rpb25hbGl0eSB3aWxsICBjZXJ0YWlubHkgIGdvIGludG8gIGEKICAgIHNwZWNpZmljIG1vZHVsZS4KCiAgLSBBRERFRCBTVVBQT1JUIEZPUiBUSEUgQVVUTy1ISU5URVIKCiAgICBJdCAgd29ya3MgOi0pIEkgIGhhdmUgYSAgZGVtbyBwcm9ncmFtICB3aGljaCBzaW1wbHkgIGlzIGEgIGNvcHkgb2YKICAgICJmdHZpZXciICAgICAgIHRoYXQgICAgICBkb2VzICAgICAgIGEgICAgICBgRlRfQWRkX01vZHVsZShsaWJyYXJ5LAogICAgJmF1dG9oaW50ZXJfbW9kdWxlX2NsYXNzKScgYWZ0ZXIgIGxpYnJhcnkgaW5pdGlhbGl6YXRpb24sIGFuZCBUeXBlCiAgICAxICYgT3BlblR5cGUvQ0ZGIGZvbnRzIGFyZSBub3cgaGludGVkLgoKICAgIENJRCAgZm9udHMgYXJlICBub3QgaGludGVkLCAgYXMgdGhleSAgaW5jbHVkZSBubyAgY2hhcm1hcCAgYW5kIHRoZQogICAgYXV0by1oaW50ZXIgZG9lc24ndCBpbmNsdWRlICAiZ2VuZXJpYyIgZ2xvYmFsIG1ldHJpY3MgY29tcHV0YXRpb25zCiAgICB5ZXQuCgogICAgTm93LCBJIG5lZWQgdG8gcmVsZWFzZSB0aGlzIHRoaW5nIHRvIHRoZSBGcmVlVHlwZSAyIHNvdXJjZS4KCiAgLSBDSEFOR0VTIFRPIFRIRSBSRU5ERVJFUiBNT0RVTEVTCgogICAgVGhlICBtb25vY2hyb21lICBhbmQgc21vb3RoICByZW5kZXJlcnMgIGFyZSAgbm93ICBpbiB0d28gIGRpc3RpbmN0CiAgICBkaXJlY3RvcmllcywgbmFtZWx5ICJzcmMvcmFzdGVyMSIgYW5kICJzcmMvc21vb3RoIi4gIE5vdGUgdGhhdCB0aGUKICAgIG9sZCAic3JjL3JlbmRlcmVyIiBpcyBub3cgZ29uZS4KCiAgICBJIGRpdGNoZWQgIHRoZSA1LWdyYXktbGV2ZWxzIHJlbmRlcmVycy4gIEJhc2ljYWxseSwgIGl0IGludm9sdmVkIGEKICAgIHNpbXBsZSAjZGVmaW5lIHRvZ2dsZSBpbiAnc3JjL3Jhc3RlcjEvZnRyYXN0ZXIuYycuCgogICAgRlRfUmVuZGVyX0dseXBoLCAgRlRfT3V0bGluZV9SZW5kZXIgICYgIEZUX091dGxpbmVfR2V0X0JpdG1hcCAgbm93CiAgICBzZWxlY3QgdGhlIGJlc3QgcmVuZGVyZXIgIGF2YWlsYWJsZSwgZGVwZW5kaW5nIG9uIHJlbmRlciBtb2RlLiAgSWYKICAgIHRoZSBjdXJyZW50IHJlbmRlcmVyIGZvciBhICBnaXZlbiBnbHlwaCBpbWFnZSBmb3JtYXQgaXNuJ3QgY2FwYWJsZQogICAgb2Ygc3VwcG9ydGluZyAgdGhlIHJlbmRlciBtb2RlLCBhbm90aGVyICBvbmUgd2lsbCBiZSAgZm91bmQgaW4gdGhlCiAgICBsaWJyYXJ5J3MgbGlzdC4gICBUaGlzIG1lYW5zIHRoYXQgY2xpZW50IGFwcGxpY2F0aW9ucyAgZG8gbm90IG5lZWQKICAgIHRvICBzd2l0Y2ggb3IgIHNldCAgdGhlICByZW5kZXJlcnMgdGhlbXNlbHZlcyAgKGFzICBpbiB0aGUgIGxhdGVzdAogICAgY2hhbmdlKSwgdGhleSdsbCBnZXQgd2hhdCB0aGV5IHdhbnQgYXV0b21hdGljYWxseS4gIEF0IGxhc3QuCgogICAgQ2hhbmdlZCB0aGUgZGVtbyBwcm9ncmFtcyBhY2NvcmRpbmdseS4KCiAgLSBNQUpPUiBJTlRFUk5BTCBSRURFU0lHTjoKCiAgICBBIGxvdCBvZiBpbnRlcm5hbCBtb2RpZmljYXRpb25zICBoYXZlIGJlZW4gcGVyZm9ybWVkIGxhdGVseSBvbiB0aGUKICAgIHNvdXJjZSBpbiBvcmRlciB0byBwcm92aWRlIHRoZSBmb2xsb3dpbmcgZW5oYW5jZW1lbnRzOgoKICAgICogTW9yZSBnZW5lcmljIG1vZHVsZSBzdXBwb3J0OgoKICAgICAgVGhlIEZUX01vZHVsZSAgdHlwZSBpcyAgbm93IGRlZmluZWQgdG8gIHJlcHJlc2VudCBhIGhhbmRsZSAgdG8gYQogICAgICBnaXZlbiAgbW9kdWxlLiAgIFRoZSAgZmlsZSAgPGZyZWV0eXBlL2Z0bW9kdWxlLmg+ICBjb250YWlucyAgdGhlCiAgICAgIEZUX01vZHVsZV9DbGFzcyBkZWZpbml0aW9uLCBhcyB3ZWxsIGFzIHRoZSBtb2R1bGUtbG9hZGluZyBwdWJsaWMKICAgICAgQVBJLgoKICAgICAgVGhlICBGVF9Ecml2ZXIgdHlwZSAgaXMgc3RpbGwgIGRlZmluZWQsIGFuZCAgc3RpbGwgIHJlcHJlc2VudHMgYQogICAgICBwb2ludGVyIHRvICBhIGZvbnQgZHJpdmVyLiAgTm90ZSB0aGF0ICBGVF9BZGRfRHJpdmVyIGlzIHJlcGxhY2VkCiAgICAgIGJ5IEZUX0FkZF9Nb2R1bGUsIEZUX0dldF9Ecml2ZXIgYnkgRlRfR2V0X01vZHVsZSwgZXRjLgoKICAgICogU3VwcG9ydCBmb3IgZ2VuZXJpYyBnbHlwaCBpbWFnZSB0eXBlczoKCiAgICAgIFRoZSBGVF9SZW5kZXJlciAgdHlwZSBpcyBhIHBvaW50ZXIgIHRvIGEgbW9kdWxlICB1c2VkIHRvIHBlcmZvcm0KICAgICAgdmFyaW91cyBvcGVyYXRpb25zIG9uIGdseXBoIGltYWdlLgoKICAgICAgRWFjaCByZW5kZXJlciBpcyAgY2FwYWJsZSBvZiBoYW5kbGluZyBpbWFnZXMgaW4gIGEgc2luZ2xlIGZvcm1hdAogICAgICAoZS5nLiBmdF9nbHlwaF9mb3JtYXRfb3V0bGluZSkuICBJdHMgZnVuY3Rpb25zIGFyZSB1c2VkIHRvOgoKICAgICAgLSB0cmFuc2Zvcm0gYW4gZ2x5cGggaW1hZ2UKICAgICAgLSByZW5kZXIgYSBnbHlwaCBpbWFnZSBpbnRvIGEgYml0bWFwCiAgICAgIC0gcmV0dXJuIHRoZSBjb250cm9sIGJveCAoZGltZW5zaW9ucykgb2YgYSBnaXZlbiBnbHlwaCBpbWFnZQoKICAgICAgVGhlIHNjYW4gY29udmVydGVycyAiZnRyYXN0ZXIuYyIgYW5kICJmdGdyYXlzLmMiIGhhdmUgYmVlbiBtb3ZlZAogICAgICB0byB0aGUgbmV3IGRpcmVjdG9yeSAic3JjL3JlbmRlcmVyIiwgYW5kIGFyZSB1c2VkIHRvIHByb3ZpZGUgdHdvCiAgICAgIGRlZmF1bHQgcmVuZGVyZXIgbW9kdWxlcy4KCiAgICAgIE9uZSBjb3JyZXNwb25kcyAgdG8gdGhlICJzdGFuZGFyZCIgc2Nhbi1jb252ZXJ0ZXIsICB0aGUgb3RoZXIgdG8KICAgICAgdGhlICJzbW9vdGgiIG9uZS4KCiAgICAgIGhlICBjdXJyZW50ICByZW5kZXJlciAgY2FuICBiZSAgc2V0ICB0aHJvdWdoICB0aGUgIG5ldyAgZnVuY3Rpb24KICAgICAgRlRfU2V0X1JlbmRlcmVyLgoKICAgICAgVGhlIG9sZCByYXN0ZXItcmVsYXRlZCBmdW5jdGlvbiBGVF9TZXRfUmFzdGVyLCBGVF9HZXRfUmFzdGVyIGFuZAogICAgICBGVF9TZXRfUmFzdGVyX01vZGUgaGF2ZSBub3cgZGlzYXBwZWFyZWQsIGluIGZhdm9yIG9mIHRoZSBuZXc6CgogICAgICAgIEZUX0dldF9SZW5kZXJlcgogICAgICAgIEZUX1NldF9SZW5kZXJlcgoKICAgICAgU2VlIHRoZSBmaWxlIDxmcmVldHlwZS9mdHJlbmRlci5oPiBmb3IgbW9yZSBkZXRhaWxzLgoKICAgICAgVGhlc2UgIGNoYW5nZXMgIHdlcmUgIG5lY2Vzc2FyeSAgdG8gcHJvcGVybHkgIHN1cHBvcnQgIGRpZmZlcmVudAogICAgICBzY2FsYWJsZSBmb3JtYXRzIGluIHRoZSBmdXR1cmUsIGxpa2UgYmktY29sb3IgZ2x5cGhzLCBldGMuCgogICAgKiBHbHlwaCBsb2FkZXIgb2JqZWN0OgoKICAgICAgQSAgbmV3ICBpbnRlcm5hbCAgb2JqZWN0LCAgY2FsbGVkICBhICAnZ2x5cGggIGxvYWRlcicgIGhhcyAgYmVlbgogICAgICBpbnRyb2R1Y2VkIGluIHRoZSBiYXNlIGxheWVyLiAgSXQgaXMgdXNlZCBieSBhbGwgc2NhbGFibGUgZm9ybWF0CiAgICAgIGZvbnQgZHJpdmVycyB0byBsb2FkIGdseXBocyBhbmQgY29tcG9zaXRlcy4KCiAgICAgIFRoaXMgb2JqZWN0ICBoYXMgYmVlbiAgY3JlYXRlZCB0byByZWR1Y2UgIHRoZSBjb2RlIHNpemUgIG9mIGVhY2gKICAgICAgZHJpdmVyLCAgYXMgIGVhY2ggIG9uZSAgb2YgIHRoZW0gIGJhc2ljYWxseSAgcmUtaW1wbGVtZW50ZWQgIGl0cwogICAgICBmdW5jdGlvbmFsaXR5LgoKICAgICAgU2VlIDxmcmVldHlwZS9pbnRlcm5hbC9mdG9ianMuaD4gYW5kIHRoZSBGVF9HbHlwaExvYWRlciB0eXBlIGZvcgogICAgICBtb3JlIGluZm9ybWF0aW9uLgoKICAgICogRlRfR2x5cGhTbG90IGhhcyBuZXcgZmllbGRzOgoKICAgICAgSW4gIG9yZGVyICAgdG8gIHN1cHBvcnQgIGV4dGVuZGVkICBmZWF0dXJlcyAgIChzZWUgIGJlbG93KSwgIHRoZQogICAgICBGVF9HbHlwaFNsb3Qgc3RydWN0dXJlIGhhcyBhIGZldyBuZXcgZmllbGRzOgoKICAgICAgbGluZWFySG9yaUFkdmFuY2U6CgogICAgICAgIFRoaXMgIGZpZWxkICBnaXZlcyAgdGhlICAgbGluZWFybHkgIHNjYWxlZCAgKGkuZS4gIHNjYWxlZCAgYnV0CiAgICAgICAgdW5oaW50ZWQpIGFkdmFuY2UgIHdpZHRoIGZvciB0aGUgIGdseXBoLCBleHByZXNzZWQgYXMgIGEgMTYuMTYKICAgICAgICBmaXhlZCBwaXhlbCB2YWx1ZS4gIFRoaXMgaXMgdXNlZnVsIHRvIHBlcmZvcm0gV1lTSVdZRyB0ZXh0LgoKICAgICAgbGluZWFyVmVydEFkdmFuY2U6CiAgICAgICAgVGhpcyBmaWVsZCAgZ2l2ZXMgdGhlIGxpbmVhcmx5ICBzY2FsZWQgYWR2YW5jZSBoZWlnaHQgIGZvciB0aGUKICAgICAgICBnbHlwaCAgKHJlbGV2YW50IGluICB2ZXJ0aWNhbCAgZ2x5cGggbGF5b3V0cyAgb25seSkuICBUaGlzICBpcwogICAgICAgIHVzZWZ1bCB0byBwZXJmb3JtIFdZU0lXWUcgdGV4dC4KCiAgICAgICAgTm90ZSB0aGF0ICB0aGUgdHdvIGFib3ZlIGZpZWxkIHJlcGxhY2UgIHRoZSByZW1vdmVkICJtZXRyaWNzMiIKICAgICAgICBmaWVsZCBpbiB0aGUgZ2x5cGggc2xvdC4KCiAgICAgIGFkdmFuY2U6CiAgICAgICAgVGhpcyBmaWVsZCBpcyBhIHZlY3RvciAgdGhhdCBnaXZlcyB0aGUgdHJhbnNmb3JtZWQgYWR2YW5jZSBmb3IKICAgICAgICB0aGUgZ2x5cGguICAgQnkgZGVmYXVsdCwgaXQgY29ycmVzcG9uZHMgdG8gIHRoZSBhZHZhbmNlIHdpZHRoLAogICAgICAgIHVubGVzcyAgRlRfTE9BRF9WRVJUSUNBTF9MQVlPVVQgIHdhcyAgc3BlY2lmaWVkICB3aGVuICBjYWxsaW5nCiAgICAgICAgRlRfTG9hZF9HbHlwaCBvciBGVF9Mb2FkX0NoYXIuCgogICAgICBiaXRtYXBfbGVmdDoKICAgICAgICBUaGlzICBmaWVsZCBnaXZlcyAgdGhlICBkaXN0YW5jZSBpbiAgaW50ZWdlciAgcGl4ZWxzIGZyb20gIHRoZQogICAgICAgIGN1cnJlbnQgcGVuIHBvc2l0aW9uICB0byB0aGUgbGVmdC1tb3N0IHBpeGVsIG9mICBhIGdseXBoIGltYWdlCiAgICAgICAgSUYgSVQgSVMgIEEgQklUTUFQLiAgSXQgaXMgb25seSB2YWxpZCAgd2hlbiB0aGUgImZvcm1hdCIgZmllbGQKICAgICAgICBpcyBzZXQgdG8gImZ0X2dseXBoX2Zvcm1hdF9iaXRtYXAiLCBmb3IgZXhhbXBsZSwgYWZ0ZXIgY2FsbGluZwogICAgICAgIHRoZSBuZXcgZnVuY3Rpb24gRlRfUmVuZGVyX0dseXBoLgoKICAgICAgYml0bWFwX3RvcDoKICAgICAgICBUaGlzICBmaWVsZCBnaXZlcyAgdGhlICBkaXN0YW5jZSBpbiAgaW50ZWdlciAgcGl4ZWxzIGZyb20gIHRoZQogICAgICAgIGN1cnJlbnQgcGVuIHBvc2l0aW9uIChsb2NhdGVkIG9uIHRoZSBiYXNlbGluZSkgdG8gdGhlIHRvcC1tb3N0CiAgICAgICAgcGl4ZWwgb2YgdGhlICBnbHlwaCBpbWFnZSBJRiBJVCBJUyAgQSBCSVRNQVAuICBQb3NpdGl2ZSB2YWx1ZXMKICAgICAgICBjb3JyZXNwb25kIHRvIHVwd2FyZHMgWS4KCiAgICAgIGxvYWRlcjoKICAgICAgICBUaGlzICBpcyBhICBuZXcgIHByaXZhdGUgIGZpZWxkIGZvciAgdGhlICBnbHlwaCBzbG90LiAgIENsaWVudAogICAgICAgIGFwcGxpY2F0aW9ucyBzaG91bGQgbm90IHRvdWNoIGl0LgoKCiAgICAqIFN1cHBvcnQgZm9yIHRyYW5zZm9ybXMgYW5kIGRpcmVjdCByZW5kZXJpbmcgaW4gRlRfTG9hZF9HbHlwaDoKCiAgICAgIE1vc3Qgb2YgdGhlIGZ1bmN0aW9uYWxpdHkgZm91bmQgaW4gPGZyZWV0eXBlL2Z0Z2x5cGguaD4gaGFzIGJlZW4KICAgICAgbW92ZWQgdG8gdGhlIGNvcmUgbGlicmFyeS4gSGVuY2UsIHRoZSBmb2xsb3dpbmc6CgogICAgICAtIEEgICB0cmFuc2Zvcm0gICBjYW4gICBiZSAgIHNwZWNpZmllZCAgZm9yICAgYSAgIGZhY2UgICB0aHJvdWdoCiAgICAgICAgRlRfU2V0X1RyYW5zZm9ybS4gIHRoaXMgdHJhbnNmb3JtICBpcyBhcHBsaWVkIGJ5IEZUX0xvYWRfR2x5cGgKICAgICAgICB0byAgc2NhbGFibGUgZ2x5cGggIGltYWdlcyAoaS5lLiAgTk9UIFRPICBCSVRNQVBTKSAgYmVmb3JlIHRoZQogICAgICAgIGZ1bmN0aW9uIHJldHVybnMsIHVubGVzcyB0aGUgYml0IGZsYWcgRlRfTE9BRF9JR05PUkVfVFJBTlNGT1JNCiAgICAgICAgd2FzIHNldCBpbiB0aGUgbG9hZCBmbGFncy4KCiAgICAgIC0gT25jZSAgYSAgZ2x5cGggaW1hZ2UgIGhhcyAgYmVlbiAgbG9hZGVkLCAgaXQgY2FuICBiZSAgZGlyZWN0bHkKICAgICAgICBjb252ZXJ0ZWQgIHRvICBhICBiaXRtYXAgIGJ5ICB1c2luZyAgdGhlICBuZXcgIEZUX1JlbmRlcl9HbHlwaAogICAgICAgIGZ1bmN0aW9uLiAgTm90ZSB0aGF0IHRoaXMgIGZ1bmN0aW9uIHRha2VzIHRoZSBnbHlwaCBpbWFnZSBmcm9tCiAgICAgICAgdGhlIGdseXBoIHNsb3QsICBhbmQgY29udmVydHMgaXQgdG8gYSAgYml0bWFwIHdob3NlIHByb3BlcnRpZXMKICAgICAgICBhcmUgcmV0dXJuZWQgIGluICJmYWNlLmdseXBoLmJpdG1hcCIsICJmYWNlLmdseXBoLmJpdG1hcF9sZWZ0IgogICAgICAgIGFuZCAiZmFjZS5nbHlwaC5iaXRtYXBfdG9wIi4gIFRoZSAgb3JpZ2luYWwgbmF0aXZlIGltYWdlIG1pZ2h0CiAgICAgICAgYmUgbG9zdCBhZnRlciB0aGUgY29udmVyc2lvbi4KCiAgICAgIC0gV2hlbiB1c2luZyB0aGUgbmV3ICBiaXQgZmxhZyBGVF9MT0FEX1JFTkRFUiwgdGhlIEZUX0xvYWRfR2x5cGgKICAgICAgICBhbmQgICBGVF9Mb2FkX0NoYXIgICBmdW5jdGlvbnMgICB3aWxsICAgY2FsbCAgIEZUX1JlbmRlcl9HbHlwaAogICAgICAgIGF1dG9tYXRpY2FsbHkgd2hlbiBuZWVkZWQuCgogIC0gUmVmb3JtYXR0ZWQgYWxsICBtb2R1bGVzIHNvdXJjZSAgY29kZSBpbiBvcmRlciAgdG8gZ2V0IHJpZCAgb2YgdGhlCiAgICBiYXNpYyBkYXRhIHR5cGVzIHJlZGlmaW5pdGlvbnMgKGkuZS4gIlRUX0ludCIgaW5zdGVhZCBvZiAiRlRfSW50IiwKICAgICJUMV9GaXhlZCIgIGluc3RlYWQgIG9mICAiRlRfRml4ZWQiKS4gIEhlbmNlICB0aGUgIGZvcm1hdC1zcGVjaWZpYwogICAgcHJlZml4ZXMgbGlrZSAgIlRUXyIsICJUMV8iLCAgIlQyXyIgYW5kICJDSURfIiAgYXJlIG9ubHkgIHVzZWQgZm9yCiAgICByZWxldmFudCBzdHJ1Y3R1cmVzLgoKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCk9MRCBDSEFOR0VTIEZPUiBCRVRBIDcKCiAgLSBidWctZml4ZWQgdGhlICBPcGVuVHlwZS9DRkYgcGFyc2VyLiBJdCAgbm93IGxvYWRzIGFuZCAgZGlzcGxheXMgbXkKICAgIHR3byAgZm9udHMgbmljZWx5LCAgYnV0IEknbSAgcHJldHR5IGNlcnRhaW4gIHRoYXQgbW9yZSAgdGVzdGluZyBpcwogICAgbmVlZGVkIDotKQoKICAtIGZpeGVkIHRoZSBjcnVtbXkgVHlwZSAxIGhpbnRlciwgaXQgbm93IGhhbmRsZXMgYWNjZW50ZWQgY2hhcmFjdGVycwogICAgY29ycmVjdGx5ICh3ZWxsLCB0aGUgYWNjZW50IGlzICBub3QgYWx3YXlzIHdlbGwgcGxhY2VkLCBidXQgdGhhdCdzCiAgICBhbm90aGVyIHByb2JsZW0uLikKCiAgLSBhZGRlZCB0aGUgQ0lELWtleWVkIFR5cGUgMSAgZHJpdmVyIGluICJzcmMvY2lkIi4gV29ya3MgcHJldHR5IHdlbGwKICAgIGZvciBvbmx5IDEzIEtiIG9mIGNvZGUgIDstKSBEb2Vzbid0IHJlYWQgQUZNIGZpbGVzIHRob3VnaCwgbm9yIHRoZQogICAgcmVhbGx5IHVzZWZ1bCBDTUFQIGZpbGVzLi4KCiAgLSBmaXhlZCB0d28gYnVncyBpbiB0aGUgc21vb3RoIHJlbmRlcmVyIChzcmMvYmFzZS9mdGdyYXlzLmMpLiBUaGFua3MKICAgIHRvIEJvcmlzIExldG9jaGEgZm9yIHNwb3R0aW5nIHRoZW0gYW5kIHByb3ZpZGluZyBhIGZpeC4uCgogIC0gZml4ZWQgcG90ZW50aWFsICJkaXZpZGUgYnkgemVybyIgYnVncyBpbiBmdGNhbGMuYy4uIG15IGdvZC4uCgogIC0gYWRkZWQgc291cmNlICBjb2RlIGZvciAgdGhlIE9wZW5UeXBlL0NGRiBkcml2ZXIgIChzdGlsbCBpbmNvbXBsZXRlCiAgICB0aG91Z2guLikKCiAgLSBtb2RpZmllZCB0aGUgIFNGTlQgZHJpdmVyIHNsaWdodGx5ICB0byBwZXJmb3JtIG1vcmUgIHJvYnVzdCBoZWFkZXIKICAgIGNoZWNrcyAgaW4gVFRfTG9hZF9TRk5UX0hlYWRlci4gVGhpcyAgcHJldmVudHMgY2VydGFpbiAgZm9udCBmaWxlcwogICAgKGUuZy4gIHNvbWUgIFR5cGUgIDEgIE11bHRpcGxlICBNYXN0ZXJzKSAgZnJvbSAgYmVpbmcgIGluY29ycmVjdGx5CiAgICAicmVjb2duaXplZCIgYXMgVHJ1ZVR5cGUgZm9udCBmaWxlcy4uCgogIC0gbW92ZWQgYSBsb3Qgb2Ygc3R1ZmYgZnJvbSAgdGhlIFRydWVUeXBlIGRyaXZlciB0byB0aGUgU0ZOVCBtb2R1bGUsCiAgICB0aGlzICAgYWxsb3dzICAgZ3JlYXRlciAgIGNvZGUgICByZS11c2UgICBiZXR3ZWVuICAgZm9udCAgIGRyaXZlcnMKICAgIChlLmcuIFRydWVUeXBlLCBPcGVuVHlwZSwgQ29tcGFjdC1UcnVlVHlwZSwgZXRjLi4pCgogIC0gYWRkZWQgYSB0aW55IHNlZ21lbnQgY2FjaGUgdG8gdGhlIFNGTlQgQ2hhcm1hcCA0IGRlY29kZXIsIGluIG9yZGVyCiAgICB0byBtaW5pbWFsbHkgc3BlZWQgaXQgdXAuLgoKICAtIGFkZGVkIHN1cHBvcnQgZm9yIE11bHRpcGxlIE1hc3RlciBmb250cyBpbiAidHlwZTF6Ii4gVGhlcmUgaXMgYWxzbwogICAgYSAgbmV3IGZpbGUgIG5hbWVkICA8ZnJlZXR5cGUvZnRtbS5oPiB3aGljaCAgZGVmaW5lcyBmdW5jdGlvbnMgIHRvCiAgICBtYW5hZ2UgdGhlbSBmcm9tIGNsaWVudCBhcHBsaWNhdGlvbnMuCgogICAgVGhlIG5ldyBmaWxlICJzcmMvYmFzZS9mdG1tLmMiIGlzIGFsc28gb3B0aW9uYWwgdG8gdGhlIGVuZ2luZS4uCgogIC0gdmFyaW91cyAgZm9ybWF0dGluZyBjaGFuZ2VzIChlLmcuICBFWFBPUlRfREVGIC0+ICBGVF9FWFBPUlRfREVGKSArCiAgICBzbWFsbCBidWcgZml4ZXMgaW4gRlRfTG9hZF9HbHlwaCwgdGhlICJ0eXBlMSIgZHJpdmVyLCBldGMuLgoKICAtIGEgbWlub3IgZml4IHRvIHRoZSBUeXBlIDEgZHJpdmVyIHRvIGxldCB0aGVtIGFwcGx5IHRoZSBmb250IG1hdHJpeAogICAgY29ycmVjdGx5ICh1c2VkIGZvciBtYW55IG9ibGlxdWUgZm9udHMuLikKCiAgLSBzb21lIGZpeGVzIGZvciA2NC1iaXQgc3lzdGVtcyAobWFpbmx5IGNoYW5naW5nIHNvbWUgRlRfVFJBQ0UgY2FsbHMKICAgIHRvIHVzZSAlcCBpbnN0ZWFkIG9mICVseCkuLiBUaGFua3MgdG8gS2FybCBSb2JpbGxhcmQKCiAgLSBmaXhlZCAgc29tZSBidWdzICBpbiAgdGhlIHNiaXQgIGxvYWRlciAoc3JjL2Jhc2Uvc2ZudC90dHNiaXQuYykgICsKICAgIGFkZGVkICBhIG5ldyBmbGFnLCAgRlRfTE9BRF9DUk9QX0JJVE1BUCB0byAgcXVlcnkgdGhhdCAgYml0bWFwcyBiZQogICAgY3JvcHBlZCB3aGVuICBsb2FkZWQgZnJvbSBhIGZpbGUgIChtYXliZSBJIHNob3VsZCAgbW92ZSB0aGUgYml0bWFwCiAgICBjcm9wcGVyIHRvIHRoZSBiYXNlIGxheWVyID8/KS4KCiAgLSBjaGFuZ2VkIHRoZSBkZWZhdWx0ICBudW1iZXIgb2YgZ3JheSBsZXZlbHMgb2YgIHRoZSBzbW9vdGggcmVuZGVyZXIKICAgIHRvIDI1NiAgKGluc3RlYWQgb2YgIHRoZSBwcmV2aW91cyAxMjgpLiAgT2YgY291cnNlLCB0aGUgIGh1bWFuIGV5ZQogICAgY2FuJ3Qgc2VlIGFueSBkaWZmZXJlbmNlIDstKQoKICAtIHJlbW92ZWQgVFRfTUFYX1NVQkdMWVBIUywgIHRoZXJlIGlzIG5vIHN0YXRpYyBsaW1pdCAgb24gdGhlIG51bWJlcgogICAgb2Ygc3ViZ2x5cGhzIGluIGEgVHJ1ZVR5cGUgZm9udCBub3cuLgoKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCk9MRCBDSEFOR0VTIDE2IE1heSAyMDAwCgogIC0gdGFnZ2VkICJCRVRBLTYiICBpbiB0aGUgIENWUyB0cmVlLiBUaGlzICBvbmUgaXMgYSAgc2VyaW91cyByZWxlYXNlCiAgICBjYW5kaWRhdGUgZXZlbiB0aG91Z2ggaXQgZG9lc24ndCBpbmNvcnBvcmF0ZSB0aGUgYXV0by1oaW50ZXIgeWV0Li4KCiAgLSB2YXJpb3VzIG9ic29sZXRlIGZpbGVzIHdlcmUgcmVtb3ZlZCwgYW5kIGNvcHlyaWdodCBoZWFkZXIgdXBkYXRlZAoKICAtIGZpbmFsbHkgIHVwZGF0ZWQgIHRoZSAgc3RhbmRhcmQgICByYXN0ZXIgIHRvICBmaXggIHRoZSAgbW9ub2Nocm9tZQogICAgcmVuZGVyaW5nIGJ1ZyArIHJlLWVuYWJsZSAgc3VwcG9ydCBmb3IgNS1ncmF5IGxldmVscyBhbnRpLWFsaWFzaW5nCiAgICAoc3Vjaywgc3Vjay4uKQoKICAtIGNyZWF0ZWQgbmV3IGhlYWRlciBmaWxlcywgYW5kIG1vZGlmaWVkIHNvdXJjZXMgYWNjb3JkaW5nbHk6CgogICAgIDxmcmVldHlwZS9mdHR5cGVzLmg+CiAgICAgICAtIHNpbXBsZSBGcmVlVHlwZSB0eXBlcywgd2l0aG91dCB0aGUgQVBJCiAgICAgPGZyZWV0eXBlL2ludGVybmFsL2Z0bWVtb3J5Lmg+CiAgICAgICAtIGRlZmluaXRpb24gb2YgbWVtb3J5LW1hbmFnZW1lbnQgbWFjcm9zCgogIC0gYWRkZWQgICB0aGUgICAiRFNJRyIgICAoT3BlblR5cGUgICBEaWdpdGFsICAgU2lnbmF0dXJlKSAgIHRhZyAgIHRvCiAgICA8ZnJlZXR5cGUvdHR0YWdzLmg+CgogIC0gbGlnaHQgdXBkYXRlL2NsZWFuaW5nIG9mIHRoZSBidWlsZCBzeXN0ZW0gKyBjaGFuZ2VzIHRvIHRoZSBzb3VyY2VzCiAgICBpbiAgb3JkZXIgIHRvICBnZXQgIHJpZCAgb2YgX2FsbF8gIGNvbXBpbGVyICB3YXJuaW5ncyAgd2l0aCAgdGhyZWUKICAgIGNvbXBpbGVycywgaS5lOgoKICAgIGdjYyB3aXRoICItYW5zaSAtcGVkYW50aWMgLVdhbGwgLVciLCBWaXN1YWwgQysrIHdpdGggIi9XMyAvV1giIGFuZAogICAgTENDCgogICAgSU1QT1JUQU5UIE5PVEUgRk9SIFdJTjMyLUxDQyBVU0VSUzoKICAgIHwKICAgIHwgIEl0IHNlZW1zIHRoZSBDIHByZS1wcm9jZXNzb3IgIHRoYXQgY29tZXMgd2l0aCBMQ0MgaXMgYnJva2VuLCBpdAogICAgfCAgZG9lc24ndCAgcmVjb2duaXplICB0aGUgIEFOU0kgIHN0YW5kYXJkICBkaXJlY3RpdmVzICAjICBhbmQgICMjCiAgICB8ICBjb3JyZWN0bHkgd2hlbiBvbmUgb2YgdGhlICBhcmd1bWVudCBpcyBhIG1hY3JvLiBBbHNvLCBzb21ldGhpbmcKICAgIHwgIGxpa2U6CiAgICB8CiAgICB8ICAgICAjZGVmaW5lIEYoeCkgIHByaW50IyN4CiAgICB8CiAgICB8ICAgICBGKCgiaGVsbG8iKSkKICAgIHwKICAgIHwgIHdpbGwgZ2V0IGluY29ycmVjdGx5IHRyYW5zbGF0ZWQgdG86CiAgICB8CiAgICB8ICAgICBwcmludCAiaGVsbG8iKQogICAgfAogICAgfCAgYnkgaXRzIHByZS1wcm9jZXNzb3IuIEZvciAgdGhpcyByZWFzb24sIHlvdSBzaW1wbHkgY2Fubm90IGJ1aWxkCiAgICB8ICBGcmVlVHlwZSAyIGluIGRlYnVnIG1vZGUgd2l0aCB0aGlzIGNvbXBpbGVyLi4KCiAgLSB5ZXQgYW5vdGhlciBtYXNzaXZlIGdydW50IHdvcmsuIEkndmUgY2hhbmdlZCB0aGUgZGVmaW5pdGlvbiBvZiB0aGUKICAgIEVYUE9SVF9ERUYsICBFWFBPUlRfRlVOQywgQkFTRV9ERUYgJiAgQkFTRV9GVU5DIG1hY3Jvcy4gIFRoZXNlIG5vdwogICAgdGFrZSBhbiBhcmd1bWVudCwgd2hpY2ggaXMgdGhlIGZ1bmN0aW9uJ3MgcmV0dXJuIHZhbHVlIHR5cGUuCgogICAgVGhpcyAgaXMgbmVjZXNzYXJ5IHRvICBjb21waWxlIEZyZWVUeXBlICBhcyBhICBETEwgb24gIFdpbmRvd3MgYW5kCiAgICBPUy8yLiAgRGVwZW5kaW5nIG9uIHRoZSBjb21waWxlciB1c2VkLCBhIGNvbXBpbGVyLXNwZWNpZmljIGtleXdvcmQKICAgIGxpa2UgIF9fZXhwb3J0IG9yIF9fc3lzdGVtICBtdXN0IGJlICBwbGFjZWQgYmVmb3JlICAoVmlzdWFsQysrKSBvcgogICAgYWZ0ZXIgKEJvcmxhbmRDKyspIHRoZSB0eXBlLi4KCiAgICBPZiBjb3Vyc2UsIHRoaXMgbmVlZGVkIGEgbG90IG9mIGNoYW5nZXMgdGhyb3VnaG91dCB0aGUgc291cmNlIGNvZGUKICAgIHRvIG1ha2UgaXQgY29tcGlsZSBhZ2Fpbi4uLiBBbGwgY2xlYW5lZCB1cCBub3csIGFwcGFyZW50bHkuLgoKICAgIE5vdGUgYWxzbyAgdGhhdCB0aGVyZSBpcyBhICBuZXcgRVhQT1JUX1ZBUiBtYWNybyAgZGVmaW5lZCB0byBhbGxvdwogICAgdGhlICAgX2RlY2xhcmF0aW9uXyAgICBvZiAgIGFuICAgZXhwb3J0YWJsZSAgICBwdWJsaWMgICAoY29uc3RhbnQpCiAgICB2YXJpYWJsZS4gIFRoaXMgIGlzICB0aGUgICBjYXNlICBvZiAgdGhlICByYXN0ZXIgIGludGVyZmFjZXMgIChzZWUKICAgIGZ0cmFzdGVyLmggYW5kIGZ0Z3JheXMuaCksIGFzIHdlbGwgYXMgZWFjaCBtb2R1bGUncyBpbnRlcmZhY2UgKHNlZQogICAgc2Zkcml2ZXIuaCwgcHNkcml2ZXIuaCwgZXRjLi4pCgogIC0gbmV3IGZlYXR1cmU6IGl0ICBpcyBub3cgcG9zc2libGUgdG8gcGFzcyAgZXh0cmEgcGFyYW1ldGVycyB0byBmb250CiAgICAgICAgICAgICAgICAgZHJpdmVycyAgd2hlbiBjcmVhdGluZyAgYSBuZXcgIGZhY2Ugb2JqZWN0LiAgRm9yIG5vdywKICAgICAgICAgICAgICAgICB0aGlzIGNhcGFiaWxpdHkgaXMgdW51c2VkLiAgSXQgY291bGQgaG93ZXZlciBwcm92ZSB0bwogICAgICAgICAgICAgICAgIGJlIHVzZWZ1bCBpbiBhIG5lYXIgZnV0dXJlLi4KCiAgICAgIHRoZSBGVF9PcGVuX0FyZ3Mgc3RydWN0dXJlIHdhcyAgY2hhbmdlcywgYXMgd2VsbCBhcyB0aGUgaW50ZXJuYWwKICAgICAgZHJpdmVyIGludGVyZmFjZSAgKHRoZSBzcGVjaWZpYyAiaW5pdF9mYWNlIiAgbW9kdWxlIGZ1bmN0aW9uIGhhcwogICAgICBub3cgYSBkaWZmZXJlbnQgc2lnbmF0dXJlKS4KCiAgLSB1cGRhdGVkIHRoZSB0dXRvcmlhbCAobm90IGZpbmlzaGVkIHRob3VnaCkuCgogIC0gdXBkYXRlZCB0aGUgdG9wLWxldmVsIEJVSUxEICBkb2N1bWVudAoKICAtIGZpeGVkICBhICBwb3RlbnRpYWwgbWVtb3J5ICBsZWFrICB0aGF0ICBjb3VsZCAgb2NjdXIgd2hlbiAgbG9hZGluZwogICAgZW1iZWRkZWQgYml0bWFwcy4KCiAgLSBhZGRlZCAgICAgdGhlICAgICBkZWNsYXJhdGlvbiAgICAgb2YgICAgIEZUX05ld19NZW1vcnlfRmFjZSAgICAgaW4KICAgIDxmcmVldHlwZS9mcmVldHlwZS5oPiwgYXMgIGl0IHdhcyAgbWlzc2luZyBmcm9tIHRoZSAgcHVibGljIGhlYWRlcgogICAgKHRoZSBpbXBsZW1lbnRhdGlvbiB3YXMgYWxyZWFkeSBpbiAiZnRvYmpzLmMiKS4KCiAgLSB0aGUgZmlsZSA8ZnJlZXR5cGUvZnRlcnJvcnMuaD4gaGFzIGJlZW4gc2VyaW91c2x5IHVwZGF0ZWQgaW4gb3JkZXIKICAgIHRvIGFsbG93IHRoZSBhdXRvbWF0aWMgZ2VuZXJhdGlvbiBvZiBlcnJvciBtZXNzYWdlIHRhYmxlcy4gU2VlIHRoZQogICAgY29tbWVudHMgd2l0aGluIGl0IGZvciBtb3JlIGluZm9ybWF0aW9uLgoKICAtIG1ham9yIGRpcmVjdG9yeSAgaGllcmFyY2h5IHJlLW9yZ2FuaXNhdGlvbi4gVGhpcyB3YXMgIGRvbmUgZm9yIHR3bwogICAgdGhpbmdzOgoKICAgICAgKiBmaXJzdCwgIHRvIGVhc2UgIHRoZSAibWFudWFsIiAgY29tcGlsYXRpb24gb2YgIHRoZSAgbGlicmFyeSBieQogICAgICAgIHJlcXVpcmluZyBhdCBsb3QgbGVzcyBpbmNsdWRlIHBhdGhzIDotKQoKICAgICAgKiBzZWNvbmQsICB0byAgYWxsb3cgIGV4dGVybmFsICBwcm9ncmFtcyB0byAgZWZmZWN0aXZlbHkgIGFjY2VzcwogICAgICAgIGludGVybmFsICBkYXRhICBmaWVsZHMuIEZvciAgZXhhbXBsZSwgIHRoaXMgIGNhbiBiZSAgZXh0cmVtZWx5CiAgICAgICAgdXNlZnVsIGlmICBzb21lb25lIHdhbnRzICB0byB3cml0ZSBhICBmb250IHByb2R1Y2VyIG9yICBhIGZvbnQKICAgICAgICBtYW5hZ2VyIG9uIHRvcCBvZiBGcmVlVHlwZS4KCiAgICBCYXNpY2FsbHksIHlvdSAgc2hvdWxkIG5vdyB1c2UgIHRoZSAnZnJlZXR5cGUvJyBwcmVmaXggIGZvciBoZWFkZXIKICAgIGluY2x1c2lvbiwgYXMgaW46CgogICAgICAgICNpbmNsdWRlIDxmcmVldHlwZS9mcmVldHlwZS5oPgogICAgICAgICNpbmNsdWRlIDxmcmVldHlwZS9mdGdseXBoLmg+CgogICAgU29tZSBuZXcgaW5jbHVkZSBzdWItZGlyZWN0b3JpZXMgYXJlIGF2YWlsYWJsZToKCiAgICAgYS4gdGhlICAiZnJlZXR5cGUvY29uZmlnIiBkaXJlY3RvcnksICBjb250YWlucyB0d28gZmlsZXMgIHVzZWQgdG8KICAgICAgICBjb25maWd1cmUgdGhlIGJ1aWxkIG9mIHRoZSBsaWJyYXJ5LiBDbGllbnQgYXBwbGljYXRpb25zIHNob3VsZAogICAgICAgIG5vdCBuZWVkIHRvIGxvb2sgYXQgdGhlc2Ugbm9ybWFsbHksIGJ1dCB0aGV5IGNhbiBpZiB0aGV5IHdhbnQuCgogICAgICAgICNpbmNsdWRlIDxmcmVldHlwZS9jb25maWcvZnRvcHRpb24uaD4KICAgICAgICAjaW5jbHVkZSA8ZnJlZXR5cGUvY29uZmlnL2Z0Y29uZmlnLmg+CgogICAgIGIuIHRoZSAiZnJlZXR5cGUvaW50ZXJuYWwiICBkaXJlY3RvcnksIGNvbnRhaW5zIGhlYWRlciBmaWxlcyB0aGF0CiAgICAgICAgZGVzY3JpYmVzIGxpYnJhcnkgIGludGVybmFscy4gVGhlc2UgYXJlIHRoZSAgaGVhZGVyIGZpbGVzIHRoYXQKICAgICAgICB3ZXJlICBwcmV2aW91c2x5ICBmb3VuZCAgaW4gIHRoZSAic3JjL2Jhc2UiICBhbmQgICJzcmMvc2hhcmVkIgogICAgICAgIGRpcmVjdG9yaWVzLgoKCiAgICBBcyAgdXN1YWwsIHRoZSBidWlsZCAgc3lzdGVtIGFuZCAgdGhlIGRlbW9zICBoYXZlIGJlZW4gIHVwZGF0ZWQgdG8KICAgIHJlZmxlY3QgdGhlIGNoYW5nZS4uCgogICAgSGVyZSdzIGEgbGF5b3V0IG9mIHRoZSBuZXcgZGlyZWN0b3J5IGhpZXJhcmNoeToKCiAgICBUT1BfRElSCiAgICAgIGluY2x1ZGUvCiAgICAgICAgIGZyZWV0eXBlLwogICAgICAgICAgICBmcmVldHlwZS5oCiAgICAgICAgICAgIC4uLgogICAgICAgICAgICBjb25maWcvCiAgICAgICAgICAgICAgZnRvcHRpb24uaAogICAgICAgICAgICAgIGZ0Y29uZmlnLmgKICAgICAgICAgICAgICBmdG1vZHVsZS5oCgogICAgICAgICAgICBpbnRlcm5hbC8KICAgICAgICAgICAgICBmdG9ianMuaAogICAgICAgICAgICAgIGZ0c3RyZWFtLmgKICAgICAgICAgICAgICBmdGNhbGMuaAogICAgICAgICAgICAgIC4uLgoKICAgICAgc3JjLwogICAgICAgICBiYXNlLwogICAgICAgICAgICAuLi4KCiAgICAgICAgIHNmbnQvCiAgICAgICAgIHBzbmFtZXMvCiAgICAgICAgIHRydWV0eXBlLwogICAgICAgICB0eXBlMS8KICAgICAgICAgdHlwZTF6LwoKCiAgICBDb21waWxpbmcgYSBtb2R1bGUgaXMgbm93ICBtdWNoIGVhc2llciwgZm9yIGV4YW1wbGUsIHRoZSBmb2xsb3dpbmcKICAgIHNob3VsZCB3b3JrIHdoZW4gaW4gdGhlIFRPUF9ESVIgZGlyZWN0b3J5IG9uIGFuIEFOU0kgYnVpbGQ6CgogICAgICAgZ2NjIC1jIC1JLi9pbmNsdWRlIC1JLi9zcmMvYmFzZSBzcmMvYmFzZS9mdGJhc2UuYwogICAgICAgZ2NjIC1jIC1JLi9pbmNsdWRlIC1JLi9zcmMvc2ZudCBzcmMvc2ZudC9zZm50LmMKICAgICAgIGV0Yy4uCgogICAgKG9mIGNvdXJzZSwgdXNpbmcgLUljb25maWcvPHN5c3RlbT4gaWYgeW91IHByb3ZpZGUgc3lzdGVtLXNwZWNpZmljCiAgICAgY29uZmlndXJhdGlvbiBmaWxlcykuCgogIC0gdXBkYXRlZCB0aGUgc3RydWN0dXJlIG9mIEZUX091dGxpbmVfRnVuY3MgaW4gb3JkZXIgdG8gYWxsb3cgZGlyZWN0CiAgICBjb29yZGluYXRlIHNjYWxpbmcgd2l0aGluICB0aGUgb3V0bGluZSBkZWNvbXBvc2l0aW9uIHJvdXRpbmUgKHRoaXMKICAgIGlzICBpbXBvcnRhbnQgZm9yIHZpcnR1YWwgICJvbiIgcG9pbnRzICB3aXRoIFRydWVUeXBlICBvdXRsaW5lcykgKwogICAgdXBkYXRlcyB0byB0aGUgcmFzdGVycyB0byBzdXBwb3J0IHRoaXMuLgoKICAtIHVwZGF0ZWQgIHRoZSBPUy8yICB0YWJsZSAgbG9hZGluZyBjb2RlICBpbiAic3JjL3NmbnQvdHRsb2FkLmMiICBpbgogICAgb3JkZXIgdG8gc3VwcG9ydCB2ZXJzaW9uIDIgb2YgdGhlIHRhYmxlIChzZWUgT3BlblR5cGUgMS4yIHNwZWMpCgogIC0gY3JlYXRlZCAgImluY2x1ZGUvdHR0YWJsZXMuaCIgIGFuZCAgImluY2x1ZGUvdDF0YWJsZXMuaCIgdG8gIGFsbG93CiAgICBjbGllbnQgYXBwbGljYXRpb25zIHRvIGFjY2VzcyBzb21lIG9mICB0aGUgU0ZOVCBhbmQgVDEgdGFibGVzIG9mIGEKICAgIGZhY2UgIHdpdGggIGEgIHByb2NlZHVyYWwgIGludGVyZmFjZSAoc2VlICBGVF9HZXRfU2ZudF9UYWJsZSgpKSAgKwogICAgdXBkYXRlcyB0byBpbnRlcm5hbCBzb3VyY2UgZmlsZXMgdG8gcmVmbGVjdCB0aGUgY2hhbmdlLi4KCiAgLSBzb21lICBjbGVhbnVwcyBpbiAgdGhlIHNvdXJjZSAgY29kZSB0byAgZ2V0IHJpZCAgb2YgIHdhcm5pbmdzIHdoZW4KICAgIGNvbXBpbGluZyB3aXRoIHRoZSAiLVdhbGwgLVcgLWFuc2kgLXBlZGFudGljIiBvcHRpb25zIGluIGdjYy4KCiAgLSBkZWJ1Z2dlZCBhbmQgbW92ZWQgdGhlIHNtb290aCByZW5kZXJlciB0byAic3JjL2Jhc2UvZnRncmF5cy5jIiBhbmQKICAgIGl0cyBoZWFkZXIgdG8gImluY2x1ZGUvZnRncmF5cy5oIgoKICAtIHVwZGF0ZWQgVFRfTUFYX1NVQkdMWVBIUyAgdG8gOTYgYXMgc29tZSBDSksgIGZvbnRzIGhhdmUgY29tcG9zaXRlcwogICAgd2l0aCB1cCB0byA4MCBzdWItZ2x5cGhzICEhIFRoYW5rcyB0byBXZXJuZXIKCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpPTEQgQ0hBTkdFUyAtIDE0LWFwci0yMDAwCgogIC0gZml4ZWQgIGEgYnVnICBpbiAgdGhlICBUcnVlVHlwZSBnbHlwaCAgbG9hZGVyICB0aGF0IHByZXZlbnRlZCAgdGhlCiAgICBjb3JyZWN0IGxvYWRpbmcgb2Ygc29tZSBDSksgZ2x5cGhzIGluIG1pbmdsaS50dGYKCiAgLSBpbXByb3ZlZCB0aGUgc3RhbmRhcmQgVHlwZSAxIGhpbnRlciBpbiAic3JjL3R5cGUxIgoKICAtIGZpeGVkIHR3byBidWdzICBpbiB0aGUgZXhwZXJpbWVudGFsIFR5cGUgMSAgZHJpdmVyIGluICJzcmMvdHlwZTF6IgogICAgdG8gaGFuZGxlIHRoZSBuZXcgWEZyZWU4NiA0LjAgZm9udHMgKGFuZCBhIGZldyBvdGhlciBvbmVzLi4pCgogIC0gdGhlIHNtb290aCAgcmVuZGVyZXIgaXMgbm93ICBjb21wbGV0ZSBhbmQgc3VwcG9ydHMgIHN1Yi1iYW5kaW5nIHRvCiAgICByZW5kZXIgbGFyZ2UgZ2x5cGhzIGF0IGhpZ2ggc3BlZWQuIEhvd2V2ZXIsIGl0IGlzIHN0aWxsIGxvY2F0ZWQgaW4KICAgICJkZW1vcy9zcmMvZnRncmF5cy5jIiBhbmQgc2hvdWxkIG1vdmUgdG8gdGhlIGxpYnJhcnkgaXRzZWxmIGluIHRoZQogICAgbmV4dCAgYmV0YS4uICAgTk9URTogIFRoZSAgc21vb3RoICByZW5kZXJlciAgIGRvZXNuJ3QgIGNvbXBpbGUgIGluCiAgICBzdGFuZC1hbG9uZSBtb2RlIGFueW1vcmUsIGJ1dCB0aGlzIHNob3VsZCBiZSBmaXhlZCBSU04uLgoKICAtIGludHJvZHVjZWQgY29udmVuaWVuY2UgIGZ1bmN0aW9ucyB0byAgbW9yZSBlYXNpbHkgZGVhbCAgd2l0aCBnbHlwaAogICAgaW1hZ2VzLCBzZWUgICJpbmNsdWRlL2Z0Z2x5cGguaCIgZm9yIG1vcmUgZGV0YWlscywgYXMgIHdlbGwgYXMgdGhlCiAgICBuZXcgIGRlbW8gcHJvZ3JhbSAgbmFtZWQgImRlbW9zL3NyYy9mdHN0cmluZy5jIiAgdGhhdCBkZW1vbnN0cmF0ZXMKICAgIGl0cyB1c2UKCiAgLSBpbXBsZW1lbnRlZCAgRlRfTE9BRF9OT19SRUNVUlNFIGluICBib3RoIHRoZSAgVHJ1ZVR5cGUgYW5kICBUeXBlIDEKICAgIGRyaXZlcnMgICh0aGlzICBpcyByZXF1aXJlZCAgYnkgIHRoZSAgYXV0by1oaW50ZXIgIHRvIGltcHJvdmUgIGl0cwogICAgcmVzdWx0cykuCgogIC0gY2hhbmdlZCAgIHRoZSAgcmFzdGVyICAgaW50ZXJmYWNlLCAgaW4gICBvcmRlciAgdG8gICBhbGxvdyAgY2xpZW50CiAgICBhcHBsaWNhdGlvbnMgdG8gcHJvdmlkZSB0aGVpciBvd24gc3Bhbi1kcmF3aW5nIGNhbGxiYWNrcy4gSG93ZXZlciwKICAgIG9ubHkgdGhlIHNtb290aCByZW5kZXJlciAgc3VwcG9ydHMgdGhpcy4gU2VlICJGVF9SYXN0ZXJfUGFyYW1zIiBpbgogICAgdGhlIGZpbGUgImluY2x1ZGUvZnRpbWFnZS5oIgoKICAtIGZpeGVkICBhIHNtYWxsIGJ1ZyAgaW4gRlRfTXVsRml4ICB0aGF0IGNhdXNlZCAgaW5jb3JyZWN0IHRyYW5zZm9ybQogICAgY29tcHV0YXRpb24hCgogIC0gTm90ZTogVGhlIHR1dG9yaWFsIGlzIG91dC1vZi1kYXRlLCBncnVtcGYuLiA6LSgKCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpPTEQgQ0hBTkdFUyAtIDEyLW1hci0yMDAwCgogIC0gY2hhbmdlZCAgdGhlICBsYXlvdXQgIG9mICBjb25maWd1cmF0aW9uICBmaWxlcyAgOiAgbm93LCAgYWxsICBBTlNJCiAgICBjb25maWd1cmF0aW9uICAgICAgICAgZmlsZXMgICAgICAgICBhcmUgICAgICAgICBsb2NhdGVkICAgICAgICAgaW4KICAgICJmcmVldHlwZTIvY29uZmlnIi4gIFN5c3RlbS1zcGVjaWZpYyBvdmVyLXJpZGVzICBjYW4gYmUgIHBsYWNlZCBpbgogICAgImZyZWV0eXBlMi9jb25maWcvPHN5c3RlbT4iLgoKICAtIG1vdmVkIGFsbCBjb25maWd1cmF0aW9uIG1hY3JvcyB0byAiY29uZmlnL2Z0b3B0aW9uLmgiCgogIC0gaW1wcm92ZW1lbnRzIGluIHRoZSBUeXBlIDEgZHJpdmVyIHdpdGggQUZNIHN1cHBvcnQKCiAgLSBjaGFuZ2VkIHRoZSBmaWVsZHMgIGluIHRoZSBGVF9PdXRsaW5lIHN0cnVjdHVyZSA6ICB0aGUgb2xkICJmbGFncyIKICAgIGFycmF5IGlzIHJlLW5hbWVkICJ0YWdzIiwgd2hpbGUgYWxsIGFuY2llbnQgZmxhZ3MgYXJlIGVuY29kZWQgaW50bwogICAgYSBzaW5nbGUgdW5zaWduZWQgaW50IG5hbWVkICJmbGFncyIuCgogIC0gaW50cm9kdWNlZCAgICAgbmV3ICAgICAgZmxhZ3MgICAgIGluICAgICBGVF9PdXRsaW5lLmZsYWdzICAgICAoc2VlCiAgICBmdF9vdXRsaW5lXy4uLi4gZW51bXMgaW4gImZ0aW1hZ2UuaCIpLgoKICAtIGNoYW5nZWQgb3V0bGluZSBmdW5jdGlvbnMgdG8gIkZUX091dGxpbmVfPGFjdGlvbj4iIHN5bnRheAoKICAtIGFkZGVkIGEgc21vb3RoIGFudGktYWxpYXMgcmVuZGVyZXIgdG8gdGhlIGRlbW9uc3RyYXRpb24gcHJvZ3JhbXMKCiAgLSBhZGRlZCBNYWMgZ3JhcGhpY3MgZHJpdmVyICh0aGFua3MgSnVzdCkKCiAgLSBGVF9PcGVuX0ZhY2UgIGNoYW5nZWQgIGluICBvcmRlciAgIHRvICByZWNlaXZlZCAgYSAgcG9pbnRlciAgdG8gIGEKICAgIEZUX09wZW5fQXJncyBkZXNjcmlwdG9yLi4KCiAgLSB2YXJpb3VzICBjbGVhbnVwcywgIGEgIGZldyAgbW9yZSBBUEkgIGZ1bmN0aW9ucyAgaW1wbGVtZW50ZWQgIChzZWUKICAgIEZUX0F0dGFjaF9GaWxlKQoKICAtIHVwZGF0ZWQgc29tZSBkb2NzCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKT0xEIENIQU5HRVMgLSAyMi1mZWItMjAwMAoKICAtIGludHJvZHVjZWQgdGhlICJwc25hbWVzIiBtb2R1bGUuIEl0IGlzIHVzZWQgdG86CgogICAgICBvIGNvbnZlcnQgIGEgUG9zdHNjcmlwdCBnbHlwaCAgbmFtZSBpbnRvIHRoZSAgZXF1aXZhbGVudCBVbmljb2RlCiAgICAgICAgY2hhcmFjdGVyIGNvZGUgKHVzZWQgYnkgdGhlICBUeXBlIDEgZHJpdmVyKHMpIHRvIHN5bnRoZXRpemUgb24KICAgICAgICB0aGUgZmx5IGEgVW5pY29kZSBjaGFybWFwKS4KCiAgICAgIG8gcHJvdmlkZSBhbiAgaW50ZXJmYWNlIHRvIHJldHJpZXZlIHRoZSBQb3N0c2NyaXB0ICBuYW1lcyBvZiB0aGUKICAgICAgICBNYWNpbnRvc2gsICBBZG9iZSAgU3RhbmRhcmQgJiAgQWRvYmUgIEV4cGVydCBjaGFyYWN0ZXIgIGNvZGVzLgogICAgICAgICh0aGUgTWFjaW50b3NoICBuYW1lcyBhcmUgIHVzZWQgYnkgdGhlICBTRk5ULW1vZHVsZSBwb3N0c2NyaXB0CiAgICAgICAgbmFtZXMgc3VwcG9ydCByb3V0aW5lcywgd2hpbGUgdGhlIG90aGVyIHR3byB0YWJsZXMgYXJlIHVzZWQgYnkKICAgICAgICB0aGUgVHlwZSAxIGRyaXZlcihzKSkuCgogIC0gaW50cm9kdWNlZCB0aGUgInR5cGUxeiIgYWx0ZXJuYXRlIFR5cGUgIDEgZHJpdmVyLiBUaGlzIGlzIGEgKHN0aWxsCiAgICBleHBlcmltZW50YWwpIGRyaXZlciAgZm9yIHRoZSBUeXBlICAxIGZvcm1hdCB0aGF0ICB3aWxsIHVsdGltYXRlbHkKICAgIHJlcGxhY2UgdGhlIG9uZSAgaW4gInNyYy90eXBlMSIuIEl0IHVzZXMgcGF0dGVybiAgbWF0Y2hpbmcgdG8gbG9hZAogICAgZGF0YSBmcm9tIHRoZSAgZm9udCwgaW5zdGVhZCBvZiBhIGZpbml0ZSAgc3RhdGUgYW5hbHl6ZXIuIEl0IHdvcmtzCiAgICBtdWNoIGJldHRlciB0aGFuIHRoZSAib2xkIiAgZHJpdmVyIHdpdGggImJyb2tlbiIgZm9udHMuIEl0IGlzIGFsc28KICAgIG11Y2ggc21hbGxlciAodW5kZXIgMTUgS2IpLgoKICAtIHRoZSAgVHlwZSAxICBkcml2ZXJzIChib3RoICBpbiAic3JjL3R5cGUxIiAgYW5kICAic3JjL3R5cGUxeiIpIGFyZQogICAgbmVhcmx5ICBjb21wbGV0ZS4gIFRoZXkgIGJvdGggIHByb3ZpZGUgYXV0b21hdGljICBVbmljb2RlICBjaGFybWFwCiAgICBzeW50aGVzaXMgdGhyb3VnaCAgdGhlICJwc25hbWVzIiBtb2R1bGUuIE5vICByZS1lbmNvZGluZyB2ZWN0b3IgaXMKICAgIG5lZWRlZC4gIChub3RlICB0aGF0IHRoZXkgIHN0aWxsICBsZWFrICBtZW1vcnkgIGR1ZSB0byAgc29tZSAgY29kZQogICAgbWlzc2luZywgYW5kIEknbSBnZXR0aW5nIGxhenkpLgoKICAgIFRyaXZpYWwgQUZNIHN1cHBvcnQgaGFzIGJlZW4gYWRkZWQgdG8gcmVhZCBrZXJuaW5nIGluZm9ybWF0aW9uIGJ1dAogICAgd2Fzbid0IGV4YWN0bHkgdGVzdGVkIGFzIGl0IHNob3VsZCA7LSkKCiAgLSBUaGUgVHJ1ZVR5cGUgIGdseXBoIGxvYWRlciBoYXMgIGJlZW4gc2VyaW91c2x5IHJld3JpdHRlbiAgKHNlZSB0aGUKICAgIGZpbGUgICJzcmMvdHJ1ZXR5cGUvdHRnbG9hZC5jIi4gSXQgIGlzIG5vdyAgbXVjaCwgbXVjaCAgc2ltcGxlciBhcwogICAgd2VsbCBhcyAgZWFzaWVyIHRvIHJlYWQsICBtYWludGFpbiBhbmQgdW5kZXJzdGFuZCAgOi0pIFByZWxpbWluYXJ5CiAgICB2ZXJzaW9ucyBpbnRyb2R1Y2VkIGEgIG1lbW9yeSBsZWFrIHRoYXQgaGFzIGJlZW4gIHJlcG9ydGVkIGJ5IEphY2sKICAgIERhdmlzLCBhbmQgaXMgbm93IGZpeGVkLi4KCiAgLSBpbnRyb2R1Y2VkICB0aGUgbmV3ICAiZnRfZ2x5cGhfZm9ybWF0X3Bsb3R0ZXIiLCB1c2VkICB0byByZXByZXNlbnQKICAgIHN0cm9rZWQgb3V0bGluZXMgIGxpa2UgV2luZG93cyAiVmVjdG9yIiBmb250cywgYW5kICBjZXJ0YWluIFR5cGUgMQogICAgZm9udHMgIGxpa2UgIkhlcnNoZXkiLiAgVGhlIGNvcnJlc3BvbmRpbmcgIHJhc3RlciB3aWxsICBiZSB3cml0dGVuCiAgICBzb29uLgoKICAtIEZUX05ld19NZW1vcnlfRmFjZSAgaXMgIGdvbmUuICBMaWtld2lzZSwgIEZUX09wZW5fRmFjZSBoYXMgIGEgIG5ldwogICAgaW50ZXJmYWNlIHRoYXQgdXNlcyBhIHN0cnVjdHVyZSAgdG8gZGVzY3JpYmUgdGhlIGlucHV0IHN0cmVhbSwgdGhlCiAgICBkcml2ZXIgKGlmIHJlcXVpcmVkKSwgZXRjLi4KCgpUT0RPCgogIC0gV3JpdGUgRlRfR2V0X0dseXBoX0JpdG1hcCBhbmQgRlRfTG9hZF9HbHlwaF9CaXRtYXAKCiAgLSBBZGQgYSBmdW5jdGlvbiBsaWtlIEZUX0xvYWRfQ2hhcmFjdGVyKCBmYWNlLCBjaGFyX2NvZGUsIGxvYWRfZmxhZ3MKICAgICkgIHRoYXQgIHdvdWxkIHJlYWxseSAgZW1iYmVkICBhICBjYWxsICB0byBGVF9HZXRfQ2hhcl9JbmRleCAgdGhlbgogICAgRlRfTG9hZF9HbHlwaCB0byBlYXNlIGRldmVsb3BlcidzIHdvcmsuCgogIC0gVXBkYXRlIHRoZSB0dXRvcmlhbCEKCiAgLSBjb25zaWRlciBhZGRpbmcgIHN1cHBvcnQgZm9yIE11bHRpcGxlICBNYXN0ZXIgZm9udHMgaW4gdGhlICBUeXBlIDEKICAgIGRyaXZlcnMuCgogIC0gVGVzdCB0aGUgQUZNIHJvdXRpbmVzIG9mIHRoZSAgVHlwZSAxIGRyaXZlcnMgdG8gY2hlY2sgdGhhdCBrZXJuaW5nCiAgICBpbmZvcm1hdGlvbiBpcyByZXR1cm5lZCBjb3JyZWN0bHkuCgogIC0gd3JpdGUgYSBkZWNlbnQgYXV0by1ncmlkZGluZyBjb21wb25lbnQgICEhIFdlIG5lZWQgdGhpcyB0byByZWxlYXNlCiAgICBGcmVlVHlwZSAyLjAgZ29sZCAhCgoKbGVzcyB1cmdlbnQgbmVlZHM6CgogIC0gYWRkIGEgQ0ZGL1R5cGUyIGRyaXZlcgogIC0gYWRkIGEgQkRGIGRyaXZlcgogIC0gYWRkIGEgRk5UL1BDRi9IQkYgZHJpdmVyCiAgLSBhZGQgYSBTcGVlZG8gZHJpdmVyIGZyb20gdGhlIFgxMSBzb3VyY2VzCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKT0xERVIgQ0hBTkdFUyAtIDI3LWphbi0yMDAwCgogIC0gdXBkYXRlZCB0aGUgICJzZm50IiBtb2R1bGUgIGludGVyZmFjZSB0byBhbGxvdyAgc2V2ZXJhbCBTRk5ULWJhc2VkCiAgICBkcml2ZXJzIHRvIGNvLWV4aXN0IHBlYWNlZnVsbHkKCiAgLSB1cGRhdGVkICB0aGUgIlQxX0ZhY2UiICB0eXBlICB0byBiZXR0ZXIgIHNlcGFyYXRlIFBvc3RzY3JpcHQgIGZvbnQKICAgIGNvbnRlbnQgIGZyb20gdGhlICByZXN0IG9mICB0aGUgRlRfRmFjZSAgc3RydWN0dXJlLiBNaWdodCAgYmUgdXNlZAogICAgbGF0ZXIgYnkgdGhlIENGRi9UeXBlMiBkcml2ZXIuLgoKICAtIGFkZGVkIGFuIGV4cGVyaW1lbnRhbCByZXBsYWNlbWVudCBUeXBlIDEgZHJpdmVyIGZlYXR1cmluZyBhZHZhbmNlZAogICAgKGFuZCBzcGVlZHkpIHBhdHRlcm4gbWF0Y2hpbmcgdG8gcmV0cmlldmUgdGhlIGRhdGEgZnJvbSBwb3N0c2NyaXB0CiAgICBmb250cy4KCiAgLSB2ZXJ5IG1pbm9yICBjaGFuZ2VzIGluIHRoZSBpbXBsZW1lbnRhdGlvbiAgb2YgRlRfU2V0X0NoYXJfU2l6ZSBhbmQKICAgIEZUX1NldF9QaXhlbF9TaXplcyAodGhleSBub3cgaW1wbGVtZW50IGRlZmF1bHQgdG8gbGlndGhlbiB0aGUgZm9udAogICAgZHJpdmVyJ3MgY29kZSkuCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKT0xEIE1FU1NBR0UKClRoaXMgZmlsZSBzdW1tYXJpemVzIHRoZSBjaGFuZ2VzIHRoYXQgb2NjdXJlZCBzaW5jZSB0aGUgbGFzdCAiYmV0YSIgb2YKRnJlZVR5cGUgMi4gIEJlY2F1c2UgIHRoZSBsaXN0IGlzIGltcG9ydGFudCwgaXQgIGhhcyBiZWVuIGRpdmlkZWQgaW50bwpzZXBhcmF0ZSBzZWN0aW9uczoKClRhYmxlIE9mIENvbnRlbnRzOgoKICAgIEkgICBIaWdoLUxldmVsIEludGVyZmFjZSAoZWFzaWVyICEpCiAgIElJICAgRGlyZWN0b3J5IFN0cnVjdHVyZQogIElJSSAgIEdseXBoIEltYWdlIEZvcm1hdHMKICAgSVYgICBCdWlsZCBTeXN0ZW0KICAgIFYgICBQb3J0YWJpbGl0eQogICBWSSAgIEZvbnQgRHJpdmVycwoKCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCkhpZ2gtTGV2ZWwgSW50ZXJmYWNlOgoKICBUaGUgaGlnaC1sZXZlbCBBUEkgaGFzIGJlZW4gY29uc2lkZXJhYmx5IHNpbXBsaWZpZWQuICBIZXJlIGlzIGhvdzoKCiAgICAtIHJlc291cmNlIG9iamVjdHMgaGF2ZSBkaXNhcHBlYXJlZC4gIHRoaXMgbWVhbnMgdGhhdCBmYWNlIG9iamVjdHMKICAgICAgY2FuIG5vdyBiZSBjcmVhdGVkIHdpdGggIGEgc2luZ2xlIGZ1bmN0aW9uIGNhbGwgKHNlZSBGVF9OZXdfRmFjZQogICAgICBhbmQgRlRfT3Blbl9GYWNlKQoKICAgIC0gd2hlbiBjYWxsaW5nICBlaXRoZXIgRlRfTmV3X0ZhY2UgICYgRlRfT3Blbl9GYWNlLCBhICBzaXplIG9iamVjdAogICAgICBhbmQgYSBnbHlwaCBzbG90IG9iamVjdCAgYXJlIGF1dG9tYXRpY2FsbHkgY3JlYXRlZCBmb3IgdGhlIGZhY2UsCiAgICAgIGFuZCBjYW4gIGJlIGFjY2Vzc2VkICB0aHJvdWdoICJmYWNlLT5nbHlwaCIgYW5kICAiZmFjZS0+c2l6ZSIgaWYKICAgICAgb25lIHJlYWxseSAgbmVlZHMgdG8uICAgSW4gbW9zdCBjYXNlcywgIHRoZXJlJ3Mgbm8gbmVlZCAgdG8gY2FsbAogICAgICBGVF9OZXdfU2l6ZSBvciBGVF9OZXdfR2x5cGguCgogICAgLSBzaW1pbGFybHksICBGVF9Mb2FkX0dseXBoICBub3cgIG9ubHkgIHRha2VzICBhICAiZmFjZSIgIGFyZ3VtZW50CiAgICAgIChpbnN0ZWFkICBvZiBhICBnbHlwaCAgc2xvdCAgYW5kIGEgIHNpemUpLiAgQWxzbywgaXQncyAgInJlc3VsdCIKICAgICAgcGFyYW1ldGVyIGlzICBnb25lLCBhcyB0aGUgZ2x5cGggIGltYWdlIHR5cGUgaXMgIHJldHVybmVkIGluIHRoZQogICAgICBmaWVsZCAiZmFjZS0+Z2x5cGguZm9ybWF0IgoKICAgIC0gdGhlIGxpc3QgIG9mIGF2YWlsYWJsZSAgY2hhcm1hcHMgaXMgZGlyZWN0bHkgIGFjY2Vzc2libGUgdGhyb3VnaAogICAgICAiZmFjZS0+Y2hhcm1hcHMiLCAgY291bnRpbmcgImZhY2UtPm51bV9jaGFybWFwcyIgIGVsZW1lbnRzLiBFYWNoCiAgICAgIGNoYXJtYXAgIGhhcyBhbiAgJ2VuY29kaW5nJyAgZmllbGQgd2hpY2ggIHNwZWNpZmllcyB3aGljaCAga25vd24KICAgICAgZW5jb2RpbmcgaXQgZGVhbHMgd2l0aC4gVmFsaWQgdmFsdWVzIGFyZSwgZm9yIGV4YW1wbGUgOgoKICAgICAgICAgIGZ0X2VuY29kaW5nX3VuaWNvZGUgICAgICAoZm9yIEFTQ0lJLCBMYXRpbi0xIGFuZCBVbmljb2RlKQogICAgICAgICAgZnRfZW5jb2RpbmdfYXBwbGVfcm9tYW4KICAgICAgICAgIGZ0X2VuY29kaW5nX3NqaXMKICAgICAgICAgIGZ0X2VuY29kaW5nX2Fkb2JlX3N0YW5kYXJkCiAgICAgICAgICBmdF9lbmNvZGluZ19hZG9iZV9leHBlcnQKCiAgICAgIG90aGVyICB2YWx1ZXMgbWF5ICBiZSBhZGRlZCAgaW4gdGhlICBmdXR1cmUuIEVhY2ggIGNoYXJtYXAgc3RpbGwKICAgICAgaG9sZHMgIGl0cyAicGxhdGZvcm1faWQiICBhbmQgImVuY29kaW5nX2lkIiAgdmFsdWVzIGluICBjYXNlIHRoZQogICAgICBlbmNvZGluZyBpcyB0b28gZXhvdGljIGZvciB0aGUgY3VycmVudCBsaWJyYXJ5CgoKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKRGlyZWN0b3J5IFN0cnVjdHVyZToKCiAgU2hvdWxkIHNlZW0gb2J2aW91cyB0byBtb3N0IG9mIHlvdToKCiAgICAgZnJlZXR5cGUvCiAgICAgICAgIGNvbmZpZy8gICAgICAgIC0tIGNvbmZpZ3VyYXRpb24gc3ViLW1ha2VmaWxlcwogICAgICAgICAgICBhbnNpLwogICAgICAgICAgICB1bml4LyAgICAgICAtLSBwbGF0Zm9ybS1zcGVjaWZpYyBjb25maWd1cmF0aW9uIGZpbGVzCiAgICAgICAgICAgIHdpbjMyLwogICAgICAgICAgICBvczIvCiAgICAgICAgICAgIG1zZG9zLwoKICAgICAgICAgaW5jbHVkZS8gICAgICAgLS0gcHVibGljIGhlYWRlciAgZmlsZXMsIHRob3NlIHRvICBiZSBpbmNsdWRlZAogICAgICAgICAgICAgICAgICAgICAgICAgICBkaXJlY3RseSBieSBjbGllbnQgYXBwcwoKICAgICAgICAgc3JjLyAgICAgICAgICAgLS0gc291cmNlcyBvZiB0aGUgbGlicmFyeQogICAgICAgICAgIGJhc2UvICAgICAgICAtLSB0aGUgYmFzZSBsYXllcgogICAgICAgICAgIHNmbnQvICAgICAgICAtLSB0aGUgc2ZudCAiZHJpdmVyIiAgKHNlZSB0aGUgZHJpdmVycyBzZWN0aW9uCiAgICAgICAgICAgICAgICAgICAgICAgICAgIGJlbG93KQogICAgICAgICAgIHRydWV0eXBlLyAgICAtLSB0aGUgdHJ1ZXR5cGUgZHJpdmVyCiAgICAgICAgICAgdHlwZTEvICAgICAgIC0tIHRoZSB0eXBlMSBkcml2ZXIKICAgICAgICAgICBzaGFyZWQvICAgICAgLS0gc29tZSBoZWFkZXIgZmlsZXMgc2hhcmVkIGJldHdlZW4gZHJpdmVycwoKICAgICAgICAgZGVtb3MvICAgICAgICAgLS0gZGVtb3MvdG9vbHMKCiAgICAgICAgIGRvY3MvICAgICAgICAgIC0tIGRvY3VtZW50YXRpb24gKGEgYml0IGVtcHR5IGZvciBub3cpCgoKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKR2x5cGggSW1hZ2UgRm9ybWF0czoKCiAgRHJpdmVycyBhcmUgbm93IGFibGUgdG8gIHJlZ2lzdGVyIG5ldyBnbHlwaCBpbWFnZSBmb3JtYXRzIHdpdGhpbiB0aGUKICBsaWJyYXJ5LiAgRm9yICBub3csIHRoZSAgYmFzZSBsYXllciBzdXBwb3J0cyAgb2YgY291cnNlICBiaXRtYXBzIGFuZAogIHZlY3RvciAgb3V0bGluZXMsIGJ1dCAgb25lICBjb3VsZCBpbWFnaW5lICBzb21ldGhpbmcgZGlmZmVyZW50ICBsaWtlCiAgY29sb3JlZCBiaXRtYXBzLCBiaS1jb2xvciB2ZWN0b3JzIG9yIHdhdGhldmVyIGVsc2UgKE1ldGFmb250cyBhbnlvbmUKICA/PykuCgogIFNlZSAgdGhlICAgZmlsZSAgYGluY2x1ZGUvZnRpbWFnZS5oJy4gICBOb3RlICBhbHNvICB0aGF0ICAgdGhlICB0eXBlCiAgRlRfUmFzdGVyX01hcCAgaXMgZ29uZSwgIGFuZCAgaXMgbm93ICByZXBsYWNlZCAgYnkgRlRfQml0bWFwLCAgd2hpY2gKICBzaG91bGQgZW5jb21wYXNzIGFsbCBrbm93biBiaXRtYXAgdHlwZXMuCgogIEVhY2ggbmV3ICBpbWFnZSBmb3JtYXQgIG11c3QgcHJvdmlkZSBhdCAgbGVhc3Qgb25lICJyYXN0ZXIiLCAgaS5lLiBhCiAgbW9kdWxlIGNhcGFibGUgb2YgIHRyYW5zZm9ybWluZyB0aGUgZ2x5cGggaW1hZ2UgaW50byAgYSBiaXRtYXAuIEl0J3MKICBhbHNvIHBvc3NpYmxlICB0byBjaGFuZ2UgdGhlIGRlZmF1bHQgIHJhc3RlciB1c2VkIGZvciAgYSBnaXZlbiBnbHlwaAogIGltYWdlIGZvcm1hdC4KCiAgVGhlIGRlZmF1bHQgb3V0bGluZSAgc2Nhbi1jb252ZXJ0ZXIgbm93IHVzZXMgMTI4IGxldmVscyAgb2YgZ3JheXMgYnkKICBkZWZhdWx0LCAgd2hpY2ggdGVuZHMgIHRvIHNtb290aCAgbWFueSAgdGhpbmdzLiBOb3RlICB0aGF0IHRoZSAgZGVtbwogIHByb2dyYW1zIGhhdmUgYmVlbiB1cGRhdGVkIHNpZ25pZmljYW50bHkgaW4gb3JkZXIgdG8gZGlzcGxheSB0aGVzZS4uCgoKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKQnVpbGQgc3lzdGVtOgoKICBZb3Ugc3RpbGwgbmVlZCAgR05VIE1ha2UgdG8gYnVpbGQgdGhlIGxpYnJhcnkuICBUaGUgYnVpbGQgc3lzdGVtIGhhcwogIGJlZW4gdmVyeSBzZXJpb3VzbHkgcmUtdmFtcGVkIGluIG9yZGVyIHRvIHByb3ZpZGUgdGhpbmdzIGxpa2UgOgoKICAgLSBhdXRvbWF0aWMgaG9zdCBwbGF0Zm9ybSAgZGV0ZWN0aW9uIChyZXZlcnRpbmcgdG8gJ2NvbmZpZy9hbnNpJyBpZgogICAgIGl0IGlzIG5vdCBkZXRlY3RlZCwgd2l0aCBwc2V1ZG8tc3RhbmRhcmQgY29tcGlsYXRpb24gZmxhZ3MpCgogICAtIHRoZSBhYmlsaXR5IHRvIGNvbXBpbGUgZnJvbSB0aGUgTWFrZWZpbGVzIHdpdGggdmVyeSBkaWZmZXJlbnQgYW5kCiAgICAgZXhvdGljIGNvbXBpbGVycy4gTm90ZSB0aGF0ICBsaW5raW5nIHRoZSBsaWJyYXJ5IGNhbiBiZSBkaWZmaWN1bHQKICAgICBmb3Igc29tZSBwbGF0Zm9ybXMuCgogICAgIEZvciBleGFtcGxlLCB0aGUgZmlsZSBgY29uZmlnL3dpbjMyL2xjY2xpYi5iYXQnIGlzIGludm9rZWQgYnkgdGhlCiAgICAgYnVpbGQgc3lzdGVtIHRvIGNyZWF0ZSB0aGUgIi5saWIiIGZpbGUgd2l0aCBMQ0MtV2luMzIgYmVjYXVzZSBpdHMKICAgICBsaWJyYXJpYW4gIGhhcyB0b28gIG1hbnkgZmxhd3MgIHRvIGJlICBpbnZva2VkIGRpcmVjdGx5ICBmcm9tIHRoZQogICAgIE1ha2VmaWxlLgoKICBIZXJlJ3MgaG93IGl0IHdvcmtzOgoKICAtIHRoZSBmaXJzdCB0aW1lIHlvdSB0eXBlIGBtYWtlJywgIHRoZSBidWlsZCBzeXN0ZW0gcnVucyBhIHNlcmllcyBvZgogICAgc3ViLW1ha2VmaWxlcyBpbiBvcmRlciB0byBkZXRlY3QgeW91ciBob3N0IHBsYXRmb3JtLiBJdCB0aGVuIGR1bXBzCiAgICB3aGF0ICBpdCBmb3VuZCwgIGFuZCAgY3JlYXRlcyAgYSBmaWxlICBjYWxsZWQgIGBjb25maWcubWsnIGluICB0aGUKICAgIGN1cnJlbnQgIGRpcmVjdG9yeS4gVGhpcyAgaXMgYSAgc3ViLU1ha2VmaWxlIHVzZWQgIHRvICBkZWZpbmUgbWFueQogICAgaW1wb3J0YW50IE1ha2UgdmFyaWFibGVzIHVzZWQgdG8gYnVpbGQgdGhlIGxpYnJhcnkuCgogIC0gdGhlIHNlY29uZCB0aW1lLCB0aGUgYnVpbGQgc3lzdGVtIGRldGVjdHMgdGhlIGBjb25maWcubWsnIHRoZW4gdXNlCiAgICBpdCAgdG8gIGJ1aWxkIHRoZSAgbGlicmFyeS4gIEFsbCBvYmplY3QgIGZpbGVzICBnbyAgaW50byAnb2JqJyAgYnkKICAgIGRlZmF1bHQsICBhcyB3ZWxsICBhcyB0aGUgIGxpYnJhcnkgZmlsZSwgIGJ1dCB0aGlzICBjYW4gIGVhc2lseSBiZQogICAgY2hhbmdlZC4KCiAgTm90ZSB0aGF0ICB5b3UgY2FuIHJ1biAibWFrZSAgc2V0dXAiIHRvIGZvcmNlICBhbm90aGVyIGhvc3QgcGxhdGZvcm0KICBkZXRlY3Rpb24gIGV2ZW4gICBpZiAgYSAgYGNvbmZpZy5taycgIGlzICBwcmVzZW50ICAgaW4gIHRoZSAgY3VycmVudAogIGRpcmVjdG9yeS4gIEFub3RoZXIgc29sdXRpb24gIGlzICBzaW1wbHkgdG8gIGRlbGV0ZSAgdGhlIGZpbGUsICB0aGVuCiAgcmUtcnVuIG1ha2UuCgogIEZpbmFsbHksIHRoZSAgZGVmYXVsdCBjb21waWxlciAgZm9yIGFsbCBwbGF0Zm9ybXMgIGlzIGdjYyAgKGZvciBub3csCiAgdGhpcyB3aWxsIGhvcGVmdWxseSBjaGFuZ2VkIGluICB0aGUgZnV0dXJlKS4gWW91IGNhbiBob3dldmVyIHNwZWNpZnkKICBhIGRpZmZlcmVudCAgY29tcGlsZXIgYnkgc3BlY2lmeWluZyAgaXQgYWZ0ZXIgdGhlICdzZXR1cCcgIHRhcmdldCBhcwogIGluOgoKICAgICAgZ251bWFrZSBzZXR1cCBsY2MgICAgICAgICBvbiBXaW4zMiB0byB1c2UgdGhlIExDQyBjb21waWxlcgogICAgICBnbnVtYWtlIHNldHVwIHZpc3VhbGMgICAgIG9uIFdpbjMyIHRvIHVzZSBWaXN1YWwgQysrCgogIFNlZSAgdGhlIGZpbGUgIGBjb25maWcvPHN5c3RlbT4vZGV0ZWN0Lm1rJyBmb3IgIGEgbGlzdCAgb2Ygc3VwcG9ydGVkCiAgY29tcGlsZXJzIGZvciB5b3VyIHBsYXRmb3Jtcy4KCiAgSXQgc2hvdWxkIGJlIHJlbGF0aXZlbHkgZWFzeSAgdG8gd3JpdGUgbmV3IGRldGVjdGlvbiBydWxlcyBmaWxlcyBhbmQKICBjb25maWcubWsuLgoKICBGaW5hbGx5LCB0byAgYnVpbGQgdGhlIGRlbW8gcHJvZ3JhbXMsICBnbyB0byBgZGVtb3MnICBhbmQgbGF1bmNoIEdOVQogIE1ha2UsIGl0IHdpbGwgdXNlIHRoZSBgY29uZmlnLm1rJyAgaW4gdGhlIHRvcCBkaXJlY3RvcnkgdG8gYnVpbGQgdGhlCiAgdGVzdCBwcm9ncmFtcy4uCgoKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKUG9ydGFiaWxpdHk6CgogIEluICB0aGUgIHByZXZpb3VzICBiZXRhLCAgYSAgc2luZ2xlIEZUX1N5c3RlbSAgb2JqZWN0ICB3YXMgIHVzZWQgIHRvCiAgZW5jb21wYXNzICBhbGwgIGxvdy1sZXZlbCAgb3BlcmF0aW9ucyBsaWtlICB0aHJlYWQgIHN5bmNocm9uaXNhdGlvbiwKICBtZW1vcnkgbWFuYWdlbWVudCBhbmQgaS9vIGFjY2Vzcy4gVGhpcyBoYXMgYmVlbiBncmVhdGx5IHNpbXBsaWZpZWQ6CgogICAgLSB0aHJlYWQgc3luY2hyb25pc2F0aW9uICBoYXMgYmVlbiBkcm9wcGVkLCBmb3IgIHRoZSBzaW1wbGUgcmVhc29uCiAgICAgIHRoYXQgdGhlIGxpYnJhcnkgIGlzIGFscmVhZHkgcmUtZW50cmFudCwgYW5kIHRoYXQgIGlmIHlvdSByZWFsbHkKICAgICAgbmVlZCAgdHdvICB0aHJlYWRzIGFjY2Vzc2luZyAgdGhlICBzYW1lICBGVF9MaWJyYXJ5LCB5b3UgIHNob3VsZAogICAgICByZWFsbHkgc3luY2hyb25pemUgYWNjZXNzIHRvIGl0IHlvdXJzZWxmIHdpdGggYSBzaW1wbGUgbXV0ZXguCgogICAgLSBtZW1vcnkgIG1hbmFnZW1lbnQgaXMgIHBlcmZvcm1lZCAgdGhyb3VnaCBhICB2ZXJ5IHNpbXBsZSAgb2JqZWN0CiAgICAgIGNhbGxlZCAiRlRfTWVtb3J5IiwgIHdoaWNoIHJlYWxseSBpcyBhIHRhYmxlICBjb250YWluaW5nIGEgdGFibGUKICAgICAgb2YgcG9pbnRlcnMgdG8gIGZ1bmN0aW9ucyBsaWtlIG1hbGxvYywgcmVhbGxvYyBhbmQgIGZyZWUgYXMgd2VsbAogICAgICBhcyBzb21lIHVzZXIgZGF0YSAoY2xvc3VyZSkuCgogICAgLSByZXNvdXJjZXMgaGF2ZSBkaXNhcHBlYXJlZCAodGhleSBjcmVhdGVkIG1vcmUgcHJvYmxlbXMgdGhhbiB0aGV5CiAgICAgIHNvbHZlZCksIGFuZCAgaS9vIG1hbmFnZW1lbnQgaGF2ZSAgYmVlbiBzaW1wbGlmaWVkIGdyZWF0bHkgIGFzIGEKICAgICAgcmVzdWx0LiBTdHJlYW1zIGFyZSBkZWZpbmVkIHRocm91Z2ggRlRfU3RyZWFtIG9iamVjdHMsIHdoaWNoIGNhbgogICAgICBiZSBlaXRoZXIgbWVtb3J5LWJhc2VkIG9yIGRpc2stYmFzZWQuCgogICAgICBOb3RlIHRoYXQgIGVhY2ggZmFjZSAgaGFzIGl0cyBvd24gIHN0cmVhbSwgd2hpY2ggaXMgIGNsb3NlZCBvbmx5CiAgICAgIHdoZW4gIHRoZSAgZmFjZSBvYmplY3QgIGlzICBkZXN0cm95ZWQuICBIZW5jZSwgIGEgZnVuY3Rpb24gIGxpa2UKICAgICAgVFRfRmx1c2hfRmFjZSBpbiAgMS54IGNhbm5vdCBiZSBkaXJlY3RseSAgc3VwcG9ydGVkLiBIb3dldmVyLCBpZgogICAgICB5b3UgcmVhbGx5IG5lZWQgc29tZXRoaW5nIGxpa2UgIHRoaXMsIHlvdSBjYW4gZWFzaWx5IHRhaWxvciB5b3VyCiAgICAgIG93biBzdHJlYW1zICB0byBhY2hpZXZlIHRoZSBzYW1lICBmZWF0dXJlIGF0IGEgIGxvd2VyIGxldmVsIChhbmQKICAgICAgdXNlIEZUX09wZW5fRmFjZSBpbnN0ZWFkIG9mIEZUX05ld19GYWNlIHRvIGNyZWF0ZSB0aGUgZmFjZSkuCgogIFNlZSB0aGUgZmlsZSAgImluY2x1ZGUvZnRzeXN0ZW0uaCIgZm9yIG1vcmUgZGV0YWlscywgYXMgIHdlbGwgYXMgdGhlCiAgaW1wbGVtZW50YXRpb25zIGZvdW5kIGluICJjb25maWcvdW5peCIgYW5kICJjb25maWcvYW5zaSIuCgoKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKRm9udCBEcml2ZXJzOgoKICBUaGUgIEZvbnQgRHJpdmVyICBpbnRlcmZhY2UgaGFzICBiZWVuIG1vZGlmaWVkICBpbiBvcmRlciAgdG8gc3VwcG9ydAogIGV4dGVuc2lvbnMgJiB2ZXJzaW9uaW5nLgoKCiAgVGhlICBsaXN0IG9mICB0aGUgZm9udCAgZHJpdmVycyB0aGF0ICBhcmUgc3RhdGljYWxseSAgbGlua2VkICB0byB0aGUKICBsaWJyYXJ5IGF0IGNvbXBpbGUgdGltZSBpcyAgbWFuYWdlZCB0aHJvdWdoIGEgbmV3IGNvbmZpZ3VyYXRpb24gZmlsZQogIGNhbGxlZCBgY29uZmlnLzxwbGF0Zm9ybT4vZnRtb2R1bGUuaCcuCgogIFRoaXMgZmlsZSBpcyBhdXRvZ2VuZXJhdGVkIHdoZW4gaW52b2tpbmcgYG1ha2UgbW9kdWxlcycuIFRoaXMgdGFyZ2V0CiAgd2lsbCBwYXJzZSAgYWxsIHN1Yi1kaXJlY3RvcmllcyBvZiAnc3JjJywgbG9va2luZyAgZm9yIGEgIm1vZHVsZS5tayIKICBydWxlcyBmaWxlLCB1c2VkIHRvIGRlc2NyaWJlIHRoZSBkcml2ZXIgdG8gdGhlIGJ1aWxkIHN5c3RlbS4KCiAgSGVuY2UsIG9uZSAgc2hvdWxkIGNhbGwgIGBtYWtlIG1vZHVsZXMnIGVhY2ggIHRpbWUgYSBmb250ICBkcml2ZXIgaXMKICBhZGRlZCBvciByZW1vdmVkIGZyb20gdGhlIGBzcmMnIGRpcmVjdG9yeS4KCiAgRmluYWxseSwgdGhpcyB2ZXJzaW9uIHByb3ZpZGVzIGEgInBzZXVkby1kcml2ZXIiIGluIGBzcmMvc2ZudCcuIFRoaXMKICBkcml2ZXIgZG9lc24ndCAgc3VwcG9ydCBmb250ICBmaWxlcyBkaXJlY3RseSwgYnV0ICBwcm92aWRlcyBzZXJ2aWNlcwogIHVzZWQgYnkgIGFsbCBUcnVlVHlwZS1saWtlIGZvbnQgIGRyaXZlcnMuIEhlbmNlLCBpdHMgY29kZSAgaXMgc2hhcmVkCiAgYmV0d2VlbiAgdGhlIFRydWVUeXBlICAmIE9wZW5UeXBlICBmb250IGZvcm1hdHMsICBhbmQgIHBvc3NpYmx5IG1vcmUKICBmb3JtYXRzIHRvIGNvbWUgaWYgd2UncmUgbHVja3kuLgoKCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCkV4dGVuc2lvbnMgc3VwcG9ydDoKCiAgVGhlIGV4dGVuc2lvbnMgc3VwcG9ydCBpcyBpbnNwaXJlZCBieSB0aGUgb25lIGZvdW5kIGluIDEueC4KCiAgTm93LCBlYWNoIGZvbnQgZHJpdmVyIGhhcyAgaXRzIG93biAiZXh0ZW5zaW9uIHJlZ2lzdHJ5Iiwgd2hpY2ggbGlzdHMKICB3aGljaCBleHRlbnNpb25zICBhcmUgYXZhaWxhYmxlICBmb3IgdGhlIGZvbnQgIGZhY2VzIG1hbmFnZWQgIGJ5IHRoZQogIGRyaXZlci4KCiAgRXh0ZW5zaW9uIGlkcyBhcmUgIG5vdyBzdHJpbmdzLCByYXRoZXIgdGhhbiA0LWJ5dGUgIHRhZ3MsIGFzIHRoaXMgaXMKICB1c3VhbGx5IG1vcmUgcmVhZGFibGUuLgoKICBFYWNoIGV4dGVuc2lvbiBoYXM6CiAgICAtIHNvbWUgZGF0YSwgYXNzb2NpYXRlZCB0byBlYWNoIGZhY2Ugb2JqZWN0CiAgICAtIGFuIGludGVyZmFjZSAodGFibGUgb2YgZnVuY3Rpb24gcG9pbnRlcnMpCgogIEFuIGV4dGVuc2lvbiAgdGhhdCBpcyBmb3JtYXQtc3BlY2lmaWMgc2hvdWxkICBzaW1wbHkgcmVnaXN0ZXIgaXRzZWxmCiAgdG8gdGhlIGNvcnJlY3QgZm9udCBkcml2ZXIuIEhlcmUgaXMgc29tZSBleGFtcGxlIGNvZGU6CgogICAvLyBSZWdpc3RlcmluZyBhbiBleHRlbnNpb25zCiAgIC8vCiAgIEZUX0Vycm9yICBGVF9Jbml0X1hYWFhfRXh0ZW5zaW9uKCBGVF9MaWJyYXJ5ICBsaWJyYXJ5ICkKICAgewogICAgIEZUX0RyaXZlckludGVyZmFjZSogIHR0X2RyaXZlcjsKCiAgICAgZHJpdmVyID0gRlRfR2V0X0RyaXZlciggbGlicmFyeSwgInRydWV0eXBlIiApOwogICAgIGlmICghZHJpdmVyKSByZXR1cm4gRlRfRXJyX1VuaW1wbGVtZW50ZWRfRmVhdHVyZTsKCiAgICAgcmV0dXJuIEZUX1JlZ2lzdGVyX0V4dGVuc2lvbiggZHJpdmVyLCAmZXh0ZW5zaW9uX2NsYXNzICk7CiAgIH0KCgogICAvLyBJbXBsZW1lbnRpbmcgdGhlIGV4dGVuc2lvbnMKICAgLy8KICAgRlRfRXJyb3IgIEZUX1Byb2NlZWRfRXh0ZW5zaW9uX1hYWCggRlRfRmFjZSAgZmFjZSApCiAgIHsKICAgICBGVF9YWFhfRXh0ZW5zaW9uICAgICAgICAgICAgZXh0OwogICAgIEZUX1hYWF9FeHRlbnNpb25fSW50ZXJmYWNlICBleHRfaW50ZXJmYWNlOwoKICAgICBleHQgPSBGVF9HZXRfRXh0ZW5zaW9uKCBmYWNlLCAiZXh0ZW5zaW9uaWQiLCAmZXh0X2ludGVyZmFjZSApOwogICAgIGlmICghZXh0KSByZXR1cm4gZXJyb3I7CgogICAgIHJldHVybiBleHRfaW50ZXJmYWNlLT5kb19pdChleHQpOwogICB9CgotLS0gZW5kIG9mIENIQU5HRVMgLS0tCg==