CkxBVEVTVCBDSEFOR0VTIEJFVFdFRU4gMi4xLjYgYW5kIDIuMS41CgogIEkuIElNUE9SVEFOVCBCVUcgRklYRVMKCiAgICAtIFRoZSBQRlIgIGZvbnQgZHJpdmVyIGRpZG4ndCAgbG9hZCBrZXJuaW5nIHRhYmxlcyAgY29ycmVjdGx5LCBhbmQKICAgICAgdGhlIGZ1bmN0aW9ucyBpbiBGVF9QRlJfSCBkaWRuJ3Qgd29yayBhdCBhbGwuCgogICAgLSBUeXBlIDEgZm9udCAgZmlsZXMgaW4gIGJpbmFyeSBmb3JtYXQgIChQRkIpIHdpdGggIGFuIGVuZC1vZi1maWxlCiAgICAgIGluZGljYXRvciB3ZXJlbid0IGFjY2VwdGVkIGJ5IHRoZSBGcmVlVHlwZSBlbmdpbmUuCgogICAgLSBGb250cyB3aGljaCBjb250YWluIC9QYWludFR5cGUgIGFuZCAvU3Ryb2tlV2lkdGggbm8gbG9uZ2VyIGNhdXNlCiAgICAgIGEgc2VnZmF1bHQuICBUaGlzIGJ1ZyBoYXMgYmVlbiBpbnRyb2R1Y2VkIGluIHZlcnNpb24gMi4xLjUuCgogICAgLSBGb250cyAgbG9hZGVkICB3aXRoICAgRlRfTE9BRF9SRU5ERVIgIG5vICBsb25nZXIgIGNhdXNlICBzdHJhbmdlCiAgICAgIHJlc3VsdHMuICBUaGlzIGJ1ZyBoYXMgYmVlbiBpbnRyb2R1Y2VkIGluIHZlcnNpb24gMi4xLjUuCgogICAgLSBTb21lICBXaW5kb3dzICAgKGJpdG1hcCkgIEZOVC9GT04gIGZpbGVzICAgY291bGRuJ3QgIGJlICBoYW5kbGVkCiAgICAgIGNvcnJlY3RseS4KCiAgSUkuIElNUE9SVEFOVCBDSEFOR0VTCgogICAgLSBUaGUgaW50ZXJuYWwgIG1vZHVsZSBBUEkgIGhhcyBiZWVuIGhlYXZpbHkgIGNoYW5nZWQgaW4gIGZhdm9yIG9mCiAgICAgIG1hc3NpdmUgc2ltcGxpZmljYXRpb25zIHdpdGhpbiB0aGUgZm9udCBlbmdpbmUuICBUaGlzIGFsc28gbWVhbnMKICAgICAgdGhhdCBhdXRob3JzIG9mIHRoaXJkLXBhcnR5IG1vZHVsZXMgbXVzdCBhZGFwdCB0aGVpciBjb2RlIHRvIHRoZQogICAgICBuZXcgc2NoZW1lLiBOT1RFOiBUSEUgTkVXIFNDSEVNRSBJUyBOT1QgRklOSVNIRUQuIFBMRUFTRSBXQUlUCiAgICAgIFVOVElMIEFUIExFQVNUIEFOT1RIRVIgUkVMRUFTRSAhIQoKICAgIC0gVGhlIFBvc3RTY3JpcHQgIHBhcnNlciBoYXMgYmVlbiBlbmhhbmNlZCB0byAgaGFuZGxlIGNvbW1lbnRzIGFuZAogICAgICBzdHJpbmdzICAgY29ycmVjdGx5LiAgIEFkZGl0aW9uYWxseSwgICBtb3JlICBzeW50YXggICBmb3JtcyAgYXJlCiAgICAgIHJlY29nbml6ZWQuCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpMQVRFU1QgQ0hBTkdFUyBCRVRXRUVOIDIuMS41IGFuZCAyLjEuNAoKCiAgSS4gSU1QT1JUQU5UIEJVRyBGSVhFUwoKICAgIC0gUGFyc2luZyB0aGUgL0NJREZvbnROYW1lIGZpZWxkICBub3cgcmVtb3ZlcyB0aGUgbGVhZGluZyBzbGFzaCB0bwogICAgICBiZSBpbiBzeW5jIHdpdGggb3RoZXIgZm9udCBkcml2ZXJzLgoKICAgIC0gZ3ppcCBzdXBwb3J0IHdhcyBidWdneS4gIFNvbWUgZm9udHMgY291bGQgbm90IGJlIHJlYWQuCgogICAgLSBGb250cyB3aGljaCAgaGF2ZSBuZXN0ZWQgc3ViZ2x5cGhzICBtb3JlIHRoYW4gb25lIGxldmVsICBkZWVwIG5vCiAgICAgIGxvbmdlciBjYXVzZSBhIHNlZ2ZhdWx0LgoKICAgIC0gQ3JlYXRpb24gb2Ygc3ludGhldGljICBjbWFwcyBmb3IgZm9udHMgaW4gQ0ZGICBmb3JtYXQgd2FzIGJyb2tlbgogICAgICBwYXJ0aWFsbHkuCgogICAgLSBOdW1lcmljICBmb250ICBkaWN0aW9uYXJ5IGVudHJpZXMgIGZvciAgc3ludGhldGljICBmb250cyBhcmUgIG5vCiAgICAgIGxvbmdlciBvdmVyd3JpdHRlbi4KCiAgICAtIFRoZSBmb250IG1hdHJpeCAgd2Fzbid0IGFwcGxpZWQgdG8gdGhlIGFkdmFuY2UgIHdpZHRoIGZvciBUeXBlMSwKICAgICAgQ0lELCBhbmQgIENGRiBmb250cy4gIFRoaXMgY2F1c2VkIHByb2JsZW1zICB3aGVuIGxvYWRpbmcgY2VydGFpbgogICAgICBzeW50aGV0aWMgVHlwZSAxIGZvbnRzIGxpa2UgYEhlbHZldGljYSBOYXJyb3cnLgoKICAgIC0gVGhlIHRlc3QgIGZvciB0aGUgY2hhcnNldCByZWdpc3RyeSAgaW4gQkRGIGFuZCBQQ0YgIGZvbnRzIGlzIG5vdwogICAgICBjYXNlLWluc2Vuc2l0aXZlLgoKICAgIC0gRlRfVmVjdG9yX1JvdGF0ZSAgc29tZXRpbWVzICByZXR1cm5lZCAgIHN0cmFuZ2UgIHZhbHVlcyAgZHVlICB0bwogICAgICByb3VuZGluZyBlcnJvcnMuCgogICAgLSBUaGUgIFBDRiAgZHJpdmVyICBub3cgIHJldHVybnMgIHRoZSAgY29ycmVjdCAgbnVtYmVyICBvZiAgZ2x5cGhzCiAgICAgIChpbmNsdWRpbmcgYW4gYXJ0aWZpY2lhbCBgbm90ZGVmJyBnbHlwaCBhdCBpbmRleCAwKS4KCiAgICAtIEZyZWVUeXBlIG5vdyAgc3VwcG9ydHMgYnVnZ3kgQ01hcHMgIHdoaWNoIGFyZSBjb250YWluZWQgIGluIG1hbnkKICAgICAgQ0pLIGZvbnRzIGZyb20gRHluYWxhYi4KCiAgICAtIE9wZW5pbmcgIGFuIGludmFsaWQgIGZvbnQgIG9uIGEgIE1hYyAgY2F1c2VkIGEgIHNlZ2ZhdWx0IGR1ZSAgdG8KICAgICAgZG91YmxlLWZyZWVpbmcgbWVtb3J5LgoKICAgIC0gQkRGICBmb250cyAgd2l0aCAgbW9yZSAgIHRoYW4gIDMyNzY4ICBnbHlwaHMgIHdlcmVuJ3QgIHN1cHBvcnRlZAogICAgICBwcm9wZXJseS4KCgogIElJLiBJTVBPUlRBTlQgQ0hBTkdFUwoKICAgIC0gQWNjZXNzaW5nIGJpdG1hcCBmb250IGZvcm1hdHMgaGFzIGJlZW4gc3luY2hyb25pemVkLiAgVG8gZG8gdGhhdAogICAgICB0aGUgRlRfQml0bWFwX1NpemUgIHN0cnVjdHVyZSBoYXMgIGJlZW4gZXh0ZW5kZWQgdG8gIGNvbnRhaW4gbmV3CiAgICAgIGZpZWxkcyBgc2l6ZScsIGB4X3BwZW0nLCBhbmQgYHlfcHBlbScuCgogICAgLSBUaGUgRk5UIGRyaXZlciBub3cgcmV0dXJucyBtdWx0aXBsZSBmYWNlcywgbm90IG11bHRpcGxlIHN0cmlrZXMuCgogICAgLSBUaGUgYHBzbmFtZXMnICBtb2R1bGUgaGFzIGJlZW4gIHVwZGF0ZWQgdG8gdGhlIEFkb2JlICBHbHlwaCBMaXN0CiAgICAgIHZlcnNpb24gMi4wLgoKICAgIC0gVGhlIGBwc25hbWVzJyBtb2R1bGUgbm93IHVuZGVyc3RhbmRzIGB1WFhYWFtYW1hdXScgZ2x5cGggbmFtZXMuCgogICAgLSBUaGUgYWxnb3JpdGhtIGZvciBndWVzc2luZyB0aGUgZm9udCBzdHlsZSBoYXMgYmVlbiBpbXByb3ZlZC4KCiAgICAtIEZvciBmb250cyBpbiBzZm50IGZvcm1hdCwgcm9vdC0+aGVpZ2h0IGlzIG5vIGxvbmdlciBpbmNyZWFzZWQgaWYKICAgICAgdGhlIGxpbmUgZ2FwICBpcyB6ZXJvLiAgVGhlcmUgZXhpc3QgZm9udHMgIChjb250YWluaW5nIGUuZy4gZm9ybQogICAgICBkcmF3aW5nICBjaGFyYWN0ZXJzKSB3aGljaCAgaW50ZW50aW9uYWxseSBoYXZlICBhIHplcm8gIGxpbmUgZ2FwCiAgICAgIHZhbHVlLgoKICAgIC0gZnRfZ2x5cGhfYmJveF94eHggIGZsYWdzICAgYXJlICBub3cgIGRlcHJlY2F0ZWQgICBpbiAgZmF2b3VyICBvZgogICAgICBGVF9HTFlQSF9CQk9YX1hYWC4KCiAgICAtIGZ0X21vZHVsZV94eHggICBmbGFncyAgIGFyZSAgIG5vdyAgIGRlcHJlY2F0ZWQgIGluICAgZmF2b3VyICAgb2YKICAgICAgRlRfTU9EVUxFX1hYWC4KCiAgICAtIEZUX0VOQ09ESU5HX01TX3tTSklTLEdCMjMxMixCSUc1LFdBTlNVTkcsSk9IQUJ9ICAgICAgYXJlICAgICBub3cKICAgICAgZGVwcmVjYXRlZCAgICAgICAgICAgICAgIGluICAgICAgICAgICAgICAgZmF2b3VyICAgICAgICAgICAgICBvZgogICAgICBGVF9FTkNPRElOR197U0pJUyxHQjIzMTIsR0lCNSxXQU5TT05HLEpPSEFCfSAgLS0gdGhvc2UgZW5jb2RpbmdzCiAgICAgIGFyZSBub3Qgc3BlY2lmaWMgdG8gTWljcm9zb2Z0LgoKCiAgSUlJLiBNSVNDRUxMQU5FT1VTCgogICAgLSBUaGUgIGF1dG9oaW50ZXIgIGhhcyBiZWVuICBmdXJ0aGVyICBpbXByb3ZlZDsgIGZvciBleGFtcGxlLCAgYG0nCiAgICAgIGdseXBocyBub3cgcmV0YWluIGl0cyB2ZXJ0aWNhbCBzeW1tZXRyeS4KCiAgICAtIFBhcnRpYWwgc3VwcG9ydCBvZiBNYWMgZm9udHMgb24gbm9uLU1hYyBwbGF0Zm9ybXMuCgogICAgLSBgbWFrZSAgIHJlZmRvYycgICAoYWZ0ZXIgICBmaXJzdCAgIGBtYWtlJykgICBidWlsZHMgICB0aGUgICBIVE1MCiAgICAgIGRvY3VtZW50YXRpb24uICBZb3UgbmVlZCBQeXRob24gZm9yIHRoaXMuCgogICAgLSBUaGUgbWFrZSBidWlsZCBzeXN0ZW0gc2hvdWxkICBub3cgd29yayBtb3JlIHJlbGlhYmx5IG9uIERPUy1saWtlCiAgICAgIHBsYXRmb3Jtcy4KCiAgICAtIFN1cHBvcnQgZm9yICBFTVggZ2NjICBhbmQgV2F0c29uIEMvQysrICBjb21waWxlcnMgb24gIE1TLURPUyBoYXMKICAgICAgYmVlbiBhZGRlZC4KCiAgICAtIEJldHRlciBWTVMgYnVpbGQgc3VwcG9ydC4KCiAgICAtIFN1cHBvcnQgZm9yIHRoZSBwa2ctY29uZmlnICBwYWNrYWdlIGJ5IHByb3ZpZGluZyBhIGBmcmVldHlwZS5wYycKICAgICAgZmlsZS4KCiAgICAtIE5ldyBjb25maWd1cmUgb3B0aW9uIC0td2l0aC1vbGQtbWFjLWZvbnRzIGZvciBEYXJ3aW4uCgogICAgLSBTb21lIHNvdXJjZSBmaWxlcyBoYXZlIGJlZW4gIHJlbmFtZWQgKG1haW5seSB0byBmaXQgaW50byB0aGUgOC4zCiAgICAgIG5hbWluZyBzY2hlbWUpLgoKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCkxBVEVTVCBDSEFOR0VTIEJFVFdFRU4gMi4xLjQgYW5kIDIuMS4zCgogIEkuIElNUE9SVEFOVCBCVUcgRklYRVMKCiAgICAtIFVwZGF0ZWQgIHRvIG5ld2VzdCAgbGlidG9vbCAgdmVyc2lvbiwgZml4aW5nICBidWlsZCBwcm9ibGVtcyAgb24KICAgICAgdmFyaW91cyBwbGF0Zm9ybXMuCgogICAgLSBBIGZpeCAgaW4gdGhlIEd6aXAgc3RyZWFtICByZWFkZXI6IEl0IGNvdWxkbid0ICByZWFkIGNlcnRhaW4gLmd6CiAgICAgIGZpbGVzIHByb3Blcmx5IGR1ZSB0byBhICBzbWFsbCB0eXBvLiAgSW4gY2VydGFpbiBjYXNlcywgRnJlZVR5cGUKICAgICAgY291bGQgIGFsc28gbG9vcCAgZW5kbGVzc2x5ICB3aGVuIHRyeWluZyAgdG8gIGxvYWQgdGlueSAgZ3ppcHBlZAogICAgICBmaWxlcy4KCiAgICAtIFRoZSBjb25maWd1cmUgc2NyaXB0IG5vdyB0cmllcyAgdG8gdXNlIHRoZSBzeXN0ZW0td2lkZSB6bGliIHdoZW4KICAgICAgaXQgIGZpbmRzIG9uZSAgKGluc3RlYWQgb2YgIHRoZSAgY29weSBmb3VuZCAgaW4gc3JjL2d6aXApLiAgIEFuZAogICAgICAiZnJlZXR5cGUtY29uZmlnIiBoYXMgIGJlZW4gdXBkYXRlZCB0byByZXR1cm4gIHJlbGV2YW50IGZsYWdzIGluCiAgICAgIHRoaXMgY2FzZSB3aGVuIGludm9rZWQgd2l0aCAiLS1saWJzIiAoZS5nLiAiLWx6bGliIikuCgogICAgLSBDZXJ0YWluIGZvbnRzIGNvdWxkbid0IGJlIGxvYWRlZCAgYnkgMi4xLjMgYmVjYXVzZSB0aGV5IGxhY2tlZCBhCiAgICAgIFVuaWNvZGUgICBjaGFybWFwICAoZS5nLiAgIFNZTUJPTC5UVEYpLiAgICBGcmVlVHlwZSAgZXJyb25lb3VzbHkKICAgICAgcmVqZWN0ZWQgdGhlbS4KCiAgICAtIFRoZSBDRkYgbG9hZGVyIHdhcyBtb2RpZmllZCB0byBhY2NlcHQgZm9udHMgd2hpY2ggb25seSBjb250YWluIGEKICAgICAgc3Vic2V0IG9mICB0aGVpciByZWZlcmVuY2UgY2hhcnNldC4gIFRoaXMgIHByZXZlbnRlZCB0aGUgY29ycmVjdAogICAgICB1c2Ugb2YgUERGLWVtYmVkZGVkIGZvbnRzLgoKICAgIC0gVGhlIGxvZ2ljIHRvIGRldGVjdCBVbmljb2RlIGNoYXJtYXBzIGhhcyBiZWVuIG1vZGlmaWVkLiAgVGhpcyBpcwogICAgICByZXF1aXJlZCB0byAgc3VwcG9ydCBmb250cyB3aGljaCBpbmNsdWRlIGJvdGggIDE2LWJpdCBhbmQgMzItYml0CiAgICAgIGNoYXJtYXBzIChsaWtlIHZlcnkgIHJlY2VudCBhc2lhbiBvbmVzKSB1c2luZyB0aGUgIG5ldyAxMCBhbmQgMTIKICAgICAgU0ZOVCBmb3JtYXRzLgoKICAgIC0gVGhlIFRydWVUeXBlICBsb2FkZXIgbm93IGxpbWl0cyAgdGhlIGRlcHRoIG9mICBjb21wb3NpdGUgZ2x5cGhzLgogICAgICBUaGlzIGlzIG5lY2Vzc2FyeSB0byBwcmV2ZW50IGJyb2tlbiBmb250cyB0byBicmVhayB0aGUgZW5naW5lIGJ5CiAgICAgIGJsb3dpbmcgdGhlIHN0YWNrIHdpdGggcmVjdXJzaXZlIGdseXBoIGRlZmluaXRpb25zLgoKICAgIC0gVGhlIENNYXAgY2FjaGUgaXMgbm93ICBjYXBhYmxlIG9mIG1hbmFnaW5nIFVDUy00IGNoYXJhY3RlciBjb2RlcwogICAgICB0aGF0ICAgYXJlICAgbWFwcGVkICAgdGhyb3VnaCAgIGV4dGVuZGVkICBjaGFybWFwcyAgIGluICAgcmVjZW50CiAgICAgIFRydWVUeXBlL09wZW5UeXBlIGZvbnRzLgoKICAgIC0gVGhlICAgY2FjaGUgIHN1Yi1zeXN0ZW0gICBub3cgIHByb3Blcmx5ICAgbWFuYWdlcyAgb3V0LW9mLW1lbW9yeQogICAgICBjb25kaXRpb25zICBpbnN0ZWFkIG9mICBibGluZGx5ICByZXBvcnRpbmcgdGhlbSAgdG8gdGhlICBjYWxsZXIuCiAgICAgIFRoaXMgbWVhbnMgdGhhdCBpdCB3aWxsIHRyeSB0byBlbXB0eSB0aGUgY2FjaGUgYmVmb3JlIHJlc3RhcnRpbmcKICAgICAgaXRzIGFsbG9jYXRpb25zIHRvIHNlZSBpZiB0aGF0IGNhbiBoZWxwLgoKICAgIC0gVGhlICBQRlIgZHJpdmVyICBkaWRuJ3QgcmV0dXJuICB0aGUgbGlzdCAgb2YgIGF2YWlsYWJsZSBlbWJlZGRlZAogICAgICBiaXRtYXBzIHByb3Blcmx5LgoKICAgIC0gVGhlcmUgd2FzICBhIG5hc3R5ICBtZW1vcnkgbGVhayB3aGVuICB1c2luZyBlbWJlZGRlZCAgYml0bWFwcyBpbgogICAgICBjZXJ0YWluIGZvbnQgZm9ybWF0cy4KCgogIElJLiBJTVBPUlRBTlQgQ0hBTkdFUwoKICAgIC0gRGF2aWQgQ2hlc3RlciAgY29udHJpYnV0ZWQgc29tZSBlbmhhbmNlbWVudHMgIHRvIHRoZSBhdXRvLWhpbnRlcgogICAgICB0aGF0ICBzaWduaWZpY2FudGx5IGluY3JlYXNlICB0aGUgIHF1YWxpdHkgb2YgIGl0cyBvdXRwdXQuICAgVGhlCiAgICAgIFBvc3RzY3JpcHQgaGludGVyIHdhcyBhbHNvIGltcHJvdmVkIGluIHNldmVyYWwgd2F5cy4KCiAgICAtIFRoZSBGVF9SRU5ERVJfTU9ERV9MSUdIVCByZW5kZXIgbW9kZSB3YXMgaW1wbGVtZW50ZWQuCgogICAgLSBBIG5ldyAgQVBJIGZ1bmN0aW9uIGNhbGxlZCBgRlRfR2V0X0JERl9Qcm9wZXJ0eScgIGhhcyBiZWVuIGFkZGVkCiAgICAgIHRvIEZUX0JERl9IIHRvICByZXRyaWV2ZSBCREYgcHJvcGVydGllcyBmcm9tIEJERiAgX2FuZF8gUENGIGZvbnQKICAgICAgZmlsZXMuICAgVEhJUyAgSVMgIFNUSUxMICBFWFBFUklNRU5UQUwsICBzaW5jZSAgaXQgIGhhc24ndCAgYmVlbgogICAgICBwcm9wZXJseSB0ZXN0ZWQgeWV0LgoKICAgIC0gQSBXaW5kb3dzIEZOVCBzcGVjaWZpYyBBUEkgaGFzIGJlZW4gYWRkZWQsIG1vc3RseSB0byBhY2Nlc3MgZm9udAogICAgICBoZWFkZXJzLiAgVGhpcyBpcyB1c2VkIGJ5IFdpbmUuCgogICAgLSBUcnVlVHlwZSB0YWJsZXMgIHdpdGhvdXQgYW4gImhtdHgiIHRhYmxlIGFyZSAgbm93IHRvbGVyYXRlZCB3aGVuCiAgICAgIGFuICBpbmNyZW1lbnRhbCBpbnRlcmZhY2UgIGlzICB1c2VkLiAgVGhpcyAgaGFwcGVucyBmb3IgIGNlcnRhaW4KICAgICAgVHlwZTQyIGZvbnRzIHBhc3NlZCBmcm9tIEdob3N0c2NyaXB0IHRvIEZyZWVUeXBlLgoKICAgIC0gVGhlIFBGUiBmb250IGRyaXZlciBpcyAgbm93IGNhcGFibGUgb2YgcmV0dXJuaW5nIHRoZSBmb250IGZhbWlseQogICAgICBhbmQgc3R5bGUgIG5hbWVzIHdoZW4gIHRoZXkgYXJlIGF2YWlsYWJsZSAgKGluc3RlYWQgb2YgIHRoZSBzb2xlCiAgICAgICJGb250SUQiKS4gICBUaGlzICBpcyAgcGVyZm9ybWVkICBieSBwYXJzaW5nICBhbiAgKnVuZG9jdW1lbnRlZCoKICAgICAgcG9ydGlvbiBvZiB0aGUgZm9udCBmaWxlIQoKCiAgSUlJLiBNSVNDRUxMQU5FT1VTCgogICAgLSBUaGUgcGF0aCBzdHJva2VyIGluIEZUX1NUUk9LRVJfSCBoYXMgZW50ZXJlZCBiZXRhIHN0YWdlLiAgSXQgbm93CiAgICAgIHdvcmtzIHZlcnkgIHdlbGwsIGJ1dCAgaXRzIGludGVyZmFjZSBtaWdodCAgY2hhbmdlIGEgYml0ICBpbiB0aGUKICAgICAgZnV0dXJlLiAgTW9yZSBvbiB0aGlzIGluIGxhdGVyIHJlbGVhc2VzLgoKICAgIC0gVGhlIGRvY3VtZW50YXRpb24gZm9yICBGVF9TaXplX01ldHJpY3MgZGlkbid0IGFwcGVhciBwcm9wZXJseSBpbgogICAgICB0aGUgQVBJIHJlZmVyZW5jZS4KCiAgICAtIFRoZSBmaWxlIGRvY3MvVkVSU0lPTi5ETEwgaGFzIGJlZW4gdXBkYXRlZCB0byBleHBsYWluIHZlcnNpb25pbmcKICAgICAgd2l0aCBGcmVlVHlwZSAgKGkuZS4sIGNvbXBhcmluZyByZWxlYXNlL2xpYnRvb2wvc28gIG51bWJlcnMsIGFuZAogICAgICBob3cgdG8gdXNlIHRoZW0gaW4gYXV0b2NvbmYgc2NyaXB0cykuCgogICAgLSBUaGUgIGluc3RhbGxhdGlvbiAgZG9jdW1lbnRhdGlvbiAgaGFzIGJlZW4gIHNlcmlvdXNseSAgcmV2YW1wZWQuCiAgICAgIEV2ZXJ5dGhpbmcgaXMgbm93IGluIHRoZSAiZG9jcyIgZGlyZWN0b3J5LgoKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCkxBVEVTVCBDSEFOR0VTIEJFVFdFRU4gMi4xLjMgYW5kIDIuMS4yCgogIEkuIElNUE9SVEFOVCBCVUcgRklYRVMKCiAgICAtIEZUX1ZlY3Rvcl9UcmFuc2Zvcm0gIGhhZCAgYmVlbiAgaW5jb3JyZWN0bHkgbW9kaWZpZWQgIGluICAyLjEuMiwKICAgICAgcmVzdWx0aW5nICBpbiAgaW5jb3JyZWN0ICAgdHJhbnNmb3JtYXRpb25zICBiZWluZyAgYXBwbGllZCAgKGZvcgogICAgICBleGFtcGxlLCByb3RhdGlvbnMgd2VyZSBwcm9jZXNzZWQgaW4gb3Bwb3NpdGUgYW5nbGVzKS4KCiAgICAtIFRoZSBmb3JtYXQgIDggYW5kIDEyIFRydWVUeXBlIGNoYXJtYXAgIGVudW1lcmF0aW9uIHJvdXRpbmVzIGhhdmUKICAgICAgYmVlbiBmaXhlZCAoRlRfR2V0X05leHRfQ2hhciByZXR1cm5lZCBpbnZhbGlkIHZhbHVlcykuCgogICAgLSBUaGUgIFBGUiBmb250IGRyaXZlciAgcmV0dXJuZWQgaW5jb3JyZWN0ICBhZHZhbmNlIHdpZHRocyAgaWYgdGhlCiAgICAgIG91dGxpbmUgIGFuZCBtZXRyaWNzIHJlc29sdXRpb24gIGRlZmluZWQgaW4gIHRoZSBmb250ICBmaWxlIHdlcmUKICAgICAgZGlmZmVyZW50LgoKICAgIC0gRlRfR2x5cGhfVG9fQml0bWFwIG5vdyByZXR1cm5zICBzdWNjZXNzZnVsbHkgd2hlbiBjYWxsZWQgd2l0aCBhbgogICAgICBGVF9CaXRtYXBHbHlwaCBhcmd1bWVudCAoaXQgcHJldmlvdXNseSByZXR1cm5lZCBhbiBlcnJvcikuCgogICAgLSBBIGJ1ZyAgaW4gdGhlIFR5cGUgMSAgbG9hZGVyIHRoYXQgcHJldmVudGVkICB2YWxpZCBmb250IGJvdW5kaW5nCiAgICAgIGJveGVzIHRvIGJlIGxvYWRlZCBmcm9tIG11bHRpcGxlIG1hc3RlciBmb250cy4KCiAgICAtIFRoZSBTRk5UICB2YWxpZGF0aW9uIGNvZGUgaGFzIGJlZW4gcmV3cml0dGVuLiAgIEZyZWVUeXBlIGNhbiBub3cKICAgICAgbG9hZCAiYnJva2VuIiAgZm9udHMgdGhhdCB3ZXJlICB1c2FibGUgb24gV2luZG93cywgYnV0ICBub3Qgd2l0aAogICAgICBwcmV2aW91cyB2ZXJzaW9ucyBvZiB0aGUgbGlicmFyeS4KCiAgICAtIFRoZSBjb21wdXRhdGlvbiBvZiBiZWFyaW5ncyBpbiB0aGUgQkRGIGRyaXZlciBoYXMgYmVlbiBmaXhlZC4KCiAgICAtIFRoZSBQb3N0c2NyaXB0IGhpbnRlciBjcmFzaGVkIHdoZW4gdHJ5aW5nIHRvIGhpbnQgY2VydGFpbiBnbHlwaHMKICAgICAgKG1vcmUgcHJlY2lzZWx5LCAgd2hlbiB0cnlpbmcgdG8gIGFwcGx5IGhpbnRzIHRvIGFuICBlbXB0eSBnbHlwaAogICAgICBvdXRsaW5lKS4KCiAgICAtIFRoZSAgVHJ1ZVR5cGUgZ2x5cGggIGxvYWRlciAgbm93IHN1cHBvcnRzICBjb21wb3NpdGVzIGluICAiQXBwbGUKICAgICAgZm9ybWF0IiAgKHRoZXkgZGlmZmVyIHNsaWdodGx5ICBmcm9tIE1pY3Jvc29mdC9PcGVuVHlwZSAgb25lcyBpbgogICAgICB0aGUgd2F5IHRyYW5zZm9ybWF0aW9uIG9mZnNldHMgYXJlIGNvbXB1dGVkKS4KCiAgICAtIEZyZWVUeXBlIHdhcyAgdmVyeSBzbG93IGF0IG9wZW5pbmcgY2VydGFpbiAgYXNpYW4gQ0lEL0NGRiBmb250cywKICAgICAgZHVlIHRvICBmaXhlZCBpbmNyZW1lbnQgIGluIGR5bmFtaWMgYXJyYXkgIHJlLWFsbG9jYXRpb25zLiAgVGhpcwogICAgICBoYXMgIGJlZW4gY2hhbmdlZCAgdG8gIGV4cG9uZW50aWFsIGJlaGF2aW91ciAgdG8gZ2V0ICBhY2NlcHRhYmxlCiAgICAgIHBlcmZvcm1hbmNlLgoKCgogIElJLiBJTVBPUlRBTlQgQ0hBTkdFUwoKICAgIC0gVGhlIFBDRiBkcml2ZXIgbm93IHN1cHBvcnRzIGd6aXAtY29tcHJlc3NlZCBmb250IGZpbGVzIG5hdGl2ZWx5LgogICAgICBUaGlzIG1lYW5zIHRoYXQgIHlvdSB3aWxsIGJlIGFibGUgdG8gdXNlICBhbGwgdGhlc2UgYml0bWFwIGZvbnRzCiAgICAgIHRoYXQgIGNvbWUgd2l0aCAgWEZyZWU4NiB3aXRoICBGcmVlVHlwZSAoYW5kICBsaWJYZnQvbGliWGZ0MiwgYnkKICAgICAgZXh0ZW5zaW9uKS4KCiAgICAtIFRoZSAgYXV0b21hdGljIGFuZCAgcG9zdHNjcmlwdCBoaW50ZXJzICBoYXZlIGJvdGggIGJlZW4gdXBkYXRlZC4KICAgICAgVGhpcyAgcmVzdWx0cyBpbiAgYSByZWxhdGl2ZWx5ICBpbXBvcnRhbnQgaW5jcmVhc2UgIG9mIHJlbmRlcmluZwogICAgICBxdWFsaXR5IHNpbmNlICBtYW55IG5hc3R5IGRlZmF1bHRzIGhhdmUgIGJlZW4gc3VwcmVzc2VkLiAgUGxlYXNlCiAgICAgIHZpc2l0IHRoZSB3ZWIgcGFnZToKCiAgICAgICAgaHR0cDovL3d3dy5mcmVldHlwZS5vcmcvaGludGluZy9zbW9vdGgtaGludGluZy5odG1sCgogICAgICBmb3IgYWRkaXRpb25hbCBkZXRhaWxzIG9uIHRoaXMgdG9waWMuCgogICAgLSBUaGUgImxvYWRfZmxhZ3MiICBwYXJhbWV0ZXIgb2YgRlRfTG9hZF9HbHlwaCBpcyAgbm93IGFuIEZUX0ludDMyCiAgICAgIChpbnN0ZWFkICBvZiBqdXN0ICBiZWluZyAgYW4gRlRfSW50KS4gICBUaGlzICBicmVha3Mgc291cmNlICBhbmQKICAgICAgYmluYXJ5ICBjb21wYXRpYmlsaXR5IGZvciAgMTZiaXQgc3lzdGVtcyAgb25seSwgIHdoaWxlIHJldGFpbmluZwogICAgICBib3RoIG9mIHRoZW0gZm9yIDMyIGFuZCA2NCBiaXQgb25lcy4KCiAgICAgIFNvbWUgbmV3IGZsYWdzIGhhdmUgYmVlbiBhZGRlZCBjb25zZXF1ZW50bHk6CgogICAgICAgIEZUX0xPQURfTk9fQVVUT0hJTlQgICA6OiBEaXNhYmxlIHRoZSB1c2Ugb2YgdGhlIGF1dG8taGludGVyCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIChidXQgbm90IG5hdGl2ZSBmb3JtYXQgaGludGVycykuCgogICAgICAgIEZUX0xPQURfVEFSR0VUX05PUk1BTCA6OiBIaW50IGFuZCByZW5kZXIgZm9yIG5vcm1hbAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbnRpLWFsaWFzZWQgZGlzcGxheXMuCgogICAgICAgIEZUX0xPQURfVEFSR0VUX01PTk8gICA6OiBIaW50IGFuZCByZW5kZXIgZm9yIDEtYml0IGRpc3BsYXlzLgoKICAgICAgICBGVF9MT0FEX1RBUkdFVF9MQ0QgICAgOjogSGludCBhbmQgcmVuZGVyIGZvciBob3Jpem9udGFsIFJHQiBvcgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBCR1Igc3ViLXBpeGVsIGRpc3BsYXlzIChsaWtlIExDRAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzY3JlZW5zKS4gIFRISVMgSVMgU1RJTEwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgRVhQRVJJTUVOVEFMIQoKICAgICAgICBGVF9MT0FEX1RBUkdFVF9MQ0RfViAgOjogU2FtZSBhcyBGVF9MT0FEX1RBUkdFVF9MQ0QsIGZvcgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2ZXJ0aWNhbCBzdWItcGl4ZWwgZGlzcGxheXMgKGxpa2UKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcm90YXRlZCBMQ0Qgc2NyZWVucykuICBUSElTIElTIFNUSUxMCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEVYUEVSSU1FTlRBTCEKCiAgICAgIEZUX0xPQURfTU9OT0NIUk9NRSAgIGlzICBzdGlsbCAgIHN1cHBvcnRlZCwgIGJ1dCAgIG9ubHkgIGFmZmVjdHMKICAgICAgcmVuZGVyaW5nLCBub3QgdGhlIGhpbnRpbmcuCgogICAgICBOb3RlIHRoYXQgdGhlIGBmdHZpZXcnICBkZW1vIHByb2dyYW0gYXZhaWxhYmxlIGluIHRoZSBgZnQyZGVtb3MnCiAgICAgIHBhY2thZ2UgIGhhcyBiZWVuICB1cGRhdGVkIHRvICBzdXBwb3J0IExDRC1vcHRpbWl6ZWQgIGRpc3BsYXkgb24KICAgICAgbm9uLXBhbGV0dGVkIGRpc3BsYXlzICh1bmRlciBXaW4zMiBhbmQgWDExKS4KCiAgICAtIFRoZSAgUEZSICBkcml2ZXIgIG5vdyAgc3VwcG9ydHMgZW1iZWRkZWQgIGJpdG1hcHMgIChhbGwgIGZvcm1hdHMKICAgICAgc3VwcG9ydGVkKSwgYW5kIHJldHVybnMgY29ycmVjdCBrZXJuaW5nIG1ldHJpY3MgZm9yIGFsbCBnbHlwaHMuCgogICAgLSBUaGUgVHJ1ZVR5cGUgY2hhcm1hcCBsb2FkZXIgIG5vdyBzdXBwb3J0cyBjZXJ0YWluIGBicm9rZW4nIGZvbnRzCiAgICAgIHRoYXQgbG9hZCB1bmRlciBXaW5kb3dzIHdpdGhvdXQgcHJvYmxlbXMuCgogICAgLSBUaGUgY2FjaGUgQVBJIGhhcyBiZWVuIHNsaWdodGx5IG1vZGlmaWVkIChpdCdzIHN0aWxsIGEgYmV0YSEpOgoKICAgICAgIC0gVGhlIHR5cGUgIEZUQ19JbWFnZURlc2MgaGFzIGJlZW4gcmVtb3ZlZDsgaXQgIGlzIG5vdyByZXBsYWNlZAogICAgICAgICBieSAgRlRDX0ltYWdlVHlwZVJlYy4gICBOb3RlIHRoYXQgIG9uZSAgb2YgIGl0cyAgZmllbGRzIGlzICBhCiAgICAgICAgIGBsb2FkX2ZsYWcnIHBhcmFtZXRlciBmb3IgRlRfTG9hZF9HbHlwaC4KCiAgICAgICAtIFRoZSAgZmllbGQgICJudW1fZ3JheXMiIG9mICBGVF9TQml0UmVjICBoYXMgIGJlZW4gY2hhbmdlZCAgdG8KICAgICAgICAgIm1heF9ncmF5cyIgIGluICBvcmRlciB0byAgZml0ICB3aXRoaW4gIGEgIHNpbmdsZSBieXRlLiAgIEl0cwogICAgICAgICBtYXhpbXVtIHZhbHVlIGlzIHRodXMgMjU1IChpbnN0ZWFkIG9mIDI1NiBhcyBwcmV2aW91c2x5KS4KCgogIElJSS4gTUlTQ0VMTEFORU9VUwoKICAgIC0gQWRkZWQgc3VwcG9ydCAgZm9yIHRoZSAgREVTVERJUiB2YXJpYWJsZSBkdXJpbmcgICJtYWtlIGluc3RhbGwiLgogICAgICBUaGlzIHNpbXBsaWZpZXMgcGFja2FnaW5nIG9mIEZyZWVUeXBlLgoKICAgIC0gSW5jbHVkZWQgbW9kaWZpZWQgIGNvcGllcyBvZiB0aGUgIFpMaWIgc291cmNlcyBpbiAgYHNyYy9nemlwJyBpbgogICAgICBvcmRlciB0byBzdXBwb3J0ICBnemlwLWNvbXByZXNzZWQgUENGIGZvbnRzLiAgV2UgZG8gIG5vdCB1c2UgdGhlCiAgICAgIHN5c3RlbS1wcm92aWRlZCAgemxpYiAgZm9yICBub3csICAgdGhvdWdoICB0aGlzICBpcyAgYSAgcHJvYmFibGUKICAgICAgZW5oYW5jZW1lbnQgZm9yIGZ1dHVyZSByZWxlYXNlcy4KCiAgICAtIFRoZSBEb2NNYWtlciB0b29sIHVzZWQgdG8gZ2VuZXJhdGUgdGhlIG9uLWxpbmUgQVBJIHJlZmVyZW5jZSBoYXMKICAgICAgYmVlbiAgIGNvbXBsZXRlbHkgICAgcmV3cml0dGVuLiAgICBJdCAgIGlzICAgIG5vdyAgIGxvY2F0ZWQgICBpbgogICAgICAic3JjL3Rvb2xzL2RvY21ha2VyL2RvY21ha2VyLnB5Ii4gIEZlYXR1cmVzOgoKICAgICAgICAtIGJldHRlciBjcm9zcy1yZWZlcmVuY2VkIG91dHB1dAogICAgICAgIC0gbW9yZSBwb2xpc2hlZCBvdXRwdXQKICAgICAgICAtIHVzZXMgUHl0aG9uIHJlZ3VsYXIgZXhwcmVzc2lvbnMgICh0aG91Z2ggaXQgZGlkbid0IHNwZWVkIHRoZQogICAgICAgICAgcHJvZ3JhbSkKICAgICAgICAtIG11Y2ggIG1vcmUgIG1vZHVsYXIgc3RydWN0dXJlLCAgd2hpY2ggIGFsbG93cyBmb3IgIGRpZmZlcmVudAogICAgICAgICAgImJhY2tlbmRzIiAgaW4gIG9yZGVyIHRvICBnZW5lcmF0ZSAgSFRNTCwgIFhNTCwgb3IgIHdoYXRldmVyCiAgICAgICAgICBmb3JtYXQuCgogICAgICBPbmUgY2FuIHJlZ2VuZXJhdGUgdGhlIEFQSSByZWZlcmVuY2UgYnkgY2FsbGluZzoKCiAgICAgICAgIHB5dGhvbiBzcmMvdG9vbHMvZG9jbWFrZXIvZG9jbWFrZXIucHkgXAogICAgICAgICAgICAgICAgLS1wcmVmaXg9ZnQyIFwKICAgICAgICAgICAgICAgIC0tdGl0bGU9RnJlZVR5cGUtMi4xLjMgXAogICAgICAgICAgICAgICAgLS1vdXRwdXQ9PG91dHB1dGRpcmVjdG9yeT4KICAgICAgICAgICAgICAgIGluY2x1ZGUvZnJlZXR5cGUvKi5oIFwKICAgICAgICAgICAgICAgIGluY2x1ZGUvZnJlZXR5cGUvY29uZmlnLyouaCBcCiAgICAgICAgICAgICAgICBpbmNsdWRlL2ZyZWV0eXBlL2NhY2hlLyouaAoKICAgIC0gQSBuZXcsIGV4cGVyaW1lbnRhbCwgc3VwcG9ydCBmb3IgaW5jcmVtZW50YWwgZm9udCBsb2FkaW5nIChpLmUuLAogICAgICBsb2FkaW5nICBvZiBmb250cyAgd2hlcmUgdGhlICBnbHlwaHMgYXJlICBub3QgaW4gIHRoZSAgZm9udCBmaWxlCiAgICAgIGl0c2VsZiwgYnV0IHByb3ZpZGVkIGJ5IGFuIGV4dGVybmFsIGNvbXBvbmVudCwgbGlrZSBhIFBvc3RzY3JpcHQKICAgICAgaW50ZXJwcmV0ZXIpIGhhcyBiZWVuIGFkZGVkIGJ5IEdyYWhhbSBBc2hlci4gIFRoaXMgaXMgc3RpbGwgd29yawogICAgICBpbiBwcm9ncmVzcywgaG93ZXZlci4KCiAgICAtIEEgbmV3LCAgRVhQRVJJTUVOVEFMLCBwYXRoIHN0cm9rZXIgIGhhcyBiZWVuIGFkZGVkLiAgIEl0IGRvZXNuJ3QKICAgICAgc3VmZmVyICBmcm9tICBzZXZlcmUgIHJvdW5kaW5nICBlcnJvcnMgIGFuZCAgdHJlYXQgIGJlemllciAgYXJjcwogICAgICBkaXJlY3RseS4gIFN0aWxsIHdvcmsgaW4gcHJvZ3Jlc3MgKGkuZS4gbm90IHBhcnQgb2YgdGhlIG9mZmljaWFsCiAgICAgIEFQSSkuICAgU2VlICB0aGUgZmlsZSAgPGZyZWV0eXBlL2Z0c3Ryb2tlci5oPiAgZm9yICBzb21lIG9mICB0aGUKICAgICAgZGV0YWlscy4KCiAgICAtIFRoZSBtYXNzaXZlICByZS1mb3JtYXR0aW5nIG9mIHNvdXJjZXMgYW5kICBpbnRlcm5hbCByZS1kZXNpZ24gaXMKICAgICAgc3RpbGwgdW5kZXItd2F5LiAgTWFueSAgaW50ZXJuYWwgZnVuY3Rpb25zLCBjb25zdGFudHMsIGFuZCB0eXBlcwogICAgICBoYXZlIGJlZW4gcmVuYW1lZC4KCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpMQVRFU1QgQ0hBTkdFUyBCRVRXRUVOIDIuMS4yIGFuZCAyLjEuMQoKICBJLiBJTVBPUlRBTlQgQlVHIEZJWEVTCgogICAgLSBNYW55ICBmb250IGRyaXZlcnMgZGlkbid0ICBzZWxlY3QgYSAgVW5pY29kZSBjaGFybWFwICBieSBkZWZhdWx0CiAgICAgIHdoZW4gYSBuZXcgZmFjZSAgd2FzIG9wZW5lZCAod2l0aCB0aGUgRlRfQ09ORklHX09QVElPTl9VU0VfQ01BUFMKICAgICAgb3B0aW9ucyBlbmFibGVkKSwgIGNhdXNpbmcgbWFueSBhcHBsaWNhdGlvbnMgIHRvIG5vdCBiZSAgYWJsZSB0bwogICAgICBkaXNwbGF5IHRleHQgY29ycmVjdGx5IHdpdGggdGhlIDIuMS54IHJlbGVhc2VzLgoKICAgIC0gVGhlICBQRlIgZHJpdmVyIGhhZCAgYSBidWcgIGluIGl0cyAgY29tcG9zaXRlIGxvYWRpbmcgIGNvZGUgdGhhdAogICAgICBwcm9kdWNlcyBpbmNvcnJlY3RseSBwbGFjZWQgYWNjZW50cyB3aXRoIG1hbnkgZm9udHMuCgogICAgLSBUaGUgVHlwZTQyIGRyaXZlciBjcmFzaGVkIHNvbWV0aW1lcyBkdWUgdG8gYSBuYXN0eSBidWcuCgogICAgLSBUaGUgVHlwZSAxIGN1c3RvbSBlbmNvZGluZyAgY2hhcm1hcCBkaWRuJ3QgaGFuZGxlIHRoZSBjYXNlIHdoZXJlCiAgICAgIHRoZSBmaXJzdCBnbHlwaCBpbmRleCB3YXNuJ3QgMC4KCiAgICAtIEEgIHNlcmlvdXMgIHR5cG8gIGluICB0aGUgIFRydWVUeXBlICBjb21wb3NpdGUgIGxvYWRlciAgcHJvZHVjZWQKICAgICAgaW5jb3JyZWN0bHkgcGxhY2VkICBnbHlwaHMgaW4gZm9udHMgIGxpa2UgIldpbmdkaW5ncyIgYW5kICBhIGZldwogICAgICBvdGhlcnMuCgoKICBJSS4gTUlTQ0VMTEFORU9VUwoKICAgIC0gVGhlIFdpbjMyICBWaXN1YWwgQysrIHByb2plY3QgIGZpbGUgaGFzIGJlZW4gdXBkYXRlZCAgdG8gaW5jbHVkZQogICAgICB0aGUgUEZSIGRyaXZlciBhcyB3ZWxsLgoKICAgIC0gImZyZWV0eXBlLm00IiBpcyAgbm93IGluc3RhbGxlZCBieSBkZWZhdWx0IGJ5ICAibWFrZSBpbnN0YWxsIiBvbgogICAgICBVbml4IHN5c3RlbXMuCgogICAgLSBUaGUgZnVuY3Rpb24gIEZUX0dldF9QU19Gb250X0luZm8gbm93IHdvcmtzIHdpdGggIENJRCBhbmQgVHlwZTQyCiAgICAgIGZvbnRzIGFzIHdlbGwuCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKTEFURVNUIENIQU5HRVMgQkVUV0VFTiAyLjEuMSBhbmQgMi4xLjAKCiAgSS4gSU1QT1JUQU5UIEJVRyBGSVhFUwoKICAgIC0gVGhlICBgdmVyc2lvbl9pbmZvJyAgcmV0dXJuZWQgICBieSAgYGZyZWV0eXBlLWNvbmZpZycgIGluICAyLjEuMAogICAgICByZXR1cm5lZCBhbiBpbnZhbGlkIHZhbHVlLiAgSXQgbm93IHJldHVybnMgOToxOjMgKDIuMC45IHJldHVybmVkCiAgICAgIDk6MDozKS4KCiAgICAtIFZlcnNpb24gMi4xLjAgIGNvdWxkbid0IGJlIGxpbmtlZCBhZ2FpbnN0ICBhcHBsaWNhdGlvbnMgb24gV2luMzIKICAgICAgYW5kICBBbWlnYSBzeXN0ZW1zICBkdWUgIHRvICBhIG5ldyAgZGVidWcgIGZ1bmN0aW9uIHRoYXQgIHdhc24ndAogICAgICBwcm9wZXJseSAgIHByb3BhZ2F0ZWQgIHRvICAgdGhlICBzeXN0ZW0tc3BlY2lmaWMgICBkaXJlY3RvcnkgIGluCiAgICAgIGBidWlsZHMnLgoKICAgIC0gVmFyaW91cyBNYWNPUyBhbmQgTWFjIE9TIFggc3BlY2lmaWMgZml4ZXMuCgogICAgLSBGaXhlZCAgYSBidWcgaW4gIHRoZSBUcnVlVHlwZSAgY2hhcm1hcCB2YWxpZGF0aW9uICByb3V0aW5lcyB0aGF0CiAgICAgIG1hZGUgdmVyc2lvbiAgMi4xLjAgdG9vIHJlc3RyaWN0aXZlICAtLSBtYW55IHBvcHVsYXIgIGZvbnRzIGhhdmUKICAgICAgYmVlbiByZWplY3RlZC4KCiAgICAtIFRoZXJlIHdhcyAgc3RpbGwgYSB2ZXJ5IHNtYWxsIGRpZmZlcmVuY2UgIGJldHdlZW4gdGhlIG1vbm9jaHJvbWUKICAgICAgZ2x5cGggYml0bWFwcyBwcm9kdWNlZCBieSBGcmVlVHlwZSAxLnggYW5kIEZyZWVUeXBlIDIueCB3aXRoIHRoZQogICAgICBieXRlY29kZSAgaW50ZXJwcmV0ZXIgZW5hYmxlZC4gICBUaGlzIHdhcyAgY2F1c2VkIGJ5ICBhbiBpbnZhbGlkCiAgICAgIGZsYWcgc2V0dGluZyBpbiB0aGUgVHJ1ZVR5cGUgZ2x5cGggbG9hZGVyLCBtYWtpbmcgdGhlIHJhc3Rlcml6ZXIKICAgICAgY2hhbmdlICBpdHMgIGRyb3Atb3V0ICAgY29udHJvbCAgbW9kZS4gICBOb3cgIHRoZXJlc3VsdHMgIHNob3VsZAogICAgICBfcmVhbGx5XyBiZSBjb21wbGV0ZWx5IGlkZW50aWNhbC4KCiAgICAtIFRoZSBUcnVlVHlwZSBuYW1lIHRhYmxlIGxvYWRlciBoYXMgYmVlbiBpbXByb3ZlZCB0byBzdXBwb3J0IG1hbnkKICAgICAgcG9wdWxhciAgdGhvdWdoIGJ1Z2d5IEFzaWFuICBmb250cy4gIEl0ICBub3cgaWdub3JlcyAgZW1wdHkgbmFtZQogICAgICBlbnRyaWVzLCAgaW52YWxpZCAgcG9pbnRlciBvZmZzZXRzICBhbmQgIGEgIGZldyBvdGhlciAgaW5jb3JyZWN0CiAgICAgIHN1YnRsZXRpZXMuICBNb3Jlb3ZlciwgIG5hbWUgc3RyaW5ncyAgYXJlIG5vdyBsb2FkZWQgIG9uIGRlbWFuZCwKICAgICAgd2hpY2ggcmVkdWNlcyB0aGUgbWVtb3J5IGxvYWQgIG9mIG1hbnkgZmFjZXMgKGUuZy4gdGhlIEFSSUFMLlRURgogICAgICBmb250IGZpbGUgY29udGFpbnMgYSAxMGtCeXRlIG5hbWUgdGFibGUgd2l0aCA3MCBuYW1lcykuCgogICAgLSBGaXhlZCBhIGJ1ZyBpbiB0aGUgUG9zdHNjcmlwdCBoaW50ZXIgdGhhdCBwcmV2ZW50ZWQgZmFtaWx5IGJsdWVzCiAgICAgIHN1YnN0aXR1dGlvbiB0byBoYXBwZW4gY29ycmVjdGx5LgoKCiAgSUkuIE5FVyBGRUFUVVJFUwoKICAgIC0gVGhyZWUgbmV3IGZvbnQgZHJpdmVycyBpbiB0aGlzIHJlbGVhc2U6CgogICAgICAqIEEgIEJERiAgZm9udCBkcml2ZXIsICBjb250cmlidXRlZCAgYnkgIEZyYW5jbyBaYXBwYSAgTmFyZGVsbGksCiAgICAgICAgaGVhdmlseSAgbW9kaWZpZWQgICBieSAgV2VybmVyICBMZW1iZXJnLiAgICBJdCAgYWxzbyAgc3VwcG9ydHMKICAgICAgICBhbnRpLWFsaWFzZWQgYml0bWFwcyAodXNpbmcgYSBzbGlnaHRseSBleHRlbmRlZCBCREYgZm9ybWF0KS4KCiAgICAgICogQSBUeXBlNDIgIGZvbnQgZHJpdmVyLCBjb250cmlidXRlZCBieSBSb2JlcnRvICBBbGFtZWRhLiAgSXQgaXMKICAgICAgICBzdGlsbCBleHBlcmltZW50YWwgYnV0IHNlZW1zIHRvIHdvcmsgcmVsYXRpdmVseSB3ZWxsLgoKICAgICAgKiBBIFBGUiAgZm9udCBkcml2ZXIsIGNvbnRyaWJ1dGVkICBieSBEYXZpZCBUdXJuZXIgIGhpbXNlbGYuICBJdAogICAgICAgIGRvZXNuJ3QgIHN1cHBvcnQgUEZSICBoaW50aW5nIC0tICBub3RlIHRoYXQgIEJpdFN0cmVhbSAgaGFzIGF0CiAgICAgICAgbGVhc3QgdHdvIHBhdGVudHMgb24gdGhpcyBmb3JtYXQhCgoKICBJSUkuIE1JU0NFTExBTkVPVVMKCiAgICAtIFRoZSAgY2FjaGUgIHN1Yi1zeXN0ZW0gaGFzICBiZWVuICBvcHRpbWl6ZWQgIGluIGltcG9ydGFudCAgd2F5cy4KICAgICAgQ2FjaGUgaGl0cyBhcmUgbm93IHNpZ25pZmljYW50bHkgZmFzdGVyLiAgRm9yIGV4YW1wbGUsIHVzaW5nIHRoZQogICAgICBDTWFwIGNhY2hlIGlzIGFib3V0ICB0d2ljZSBmYXN0ZXIgdGhhbiBjYWxsaW5nIEZUX0dldF9DaGFyX0luZGV4CiAgICAgIG9uIG1vc3QgcGxhdGZvcm1zLiAgU2ltaWxhcmx5LCB1c2luZyBhbiBTQml0IGNhY2hlIGlzIGFib3V0IGZpdmUKICAgICAgdGltZXMgZmFzdGVyICB0aGFuIGxvYWRpbmcgdGhlICBiaXRtYXBzIGZyb20gYSBiaXRtYXAgIGZpbGUsIGFuZAogICAgICAzMDAgdG8gIDUwMCB0aW1lcyAgZmFzdGVyIHRoYW4gZ2VuZXJhdGluZyAgdGhlbSBmcm9tICBhIHNjYWxhYmxlCiAgICAgIGZvcm1hdC4KCiAgICAgIE5vdGUgdGhhdCAgeW91IHNob3VsZCByZWNvbXBpbGUgIHlvdXIgc291cmNlcyBpZiB5b3UgIGRlc2lnbmVkIGEKICAgICAgY3VzdG9tICBjYWNoZSAgY2xhc3MgZm9yICB0aGUgIEZUMiAgQ2FjaGUgIHN1YnN5c3RlbSwgc2luY2UgIHRoZQogICAgICBjaGFuZ2VzIHBlcmZvcm1lZCBhcmUgc291cmNlLCBidXQgbm90IGJpbmFyeSwgY29tcGF0aWJsZS4KCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpMQVRFU1QgQ0hBTkdFUyBCRVRXRUVOIDIuMS4wIGFuZCAyLjAuOQoKICBJLiBJTVBPUlRBTlQgQlVHIEZJWEVTCgogICAgLSBUaGUgIFRydWVUeXBlIGJ5dGVjb2RlICBpbnRlcnByZXRlciAgaGFzIGJlZW4gIGZpeGVkIHRvICBwcm9kdWNlCiAgICAgIF9leGFjdGx5XyB0aGUgc2FtZSBvdXRwdXQgYXMgRnJlZVR5cGUgMS54LiAgUHJldmlvdXMgZGlmZmVyZW5jZXMKICAgICAgd2VyZSBkdWUgIHRvIHNsaWdodGx5IGRpc3RpbmN0ICBmaXhlZC1wb2ludCBjb21wdXRhdGlvbiByb3V0aW5lcwogICAgICB1c2VkIHRvIHBlcmZvcm0gZG90IHByb2R1Y3RzIGFuZCB2ZWN0b3IgbGVuZ3RoIG1lYXN1cmVtZW50cy4KCiAgICAgIEl0IHNlZW1zICB0aGF0IG5hdGl2ZSBUcnVlVHlwZSBoaW50aW5nICBpcyBfZXh0cmVtZWx5XyBzZW5zaXRpdmUKICAgICAgdG8gIHJvdW5kaW5nIGVycm9ycy4gIFRoZSAgcmVxdWlyZWQgdmVjdG9yICBjb21wdXRhdGlvbiByb3V0aW5lcwogICAgICBoYXZlIGJlZW4gb3B0aW1pemVkIGFuZCBwbGFjZWQgd2l0aGluIHRoZSAidHRpbnRlcnAuYyIgZmlsZS4KCiAgICAtIEZpeGVkIHRoZSBwYXJzaW5nIG9mIGFjY2VsZXJhdG9yIHRhYmxlcyBpbiB0aGUgUENGIGZvbnQgZHJpdmVyLgoKICAgIC0gRml4ZWQgdGhlIFR5cGUxIGdseXBoIGxvYWRlciAgcm91dGluZSB1c2VkIHRvIGNvbXB1dGUgdGhlIGZvbnQncwogICAgICBtYXhpbXVtIGFkdmFuY2Ugd2lkdGguCgoKICBJSS4gTkVXIEZFQVRVUkVTCgogICAgLSBUaGUgYGNvbmZpZ3VyZScgc2NyaXB0IHVzZWQgb24gVW5peCBzeXN0ZW1zIGhhcyBiZWVuIG1vZGlmaWVkIHRvCiAgICAgIGNoZWNrICB0aGF0ICBHTlUgIE1ha2UgIGlzICBiZWluZyB1c2VkICB0byAgYnVpbGQgIHRoZSAgbGlicmFyeS4KICAgICAgT3RoZXJ3aXNlLCAgaXQgIHdpbGwgZGlzcGxheSAgYSAgbWVzc2FnZSAgcHJvcG9zaW5nICB0byB1c2UgIHRoZQogICAgICBHTlVNQUtFIGVudmlyb25tZW50IHZhcmlhYmxlIHRvIG5hbWUgaXQuCgogICAgICBUaGUgVW5peC1zcGVjaWZpYyBmaWxlIFJFQURNRS5VTlggaGFzIGJlZW4gbW9kaWZpZWQgYWNjb3JkaW5nbHkuCgoKICBJSUkuIE1JU0NFTExBTkVPVVMKCiAgICAtIFRoZSAgRnJlZVR5cGUgIExpY2Vuc2UgaW4gIGBkb2NzL0ZUTC50eHQnICBoYXMgIGJlZW4gdXBkYXRlZCAgdG8KICAgICAgaW5jbHVkZSAgYSAgcHJvcG9zZWQgcHJlZmVycmVkICBkaXNjbGFpbWVyLiAgIElmICB5b3UgYXJlICB1c2luZwogICAgICBGcmVlVHlwZSBpbiB5b3VyIHByb2R1Y3RzLCB5b3UgYXJlIGVuY291cmFnZWQgKGJ1dCBub3QgbWFuZGF0ZWQpCiAgICAgIHRvIHVzZSB0aGUgZm9sbG93aW5nIHRleHQgaW4geW91ciBkb2N1bWVudGF0aW9uOgoKICAgICAgIiIiCiAgICAgICAgUG9ydGlvbnMgb2YgdGhpcyBzb2Z0d2FyZSBhcmUgY29weXJpZ2h0IKkgMTk5Ni0yMDAyIFRoZQogICAgICAgIEZyZWVUeXBlIFByb2plY3QgKHd3dy5mcmVldHlwZS5vcmcpLiAgQWxsIHJpZ2h0cyByZXNlcnZlZC4KICAgICAgIiIiCgogICAgLSBUaGUgZGVmYXVsdCBzaXplIG9mIHRoZSByZW5kZXIgcG9vbCBoYXMgYmVlbiByZWR1Y2VkIHRvIDE2a0J5dGUuCiAgICAgIFRoaXMgIHNob3VsZG4ndCByZXN1bHQgIGluIGFueSAgbm90aWNlYWJsZSAgcGVyZm9ybWFuY2UgcGVuYWx0eSwKICAgICAgdW5sZXNzIHlvdSBhcmUgIHVzaW5nIHRoZSBlbmdpbmUgYXMtaXMgdG8gIHJlbmRlciB2ZXJ5IGxhcmdlIGFuZAogICAgICBjb21wbGV4IGdseXBocy4KCiAgICAtIFRoZSAgRnJlZVR5cGUgMiAgcmVkZXNpZ24gaGFzICBiZWd1bi4gIE1vcmUgIGluZm9ybWF0aW9uICBjYW4gYmUKICAgICAgZm91bmQgYXQgdGhpcyBVUkw6CgogICAgICAgIGh0dHA6Ly93d3cuZnJlZXR5cGUub3JnL2ZyZWV0eXBlMi9yZWRlc2lnbi5odG1sCgogICAgICBUaGUgZm9sbG93aW5nICBpbnRlcm5hbCBjaGFuZ2VzICBoYXZlIGJlZW4gcGVyZm9ybWVkICB3aXRoaW4gdGhlCiAgICAgIHNvdXJjZXMgb2YgdGhpcyByZWxlYXNlOgoKICAgICAgICAtIE1hbnkgICBpbnRlcm5hbCAgdHlwZXMgICBoYXZlICBiZWVuICAgcmVuYW1lZCAgIHRvICBpbmNyZWFzZQogICAgICAgICAgY29uc2lzdGVuY3kuICAgVGhlICBmb2xsb3dpbmcgIHNob3VsZCAgYmUgdHJ1ZSwgIGV4Y2VwdCAgZm9yCiAgICAgICAgICBwdWJsaWMgdHlwZXM6CgogICAgICAgICAgICAqIEFsbCBzdHJ1Y3R1cmUgIHR5cGVzIGhhdmUgYSBuYW1lIGVuZGluZyAgaW4gIlJlYyIgKHNob3J0CiAgICAgICAgICAgICAgZm9yIGByZWNvcmQnKS4KCiAgICAgICAgICAgICogQSAgcG9pbnRlci10by1zdHJ1Y3R1cmUgdHlwZSAgaGFzIHRoZSAgc2FtZSBuYW1lICBhcyB0aGUKICAgICAgICAgICAgICBzdHJ1Y3R1cmUsIF93aXRob3V0XyB0aGUgIlJlYyIgc3VmZml4LgoKICAgICAgICAgICAgICBFeGFtcGxlOgoKICAgICAgICAgICAgICAgIHR5cGVkZWYgc3RydWN0IEZvb1JlY18KICAgICAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgICAgLi4uCgogICAgICAgICAgICAgICAgfSBGb29SZWMsICpGb287CgogICAgICAgIC0gTWFueSAgIGludGVybmFsICBtYWNyb3MgIGhhdmUgICBiZWVuICByZW5hbWVkICAgdG8gIGluY3JlYXNlCiAgICAgICAgICBjb25zaXN0ZW5jeS4gIFRoZSBmb2xsb3dpbmcgc2hvdWxkIGJlIHRydWU6CgogICAgICAgICAgICAqIEFsbCAgbWFjcm9zICBoYXZlIGEgIG5hbWUgIGJlZ2lubmluZyAgd2l0aCAiRlRfIi4gICBUaGlzCiAgICAgICAgICAgICAgcmVxdWlyZWQgYSBmZXcgY2hhbmdlcyBsaWtlCgogICAgICAgICAgICAgICAgQUxMT0MgICA9PiBGVF9BTExPQwogICAgICAgICAgICAgICAgRlJFRSAgICA9PiBGVF9GUkVFCiAgICAgICAgICAgICAgICBSRUFMTE9DID0+IEZUX1JFQUxMT0MKCiAgICAgICAgICAgICogQWxsICBtYWNyb3MgYXJlIGNvbXBsZXRlbHkgIFVQUEVSQ0FTRS4gIFRoaXMgIHJlcXVpcmVkIGEKICAgICAgICAgICAgICBmZXcgY2hhbmdlcyBsaWtlOgoKICAgICAgICAgICAgICAgIFJFQURfU2hvcnQgID0+IEZUX1JFQURfU0hPUlQKICAgICAgICAgICAgICAgIE5FWFRfU2hvcnQgID0+IEZUX05FWFRfU0hPUlQKICAgICAgICAgICAgICAgIEdFVF9VTG9uZ0xFID0+IEZUX0dFVF9VTE9OR19MRQogICAgICAgICAgICAgICAgTUVNX1NldCAgICAgPT4gRlRfTUVNX1NFVAogICAgICAgICAgICAgICAgTUVNX0NvcHkgICAgPT4gRlRfTUVNX0NPUFkKICAgICAgICAgICAgICAgIGV0Yy4KCiAgICAgICAgICAgICogV2hlbmV2ZXIgICBwb3NzaWJsZSwgICBhbGwgICBtYWNybyAgbmFtZXMgICBmb2xsb3cgICB0aGUKICAgICAgICAgICAgICBGVF88T0JKRUNUPl88TUVUSE9EPiBwYXR0ZXJuLiAgRm9yIGV4YW1wbGUKCiAgICAgICAgICAgICAgICBBQ0NFU1NfRnJhbWUgICA9PiBGVF9GUkFNRV9FTlRFUgogICAgICAgICAgICAgICAgRk9SR0VUX0ZyYW1lICAgPT4gRlRfRlJBTUVfRVhJVAogICAgICAgICAgICAgICAgRVhUUkFDVF9GcmFtZSAgPT4gRlRfRlJBTUVfRVhUUkFDVAogICAgICAgICAgICAgICAgUkVMRUFTRV9GcmFtZSAgPT4gRlRfRlJBTUVfUkVMRUFTRQoKICAgICAgICAgICAgICAgIEZJTEVfUG9zICAgICAgID0+IEZUX1NUUkVBTV9QT1MKICAgICAgICAgICAgICAgIEZJTEVfU2VlayAgICAgID0+IEZUX1NUUkVBTV9TRUVLCiAgICAgICAgICAgICAgICBGSUxFX1JlYWQgICAgICA9PiBGVF9TVFJFQU1fUkVBRAogICAgICAgICAgICAgICAgRklMRV9SZWFkQXQgICAgPT4gRlRfU1RSRUFNX1JFQURfQVQKICAgICAgICAgICAgICAgIFJFQURfRmllbGRzICAgID0+IEZUX1NUUkVBTV9SRUFEX0ZJRUxEUwoKICAgICAgICAtIE1hbnkgIGludGVybmFsIGZ1bmN0aW9ucyAgaGF2ZSAgYmVlbiByZW5hbWVkICB0byBmb2xsb3cgIHRoZQogICAgICAgICAgRlRfPE9iamVjdD5fPE1ldGhvZD4gcGF0dGVybi4gIEZvciBleGFtcGxlOgoKICAgICAgICAgICAgRlRfU2Vla19TdHJlYW0gICAgICAgPT4gRlRfU3RyZWFtX1NlZWsKICAgICAgICAgICAgRlRfUmVhZF9TdHJlYW1fQXQgICAgPT4gRlRfU3RyZWFtX1JlYWRBdAogICAgICAgICAgICBGVF9Eb25lX1N0cmVhbSAgICAgICA9PiBGVF9TdHJlYW1fQ2xvc2UKICAgICAgICAgICAgRlRfTmV3X1N0cmVhbSAgICAgICAgPT4gRlRfU3RyZWFtX09wZW4KICAgICAgICAgICAgRlRfTmV3X01lbW9yeV9TdHJlYW0gPT4gRlRfU3RyZWFtX09wZW5NZW1vcnkKICAgICAgICAgICAgRlRfRXh0cmFjdF9GcmFtZSAgICAgPT4gRlRfU3RyZWFtX0V4dHJhY3RGcmFtZQoKICAgICAgICAgIE5vdGUgdGhhdCBtZXRob2QgbmFtZXMgZG8gbm90IGNvbnRhaW4gIl8iLgoKICAgICAgICAtIFRoZSBGVF9BTExPQ19BUlJBWSAgYW5kIEZUX1JFQUxMT0NfQVJSQVkgaGF2ZSAgYmVlbiByZXBsYWNlZAogICAgICAgICAgd2l0aCAgRlRfTkVXX0FSUkFZIGFuZCAgRlRfUkVORVdfQVJSQVkgd2hpY2ggIGRvIG5vdCAgdGFrZSBhCiAgICAgICAgICB0eXBlICBhcyB0aGUgIGZvdXJ0aCBhcmd1bWVudC4gICBJbnN0ZWFkLCB0aGUgIGFycmF5IGVsZW1lbnQKICAgICAgICAgIHR5cGUgIHNpemUgaXMgY29tcHV0ZWQgIGF1dG9tYXRpY2FsbHkgZnJvbSAgdGhlIHR5cGUgIG9mIHRoZQogICAgICAgICAgdGFyZ2V0IHBvaW50ZXIgdXNlZC4KCiAgICAgICAgLSBBICBuZXcgb2JqZWN0ICBjbGFzcywgRlRfQ01hcCwgIGhhcyBiZWVuICBpbnRyb2R1Y2VkLiAgVGhlc2UKICAgICAgICAgIGludGVybmFsICBvYmplY3RzIGFyZSAgdXNlZCB0byAgbW9kZWwgY2hhcmFjdGVyICBtYXBzLiAgVGhpcwogICAgICAgICAgZWFzZXMgIHRoZSBzdXBwb3J0ICBvZiBhZGRpdGlvbmFsICBjaGFybWFwIHR5cGVzICB3aXRoaW4gdGhlCiAgICAgICAgICBlbmdpbmUuCgogICAgICAgIC0gQSBuZXcgIGNvbmZpZ3VyYXRpb24gZmlsZSBuYW1lZCAiZnRzdGRsaWIuaCIgIGhhcyBiZWVuIGFkZGVkCiAgICAgICAgICB0byBgaW5jbHVkZS9mcmVldHlwZS9jb25maWcnLiAgSXQgIGlzIHVzZWQgdG8gZGVmaW5lIGFsaWFzZXMKICAgICAgICAgIGZvciAgX2V2ZXJ5XyByb3V0aW5lICBvZiB0aGUgIElTTyAgQyBsaWJyYXJ5ICB0aGF0IHRoZSAgZm9udAogICAgICAgICAgZW5naW5lICAgdXNlcy4gICAgRWFjaCAgICBhbGlhc2VzICAgaGFzICAgYSAgICJmdF8iICAgcHJlZml4CiAgICAgICAgICAoZS5nLiAiZnRfc3RybGVuIiBpcyBhbiBhbGlhcyBmb3IgInN0cmxlbiIpLgoKICAgICAgICAgIFRoaXMgaXMgIHVzZWQgdG8gIGVhc2UgdGhlIHBvcnRpbmcgIG9mIEZyZWVUeXBlIDIgIHRvIGV4b3RpYwogICAgICAgICAgcnVudGltZSBlbnZpcm9ubWVudHMgd2hlcmUgdGhlIElTTyBDIExpYnJhcnkgaXNuJ3QgYXZhaWxhYmxlCiAgICAgICAgICAoZS5nLiAgWEZyZWU4NiBleHRlbnNpb24gbW9kdWxlcykuCgogICAgICBNb3JlIGRldGFpbHMgYXJlIGF2YWlsYWJsZSBpbiB0aGUgIkNoYW5nZUxvZyIgZmlsZS4KCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpMQVRFU1QgQ0hBTkdFUyBCRVRXRUVOIDIuMC45IGFuZCAyLjAuOAoKICBJLiBJTVBPUlRBTlQgQlVHIEZJWEVTCgogICAgLSBDZXJ0YWluIGZvbnRzIGxpa2UgImZveGp1bXAudHRmIiBjb250YWluIGJyb2tlbiBuYW1lIHRhYmxlcyB3aXRoCiAgICAgIGludmFsaWQgZW50cmllcyBhbmQgd2lsZCBvZmZzZXRzLiAgVGhpcyBjYXVzZWQgRnJlZVR5cGUgdG8gY3Jhc2gKICAgICAgd2hlbiB0cnlpbmcgdG8gbG9hZCB0aGVtLgoKICAgICAgVGhlICBTRk5UIGBuYW1lJyAgdGFibGUgIGxvYWRlciBoYXMgIGJlZW4gIGZpeGVkIHRvICBiZSBhYmxlICB0bwogICAgICBzdXBwb3J0IHRoZXNlIHN0cmFuZ2UgZm9udHMuCgogICAgICBNb3Jlb3ZlciwgdGhlIGNvZGUgIGluIGNoYXJnZSBvZiBwcm9jZXNzaW5nIHRoaXMgIHRhYmxlIGhhcyBiZWVuCiAgICAgIGNoYW5nZWQgIHRvIGFsd2F5cyBmYXZvdXIgIFdpbmRvd3MtZm9ybWF0dGVkIGVudHJpZXMgIG92ZXIgb3RoZXIKICAgICAgb25lcy4gIEhlbmNlLCAgYSBmb250IHRoYXQgd29ya3MgIG9uIFdpbmRvd3MgYnV0IG5vdCAgb24gdGhlIE1hYwogICAgICB3aWxsICBsb2FkIGNsZWFubHkgaW4gIEZyZWVUeXBlIGFuZCAgcmVwb3J0IGFjY3VyYXRlICB2YWx1ZXMgZm9yCiAgICAgIEZhbWlseSAmIFBvc3RTY3JpcHQgbmFtZXMuCgogICAgLSBUaGUgQ0lEIGZvbnQgZHJpdmVyIGhhcyBiZWVuIGZpeGVkLiAgSXQgdW5mb3J0dW5hdGVseSByZXR1cm5lZCBhCiAgICAgIFBvc3RzY3JpcHQgICBGb250ICAgbmFtZSAgIHdpdGggICBhICAgbGVhZGluZyAgIHNsYXNoLCAgIGFzICAgaW4KICAgICAgIi9NdW5od2FHb3RoaWMtUmVndWxhciIuCgogICAgLSBGcmVlVHlwZSAgMiBzaG91bGQgbm93ICBjb21waWxlIGZpbmUgIG9uIEFJWCAgNC4zLjMgYXMgIGEgc2hhcmVkCiAgICAgIGxpYnJhcnkuCgogICAgLSBBICBidWcgIGluIHRoZSAgUG9zdHNjcmlwdCAgaGludGVyICBoYXMgIGJlZW4gZm91bmQgIGFuZCAgZml4ZWQsCiAgICAgIHJlbW92aW5nIHVuLWV2ZW4gc3RlbSB3aWR0aHMgYXQgc21hbGwgcGl4ZWwgc2l6ZXMgKGxpa2UgMTQtMTcpLgoKICAgICAgVGhpcyAgaW1wcm92ZXMgdGhlICBxdWFsaXR5IG9mICBhIGNlcnRhaW4gIG51bWJlciAgb2YgUG9zdHNjcmlwdAogICAgICBmb250cy4KCgogIElJLiBORVcgRkVBVFVSRVMKCiAgICAtIEEgIG5ldyBmdW5jdGlvbiAgbmFtZWQgIGBGVF9MaWJyYXJ5X1ZlcnNpb24nIGhhcyAgYmVlbiBhZGRlZCAgdG8KICAgICAgcmV0dXJuICB0aGUgY3VycmVudCAgbGlicmFyeSdzIG1ham9yLCAgbWlub3IsIGFuZCAgcGF0Y2ggdmVyc2lvbgogICAgICBudW1iZXJzLiAgIFRoaXMgaXMgIGltcG9ydGFudCBzaW5jZSAgdGhlICBtYWNyb3MgRlJFRVRZUEVfTUFKT1IsCiAgICAgIEZSRUVUWVBFX01JTk9SLCAgYW5kICBGUkVFVFlQRV9QQVRDSCAgY2Fubm90ICBiZSB1c2VkICB3aGVuICB0aGUKICAgICAgbGlicmFyeSBpcyBkeW5hbWljYWxseSBsaW5rZWQgYnkgYSBwcm9ncmFtLgoKICAgIC0gVHdvICAgbmV3ICBBUElzICAgaGF2ZSAgYmVlbiAgIGFkZGVkOiAgIGBGVF9HZXRfRmlyc3RfQ2hhcicgIGFuZAogICAgICBgRlRfR2V0X05leHRfQ2hhcicuCgogICAgICBUb2dldGhlciwgIHRoZXNlIGNhbiAgYmUgdXNlZCAgdG8gaXRlcmF0ZSAgZWZmaWNpZW50bHkgIG92ZXIgdGhlCiAgICAgIGN1cnJlbnRseSAgc2VsZWN0ZWQgIGNoYXJtYXAgb2YgIGEgIGdpdmVuICBmYWNlLiAgIFJlYWQgdGhlICBBUEkKICAgICAgcmVmZXJlbmNlIGZvciBtb3JlIGRldGFpbHMuCgoKICBJSUkuIE1JU0NFTExBTkVPVVMKCiAgICAtIFRoZSBGcmVlVHlwZSBzb3VyY2VzIGFyZSAgdW5kZXIgaGVhdnkgaW50ZXJuYWwgcmUtZmFjdG9yaW5nLiAgQXMKICAgICAgYSBjb25zZXF1ZW5jZSwgIHdlIGhhdmUgY3JlYXRlZCAgYSBicmFuY2ggbmFtZWQgIlNUQUJMRSIgIG9uIHRoZQogICAgICBDVlMgdG8gaG9sZCBhbGwgZnV0dXJlIHJlbGVhc2VzL2ZpeGVzIGluIHRoZSAyLjAueCBmYW1pbHkuCgogICAgICBUaGUgIEhFQUQgIGJyYW5jaCAgbm93ICBjb250YWlucyAgdGhlICByZS1mYWN0b3JlZCAgc291cmNlcyAgYW5kCiAgICAgIHNob3VsZG4ndCAgYmUgdXNlZCBmb3IgIHRlc3Rpbmcgb3IgIHBhY2thZ2luZyBuZXcgIHJlbGVhc2VzLiAgSW4KICAgICAgY2FzZSB5b3UgIHdvdWxkIGxpa2UgIHRvIGFjY2VzcyB0aGUgIDIuMC45IHNvdXJjZXMgZnJvbSAgb3VyIENWUwogICAgICByZXBvc2l0b3J5LCB1c2UgdGhlIHRhZyBgVkVSLTItMC05Jy4KCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpMQVRFU1QgQ0hBTkdFUyBCRVRXRUVOIDIuMC44IGFuZCAyLjAuNwoKICBJLiBJTVBPUlRBTlQgQlVHIEZJWEVTCgogICAgLSBUaGVyZSB3YXMgIGEgc21hbGwgYnV0ICBuYXN0eSBidWcgaW4gICJmcmVldHlwZS1jb25maWcuaW4iIHdoaWNoCiAgICAgIGNhdXNlZCB0aGUgImZyZWV0eXBlLWNvbmZpZyIgc2NyaXB0IHRvIGZhaWwgb24gVW5peC4KCiAgICAgIFRoaXMgZGlkbid0IHByZXZlbnQgdGhlIGluc3RhbGxhdGlvbiAgb2YgdGhlIGxpYnJhcnkgb3IgZXZlbiBpdHMKICAgICAgZXhlY3V0aW9uLCBidXQgY2F1c2VkIHByb2JsZW1zICB3aGVuIHRyeWluZyB0byBjb21waWxlIG1hbnkgVW5peAogICAgICBwYWNrYWdlcyB0aGF0IGRlcGVuZCBvbiBpdC4KCiAgICAtIFNvbWUgVHJ1ZVR5cGUgb3IgT3BlblR5cGUgZm9udHMgZW1iZWRkZWQgaW4gUERGIGRvY3VtZW50cyBkbyBub3QKICAgICAgaGF2ZSAgYSAgJ2NtYXAnLCAgJ3Bvc3QnICBhbmQgICduYW1lJyAgYXMgIGlzICByZXF1aXJlZCAgYnkgIHRoZQogICAgICBzcGVjaWZpY2F0aW9uLiAgRnJlZVR5cGUgbm8gbG9uZ2VyIHJlZnVzZXMgdG8gbG9hZCBzdWNoIGZvbnRzLgoKICAgIC0gVmFyaW91cyBmaXhlcyB0byB0aGUgUENGIGZvbnQgZHJpdmVyLgoKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCkxBVEVTVCBDSEFOR0VTIEJFVFdFRU4gMi4wLjcgYW5kIDIuMC42CgogIEkuIElNUE9SVEFOVCBCVUcgRklYRVMKCiAgICAtIEZpeGVkICB0d28gIGJ1Z3MgaW4gIHRoZSAgVHlwZSAxICBmb250ICBkcml2ZXIuICAgVGhlIGZpcnN0ICBvbmUKICAgICAgcmVzdWx0ZWQgaW4gYSBtZW1vcnkgbGVhayBpbiBzdWJ0bGUgY2FzZXMuICBUaGUgb3RoZXIgb25lIGNhdXNlZAogICAgICBGcmVlVHlwZSB0byBjcmFzaCB3aGVuICB0cnlpbmcgdG8gbG9hZCAiLmdzZiIgZmlsZXMgKEdob3N0c2NyaXB0CiAgICAgIHNvLWNhbGxlZCBQb3N0c2NyaXB0IGZvbnRzKS4KCiAgICAgIChUaGlzICBtYWRlIF9tYW55XyAgS0RFIGFwcGxpY2F0aW9ucyAgY3Jhc2ggb24gIGNlcnRhaW4gc3lzdGVtcy4KICAgICAgIEZyZWVUeXBlIF9pc18gYmVjb21pbmcgYSBjcml0aWNhbCBzeXN0ZW0gY29tcG9uZW50IG9uIExpbnV4IDotKQoKICAgIC0gRml4ZWQgYSBtZW1vcnkgbGVhayBpbiB0aGUgQ0ZGIGZvbnQgZHJpdmVyLgoKICAgIC0gRml4ZWQgYSBtZW1vcnkgbGVhayBpbiB0aGUgUENGIGZvbnQgZHJpdmVyLgoKICAgIC0gRml4ZWQgICAgICAgdGhlICAgICAgICBWaXN1YWwgICAgICAgQysrICAgICAgIHByb2plY3QgICAgICAgZmlsZQogICAgICAiYnVpbGRzL3dpbjMyL3Zpc3VhbGMvZnJlZXR5cGUuZHNwIiBzaW5jZSAgaXQgZGlkbid0IGluY2x1ZGUgdGhlCiAgICAgIFBvc3RzY3JpcHQgaGludGVyIGNvbXBvbmVudCwgY2F1c2luZyBlcnJvcnMgYXQgYnVpbGQgdGltZS4KCiAgICAtIEZpeGVkIGEgIHNtYWxsIHJlbmRlcmluZyBidWcgIGluIHRoZSBhbnRpLWFsaWFzZWQgIHJlbmRlcmVyIHRoYXQKICAgICAgb25seSAgb2NjdXJyZWQgd2hlbiAgdHJ5aW5nIHRvICBkcmF3ICB0aGluIChsZXNzICB0aGFuIDEgIHBpeGVsKQogICAgICBzdHJva2VzLgoKICAgIC0gRml4ZWQgICJidWlsZHMvdW5peC9mcmVldHlwZTIuYTQiIHdoaWNoICBpcyB1c2VkICB0byAgZ2VuZXJhdGUgYQogICAgICB2YWxpZCAiZnJlZXR5cGUyLm00IiBmb3IgdXNlIHdpdGggYXV0b2NvbmYuCgogICAgLSBGaXhlZCB0aGUgT3BlblZNUyBNYWtlZmlsZXMuCgoKICBJSS4gTUlTQ0VMTEFORU9VUwoKICAgIC0gQWRkZWQgICJjb25maWd1cmUiICBhbmQgICAiaW5zdGFsbCIgIHNjcmlwdHMgIHRvICB0aGUgIHRvcC1sZXZlbAogICAgICBkaXJlY3RvcnkuICBBIEdOVS1zdHlsZSBpbnN0YWxsYXRpb24gaXMgdGh1cyBub3cgZWFzaWx5IHBvc3NpYmxlCiAgICAgIHdpdGgKCiAgICAgICAgLi9jb25maWd1cmUgIDxvcHRpb25zPgogICAgICAgIG1ha2UKICAgICAgICBtYWtlIGluc3RhbGwKCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpMQVRFU1QgQ0hBTkdFUyBCRVRXRUVOIDIuMC42IGFuZCAyLjAuNQoKICBJLiBJTVBPUlRBTlQgQlVHIEZJWEVTCgogICAgLSBJdCB3YXNuJ3QgcG9zc2libGUgdG8gbG9hZCBlbWJlZGRlZCBiaXRtYXBzIHdoZW4gdGhlIGF1dG8taGludGVyCiAgICAgIHdhcyB1c2VkLiAgVGhpcyBpcyBub3cgZml4ZWQuCgogICAgLSBUaGUgVHJ1ZVR5cGUgIGZvbnQgZHJpdmVyICBkaWRuJ3QgbG9hZCBzb21lICBjb21wb3NpdGVzIHByb3Blcmx5CiAgICAgICh0aGUgIHN1Yi1nbHlwaHMgIHdlcmUgIHNsaWdodGx5ICBzaGlmdGVkLCAgYW5kICB0aGlzICB3YXMgIG9ubHkKICAgICAgbm90aWNlYWJsZSB3aGVuIHVzaW5nIG1vbm9jaHJvbWUgcmVuZGVyaW5nKS4KCiAgICAtIFZhcmlvdXMgIGZpeGVzICB0byB0aGUgIGF1dG8taGludGVyLiAgIFRoZXkgIG1lcmVseSBpbXByb3ZlICB0aGUKICAgICAgb3V0cHV0IG9mIHNhbnMtc2VyaWYgZm9udHMuICAgTm90ZSB0aGF0IHRoZXJlIGFyZSBzdGlsbCBwcm9ibGVtcwogICAgICB3aXRoIHNlcmlmZWQgZm9udHMgYW5kIGNvbXBvc2l0ZXMgKGFjY2VudGVkIGNoYXJhY3RlcnMpLgoKICAgIC0gQWxsIHNjYWxhYmxlICBmb250IGRyaXZlcnMgZXJyb25lb3VzbHkgIHJldHVybmVkIHVuLWZpdHRlZCBnbHlwaAogICAgICBhZHZhbmNlcyB3aGVuIGhpbnRpbmcgd2FzICByZXF1ZXN0ZWQuICBUaGlzIGNyZWF0ZWQgcHJvYmxlbXMgZm9yCiAgICAgIGEgbnVtYmVyICBvZiBsYXlvdXQgYXBwbGljYXRpb25zLiAgVGhpcyAgaXMgYSB2ZXJ5ICBvbGQgYnVnIHRoYXQKICAgICAgZ290ICB1bmRldGVjdGVkIG1haW5seSAgYmVjYXVzZSBtb3N0ICB0ZXN0L2RlbW8gIHByb2dyYW0gcGVyZm9ybQogICAgICByb3VuZGluZyBleHBsaWNpdGx5IG9yIGltcGxpY2l0bHkgKHRocm91Z2ggdGhlIGNhY2hlKS4KCiAgICAtIEZUX0dseXBoX1RvX0JpdG1hcCgpIGRpZCBlcnJvbmVvdXNseSAgbW9kaWZ5IHRoZSBzb3VyY2UgZ2x5cGggaW4KICAgICAgY2VydGFpbiBjYXNlcy4KCiAgICAtICJnbG5hbWVzLnB5IiAgc3RpbGwgY29udGFpbmVkICBhIGJ1ZyAgdGhhdCBtYWRlICBGcmVlVHlwZSByZXR1cm4KICAgICAgaW52YWxpZCBuYW1lcyBmb3IgY2VydGFpbiBnbHlwaHMuCgogICAgLSBUaGUgIGxpYnJhcnkgY3Jhc2hlZCAgd2hlbiAgbG9hZGluZyBjZXJ0YWluICBUeXBlICAxIGZvbnRzICBsaWtlCiAgICAgICJzYWRuLnBmYiIgICgiU3RhbGluZ3JhZCAgTm9ybWFsIiksICAgd2hpY2ggIGFwcGVhciAgdG8gIGNvbnRhaW4KICAgICAgcGF0aGV0aWMgZm9udCBpbmZvIGRpY3Rpb25hcmllcy4KCiAgICAtIFRoZSBUcnVlVHlwZSBnbHlwaCAgbG9hZGVyIGlzIG5vdyBtdWNoIG1vcmUgIHBhcmFub2lkIGFuZCBjaGVja3MKICAgICAgZXZlcnl0aGluZyB3aGVuIGxvYWRpbmcgYSBnaXZlbiBnbHlwaCBpbWFnZS4gIFRoaXMgd2FzIG5lY2Vzc2FyeQogICAgICB0byBhdm9pZCBwcm9ibGVtcyAoY3Jhc2hlcyBhbmQvb3IgbWVtb3J5IG92ZXJ3cml0ZXMpIHdpdGggYnJva2VuCiAgICAgIGZvbnRzIHRoYXQgY2FtZSBmcm9tIGEgcmVhbGx5IGJ1Z2d5IGF1dG9tYXRpYyBmb250IGNvbnZlcnRlci4KCgogIElJLiBJTVBPUlRBTlQgVVBEQVRFUyBBTkQgTkVXIEZFQVRVUkVTCgogICAgLSBJbXBvcnRhbnQgdXBkYXRlcyB0byB0aGUgTWFjLXNwZWNpZmljIHBhcnRzIG9mIHRoZSBsaWJyYXJ5LgoKICAgIC0gVGhlIGNhY2hpbmcgc3ViLXN5c3RlbSBoYXMgIGJlZW4gY29tcGxldGVseSByZS1kZXNpZ25lZCwgYW5kIGl0cwogICAgICBBUEkgaGFzICBldm9sdmVkICh0aGUgb2xkICBvbmUgaXMgc3RpbGwgc3VwcG9ydGVkICBmb3IgYmFja3dhcmRzCiAgICAgIGNvbXBhdGliaWxpdHkpLgoKICAgICAgVGhlIGRvY3VtZW50YXRpb24gZm9yIGl0IGlzICBub3QgeWV0IGNvbXBsZXRlZCwgc29ycnkuICBGb3Igbm93LAogICAgICB5b3UgYXJlIGVuY291cmFnZWQgdG8gY29udGludWUgIHVzaW5nIHRoZSBvbGQgQVBJLiAgSG93ZXZlciwgdGhlCiAgICAgIGZ0dmlldyAgZGVtbyBwcm9ncmFtIGluICB0aGUgZnQyZGVtb3MgIHBhY2thZ2UgaGFzICBhbHJlYWR5IGJlZW4KICAgICAgdXBkYXRlZCB0byB1c2UgdGhlIG5ldyBjYWNoaW5nIGZ1bmN0aW9ucy4KCiAgICAtIEEgbmV3IGNoYXJtYXAgY2FjaGUgaXMgcHJvdmlkZWQgdG9vLiAgU2VlIEZUQ19DTWFwQ2FjaGUoKS4gIFRoaXMKICAgICAgaXMgdXNlZnVsIHRvIHBlcmZvcm0gIGNoYXJhY3RlciBjb2RlIC0+IGdseXBoIGluZGV4IHRyYW5zbGF0aW9ucwogICAgICBxdWlja2x5LCB3aXRob3V0IHRoZSBuZWVkIGZvciBhbiBvcGVuZWQgRlRfRmFjZS4KCiAgICAtIEEgTkVXIFBPU1RTQ1JJUFQgSElOVEVSIG1vZHVsZSAgaGFzIGJlZW4gYWRkZWQgdG8gc3VwcG9ydCBuYXRpdmUKICAgICAgaGludHMgaW4gIHRoZSBmb2xsb3dpbmcgIGZvcm1hdHM6IFBvc3RTY3JpcHQgVHlwZSAgMSwgUG9zdFNjcmlwdAogICAgICBDSUQsIGFuZCBDRkYvQ0VGLgoKICAgICAgUGxlYXNlIHRlc3QhICBOb3RlIHRoYXQgIHRoZSBhdXRvLWhpbnRlciBwcm9kdWNlcyBiZXR0ZXIgcmVzdWx0cwogICAgICBmb3IgYSBudW1iZXIgb2YgIGJhZGx5LWhpbnRlZCBmb250cyAobW9zdGx5IGF1dG8tZ2VuZXJhdGVkIG9uZXMpCiAgICAgIHRob3VnaC4KCiAgICAtIEEgbWVtb3J5IGRlYnVnZ2VyIGlzIG5vdyAgcGFydCBvZiB0aGUgc3RhbmRhcmQgRnJlZVR5cGUgc291cmNlcy4KICAgICAgVG8gICAgICBlbmFibGUgICAgICBpdCwgICAgICBkZWZpbmUgICAgICBGVF9ERUJVR19NRU1PUlkgICAgICBpbgogICAgICA8ZnJlZXR5cGUvY29uZmlnL2Z0b3B0aW9uLmg+LCBhbmQgcmVjb21waWxlIHRoZSBsaWJyYXJ5LgoKICAgICAgQWRkaXRpb25hbGx5LCBkZWZpbmUgIHRoZSBfZW52aXJvbm1lbnRfIHZhcmlhYmxlIEZUX0RFQlVHX01FTU9SWQogICAgICBhbmQgcnVuIGFueSBwcm9ncmFtIHVzaW5nIEZyZWVUeXBlLiAgV2hlbiB0aGUgbGlicmFyeSBpcyBleGl0ZWQsCiAgICAgIGEgIHN1bW1hcnkgIG9mIG1lbW9yeSAgZm9vdHByaW50cyAgYW5kICBwb3NzaWJsZSAgbGVha3Mgd2lsbCAgYmUKICAgICAgZGlzcGxheWVkLgoKICAgICAgVGhpcyB3b3JrcyB0cmFuc3BhcmVudGx5IHdpdGggIF9hbnlfIHByb2dyYW0gdGhhdCB1c2VzIEZyZWVUeXBlLgogICAgICBIb3dldmVyLCB5b3UgIHdpbGwgbmVlZCBhIGxvdCAgb2YgbWVtb3J5IHRvICB1c2UgdGhpcyAoYWxsb2NhdGVkCiAgICAgIGJsb2NrcyBhcmUgbmV2ZXIgIHJlbGVhc2VkIHRvIHRoZSBoZWFwIHRvICBkZXRlY3QgZG91YmxlIGRlbGV0ZXMKICAgICAgZWFzaWx5KS4KCgogIElJSS4gTUlTQ0VMTEFORU9VUwoKICAgIC0gV2UgIGFyZSAgYXdhcmUgIG9mICBzdWJ0bGUgIGRpZmZlcmVuY2VzIGJldHdlZW4gIHRoZSAgb3V0cHV0ICBvZgogICAgICBGcmVlVHlwZSAgdmVyc2lvbnMgICAxICBhbmQgIDIgIHdoZW4gIGl0ICAgY29tZXMgIHRvICBtb25vY2hyb21lCiAgICAgIFRydWVUeXBlLWhpbnRlZCBnbHlwaHMuICAgVGhlc2UgYXJlICBtb3N0IHByb2JhYmx5IGR1ZSAgdG8gc21hbGwKICAgICAgZGlmZmVyZW5jZXMgaW4gdGhlIG1vbm9jaHJvbWUgcmFzdGVyaXplcnMgYW5kIHdpbGwgYmUgd29ya2VkIG91dAogICAgICBpbiBhbiB1cGNvbWluZyByZWxlYXNlLgoKICAgIC0gV2UgaGF2ZSBkZWNpZGVkIHRvIGZvcmsgdGhlIHNvdXJjZXMgaW4gYSAic3RhYmxlIiBicmFuY2gsIGFuZCBhbgogICAgICAidW5zdGFibGUiIG9uZSwgc2luY2UgRnJlZVR5cGUgIGlzIGJlY29taW5nIGEgY3JpdGljYWwgY29tcG9uZW50CiAgICAgIG9mIG1hbnkgVW5peCBzeXN0ZW1zLgoKICAgICAgVGhlIG5leHQgIGJ1Zy1maXggcmVsZWFzZXMgb2YgIHRoZSBsaWJyYXJ5IHdpbGwgYmUgIG5hbWVkIDIuMC43LAogICAgICAyLjAuOCwgZXRjLiwgIHdoaWxlIHRoZSAiMi4xIiAgYnJhbmNoIHdpbGwgY29udGFpbiBhICB2ZXJzaW9uIG9mCiAgICAgIHRoZSBzb3VyY2VzIHdoZXJlIHdlIHdpbGwgc3RhcnQgbWFqb3IgcmV3b3JraW5nIG9mIHRoZSBsaWJyYXJ5J3MKICAgICAgaW50ZXJuYWxzLCBpbiBvcmRlciB0byBwcm9kdWNlIEZyZWVUeXBlIDIuMi4wIChvciBldmVuIDMuMCkgaW4gYQogICAgICBtb3JlIGRpc3RhbnQgZnV0dXJlLgoKICAgICAgV2UgIGFsc28gaG9wZSAgdGhhdCB0aGlzICBzY2hlbWUgd2lsbCAgYWxsb3cgbXVjaCAgbW9yZSBmcmVxdWVudAogICAgICByZWxlYXNlcyB0aGFuIGluIHRoZSBwYXN0LgoKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCkxBVEVTVCBDSEFOR0VTIEJFVFdFRU4gMi4wLjUgYW5kIDIuMC40CgogIE5PVEUgVEhBVCAyLjAuNSBET0VTIE5PVCBDT05UQUlOIFRIRSBQT1NUU0NSSVBUIEhJTlRFUi4gIFRISVMgTU9EVUxFCiAgV0lMTCBCRSBQQVJUIE9GIFRIRSBORVhUIFJFTEVBU0UgKEVJVEhFUiAyLjAuNiBvciAyLjEpCgogIC0gRml4ZWQgYSBidWcgdGhhdCBtYWRlICBjZXJ0YWluIGdseXBocywgbGlrZSAiQ2FjdXRlIiwgImNhY3V0ZSIgYW5kCiAgICAibHNsYXNoIiAgdW5hdmFpbGFibGUgZnJvbSBVbmljb2RlICBjaGFybWFwcyBvZiAgUG9zdHNjcmlwdCBmb250cy4KICAgIFRoaXMgcHJldmVudGVkIHRoZSBjb3JyZWN0IGRpc3BsYXkgb2YgUG9saXNoIHRleHQsIGZvciBleGFtcGxlLgoKICAtIFRoZSBrZXJuaW5nIHRhYmxlIG9mIFR5cGUgMSBmb250cyB3YXMgbG9hZGVkIGJ5IEZyZWVUeXBlLCB3aGVuIGl0cwogICAgQUZNICAgIGZpbGUgICAgd2FzICAgIGF0dGFjaGVkICAgIHRvICAgIGl0cyAgICBmYWNlLCAgICBidXQgICAgdGhlCiAgICBGVF9GQUNFX0ZMQUdfSEFTX0tFUk5JTkcgICBiaXQgIGZsYWdzICAgd2FzICBub3QgICBzZXQgIGNvcnJlY3RseSwKICAgIHByZXZlbnRpbmcgRlRfR2V0X0tlcm5pbmcgdG8gcmV0dXJuIG1lYW5pbmdmdWwgdmFsdWVzLgoKICAtIEltcHJvdmVkICBTRk5UIChUcnVlVHlwZSAgJiBPcGVuVHlwZSkgIGNoYXJtYXAgIHN1cHBvcnQuICBTbGlnaHRseQogICAgYmV0dGVyIHBlcmZvcm1hbmNlLCBhcyB3ZWxsIGFzIHN1cHBvcnQgZm9yIHRoZSBuZXcgZm9ybWF0cyBkZWZpbmVkCiAgICBieSB0aGUgT3BlblR5cGUgMS4zIHNwZWNpZmljYXRpb24gKDgsIDEwLCBhbmQgMTIpCgogIC0gRml4ZWQgYSAgc2VyaW91cyB0eXBvIGluICJzcmMvYmFzZS9mdGNhbGMuYyIgIHdoaWNoIGNhdXNlZCBpbnZhbGlkCiAgICBjb21wdXRhdGlvbnMgaW4gY2VydGFpbiByYXJlIGNhc2VzLCBwcm9kdWNpbmcgdWdseSBhcnRlZmFjdHMuCgogIC0gVGhlICBzaXplICBvZiB0aGUgIEVNICBzcXVhcmUgaXMgIGNvbXB1dGVkICB3aXRoICBhIG1vcmUgIGFjY3VyYXRlCiAgICBhbGdvcml0aG0gZm9yIFBvc3RzY3JpcHQgZm9udHMuICAgVGhlIG9sZCBvbmUgY2F1c2VkIHNsaWdodCBlcnJvcnMKICAgIHdpdGggZW1iZWRkZWQgZm9udHMgZm91bmQgaW4gUERGIGRvY3VtZW50cy4KCiAgLSBGaXhlZCAgYSAgYnVnIGluICB0aGUgIGNhY2hlICBtYW5hZ2VyICB0aGF0IHByZXZlbnRlZCAgbm9ybWFsICBMUlUKICAgIGJlaGF2aW91ciAgd2l0aGluIHRoZSBjYWNoZSAgbWFuYWdlciwgY2F1c2luZyAgdW5uZWNlc3NhcnkgcmVsb2FkcwogICAgKGZvciBGVF9GYWNlIGFuZCBGVF9TaXplIG9iamVjdHMgb25seSkuCgogIC0gQWRkZWQgIGEgbmV3ICBmdW5jdGlvbiBuYW1lZCAgIkZUX0dldF9OYW1lX0luZGV4IiB0byAgcmV0cmlldmUgdGhlCiAgICBnbHlwaCBpbmRleCBvZiBhIGdpdmVuIGdseXBoIG5hbWUsIHdoZW4gZm91bmQgaW4gYSBmYWNlLgoKICAtIEFkZGVkICBhIG5ldyBmdW5jdGlvbiAgbmFtZWQgIkZUX0dldF9Qb3N0c2NyaXB0X05hbWUiICB0byByZXRyaWV2ZQogICAgdGhlICJ1bmlxdWUiIFBvc3RzY3JpcHQgZm9udCBuYW1lIG9mIGEgZ2l2ZW4gZmFjZS4KCiAgLSBBZGRlZCAgIGEgICBuZXcgICBwdWJsaWMgICBoZWFkZXIgIHNpemUgICBuYW1lZCAgIEZUX1NJWkVTX0ggICAob3IKICAgIDxmcmVldHlwZS9mdHNpemVzLmg+KSBwcm92aWRpbmcgIG5ldyBGVF9TaXplLW1hbmFnZW1lbnQgZnVuY3Rpb25zOgogICAgRlRfTmV3X1NpemUsIEZUX0FjdGl2YXRlX1NpemUsIEZUX0RvbmVfU2l6ZS4KCiAgLSBGaXhlZCBhICByZWFsbG9jYXRpb24gYnVnIHRoYXQgIGdlbmVyYXRlZCBhIGRhbmdsaW5nICBwb2ludGVyIChhbmQKICAgIHBvc3NpYmx5ICAgIG1lbW9yeSAgICBsZWFrcykgICAgd2l0aCAgICBQb3N0c2NyaXB0ICAgIGZvbnRzICAgIChpbgogICAgc3JjL3BzYXV4L3Bzb2Jqcy5jKS4KCiAgLSBNYW55IGZpeGVzIGZvciAxNi1iaXQgY29ycmVjdG5lc3MuCgogIC0gUmVtb3ZlZCBtYW55IHBlZGFudGljIGNvbXBpbGVyIHdhcm5pbmdzIGZyb20gdGhlIHNvdXJjZXMuCgogIC0gQWRkZWQgYW4gQW1pZ2EgYnVpbGQgZGlyZWN0b3J5IGluICJidWlsZHMvYW1pZ2EiLgoKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCkxBVEVTVCBDSEFOR0VTIEJFVFdFRU4gMi4wLjQgYW5kIDIuMC4zCgogIC0gRml4ZWQgYSByYXRoZXIgYW5ub3lpbmcgYnVnIHRoYXQgd2FzIGludHJvZHVjZWQgaW4gMi4wLjMuICBOYW1lbHksCiAgICB0aGUgZm9udCAgdHJhbnNmb3JtYXRpb24gc2V0IHRocm91Z2ggIEZUX1NldF9UcmFuc2Zvcm0gd2FzIGFwcGxpZWQKICAgIHR3aWNlIHRvIGF1dG8taGludGVkIGdseXBocywgcmVzdWx0aW5nIGluIGluY29ycmVjdGx5IHJvdGF0ZWQgdGV4dAogICAgb3V0cHV0LgoKICAtIEZpeGVkIF9tYW55XyAgY29tcGlsZXIgd2FybmluZ3MuICAgRlQyIHNob3VsZCBub3cgIGNvbXBpbGUgY2xlYW5seQogICAgd2l0aCBWaXN1YWwgIEMrKydzIG1vc3QgcGVkYW50aWMgd2FybmluZyBsZXZlbCAgKC9XNCkuICBJdCBhbHJlYWR5CiAgICBjb21waWxlZCBmaW5lIHdpdGggR0NDIGFuZCBhIGZldyBvdGhlciBjb21waWxlcnMuCgogIC0gRml4ZWQgYSBidWcgIHRoYXQgcHJldmVudGVkIHRoZSBsaW5lYXIgYWR2YW5jZSAgd2lkdGggb2YgY29tcG9zaXRlCiAgICBUcnVlVHlwZSBnbHlwaHMgdG8gYmUgY29ycmVjdGx5IHJldHVybmVkLgoKICAtIEZpeGVkICAgIHRoZSAgICBWaXN1YWwgICAgQysrICAgIHByb2plY3QgICAgZmlsZXMgICAgbG9jYXRlZCAgICBpbgogICAgImJ1aWxkcy93aW4zMi92aXN1YWxjIiAocHJldmlvdXMgdmVyc2lvbnMgIHVzZWQgb2xkZXIgbmFtZXMgb2YgdGhlCiAgICBsaWJyYXJ5KS4KCiAgLSBNYW55ICAzMi1iaXQgY29uc3RhbnRzICBoYXZlIGFuICAiTCIgYXBwZW5kZWQgIHRvIHRoZWlyICB2YWx1ZSwgaW4KICAgIG9yZGVyIHRvIGltcHJvdmUgdGhlIDE2LWJpdG5lc3MgIG9mIHRoZSBjb2RlLiAgU29tZW9uZSBpcyBhY3R1YWxseQogICAgdHJ5aW5nIHRvIHVzZSBGVDIgb24gYW4gQXRhcmkgU1QgbWFjaGluZSEKCiAgLSBVcGRhdGVkICB0aGUgICJidWlsZHMvZGV0ZWN0Lm1rIiBmaWxlICBpbiAgb3JkZXIgdG8gIGF1dG9tYXRpY2FsbHkKICAgIGJ1aWxkIEZUMiAgb24gQUlYIHN5c3RlbXMuICAgQUlYIHVzZXMgIi91c3Ivc2Jpbi9pbml0IiAgaW5zdGVhZCBvZgogICAgIi9zYmluL2luaXQiIGFuZCB3YXNuJ3QgcHJldmlvdXNseSAgZGV0ZWN0ZWQgYXMgYSBVbml4IHBsYXRmb3JtIGJ5CiAgICB0aGUgRnJlZVR5cGUgYnVpbGQgc3lzdGVtLgoKICAtIFVwZGF0ZWQgIHRoZSAgVW5peC1zcGVjaWZpYyAgcG9ydGlvbnMgIG9mIHRoZSAgYnVpbGQgIHN5c3RlbSAgKG5ldwogICAgbGlidG9vbCB2ZXJzaW9uLCBldGMuKS4KCiAgLSBUaGUgIFNGTlQga2VybmluZyAgbG9kYWVyIG5vdyAgZW5zdXJlcyAgdGhhdCB0aGUgIHRhYmxlIGlzICBzb3J0ZWQKICAgIChzaW5jZSBzb21lIHByb2JsZW0gZm9udHMgZG8gbm90IG1lZXQgdGhpcyByZXF1aXJlbWVudCkuCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCkxBVEVTVCBDSEFOR0VTIEJFVFdFRU4gMi4wLjMgYW5kIDIuMC4yCgogIEkuIENIQU5HRVMgVE8gVEhFIE1PRFVMRVMgLyBGT05UIERSSVZFUlMKCiAgICAtIFRIRSAgQVVUTy1ISU5URVIgSEFTICBCRUVOIFNMSUdIVExZICBJTVBST1ZFRCwgaW4gIG9yZGVyICB0byBmaXgKICAgICAgc2V2ZXJhbCBhbm5veWluZyBhcnRlZmFjdHMsIG1haW5seToKCiAgICAgICAgLSBCbHVlICB6b25lIGFsaWduZW1lbnQgb2YgIGhvcml6b250YWwgc3RlbXMgIHdhc24ndCBwZXJmb3JtZWQKICAgICAgICAgIGNvcnJlY3RseSwgcmVzdWx0aW5nIGluIGFydGVmYWN0cyAgbGlrZSB0aGUgImQiIGJlaW5nIHBsYWNlZAogICAgICAgICAgb25lIHBpeGVsIGJlbG93IHRoZSAiYiIgaW4gc29tZSBmb250cyBsaWtlIFRpbWUgTmV3IFJvbWFuLgoKICAgICAgICAtIE92ZXJzaG9vdCB0aHJlc2hvbGRpbmcgIHdhc24ndCBwZXJmb3JtZWQgY29ycmVjdGx5LCBjcmVhdGluZwogICAgICAgICAgdW5wbGVhc2FudCBhcnRlZmFjdHMgYXQgbGFyZ2UgY2hhcmFjdGVyIHBpeGVsIHNpemVzLgoKICAgICAgICAtIENvbXBvc2l0ZSBnbHlwaCBsb2FkaW5nIGhhcyAgYmVlbiBzaW1wbGlmaWVkLiAgVGhpcyBnZXRzIHJpZAogICAgICAgICAgb2YgIHZhcmlvdXMgYXJ0ZWZhY3RzICB3aGVyZSB0aGUgIGNvbXBvbmVudHMgb2YgIGEgY29tcG9zaXRlCiAgICAgICAgICBnbHlwaHMgd2VyZSBub3QgY29ycmVjdGx5IHNwYWNlZC4KCiAgICAgIFRoZXNlIGFyZSAgdGhlIGxhc3QgY2hhbmdlcyB0byB0aGUgIGN1cnJlbnQgYXV0by1oaW50aW5nIG1vZHVsZS4KICAgICAgQSBuZXcgIGhpbnRpbmcgc3ViLXN5c3RlbSBpcyBjdXJyZW50bHkgIGluIHRoZSB3b3JrICBpbiBvcmRlciB0bwogICAgICBzdXBwb3J0IG5hdGl2ZSBoaW50cyAgaW4gVHlwZSAxIC8gQ0ZGIC8gIE9wZW5UeXBlIGZvbnRzLCBhcyB3ZWxsCiAgICAgIGFzIGdsb2JhbGx5IGltcHJvdmUgcmVuZGVyaW5nLgoKICAgIC0gVGhlICBQQ0YgIGRyaXZlciBoYXMgIGJlZW4gIGZpeGVkLiAgIEl0ICByZXBvcnRlZCBpbnZhbGlkICBnbHlwaAogICAgICBkaW1lbnNpb25zIGZvciB0aGUgZm9udHMgYXZhaWxhYmxlIG9uIFNvbGFyaXMuCgogICAgLSBUaGUgVHlwZSAgMSwgQ0lEIGFuZCBDRkYgIGRyaXZlcnMgaGF2ZSBiZWVuIG1vZGlmaWVkICB0byBmaXggdGhlCiAgICAgIGNvbXB1dGF0aW9uIG9mIHRoZSBFTSBzaXplLgoKICAgIC0gVGhlIFR5cGUgMSAgZHJpdmVyIGhhcyBiZWVuIGZpeGVkIHRvIGF2b2lkICBhIGRhbmdlcm91cyBidWcgdGhhdAogICAgICBjcmFzaGVkIHRoZSBsaWJyYXJ5IHdpdGggbm9uLWNvbmZvcm1pbmcgZm9udHMgKGkuZS4gb25lcyB0aGF0IGRvCiAgICAgIG5vdCBwbGFjZSB0aGUgLm5vdGRlZiBnbHlwaCBhdCBwb3NpdGlvbiAwKS4KCiAgICAtIFRoZSBUcnVlVHlwZSAgZHJpdmVyIGhhZCBhICByYXRoZXIgc3VidGxlIGJ1ZyAgKGRhbmdsaW5nIHBvaW50ZXIKICAgICAgd2hlbiBsb2FkaW5nICBjb21wb3NpdGUgZ2x5cGhzKSB0aGF0IGNvdWxkIGNyYXNoICB0aGUgbGlicmFyeSBpbgogICAgICByYXJlIG9jY2FzaW9ucyEKCgogIElJLiBISUdILUxFVkVMIEFQSSBDSEFOR0VTCgogICAgLSBUaGUgZXJyb3IgIGNvZGUgZW51bWVyYXRpb24gdmFsdWVzIGhhdmUgYmVlbiAgY2hhbmdlZC4gIEFuIGVycm9yCiAgICAgIHZhbHVlICBpcyBkZWNvbXBvc2VkICBpbiAgYSAgZ2VuZXJpYyBlcnJvciAgY29kZSwgIGFuZCBhICBtb2R1bGUKICAgICAgbnVtYmVyLiAgc2VlIDxmcmVldHlwZS9mdGVycm9ycy5oPiBmb3IgZGV0YWlscy4KCiAgICAtIEEgICBuZXcgIHB1YmxpYyAgIGhlYWRlciAgIGZpbGUgIGhhcyAgIGJlZW4gIGludHJvZHVjZWQsICAgbmFtZWQKICAgICAgRlRfVFJJR09OT01FVFJZX0ggICAgIChpbmNsdWRlL2ZyZWV0eXBlL2Z0dHJpZy5oKSwgICAgIHByb3ZpZGluZwogICAgICB0cmlnb25vbWV0cmljIGZ1bmN0aW9ucyB0byAgY29tcHV0ZSBzaW5lcywgY29zaW5lcywgYXJjdGFuZ2VudHMsCiAgICAgIGV0Yy4gd2l0aCAxNi4xNiBmaXhlZCBwcmVjaXNpb24uICBUaGUgaW1wbGVtZW50YXRpb24gaXMgYmFzZWQgb24KICAgICAgdGhlIENPUkRJQyAgYWxnb3JpdGhtIGFuZCBpcyB2ZXJ5IGZhc3QgIHdoaWxlIGJlaW5nIHN1ZmZpY2llbnRseQogICAgICBhY2N1cmF0ZS4KCgogIElJSS4gSU5URVJOQUxTCgogICAgLSBBZGRlZCAgQmVPUy1zcGVjaWZpYyBmaWxlcyAgaW4gdGhlICBvbGQgYnVpbGQgIHN1Yi1zeXN0ZW0uICBOb3RlCiAgICAgIHRoYXQgbm8gY2hhbmdlcyB3ZXJlIHJlcXVpcmVkIHRvIGNvbXBpbGUgdGhlIGxpYnJhcnkgd2l0aCBKYW0uCgogICAgLSBUaGUgIGNvbmZpZ3VyYXRpb24gIGlzIG5vdyAgY2FwYWJsZSAgb2YgYXV0b21hdGljYWxseSAgZGV0ZWN0aW5nCiAgICAgIDY0LWJpdCBpbnRlZ2VycyAgb24gYSBzZXQgIG9mIHByZWRlZmluZWQgY29tcGlsZXJzICAoR0NDLCBWaXN1YWwKICAgICAgQysrLCBCb3JsYW5kIEMrKykgYW5kIHdpbGwgdXNlIHRoZW0gYnkgZGVmYXVsdC4gIFRoaXMgcHJvdmlkZXMgYQogICAgICBzbWFsbCBwZXJmb3JtYW5jZSBib29zdC4KCiAgICAtIEEgIHNtYWxsIG1lbW9yeSBsZWFrICB0aGF0IGhhcHBlbmVkICB3aGVuIG9wZW5pbmcgIDAtc2l6ZWQgZmlsZXMKICAgICAgKGR1aCEpICBoYXZlIGJlZW4gZml4ZWQuCgogICAgLSBGaXhlZCBiZXppZXIgIHN0YWNrIGRlcHRoICBidWcgaW4gdGhlICByb3V0aW5lcyBwcm92aWRlZCAgYnkgdGhlCiAgICAgIEZUX0JCT1hfSCAgaGVhZGVyICAgZmlsZS4gICBBbHNvICBmaXhlZCAgc2ltaWxhciAgIGJ1Z3MgIGluICB0aGUKICAgICAgcmFzdGVyaXplcnMuCgogICAgLSBUaGUgb3V0bGluZSBib3VuZGluZyAgYm94IGNvZGUgaGFzIGJlZW4gcmV3cml0dGVuICB0byB1c2UgZGlyZWN0CiAgICAgIGNvbXB1dGF0aW9ucywgIGluc3RlYWQgb2YgIGJlemllciBzdWItZGl2aXNpb24sICB0byAgY29tcHV0ZSB0aGUKICAgICAgZXhhY3QgYm91bmRpbmcgYm94IG9mIGdseXBocy4gICBUaGlzIGlzIHNsaWdodGx5IHNsb3dlciBidXQgbW9yZQogICAgICBhY2N1cmF0ZS4KCiAgICAtIFRoZSBidWlsZCBzeXN0ZW0gaGFzIGJlZW4gIGltcHJvdmVkIGFuZCBmaXhlZCwgbWFpbmx5IHRvIHN1cHBvcnQKICAgICAgIm1ha2UiICBvbiBXaW5kb3dzICAyMDAwICBjb3JyZWN0bHksIGF2b2lkICBwcm9ibGVtcyB3aXRoICAibWFrZQogICAgICBkaXN0Y2xlYW4iIG9uIG5vbiBVbml4IHN5c3RlbXMsIGV0Yy4KCiAgICAtIEhleGFkZWNpbWFsICBjb25zdGFudHMgIGhhdmUgYmVlbiAgc3VmZml4ZWQgIHdpdGggICJVIiB0byAgYXZvaWQKICAgICAgcHJvYmxlbXMgd2l0aCBjZXJ0YWluIGNvbXBpbGVycyBvbiA2NC1iaXQgcGxhdGZvcm1zLgoKICAgIC0gQSBuZXcgZGlyZWN0b3J5IG5hbWVkICJzcmMvdG9vbHMiIGhhcyBiZWVuIGNyZWF0ZWQuICBJdCBjb250YWlucwogICAgICBQeXRob24gc2NyaXB0cyBhbmQgc2ltcGxlIHVuaXQgdGVzdCBwcm9ncmFtcyB1c2VkIHRvIGRldmVsb3AgdGhlCiAgICAgIGxpYnJhcnkuCgogICAgLSBUaGUgRG9jTWFrZXIgdG9vbCBoYXMgYmVlbiAgbW92ZWQgZnJvbSAiZG9jcyIgdG8gInNyYy90b29scyIgYW5kCiAgICAgIGhhcyBiZWVuIHVwZGF0ZWQgd2l0aCB0aGUgZm9sbG93aW5nOgoKICAgICAgICAgLSBOb3cgYWNjZXB0cyB0aGUgIi0tdGl0bGU9WFhYWCIgb3IgIi10IFhYWFgiIG9wdGlvbiBmcm9tIHRoZQogICAgICAgICAgIGNvbW1hbmQgbGluZSB0byBzZXQgdGhlIHByb2plY3QncyBuYW1lIGluIHRoZSBnZW5lcmF0ZWQgQVBJCiAgICAgICAgICAgcmVmZXJlbmNlLgoKICAgICAgICAgLSBOb3cgYWNjZXB0cyB0aGUgIi0tb3V0cHV0PURJUiIgIG9yICItbyBESVIiIG9wdGlvbiBmcm9tIHRoZQogICAgICAgICAgIGNvbW1hbmQgbGluZSB0byBzZXQgIHRoZSBvdXRwdXQgZGlyZWN0b3J5IGZvciBhbGwgZ2VuZXJhdGVkCiAgICAgICAgICAgSFRNTCBmaWxlcy4KCiAgICAgICAgIC0gTm93IGFjY2VwdHMgdGhlICItLXByZWZpeD1YWFhYIiBvciAiLXAgWFhYIiBvcHRpb24gZnJvbSB0aGUKICAgICAgICAgICBjb21tYW5kICBsaW5lICB0byAgc2V0ICB0aGUgIGZpbGUgcHJlZml4ICB0byAgdXNlICBmb3IgIGFsbAogICAgICAgICAgIGdlbmVyYXRlZCBIVE1MIGZpbGVzLgoKICAgICAgICAgLSBOb3cgZ2VuZXJhdGVzIHRoZSBjdXJyZW50ICB0aW1lL2RhdGEgb24gZWFjaCBnZW5lcmF0ZWQgcGFnZQogICAgICAgICAgIGluIG9yZGVyIHRvIGRpc3Rpbmd1aXNoIGJldHdlZW4gdmVyc2lvbnMuCgogICAgICBEb2NNYWtlciAgY2FuIGJlICB1c2VkIHdpdGggIG90aGVyICBwcm9qZWN0cyBub3csICBub3Qgb25seSAgRlQyCiAgICAgIChlLmcuIE1MaWIsIEZUTGF5b3V0LCBldGMuKS4KCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpMQVRFU1QgQ0hBTkdFUyBCRVRXRUVOIDIuMC4yIGFuZCAyLjAuMQoKICBJLiBDSEFOR0VTIFRPIFRIRSBNT0RVTEVTIC8gRk9OVCBEUklWRVJTCgogICAgLSBUSEUgVFJVRVRZUEUgQllURUNPREUgSU5URVJQUkVURVIgSVMgTk9XIFRVUk5FRCBPRkYsIGluIG9yZGVyIHRvCiAgICAgIGF2b2lkIGxlZ2FsIHByb2JsZW1zICB3aXRoIHRoZSBBcHBsZSBwYXRlbnRzLiAgSXQgIHNlZW1zIHRoYXQgd2UKICAgICAgbWlzdGFrZW5seSAgdHVybmVkIHRoaXMgb3B0aW9uICBvbiBpbiAgcHJldmlvdXMgcmVsZWFzZXMgIG9mIHRoZQogICAgICBidWlsZC4KCiAgICAgIE5vdGUgdGhhdCBpZiAgeW91IHdhbnQgdG8gdXNlIHRoZSAgYnl0ZWNvZGUgaW50ZXJwcmV0ZXIgaW4gb3JkZXIKICAgICAgdG8gZ2V0IGhpZ2gtcXVhbGl0eSBUcnVlVHlwZSAgcmVuZGVyaW5nLCB5b3Ugd2lsbCBuZWVkIHRvIHRvZ2dsZQogICAgICBieSAgICAgICAgaGFuZCAgICAgICAgdGhlICAgICAgICBkZWZpbml0aW9uICAgICAgICBvZiAgICAgICAgdGhlCiAgICAgIFRUX0NPTkZJR19PUFRJT05fQllURUNPREVfSU5URVJQUkVURVIgICBtYWNybyAgICBpbiAgIHRoZSAgIGZpbGUKICAgICAgImluY2x1ZGUvZnJlZXR5cGUvY29uZmlnL2Z0b3B0aW9uLmgiLgoKICAgIC0gVGhlIENGRiBkcml2ZXIgaGFzIGJlZW4gaW1wcm92ZWQgYnkgVG9tIEthY3ZpbnNreSBhbmQgU2FuZGVyIHZhbgogICAgICBkZXIgV2FsOgoKICAgICAgKiBTdXBwb3J0IGZvciAic2VhYyIgZW11bGF0aW9uLgogICAgICAqIFN1cHBvcnQgZm9yICJkb3RzZWN0aW9uIi4KICAgICAgKiBTdXBwb3J0IGZvciByZXRyaWV2aW5nIGdseXBoIG5hbWVzIHRocm91Z2gKICAgICAgICAiRlRfR2V0X0dseXBoX05hbWUiLgoKICAgICAgVGhlIGZpcnN0IHR3byBpdGVtcyBhcmUgbmVjZXNzYXJ5IHRvIGNvcnJlY3RseSBhIGxhcmdlIG51bWJlciBvZgogICAgICBUeXBlIDEgZm9udHMgY29udmVydGVkIHRvIHRoZSBDRkYgZm9ybWF0cyBieSBBZG9iZSBBY3JvYmF0LgoKICAgIC0gVGhlIFR5cGUgMSBkcml2ZXIgd2FzIGFsc28gaW1wcm92ZWQgYnkgVG9tICYgb3RoZXJzOgoKICAgICAgKiBCZXR0ZXIgRU0gc2l6ZSBjb21wdXRhdGlvbi4KICAgICAgKiBCZXR0ZXIgc3VwcG9ydCBmb3Igc3ludGhldGljICh0cmFuc2Zvcm1lZCkgZm9udHMuCiAgICAgICogVGhlICBUeXBlIDEgIGRyaXZlciByZXR1cm5zICB0aGUgY2hhcnN0cmluZ3MgIGNvcnJlc3BvbmRpbmcgdG8KICAgICAgICBlYWNoIGdseXBoIGluIHRoZSAgImdseXBoLT5jb250cm9sX2RhdGEiIGZpZWxkIGFmdGVyIGEgY2FsbCB0bwogICAgICAgICJGVF9Mb2FkX0dseXBoIiAodGhhbmtzIEhhIFNoYW8pLgoKICAgIC0gVmFyaW91cyBvdGhlciBidWdmaXhlcywgaW5jbHVkaW5nIHRoZSBmb2xsb3dpbmc6CgogICAgICAqIEZpeGVkIGEgbmFzdHkgbWVtb3J5IGxlYWsgaW4gdGhlIFR5cGUgMSBkcml2ZXIuCiAgICAgICogVGhlIGF1dG9oaW50ZXIgIGFuZCB0aGUgcGNmICBkcml2ZXIgdXNlZCBzdGF0aWMgIHdyaXRhYmxlIGRhdGEKICAgICAgICB3aGVuIHRoZXkgc2hvdWxkbid0LgogICAgICAqIE1hbnkgY2FzdHMgd2VyZSBhZGRlZCB0byAgbWFrZSB0aGUgY29kZSBtb3JlIDY0LWJpdHMgc2FmZS4gIEl0CiAgICAgICAgYWxzbyBub3cgY29tcGlsZXMgb24gV2luZG93cyBYUCA2NC1iaXRzIHdpdGhvdXQgd2FybmluZ3MuCiAgICAgICogU29tZSBpbmNvcnJlY3Qgd3JpdGFibGUgc3RhdGljcyB3ZXJlIHJlbW92ZWQgaW4gdGhlICJhdXRvaGludCIKICAgICAgICBhbmQgInBjZiIgZHJpdmVycy4gIEZyZWVUeXBlIDIgbm93IGNvbXBpbGVzIG9uIEVwb2MgYWdhaW4uCgoKICBJSS4gQ0hBTkdFUyBUTyBUSEUgSElHSC1MRVZFTCBBUEkKCiAgICAtIFRoZSBsaWJyYXJ5IGhlYWRlciBmaWxlcyBpbmNsdXNpb24gc2NoZW1lIGhhcyBiZWVuIGNoYW5nZWQuICBUaGUKICAgICAgb2xkIHNjaGVtZSBsb29rZWQgbGlrZToKCiAgICAgICAgI2luY2x1ZGUgPGZyZWV0eXBlL2ZyZWV0eXBlLmg+CiAgICAgICAgI2luY2x1ZGUgPGZyZWV0eXBlL2Z0Z2x5cGguaD4KICAgICAgICAjaW5jbHVkZSA8ZnJlZXR5cGUvZnRjYWNoZS5oPgogICAgICAgICNpbmNsdWRlIDxmcmVldHlwZS9jYWNoZS9mdGltYWdlLmg+CgogICAgICBOb3cgeW91IHNob3VsZCB1c2U6CgogICAgICAgICNpbmNsdWRlIDxmdDJidWlsZC5oPgogICAgICAgICNpbmNsdWRlIEZUX0ZSRUVUWVBFX0gKICAgICAgICAjaW5jbHVkZSBGVF9HTFlQSF9ICiAgICAgICAgI2luY2x1ZGUgRlRfQ0FDSEVfSAogICAgICAgICNpbmNsdWRlIEZUX0NBQ0hFX0lNQUdFX0gKCiAgICAgIE5PVEUgVEhBVCAgVEhFIE9MRCAgSU5DTFVTSU9OIFNDSEVNRSBXSUxMICBTVElMTCBXT1JLICBXSVRIIFRISVMKICAgICAgUkVMRUFTRS4gIEhPV0VWRVIsIFdFICBETyBOT1QgR1VBUkFOVEVFIFRIQVQgVEhJUyAgV0lMTCBTVElMTCBCRQogICAgICBUUlVFIElOIFRIRSBORVhUIE9ORSAoQS5LLkEuIEZSRUVUWVBFIDIuMSkuCgogICAgICBUaGUgIGZpbGUgPGZ0MmJ1aWxkLmg+ICBpcyB1c2VkICB0byBkZWZpbmUgIHRoZSAgaGVhZGVyIGZpbGVuYW1lCiAgICAgIG1hY3Jvcy4gIFRoZSBjb21wbGV0ZSBhbmQgIGNvbW1lbnRlZCBsaXN0IG9mIG1hY3JvcyBpcyBhdmFpbGFibGUKICAgICAgaW4gdGhlIEFQSSByZWZlcmVuY2UgdW5kZXIgdGhlIHNlY3Rpb24gbmFtZSAiSGVhZGVyIEZpbGUgTWFjcm9zIgogICAgICBpbiBDaGFwdGVyIEkuCgogICAgICBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIHNlY3Rpb24gSSBvZiB0aGUgZm9sbG93aW5nIGRvY3VtZW50OgoKICAgICAgICBodHRwOi8vd3d3LmZyZWV0eXBlLm9yZy8KICAgICAgICAgIGZyZWV0eXBlMi9kb2NzL3R1dG9yaWFsL3N0ZXAxLmh0bWwKCiAgICAgIG9yCgogICAgICAgIGh0dHA6Ly9mcmVldHlwZS5zb3VyY2Vmb3JnZS5uZXQvCiAgICAgICAgICBmcmVldHlwZTIvZG9jcy90dXRvcmlhbC9zdGVwMS5odG1sCgogICAgLSBNYW55LCBtYW55IGNvbW1lbnRzIGhhdmUgYmVlbiBhZGRlZCB0byB0aGUgcHVibGljIHNvdXJjZSBmaWxlIGluCiAgICAgIG9yZGVyIHRvICBhdXRvbWF0aWNhbGx5IGdlbmVyYXRlICB0aGUgQVBJIFJlZmVyZW5jZSAgdGhyb3VnaCB0aGUKICAgICAgImRvY21ha2VyLnB5IiBQeXRob24gc2NyaXB0LgoKICAgICAgVGhlIGxhdHRlciBoYXMgYmVlbiB1cGRhdGVkICB0byBzdXBwb3J0IHRoZSBncm91cGluZyBvZiBzZWN0aW9ucwogICAgICBpbiBjaGFwdGVycyBhbmQgYmV0dGVyIGluZGV4IHNvcnQuICBTZWU6CgogICAgICAgIGh0dHA6Ly93d3cuZnJlZXR5cGUub3JnL2ZyZWV0eXBlMi9kb2NzL3JlZmVyZW5jZS9mdDItdG9jLmh0bWwKCgogIElJSS4gQ0hBTkdFUyBUTyBUSEUgQlVJTEQgUFJPQ0VTUwoKICAgIC0gSWYgeW91ICBhcmUgbm90ICBidWlsZGluZyBGcmVlVHlwZSAyICB3aXRoIGl0cyBvd24gIGJ1aWxkIHN5c3RlbQogICAgICAoYnV0IHdpdGggeW91ciBvd24gTWFrZWZpbGVzIG9yIHByb2plY3QgZmlsZXMpLCB5b3Ugd2lsbCBuZWVkIHRvCiAgICAgIGJlICBhd2FyZSB0aGF0ICB0aGUgIGJ1aWxkICBwcm9jZXNzIGhhcyAgY2hhbmdlZCAgYSBsaXR0bGUgIGJpdC4KCiAgICAgIFlvdSBkb24ndCAgbmVlZCB0byBwdXQgdGhlICAic3JjIiBkaXJlY3RvcnkgaW4gIHRoZSBpbmNsdWRlIHBhdGgKICAgICAgd2hlbiAgY29tcGlsaW5nICBhbnkgRlQyICBjb21wb25lbnQuICAgSW5zdGVhZCwgIHNpbXBseSBwdXQgIHRoZQogICAgICBjb21wb25lbnQncyBkaXJlY3RvcnkgaW4gdGhlIGN1cnJlbnQgaW5jbHVkZSBwYXRoLgoKICAgICAgU28sIGlmIHlvdSB3ZXJlIGRvaW5nIHNvbWV0aGluZyBsaWtlOgoKICAgICAgICBjYyAtYyAtSWluY2x1ZGUgLUlzcmMgc3JjL2Jhc2UvZnRiYXNlLmMKCiAgICAgIGNoYW5nZSB0aGUgbGluZSB0bzoKCiAgICAgICAgY2MgLWMgLUlpbmNsdWRlIC1Jc3JjL2Jhc2Ugc3JjL2Jhc2UvZnRiYXNlLmMKCiAgICAgIElmIHlvdSB3ZXJlIGRvaW5nIHNvbWV0aGluZyBsaWtlOgoKICAgICAgICBjZCBzcmMvYmFzZQogICAgICAgIGNjIC1jIC1JLi4vLi4vaW5jbHVkZSAtSS4uIGZ0YmFzZS5jCgogICAgICBjaGFuZ2UgaXQgdG86CgogICAgICAgIGNkIHNyYy9iYXNlCiAgICAgICAgY2MgLWMgLUkuLi8uLi9pbmNsdWRlIGZ0YmFzZS5jCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKTEFURVNUIENIQU5HRVMgQkVUV0VFTiAyLjAuMSBhbmQgMi4wCgogIDIuMC4xIGludHJvZHVjZXMgYSBmZXcgY2hhbmdlczoKCiAgICAtIEZpeGVkIG1hbnkgYnVncyByZWxhdGVkIHRvICB0aGUgc3VwcG9ydCBvZiBDRkYgLyBPcGVuVHlwZSBmb250cy4KICAgICAgVGhlc2UgIGZvcm1hdHMgYXJlICBub3cgbXVjaCAgYmV0dGVyIHN1cHBvcnRlZCAgdGhvdWdoICB0aGVyZSBpcwogICAgICBzdGlsbCB3b3JrIHBsYW5uZWQgdG8gIGRlYWwgd2l0aCBjaGFyc2V0IHRhYmxlcyBhbmQgUERGLWVtYmVkZGVkCiAgICAgIENGRiBmaWxlcyB0aGF0IHVzZSB0aGUgb2xkICJzZWFjIiBjb21tYW5kLgoKICAgIC0gVGhlICBsaWJyYXJ5IGNvdWxkIG5vdCAgYmUgY29tcGlsZWQgIGluIGRlYnVnICBtb2RlIHdpdGggIGEgdmVyeQogICAgICBzbWFsbCAgbnVtYmVyICAgb2YgIEMgIGNvbXBpbGVycyAgIHdob3NlICBwcmUtcHJvY2Vzc29ycyAgZGlkbid0CiAgICAgIGltcGxlbWVudCB0aGUgIiMjIiAgZGlyZWN0aXZlIGNvcnJlY3RseSAoaS5lLiBwZXIgc2UgIHRoZSBBTlNJIEMKICAgICAgc3BlY2lmaWNhdGlvbiEpICBBbiBlbGVnYW50IGZpeCB3YXMgZm91bmQuCgogICAgLSBBZGRlZCAgc3VwcG9ydCBmb3IgIHRoZSAgZnJlZSBCb3JsYW5kICBjb21tYW5kLWxpbmUgQysrICBCdWlsZGVyCiAgICAgIGNvbXBpbGVyLiAgIFVzZSAibWFrZSAgc2V0dXAgYmNjMzIiLiAgIEFsc28gZml4ZWQgIGEgIGZldyBzb3VyY2UKICAgICAgbGluZXMgdGhhdCBnZW5lcmF0ZWQgbmV3IHdhcm5pbmdzIHdpdGggQkNDMzIuCgogICAgLSBGaXhlZCBhIGJ1ZyBpbiBGVF9PdXRsaW5lX0dldF9CQm94IHdoZW4gY29tcHV0aW5nIHRoZSBleHRyZW1hIG9mCiAgICAgIGEgY29uaWMgQmV6aWVyIGFyYy4KCiAgICAtIFVwZGF0ZWQgdGhlIElOU1RBTEwgZmlsZSB0byBhZGQgSURFIGNvbXBpbGF0aW9uLgoKICAgIC0gT3RoZXIgIG1pbm9yIGJ1ZyAgZml4ZXMsICBmcm9tICBpbnZhbGlkIFR5cGUgIDEgIHN0eWxlIGZsYWdzICB0bwogICAgICBjb3JyZWN0ICAgc3VwcG9ydCAgIG9mICBzeW50aGV0aWMgICAob2JsaXF1ZWQpICAgZm9udHMgIGluICAgdGhlCiAgICAgIGF1dG8taGludGVyLCBiZXR0ZXIgc3VwcG9ydCBmb3IgZW1iZWRkZWQgYml0bWFwcyBpbiBhIFNGTlQgZm9udC4KCiAgICAtIEZpeGVkIHNvbWUgcHJvYmxlbXMgd2l0aCAiZnJlZXR5cGUtY29uZmlnIi4KCiAgRmluYWxseSwgdGhlICJzdGFuZGFyZCIgc2NoZW1lIGZvciBpbmNsdWRpbmcgRnJlZVR5cGUgaGVhZGVycyBpcyBub3cKICBncmFkdWFsbHkgY2hhbmdpbmcsICBidXQgdGhpcyB3aWxsICBiZSBleHBsYWluZWQgaW4gYSAgbGF0ZXIgcmVsZWFzZQogIChwcm9iYWJseSAyLjAuMikuCgogIEFuZCB2ZXJ5ICBzcGVjaWFsIHRoYW5rcyB0byBUb20gS2Fjdmluc2t5ICBhbmQgWUFNQU5PLVVDSEkgSGlkZXRvc2hpCiAgZm9yIHRoZWlyIGNvbnRyaWJ1dGlvbnMhCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKQ0hBTkdFUyBCRVRXRUVOIGJldGE4IGFuZCAyLjAKCiAgLSBDaGFuZ2VkICB0aGUgZGVmYXVsdCAgaW5zdGFsbGF0aW9uICBwYXRoIGZvciAgcHVibGljIGhlYWRlcnMgIGZyb20KICAgICJpbmNsdWRlL2ZyZWV0eXBlIiB0byAiaW5jbHVkZS9mcmVldHlwZTIiLgoKICAgIEFsc28gYWRkZWQgYSBuZXcgImZyZWV0eXBlLWNvbmZpZyIgdGhhdCBpcyBhdXRvbWF0aWNhbGx5IGdlbmVyYXRlZAogICAgYW5kIGluc3RhbGxlZCAgb24gVW5peCBhbmQgIEN5Z3dpbiBzeXN0ZW1zLiAgVGhlIHNjcmlwdCAgaXRzZWxmIGlzCiAgICB1c2VkIHRvIHJldHJpZXZlIHRoZSBjdXJyZW50ICBpbnN0YWxsIHBhdGgsIEMgY29tcGlsYXRpb24gZmxhZ3MgYXMKICAgIHdlbGwgYXMgbGlua2VyIGZsYWdzLgoKICAtIEZpeGVkIHNldmVyYWwgc21hbGwgYnVnczoKCiAgICAqIEluY29ycmVjdCBtYXggYWR2YW5jZSB3aWR0aCBmb3IgZml4ZWQtcGl0Y2ggVHlwZSAxIGZvbnRzLgogICAgKiBJbmNvcnJlY3QgZ2x5cGggbmFtZXMgZm9yIGNlcnRhaW4gVHJ1ZVR5cGUgZm9udHMuCiAgICAqIFRoZSAgZ2x5cGggYWR2YW5jZSAgd2FzIG5vdCAgY29waWVkIHdoZW4gIEZUX0dseXBoX1RvX0JpdG1hcCB3YXMKICAgICAgY2FsbGVkLgogICAgKiBUaGUgIGxpbmVhckhvcmlBZHZhbmNlICBhbmQgIGxpbmVyVmVydEFkdmFuY2UgIGZpZWxkcyAgd2VyZSAgbm90CiAgICAgIGNvcnJlY3RseSByZXR1cm5lZCBmb3IgZ2x5cGhzIHByb2Nlc3NlZCBieSB0aGUgYXV0by1oaW50ZXIuCiAgICAqICJ0eXBlMXoiICByZW5hbWVkIGJhY2sgdG8gICJ0eXBlMSI7IHRoZSAgb2xkICJ0eXBlMSIgIG1vZHVsZSBoYXMKICAgICAgYmVlbiByZW1vdmVkLgoKICAtIFJldmFtcGVkIHRoZSAgYnVpbGQgc3lzdGVtICB0byBtYWtlIGl0ICBhIGxvdCBtb3JlICBnZW5lcmljLiAgVGhpcwogICAgd2lsbCAgYWxsb3cgdXMgIHRvICByZS11c2UgIG5lYXJseSB1bi1tb2RpZmllZCAgaW4gIGxvdHMgb2YgIG90aGVyCiAgICBwcm9qZWN0cyAoaW5jbHVkaW5nIEZyZWVUeXBlIExheW91dCkuCgogIC0gQ2hhbmdlZCAiY2lkIiB0byB1c2UgInBzYXV4IiB0b28uCgogIC0gQWRkZWQgdGhlICBjYWNoZSBzdWItc3lzdGVtLiAgU2VlIDxmcmVldHlwZS9mdGNhY2hlLmg+ICBhcyB3ZWxsIGFzCiAgICB0aGUgc291cmNlcyAgaW4gInNyYy9jYWNoZSIuICBOb3RlICB0aGF0IGl0IGNvbXBpbGVzIGJ1dCAgaXMgc3RpbGwKICAgIHVudGVzdGVkIGZvciBub3cuCgogIC0gVXBkYXRlZCAiZG9jcy9kb2NtYWtlci5weSIsIGEgZHJhZnQgIEFQSSByZWZlcmVuY2UgaXMgYXZhaWxhYmxlIGF0CiAgICBodHRwOi8vd3d3LmZyZWV0eXBlLm9yZy9mdDJhcGkuaHRtbC4KCiAgLSBDaGFuZ2VkICJ0eXBlMSIgdG8gdXNlICJwc2F1eCIuCgogIC0gQ3JlYXRlZCBhICBuZXcgbW9kdWxlIG5hbWVkICAicHNhdXgiIHRvIGhvbGQgIHRoZSBUeXBlIDEgJiAgVHlwZSAyCiAgICBwYXJzaW5nIHJvdXRpbmVzLiAgSXQgc2hvdWxkIGJlICB1c2VkIGJ5ICJ0eXBlMSIsICJjaWQiLCBhbmQgImNmZiIKICAgIGluIHRoZSBmdXR1cmUuCgogIC0gRml4ZWQgYW4gaW1wb3J0YW50IGJ1ZyBpbiAiRlRfR2x5cGhfR2V0X0NCb3giLgoKICAtIEZpeGVkICBzb21lIGNvbXBpbGVyICB3YXJuaW5ncyAgdGhhdCBoYXBwZW5lZCAgc2luY2UgdGhlICBUcnVlVHlwZQogICAgYnl0ZWNvZGUgZGVjb2RlciB3YXMgZGVhY3RpdmF0ZWQgYnkgZGVmYXVsdC4KCiAgLSBGaXhlZCB0d28gbWVtb3J5IGxlYWtzOgoKICAgICogVGhlICAgIG1lbW9yeSAgIG1hbmFnZXIgICAoMTYgICAgYnl0ZXMpICAgaXNuJ3QgICAgcmVsZWFzZWQgICBpbgogICAgICBGVF9Eb25lX0ZyZWVUeXBlIQogICAgKiBVc2luZyBjdXN0b20gaW5wdXQgc3RyZWFtcywgdGhlICBjb3B5IG9mIHRoZSBvcmlnaW5hbCBzdHJlYW0gd2FzCiAgICAgIG5ldmVyIHJlbGVhc2VkLgoKICAtIEZpeGVkIHRoZSAgYXV0by1oaW50ZXIgYnkgcGVyZm9ybWluZyBhdXRvbWF0aWMgIGNvbXB1dGF0aW9uIG9mIHRoZQogICAgImZpbGxpbmcgZGlyZWN0aW9uIiBvZiBlYWNoIGdseXBoLiAgIFRoaXMgaXMgZG9uZSB0aHJvdWdoIGEgc2ltcGxlCiAgICBhbmQgIGZhc3QgYXBwcm94aW1hdGlvbiwgYW5kICBzZWVtcyB0byAgd29yayAocHJvYmxlbXMgIHNwb3R0ZWQgYnkKICAgIFdlcm5lciB0aG91Z2gpLiAgVGhlIEFycGhpYyBmb250cyBhcmUgYSBsb3QgbmljZXIgdGhvdWdoIHRoZXJlIGFyZQogICAgc3RpbGwgYSBsb3Qgb2YgdGhpbmdzIHRvIGRvIHRvIGhhbmRsZSBBc2lhbiBmb250cyBjb3JyZWN0bHkuCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKQkVUQS04IChSRUxFQVNFIENBTkRJREFURSkgQ0hBTkdFUwoKICAtIERlYWN0aXZhdGVkIHRoZSBUcnVlVHlwZSBieXRlY29kZSBpbnRlcnByZXRlciBieSBkZWZhdWx0LgoKICAtIERlYWN0aXZhdGVkIHRoZSAic3JjL3R5cGUxIiBmb250IGRyaXZlci4gIE5vdyAic3JjL3R5cGUxeiIgaXMgdXNlZAogICAgYnkgZGVmYXVsdC4KCiAgLSBVcGRhdGVzIHRvIHRoZSBidWlsZCBzeXN0ZW0uICBXZSBub3cgY29tcGlsZSB0aGUgbGlicmFyeSBjb3JyZWN0bHkKICAgIHVuZGVyICBVbml4ICBzeXN0ZW0gIHRocm91Z2ggICJjb25maWd1cmUiIHdoaWNoICBpcyAgYXV0b21hdGljYWxseQogICAgY2FsbGVkIG9uIHRoZSBmaXJzdCAibWFrZSIgaW52b2NhdGlvbi4KCiAgLSBBZGRlZCB0aGUgYXV0by1oaW50aW5nIG1vZHVsZSEgIEZpeGluZyBzb21lIGJ1Z3MgaGVyZSBhbmQgdGhlcmUuCgogIC0gRm91bmQgc29tZSBidWdzIGluIHRoZSAgY29tcG9zaXRlIGxvYWRlciAoc2VhYykgb2YgdGhlIFR5cGUxLWJhc2VkCiAgICBmb250IGRyaXZlcnMuCgogIC0gUmVuYW1lZCB0aGUgZGlyZWN0b3J5ICJmcmVldHlwZTIvY29uZmlnIiB0byAiZnJlZXR5cGUyL2J1aWxkcyIgYW5kCiAgICB1cGRhdGVkIGFsbCByZWxldmFudCBmaWxlcy4KCiAgLSBGb3VuZCBhIG1lbW9yeSBsZWFrIGluIHRoZSAidHlwZTEiIGRyaXZlci4KCiAgLSBJbmNvcnBvcmF0ZWQgVG9tJ3MgcGF0Y2hlcyB0byAgc3VwcG9ydCBmbGV4IG9wZXJhdG9ycyBjb3JyZWN0bHkgaW4KICAgIE9wZW5UeXBlL0NGRiBmb250cy4gIE5vdyBhbGwgSSBuZWVkIGlzIHRvIHN1cHBvcnQgcHVyZSBDRkYgYW5kIENFRgogICAgZm9udHMgdG8gYmUgZG9uZSB3aXRoIHRoaXMgZHJpdmVyIDotKQoKICAtIEFkZGVkIHRoZSAgV2luZG93cyBGTlQvRk9OIGRyaXZlciBpbiAic3JjL3dpbmZvbnRzIi4gICBGb3Igbm93LCBpdAogICAgYWx3YXlzICAic2ltdWxhdGVzIiAgIGEgIFVuaWNvZGUgIGNoYXJtYXAsICBzbyAgIGl0ICBzaG91bGRuJ3QgIGJlCiAgICBjb25zaWRlcmVkIGNvbXBsZXRlZCByaWdodCBub3cuCgogICAgSXQgIGlzIHRoZXJlICB0byBiZSAgbW9yZSBhICBwcm9vZiBvZiAgY29uY2VwdCB0aGFuICBhbnl0aGluZyBlbHNlCiAgICBhbnl3YXkuICBUaGUgZHJpdmVyIGlzIGEgc2luZ2xlICBDIHNvdXJjZSBmaWxlLCB0aGF0IGNvbXBpbGVzIHRvIDMKICAgIEtiIG9mIGNvZGUuCgogICAgSSdtICBzdGlsbCB3b3JraW5nIG9uICB0aGUgUENGL0JERiAgZHJpdmVycywgYnV0ICBJJ20gdG9vICBsYXp5IHRvCiAgICBmaW5pc2ggdGhlbSBub3cuCgogIC0gQ0hBTkdFUyBUTyBUSEUgSElHSC1MRVZFTCBBUEkKCiAgICAqIEZUX0dldF9LZXJuaW5nIGhhcyBhIG5ldyBwYXJhbWV0ZXIgdGhhdCBhbGxvd3MgeW91IHRvIHNlbGVjdCB0aGUKICAgICAgY29vcmRpbmF0ZXMgb2YgdGhlIGtlcm5pbmcgIHZlY3RvciAoZm9udCB1bml0cywgc2NhbGVkLCBzY2FsZWQgKwogICAgICBncmlkLWZpdHRlZCkuCiAgICAqIFRoZSAgb3V0bGluZSBmdW5jdGlvbnMgYXJlICBub3cgaW4gPGZyZWV0eXBlL2Z0b3V0bG4uaD4gIGFuZCBub3QKICAgICAgcGFydCBvZiA8ZnJlZXR5cGUvZnJlZXR5cGUuaD4gYW55bW9yZS4KICAgICogPGZyZWV0eXBlL2Z0bW9kdWxlLmg+ICAgIG5vdyAgICAgY29udGFpbnMgICAgZGVjbGFyYXRpb25zICAgIGZvcgogICAgICAgRlRfTmV3X0xpYnJhcnksIEZUX0RvbmVfTGlicmFyeSwgRlRfQWRkX0RlZmF1bHRfTW9kdWxlcy4KICAgICogVGhlIHNvLWNhbGxlZCBjb252ZW5pZW5jZSAgZnVuY3Rpb25zIGhhdmUgbW92ZWQgZnJvbSAiZnRvdXRsbi5jIgogICAgICB0byAgImZ0Z2x5cGguYyIsICBhbmQgIGFyZSAgdGh1cyBhdmFpbGFibGUgIHdpdGggIHRoaXMgIG9wdGlvbmFsCiAgICAgIGNvbXBvbmVudCAgICBvZiAgIHRoZSAgIGxpYnJhcnkuICAgICBUaGV5ICAgYXJlICAgIGRlY2xhcmVkICAgaW4KICAgICAgPGZyZWV0eXBlL2Z0Z2x5cGguaD4gbm93LgogICAgKiBBbnRpLWFsaWFzZWQgIHJlbmRlcmluZyBpcyBub3cgIHRoZSBkZWZhdWx0ICBmb3IgRlRfUmVuZGVyX0dseXBoCiAgICAgIChpLmUuIGNvcnJlc3BvbmRzIHRvIHJlbmRlcl9tb2RlID09IDAgPT0gZnRfcmVuZGVyX21vZGVfbm9ybWFsKS4KICAgICAgVG8gZ2VuZXJhdGUgYSBtb25vY2hyb21lIGJpdG1hcCwgdXNlIGZ0X3JlbmRlcl9tb2RlX21vbm8sIG9yIHRoZQogICAgICBGVF9MT0FEX01PTk9DSFJPTUUgICAgIGZsYWcgICAgaW4gICAgRlRfTG9hZF9HbHlwaC9GVF9Mb2FkX0NoYXIuCiAgICAgIEZUX0xPQURfQU5USV9BTElBUyBpcyBzdGlsbCBkZWZpbmVkLCBidXQgdmFsdWVzIHRvIDAuCiAgICAqIDxmcmVldHlwZS9mcmVldHlwZS5oPiAgbm93IGluY2x1ZGUgPGZyZWV0eXBlL2NvbmZpZy9mdGNvbmZpZy5oPiwKICAgICAgc29sdmluZyBhIGZldyBoZWFkYWNoZXMgOi0pCiAgICAqIFRoZSB0eXBlIEZUX0dseXBoU2xvdFJlYyBoYXMgbm93IGEgImxpYnJhcnkiIGZpZWxkLgoKICAtIENIQU5HRVMgVE8gVEhFICJmdGdseXBoLmgiIEFQSQoKICAgIFRoaXMgQVBJIGhhcyAgYmVlbiBzZXZlcmVseSBtb2RpZmllZCBpbiBvcmRlciAgdG8gbWFrZSBpdCBzaW1wbGVyLAogICAgY2xlYXJlciwgYW5kIG1vcmUgIGVmZmljaWVudC4gIEl0IGNlcnRhaW5seSBub3cgbG9va3MgIGxpa2UgYSByZWFsCiAgICAiZ2x5cGggZmFjdG9yeSIgIG9iamVjdCwgYW5kIGFsbG93cyBjbGllbnQgIGFwcGxpY2F0aW9ucyB0byBtYW5hZ2UKICAgIChpLmUuICB0cmFuc2Zvcm0sICBiYm94ICBhbmQgIHJlbmRlcikgZ2x5cGggIGltYWdlcyAgd2l0aG91dCAgZXZlcgogICAga25vd2luZyB0aGVpciBvcmlnaW5hbCBmb3JtYXQuCgogIC0gQWRkZWQgIHN1cHBvcnQgIGZvciBDSUQta2V5ZWQgIGZvbnRzICB0byAgdGhlICBDRkYgZHJpdmVyLiAgIE1heWJlCiAgICBzdXBwb3J0IGZvciBwdXJlIENGRiArIENFRiBmb250cyBzaG91bGQgY29tZSBpbj8KCiAgLSBDbGVhbmVkIHVwICBzb3VyY2UgY29kZSBpbiBvcmRlciAgdG8gYXZvaWQgdHdvICBmdW5jdGlvbnMgd2l0aCB0aGUKICAgIHNhbWUgbmFtZS4gIEFsc28gIGNoYW5nZWQgdGhlIG5hbWVzIG9mIHRoZSAgZmlsZXMgaW4gInR5cGUxeiIgZnJvbQogICAgInQxWFhYWCIgdG8gInoxWFhYWCIgaW4gb3JkZXIgdG8gYXZvaWQgYW55IGNvbmZsaWN0cy4KCiAgICAibWFrZSBtdWx0aSIgbm93IHdvcmtzIHdlbGwgOi0pCgogICAgQWxzbyByZW1vdmVkIHRoZSB1c2Ugb2YgImNpZGFmbSIgZm9yIG5vdywgZXZlbiBpZiB0aGUgc291cmNlIGZpbGVzCiAgICBhcmUgIHN0aWxsIHRoZXJlLiAgVGhpcyAgZnVuY3Rpb25hbGl0eSB3aWxsICBjZXJ0YWlubHkgIGdvIGludG8gIGEKICAgIHNwZWNpZmljIG1vZHVsZS4KCiAgLSBBRERFRCBTVVBQT1JUIEZPUiBUSEUgQVVUTy1ISU5URVIKCiAgICBJdCAgd29ya3MgOi0pIEkgIGhhdmUgYSAgZGVtbyBwcm9ncmFtICB3aGljaCBzaW1wbHkgIGlzIGEgIGNvcHkgb2YKICAgICJmdHZpZXciICAgICAgIHRoYXQgICAgICBkb2VzICAgICAgIGEgICAgICBgRlRfQWRkX01vZHVsZShsaWJyYXJ5LAogICAgJmF1dG9oaW50ZXJfbW9kdWxlX2NsYXNzKScgYWZ0ZXIgIGxpYnJhcnkgaW5pdGlhbGl6YXRpb24sIGFuZCBUeXBlCiAgICAxICYgT3BlblR5cGUvQ0ZGIGZvbnRzIGFyZSBub3cgaGludGVkLgoKICAgIENJRCAgZm9udHMgYXJlICBub3QgaGludGVkLCAgYXMgdGhleSAgaW5jbHVkZSBubyAgY2hhcm1hcCAgYW5kIHRoZQogICAgYXV0by1oaW50ZXIgZG9lc24ndCBpbmNsdWRlICAiZ2VuZXJpYyIgZ2xvYmFsIG1ldHJpY3MgY29tcHV0YXRpb25zCiAgICB5ZXQuCgogICAgTm93LCBJIG5lZWQgdG8gcmVsZWFzZSB0aGlzIHRoaW5nIHRvIHRoZSBGcmVlVHlwZSAyIHNvdXJjZS4KCiAgLSBDSEFOR0VTIFRPIFRIRSBSRU5ERVJFUiBNT0RVTEVTCgogICAgVGhlICBtb25vY2hyb21lICBhbmQgc21vb3RoICByZW5kZXJlcnMgIGFyZSAgbm93ICBpbiB0d28gIGRpc3RpbmN0CiAgICBkaXJlY3RvcmllcywgbmFtZWx5ICJzcmMvcmFzdGVyMSIgYW5kICJzcmMvc21vb3RoIi4gIE5vdGUgdGhhdCB0aGUKICAgIG9sZCAic3JjL3JlbmRlcmVyIiBpcyBub3cgZ29uZS4KCiAgICBJIGRpdGNoZWQgIHRoZSA1LWdyYXktbGV2ZWxzIHJlbmRlcmVycy4gIEJhc2ljYWxseSwgIGl0IGludm9sdmVkIGEKICAgIHNpbXBsZSAjZGVmaW5lIHRvZ2dsZSBpbiAnc3JjL3Jhc3RlcjEvZnRyYXN0ZXIuYycuCgogICAgRlRfUmVuZGVyX0dseXBoLCAgRlRfT3V0bGluZV9SZW5kZXIgICYgIEZUX091dGxpbmVfR2V0X0JpdG1hcCAgbm93CiAgICBzZWxlY3QgdGhlIGJlc3QgcmVuZGVyZXIgIGF2YWlsYWJsZSwgZGVwZW5kaW5nIG9uIHJlbmRlciBtb2RlLiAgSWYKICAgIHRoZSBjdXJyZW50IHJlbmRlcmVyIGZvciBhICBnaXZlbiBnbHlwaCBpbWFnZSBmb3JtYXQgaXNuJ3QgY2FwYWJsZQogICAgb2Ygc3VwcG9ydGluZyAgdGhlIHJlbmRlciBtb2RlLCBhbm90aGVyICBvbmUgd2lsbCBiZSAgZm91bmQgaW4gdGhlCiAgICBsaWJyYXJ5J3MgbGlzdC4gICBUaGlzIG1lYW5zIHRoYXQgY2xpZW50IGFwcGxpY2F0aW9ucyAgZG8gbm90IG5lZWQKICAgIHRvICBzd2l0Y2ggb3IgIHNldCAgdGhlICByZW5kZXJlcnMgdGhlbXNlbHZlcyAgKGFzICBpbiB0aGUgIGxhdGVzdAogICAgY2hhbmdlKSwgdGhleSdsbCBnZXQgd2hhdCB0aGV5IHdhbnQgYXV0b21hdGljYWxseS4gIEF0IGxhc3QuCgogICAgQ2hhbmdlZCB0aGUgZGVtbyBwcm9ncmFtcyBhY2NvcmRpbmdseS4KCiAgLSBNQUpPUiBJTlRFUk5BTCBSRURFU0lHTjoKCiAgICBBIGxvdCBvZiBpbnRlcm5hbCBtb2RpZmljYXRpb25zICBoYXZlIGJlZW4gcGVyZm9ybWVkIGxhdGVseSBvbiB0aGUKICAgIHNvdXJjZSBpbiBvcmRlciB0byBwcm92aWRlIHRoZSBmb2xsb3dpbmcgZW5oYW5jZW1lbnRzOgoKICAgICogTW9yZSBnZW5lcmljIG1vZHVsZSBzdXBwb3J0OgoKICAgICAgVGhlIEZUX01vZHVsZSAgdHlwZSBpcyAgbm93IGRlZmluZWQgdG8gIHJlcHJlc2VudCBhIGhhbmRsZSAgdG8gYQogICAgICBnaXZlbiAgbW9kdWxlLiAgIFRoZSAgZmlsZSAgPGZyZWV0eXBlL2Z0bW9kdWxlLmg+ICBjb250YWlucyAgdGhlCiAgICAgIEZUX01vZHVsZV9DbGFzcyBkZWZpbml0aW9uLCBhcyB3ZWxsIGFzIHRoZSBtb2R1bGUtbG9hZGluZyBwdWJsaWMKICAgICAgQVBJLgoKICAgICAgVGhlICBGVF9Ecml2ZXIgdHlwZSAgaXMgc3RpbGwgIGRlZmluZWQsIGFuZCAgc3RpbGwgIHJlcHJlc2VudHMgYQogICAgICBwb2ludGVyIHRvICBhIGZvbnQgZHJpdmVyLiAgTm90ZSB0aGF0ICBGVF9BZGRfRHJpdmVyIGlzIHJlcGxhY2VkCiAgICAgIGJ5IEZUX0FkZF9Nb2R1bGUsIEZUX0dldF9Ecml2ZXIgYnkgRlRfR2V0X01vZHVsZSwgZXRjLgoKICAgICogU3VwcG9ydCBmb3IgZ2VuZXJpYyBnbHlwaCBpbWFnZSB0eXBlczoKCiAgICAgIFRoZSBGVF9SZW5kZXJlciAgdHlwZSBpcyBhIHBvaW50ZXIgIHRvIGEgbW9kdWxlICB1c2VkIHRvIHBlcmZvcm0KICAgICAgdmFyaW91cyBvcGVyYXRpb25zIG9uIGdseXBoIGltYWdlLgoKICAgICAgRWFjaCByZW5kZXJlciBpcyAgY2FwYWJsZSBvZiBoYW5kbGluZyBpbWFnZXMgaW4gIGEgc2luZ2xlIGZvcm1hdAogICAgICAoZS5nLiBmdF9nbHlwaF9mb3JtYXRfb3V0bGluZSkuICBJdHMgZnVuY3Rpb25zIGFyZSB1c2VkIHRvOgoKICAgICAgLSB0cmFuc2Zvcm0gYW4gZ2x5cGggaW1hZ2UKICAgICAgLSByZW5kZXIgYSBnbHlwaCBpbWFnZSBpbnRvIGEgYml0bWFwCiAgICAgIC0gcmV0dXJuIHRoZSBjb250cm9sIGJveCAoZGltZW5zaW9ucykgb2YgYSBnaXZlbiBnbHlwaCBpbWFnZQoKICAgICAgVGhlIHNjYW4gY29udmVydGVycyAiZnRyYXN0ZXIuYyIgYW5kICJmdGdyYXlzLmMiIGhhdmUgYmVlbiBtb3ZlZAogICAgICB0byB0aGUgbmV3IGRpcmVjdG9yeSAic3JjL3JlbmRlcmVyIiwgYW5kIGFyZSB1c2VkIHRvIHByb3ZpZGUgdHdvCiAgICAgIGRlZmF1bHQgcmVuZGVyZXIgbW9kdWxlcy4KCiAgICAgIE9uZSBjb3JyZXNwb25kcyAgdG8gdGhlICJzdGFuZGFyZCIgc2Nhbi1jb252ZXJ0ZXIsICB0aGUgb3RoZXIgdG8KICAgICAgdGhlICJzbW9vdGgiIG9uZS4KCiAgICAgIGhlICBjdXJyZW50ICByZW5kZXJlciAgY2FuICBiZSAgc2V0ICB0aHJvdWdoICB0aGUgIG5ldyAgZnVuY3Rpb24KICAgICAgRlRfU2V0X1JlbmRlcmVyLgoKICAgICAgVGhlIG9sZCByYXN0ZXItcmVsYXRlZCBmdW5jdGlvbiBGVF9TZXRfUmFzdGVyLCBGVF9HZXRfUmFzdGVyIGFuZAogICAgICBGVF9TZXRfUmFzdGVyX01vZGUgaGF2ZSBub3cgZGlzYXBwZWFyZWQsIGluIGZhdm9yIG9mIHRoZSBuZXc6CgogICAgICAgIEZUX0dldF9SZW5kZXJlcgogICAgICAgIEZUX1NldF9SZW5kZXJlcgoKICAgICAgU2VlIHRoZSBmaWxlIDxmcmVldHlwZS9mdHJlbmRlci5oPiBmb3IgbW9yZSBkZXRhaWxzLgoKICAgICAgVGhlc2UgIGNoYW5nZXMgIHdlcmUgIG5lY2Vzc2FyeSAgdG8gcHJvcGVybHkgIHN1cHBvcnQgIGRpZmZlcmVudAogICAgICBzY2FsYWJsZSBmb3JtYXRzIGluIHRoZSBmdXR1cmUsIGxpa2UgYmktY29sb3IgZ2x5cGhzLCBldGMuCgogICAgKiBHbHlwaCBsb2FkZXIgb2JqZWN0OgoKICAgICAgQSAgbmV3ICBpbnRlcm5hbCAgb2JqZWN0LCAgY2FsbGVkICBhICAnZ2x5cGggIGxvYWRlcicgIGhhcyAgYmVlbgogICAgICBpbnRyb2R1Y2VkIGluIHRoZSBiYXNlIGxheWVyLiAgSXQgaXMgdXNlZCBieSBhbGwgc2NhbGFibGUgZm9ybWF0CiAgICAgIGZvbnQgZHJpdmVycyB0byBsb2FkIGdseXBocyBhbmQgY29tcG9zaXRlcy4KCiAgICAgIFRoaXMgb2JqZWN0ICBoYXMgYmVlbiAgY3JlYXRlZCB0byByZWR1Y2UgIHRoZSBjb2RlIHNpemUgIG9mIGVhY2gKICAgICAgZHJpdmVyLCAgYXMgIGVhY2ggIG9uZSAgb2YgIHRoZW0gIGJhc2ljYWxseSAgcmUtaW1wbGVtZW50ZWQgIGl0cwogICAgICBmdW5jdGlvbmFsaXR5LgoKICAgICAgU2VlIDxmcmVldHlwZS9pbnRlcm5hbC9mdG9ianMuaD4gYW5kIHRoZSBGVF9HbHlwaExvYWRlciB0eXBlIGZvcgogICAgICBtb3JlIGluZm9ybWF0aW9uLgoKICAgICogRlRfR2x5cGhTbG90IGhhcyBuZXcgZmllbGRzOgoKICAgICAgSW4gIG9yZGVyICAgdG8gIHN1cHBvcnQgIGV4dGVuZGVkICBmZWF0dXJlcyAgIChzZWUgIGJlbG93KSwgIHRoZQogICAgICBGVF9HbHlwaFNsb3Qgc3RydWN0dXJlIGhhcyBhIGZldyBuZXcgZmllbGRzOgoKICAgICAgbGluZWFySG9yaUFkdmFuY2U6CgogICAgICAgIFRoaXMgIGZpZWxkICBnaXZlcyAgdGhlICAgbGluZWFybHkgIHNjYWxlZCAgKGkuZS4gIHNjYWxlZCAgYnV0CiAgICAgICAgdW5oaW50ZWQpIGFkdmFuY2UgIHdpZHRoIGZvciB0aGUgIGdseXBoLCBleHByZXNzZWQgYXMgIGEgMTYuMTYKICAgICAgICBmaXhlZCBwaXhlbCB2YWx1ZS4gIFRoaXMgaXMgdXNlZnVsIHRvIHBlcmZvcm0gV1lTSVdZRyB0ZXh0LgoKICAgICAgbGluZWFyVmVydEFkdmFuY2U6CiAgICAgICAgVGhpcyBmaWVsZCAgZ2l2ZXMgdGhlIGxpbmVhcmx5ICBzY2FsZWQgYWR2YW5jZSBoZWlnaHQgIGZvciB0aGUKICAgICAgICBnbHlwaCAgKHJlbGV2YW50IGluICB2ZXJ0aWNhbCAgZ2x5cGggbGF5b3V0cyAgb25seSkuICBUaGlzICBpcwogICAgICAgIHVzZWZ1bCB0byBwZXJmb3JtIFdZU0lXWUcgdGV4dC4KCiAgICAgICAgTm90ZSB0aGF0ICB0aGUgdHdvIGFib3ZlIGZpZWxkIHJlcGxhY2UgIHRoZSByZW1vdmVkICJtZXRyaWNzMiIKICAgICAgICBmaWVsZCBpbiB0aGUgZ2x5cGggc2xvdC4KCiAgICAgIGFkdmFuY2U6CiAgICAgICAgVGhpcyBmaWVsZCBpcyBhIHZlY3RvciAgdGhhdCBnaXZlcyB0aGUgdHJhbnNmb3JtZWQgYWR2YW5jZSBmb3IKICAgICAgICB0aGUgZ2x5cGguICAgQnkgZGVmYXVsdCwgaXQgY29ycmVzcG9uZHMgdG8gIHRoZSBhZHZhbmNlIHdpZHRoLAogICAgICAgIHVubGVzcyAgRlRfTE9BRF9WRVJUSUNBTF9MQVlPVVQgIHdhcyAgc3BlY2lmaWVkICB3aGVuICBjYWxsaW5nCiAgICAgICAgRlRfTG9hZF9HbHlwaCBvciBGVF9Mb2FkX0NoYXIuCgogICAgICBiaXRtYXBfbGVmdDoKICAgICAgICBUaGlzICBmaWVsZCBnaXZlcyAgdGhlICBkaXN0YW5jZSBpbiAgaW50ZWdlciAgcGl4ZWxzIGZyb20gIHRoZQogICAgICAgIGN1cnJlbnQgcGVuIHBvc2l0aW9uICB0byB0aGUgbGVmdC1tb3N0IHBpeGVsIG9mICBhIGdseXBoIGltYWdlCiAgICAgICAgSUYgSVQgSVMgIEEgQklUTUFQLiAgSXQgaXMgb25seSB2YWxpZCAgd2hlbiB0aGUgImZvcm1hdCIgZmllbGQKICAgICAgICBpcyBzZXQgdG8gImZ0X2dseXBoX2Zvcm1hdF9iaXRtYXAiLCBmb3IgZXhhbXBsZSwgYWZ0ZXIgY2FsbGluZwogICAgICAgIHRoZSBuZXcgZnVuY3Rpb24gRlRfUmVuZGVyX0dseXBoLgoKICAgICAgYml0bWFwX3RvcDoKICAgICAgICBUaGlzICBmaWVsZCBnaXZlcyAgdGhlICBkaXN0YW5jZSBpbiAgaW50ZWdlciAgcGl4ZWxzIGZyb20gIHRoZQogICAgICAgIGN1cnJlbnQgcGVuIHBvc2l0aW9uIChsb2NhdGVkIG9uIHRoZSBiYXNlbGluZSkgdG8gdGhlIHRvcC1tb3N0CiAgICAgICAgcGl4ZWwgb2YgdGhlICBnbHlwaCBpbWFnZSBJRiBJVCBJUyAgQSBCSVRNQVAuICBQb3NpdGl2ZSB2YWx1ZXMKICAgICAgICBjb3JyZXNwb25kIHRvIHVwd2FyZHMgWS4KCiAgICAgIGxvYWRlcjoKICAgICAgICBUaGlzICBpcyBhICBuZXcgIHByaXZhdGUgIGZpZWxkIGZvciAgdGhlICBnbHlwaCBzbG90LiAgIENsaWVudAogICAgICAgIGFwcGxpY2F0aW9ucyBzaG91bGQgbm90IHRvdWNoIGl0LgoKCiAgICAqIFN1cHBvcnQgZm9yIHRyYW5zZm9ybXMgYW5kIGRpcmVjdCByZW5kZXJpbmcgaW4gRlRfTG9hZF9HbHlwaDoKCiAgICAgIE1vc3Qgb2YgdGhlIGZ1bmN0aW9uYWxpdHkgZm91bmQgaW4gPGZyZWV0eXBlL2Z0Z2x5cGguaD4gaGFzIGJlZW4KICAgICAgbW92ZWQgdG8gdGhlIGNvcmUgbGlicmFyeS4gIEhlbmNlLCB0aGUgZm9sbG93aW5nOgoKICAgICAgLSBBICAgdHJhbnNmb3JtICAgY2FuICAgYmUgICBzcGVjaWZpZWQgIGZvciAgIGEgICBmYWNlICAgdGhyb3VnaAogICAgICAgIEZUX1NldF9UcmFuc2Zvcm0uICB0aGlzIHRyYW5zZm9ybSAgaXMgYXBwbGllZCBieSBGVF9Mb2FkX0dseXBoCiAgICAgICAgdG8gIHNjYWxhYmxlIGdseXBoICBpbWFnZXMgKGkuZS4gIE5PVCBUTyAgQklUTUFQUykgIGJlZm9yZSB0aGUKICAgICAgICBmdW5jdGlvbiByZXR1cm5zLCB1bmxlc3MgdGhlIGJpdCBmbGFnIEZUX0xPQURfSUdOT1JFX1RSQU5TRk9STQogICAgICAgIHdhcyBzZXQgaW4gdGhlIGxvYWQgZmxhZ3MuCgogICAgICAtIE9uY2UgIGEgIGdseXBoIGltYWdlICBoYXMgIGJlZW4gIGxvYWRlZCwgIGl0IGNhbiAgYmUgIGRpcmVjdGx5CiAgICAgICAgY29udmVydGVkICB0byAgYSAgYml0bWFwICBieSAgdXNpbmcgIHRoZSAgbmV3ICBGVF9SZW5kZXJfR2x5cGgKICAgICAgICBmdW5jdGlvbi4gIE5vdGUgdGhhdCB0aGlzICBmdW5jdGlvbiB0YWtlcyB0aGUgZ2x5cGggaW1hZ2UgZnJvbQogICAgICAgIHRoZSBnbHlwaCBzbG90LCAgYW5kIGNvbnZlcnRzIGl0IHRvIGEgIGJpdG1hcCB3aG9zZSBwcm9wZXJ0aWVzCiAgICAgICAgYXJlIHJldHVybmVkICBpbiAiZmFjZS5nbHlwaC5iaXRtYXAiLCAiZmFjZS5nbHlwaC5iaXRtYXBfbGVmdCIKICAgICAgICBhbmQgImZhY2UuZ2x5cGguYml0bWFwX3RvcCIuICBUaGUgIG9yaWdpbmFsIG5hdGl2ZSBpbWFnZSBtaWdodAogICAgICAgIGJlIGxvc3QgYWZ0ZXIgdGhlIGNvbnZlcnNpb24uCgogICAgICAtIFdoZW4gdXNpbmcgdGhlIG5ldyAgYml0IGZsYWcgRlRfTE9BRF9SRU5ERVIsIHRoZSBGVF9Mb2FkX0dseXBoCiAgICAgICAgYW5kICAgRlRfTG9hZF9DaGFyICAgZnVuY3Rpb25zICAgd2lsbCAgIGNhbGwgICBGVF9SZW5kZXJfR2x5cGgKICAgICAgICBhdXRvbWF0aWNhbGx5IHdoZW4gbmVlZGVkLgoKICAtIFJlZm9ybWF0dGVkIGFsbCAgbW9kdWxlcyBzb3VyY2UgIGNvZGUgaW4gb3JkZXIgIHRvIGdldCByaWQgIG9mIHRoZQogICAgYmFzaWMgZGF0YSB0eXBlcyByZWRpZmluaXRpb25zIChpLmUuICJUVF9JbnQiIGluc3RlYWQgb2YgIkZUX0ludCIsCiAgICAiVDFfRml4ZWQiICBpbnN0ZWFkICBvZiAgIkZUX0ZpeGVkIikuICBIZW5jZSAgdGhlICBmb3JtYXQtc3BlY2lmaWMKICAgIHByZWZpeGVzIGxpa2UgICJUVF8iLCAiVDFfIiwgICJUMl8iIGFuZCAiQ0lEXyIgIGFyZSBvbmx5ICB1c2VkIGZvcgogICAgcmVsZXZhbnQgc3RydWN0dXJlcy4KCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpPTEQgQ0hBTkdFUyBGT1IgQkVUQSA3CgogIC0gYnVnLWZpeGVkIHRoZSAgT3BlblR5cGUvQ0ZGIHBhcnNlci4gIEl0ICBub3cgbG9hZHMgYW5kIGRpc3BsYXlzIG15CiAgICB0d28gIGZvbnRzIG5pY2VseSwgIGJ1dCBJJ20gIHByZXR0eSBjZXJ0YWluICB0aGF0IG1vcmUgIHRlc3RpbmcgaXMKICAgIG5lZWRlZCA6LSkKCiAgLSBmaXhlZCB0aGUgY3J1bW15IFR5cGUgMSBoaW50ZXIsIGl0IG5vdyBoYW5kbGVzIGFjY2VudGVkIGNoYXJhY3RlcnMKICAgIGNvcnJlY3RseSAod2VsbCwgdGhlIGFjY2VudCBpcyAgbm90IGFsd2F5cyB3ZWxsIHBsYWNlZCwgYnV0IHRoYXQncwogICAgYW5vdGhlciBwcm9ibGVtLi4pCgogIC0gYWRkZWQgdGhlIENJRC1rZXllZCBUeXBlIDEgZHJpdmVyIGluICJzcmMvY2lkIi4gIFdvcmtzIHByZXR0eSB3ZWxsCiAgICBmb3Igb25seSAxMyBLYiBvZiBjb2RlICA7LSkgRG9lc24ndCByZWFkIEFGTSBmaWxlcyB0aG91Z2gsIG5vciB0aGUKICAgIHJlYWxseSB1c2VmdWwgQ01BUCBmaWxlcy4uCgogIC0gZml4ZWQgIHR3byAgYnVncyAgaW4gIHRoZSAgc21vb3RoICByZW5kZXJlciAgKHNyYy9iYXNlL2Z0Z3JheXMuYykuCiAgICBUaGFua3MgdG8gQm9yaXMgTGV0b2NoYSBmb3Igc3BvdHRpbmcgdGhlbSBhbmQgcHJvdmlkaW5nIGEgZml4LgoKICAtIGZpeGVkIHBvdGVudGlhbCAiZGl2aWRlIGJ5IHplcm8iIGJ1Z3MgaW4gZnRjYWxjLmMuCgogIC0gYWRkZWQgc291cmNlICBjb2RlIGZvciAgdGhlIE9wZW5UeXBlL0NGRiBkcml2ZXIgIChzdGlsbCBpbmNvbXBsZXRlCiAgICB0aG91Z2guLikKCiAgLSBtb2RpZmllZCB0aGUgIFNGTlQgZHJpdmVyIHNsaWdodGx5ICB0byBwZXJmb3JtIG1vcmUgIHJvYnVzdCBoZWFkZXIKICAgIGNoZWNrcyAgaW4gVFRfTG9hZF9TRk5UX0hlYWRlci4gIFRoaXMgcHJldmVudHMgY2VydGFpbiAgZm9udCBmaWxlcwogICAgKGUuZy4gIHNvbWUgIFR5cGUgIDEgIE11bHRpcGxlICBNYXN0ZXJzKSAgZnJvbSAgYmVpbmcgIGluY29ycmVjdGx5CiAgICAicmVjb2duaXplZCIgYXMgVHJ1ZVR5cGUgZm9udCBmaWxlcy4uCgogIC0gbW92ZWQgYSBsb3Qgb2Ygc3R1ZmYgZnJvbSAgdGhlIFRydWVUeXBlIGRyaXZlciB0byB0aGUgU0ZOVCBtb2R1bGUsCiAgICB0aGlzICAgYWxsb3dzICAgZ3JlYXRlciAgIGNvZGUgICByZS11c2UgICBiZXR3ZWVuICAgZm9udCAgIGRyaXZlcnMKICAgIChlLmcuIFRydWVUeXBlLCBPcGVuVHlwZSwgQ29tcGFjdC1UcnVlVHlwZSwgZXRjLi4pCgogIC0gYWRkZWQgYSB0aW55IHNlZ21lbnQgY2FjaGUgdG8gdGhlIFNGTlQgQ2hhcm1hcCA0IGRlY29kZXIsIGluIG9yZGVyCiAgICB0byBtaW5pbWFsbHkgc3BlZWQgaXQgdXAuLgoKICAtIGFkZGVkICBzdXBwb3J0IGZvciAgTXVsdGlwbGUgTWFzdGVyICBmb250cyBpbiAgInR5cGUxeiIuICBUaGVyZSBpcwogICAgYWxzbyBhIG5ldyBmaWxlIG5hbWVkIDxmcmVldHlwZS9mdG1tLmg+IHdoaWNoIGRlZmluZXMgZnVuY3Rpb25zIHRvCiAgICBtYW5hZ2UgdGhlbSBmcm9tIGNsaWVudCBhcHBsaWNhdGlvbnMuCgogICAgVGhlIG5ldyBmaWxlICJzcmMvYmFzZS9mdG1tLmMiIGlzIGFsc28gb3B0aW9uYWwgdG8gdGhlIGVuZ2luZS4uCgogIC0gdmFyaW91cyAgZm9ybWF0dGluZyBjaGFuZ2VzIChlLmcuICBFWFBPUlRfREVGIC0+ICBGVF9FWFBPUlRfREVGKSArCiAgICBzbWFsbCBidWcgZml4ZXMgaW4gRlRfTG9hZF9HbHlwaCwgdGhlICJ0eXBlMSIgZHJpdmVyLCBldGMuLgoKICAtIGEgbWlub3IgZml4IHRvIHRoZSBUeXBlIDEgZHJpdmVyIHRvIGxldCB0aGVtIGFwcGx5IHRoZSBmb250IG1hdHJpeAogICAgY29ycmVjdGx5ICh1c2VkIGZvciBtYW55IG9ibGlxdWUgZm9udHMuLikKCiAgLSBzb21lIGZpeGVzIGZvciA2NC1iaXQgc3lzdGVtcyAobWFpbmx5IGNoYW5naW5nIHNvbWUgRlRfVFJBQ0UgY2FsbHMKICAgIHRvIHVzZSAlcCBpbnN0ZWFkIG9mICVseCkuICBUaGFua3MgdG8gS2FybCBSb2JpbGxhcmQuCgogIC0gZml4ZWQgIHNvbWUgYnVncyAgaW4gIHRoZSBzYml0ICBsb2FkZXIgKHNyYy9iYXNlL3NmbnQvdHRzYml0LmMpICArCiAgICBhZGRlZCAgYSBuZXcgZmxhZywgIEZUX0xPQURfQ1JPUF9CSVRNQVAgdG8gIHF1ZXJ5IHRoYXQgIGJpdG1hcHMgYmUKICAgIGNyb3BwZWQgd2hlbiAgbG9hZGVkIGZyb20gYSBmaWxlICAobWF5YmUgSSBzaG91bGQgIG1vdmUgdGhlIGJpdG1hcAogICAgY3JvcHBlciB0byB0aGUgYmFzZSBsYXllciA/PykuCgogIC0gY2hhbmdlZCB0aGUgZGVmYXVsdCAgbnVtYmVyIG9mIGdyYXkgbGV2ZWxzIG9mICB0aGUgc21vb3RoIHJlbmRlcmVyCiAgICB0byAyNTYgIChpbnN0ZWFkIG9mICB0aGUgcHJldmlvdXMgMTI4KS4gIE9mIGNvdXJzZSwgdGhlICBodW1hbiBleWUKICAgIGNhbid0IHNlZSBhbnkgZGlmZmVyZW5jZSA7LSkKCiAgLSByZW1vdmVkIFRUX01BWF9TVUJHTFlQSFMsICB0aGVyZSBpcyBubyBzdGF0aWMgbGltaXQgIG9uIHRoZSBudW1iZXIKICAgIG9mIHN1YmdseXBocyBpbiBhIFRydWVUeXBlIGZvbnQgbm93Li4KCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpPTEQgQ0hBTkdFUyAxNiBNYXkgMjAwMAoKICAtIHRhZ2dlZCAiQkVUQS02IiAgaW4gdGhlICBDVlMgdHJlZS4gIFRoaXMgb25lIGlzIGEgIHNlcmlvdXMgcmVsZWFzZQogICAgY2FuZGlkYXRlIGV2ZW4gdGhvdWdoIGl0IGRvZXNuJ3QgaW5jb3Jwb3JhdGUgdGhlIGF1dG8taGludGVyIHlldC4uCgogIC0gdmFyaW91cyBvYnNvbGV0ZSBmaWxlcyB3ZXJlIHJlbW92ZWQsIGFuZCBjb3B5cmlnaHQgaGVhZGVyIHVwZGF0ZWQKCiAgLSBmaW5hbGx5ICB1cGRhdGVkICB0aGUgIHN0YW5kYXJkICAgcmFzdGVyICB0byAgZml4ICB0aGUgIG1vbm9jaHJvbWUKICAgIHJlbmRlcmluZyBidWcgKyByZS1lbmFibGUgIHN1cHBvcnQgZm9yIDUtZ3JheSBsZXZlbHMgYW50aS1hbGlhc2luZwogICAgKHN1Y2ssIHN1Y2suLikKCiAgLSBjcmVhdGVkIG5ldyBoZWFkZXIgZmlsZXMsIGFuZCBtb2RpZmllZCBzb3VyY2VzIGFjY29yZGluZ2x5OgoKICAgICA8ZnJlZXR5cGUvZnR0eXBlcy5oPgogICAgICAgLSBzaW1wbGUgRnJlZVR5cGUgdHlwZXMsIHdpdGhvdXQgdGhlIEFQSQogICAgIDxmcmVldHlwZS9pbnRlcm5hbC9mdG1lbW9yeS5oPgogICAgICAgLSBkZWZpbml0aW9uIG9mIG1lbW9yeS1tYW5hZ2VtZW50IG1hY3JvcwoKICAtIGFkZGVkICAgdGhlICAgIkRTSUciICAgKE9wZW5UeXBlICAgRGlnaXRhbCAgIFNpZ25hdHVyZSkgICB0YWcgICB0bwogICAgPGZyZWV0eXBlL3R0dGFncy5oPgoKICAtIGxpZ2h0IHVwZGF0ZS9jbGVhbmluZyBvZiB0aGUgYnVpbGQgc3lzdGVtICsgY2hhbmdlcyB0byB0aGUgc291cmNlcwogICAgaW4gIG9yZGVyICB0byAgZ2V0ICByaWQgIG9mIF9hbGxfICBjb21waWxlciAgd2FybmluZ3MgIHdpdGggIHRocmVlCiAgICBjb21waWxlcnMsIGkuZToKCiAgICBnY2Mgd2l0aCAiLWFuc2kgLXBlZGFudGljIC1XYWxsIC1XIiwgVmlzdWFsIEMrKyB3aXRoICIvVzMgL1dYIiBhbmQKICAgIExDQwoKICAgIElNUE9SVEFOVCBOT1RFIEZPUiBXSU4zMi1MQ0MgVVNFUlM6CiAgICB8CiAgICB8ICBJdCBzZWVtcyB0aGUgQyBwcmUtcHJvY2Vzc29yICB0aGF0IGNvbWVzIHdpdGggTENDIGlzIGJyb2tlbiwgaXQKICAgIHwgIGRvZXNuJ3QgIHJlY29nbml6ZSAgdGhlICBBTlNJICBzdGFuZGFyZCAgZGlyZWN0aXZlcyAgIyAgYW5kICAjIwogICAgfCAgY29ycmVjdGx5ICAgd2hlbiAgb25lICBvZiAgIHRoZSAgYXJndW1lbnQgIGlzICBhICBtYWNyby4gIEFsc28sCiAgICB8ICBzb21ldGhpbmcgbGlrZToKICAgIHwKICAgIHwgICAgICNkZWZpbmUgRih4KSAgcHJpbnQjI3gKICAgIHwKICAgIHwgICAgIEYoKCJoZWxsbyIpKQogICAgfAogICAgfCAgd2lsbCBnZXQgaW5jb3JyZWN0bHkgdHJhbnNsYXRlZCB0bzoKICAgIHwKICAgIHwgICAgIHByaW50ICJoZWxsbyIpCiAgICB8CiAgICB8ICBieSBpdHMgcHJlLXByb2Nlc3Nvci4gIEZvciB0aGlzIHJlYXNvbiwgeW91IHNpbXBseSBjYW5ub3QgYnVpbGQKICAgIHwgIEZyZWVUeXBlIDIgaW4gZGVidWcgbW9kZSB3aXRoIHRoaXMgY29tcGlsZXIuLgoKICAtIHlldCAgYW5vdGhlciBtYXNzaXZlIGdydW50IHdvcmsuICBJJ3ZlICBjaGFuZ2VkIHRoZSAgZGVmaW5pdGlvbiBvZgogICAgdGhlIEVYUE9SVF9ERUYsICBFWFBPUlRfRlVOQywgQkFTRV9ERUYgJiAgQkFTRV9GVU5DIG1hY3Jvcy4gIFRoZXNlCiAgICBub3cgdGFrZSBhbiBhcmd1bWVudCwgd2hpY2ggaXMgdGhlIGZ1bmN0aW9uJ3MgcmV0dXJuIHZhbHVlIHR5cGUuCgogICAgVGhpcyAgaXMgbmVjZXNzYXJ5IHRvICBjb21waWxlIEZyZWVUeXBlICBhcyBhICBETEwgb24gIFdpbmRvd3MgYW5kCiAgICBPUy8yLiAgRGVwZW5kaW5nIG9uIHRoZSBjb21waWxlciB1c2VkLCBhIGNvbXBpbGVyLXNwZWNpZmljIGtleXdvcmQKICAgIGxpa2UgIF9fZXhwb3J0IG9yIF9fc3lzdGVtICBtdXN0IGJlICBwbGFjZWQgYmVmb3JlICAoVmlzdWFsQysrKSBvcgogICAgYWZ0ZXIgKEJvcmxhbmRDKyspIHRoZSB0eXBlLi4KCiAgICBPZiBjb3Vyc2UsIHRoaXMgbmVlZGVkIGEgbG90IG9mIGNoYW5nZXMgdGhyb3VnaG91dCB0aGUgc291cmNlIGNvZGUKICAgIHRvIG1ha2UgaXQgY29tcGlsZSBhZ2Fpbi4uLiAgQWxsIGNsZWFuZWQgdXAgbm93LCBhcHBhcmVudGx5Li4KCiAgICBOb3RlIGFsc28gIHRoYXQgdGhlcmUgaXMgYSAgbmV3IEVYUE9SVF9WQVIgbWFjcm8gIGRlZmluZWQgdG8gYWxsb3cKICAgIHRoZSAgIF9kZWNsYXJhdGlvbl8gICAgb2YgICBhbiAgIGV4cG9ydGFibGUgICAgcHVibGljICAgKGNvbnN0YW50KQogICAgdmFyaWFibGUuICBUaGlzICBpcyAgdGhlICAgY2FzZSAgb2YgIHRoZSAgcmFzdGVyICBpbnRlcmZhY2VzICAoc2VlCiAgICBmdHJhc3Rlci5oIGFuZCBmdGdyYXlzLmgpLCBhcyB3ZWxsIGFzIGVhY2ggbW9kdWxlJ3MgaW50ZXJmYWNlIChzZWUKICAgIHNmZHJpdmVyLmgsIHBzZHJpdmVyLmgsIGV0Yy4uKQoKICAtIG5ldyBmZWF0dXJlOiBpdCAgaXMgbm93IHBvc3NpYmxlIHRvIHBhc3MgIGV4dHJhIHBhcmFtZXRlcnMgdG8gZm9udAogICAgICAgICAgICAgICAgIGRyaXZlcnMgIHdoZW4gY3JlYXRpbmcgIGEgbmV3ICBmYWNlIG9iamVjdC4gIEZvciBub3csCiAgICAgICAgICAgICAgICAgdGhpcyBjYXBhYmlsaXR5IGlzIHVudXNlZC4gIEl0IGNvdWxkIGhvd2V2ZXIgcHJvdmUgdG8KICAgICAgICAgICAgICAgICBiZSB1c2VmdWwgaW4gYSBuZWFyIGZ1dHVyZS4uCgogICAgICB0aGUgRlRfT3Blbl9BcmdzIHN0cnVjdHVyZSB3YXMgIGNoYW5nZXMsIGFzIHdlbGwgYXMgdGhlIGludGVybmFsCiAgICAgIGRyaXZlciBpbnRlcmZhY2UgICh0aGUgc3BlY2lmaWMgImluaXRfZmFjZSIgIG1vZHVsZSBmdW5jdGlvbiBoYXMKICAgICAgbm93IGEgZGlmZmVyZW50IHNpZ25hdHVyZSkuCgogIC0gdXBkYXRlZCB0aGUgdHV0b3JpYWwgKG5vdCBmaW5pc2hlZCB0aG91Z2gpLgoKICAtIHVwZGF0ZWQgdGhlIHRvcC1sZXZlbCBCVUlMRCAgZG9jdW1lbnQKCiAgLSBmaXhlZCAgYSAgcG90ZW50aWFsIG1lbW9yeSAgbGVhayAgdGhhdCAgY291bGQgIG9jY3VyIHdoZW4gIGxvYWRpbmcKICAgIGVtYmVkZGVkIGJpdG1hcHMuCgogIC0gYWRkZWQgICAgIHRoZSAgICAgZGVjbGFyYXRpb24gICAgIG9mICAgICBGVF9OZXdfTWVtb3J5X0ZhY2UgICAgIGluCiAgICA8ZnJlZXR5cGUvZnJlZXR5cGUuaD4sIGFzICBpdCB3YXMgIG1pc3NpbmcgZnJvbSB0aGUgIHB1YmxpYyBoZWFkZXIKICAgICh0aGUgaW1wbGVtZW50YXRpb24gd2FzIGFscmVhZHkgaW4gImZ0b2Jqcy5jIikuCgogIC0gdGhlIGZpbGUgPGZyZWV0eXBlL2Z0ZXJyb3JzLmg+IGhhcyBiZWVuIHNlcmlvdXNseSB1cGRhdGVkIGluIG9yZGVyCiAgICB0byBhbGxvdyAgdGhlIGF1dG9tYXRpYyBnZW5lcmF0aW9uICBvZiBlcnJvciBtZXNzYWdlIHRhYmxlcy4gICBTZWUKICAgIHRoZSBjb21tZW50cyB3aXRoaW4gaXQgZm9yIG1vcmUgaW5mb3JtYXRpb24uCgogIC0gbWFqb3IgZGlyZWN0b3J5ICBoaWVyYXJjaHkgcmUtb3JnYW5pc2F0aW9uLiAgVGhpcyB3YXMgZG9uZSBmb3IgdHdvCiAgICB0aGluZ3M6CgogICAgICAqIGZpcnN0LCAgdG8gZWFzZSAgdGhlICJtYW51YWwiICBjb21waWxhdGlvbiBvZiAgdGhlICBsaWJyYXJ5IGJ5CiAgICAgICAgcmVxdWlyaW5nIGF0IGxvdCBsZXNzIGluY2x1ZGUgcGF0aHMgOi0pCgogICAgICAqIHNlY29uZCwgIHRvICBhbGxvdyAgZXh0ZXJuYWwgIHByb2dyYW1zIHRvICBlZmZlY3RpdmVseSAgYWNjZXNzCiAgICAgICAgaW50ZXJuYWwgIGRhdGEgIGZpZWxkcy4gIEZvciBleGFtcGxlLCAgdGhpcyAgY2FuIGJlICBleHRyZW1lbHkKICAgICAgICB1c2VmdWwgaWYgIHNvbWVvbmUgd2FudHMgIHRvIHdyaXRlIGEgIGZvbnQgcHJvZHVjZXIgb3IgIGEgZm9udAogICAgICAgIG1hbmFnZXIgb24gdG9wIG9mIEZyZWVUeXBlLgoKICAgIEJhc2ljYWxseSwgeW91ICBzaG91bGQgbm93IHVzZSAgdGhlICdmcmVldHlwZS8nIHByZWZpeCAgZm9yIGhlYWRlcgogICAgaW5jbHVzaW9uLCBhcyBpbjoKCiAgICAgICAgI2luY2x1ZGUgPGZyZWV0eXBlL2ZyZWV0eXBlLmg+CiAgICAgICAgI2luY2x1ZGUgPGZyZWV0eXBlL2Z0Z2x5cGguaD4KCiAgICBTb21lIG5ldyBpbmNsdWRlIHN1Yi1kaXJlY3RvcmllcyBhcmUgYXZhaWxhYmxlOgoKICAgICBhLiB0aGUgICJmcmVldHlwZS9jb25maWciIGRpcmVjdG9yeSwgIGNvbnRhaW5zIHR3byBmaWxlcyAgdXNlZCB0bwogICAgICAgIGNvbmZpZ3VyZSAgdGhlICBidWlsZCAgb2YgIHRoZSAgbGlicmFyeS4gIENsaWVudCAgYXBwbGljYXRpb25zCiAgICAgICAgc2hvdWxkICBub3QgbmVlZCAgdG8gbG9vayAgYXQgdGhlc2UgIG5vcm1hbGx5LCBidXQgdGhleSBjYW4gaWYKICAgICAgICB0aGV5IHdhbnQuCgogICAgICAgICNpbmNsdWRlIDxmcmVldHlwZS9jb25maWcvZnRvcHRpb24uaD4KICAgICAgICAjaW5jbHVkZSA8ZnJlZXR5cGUvY29uZmlnL2Z0Y29uZmlnLmg+CgogICAgIGIuIHRoZSAiZnJlZXR5cGUvaW50ZXJuYWwiICBkaXJlY3RvcnksIGNvbnRhaW5zIGhlYWRlciBmaWxlcyB0aGF0CiAgICAgICAgZGVzY3JpYmVzIGxpYnJhcnkgIGludGVybmFscy4gIFRoZXNlIGFyZSB0aGUgaGVhZGVyIGZpbGVzIHRoYXQKICAgICAgICB3ZXJlICBwcmV2aW91c2x5ICBmb3VuZCAgaW4gIHRoZSAic3JjL2Jhc2UiICBhbmQgICJzcmMvc2hhcmVkIgogICAgICAgIGRpcmVjdG9yaWVzLgoKCiAgICBBcyAgdXN1YWwsIHRoZSBidWlsZCAgc3lzdGVtIGFuZCAgdGhlIGRlbW9zICBoYXZlIGJlZW4gIHVwZGF0ZWQgdG8KICAgIHJlZmxlY3QgdGhlIGNoYW5nZS4uCgogICAgSGVyZSdzIGEgbGF5b3V0IG9mIHRoZSBuZXcgZGlyZWN0b3J5IGhpZXJhcmNoeToKCiAgICBUT1BfRElSCiAgICAgIGluY2x1ZGUvCiAgICAgICAgIGZyZWV0eXBlLwogICAgICAgICAgICBmcmVldHlwZS5oCiAgICAgICAgICAgIC4uLgogICAgICAgICAgICBjb25maWcvCiAgICAgICAgICAgICAgZnRvcHRpb24uaAogICAgICAgICAgICAgIGZ0Y29uZmlnLmgKICAgICAgICAgICAgICBmdG1vZHVsZS5oCgogICAgICAgICAgICBpbnRlcm5hbC8KICAgICAgICAgICAgICBmdG9ianMuaAogICAgICAgICAgICAgIGZ0c3RyZWFtLmgKICAgICAgICAgICAgICBmdGNhbGMuaAogICAgICAgICAgICAgIC4uLgoKICAgICAgc3JjLwogICAgICAgICBiYXNlLwogICAgICAgICAgICAuLi4KCiAgICAgICAgIHNmbnQvCiAgICAgICAgIHBzbmFtZXMvCiAgICAgICAgIHRydWV0eXBlLwogICAgICAgICB0eXBlMS8KICAgICAgICAgdHlwZTF6LwoKCiAgICBDb21waWxpbmcgYSBtb2R1bGUgaXMgbm93ICBtdWNoIGVhc2llciwgZm9yIGV4YW1wbGUsIHRoZSBmb2xsb3dpbmcKICAgIHNob3VsZCB3b3JrIHdoZW4gaW4gdGhlIFRPUF9ESVIgZGlyZWN0b3J5IG9uIGFuIEFOU0kgYnVpbGQ6CgogICAgICAgZ2NjIC1jIC1JLi9pbmNsdWRlIC1JLi9zcmMvYmFzZSBzcmMvYmFzZS9mdGJhc2UuYwogICAgICAgZ2NjIC1jIC1JLi9pbmNsdWRlIC1JLi9zcmMvc2ZudCBzcmMvc2ZudC9zZm50LmMKICAgICAgIGV0Yy4uCgogICAgKG9mIGNvdXJzZSwgdXNpbmcgLUljb25maWcvPHN5c3RlbT4gaWYgeW91IHByb3ZpZGUgc3lzdGVtLXNwZWNpZmljCiAgICAgY29uZmlndXJhdGlvbiBmaWxlcykuCgogIC0gdXBkYXRlZCB0aGUgc3RydWN0dXJlIG9mIEZUX091dGxpbmVfRnVuY3MgaW4gb3JkZXIgdG8gYWxsb3cgZGlyZWN0CiAgICBjb29yZGluYXRlIHNjYWxpbmcgd2l0aGluICB0aGUgb3V0bGluZSBkZWNvbXBvc2l0aW9uIHJvdXRpbmUgKHRoaXMKICAgIGlzICBpbXBvcnRhbnQgZm9yIHZpcnR1YWwgICJvbiIgcG9pbnRzICB3aXRoIFRydWVUeXBlICBvdXRsaW5lcykgKwogICAgdXBkYXRlcyB0byB0aGUgcmFzdGVycyB0byBzdXBwb3J0IHRoaXMuLgoKICAtIHVwZGF0ZWQgIHRoZSBPUy8yICB0YWJsZSAgbG9hZGluZyBjb2RlICBpbiAic3JjL3NmbnQvdHRsb2FkLmMiICBpbgogICAgb3JkZXIgdG8gc3VwcG9ydCB2ZXJzaW9uIDIgb2YgdGhlIHRhYmxlIChzZWUgT3BlblR5cGUgMS4yIHNwZWMpCgogIC0gY3JlYXRlZCAgImluY2x1ZGUvdHR0YWJsZXMuaCIgIGFuZCAgImluY2x1ZGUvdDF0YWJsZXMuaCIgdG8gIGFsbG93CiAgICBjbGllbnQgYXBwbGljYXRpb25zIHRvIGFjY2VzcyBzb21lIG9mICB0aGUgU0ZOVCBhbmQgVDEgdGFibGVzIG9mIGEKICAgIGZhY2UgIHdpdGggIGEgIHByb2NlZHVyYWwgIGludGVyZmFjZSAoc2VlICBGVF9HZXRfU2ZudF9UYWJsZSgpKSAgKwogICAgdXBkYXRlcyB0byBpbnRlcm5hbCBzb3VyY2UgZmlsZXMgdG8gcmVmbGVjdCB0aGUgY2hhbmdlLi4KCiAgLSBzb21lICBjbGVhbnVwcyBpbiAgdGhlIHNvdXJjZSAgY29kZSB0byAgZ2V0IHJpZCAgb2YgIHdhcm5pbmdzIHdoZW4KICAgIGNvbXBpbGluZyB3aXRoIHRoZSAiLVdhbGwgLVcgLWFuc2kgLXBlZGFudGljIiBvcHRpb25zIGluIGdjYy4KCiAgLSBkZWJ1Z2dlZCBhbmQgbW92ZWQgdGhlIHNtb290aCByZW5kZXJlciB0byAic3JjL2Jhc2UvZnRncmF5cy5jIiBhbmQKICAgIGl0cyBoZWFkZXIgdG8gImluY2x1ZGUvZnRncmF5cy5oIgoKICAtIHVwZGF0ZWQgVFRfTUFYX1NVQkdMWVBIUyAgdG8gOTYgYXMgc29tZSBDSksgIGZvbnRzIGhhdmUgY29tcG9zaXRlcwogICAgd2l0aCB1cCB0byA4MCBzdWItZ2x5cGhzICEhIFRoYW5rcyB0byBXZXJuZXIKCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpPTEQgQ0hBTkdFUyAtIDE0LWFwci0yMDAwCgogIC0gZml4ZWQgIGEgYnVnICBpbiAgdGhlICBUcnVlVHlwZSBnbHlwaCAgbG9hZGVyICB0aGF0IHByZXZlbnRlZCAgdGhlCiAgICBjb3JyZWN0IGxvYWRpbmcgb2Ygc29tZSBDSksgZ2x5cGhzIGluIG1pbmdsaS50dGYKCiAgLSBpbXByb3ZlZCB0aGUgc3RhbmRhcmQgVHlwZSAxIGhpbnRlciBpbiAic3JjL3R5cGUxIgoKICAtIGZpeGVkIHR3byBidWdzICBpbiB0aGUgZXhwZXJpbWVudGFsIFR5cGUgMSAgZHJpdmVyIGluICJzcmMvdHlwZTF6IgogICAgdG8gaGFuZGxlIHRoZSBuZXcgWEZyZWU4NiA0LjAgZm9udHMgKGFuZCBhIGZldyBvdGhlciBvbmVzLi4pCgogIC0gdGhlIHNtb290aCAgcmVuZGVyZXIgaXMgbm93ICBjb21wbGV0ZSBhbmQgc3VwcG9ydHMgIHN1Yi1iYW5kaW5nIHRvCiAgICByZW5kZXIgbGFyZ2UgZ2x5cGhzICBhdCBoaWdoIHNwZWVkLiAgSG93ZXZlciwgaXQgaXMgc3RpbGwgIGxvY2F0ZWQKICAgIGluICJkZW1vcy9zcmMvZnRncmF5cy5jIiBhbmQgc2hvdWxkIG1vdmUgdG8gdGhlICBsaWJyYXJ5IGl0c2VsZiBpbgogICAgdGhlIG5leHQgIGJldGEuICBOT1RFOiBUaGUgIHNtb290aCAgcmVuZGVyZXIgIGRvZXNuJ3QgIGNvbXBpbGUgIGluCiAgICBzdGFuZC1hbG9uZSBtb2RlIGFueW1vcmUsIGJ1dCB0aGlzIHNob3VsZCBiZSBmaXhlZCBSU04uLgoKICAtIGludHJvZHVjZWQgY29udmVuaWVuY2UgIGZ1bmN0aW9ucyB0byAgbW9yZSBlYXNpbHkgZGVhbCAgd2l0aCBnbHlwaAogICAgaW1hZ2VzLCBzZWUgICJpbmNsdWRlL2Z0Z2x5cGguaCIgZm9yIG1vcmUgZGV0YWlscywgYXMgIHdlbGwgYXMgdGhlCiAgICBuZXcgIGRlbW8gcHJvZ3JhbSAgbmFtZWQgImRlbW9zL3NyYy9mdHN0cmluZy5jIiAgdGhhdCBkZW1vbnN0cmF0ZXMKICAgIGl0cyB1c2UKCiAgLSBpbXBsZW1lbnRlZCAgRlRfTE9BRF9OT19SRUNVUlNFIGluICBib3RoIHRoZSAgVHJ1ZVR5cGUgYW5kICBUeXBlIDEKICAgIGRyaXZlcnMgICh0aGlzICBpcyByZXF1aXJlZCAgYnkgIHRoZSAgYXV0by1oaW50ZXIgIHRvIGltcHJvdmUgIGl0cwogICAgcmVzdWx0cykuCgogIC0gY2hhbmdlZCAgIHRoZSAgcmFzdGVyICAgaW50ZXJmYWNlLCAgaW4gICBvcmRlciAgdG8gICBhbGxvdyAgY2xpZW50CiAgICBhcHBsaWNhdGlvbnMgIHRvICAgcHJvdmlkZSAgdGhlaXIgICBvd24gIHNwYW4tZHJhd2luZyAgIGNhbGxiYWNrcy4KICAgIEhvd2V2ZXIsICAgb25seSAgIHRoZSAgIHNtb290aCAgIHJlbmRlcmVyICAgc3VwcG9ydHMgICB0aGlzLiAgIFNlZQogICAgIkZUX1Jhc3Rlcl9QYXJhbXMiIGluIHRoZSBmaWxlICJpbmNsdWRlL2Z0aW1hZ2UuaCIuCgogIC0gZml4ZWQgIGEgc21hbGwgYnVnICBpbiBGVF9NdWxGaXggIHRoYXQgY2F1c2VkICBpbmNvcnJlY3QgdHJhbnNmb3JtCiAgICBjb21wdXRhdGlvbiEKCiAgLSBOb3RlOiBUaGUgdHV0b3JpYWwgaXMgb3V0LW9mLWRhdGUuCgoKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKT0xEIENIQU5HRVMgLSAxMi1tYXItMjAwMAoKICAtIGNoYW5nZWQgIHRoZSAgbGF5b3V0ICBvZiAgY29uZmlndXJhdGlvbiAgZmlsZXMgIDogIG5vdywgIGFsbCAgQU5TSQogICAgY29uZmlndXJhdGlvbiAgICAgICAgIGZpbGVzICAgICAgICAgYXJlICAgICAgICAgbG9jYXRlZCAgICAgICAgIGluCiAgICAiZnJlZXR5cGUyL2NvbmZpZyIuICBTeXN0ZW0tc3BlY2lmaWMgb3Zlci1yaWRlcyAgY2FuIGJlICBwbGFjZWQgaW4KICAgICJmcmVldHlwZTIvY29uZmlnLzxzeXN0ZW0+Ii4KCiAgLSBtb3ZlZCBhbGwgY29uZmlndXJhdGlvbiBtYWNyb3MgdG8gImNvbmZpZy9mdG9wdGlvbi5oIgoKICAtIGltcHJvdmVtZW50cyBpbiB0aGUgVHlwZSAxIGRyaXZlciB3aXRoIEFGTSBzdXBwb3J0CgogIC0gY2hhbmdlZCB0aGUgZmllbGRzICBpbiB0aGUgRlRfT3V0bGluZSBzdHJ1Y3R1cmUgOiAgdGhlIG9sZCAiZmxhZ3MiCiAgICBhcnJheSBpcyByZS1uYW1lZCAidGFncyIsIHdoaWxlIGFsbCBhbmNpZW50IGZsYWdzIGFyZSBlbmNvZGVkIGludG8KICAgIGEgc2luZ2xlIHVuc2lnbmVkIGludCBuYW1lZCAiZmxhZ3MiLgoKICAtIGludHJvZHVjZWQgICAgIG5ldyAgICAgIGZsYWdzICAgICBpbiAgICAgRlRfT3V0bGluZS5mbGFncyAgICAgKHNlZQogICAgZnRfb3V0bGluZV8uLi4uIGVudW1zIGluICJmdGltYWdlLmgiKS4KCiAgLSBjaGFuZ2VkIG91dGxpbmUgZnVuY3Rpb25zIHRvICJGVF9PdXRsaW5lXzxhY3Rpb24+IiBzeW50YXgKCiAgLSBhZGRlZCBhIHNtb290aCBhbnRpLWFsaWFzIHJlbmRlcmVyIHRvIHRoZSBkZW1vbnN0cmF0aW9uIHByb2dyYW1zCgogIC0gYWRkZWQgTWFjIGdyYXBoaWNzIGRyaXZlciAodGhhbmtzIEp1c3QpCgogIC0gRlRfT3Blbl9GYWNlICBjaGFuZ2VkICBpbiAgb3JkZXIgICB0byAgcmVjZWl2ZWQgIGEgIHBvaW50ZXIgIHRvICBhCiAgICBGVF9PcGVuX0FyZ3MgZGVzY3JpcHRvci4uCgogIC0gdmFyaW91cyAgY2xlYW51cHMsICBhICBmZXcgIG1vcmUgQVBJICBmdW5jdGlvbnMgIGltcGxlbWVudGVkICAoc2VlCiAgICBGVF9BdHRhY2hfRmlsZSkKCiAgLSB1cGRhdGVkIHNvbWUgZG9jcwoKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCk9MRCBDSEFOR0VTIC0gMjItZmViLTIwMDAKCiAgLSBpbnRyb2R1Y2VkIHRoZSAicHNuYW1lcyIgbW9kdWxlLiAgSXQgaXMgdXNlZCB0bzoKCiAgICAgIG8gY29udmVydCAgYSBQb3N0c2NyaXB0IGdseXBoICBuYW1lIGludG8gdGhlICBlcXVpdmFsZW50IFVuaWNvZGUKICAgICAgICBjaGFyYWN0ZXIgY29kZSAodXNlZCBieSB0aGUgIFR5cGUgMSBkcml2ZXIocykgdG8gc3ludGhldGl6ZSBvbgogICAgICAgIHRoZSBmbHkgYSBVbmljb2RlIGNoYXJtYXApLgoKICAgICAgbyBwcm92aWRlIGFuICBpbnRlcmZhY2UgdG8gcmV0cmlldmUgdGhlIFBvc3RzY3JpcHQgIG5hbWVzIG9mIHRoZQogICAgICAgIE1hY2ludG9zaCwgIEFkb2JlICBTdGFuZGFyZCAmICBBZG9iZSAgRXhwZXJ0IGNoYXJhY3RlciAgY29kZXMuCiAgICAgICAgKHRoZSBNYWNpbnRvc2ggIG5hbWVzIGFyZSAgdXNlZCBieSB0aGUgIFNGTlQtbW9kdWxlIHBvc3RzY3JpcHQKICAgICAgICBuYW1lcyBzdXBwb3J0IHJvdXRpbmVzLCB3aGlsZSB0aGUgb3RoZXIgdHdvIHRhYmxlcyBhcmUgdXNlZCBieQogICAgICAgIHRoZSBUeXBlIDEgZHJpdmVyKHMpKS4KCiAgLSBpbnRyb2R1Y2VkIHRoZSAidHlwZTF6IiBhbHRlcm5hdGUgVHlwZSAxIGRyaXZlci4gIFRoaXMgaXMgYSAoc3RpbGwKICAgIGV4cGVyaW1lbnRhbCkgZHJpdmVyICBmb3IgdGhlIFR5cGUgIDEgZm9ybWF0IHRoYXQgIHdpbGwgdWx0aW1hdGVseQogICAgcmVwbGFjZSB0aGUgb25lICBpbiAic3JjL3R5cGUxIi4gIEl0IHVzZXMgcGF0dGVybiBtYXRjaGluZyB0byBsb2FkCiAgICBkYXRhIGZyb20gdGhlIGZvbnQsIGluc3RlYWQgb2YgYSBmaW5pdGUgIHN0YXRlIGFuYWx5emVyLiAgSXQgd29ya3MKICAgIG11Y2ggYmV0dGVyIHRoYW4gdGhlICJvbGQiIGRyaXZlciB3aXRoICJicm9rZW4iIGZvbnRzLiAgSXQgaXMgYWxzbwogICAgbXVjaCBzbWFsbGVyICh1bmRlciAxNSBLYikuCgogIC0gdGhlICBUeXBlIDEgIGRyaXZlcnMgKGJvdGggIGluICJzcmMvdHlwZTEiICBhbmQgICJzcmMvdHlwZTF6IikgYXJlCiAgICBuZWFybHkgIGNvbXBsZXRlLiAgVGhleSAgYm90aCAgcHJvdmlkZSBhdXRvbWF0aWMgIFVuaWNvZGUgIGNoYXJtYXAKICAgIHN5bnRoZXNpcyB0aHJvdWdoICB0aGUgInBzbmFtZXMiIG1vZHVsZS4gIE5vIHJlLWVuY29kaW5nIHZlY3RvciBpcwogICAgbmVlZGVkLiAgKG5vdGUgIHRoYXQgdGhleSAgc3RpbGwgIGxlYWsgIG1lbW9yeSAgZHVlIHRvICBzb21lICBjb2RlCiAgICBtaXNzaW5nLCBhbmQgSSdtIGdldHRpbmcgbGF6eSkuCgogICAgVHJpdmlhbCBBRk0gc3VwcG9ydCBoYXMgYmVlbiBhZGRlZCB0byByZWFkIGtlcm5pbmcgaW5mb3JtYXRpb24gYnV0CiAgICB3YXNuJ3QgZXhhY3RseSB0ZXN0ZWQgYXMgaXQgc2hvdWxkIDstKQoKICAtIFRoZSBUcnVlVHlwZSAgZ2x5cGggbG9hZGVyIGhhcyAgYmVlbiBzZXJpb3VzbHkgcmV3cml0dGVuICAoc2VlIHRoZQogICAgZmlsZSAgInNyYy90cnVldHlwZS90dGdsb2FkLmMiLiAgSXQgaXMgbm93ICBtdWNoLCBtdWNoICBzaW1wbGVyIGFzCiAgICB3ZWxsIGFzICBlYXNpZXIgdG8gcmVhZCwgIG1haW50YWluIGFuZCB1bmRlcnN0YW5kICA6LSkgUHJlbGltaW5hcnkKICAgIHZlcnNpb25zIGludHJvZHVjZWQgYSAgbWVtb3J5IGxlYWsgdGhhdCBoYXMgYmVlbiAgcmVwb3J0ZWQgYnkgSmFjawogICAgRGF2aXMsIGFuZCBpcyBub3cgZml4ZWQuLgoKICAtIGludHJvZHVjZWQgIHRoZSBuZXcgICJmdF9nbHlwaF9mb3JtYXRfcGxvdHRlciIsIHVzZWQgIHRvIHJlcHJlc2VudAogICAgc3Ryb2tlZCBvdXRsaW5lcyAgbGlrZSBXaW5kb3dzICJWZWN0b3IiIGZvbnRzLCBhbmQgIGNlcnRhaW4gVHlwZSAxCiAgICBmb250cyAgbGlrZSAiSGVyc2hleSIuICBUaGUgY29ycmVzcG9uZGluZyAgcmFzdGVyIHdpbGwgIGJlIHdyaXR0ZW4KICAgIHNvb24uCgogIC0gRlRfTmV3X01lbW9yeV9GYWNlICBpcyAgZ29uZS4gIExpa2V3aXNlLCAgRlRfT3Blbl9GYWNlIGhhcyAgYSAgbmV3CiAgICBpbnRlcmZhY2UgdGhhdCB1c2VzIGEgc3RydWN0dXJlICB0byBkZXNjcmliZSB0aGUgaW5wdXQgc3RyZWFtLCB0aGUKICAgIGRyaXZlciAoaWYgcmVxdWlyZWQpLCBldGMuLgoKClRPRE8KCiAgLSBXcml0ZSBGVF9HZXRfR2x5cGhfQml0bWFwIGFuZCBGVF9Mb2FkX0dseXBoX0JpdG1hcAoKICAtIEFkZCBhIGZ1bmN0aW9uIGxpa2UgRlRfTG9hZF9DaGFyYWN0ZXIoIGZhY2UsIGNoYXJfY29kZSwgbG9hZF9mbGFncwogICAgKSAgdGhhdCAgd291bGQgcmVhbGx5ICBlbWJiZWQgIGEgIGNhbGwgIHRvIEZUX0dldF9DaGFyX0luZGV4ICB0aGVuCiAgICBGVF9Mb2FkX0dseXBoIHRvIGVhc2UgZGV2ZWxvcGVyJ3Mgd29yay4KCiAgLSBVcGRhdGUgdGhlIHR1dG9yaWFsIQoKICAtIGNvbnNpZGVyIGFkZGluZyAgc3VwcG9ydCBmb3IgTXVsdGlwbGUgIE1hc3RlciBmb250cyBpbiB0aGUgIFR5cGUgMQogICAgZHJpdmVycy4KCiAgLSBUZXN0IHRoZSBBRk0gcm91dGluZXMgb2YgdGhlICBUeXBlIDEgZHJpdmVycyB0byBjaGVjayB0aGF0IGtlcm5pbmcKICAgIGluZm9ybWF0aW9uIGlzIHJldHVybmVkIGNvcnJlY3RseS4KCiAgLSB3cml0ZSBhIGRlY2VudCBhdXRvLWdyaWRkaW5nIGNvbXBvbmVudCAgISEgV2UgbmVlZCB0aGlzIHRvIHJlbGVhc2UKICAgIEZyZWVUeXBlIDIuMCBnb2xkICEKCgpsZXNzIHVyZ2VudCBuZWVkczoKCiAgLSBhZGQgYSBDRkYvVHlwZTIgZHJpdmVyCiAgLSBhZGQgYSBCREYgZHJpdmVyCiAgLSBhZGQgYSBGTlQvUENGL0hCRiBkcml2ZXIKICAtIGFkZCBhIFNwZWVkbyBkcml2ZXIgZnJvbSB0aGUgWDExIHNvdXJjZXMKCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpPTERFUiBDSEFOR0VTIC0gMjctamFuLTIwMDAKCiAgLSB1cGRhdGVkIHRoZSAgInNmbnQiIG1vZHVsZSAgaW50ZXJmYWNlIHRvIGFsbG93ICBzZXZlcmFsIFNGTlQtYmFzZWQKICAgIGRyaXZlcnMgdG8gY28tZXhpc3QgcGVhY2VmdWxseQoKICAtIHVwZGF0ZWQgIHRoZSAiVDFfRmFjZSIgIHR5cGUgIHRvIGJldHRlciAgc2VwYXJhdGUgUG9zdHNjcmlwdCAgZm9udAogICAgY29udGVudCAgZnJvbSB0aGUgIHJlc3Qgb2YgIHRoZSBGVF9GYWNlICBzdHJ1Y3R1cmUuICBNaWdodCBiZSB1c2VkCiAgICBsYXRlciBieSB0aGUgQ0ZGL1R5cGUyIGRyaXZlci4uCgogIC0gYWRkZWQgYW4gZXhwZXJpbWVudGFsIHJlcGxhY2VtZW50IFR5cGUgMSBkcml2ZXIgZmVhdHVyaW5nIGFkdmFuY2VkCiAgICAoYW5kIHNwZWVkeSkgcGF0dGVybiBtYXRjaGluZyB0byByZXRyaWV2ZSB0aGUgZGF0YSBmcm9tIHBvc3RzY3JpcHQKICAgIGZvbnRzLgoKICAtIHZlcnkgbWlub3IgIGNoYW5nZXMgaW4gdGhlIGltcGxlbWVudGF0aW9uICBvZiBGVF9TZXRfQ2hhcl9TaXplIGFuZAogICAgRlRfU2V0X1BpeGVsX1NpemVzICh0aGV5IG5vdyBpbXBsZW1lbnQgZGVmYXVsdCB0byBsaWd0aGVuIHRoZSBmb250CiAgICBkcml2ZXIncyBjb2RlKS4KCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpPTEQgTUVTU0FHRQoKVGhpcyBmaWxlIHN1bW1hcml6ZXMgdGhlIGNoYW5nZXMgdGhhdCBvY2N1cmVkIHNpbmNlIHRoZSBsYXN0ICJiZXRhIiBvZgpGcmVlVHlwZSAyLiAgQmVjYXVzZSAgdGhlIGxpc3QgaXMgaW1wb3J0YW50LCBpdCAgaGFzIGJlZW4gZGl2aWRlZCBpbnRvCnNlcGFyYXRlIHNlY3Rpb25zOgoKVGFibGUgT2YgQ29udGVudHM6CgogICAgSSAgIEhpZ2gtTGV2ZWwgSW50ZXJmYWNlIChlYXNpZXIgISkKICAgSUkgICBEaXJlY3RvcnkgU3RydWN0dXJlCiAgSUlJICAgR2x5cGggSW1hZ2UgRm9ybWF0cwogICBJViAgIEJ1aWxkIFN5c3RlbQogICAgViAgIFBvcnRhYmlsaXR5CiAgIFZJICAgRm9udCBEcml2ZXJzCgoKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKSGlnaC1MZXZlbCBJbnRlcmZhY2U6CgogIFRoZSBoaWdoLWxldmVsIEFQSSBoYXMgYmVlbiBjb25zaWRlcmFibHkgc2ltcGxpZmllZC4gIEhlcmUgaXMgaG93OgoKICAgIC0gcmVzb3VyY2Ugb2JqZWN0cyBoYXZlIGRpc2FwcGVhcmVkLiAgdGhpcyBtZWFucyB0aGF0IGZhY2Ugb2JqZWN0cwogICAgICBjYW4gbm93IGJlIGNyZWF0ZWQgd2l0aCAgYSBzaW5nbGUgZnVuY3Rpb24gY2FsbCAoc2VlIEZUX05ld19GYWNlCiAgICAgIGFuZCBGVF9PcGVuX0ZhY2UpCgogICAgLSB3aGVuIGNhbGxpbmcgIGVpdGhlciBGVF9OZXdfRmFjZSAgJiBGVF9PcGVuX0ZhY2UsIGEgIHNpemUgb2JqZWN0CiAgICAgIGFuZCBhIGdseXBoIHNsb3Qgb2JqZWN0ICBhcmUgYXV0b21hdGljYWxseSBjcmVhdGVkIGZvciB0aGUgZmFjZSwKICAgICAgYW5kIGNhbiAgYmUgYWNjZXNzZWQgIHRocm91Z2ggImZhY2UtPmdseXBoIiBhbmQgICJmYWNlLT5zaXplIiBpZgogICAgICBvbmUgcmVhbGx5ICBuZWVkcyB0by4gICBJbiBtb3N0IGNhc2VzLCAgdGhlcmUncyBubyBuZWVkICB0byBjYWxsCiAgICAgIEZUX05ld19TaXplIG9yIEZUX05ld19HbHlwaC4KCiAgICAtIHNpbWlsYXJseSwgIEZUX0xvYWRfR2x5cGggIG5vdyAgb25seSAgdGFrZXMgIGEgICJmYWNlIiAgYXJndW1lbnQKICAgICAgKGluc3RlYWQgIG9mIGEgIGdseXBoICBzbG90ICBhbmQgYSAgc2l6ZSkuICBBbHNvLCBpdCdzICAicmVzdWx0IgogICAgICBwYXJhbWV0ZXIgaXMgIGdvbmUsIGFzIHRoZSBnbHlwaCAgaW1hZ2UgdHlwZSBpcyAgcmV0dXJuZWQgaW4gdGhlCiAgICAgIGZpZWxkICJmYWNlLT5nbHlwaC5mb3JtYXQiCgogICAgLSB0aGUgbGlzdCAgb2YgYXZhaWxhYmxlICBjaGFybWFwcyBpcyBkaXJlY3RseSAgYWNjZXNzaWJsZSB0aHJvdWdoCiAgICAgICJmYWNlLT5jaGFybWFwcyIsIGNvdW50aW5nICJmYWNlLT5udW1fY2hhcm1hcHMiICBlbGVtZW50cy4gIEVhY2gKICAgICAgY2hhcm1hcCAgaGFzIGFuICAnZW5jb2RpbmcnICBmaWVsZCB3aGljaCAgc3BlY2lmaWVzIHdoaWNoICBrbm93bgogICAgICBlbmNvZGluZyBpdCBkZWFscyB3aXRoLiAgVmFsaWQgdmFsdWVzIGFyZSwgZm9yIGV4YW1wbGU6CgogICAgICAgICAgZnRfZW5jb2RpbmdfdW5pY29kZSAgICAgIChmb3IgQVNDSUksIExhdGluLTEgYW5kIFVuaWNvZGUpCiAgICAgICAgICBmdF9lbmNvZGluZ19hcHBsZV9yb21hbgogICAgICAgICAgZnRfZW5jb2Rpbmdfc2ppcwogICAgICAgICAgZnRfZW5jb2RpbmdfYWRvYmVfc3RhbmRhcmQKICAgICAgICAgIGZ0X2VuY29kaW5nX2Fkb2JlX2V4cGVydAoKICAgICAgb3RoZXIgIHZhbHVlcyBtYXkgIGJlIGFkZGVkICBpbiB0aGUgIGZ1dHVyZS4gIEVhY2ggY2hhcm1hcCBzdGlsbAogICAgICBob2xkcyAgaXRzICJwbGF0Zm9ybV9pZCIgIGFuZCAiZW5jb2RpbmdfaWQiICB2YWx1ZXMgaW4gIGNhc2UgdGhlCiAgICAgIGVuY29kaW5nIGlzIHRvbyBleG90aWMgZm9yIHRoZSBjdXJyZW50IGxpYnJhcnkKCgotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpEaXJlY3RvcnkgU3RydWN0dXJlOgoKICBTaG91bGQgc2VlbSBvYnZpb3VzIHRvIG1vc3Qgb2YgeW91OgoKICAgICBmcmVldHlwZS8KICAgICAgICAgY29uZmlnLyAgICAgICAgLS0gY29uZmlndXJhdGlvbiBzdWItbWFrZWZpbGVzCiAgICAgICAgICAgIGFuc2kvCiAgICAgICAgICAgIHVuaXgvICAgICAgIC0tIHBsYXRmb3JtLXNwZWNpZmljIGNvbmZpZ3VyYXRpb24gZmlsZXMKICAgICAgICAgICAgd2luMzIvCiAgICAgICAgICAgIG9zMi8KICAgICAgICAgICAgbXNkb3MvCgogICAgICAgICBpbmNsdWRlLyAgICAgICAtLSBwdWJsaWMgaGVhZGVyICBmaWxlcywgdGhvc2UgdG8gIGJlIGluY2x1ZGVkCiAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpcmVjdGx5IGJ5IGNsaWVudCBhcHBzCgogICAgICAgICBzcmMvICAgICAgICAgICAtLSBzb3VyY2VzIG9mIHRoZSBsaWJyYXJ5CiAgICAgICAgICAgYmFzZS8gICAgICAgIC0tIHRoZSBiYXNlIGxheWVyCiAgICAgICAgICAgc2ZudC8gICAgICAgIC0tIHRoZSBzZm50ICJkcml2ZXIiICAoc2VlIHRoZSBkcml2ZXJzIHNlY3Rpb24KICAgICAgICAgICAgICAgICAgICAgICAgICAgYmVsb3cpCiAgICAgICAgICAgdHJ1ZXR5cGUvICAgIC0tIHRoZSB0cnVldHlwZSBkcml2ZXIKICAgICAgICAgICB0eXBlMS8gICAgICAgLS0gdGhlIHR5cGUxIGRyaXZlcgogICAgICAgICAgIHNoYXJlZC8gICAgICAtLSBzb21lIGhlYWRlciBmaWxlcyBzaGFyZWQgYmV0d2VlbiBkcml2ZXJzCgogICAgICAgICBkZW1vcy8gICAgICAgICAtLSBkZW1vcy90b29scwoKICAgICAgICAgZG9jcy8gICAgICAgICAgLS0gZG9jdW1lbnRhdGlvbiAoYSBiaXQgZW1wdHkgZm9yIG5vdykKCgotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpHbHlwaCBJbWFnZSBGb3JtYXRzOgoKICBEcml2ZXJzIGFyZSBub3cgYWJsZSB0byAgcmVnaXN0ZXIgbmV3IGdseXBoIGltYWdlIGZvcm1hdHMgd2l0aGluIHRoZQogIGxpYnJhcnkuICBGb3IgIG5vdywgdGhlICBiYXNlIGxheWVyIHN1cHBvcnRzICBvZiBjb3Vyc2UgIGJpdG1hcHMgYW5kCiAgdmVjdG9yICBvdXRsaW5lcywgYnV0ICBvbmUgIGNvdWxkIGltYWdpbmUgIHNvbWV0aGluZyBkaWZmZXJlbnQgIGxpa2UKICBjb2xvcmVkIGJpdG1hcHMsIGJpLWNvbG9yIHZlY3RvcnMgb3Igd2F0aGV2ZXIgZWxzZSAoTWV0YWZvbnRzIGFueW9uZQogID8/KS4KCiAgU2VlICB0aGUgICBmaWxlICBgaW5jbHVkZS9mdGltYWdlLmgnLiAgIE5vdGUgIGFsc28gIHRoYXQgICB0aGUgIHR5cGUKICBGVF9SYXN0ZXJfTWFwICBpcyBnb25lLCAgYW5kICBpcyBub3cgIHJlcGxhY2VkICBieSBGVF9CaXRtYXAsICB3aGljaAogIHNob3VsZCBlbmNvbXBhc3MgYWxsIGtub3duIGJpdG1hcCB0eXBlcy4KCiAgRWFjaCBuZXcgIGltYWdlIGZvcm1hdCAgbXVzdCBwcm92aWRlIGF0ICBsZWFzdCBvbmUgInJhc3RlciIsICBpLmUuIGEKICBtb2R1bGUgY2FwYWJsZSBvZiAgdHJhbnNmb3JtaW5nIHRoZSBnbHlwaCBpbWFnZSBpbnRvIGEgYml0bWFwLiAgSXQncwogIGFsc28gcG9zc2libGUgIHRvIGNoYW5nZSB0aGUgZGVmYXVsdCAgcmFzdGVyIHVzZWQgZm9yICBhIGdpdmVuIGdseXBoCiAgaW1hZ2UgZm9ybWF0LgoKICBUaGUgZGVmYXVsdCBvdXRsaW5lICBzY2FuLWNvbnZlcnRlciBub3cgdXNlcyAxMjggbGV2ZWxzICBvZiBncmF5cyBieQogIGRlZmF1bHQsICB3aGljaCB0ZW5kcyAgdG8gc21vb3RoICBtYW55ICB0aGluZ3MuICBOb3RlIHRoYXQgdGhlICBkZW1vCiAgcHJvZ3JhbXMgaGF2ZSBiZWVuIHVwZGF0ZWQgc2lnbmlmaWNhbnRseSBpbiBvcmRlciB0byBkaXNwbGF5IHRoZXNlLi4KCgotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpCdWlsZCBzeXN0ZW06CgogIFlvdSBzdGlsbCBuZWVkICBHTlUgTWFrZSB0byBidWlsZCB0aGUgbGlicmFyeS4gIFRoZSBidWlsZCBzeXN0ZW0gaGFzCiAgYmVlbiB2ZXJ5IHNlcmlvdXNseSByZS12YW1wZWQgaW4gb3JkZXIgdG8gcHJvdmlkZSB0aGluZ3MgbGlrZSA6CgogICAtIGF1dG9tYXRpYyBob3N0IHBsYXRmb3JtICBkZXRlY3Rpb24gKHJldmVydGluZyB0byAnY29uZmlnL2Fuc2knIGlmCiAgICAgaXQgaXMgbm90IGRldGVjdGVkLCB3aXRoIHBzZXVkby1zdGFuZGFyZCBjb21waWxhdGlvbiBmbGFncykKCiAgIC0gdGhlIGFiaWxpdHkgdG8gY29tcGlsZSBmcm9tIHRoZSBNYWtlZmlsZXMgd2l0aCB2ZXJ5IGRpZmZlcmVudCBhbmQKICAgICBleG90aWMgY29tcGlsZXJzLiAgTm90ZSB0aGF0IGxpbmtpbmcgdGhlIGxpYnJhcnkgY2FuIGJlIGRpZmZpY3VsdAogICAgIGZvciBzb21lIHBsYXRmb3Jtcy4KCiAgICAgRm9yIGV4YW1wbGUsIHRoZSBmaWxlIGBjb25maWcvd2luMzIvbGNjbGliLmJhdCcgaXMgaW52b2tlZCBieSB0aGUKICAgICBidWlsZCBzeXN0ZW0gdG8gY3JlYXRlIHRoZSAiLmxpYiIgZmlsZSB3aXRoIExDQy1XaW4zMiBiZWNhdXNlIGl0cwogICAgIGxpYnJhcmlhbiAgaGFzIHRvbyAgbWFueSBmbGF3cyAgdG8gYmUgIGludm9rZWQgZGlyZWN0bHkgIGZyb20gdGhlCiAgICAgTWFrZWZpbGUuCgogIEhlcmUncyBob3cgaXQgd29ya3M6CgogIC0gdGhlIGZpcnN0IHRpbWUgeW91IHR5cGUgYG1ha2UnLCAgdGhlIGJ1aWxkIHN5c3RlbSBydW5zIGEgc2VyaWVzIG9mCiAgICBzdWItbWFrZWZpbGVzICBpbiBvcmRlciAgdG8gZGV0ZWN0ICB5b3VyIGhvc3QgIHBsYXRmb3JtLiAgSXQgIHRoZW4KICAgIGR1bXBzIHdoYXQgaXQgZm91bmQsIGFuZCBjcmVhdGVzIGEgZmlsZSBjYWxsZWQgYGNvbmZpZy5taycgaW4gIHRoZQogICAgY3VycmVudCAgZGlyZWN0b3J5LiAgVGhpcyBpcyBhICBzdWItTWFrZWZpbGUgdXNlZCAgdG8gIGRlZmluZSBtYW55CiAgICBpbXBvcnRhbnQgTWFrZSB2YXJpYWJsZXMgdXNlZCB0byBidWlsZCB0aGUgbGlicmFyeS4KCiAgLSB0aGUgc2Vjb25kIHRpbWUsIHRoZSBidWlsZCBzeXN0ZW0gZGV0ZWN0cyB0aGUgYGNvbmZpZy5taycgdGhlbiB1c2UKICAgIGl0ICB0byAgYnVpbGQgdGhlICBsaWJyYXJ5LiAgQWxsIG9iamVjdCAgZmlsZXMgIGdvICBpbnRvICdvYmonICBieQogICAgZGVmYXVsdCwgIGFzIHdlbGwgIGFzIHRoZSAgbGlicmFyeSBmaWxlLCAgYnV0IHRoaXMgIGNhbiAgZWFzaWx5IGJlCiAgICBjaGFuZ2VkLgoKICBOb3RlIHRoYXQgIHlvdSBjYW4gcnVuICJtYWtlICBzZXR1cCIgdG8gZm9yY2UgIGFub3RoZXIgaG9zdCBwbGF0Zm9ybQogIGRldGVjdGlvbiAgZXZlbiAgIGlmICBhICBgY29uZmlnLm1rJyAgaXMgIHByZXNlbnQgICBpbiAgdGhlICBjdXJyZW50CiAgZGlyZWN0b3J5LiAgQW5vdGhlciBzb2x1dGlvbiAgaXMgIHNpbXBseSB0byAgZGVsZXRlICB0aGUgZmlsZSwgIHRoZW4KICByZS1ydW4gbWFrZS4KCiAgRmluYWxseSwgdGhlICBkZWZhdWx0IGNvbXBpbGVyICBmb3IgYWxsIHBsYXRmb3JtcyAgaXMgZ2NjICAoZm9yIG5vdywKICB0aGlzIHdpbGwgaG9wZWZ1bGx5IGNoYW5nZWQgaW4gdGhlIGZ1dHVyZSkuICBZb3UgY2FuIGhvd2V2ZXIgc3BlY2lmeQogIGEgZGlmZmVyZW50ICBjb21waWxlciBieSBzcGVjaWZ5aW5nICBpdCBhZnRlciB0aGUgJ3NldHVwJyAgdGFyZ2V0IGFzCiAgaW46CgogICAgICBnbnVtYWtlIHNldHVwIGxjYyAgICAgICAgIG9uIFdpbjMyIHRvIHVzZSB0aGUgTENDIGNvbXBpbGVyCiAgICAgIGdudW1ha2Ugc2V0dXAgdmlzdWFsYyAgICAgb24gV2luMzIgdG8gdXNlIFZpc3VhbCBDKysKCiAgU2VlICB0aGUgZmlsZSAgYGNvbmZpZy88c3lzdGVtPi9kZXRlY3QubWsnIGZvciAgYSBsaXN0ICBvZiBzdXBwb3J0ZWQKICBjb21waWxlcnMgZm9yIHlvdXIgcGxhdGZvcm1zLgoKICBJdCBzaG91bGQgYmUgcmVsYXRpdmVseSBlYXN5ICB0byB3cml0ZSBuZXcgZGV0ZWN0aW9uIHJ1bGVzIGZpbGVzIGFuZAogIGNvbmZpZy5tay4uCgogIEZpbmFsbHksIHRvICBidWlsZCB0aGUgZGVtbyBwcm9ncmFtcywgIGdvIHRvIGBkZW1vcycgIGFuZCBsYXVuY2ggR05VCiAgTWFrZSwgaXQgd2lsbCB1c2UgdGhlIGBjb25maWcubWsnICBpbiB0aGUgdG9wIGRpcmVjdG9yeSB0byBidWlsZCB0aGUKICB0ZXN0IHByb2dyYW1zLi4KCgotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpQb3J0YWJpbGl0eToKCiAgSW4gIHRoZSAgcHJldmlvdXMgIGJldGEsICBhICBzaW5nbGUgRlRfU3lzdGVtICBvYmplY3QgIHdhcyAgdXNlZCAgdG8KICBlbmNvbXBhc3MgIGFsbCAgbG93LWxldmVsICBvcGVyYXRpb25zIGxpa2UgIHRocmVhZCAgc3luY2hyb25pc2F0aW9uLAogIG1lbW9yeSBtYW5hZ2VtZW50IGFuZCBpL28gYWNjZXNzLiAgVGhpcyBoYXMgYmVlbiBncmVhdGx5IHNpbXBsaWZpZWQ6CgogICAgLSB0aHJlYWQgc3luY2hyb25pc2F0aW9uICBoYXMgYmVlbiBkcm9wcGVkLCBmb3IgIHRoZSBzaW1wbGUgcmVhc29uCiAgICAgIHRoYXQgdGhlIGxpYnJhcnkgIGlzIGFscmVhZHkgcmUtZW50cmFudCwgYW5kIHRoYXQgIGlmIHlvdSByZWFsbHkKICAgICAgbmVlZCAgdHdvICB0aHJlYWRzIGFjY2Vzc2luZyAgdGhlICBzYW1lICBGVF9MaWJyYXJ5LCB5b3UgIHNob3VsZAogICAgICByZWFsbHkgc3luY2hyb25pemUgYWNjZXNzIHRvIGl0IHlvdXJzZWxmIHdpdGggYSBzaW1wbGUgbXV0ZXguCgogICAgLSBtZW1vcnkgIG1hbmFnZW1lbnQgaXMgIHBlcmZvcm1lZCAgdGhyb3VnaCBhICB2ZXJ5IHNpbXBsZSAgb2JqZWN0CiAgICAgIGNhbGxlZCAiRlRfTWVtb3J5IiwgIHdoaWNoIHJlYWxseSBpcyBhIHRhYmxlICBjb250YWluaW5nIGEgdGFibGUKICAgICAgb2YgcG9pbnRlcnMgdG8gIGZ1bmN0aW9ucyBsaWtlIG1hbGxvYywgcmVhbGxvYyBhbmQgIGZyZWUgYXMgd2VsbAogICAgICBhcyBzb21lIHVzZXIgZGF0YSAoY2xvc3VyZSkuCgogICAgLSByZXNvdXJjZXMgaGF2ZSBkaXNhcHBlYXJlZCAodGhleSBjcmVhdGVkIG1vcmUgcHJvYmxlbXMgdGhhbiB0aGV5CiAgICAgIHNvbHZlZCksIGFuZCAgaS9vIG1hbmFnZW1lbnQgaGF2ZSAgYmVlbiBzaW1wbGlmaWVkIGdyZWF0bHkgIGFzIGEKICAgICAgcmVzdWx0LiAgU3RyZWFtcyBhcmUgIGRlZmluZWQgdGhyb3VnaCAgRlRfU3RyZWFtIG9iamVjdHMsICB3aGljaAogICAgICBjYW4gYmUgZWl0aGVyIG1lbW9yeS1iYXNlZCBvciBkaXNrLWJhc2VkLgoKICAgICAgTm90ZSB0aGF0ICBlYWNoIGZhY2UgIGhhcyBpdHMgb3duICBzdHJlYW0sIHdoaWNoIGlzICBjbG9zZWQgb25seQogICAgICB3aGVuICB0aGUgIGZhY2Ugb2JqZWN0ICBpcyAgZGVzdHJveWVkLiAgSGVuY2UsICBhIGZ1bmN0aW9uICBsaWtlCiAgICAgIFRUX0ZsdXNoX0ZhY2UgaW4gMS54IGNhbm5vdCBiZSBkaXJlY3RseSAgc3VwcG9ydGVkLiAgSG93ZXZlciwgaWYKICAgICAgeW91IHJlYWxseSBuZWVkIHNvbWV0aGluZyBsaWtlICB0aGlzLCB5b3UgY2FuIGVhc2lseSB0YWlsb3IgeW91cgogICAgICBvd24gc3RyZWFtcyAgdG8gYWNoaWV2ZSB0aGUgc2FtZSAgZmVhdHVyZSBhdCBhICBsb3dlciBsZXZlbCAoYW5kCiAgICAgIHVzZSBGVF9PcGVuX0ZhY2UgaW5zdGVhZCBvZiBGVF9OZXdfRmFjZSB0byBjcmVhdGUgdGhlIGZhY2UpLgoKICBTZWUgdGhlIGZpbGUgICJpbmNsdWRlL2Z0c3lzdGVtLmgiIGZvciBtb3JlIGRldGFpbHMsIGFzICB3ZWxsIGFzIHRoZQogIGltcGxlbWVudGF0aW9ucyBmb3VuZCBpbiAiY29uZmlnL3VuaXgiIGFuZCAiY29uZmlnL2Fuc2kiLgoKCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCkZvbnQgRHJpdmVyczoKCiAgVGhlICBGb250IERyaXZlciAgaW50ZXJmYWNlIGhhcyAgYmVlbiBtb2RpZmllZCAgaW4gb3JkZXIgIHRvIHN1cHBvcnQKICBleHRlbnNpb25zICYgdmVyc2lvbmluZy4KCgogIFRoZSAgbGlzdCBvZiAgdGhlIGZvbnQgIGRyaXZlcnMgdGhhdCAgYXJlIHN0YXRpY2FsbHkgIGxpbmtlZCAgdG8gdGhlCiAgbGlicmFyeSBhdCBjb21waWxlIHRpbWUgaXMgIG1hbmFnZWQgdGhyb3VnaCBhIG5ldyBjb25maWd1cmF0aW9uIGZpbGUKICBjYWxsZWQgYGNvbmZpZy88cGxhdGZvcm0+L2Z0bW9kdWxlLmgnLgoKICBUaGlzICBmaWxlIGlzICBhdXRvZ2VuZXJhdGVkICB3aGVuICBpbnZva2luZyAgYG1ha2UgbW9kdWxlcycuICAgVGhpcwogIHRhcmdldCAgd2lsbCAgcGFyc2UgIGFsbCAgc3ViLWRpcmVjdG9yaWVzICBvZiAgJ3NyYycsIGxvb2tpbmcgIGZvciBhCiAgIm1vZHVsZS5tayIgcnVsZXMgIGZpbGUsIHVzZWQgIHRvIGRlc2NyaWJlICB0aGUgZHJpdmVyIHRvICB0aGUgYnVpbGQKICBzeXN0ZW0uCgogIEhlbmNlLCBvbmUgIHNob3VsZCBjYWxsICBgbWFrZSBtb2R1bGVzJyBlYWNoICB0aW1lIGEgZm9udCAgZHJpdmVyIGlzCiAgYWRkZWQgb3IgcmVtb3ZlZCBmcm9tIHRoZSBgc3JjJyBkaXJlY3RvcnkuCgogIEZpbmFsbHksIHRoaXMgIHZlcnNpb24gIHByb3ZpZGVzICBhICJwc2V1ZG8tZHJpdmVyIiAgaW4gIGBzcmMvc2ZudCcuCiAgVGhpcyAgZHJpdmVyICBkb2Vzbid0ICBzdXBwb3J0ICBmb250ICBmaWxlcyAgZGlyZWN0bHksIGJ1dCAgcHJvdmlkZXMKICBzZXJ2aWNlcyB1c2VkIGJ5IGFsbCBUcnVlVHlwZS1saWtlIGZvbnQgZHJpdmVycy4gIEhlbmNlLCBpdHMgY29kZSBpcwogIHNoYXJlZCBiZXR3ZWVuICB0aGUgVHJ1ZVR5cGUgJiBPcGVuVHlwZSAgZm9udCBmb3JtYXRzLCAgYW5kIHBvc3NpYmx5CiAgbW9yZSBmb3JtYXRzIHRvIGNvbWUgaWYgd2UncmUgbHVja3kuLgoKCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCkV4dGVuc2lvbnMgc3VwcG9ydDoKCiAgVGhlIGV4dGVuc2lvbnMgc3VwcG9ydCBpcyBpbnNwaXJlZCBieSB0aGUgb25lIGZvdW5kIGluIDEueC4KCiAgTm93LCBlYWNoIGZvbnQgZHJpdmVyIGhhcyAgaXRzIG93biAiZXh0ZW5zaW9uIHJlZ2lzdHJ5Iiwgd2hpY2ggbGlzdHMKICB3aGljaCBleHRlbnNpb25zICBhcmUgYXZhaWxhYmxlICBmb3IgdGhlIGZvbnQgIGZhY2VzIG1hbmFnZWQgIGJ5IHRoZQogIGRyaXZlci4KCiAgRXh0ZW5zaW9uIGlkcyBhcmUgIG5vdyBzdHJpbmdzLCByYXRoZXIgdGhhbiA0LWJ5dGUgIHRhZ3MsIGFzIHRoaXMgaXMKICB1c3VhbGx5IG1vcmUgcmVhZGFibGUuCgogIEVhY2ggZXh0ZW5zaW9uIGhhczoKICAgIC0gc29tZSBkYXRhLCBhc3NvY2lhdGVkIHRvIGVhY2ggZmFjZSBvYmplY3QKICAgIC0gYW4gaW50ZXJmYWNlICh0YWJsZSBvZiBmdW5jdGlvbiBwb2ludGVycykKCiAgQW4gZXh0ZW5zaW9uICB0aGF0IGlzIGZvcm1hdC1zcGVjaWZpYyBzaG91bGQgIHNpbXBseSByZWdpc3RlciBpdHNlbGYKICB0byB0aGUgY29ycmVjdCBmb250IGRyaXZlci4gIEhlcmUgaXMgc29tZSBleGFtcGxlIGNvZGU6CgogICAvLyBSZWdpc3RlcmluZyBhbiBleHRlbnNpb25zCiAgIC8vCiAgIEZUX0Vycm9yICBGVF9Jbml0X1hYWFhfRXh0ZW5zaW9uKCBGVF9MaWJyYXJ5ICBsaWJyYXJ5ICkKICAgewogICAgIEZUX0RyaXZlckludGVyZmFjZSogIHR0X2RyaXZlcjsKCiAgICAgZHJpdmVyID0gRlRfR2V0X0RyaXZlciggbGlicmFyeSwgInRydWV0eXBlIiApOwogICAgIGlmICghZHJpdmVyKSByZXR1cm4gRlRfRXJyX1VuaW1wbGVtZW50ZWRfRmVhdHVyZTsKCiAgICAgcmV0dXJuIEZUX1JlZ2lzdGVyX0V4dGVuc2lvbiggZHJpdmVyLCAmZXh0ZW5zaW9uX2NsYXNzICk7CiAgIH0KCgogICAvLyBJbXBsZW1lbnRpbmcgdGhlIGV4dGVuc2lvbnMKICAgLy8KICAgRlRfRXJyb3IgIEZUX1Byb2NlZWRfRXh0ZW5zaW9uX1hYWCggRlRfRmFjZSAgZmFjZSApCiAgIHsKICAgICBGVF9YWFhfRXh0ZW5zaW9uICAgICAgICAgICAgZXh0OwogICAgIEZUX1hYWF9FeHRlbnNpb25fSW50ZXJmYWNlICBleHRfaW50ZXJmYWNlOwoKICAgICBleHQgPSBGVF9HZXRfRXh0ZW5zaW9uKCBmYWNlLCAiZXh0ZW5zaW9uaWQiLCAmZXh0X2ludGVyZmFjZSApOwogICAgIGlmICghZXh0KSByZXR1cm4gZXJyb3I7CgogICAgIHJldHVybiBleHRfaW50ZXJmYWNlLT5kb19pdChleHQpOwogICB9CgotLS0gZW5kIG9mIENIQU5HRVMgLS0tCg==