KysrKysrKysrKysKUHl0aG9uIE5ld3MKKysrKysrKysrKysKCihlZGl0b3JzOiBjaGVjayBORVdTLmhlbHAgZm9yIGluZm9ybWF0aW9uIGFib3V0IGVkaXRpbmcgTkVXUyB1c2luZyBSZVNULikKCldoYXQncyBOZXcgaW4gUHl0aG9uIDIuMyBhbHBoYSAyPwo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCipSZWxlYXNlIGRhdGU6IFhYLVhYWC0yMDAzKgoKQ29yZSBhbmQgYnVpbHRpbnMKLS0tLS0tLS0tLS0tLS0tLS0KCi0gZmlsdGVyIHJldHVybnMgbm93IFVuaWNvZGUgcmVzdWx0cyBmb3IgVW5pY29kZSBhcmd1bWVudHMuCgotIHJhd19pbnB1dCBjYW4gbm93IHJldHVybiBVbmljb2RlIG9iamVjdHMuCgotIExpc3Qgb2JqZWN0cycgc29ydCgpIG1ldGhvZCBub3cgYWNjZXB0cyBOb25lIGFzIHRoZSBjb21wYXJpc29uIGZ1bmN0aW9uLgogIFBhc3NpbmcgTm9uZSBpcyBzZW1hbnRpY2FsbHkgaWRlbnRpY2FsIHRvIGNhbGxpbmcgc29ydCgpIHdpdGggbm8KICBhcmd1bWVudHMuCgotIEZpeGVkIGNyYXNoIHdoZW4gcHJpbnRpbmcgYSBzdWJjbGFzcyBvZiBzdHIgYW5kIF9fc3RyX18gcmV0dXJuZWQgc2VsZi4KICBTZWUgU0YgYnVnICM2NjcxNDcuCgpFeHRlbnNpb24gbW9kdWxlcwotLS0tLS0tLS0tLS0tLS0tLQoKLSBUaGUgU1NMIG1vZHVsZSBub3cgaGFuZGxlcyBzb2NrZXRzIHdpdGggYSB0aW1lb3V0IHNldCBjb3JyZWN0bHkgKFNGCiAgcGF0Y2ggIzY3NTc1MCwgZml4aW5nIFNGIGJ1ZyAjNjc1NTUyKS4KCi0gQSBuZXcgbW9kdWxlIF9pY29udl9jb2RlYyBoYXMgYmVlbiBhZGRlZCwgdG8gZXhwb3NlIHRoZSBpY29udigzKQogIGxpYnJhcnkuCgotIG9zL3Bvc2l4bW9kdWxlIGhhcyBncm93biB0aGUgc3lzZXhpdHMuaCBjb25zdGFudHMgKEVYX09LIGFuZCBmcmllbmRzKS4KCi0gRml4ZWQgYnJva2VuIHRocmVhZHN0YXRlIHN3YXAgaW4gcmVhZGxpbmUgdGhhdCBjb3VsZCBjYXVzZSBmYXRhbAogIGVycm9ycyB3aGVuIGEgcmVhZGxpbmUgaG9vayB3YXMgYmVpbmcgaW52b2tlZCB3aGlsZSBhIGJhY2tncm91bmQKICB0aHJlYWQgd2FzIGFjdGl2ZS4gIChTRiBidWdzICM2NjA0NzYgYW5kICM1MTMwMzMuKQoKLSBmY250bCBub3cgZXhwb3NlcyB0aGUgc3Ryb3BzLmggSV8qIGNvbnN0YW50cy4KCi0gRml4IGEgY3Jhc2ggb24gU29sYXJpcyB0aGF0IG9jY3VycmVkIHdoZW4gY2FsbGluZyBjbG9zZSgpIG9uCiAgYW4gbW1hcCdlZCBmaWxlIHdoaWNoIHdhcyBhbHJlYWR5IGNsb3NlZC4gIChTRiBwYXRjaCAjNjY1OTEzKQoKLSBkYXRldGltZSBjaGFuZ2VzOgoKICBUaGUgZGF0ZXRpbWUgYW5kIGRhdGV0aW1ldHogY2xhc3NlcyBoYXZlIGJlZW4gY29sbGFwc2VkIGludG8gYSBzaW5nbGUKICBkYXRldGltZSBjbGFzcywgYW5kIGxpa2V3aXNlIHRoZSB0aW1lIGFuZCB0aW1ldHogY2xhc3NlcyBpbnRvIGEgc2luZ2xlCiAgdGltZSBjbGFzcy4gIFByZXZpb3VzbHksIGEgZGF0ZXRpbWV0eiBvYmplY3Qgd2l0aCB0emluZm89Tm9uZSBhY3RlZAogIGV4YWN0bHkgbGlrZSBhIGRhdGV0aW1lIG9iamVjdCwgYW5kIHNpbWlsYXJseSBmb3IgdGltZXR6LiAgVGhpcyB3YXNuJ3QKICBlbm91Z2ggb2YgYSBkaWZmZXJlbmNlIHRvIGp1c3RpZnkgZGlzdGluY3QgY2xhc3NlcywgYW5kIGxpZmUgaXMgc2ltcGxlcgogIG5vdy4KCiAgdG9kYXkoKSBhbmQgbm93KCkgbm93IHJvdW5kIHN5c3RlbSB0aW1lc3RhbXBzIHRvIHRoZSBjbG9zZXN0CiAgbWljcm9zZWNvbmQgPGh0dHA6Ly93d3cucHl0aG9uLm9yZy9zZi82NjEwODY+LiAgVGhpcyByZXBhaXJzIGFuCiAgaXJyaXRhdGlvbiBtb3N0IGxpa2VseSBzZWVuIG9uIFdpbmRvd3Mgc3lzdGVtcy4KCiAgSW4gZHQuYXN0aW1lem9uZSh0eiksIGlmIHR6LnV0Y29mZnNldChkdCkgcmV0dXJucyBhIGR1cmF0aW9uLAogIFZhbHVlRXJyb3IgaXMgcmFpc2VkIGlmIHR6LmRzdChkdCkgcmV0dXJucyBOb25lICgyLjNhMSB0cmVhdGVkIGl0CiAgYXMgMCBpbnN0ZWFkLCBidXQgYSB0emluZm8gc3ViY2xhc3Mgd2lzaGluZyB0byBwYXJ0aWNpcGF0ZSBpbgogIHRpbWUgem9uZSBjb252ZXJzaW9uIGhhcyB0byB0YWtlIGEgc3RhbmQgb24gd2hldGhlciBpdCBzdXBwb3J0cwogIERTVDsgaWYgeW91IGRvbid0IGNhcmUgYWJvdXQgRFNULCB0aGVuIGNvZGUgZHN0KCkgdG8gcmV0dXJuIDAgbWludXRlcywKICBtZWFuaW5nIHRoYXQgRFNUIGlzIG5ldmVyIGluIGVmZmVjdCkuCgogIFRoZSB0emluZm8gbWV0aG9kcyB1dGNvZmZzZXQoKSBhbmQgZHN0KCkgbXVzdCByZXR1cm4gYSB0aW1lZGVsdGEgb2JqZWN0CiAgKG9yIE5vbmUpIG5vdy4gIEluIDIuM2ExIHRoZXkgY291bGQgYWxzbyByZXR1cm4gYW4gaW50IG9yIGxvbmcsIGJ1dCB0aGF0CiAgd2FzIGFuIHVuaGVscGZ1bGx5IHJlZHVuZGFudCBsZWZ0b3ZlciBmcm9tIGFuIGVhcmxpZXIgdmVyc2lvbiB3aGVyZWluCiAgdGhleSBjb3VsZG4ndCByZXR1cm4gYSB0aW1lZGVsdGEuICBUT09XVERJLgoKICBUaGUgZXhhbXBsZSB0emluZm8gY2xhc3MgZm9yIGxvY2FsIHRpbWUgaGFkIGEgYnVnLiAgSXQgd2FzIHJlcGxhY2VkCiAgYnkgYSBsYXRlciBleGFtcGxlIGNvZGVkIGJ5IEd1aWRvLgoKICBkYXRldGltZS5hc3RpbWV6b25lKHR6KSBubyBsb25nZXIgcmFpc2VzIGFuIGV4Y2VwdGlvbiB3aGVuIHRoZQogIGlucHV0IGRhdGV0aW1lIGhhcyBubyBVVEMgZXF1aXZhbGVudCBpbiB0ei4gIEZvciB0eXBpY2FsICJoeWJyaWQiIHRpbWUKICB6b25lcyAoYSBzaW5nbGUgdHppbmZvIHN1YmNsYXNzIG1vZGVsaW5nIGJvdGggc3RhbmRhcmQgYW5kIGRheWxpZ2h0CiAgdGltZSksIHRoaXMgY2FzZSBjYW4gYXJpc2Ugb25lIGhvdXIgcGVyIHllYXIsIGF0IHRoZSBob3VyIGRheWxpZ2h0IHRpbWUKICBlbmRzLiAgU2VlIG5ldyBkb2NzIGZvciBkZXRhaWxzLiAgSW4gc2hvcnQsIHRoZSBuZXcgYmVoYXZpb3IgbWltaWNzCiAgdGhlIGxvY2FsIHdhbGwgY2xvY2sncyBiZWhhdmlvciBvZiByZXBlYXRpbmcgYW4gaG91ciBpbiBsb2NhbCB0aW1lLgoKICBkdC5hc3RpbWV6b25lKCkgY2FuIG5vIGxvbmdlciBiZSB1c2VkIHRvIGNvbnZlcnQgYmV0d2VlbiBuYWl2ZSBhbmQgYXdhcmUKICBkYXRldGltZSBvYmplY3RzLiAgSWYgeW91IG1lcmVseSB3YW50IHRvIGF0dGFjaCwgb3IgcmVtb3ZlLCBhIHR6aW5mbwogIG9iamVjdCwgd2l0aG91dCBhbnkgY29udmVyc2lvbiBvZiBkYXRlIGFuZCB0aW1lIG1lbWJlcnMsIHVzZQogIGR0LnJlcGxhY2UodHppbmZvPXdoYXRldmVyKSBpbnN0ZWFkLCB3aGVyZSAid2hhdGV2ZXIiIGlzIE5vbmUgb3IgYQogIHR6aW5mbyBzdWJjbGFzcyBpbnN0YW5jZS4KCiAgQSBuZXcgbWV0aG9kIHR6aW5mby5mcm9tdXRjKGR0KSBjYW4gYmUgb3ZlcnJpZGRlbiBpbiB0emluZm8gc3ViY2xhc3NlcwogIHRvIGdpdmUgY29tcGxldGUgY29udHJvbCBvdmVyIGhvdyBhIFVUQyB0aW1lIGlzIHRvIGJlIGNvbnZlcnRlZCB0bwogIGEgbG9jYWwgdGltZS4gIFRoZSBkZWZhdWx0IGFzdGltZXpvbmUoKSBpbXBsZW1lbnRhdGlvbiBjYWxscyBmcm9tdXRjKCkKICBhcyBpdHMgbGFzdCBzdGVwLCBzbyBhIHR6aW5mbyBzdWJjbGFzcyBjYW4gYWZmZWN0IHRoYXQgdG9vIGJ5IG92ZXJyaWRpbmcKICBmcm9tdXRjKCkuICBJdCdzIGV4cGVjdGVkIHRoYXQgdGhlIGRlZmF1bHQgZnJvbXV0YygpIGltcGxlbWVudGF0aW9uIHdpbGwKICBiZSBzdWl0YWJsZSBhcy1pcyBmb3IgImFsbW9zdCBhbGwiIHRpbWUgem9uZSBzdWJjbGFzc2VzLCBidXQgdGhlCiAgY3JlYXRpdml0eSBvZiBwb2xpdGljYWwgdGltZSB6b25lIGZpZGRsaW5nIGFwcGVhcnMgdW5ib3VuZGVkIC0tIGZyb211dGMoKQogIGFsbG93cyB0aGUgaGlnaGx5IG1vdGl2YXRlZCB0byBlbXVsYXRlIGFueSBzY2hlbWUgZXhwcmVzc2libGUgaW4gUHl0aG9uLgoKICBkYXRldGltZS5ub3coKTogIFRoZSBvcHRpb25hbCB0emluZm8gYXJndW1lbnQgd2FzIHVuZG9jdW1lbnRlZCAodGhhdCdzCiAgcmVwYWlyZWQpLCBhbmQgaXRzIG5hbWUgd2FzIGNoYW5nZWQgdG8gdHogKCJ0emluZm8iIGlzIG92ZXJsb2FkZWQgZW5vdWdoCiAgYWxyZWFkeSkuICBXaXRoIGEgdHogYXJndW1lbnQsIG5vdyh0eikgdXNlZCB0byByZXR1cm4gdGhlIGxvY2FsIGRhdGUKICBhbmQgdGltZSwgYW5kIGF0dGFjaCB0eiB0byBpdCwgd2l0aG91dCBhbnkgY29udmVyc2lvbiBvZiBkYXRlIGFuZCB0aW1lCiAgbWVtYmVycy4gIFRoaXMgd2FzIGxlc3MgdGhhbiB1c2VmdWwuICBOb3cgbm93KHR6KSByZXR1cm5zIHRoZSBjdXJyZW50CiAgZGF0ZSBhbmQgdGltZSBhcyBsb2NhbCB0aW1lIGluIHR6J3MgdGltZSB6b25lLCBha2luIHRvCiAgICAgIHR6LmZyb211dGMoZGF0ZXRpbWUudXRjbm93KCkucmVwbGFjZSh0emluZm89dXRjKSkKICB3aGVyZSAidXRjIiBpcyBhbiBpbnN0YW5jZSBvZiBhIHR6aW5mbyBzdWJjbGFzcyBtb2RlbGluZyBVVEMuICBXaXRob3V0CiAgYSB0eiBhcmd1bWVudCwgbm93KCkgY29udGludWVzIHRvIHJldHVybiB0aGUgY3VycmVudCBsb2NhbCBkYXRlIGFuZCB0aW1lLAogIGFzIGEgbmFpdmUgZGF0ZXRpbWUgb2JqZWN0LgoKICBkYXRldGltZS5mcm9tdGltZXN0YW1wKCk6ICBMaWtlIGRhdGV0aW1lLm5vdygpIGFib3ZlLCB0aGlzIGhhZCBsZXNzIHRoYW4KICB1c2VmdWwgYmVoYXZpb3Igd2hlbiB0aGUgb3B0aW9uYWwgdGluem8gYXJndW1lbnQgd2FzIHNwZWNpZmllZC4gIFNlZQogIGFsc28gU0YgYnVnIHJlcG9ydCA8aHR0cDovL3d3dy5weXRob24ub3JnL3NmLzY2MDg3Mj4uCgogIGRhdGUgYW5kIGRhdGV0aW1lIGNvbXBhcmlzb246ICBJbiBvcmRlciB0byBwcmV2ZW50IGNvbXBhcmlzb24gZnJvbQogIGZhbGxpbmcgYmFjayB0byB0aGUgZGVmYXVsdCBjb21wYXJlLW9iamVjdC1hZGRyZXNzZXMgc3RyYXRlZ3ksIHRoZXNlCiAgcmFpc2VkIFR5cGVFcnJvciB3aGVuZXZlciB0aGV5IGRpZG4ndCB1bmRlcnN0YW5kIHRoZSBvdGhlciBvYmplY3QgdHlwZS4KICBUaGV5IHN0aWxsIGRvLCBleGNlcHQgd2hlbiB0aGUgb3RoZXIgb2JqZWN0IGhhcyBhICJ0aW1ldHVwbGUiIGF0dHJpYnV0ZSwKICBpbiB3aGljaCBjYXNlIHRoZXkgcmV0dXJuIE5vdEltcGxlbWVudGVkIG5vdy4gIFRoaXMgZ2l2ZXMgb3RoZXIKICBkYXRldGltZSBvYmplY3RzIChlLmcuLCBteERhdGVUaW1lKSBhIGNoYW5jZSB0byBpbnRlcmNlcHQgdGhlCiAgY29tcGFyaXNvbi4KCiAgVGhlIGNvbnN0cnVjdG9ycyBidWlsZGluZyBhIGRhdGV0aW1lIGZyb20gYSB0aW1lc3RhbXAgY291bGQgcmFpc2UKICBWYWx1ZUVycm9yIGlmIHRoZSBwbGF0Zm9ybSBDIGxvY2FsdGltZSgpL2dtdGltZSgpIGluc2VydGVkICJsZWFwCiAgc2Vjb25kcyIuICBMZWFwIHNlY29uZHMgYXJlIGlnbm9yZWQgbm93LiAgT24gc3VjaCBwbGF0Zm9ybXMsIGl0J3MKICBwb3NzaWJsZSB0byBoYXZlIHRpbWVzdGFtcHMgdGhhdCBkaWZmZXIgYnkgYSBzZWNvbmQsIHlldCB3aGVyZQogIGRhdGV0aW1lcyBjb25zdHJ1Y3RlZCBmcm9tIHRoZW0gYXJlIGVxdWFsLgoKTGlicmFyeQotLS0tLS0tCgotIFRoZSBuZXcgcGlja2xldG9vbHMucHkgY29udGFpbnMgbG90cyBvZiBkb2N1bWVudGF0aW9uIGFib3V0IHBpY2tsZQogIGludGVybmFscywgYW5kIHN1cHBsaWVzIHNvbWUgaGVscGVycyBmb3Igd29ya2luZyB3aXRoIHBpY2tsZXMsIHN1Y2ggYXMKICBhIHN5bWJvbGljIHBpY2tsZSBkaXNhc3NlbWJsZXIuCgotIFhtbHJwY2xpYi5weSBub3cgc3VwcG9ydHMgdGhlIGJ1aWx0aW4gYm9vbGVhbiB0eXBlLgoKLSBweV9jb21waWxlIGhhcyBhIG5ldyAnZG9yYWlzZScgZmxhZyBhbmQgYSBuZXcgUHlDb21waWxlRXJyb3IKICBleGNlcHRpb24uCgotIFNpbXBsZVhNTFJQQ1NlcnZlciBub3cgc3VwcG9ydHMgQ0dJIHRocm91Z2ggdGhlIENHSVhNTFJQQ1JlcXVlc3RIYW5kbGVyCiAgY2xhc3MuCgotIFRoZSBzZXRzIG1vZHVsZSBub3cgcmFpc2VzIFR5cGVFcnJvciBpbiBfX2NtcF9fLCB0byBjbGFyaWZ5IHRoYXQKICBzZXRzIGFyZSBub3QgaW50ZW5kZWQgdG8gYmUgdGhyZWUtd2F5LWNvbXBhcmVkOyB0aGUgY29tcGFyaXNvbgogIG9wZXJhdG9ycyBhcmUgb3ZlcmxvYWRlZCBhcyBzdWJzZXQvc3VwZXJzZXQgdGVzdHMuCgotIEJhc3Rpb24ucHkgYW5kIHJleGVjLnB5IGFyZSBkaXNhYmxlZC4gIFRoZXNlIG1vZHVsZXMgYXJlIG5vdCBzYWZlIGluCiAgUHl0aG9uIDIuMi4gb3IgMi4zLgoKLSByZWFscGF0aCBpcyBub3cgZXhwb3J0ZWQgd2hlbiBkb2luZyBmcm9tIHBveGl4cGF0aCBpbXBvcnQgKi4KICBJdCBpcyBhbHNvIGV4cG9ydGVkIGZvciBudHBhdGgsIG1hY3BhdGgsIGFuZCBvczJlbXhwYXRoLgogIFNlZSBTRiBidWcgIzY1OTIyOC4KCi0gTmV3IG1vZHVsZSB0YXJmaWxlIGZyb20gTGFycyBHdXN05GJlbCBwcm92aWRlcyBhIGNvbXByZWhlbnNpdmUgaW50ZXJmYWNlCiAgdG8gdGFyIGFyY2hpdmUgZmlsZXMgd2l0aCB0cmFuc3BhcmVudCBnemlwIGFuZCBiemlwMiBjb21wcmVzc2lvbi4KICBTZWUgU0YgcGF0Y2ggIzY1MTA4Mi4KCi0gdXJscGFyc2UgY2FuIG5vdyBwYXJzZSBpbWFwOi8vIFVSTHMuICBTZWUgU0YgZmVhdHVyZSByZXF1ZXN0ICM2MTgwMjQuCgotIFRraW50ZXIuQ2FudmFzLnNjYW5fZHJhZ3RvKCkgcHJvdmlkZXMgYW4gb3B0aW9uYWwgcGFyYW1ldGVyIHRvIHN1cHBvcnQKICB0aGUgZ2FpbiB2YWx1ZSB3aGljaCBpcyBwYXNzZWQgdG8gVGsuICBTRiBidWcjIDYwMjI1OS4KCi0gRml4IGxvZ2dpbmcuaGFuZGxlcnMuU3lzTG9nSGFuZGxlciBwcm90b2NvbCB3aGVuIHVzaW5nIFVOSVggZG9tYWluIHNvY2tldHMuCiAgU2VlIFNGIHBhdGNoICM2NDI5NzQuCgpUb29scy9EZW1vcwotLS0tLS0tLS0tLQoKVEJECgpCdWlsZAotLS0tLQoKLSBPbiBzeXN0ZW1zIHdoaWNoIGJ1aWxkIHVzaW5nIHRoZSBjb25maWd1cmUgc2NyaXB0LCBjb21waWxlciBmbGFncyB3aGljaAogIHVzZWQgdG8gYmUgbHVtcGVkIHRvZ2V0aGVyIHVzaW5nIHRoZSBPUFQgZmxhZyBoYXZlIGJlZW4gc3BsaXQgaW50byB0d28KICBncm91cHMsIE9QVCBhbmQgQkFTRUNGTEFHUy4gIE9QVCBpcyBtZWFudCB0byBjYXJyeSBqdXN0IG9wdGltaXphdGlvbi0gYW5kCiAgZGVidWctcmVsYXRlZCBmbGFncyBsaWtlICItZyIgYW5kICItTzMiLiAgQkFTRUNGTEFHUyBpcyBtZWFudCB0byBjYXJyeQogIGNvbXBpbGVyIGZsYWdzIHRoYXQgYXJlIHJlcXVpcmVkIHRvIGdldCBhIGNsZWFuIGNvbXBpbGUuICBPbiBzb21lCiAgcGxhdGZvcm1zIChtYW55IExpbnV4IGZsYXZvcnMgaW4gcGFydGljdWxhcikgQkFTRUNGTEFHUyB3aWxsIGJlIGVtcHR5IGJ5CiAgZGVmYXVsdC4gIE9uIG90aGVycywgc3VjaCBhcyBNYWMgT1MgWCBhbmQgU0NPLCBpdCB3aWxsIGNvbnRhaW4gcmVxdWlyZWQKICBmbGFncy4gIFRoaXMgY2hhbmdlIGFsbG93cyBwZW9wbGUgYnVpbGRpbmcgUHl0aG9uIHRvIG92ZXJyaWRlIE9QVCB3aXRob3V0CiAgZmVhciBvZiBjbG9iYmVyaW5nIGNvbXBpbGVyIGZsYWdzIHdoaWNoIGFyZSByZXF1aXJlZCB0byBnZXQgYSBjbGVhbiBidWlsZC4KCi0gT24gRGFyd2luL01hYyBPUyBYIHBsYXRmb3JtcywgL3N3L2xpYiBhbmQgL3N3L2luY2x1ZGUgYXJlIGFkZGVkIHRvIHRoZQogIHJlbGV2YW50IHNlYXJjaCBsaXN0cyBpbiBzZXR1cC5weS4gIFRoaXMgYWxsb3dzIHVzZXJzIGJ1aWxkaW5nIFB5dGhvbiB0bwogIHRha2UgYWR2YW50YWdlIG9mIHRoZSBtYW55IHBhY2thZ2VzIGF2YWlsYWJsZSBmcm9tIHRoZSBmaW5rIHByb2plY3QKICA8aHR0cDovL2Zpbmsuc2YubmV0Lz4uCgotIEEgbmV3IE1ha2VmaWxlIHRhcmdldCwgc2NyaXB0c2luc3RhbGwsIGluc3RhbGxzIGEgbnVtYmVyIG9mIHVzZWZ1bCBzY3JpcHRzCiAgZnJvbSB0aGUgVG9vbHMvc2NyaXB0cyBkaXJlY3RvcnkuCgpDIEFQSQotLS0tLQoKLSBUaGUgUHlBcmdfUGFyc2UgZnVuY3Rpb25zIG5vdyByYWlzZSBhIFR5cGVFcnJvciBpbnN0ZWFkIG9mIHRydW5jYXRpbmcgZmxvYXQKICBhcmd1bWVudHMgaWYgYW4gaW50ZWdlciBpcyBzcGVjaWZpZWQgKHRoaXMgYWZmZWN0cyB0aGUgJ2InLCAnQicsICdoJywgJ0gnLAogICdpJywgYW5kICdsJyBjb2RlcykuCgoKTmV3IHBsYXRmb3JtcwotLS0tLS0tLS0tLS0tCgpUQkQKClRlc3RzCi0tLS0tCgpUQkQKCldpbmRvd3MKLS0tLS0tLQoKLSBUaGUgYnNkZGIgbW9kdWxlIG5vdyBzaGlwcyB3aXRoIFNsZWVweWNhdCdzIDQuMS4yNS5OQywgdGhlIGxhdGVzdAogIHJlbGVhc2Ugd2l0aG91dCBzdHJvbmcgY3J5cHRvZ3JhcGh5LgoKLSBzeXMucGF0aFswXSwgaWYgaXQgY29udGFpbnMgYSBkaXJlY3RvcnkgbmFtZSwgaXMgbm93IGFsd2F5cyBhbgogIGFic29sdXRlIHBhdGhuYW1lLgoKLSBUaGUgbmV3IGxvZ2dpbmcgcGFja2FnZSBpcyBub3cgaW5zdGFsbGVkIGJ5IHRoZSBXaW5kb3dzIGluc3RhbGxlci4gIEl0CiAgd2Fzbid0IGluIDIuM2ExIGR1ZSB0byBvdmVyc2lnaHQuCgpNYWMKLS0tCgotIFRoZXJlIGFyZSBuZXcgZGlhbG9ncyBFYXN5RGlhbG9ncy5Bc2tGaWxlRm9yT3BlbiwgQXNrRmlsZUZvclNhdmUKICBhbmQgQXNrRm9sZGVyLiBUaGUgb2xkIG1hY2ZzLlN0YW5kYXJkR2V0RmlsZSBhbmQgZnJpZW5kcyBhcmUgZGVwcmVjYXRlZC4KCi0gVHlwZSBDYXJib24uRmlsZS5GU0NhdGFsb2dJbmZvIGFuZCBzdXBwb3J0aW5nIG1ldGhvZHMgaGF2ZSBiZWVuIGltcGxlbWVudGVkLgogIFRoaXMgYWxzbyBtYWtlcyBtYWNmcy5GU1NwZWMuU2V0RGF0ZXMoKSB3b3JrIGFnYWluLgoKCldoYXQncyBOZXcgaW4gUHl0aG9uIDIuMyBhbHBoYSAxPwo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCipSZWxlYXNlIGRhdGU6IDMxLURlYy0yMDAyKgoKVHlwZS9jbGFzcyB1bmlmaWNhdGlvbiBhbmQgbmV3LXN0eWxlIGNsYXNzZXMKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCi0gT25lIGNhbiBub3cgYXNzaWduIHRvIF9fYmFzZXNfXyBhbmQgX19uYW1lX18gb2YgbmV3LXN0eWxlIGNsYXNzZXMuCgotIGRpY3QoKSBub3cgYWNjZXB0cyBrZXl3b3JkIGFyZ3VtZW50cyBzbyB0aGF0IGRpY3Qob25lPTEsIHR3bz0yKQogIGlzIHRoZSBlcXVpdmFsZW50IG9mIHsib25lIjogMSwgInR3byI6IDJ9LiAgQWNjb3JkaW5nbHksCiAgdGhlIGV4aXN0aW5nIChidXQgdW5kb2N1bWVudGVkKSAnaXRlbXMnIGtleXdvcmQgYXJndW1lbnQgaGFzCiAgYmVlbiBlbGltaW5hdGVkLiAgVGhpcyBtZWFucyB0aGF0IGRpY3QoaXRlbXM9c29tZU1hcHBpbmcpIG5vdyBoYXMKICBhIGRpZmZlcmVudCBtZWFuaW5nIHRoYW4gYmVmb3JlLgoKLSBpbnQoKSBub3cgcmV0dXJucyBhIGxvbmcgb2JqZWN0IGlmIHRoZSBhcmd1bWVudCBpcyBvdXRzaWRlIHRoZQogIGludGVnZXIgcmFuZ2UsIHNvIGludCgiNCIgKiAxMDAwKSwgaW50KDFlMjAwKSBhbmQgaW50KDFMPDwxMDAwKSB3aWxsCiAgYWxsIHJldHVybiBsb25nIG9iamVjdHMgaW5zdGVhZCBvZiByYWlzaW5nIGFuIE92ZXJmbG93RXJyb3IuCgotIEFzc2lnbm1lbnQgdG8gX19jbGFzc19fIGlzIGRpc2FsbG93ZWQgaWYgZWl0aGVyIHRoZSBvbGQgb3IgdGhlIG5ldwogIGNsYXNzIGlzIGEgc3RhdGljYWxseSBhbGxvY2F0ZWQgdHlwZSBvYmplY3QgKHN1Y2ggYXMgZGVmaW5lZCBieSBhbgogIGV4dGVuc2lvbiBtb2R1bGUpLiAgVGhpcyBwcmV2ZW50cyBhbm9tYWxpZXMgbGlrZSAyLl9fY2xhc3NfXyA9IGJvb2wuCgotIE5ldy1zdHlsZSBvYmplY3QgY3JlYXRpb24gYW5kIGRlYWxsb2NhdGlvbiBoYXZlIGJlZW4gc3BlZCB1cAogIHNpZ25pZmljYW50bHk7IHRoZXkgYXJlIG5vdyBmYXN0ZXIgdGhhbiBjbGFzc2ljIGluc3RhbmNlIGNyZWF0aW9uCiAgYW5kIGRlYWxsb2NhdGlvbi4KCi0gVGhlIF9fc2xvdHNfXyB2YXJpYWJsZSBjYW4gbm93IG1lbnRpb24gInByaXZhdGUiIG5hbWVzLCBhbmQgdGhlCiAgcmlnaHQgdGhpbmcgd2lsbCBoYXBwZW4gKGUuZy4gX19zbG90c19fID0gWyJfX2ZvbyJdKS4KCi0gVGhlIGJ1aWx0LWlucyBzbGljZSgpIGFuZCBidWZmZXIoKSBhcmUgbm93IGNhbGxhYmxlIHR5cGVzLiAgVGhlCiAgdHlwZXMgY2xhc3NvYmogKGZvcm1lcmx5IGNsYXNzKSwgY29kZSwgZnVuY3Rpb24sIGluc3RhbmNlLCBhbmQKICBpbnN0YW5jZW1ldGhvZCAoZm9ybWVybHkgaW5zdGFuY2UtbWV0aG9kKSwgd2hpY2ggaGF2ZSBubyBidWlsdC1pbgogIG5hbWVzIGJ1dCBhcmUgYWNjZXNzaWJsZSB0aHJvdWdoIHRoZSB0eXBlcyBtb2R1bGUsIGFyZSBub3cgYWxzbwogIGNhbGxhYmxlLiAgVGhlIHR5cGUgZGljdC1wcm94eSBpcyByZW5hbWVkIHRvIGRpY3Rwcm94eS4KCi0gQ3ljbGVzIGdvaW5nIHRocm91Z2ggdGhlIF9fY2xhc3NfXyBsaW5rIG9mIGEgbmV3LXN0eWxlIGluc3RhbmNlIGFyZQogIG5vdyBkZXRlY3RlZCBieSB0aGUgZ2FyYmFnZSBjb2xsZWN0b3IuCgotIENsYXNzZXMgdXNpbmcgX19zbG90c19fIGFyZSBub3cgcHJvcGVybHkgZ2FyYmFnZSBjb2xsZWN0ZWQuCiAgW1NGIGJ1ZyA1MTk2MjFdCgotIFRpZ2h0ZW5lZCB0aGUgX19zbG90c19fIHJ1bGVzOiBhIHNsb3QgbmFtZSBtdXN0IGJlIGEgdmFsaWQgUHl0aG9uCiAgaWRlbnRpZmllci4KCi0gVGhlIGNvbnN0cnVjdG9yIGZvciB0aGUgbW9kdWxlIHR5cGUgbm93IHJlcXVpcmVzIGEgbmFtZSBhcmd1bWVudCBhbmQKICB0YWtlcyBhbiBvcHRpb25hbCBkb2NzdHJpbmcgYXJndW1lbnQuICBQcmV2aW91c2x5LCB0aGlzIGNvbnN0cnVjdG9yCiAgaWdub3JlZCBpdHMgYXJndW1lbnRzLiAgQXMgYSBjb25zZXF1ZW5jZSwgZGVyaXZpbmcgYSBjbGFzcyBmcm9tIGEKICBtb2R1bGUgKG5vdCBmcm9tIHRoZSBtb2R1bGUgdHlwZSkgaXMgbm93IGlsbGVnYWw7IHByZXZpb3VzbHkgdGhpcwogIGNyZWF0ZWQgYW4gdW5uYW1lZCBtb2R1bGUsIGp1c3QgbGlrZSBpbnZva2luZyB0aGUgbW9kdWxlIHR5cGUgZGlkLgogIFtTRiBidWcgNTYzMDYwXQoKLSBBIG5ldyB0eXBlIG9iamVjdCwgJ2Jhc2VzdHJpbmcnLCBpcyBhZGRlZC4gIFRoaXMgaXMgYSBjb21tb24gYmFzZSB0eXBlCiAgZm9yICdzdHInIGFuZCAndW5pY29kZScsIGFuZCBjYW4gYmUgdXNlZCBpbnN0ZWFkIG9mCiAgdHlwZXMuU3RyaW5nVHlwZXMsIGUuZy4gdG8gdGVzdCB3aGV0aGVyIHNvbWV0aGluZyBpcyAiYSBzdHJpbmciOgogIGlzaW5zdGFuY2UoeCwgYmFzZXN0cmluZykgaXMgVHJ1ZSBmb3IgVW5pY29kZSBhbmQgOC1iaXQgc3RyaW5ncy4gIFRoaXMKICBpcyBhbiBhYnN0cmFjdCBiYXNlIGNsYXNzIGFuZCBjYW5ub3QgYmUgaW5zdGFudGlhdGVkIGRpcmVjdGx5LgoKLSBDaGFuZ2VkIG5ldy1zdHlsZSBjbGFzcyBpbnN0YW50aWF0aW9uIHNvIHRoYXQgd2hlbiBDJ3MgX19uZXdfXwogIG1ldGhvZCByZXR1cm5zIHNvbWV0aGluZyB0aGF0J3Mgbm90IGEgQyBpbnN0YW5jZSwgaXRzIF9faW5pdF9fIGlzCiAgbm90IGNhbGxlZC4gIFtTRiBidWcgIzUzNzQ1MF0KCi0gRml4ZWQgc3VwZXIoKSB0byB3b3JrIGNvcnJlY3RseSB3aXRoIGNsYXNzIG1ldGhvZHMuICBbU0YgYnVnICM1MzU0NDRdCgotIElmIHlvdSB0cnkgdG8gcGlja2xlIGFuIGluc3RhbmNlIG9mIGEgY2xhc3MgdGhhdCBoYXMgX19zbG90c19fIGJ1dAogIGRvZXNuJ3QgZGVmaW5lIG9yIG92ZXJyaWRlIF9fZ2V0c3RhdGVfXywgYSBUeXBlRXJyb3IgaXMgbm93IHJhaXNlZC4KICBUaGlzIGlzIGRvbmUgYnkgYWRkaW5nIGEgYm96byBfX2dldHN0YXRlX18gdG8gdGhlIGNsYXNzIHRoYXQgYWx3YXlzCiAgcmFpc2VzIFR5cGVFcnJvci4gIChCZWZvcmUsIHRoaXMgd291bGQgYXBwZWFyIHRvIGJlIHBpY2tsZWQsIGJ1dCB0aGUKICBzdGF0ZSBvZiB0aGUgc2xvdHMgd291bGQgYmUgbG9zdC4pCgpDb3JlIGFuZCBidWlsdGlucwotLS0tLS0tLS0tLS0tLS0tLQoKLSBJbXBvcnQgZnJvbSB6aXBmaWxlcyBpcyBub3cgc3VwcG9ydGVkLiAgVGhlIG5hbWUgb2YgYSB6aXBmaWxlIHBsYWNlZAogIG9uIHN5cy5wYXRoIGNhdXNlcyB0aGUgaW1wb3J0IHN0YXRlbWVudCB0byBsb29rIGZvciBpbXBvcnRhYmxlIFB5dGhvbgogIG1vZHVsZXMgKHdpdGggLnB5LCBweWMgYW5kIC5weW8gZXh0ZW5zaW9ucykgYW5kIHBhY2thZ2VzIGluc2lkZSB0aGUKICB6aXBmaWxlLiAgVGhlIHppcGZpbGUgaW1wb3J0IGZvbGxvd3MgdGhlIHNwZWNpZmljYXRpb24gKHRob3VnaCBub3QKICB0aGUgc2FtcGxlIGltcGxlbWVudGF0aW9uKSBvZiBQRVAgMjczLiAgVGhlIHNlbWFudGljcyBvZiBfX3BhdGhfXyBhcmUKICBjb21wYXRpYmxlIHdpdGggdGhvc2UgdGhhdCBoYXZlIGJlZW4gaW1wbGVtZW50ZWQgaW4gSnl0aG9uIHNpbmNlCiAgSnl0aG9uIDIuMS4KCi0gUEVQIDMwMiBoYXMgYmVlbiBhY2NlcHRlZC4gIEFsdGhvdWdoIGl0IHdhcyBpbml0aXRhbGx5IGRldmVsb3BlZCB0bwogIHN1cHBvcnQgemlwaW1wb3J0LCBpdCBvZmZlcnMgYSBuZXcsIGdlbmVyYWwgaW1wb3J0IGhvb2sgbWVjaGFuaXNtLgogIFNldmVyYWwgbmV3IHZhcmlhYmxlcyBoYXZlIGJlZW4gYWRkZWQgdG8gdGhlIHN5cyBtb2R1bGU6CiAgc3lzLm1ldGFfcGF0aCwgc3lzLnBhdGhfaG9va3MsIGFuZCBzeXMucGF0aF9pbXBvcnRlcl9jYWNoZTsgdGhlc2UKICBtYWtlIGV4dGVuZGluZyB0aGUgaW1wb3J0IHN0YXRlbWVudCBtdWNoIG1vcmUgY29udmVuaWVudCB0aGFuCiAgb3ZlcnJpZGluZyB0aGUgX19pbXBvcnRfXyBidWlsdC1pbiBmdW5jdGlvbi4gIEZvciBhIGRlc2NyaXB0aW9uIG9mCiAgdGhlc2UsIHNlZSBQRVAgMzAyLgoKLSBBIGZyYW1lIG9iamVjdCdzIGZfbGluZW5vIGF0dHJpYnV0ZSBjYW4gbm93IGJlIHdyaXR0ZW4gdG8gZnJvbSBhCiAgdHJhY2UgZnVuY3Rpb24gdG8gY2hhbmdlIHdoaWNoIGxpbmUgd2lsbCBleGVjdXRlIG5leHQuICBBIGNvbW1hbmQgdG8KICBleHBsb2l0IHRoaXMgZnJvbSBwZGIgaGFzIGJlZW4gYWRkZWQuICBbU0YgcGF0Y2ggIzY0MzgzNV0KCi0gVGhlIF9jb2RlY3Mgc3VwcG9ydCBtb2R1bGUgZm9yIGNvZGVjcy5weSB3YXMgdHVybmVkIGludG8gYSBidWlsdGluCiAgbW9kdWxlIHRvIGFzc3VyZSB0aGF0IGF0IGxlYXN0IHRoZSBidWlsdGluIGNvZGVjcyBhcmUgYXZhaWxhYmxlCiAgdG8gdGhlIFB5dGhvbiBwYXJzZXIgZm9yIHNvdXJjZSBjb2RlIGRlY29kaW5nIGFjY29yZGluZyB0byBQRVAgMjYzLgoKLSBpc3N1YmNsYXNzIG5vdyBzdXBwb3J0cyBhIHR1cGxlIGFzIHRoZSBzZWNvbmQgYXJndW1lbnQsIGp1c3QgbGlrZQogIGlzaW5zdGFuY2UgZG9lcy4gYGBpc3N1YmNsYXNzKFgsIChBLCBCKSlgYCBpcyBlcXVpdmFsZW50IHRvCiAgYGBpc3N1YmNsYXNzKFgsIEEpIG9yIGlzc3ViY2xhc3MoWCwgQilgYC4KCi0gVGhhbmtzIHRvIEFybWluIFJpZ28sIHRoZSBsYXN0IGtub3duIHdheSB0byBwcm92b2tlIGEgc3lzdGVtIGNyYXNoCiAgYnkgY2xldmVybHkgYXJyYW5naW5nIGZvciBhIGNvbXBhcmlzb24gZnVuY3Rpb24gdG8gbXV0YXRlIGEgbGlzdAogIGR1cmluZyBhIGxpc3Quc29ydCgpIG9wZXJhdGlvbiBoYXMgYmVlbiBmaXhlZC4gIFRoZSBlZmZlY3Qgb2YKICBhdHRlbXB0aW5nIHRvIG11dGF0ZSBhIGxpc3QsIG9yIGV2ZW4gdG8gaW5zcGVjdCBpdHMgY29udGVudHMgb3IKICBsZW5ndGgsIHdoaWxlIGEgc29ydCBpcyBpbiBwcm9ncmVzcywgaXMgbm90IGRlZmluZWQgYnkgdGhlIGxhbmd1YWdlLgogIFRoZSBDIGltcGxlbWVudGF0aW9uIG9mIFB5dGhvbiAyLjMgYXR0ZW1wdHMgdG8gZGV0ZWN0IG11dGF0aW9ucywKICBhbmQgcmFpc2UgVmFsdWVFcnJvciBpZiBvbmUgb2NjdXJzLCBidXQgdGhlcmUncyBubyBndWFyYW50ZWUgdGhhdAogIGFsbCBtdXRhdGlvbnMgd2lsbCBiZSBjYXVnaHQsIG9yIHRoYXQgYW55IHdpbGwgYmUgY2F1Z2h0IGFjcm9zcwogIHJlbGVhc2VzIG9yIGltcGxlbWVudGF0aW9ucy4KCi0gVW5pY29kZSBmaWxlIG5hbWUgcHJvY2Vzc2luZyBmb3IgV2luZG93cyAoUEVQIDI3NykgaXMgaW1wbGVtZW50ZWQuCiAgQWxsIHBsYXRmb3JtcyBub3cgaGF2ZSBhbiBvcy5wYXRoLnN1cHBvcnRzX3VuaWNvZGVfZmlsZW5hbWVzIGF0dHJpYnV0ZSwKICB3aGljaCBpcyBzZXQgdG8gVHJ1ZSBvbiBXaW5kb3dzIE5ULzIwMDAvWFAsIGFuZCBGYWxzZSBlbHNld2hlcmUuCgotIENvZGVjIGVycm9yIGhhbmRsaW5nIGNhbGxiYWNrcyAoUEVQIDI5MykgYXJlIGltcGxlbWVudGVkLgogIEVycm9yIGhhbmRsaW5nIGluIHVuaWNvZGUuZW5jb2RlIG9yIHN0ci5kZWNvZGUgY2FuIG5vdyBiZSBjdXN0b21pemVkLgoKLSBBIHN1YnRsZSBjaGFuZ2UgdG8gdGhlIHNlbWFudGljcyBvZiB0aGUgYnVpbHQtaW4gZnVuY3Rpb24gaW50ZXJuKCk6CiAgaW50ZXJuZWQgc3RyaW5ncyBhcmUgbm8gbG9uZ2VyIGltbW9ydGFsLiAgWW91IG11c3Qga2VlcCBhIHJlZmVyZW5jZQogIHRvIHRoZSByZXR1cm4gdmFsdWUgaW50ZXJuKCkgYXJvdW5kIHRvIGdldCB0aGUgYmVuZWZpdC4KCi0gVXNlIG9mICdOb25lJyBhcyBhIHZhcmlhYmxlLCBhcmd1bWVudCBvciBhdHRyaWJ1dGUgbmFtZSBub3cKICBpc3N1ZXMgYSBTeW50YXhXYXJuaW5nLiAgSW4gdGhlIGZ1dHVyZSwgTm9uZSBtYXkgYmVjb21lIGEga2V5d29yZC4KCi0gU0VUX0xJTkVOTyBpcyBnb25lLiAgY29fbG5vdGFiIGlzIG5vdyBjb25zdWx0ZWQgdG8gZGV0ZXJtaW5lIHdoZW4gdG8KICBjYWxsIHRoZSB0cmFjZSBmdW5jdGlvbi4gIEMgY29kZSB0aGF0IGFjY2Vzc2VkIGZfbGluZW5vIHNob3VsZCBjYWxsCiAgUHlDb2RlX0FkZHIyTGluZSBpbnN0ZWFkIChmX2xpbmVubyBpcyBzdGlsbCB0aGVyZSwgYnV0IG9ubHkga2VwdCB1cAogIHRvIGRhdGUgd2hlbiB0aGVyZSBpcyBhIHRyYWNlIGZ1bmN0aW9uIHNldCkuCgotIFRoZXJlJ3MgYSBuZXcgd2FybmluZyBjYXRlZ29yeSwgRnV0dXJlV2FybmluZy4gIFRoaXMgaXMgdXNlZCB0byB3YXJuCiAgYWJvdXQgYSBudW1iZXIgb2Ygc2l0dWF0aW9ucyB3aGVyZSB0aGUgdmFsdWUgb3Igc2lnbiBvZiBhbiBpbnRlZ2VyCiAgcmVzdWx0IHdpbGwgY2hhbmdlIGluIFB5dGhvbiAyLjQgYXMgYSByZXN1bHQgb2YgUEVQIDIzNyAoaW50ZWdlcgogIHVuaWZpY2F0aW9uKS4gIFRoZSB3YXJuaW5ncyBpbXBsZW1lbnQgc3RhZ2UgQjAgbWVudGlvbmVkIGluIHRoYXQKICBQRVAuICBUaGUgd2FybmluZ3MgYXJlIGFib3V0IHRoZSBmb2xsb3dpbmcgc2l0dWF0aW9uczoKCiAgICAtIE9jdGFsIGFuZCBoZXggbGl0ZXJhbHMgd2l0aG91dCAnTCcgcHJlZml4IGluIHRoZSBpbmNsdXNpdmUgcmFuZ2UKICAgICAgWzB4ODAwMDAwMDAuLjB4ZmZmZmZmZmZdOyB0aGVzZSBhcmUgY3VycmVudGx5IG5lZ2F0aXZlIGludHMsIGJ1dAogICAgICBpbiBQeXRob24gMi40IHRoZXkgd2lsbCBiZSBwb3NpdGl2ZSBsb25ncyB3aXRoIHRoZSBzYW1lIGJpdAogICAgICBwYXR0ZXJuLgoKICAgIC0gTGVmdCBzaGlmdHMgb24gaW50ZWdlciB2YWx1ZXMgdGhhdCBjYXVzZSB0aGUgb3V0Y29tZSB0byBsb3NlCiAgICAgIGJpdHMgb3IgaGF2ZSBhIGRpZmZlcmVudCBzaWduIHRoYW4gdGhlIGxlZnQgb3BlcmFuZC4gIFRvIGJlCiAgICAgIHByZWNpc2U6IHg8PG4gd2hlcmUgdGhpcyBjdXJyZW50bHkgZG9lc24ndCB5aWVsZCB0aGUgc2FtZSB2YWx1ZQogICAgICBhcyBsb25nKHgpPDxuOyBpbiBQeXRob24gMi40LCB0aGUgb3V0Y29tZSB3aWxsIGJlIGxvbmcoeCk8PG4uCgogICAgLSBDb252ZXJzaW9ucyBmcm9tIGludHMgdG8gc3RyaW5nIHRoYXQgc2hvdyBuZWdhdGl2ZSB2YWx1ZXMgYXMKICAgICAgdW5zaWduZWQgaW50cyBpbiB0aGUgaW5jbHVzaXZlIHJhbmdlIFsweDgwMDAwMDAwLi4weGZmZmZmZmZmXTsKICAgICAgdGhpcyBhZmZlY3RzIHRoZSBmdW5jdGlvbnMgaGV4KCkgYW5kIG9jdCgpLCBhbmQgdGhlIHN0cmluZwogICAgICBmb3JtYXR0aW5nIGNvZGVzICV1LCAlbywgJXgsIGFuZCAlWC4gIEluIFB5dGhvbiAyLjQsIHRoZXNlIHdpbGwKICAgICAgc2hvdyBzaWduZWQgdmFsdWVzIChlLmcuIGhleCgtMSkgY3VycmVudGx5IHJldHVybnMgIjB4ZmZmZmZmZmYiOwogICAgICBpbiBQeXRob24gMi40IGl0IHdpbGwgcmV0dXJuICItMHgxIikuCgotIFRoZSBiaXRzIG1hbmlwdWxhdGVkIHVuZGVyIHRoZSBjb3ZlciBieSBzeXMuc2V0Y2hlY2tpbnRlcnZhbCgpIGhhdmUKICBiZWVuIGNoYW5nZWQuICBCb3RoIHRoZSBjaGVjayBpbnRlcnZhbCBhbmQgdGhlIHRpY2tlciB1c2VkIHRvIGJlCiAgcGVyLXRocmVhZCB2YWx1ZXMuICBUaGV5IGFyZSBub3cganVzdCBhIHBhaXIgb2YgZ2xvYmFsIHZhcmlhYmxlcy4KICBJbiBhZGRpdGlvbiwgdGhlIGRlZmF1bHQgY2hlY2sgaW50ZXJ2YWwgd2FzIGJvb3N0ZWQgZnJvbSAxMCB0byAxMDAKICBieXRlY29kZSBpbnN0cnVjdGlvbnMuICBUaGlzIG1heSBoYXZlIHNvbWUgZWZmZWN0IG9uIHN5c3RlbXMgdGhhdAogIHJlbGllZCBvbiB0aGUgb2xkIGRlZmF1bHQgdmFsdWUuICBJbiBwYXJ0aWN1bGFyLCBpbiBtdWx0aS10aHJlYWRlZAogIGFwcGxpY2F0aW9ucyB3aGljaCB0cnkgdG8gYmUgaGlnaGx5IHJlc3BvbnNpdmUsIHJlc3BvbnNlIHRpbWUgd2lsbAogIGluY3JlYXNlIGJ5IHNvbWUgKHBlcmhhcHMgaW1wZXJjZXB0aWJsZSkgYW1vdW50LgoKLSBXaGVuIG11bHRpcGx5aW5nIHZlcnkgbGFyZ2UgaW50ZWdlcnMsIGEgdmVyc2lvbiBvZiB0aGUgc28tY2FsbGVkCiAgS2FyYXRzdWJhIGFsZ29yaXRobSBpcyBub3cgdXNlZC4gIFRoaXMgaXMgbW9zdCBlZmZlY3RpdmUgaWYgdGhlCiAgaW5wdXRzIGhhdmUgcm91Z2hseSB0aGUgc2FtZSBzaXplLiAgSWYgdGhleSBib3RoIGhhdmUgYWJvdXQgTiBkaWdpdHMsCiAgS2FyYXRzdWJhIG11bHRpcGxpY2F0aW9uIGhhcyBPKE4qKjEuNTgpIHJ1bnRpbWUgKHRoZSBleHBvbmVudCBpcwogIGxvZ19iYXNlXzIoMykpIGluc3RlYWQgb2YgdGhlIHByZXZpb3VzIE8oTioqMikuICBNZWFzdXJlZCByZXN1bHRzIG1heQogIGJlIGJldHRlciBvciB3b3JzZSB0aGFuIHRoYXQsIGRlcGVuZGluZyBvbiBwbGF0Zm9ybSBxdWlya3MuICBCZXNpZGVzCiAgdGhlIE8oKSBpbXByb3ZlbWVudCBpbiByYXcgaW5zdHJ1Y3Rpb24gY291bnQsIHRoZSBLYXJhdHN1YmEgYWxnb3JpdGhtCiAgYXBwZWFycyB0byBoYXZlIG11Y2ggYmV0dGVyIGNhY2hlIGJlaGF2aW9yIG9uIGV4dHJlbWVseSBsYXJnZSBpbnRlZ2VycwogIChzdGFydGluZyBpbiB0aGUgYmFsbHBhcmsgb2YgYSBtaWxsaW9uIGJpdHMpLiAgTm90ZSB0aGF0IHRoaXMgaXMgYQogIHNpbXBsZSBpbXBsZW1lbnRhdGlvbiwgYW5kIHRoZXJlJ3Mgbm8gaW50ZW50IGhlcmUgdG8gY29tcGV0ZSB3aXRoLAogIGUuZy4sIEdNUC4gIEl0IGdpdmVzIGEgdmVyeSBuaWNlIHNwZWVkdXAgd2hlbiBpdCBhcHBsaWVzLCBidXQgYSBwYWNrYWdlCiAgZGV2b3RlZCB0byBmYXN0IGxhcmdlLWludGVnZXIgYXJpdGhtZXRpYyBzaG91bGQgcnVuIGNpcmNsZXMgYXJvdW5kIGl0LgoKLSB1JyVjJyB3aWxsIG5vdyByYWlzZSBhIFZhbHVlRXJyb3IgaW4gY2FzZSB0aGUgYXJndW1lbnQgaXMgYW4KICBpbnRlZ2VyIG91dHNpZGUgdGhlIHZhbGlkIHJhbmdlIG9mIFVuaWNvZGUgY29kZSBwb2ludCBvcmRpbmFscy4KCi0gVGhlIHRlbXBmaWxlIG1vZHVsZSBoYXMgYmVlbiBvdmVyaGF1bGVkIGZvciBlbmhhbmNlZCBzZWN1cml0eS4gIFRoZQogIG1rdGVtcCgpIGZ1bmN0aW9uIGlzIG5vdyBkZXByZWNhdGVkOyBuZXcsIHNhZmUgcmVwbGFjZW1lbnRzIGFyZQogIG1rc3RlbXAoKSAoZm9yIGZpbGVzKSBhbmQgbWtkdGVtcCgpIChmb3IgZGlyZWN0b3JpZXMpLCBhbmQgdGhlCiAgaGlnaGVyLWxldmVsIGZ1bmN0aW9ucyBOYW1lZFRlbXBvcmFyeUZpbGUoKSBhbmQgVGVtcG9yYXJ5RmlsZSgpLgogIFVzZSBvZiBzb21lIGdsb2JhbCB2YXJpYWJsZXMgaW4gdGhpcyBtb2R1bGUgaXMgYWxzbyBkZXByZWNhdGVkOyB0aGUKICBuZXcgZnVuY3Rpb25zIGhhdmUga2V5d29yZCBhcmd1bWVudHMgdG8gcHJvdmlkZSB0aGUgc2FtZQogIGZ1bmN0aW9uYWxpdHkuICBBbGwgTGliLCBUb29scyBhbmQgRGVtbyBtb2R1bGVzIHRoYXQgdXNlZCB0aGUgdW5zYWZlCiAgaW50ZXJmYWNlcyBoYXZlIGJlZW4gdXBkYXRlZCB0byB1c2UgdGhlIHNhZmUgcmVwbGFjZW1lbnRzLiAgVGhhbmtzCiAgdG8gWmFjayBXZWluYmVyZyEKCi0gV2hlbiB4IGlzIGFuIG9iamVjdCB3aG9zZSBjbGFzcyBpbXBsZW1lbnRzIF9fbXVsX18gYW5kIF9fcm11bF9fLAogIDEuMCp4IHdvdWxkIGNvcnJlY3RseSBpbnZva2UgX19ybXVsX18sIGJ1dCAxKnggd291bGQgZXJyb25lb3VzbHkKICBpbnZva2UgX19tdWxfXy4gIFRoaXMgd2FzIGR1ZSB0byB0aGUgc2VxdWVuY2UtcmVwZWF0IGNvZGUgaW4gdGhlIGludAogIHR5cGUuICBUaGlzIGhhcyBiZWVuIGZpeGVkIG5vdy4KCi0gUHJldmlvdXNseSwgInN0cjEgaW4gc3RyMiIgcmVxdWlyZWQgc3RyMSB0byBiZSBhIHN0cmluZyBvZiBsZW5ndGggMS4KICBUaGlzIHJlc3RyaWN0aW9uIGhhcyBiZWVuIHJlbGF4ZWQgdG8gYWxsb3cgc3RyMSB0byBiZSBhIHN0cmluZyBvZgogIGFueSBsZW5ndGguICBUaHVzICInZWwnIGluICdoZWxsbyB3b3JsZCciIHJldHVybnMgVHJ1ZSBub3cuCgotIEZpbGUgb2JqZWN0cyBhcmUgbm93IHRoZWlyIG93biBpdGVyYXRvcnMuICBGb3IgYSBmaWxlIGYsIGl0ZXIoZikgbm93CiAgcmV0dXJucyBmICh1bmxlc3MgZiBpcyBjbG9zZWQpLCBhbmQgZi5uZXh0KCkgaXMgc2ltaWxhciB0bwogIGYucmVhZGxpbmUoKSB3aGVuIEVPRiBpcyBub3QgcmVhY2hlZDsgaG93ZXZlciwgZi5uZXh0KCkgdXNlcyBhCiAgcmVhZGFoZWFkIGJ1ZmZlciB0aGF0IG1lc3NlcyB1cCB0aGUgZmlsZSBwb3NpdGlvbiwgc28gbWl4aW5nCiAgZi5uZXh0KCkgYW5kIGYucmVhZGxpbmUoKSAob3Igb3RoZXIgbWV0aG9kcykgZG9lc24ndCB3b3JrIHJpZ2h0LgogIENhbGxpbmcgZi5zZWVrKCkgZHJvcHMgdGhlIHJlYWRhaGVhZCBidWZmZXIsIGJ1dCBvdGhlciBvcGVyYXRpb25zCiAgZG9uJ3QuICBJdCBzbyBoYXBwZW5zIHRoYXQgdGhpcyBnaXZlcyBhIG5pY2UgYWRkaXRpb25hbCBzcGVlZCBib29zdAogIHRvICJmb3IgbGluZSBpbiBmaWxlOiI7IHRoZSB4cmVhZGxpbmVzIG1ldGhvZCBhbmQgY29ycmVzcG9uZGluZwogIG1vZHVsZSBhcmUgbm93IG9ic29sZXRlLiAgVGhhbmtzIHRvIE9yZW4gVGlyb3NoIQoKLSBFbmNvZGluZyBkZWNsYXJhdGlvbnMgKFBFUCAyNjMsIHBoYXNlIDEpIGhhdmUgYmVlbiBpbXBsZW1lbnRlZC4gIEEKICBjb21tZW50IG9mIHRoZSBmb3JtICIjIC0qLSBjb2Rpbmc6IDxlbmNvZGluZ25hbWU+IC0qLSIgaW4gdGhlIGZpcnN0CiAgb3Igc2Vjb25kIGxpbmUgb2YgYSBQeXRob24gc291cmNlIGZpbGUgaW5kaWNhdGVzIHRoZSBlbmNvZGluZy4KCi0gbGlzdC5zb3J0KCkgaGFzIGEgbmV3IGltcGxlbWVudGF0aW9uLiAgV2hpbGUgY3Jvc3MtcGxhdGZvcm0gcmVzdWx0cwogIG1heSB2YXJ5LCBhbmQgaW4gZGF0YS1kZXBlbmRlbnQgd2F5cywgdGhpcyBpcyBtdWNoIGZhc3RlciBvbiBtYW55CiAga2luZHMgb2YgcGFydGlhbGx5IG9yZGVyZWQgbGlzdHMgdGhhbiB0aGUgcHJldmlvdXMgaW1wbGVtZW50YXRpb24sCiAgYW5kIHJlcG9ydGVkIHRvIGJlIGp1c3QgYXMgZmFzdCBvbiByYW5kb21seSBvcmRlcmVkIGxpc3RzIG9uCiAgc2V2ZXJhbCBtYWpvciBwbGF0Zm9ybXMuICBUaGlzIHNvcnQgaXMgYWxzbyBzdGFibGUgKGlmIEE9PUIgYW5kIEEKICBwcmVjZWRlcyBCIGluIHRoZSBsaXN0IGF0IHRoZSBzdGFydCwgQSBwcmVjZWRlcyBCIGFmdGVyIHRoZSBzb3J0IHRvbyksCiAgYWx0aG91Z2ggdGhlIGxhbmd1YWdlIGRlZmluaXRpb24gZG9lcyBub3QgZ3VhcmFudGVlIHN0YWJpbGl0eS4gIEEKICBwb3RlbnRpYWwgZHJhd2JhY2sgaXMgdGhhdCBsaXN0LnNvcnQoKSBtYXkgcmVxdWlyZSB0ZW1wIHNwYWNlIG9mCiAgbGVuKGxpc3QpKjIgYnl0ZXMgKGBgKjRgYCBvbiBhIDY0LWJpdCBtYWNoaW5lKS4gIEl0J3MgdGhlcmVmb3JlIHBvc3NpYmxlCiAgZm9yIGxpc3Quc29ydCgpIHRvIHJhaXNlIE1lbW9yeUVycm9yIG5vdywgZXZlbiBpZiBhIGNvbXBhcmlzb24gZnVuY3Rpb24KICBkb2VzIG5vdC4gIFNlZSA8aHR0cDovL3d3dy5weXRob24ub3JnL3NmLzU4NzA3Nj4gZm9yIGZ1bGwgZGV0YWlscy4KCi0gQWxsIHN0YW5kYXJkIGl0ZXJhdG9ycyBub3cgZW5zdXJlIHRoYXQsIG9uY2UgU3RvcEl0ZXJhdGlvbiBoYXMgYmVlbgogIHJhaXNlZCwgYWxsIGZ1dHVyZSBjYWxscyB0byBuZXh0KCkgb24gdGhlIHNhbWUgaXRlcmF0b3Igd2lsbCBhbHNvCiAgcmFpc2UgU3RvcEl0ZXJhdGlvbi4gIFRoZXJlIHVzZWQgdG8gYmUgdmFyaW91cyBjb3VudGVyZXhhbXBsZXMgdG8KICB0aGlzIGJlaGF2aW9yLCB3aGljaCBjb3VsZCBjYXVzZWQgY29uZnVzaW9uIG9yIHN1YnRsZSBwcm9ncmFtCiAgYnJlYWthZ2UsIHdpdGhvdXQgYW55IGJlbmVmaXRzLiAgKE5vdGUgdGhhdCB0aGlzIGlzIHN0aWxsIGFuCiAgaXRlcmF0b3IncyByZXNwb25zaWJpbGl0eTsgdGhlIGl0ZXJhdG9yIGZyYW1ld29yayBkb2VzIG5vdCBlbmZvcmNlCiAgdGhpcy4pCgotIEN0cmwrQyBoYW5kbGluZyBvbiBXaW5kb3dzIGhhcyBiZWVuIG1hZGUgbW9yZSBjb25zaXN0ZW50IHdpdGgKICBvdGhlciBwbGF0Zm9ybXMuICBLZXlib2FyZEludGVycnVwdCBjYW4gbm93IHJlbGlhYmx5IGJlIGNhdWdodCwKICBhbmQgQ3RybCtDIGF0IGFuIGludGVyYWN0aXZlIHByb21wdCBubyBsb25nZXIgdGVybWluYXRlcyB0aGUKICBwcm9jZXNzIHVuZGVyIE5ULzJrL1hQIChpdCBuZXZlciBkaWQgdW5kZXIgV2luOXgpLiAgQ3RybCtDIHdpbGwKICBpbnRlcnJ1cHQgdGltZS5zbGVlcCgpIGluIHRoZSBtYWluIHRocmVhZCwgYW5kIGFueSBjaGlsZCBwcm9jZXNzZXMKICBjcmVhdGVkIHZpYSB0aGUgcG9wZW4gZmFtaWx5IChvbiB3aW4yazsgd2UgY2FuJ3QgbWFrZSB3aW45eCB3b3JrCiAgcmVsaWFibHkpIGFyZSBhbHNvIGludGVycnVwdGVkIChhcyBnZW5lcmFsbHkgaGFwcGVucyBvbiBmb3IgTGludXgvVW5peC4pCiAgW1NGIGJ1Z3MgMjMxMjczLCA0Mzk5OTIgYW5kIDU4MTIzMl0KCi0gc3lzLmdldHdpbmRvd3N2ZXJzaW9uKCkgaGFzIGJlZW4gYWRkZWQgb24gV2luZG93cy4gIFRoaXMKICByZXR1cm5zIGEgdHVwbGUgd2l0aCBpbmZvcm1hdGlvbiBhYm91dCB0aGUgdmVyc2lvbiBvZiBXaW5kb3dzCiAgY3VycmVudGx5IHJ1bm5pbmcuCgotIFNsaWNlcyBhbmQgcmVwZXRpdGlvbnMgb2YgYnVmZmVyIG9iamVjdHMgbm93IGNvbnNpc3RlbnRseSByZXR1cm4KICBhIHN0cmluZy4gIEZvcm1lcmx5LCBzdHJpbmdzIHdvdWxkIGJlIHJldHVybmVkIG1vc3Qgb2YgdGhlIHRpbWUsCiAgYnV0IGEgYnVmZmVyIG9iamVjdCB3b3VsZCBiZSByZXR1cm5lZCB3aGVuIHRoZSByZXBldGl0aW9uIGNvdW50CiAgd2FzIG9uZSBvciB3aGVuIHRoZSBzbGljZSByYW5nZSB3YXMgYWxsIGluY2x1c2l2ZS4KCi0gVW5pY29kZSBvYmplY3RzIGluIHN5cy5wYXRoIGFyZSBubyBsb25nZXIgaWdub3JlZCBidXQgdHJlYXRlZAogIGFzIGRpcmVjdG9yeSBuYW1lcy4KCi0gRml4ZWQgc3RyaW5nLnN0YXJ0c3dpdGggYW5kIHN0cmluZy5lbmRzd2l0aCBidWlsdGluIG1ldGhvZHMKICBzbyB0aGV5IGFjY2VwdCBuZWdhdGl2ZSBpbmRpY2VzLiAgW1NGIGJ1ZyA0OTM5NTFdCgotIEZpeGVkIGEgYnVnIHdpdGggYSBjb250aW51ZSBpbnNpZGUgYSB0cnkgYmxvY2sgYW5kIGEgeWllbGQgaW4gdGhlCiAgZmluYWxseSBjbGF1c2UuICBbU0YgYnVnIDU2NzUzOF0KCi0gTW9zdCBidWlsdGluIHNlcXVlbmNlcyBub3cgc3VwcG9ydCAiZXh0ZW5kZWQgc2xpY2VzIiwgaS5lLiBzbGljZXMKICB3aXRoIGEgdGhpcmQgInN0cmlkZSIgcGFyYW1ldGVyLiAgRm9yIGV4YW1wbGUsICJoZWxsbyB3b3JsZCJbOjotMV0KICBnaXZlcyAiZGxyb3cgb2xsZWgiLgoKLSBBIG5ldyB3YXJuaW5nIFBlbmRpbmdEZXByZWNhdGlvbldhcm5pbmcgd2FzIGFkZGVkIHRvIHByb3ZpZGUKICBkaXJlY3Rpb24gb24gZmVhdHVyZXMgd2hpY2ggYXJlIGluIHRoZSBwcm9jZXNzIG9mIGJlaW5nIGRlcHJlY2F0ZWQuCiAgVGhlIHdhcm5pbmcgd2lsbCBub3QgYmUgcHJpbnRlZCBieSBkZWZhdWx0LiAgVG8gc2VlIHRoZSBwZW5kaW5nCiAgZGVwcmVjYXRpb25zLCB1c2UgLVdhbHdheXM6OlBlbmRpbmdEZXByZWNhdGlvbldhcm5pbmc6OgogIGFzIGEgY29tbWFuZCBsaW5lIG9wdGlvbiBvciB3YXJuaW5ncy5maWx0ZXJ3YXJuaW5ncygpIGluIGNvZGUuCgotIERlcHJlY2F0ZWQgZmVhdHVyZXMgb2YgeHJhbmdlIG9iamVjdHMgaGF2ZSBiZWVuIHJlbW92ZWQgYXMKICBwcm9taXNlZC4gIFRoZSBzdGFydCwgc3RvcCwgYW5kIHN0ZXAgYXR0cmlidXRlcyBhbmQgdGhlIHRvbGlzdCgpCiAgbWV0aG9kIG5vIGxvbmdlciBleGlzdC4gIHhyYW5nZSByZXBldGl0aW9uIGFuZCBzbGljaW5nIGhhdmUgYmVlbgogIHJlbW92ZWQuCgotIE5ldyBidWlsdGluIGZ1bmN0aW9uIGVudW1lcmF0ZSh4KSwgZnJvbSBQRVAgMjc5LiAgRXhhbXBsZToKICBlbnVtZXJhdGUoImFiYyIpIGlzIGFuIGl0ZXJhdG9yIHJldHVybmluZyAoMCwiYSIpLCAoMSwiYiIpLCAoMiwiYyIpLgogIFRoZSBhcmd1bWVudCBjYW4gYmUgYW4gYXJiaXRyYXJ5IGl0ZXJhYmxlIG9iamVjdC4KCi0gVGhlIGFzc2VydCBzdGF0ZW1lbnQgbm8gbG9uZ2VyIHRlc3RzIF9fZGVidWdfXyBhdCBydW50aW1lLiAgVGhpcyBtZWFucwogIHRoYXQgYXNzZXJ0IHN0YXRlbWVudHMgY2Fubm90IGJlIGRpc2FibGVkIGJ5IGFzc2lnbmluZyBhIGZhbHNlIHZhbHVlCiAgdG8gX19kZWJ1Z19fLgoKLSBBIG1ldGhvZCB6ZmlsbCgpIHdhcyBhZGRlZCB0byBzdHIgYW5kIHVuaWNvZGUsIHRoYXQgZmlsbHMgYSBudW1lcmljCiAgc3RyaW5nIHRvIHRoZSBsZWZ0IHdpdGggemVyb3MuICBGb3IgZXhhbXBsZSwKICAiKzEyMyIuemZpbGwoNikgLT4gIiswMDEyMyIuCgotIENvbXBsZXggbnVtYmVycyBzdXBwb3J0ZWQgZGl2bW9kKCkgYW5kIHRoZSAvLyBhbmQgJSBvcGVyYXRvcnMsIGJ1dAogIHRoZXNlIG1ha2Ugbm8gc2Vuc2UuICBTaW5jZSB0aGlzIHdhcyBkb2N1bWVudGVkLCB0aGV5J3JlIGJlaW5nCiAgZGVwcmVjYXRlZCBub3cuCgotIFN0cmluZyBhbmQgdW5pY29kZSBtZXRob2RzIGxzdHJpcCgpLCByc3RyaXAoKSBhbmQgc3RyaXAoKSBub3cgdGFrZQogIGFuIG9wdGlvbmFsIGFyZ3VtZW50IHRoYXQgc3BlY2lmaWVzIHRoZSBjaGFyYWN0ZXJzIHRvIHN0cmlwLiAgRm9yCiAgZXhhbXBsZSwgIkZvbyEhIT8hPyE/Ii5yc3RyaXAoIj8hIikgLT4gIkZvbyIuCgotIFRoZXJlJ3MgYSBuZXcgZGljdGlvbmFyeSBjb25zdHJ1Y3RvciAoYSBjbGFzcyBtZXRob2Qgb2YgdGhlIGRpY3QKICBjbGFzcyksIGRpY3QuZnJvbWtleXMoaXRlcmFibGUsIHZhbHVlPU5vbmUpLiAgSXQgY29uc3RydWN0cyBhCiAgZGljdGlvbmFyeSB3aXRoIGtleXMgdGFrZW4gZnJvbSB0aGUgaXRlcmFibGUgYW5kIGFsbCB2YWx1ZXMgc2V0IHRvIGEKICBzaW5nbGUgdmFsdWUuICBJdCBjYW4gYmUgdXNlZCBmb3IgYnVpbGRpbmcgc2V0cyBhbmQgZm9yIHJlbW92aW5nCiAgZHVwbGljYXRlcyBmcm9tIHNlcXVlbmNlcy4KCi0gQWRkZWQgYSBuZXcgZGljdCBtZXRob2QgcG9wKGtleSkuICBUaGlzIHJlbW92ZXMgYW5kIHJldHVybnMgdGhlCiAgdmFsdWUgY29ycmVzcG9uZGluZyB0byBrZXkuICBbU0YgcGF0Y2ggIzUzOTk0OV0KCi0gQSBuZXcgYnVpbHQtaW4gdHlwZSwgYm9vbCwgaGFzIGJlZW4gYWRkZWQsIGFzIHdlbGwgYXMgYnVpbHQtaW4KICBuYW1lcyBmb3IgaXRzIHR3byB2YWx1ZXMsIFRydWUgYW5kIEZhbHNlLiAgQ29tcGFyaXNvbnMgYW5kIHN1bmRyeQogIG90aGVyIG9wZXJhdGlvbnMgdGhhdCByZXR1cm4gYSB0cnV0aCB2YWx1ZSBoYXZlIGJlZW4gY2hhbmdlZCB0bwogIHJldHVybiBhIGJvb2wgaW5zdGVhZC4gIFJlYWQgUEVQIDI4NSBmb3IgYW4gZXhwbGFuYXRpb24gb2Ygd2h5IHRoaXMKICBpcyBiYWNrd2FyZCBjb21wYXRpYmxlLgoKLSBGaXhlZCB0d28gYnVncyByZXBvcnRlZCBhcyBTRiAjNTM1OTA1OiB1bmRlciBjZXJ0YWluIGNvbmRpdGlvbnMsCiAgZGVhbGxvY2F0aW5nIGEgZGVlcGx5IG5lc3RlZCBzdHJ1Y3R1cmUgY291bGQgY2F1c2UgYSBzZWdmYXVsdCBpbiB0aGUKICBnYXJiYWdlIGNvbGxlY3RvciwgZHVlIHRvIGludGVyYWN0aW9uIHdpdGggdGhlICJ0cmFzaGNhbiIgY29kZTsKICBhY2Nlc3MgdG8gdGhlIGN1cnJlbnQgZnJhbWUgZHVyaW5nIGRlc3RydWN0aW9uIG9mIGEgbG9jYWwgdmFyaWFibGUKICBjb3VsZCBhY2Nlc3MgYSBwb2ludGVyIHRvIGZyZWVkIG1lbW9yeS4KCi0gVGhlIG9wdGlvbmFsIG9iamVjdCBhbGxvY2F0b3IgKCJweW1hbGxvYyIpIGhhcyBiZWVuIGVuYWJsZWQgYnkKICBkZWZhdWx0LiAgVGhlIHJlY29tbWVuZGVkIHByYWN0aWNlIGZvciBtZW1vcnkgYWxsb2NhdGlvbiBhbmQKICBkZWFsbG9jYXRpb24gaGFzIGJlZW4gc3RyZWFtbGluZWQuICBBIGhlYWRlciBmaWxlIGlzIGluY2x1ZGVkLAogIE1pc2MvcHltZW1jb21wYXQuaCwgd2hpY2ggY2FuIGJlIGJ1bmRsZWQgd2l0aCAzcmQgcGFydHkgZXh0ZW5zaW9ucwogIGFuZCBsZXRzIHRoZW0gdXNlIHRoZSBzYW1lIEFQSSB3aXRoIFB5dGhvbiB2ZXJzaW9ucyBmcm9tIDEuNS4yCiAgb253YXJkcy4KCi0gUHlFcnJfRGlzcGxheSB3aWxsIHByb3ZpZGUgZmlsZSBhbmQgbGluZSBpbmZvcm1hdGlvbiBmb3IgYWxsIGV4Y2VwdGlvbnMKICB0aGF0IGhhdmUgYW4gYXR0cmlidXRlIHByaW50X2ZpbGVfYW5kX2xpbmUsIG5vdCBqdXN0IFN5bnRheEVycm9ycy4KCi0gVGhlIFVURi04IGNvZGVjIHdpbGwgbm93IGVuY29kZSBhbmQgZGVjb2RlIFVuaWNvZGUgc3Vycm9nYXRlcwogIGNvcnJlY3RseSBhbmQgd2l0aG91dCByYWlzaW5nIGV4Y2VwdGlvbnMgZm9yIHVucGFpcmVkIG9uZXMuCgotIFVuaXZlcnNhbCBuZXdsaW5lcyAoUEVQIDI3OCkgaXMgaW1wbGVtZW50ZWQuICBCcmllZmx5LCB1c2luZyAnVScKICBpbnN0ZWFkIG9mICdyJyB3aGVuIG9wZW5pbmcgYSB0ZXh0IGZpbGUgZm9yIHJlYWRpbmcgY2hhbmdlcyB0aGUgbGluZQogIGVuZGluZyBjb252ZW50aW9uIHNvIHRoYXQgYW55IG9mICdccicsICdcclxuJywgYW5kICdcbicgaXMKICByZWNvZ25pemVkIChldmVuIG1peGVkIGluIG9uZSBmaWxlKTsgYWxsIHRocmVlIGFyZSBjb252ZXJ0ZWQgdG8KICAnXG4nLCB0aGUgc3RhbmRhcmQgUHl0aG9uIGxpbmUgZW5kIGNoYXJhY3Rlci4KCi0gZmlsZS54cmVhZGxpbmVzKCkgbm93IHJhaXNlcyBhIFZhbHVlRXJyb3IgaWYgdGhlIGZpbGUgaXMgY2xvc2VkOgogIFByZXZpb3VzbHksIGFuIHhyZWFkbGluZXMgb2JqZWN0IHdhcyByZXR1cm5lZCB3aGljaCB3b3VsZCByYWlzZQogIGEgVmFsdWVFcnJvciB3aGVuIHRoZSB4cmVhZGxpbmVzLm5leHQoKSBtZXRob2Qgd2FzIGNhbGxlZC4KCi0gc3lzLmV4aXQoKSBpbmFkdmVydGVudGx5IGFsbG93ZWQgbW9yZSB0aGFuIG9uZSBhcmd1bWVudC4KICBBbiBleGNlcHRpb24gd2lsbCBub3cgYmUgcmFpc2VkIGlmIG1vcmUgdGhhbiBvbmUgYXJndW1lbnQgaXMgdXNlZC4KCi0gQ2hhbmdlZCBldmFsdWF0aW9uIG9yZGVyIG9mIGRpY3Rpb25hcnkgbGl0ZXJhbHMgdG8gY29uZm9ybSB0byB0aGUKICBnZW5lcmFsIGxlZnQgdG8gcmlnaHQgZXZhbHVhdGlvbiBvcmRlciBydWxlLiBOb3cge2YxKCk6IGYyKCl9IHdpbGwKICBldmFsdWF0ZSBmMSBmaXJzdC4KCi0gRml4ZWQgYnVnICM1MjE3ODI6IHdoZW4gYSBmaWxlIHdhcyBpbiBub24tYmxvY2tpbmcgbW9kZSwgZmlsZS5yZWFkKCkKICBjb3VsZCBzaWxlbnRseSBsb3NlIGRhdGEgb3Igd3JvbmdseSB0aHJvdyBhbiB1bmtub3duIGVycm9yLgoKLSBUaGUgc3FfcmVwZWF0LCBzcV9pbnBsYWNlX3JlcGVhdCwgc3FfY29uY2F0IGFuZCBzcV9pbnBsYWNlX2NvbmNhdAogIHNsb3RzIGFyZSBub3cgYWx3YXlzIHRyaWVkIGFmdGVyIHRyeWluZyB0aGUgY29ycmVzcG9uZGluZyBuYl8qIHNsb3RzLgogIFRoaXMgZml4ZXMgYSBudW1iZXIgb2YgbWlub3IgYnVncyAoc2VlIGJ1ZyAjNjI0ODA3KS4KCi0gRml4IHByb2JsZW0gd2l0aCBkeW5hbWljIGxvYWRpbmcgb24gNjQtYml0IEFJWCAoc2VlIGJ1ZyAjNjM5OTQ1KS4KCkV4dGVuc2lvbiBtb2R1bGVzCi0tLS0tLS0tLS0tLS0tLS0tCgotIEFkZGVkIHRocmVlIG9wZXJhdG9ycyB0byB0aGUgb3BlcmF0b3IgbW9kdWxlOgogICAgb3BlcmF0b3IucG93KGEsYikgd2hpY2ggaXMgZXF1aXZhbGVudCB0bzogIGEqKmIuCiAgICBvcGVyYXRvci5pc18oYSxiKSB3aGljaCBpcyBlcXVpdmFsZW50IHRvOiAgYSBpcyBiLgogICAgb3BlcmF0b3IuaXNfbm90KGEsYikgd2hpY2ggaXMgZXF1aXZhbGVudCB0bzogIGEgaXMgbm90IGIuCgotIHBvc2l4Lm9wZW5wdHkgbm93IHdvcmtzIG9uIGFsbCBzeXN0ZW1zIHRoYXQgaGF2ZSAvZGV2L3B0bXguCgotIEEgbW9kdWxlIHppcGltcG9ydCBleGlzdHMgdG8gc3VwcG9ydCBpbXBvcnRpbmcgY29kZSBmcm9tIHppcAogIGFyY2hpdmVzLgoKLSBUaGUgbmV3IGRhdGV0aW1lIG1vZHVsZSBzdXBwbGllcyBjbGFzc2VzIGZvciBtYW5pcHVsYXRpbmcgZGF0ZXMgYW5kCiAgdGltZXMuICBUaGUgYmFzaWMgZGVzaWduIGNhbWUgZnJvbSB0aGUgWm9wZSAiZmlzaGJvd2wgcHJvY2VzcyIsIGFuZAogIGZhdm9ycyBwcmFjdGljYWwgY29tbWVyY2lhbCBhcHBsaWNhdGlvbnMgb3ZlciBjYWxlbmRhciBlc290ZXJpY2EuICBTZWUKCiAgICAgIGh0dHA6Ly93d3cuem9wZS5vcmcvTWVtYmVycy9mZHJha2UvRGF0ZVRpbWVXaWtpL0Zyb250UGFnZQoKLSBfdGtpbnRlciBub3cgcmV0dXJucyBUY2wgb2JqZWN0cywgaW5zdGVhZCBvZiBzdHJpbmdzLiBPYmplY3RzIHdoaWNoCiAgaGF2ZSBQeXRob24gZXF1aXZhbGVudHMgYXJlIGNvbnZlcnRlZCB0byBQeXRob24gb2JqZWN0cywgb3RoZXIgb2JqZWN0cwogIGFyZSB3cmFwcGVkLiBUaGlzIGNhbiBiZSBjb25maWd1cmVkIHRocm91Z2ggdGhlIHdhbnRvYmplY3RzIG1ldGhvZCwKICBvciBUa2ludGVyLndhbnRvYmplY3RzLgoKLSBUaGUgUHlCU0REQiB3cmFwcGVyIGFyb3VuZCB0aGUgU2xlZXB5Y2F0IEJlcmtlbGV5IERCIGxpYnJhcnkgaGFzCiAgYmVlbiBhZGRlZCBhcyB0aGUgcGFja2FnZSBic2RkYi4gIFRoZSB0cmFkaXRpb25hbCBic2RkYiBtb2R1bGUgaXMKICBzdGlsbCBhdmFpbGFibGUgaW4gc291cmNlIGNvZGUsIGJ1dCBub3QgYnVpbHQgYXV0b21hdGljYWxseSBhbnltb3JlLAogIGFuZCBpcyBub3cgbmFtZWQgYnNkZGIxODUuICBUaGlzIHN1cHBvcnRzIEJlcmtlbGV5IERCIHZlcnNpb25zIGZyb20KICAzLjAgdG8gNC4xLgoKLSB1bmljb2RlZGF0YSB3YXMgdXBkYXRlZCB0byBVbmljb2RlIDMuMi4gSXQgc3VwcG9ydHMgbm9ybWFsaXphdGlvbgogIGFuZCBuYW1lcyBmb3IgSGFuZ3VsIHN5bGxhYmxlcyBhbmQgQ0pLIHVuaWZpZWQgaWRlb2dyYXBocy4KCi0gcmVzb3VyY2UuZ2V0cmxpbWl0KCkgbm93IHJldHVybnMgbG9uZ3MgaW5zdGVhZCBvZiBpbnRzLgoKLSByZWFkbGluZSBub3cgZHluYW1pY2FsbHkgYWRqdXN0cyBpdHMgaW5wdXQvb3V0cHV0IHN0cmVhbSBpZgogIHN5cy5zdGRpbi9zdGRvdXQgY2hhbmdlcy4KCi0gVGhlIF90a2ludGVyIG1vZHVsZSAoYW5kIGhlbmNlIFRraW50ZXIpIGhhcyBkcm9wcGVkIHN1cHBvcnQgZm9yCiAgVGNsL1RrIDguMCBhbmQgOC4xLiAgT25seSBUY2wvVGsgdmVyc2lvbnMgOC4yLCA4LjMgYW5kIDguNCBhcmUKICBzdXBwb3J0ZWQuCgotIGNQaWNrbGUuQmFkUGlja2xlR2V0IGlzIG5vdyBhIGNsYXNzLgoKLSBUaGUgdGltZSBzdGFtcHMgaW4gb3Muc3RhdF9yZXN1bHQgYXJlIGZsb2F0aW5nIHBvaW50IG51bWJlcnMKICBhZnRlciBzdGF0X2Zsb2F0X3RpbWVzIGhhcyBiZWVuIGNhbGxlZC4KCi0gSWYgdGhlIHNpemUgcGFzc2VkIHRvIG1tYXAubW1hcCgpIGlzIGxhcmdlciB0aGFuIHRoZSBsZW5ndGggb2YgdGhlCiAgZmlsZSBvbiBub24tV2luZG93cyBwbGF0Zm9ybXMsIGEgVmFsdWVFcnJvciBpcyByYWlzZWQuIFtTRiBidWcgNTg1NzkyXQoKLSBUaGUgeHJlYWRsaW5lcyBtb2R1bGUgaXMgc2xhdGVkIGZvciBvYnNvbGVzY2VuY2UuCgotIFRoZSBzdHJwdGltZSBmdW5jdGlvbiBpbiB0aGUgdGltZSBtb2R1bGUgaXMgbm93IGFsd2F5cyBhdmFpbGFibGUgKGEKICBQeXRob24gaW1wbGVtZW50YXRpb24gaXMgdXNlZCB3aGVuIHRoZSBDIGxpYnJhcnkgZG9lc24ndCBkZWZpbmUgaXQpLgoKLSBUaGUgJ25ldycgbW9kdWxlIGlzIG5vIGxvbmdlciBhbiBleHRlbnNpb24sIGJ1dCBhIFB5dGhvbiBtb2R1bGUgdGhhdAogIG9ubHkgZXhpc3RzIGZvciBiYWNrd2FyZHMgY29tcGF0aWJpbGl0eS4gIEl0cyBjb250ZW50cyBhcmUgbm8gbG9uZ2VyCiAgZnVuY3Rpb25zIGJ1dCBjYWxsYWJsZSB0eXBlIG9iamVjdHMuCgotIFRoZSBic2RkYi4qb3BlbiBmdW5jdGlvbnMgY2FuIG5vdyB0YWtlICdOb25lJyBhcyBhIGZpbGVuYW1lLgogIFRoaXMgd2lsbCBjcmVhdGUgYSB0ZW1wb3JhcnkgaW4tbWVtb3J5IGJzZGRiIHRoYXQgd29uJ3QgYmUKICB3cml0dGVuIHRvIGRpc2suCgotIHBvc2l4LmdldGxvYWRhdmcsIHBvc2l4LmxjaG93biwgcG9zaXgua2lsbHBnLCBwb3NpeC5ta25vZCwgYW5kCiAgcG9zaXguZ2V0cGdpZCBoYXZlIGJlZW4gYWRkZWQgd2hlcmUgYXZhaWxhYmxlLgoKLSBUaGUgbG9jYWxlIG1vZHVsZSBub3cgZXhwb3NlcyB0aGUgQyBsaWJyYXJ5J3MgZ2V0dGV4dCBpbnRlcmZhY2UuIEl0CiAgYWxzbyBoYXMgYSBuZXcgZnVuY3Rpb24gZ2V0cHJlZmVycmVkZW5jb2RpbmcuCgotIEEgc2VjdXJpdHkgaG9sZSAoImRvdWJsZSBmcmVlIikgd2FzIGZvdW5kIGluIHpsaWItMS4xLjMsIGEgcG9wdWxhcgogIHRoaXJkIHBhcnR5IGNvbXByZXNzaW9uIGxpYnJhcnkgdXNlZCBieSBzb21lIFB5dGhvbiBtb2R1bGVzLiAgVGhlCiAgaG9sZSB3YXMgcXVpY2tseSBwbHVnZ2VkIGluIHpsaWItMS4xLjQsIGFuZCB0aGUgV2luZG93cyBidWlsZCBvZgogIFB5dGhvbiBub3cgc2hpcHMgd2l0aCB6bGliLTEuMS40LgoKLSBwd2QsIGdycCwgYW5kIHJlc291cmNlIHJldHVybiBlbmhhbmNlZCB0dXBsZXMgbm93LCB3aXRoIHN5bWJvbGljCiAgZmllbGQgbmFtZXMuCgotIGFycmF5LmFycmF5IGlzIG5vdyBhIHR5cGUgb2JqZWN0LiBBIG5ldyBmb3JtYXQgY2hhcmFjdGVyCiAgJ3UnIGluZGljYXRlcyBQeV9VTklDT0RFIGFycmF5cy4gRm9yIHRob3NlLCAudG91bmljb2RlIGFuZAogIC5mcm9tdW5pY29kZSBtZXRob2RzIGFyZSBhdmFpbGFibGUuIEFycmF5cyBub3cgc3VwcG9ydCBfX2lhZGRfXwogIGFuZCBfX2ltdWxfXy4KCi0gZGwgbm93IGJ1aWxkcyBvbiBldmVyeSBzeXN0ZW0gdGhhdCBoYXMgZGxmY24uaC4gIEZhaWx1cmUgaW4gY2FzZQogIG9mIHNpemVvZihpbnQpIT1zaXplb2YobG9uZykhPXNpemVvZih2b2lkKikgaXMgZGVsYXllZCB1bnRpbCBkbC5vcGVuCiAgaXMgY2FsbGVkLgoKLSBzaWduYWwuc2lncGVuZGluZywgc2lnbmFsLnNpZ3Byb2NtYXNrIGFuZCBzaWduYWwuc2lnc3VzcGVuZCBoYXZlCiAgYmVlbiBhZGRlZCB3aGVyZSBhdmFpbGFibGUuCgotIFRoZSBzeXMgbW9kdWxlIGFjcXVpcmVkIGEgbmV3IGF0dHJpYnV0ZSwgYXBpX3ZlcnNpb24sIHdoaWNoIGV2YWx1YXRlcwogIHRvIHRoZSB2YWx1ZSBvZiB0aGUgUFlUSE9OX0FQSV9WRVJTSU9OIG1hY3JvIHdpdGggd2hpY2ggdGhlCiAgaW50ZXJwcmV0ZXIgd2FzIGNvbXBpbGVkLgoKLSBGaXhlZCBidWcgIzQ3MDU4Mjogc3JlIG1vZHVsZSB3b3VsZCByZXR1cm4gYSB0dXBsZSAoTm9uZSwgJ2EnLCAnYWInKQogIHdoZW4gYXBwbHlpbmcgdGhlIHJlZ3VsYXIgZXhwcmVzc2lvbiAnXigoYSljKT8oYWIpJCcgb24gJ2FiJy4gSXQgbm93CiAgcmV0dXJucyAoTm9uZSwgTm9uZSwgJ2FiJyksIGFzIGV4cGVjdGVkLiBBbHNvIGZpeGVkIGhhbmRsaW5nIG9mCiAgbGFzdGluZGV4L2xhc3Rncm91cCBtYXRjaCBhdHRyaWJ1dGVzIGluIHNpbWlsYXIgY2FzZXMuIEZvciBleGFtcGxlLAogIHdoZW4gcnVubmluZyB0aGUgZXhwcmVzc2lvbiByJyhhKShiKT9iJyBvdmVyICdhYicsIGxhc3RpbmRleCBtdXN0IGJlCiAgMSwgbm90IDIuCgotIEZpeGVkIGJ1ZyAjNTgxMDgwOiBzcmUgc2Nhbm5lciB3YXMgbm90IGNoZWNraW5nIHRoZSBidWZmZXIgbGltaXQKICBiZWZvcmUgaW5jcmVhc2luZyB0aGUgY3VycmVudCBwb2ludGVyLiBUaGlzIHdhcyBjcmVhdGluZyBhbiBpbmZpbml0ZQogIGxvb3AgaW4gdGhlIHNlYXJjaCBmdW5jdGlvbiwgb25jZSB0aGUgcG9pbnRlciBleGNlZWRlZCB0aGUgYnVmZmVyCiAgbGltaXQuCgotIFRoZSBvcy5mZG9wZW4gZnVuY3Rpb24gbm93IGVuZm9yY2VzIGEgZmlsZSBtb2RlIHN0YXJ0aW5nIHdpdGggdGhlCiAgbGV0dGVyICdyJywgJ3cnIG9yICdhJywgb3RoZXJ3aXNlIGEgVmFsdWVFcnJvciBpcyByYWlzZWQuIFRoaXMgZml4ZXMKICBidWcgIzYyMzQ2NC4KCi0gVGhlIGxpbnV4YXVkaW9kZXYgbW9kdWxlIGlzIG5vdyBkZXByZWNhdGVkOyBpdCBpcyBiZWluZyByZXBsYWNlZCBieQogIG9zc2F1ZGlvZGV2LiAgVGhlIGludGVyZmFjZSBoYXMgYmVlbiBleHRlbmRlZCB0byBjb3ZlciBhIGxvdCBtb3JlIG9mCiAgT1NTIChzZWUgd3d3Lm9wZW5zb3VuZC5jb20pLCBpbmNsdWRpbmcgbW9zdCBEU1AgaW9jdGxzIGFuZCB0aGUKICBPU1MgbWl4ZXIgQVBJLiAgRG9jdW1lbnRhdGlvbiBmb3J0aGNvbWluZyBpbiAyLjNhMi4KCkxpYnJhcnkKLS0tLS0tLQoKLSBpbWFwbGliLnB5IG5vdyBzdXBwb3J0cyBTU0wgKFRpbm8gTGFuZ2UgYW5kIFBpZXJzIExhdWRlcikuCgotIEZyZWV6ZSdzIG1vZHVsZWZpbmRlci5weSBoYXMgYmVlbiBtb3ZlZCB0byB0aGUgc3RhbmRhcmQgbGlicmFyeTsKICBzbGlnaHRseSBpbXByb3ZlZCBzbyBpdCB3aWxsIGlzc3VlIGxlc3MgZmFsc2UgbWlzc2luZyBzdWJtb2R1bGUKICByZXBvcnRzIChzZWUgc2YgcGF0aCAjNjQzNzExIGZvciBkZXRhaWxzKS4gIERvY3VtZW50YXRpb24gd2lsbCBmb2xsb3cKICB3aXRoIFB5dGhvbiAyLjNhMi4KCi0gb3MucGF0aCBleHBvc2VzIGdldGN0aW1lLgoKLSB1bml0dGVzdC5weSBub3cgaGFzIHR3byBhZGRpdGlvbmFsIG1ldGhvZHMgY2FsbGVkIGFzc2VydEFsbW9zdEVxdWFsKCkKICBhbmQgZmFpbElmQWxtb3N0RXF1YWwoKS4gIFRoZXkgaW1wbGVtZW50IGFuIGFwcHJveGltYXRlIGNvbXBhcmlzaW9uCiAgYnkgcm91bmRpbmcgdGhlIGRpZmZlcmVuY2UgYmV0d2VlbiB0aGUgdHdvIGFyZ3VtZW50cyBhbmQgY29tcGFyaW5nCiAgdGhlIHJlc3VsdCB0byB6ZXJvLiAgQXBwcm94aW1hdGUgY29tcGFyaXNpb24gaXMgZXNzZW50aWFsIGZvcgogIHVuaXQgdGVzdHMgb2YgZmxvYXRpbmcgcG9pbnQgcmVzdWx0cy4KCi0gY2FsZW5kYXIucHkgbm93IGRlcGVuZHMgb24gdGhlIG5ldyBkYXRldGltZSBtb2R1bGUgcmF0aGVyIHRoYW4KICB0aGUgdGltZSBtb2R1bGUuICBBcyBhIHJlc3VsdCwgdGhlIHJhbmdlIG9mIGFsbG93YWJsZSBkYXRlcwogIGhhcyBiZWVuIGluY3JlYXNlZC4KCi0gcGRiIGhhcyBhIG5ldyAnaih1bXApJyBjb21tYW5kIHRvIHNlbGVjdCB0aGUgbmV4dCBsaW5lIHRvIGJlCiAgZXhlY3V0ZWQuCgotIFRoZSBkaXN0dXRpbHMgY3JlYXRlZCB3aW5kb3dzIGluc3RhbGxlcnMgbm93IGNhbiBydW4gYQogIHBvc3RpbnN0YWxsYXRpb24gc2NyaXB0LgoKLSBkb2N0ZXN0LnRlc3Rtb2QgY2FuIG5vdyBiZSBjYWxsZWQgd2l0aG91dCBhcmd1bWVudCwgd2hpY2ggbWVhbnMgdG8KICB0ZXN0IHRoZSBjdXJyZW50IG1vZHVsZS4KCi0gV2hlbiBjYW5jZWxsaW5nIGEgc2VydmVyIHRoYXQgaW1wbGVtZW50ZWQgdGhyZWFkaW5nIHdpdGggYSBrZXlib2FyZAogIGludGVycnVwdCwgdGhlIHNlcnZlciB3b3VsZCBzaHV0IGRvd24gYnV0IG5vdCB0ZXJtaW5hdGUgKHdhaXRpbmcgb24KICBjbGllbnQgdGhyZWFkcykuIEEgbmV3IG1lbWJlciB2YXJpYWJsZSwgZGFlbW9uX3RocmVhZHMsIHdhcyBhZGRlZCB0bwogIHRoZSBUaHJlYWRpbmdNaXhJbiBjbGFzcyBpbiBTb2NrZXRTZXJ2ZXIucHkgdG8gbWFrZSBpdCBleHBsaWNpdCB0aGF0CiAgdGhpcyBiZWhhdmlvciBuZWVkcyB0byBiZSBjb250cm9sbGVkLgoKLSBBIG5ldyBtb2R1bGUsIG9wdHBhcnNlLCBwcm92aWRlcyBhIGZhbmN5IGFsdGVybmF0aXZlIHRvIGdldG9wdCBmb3IKICBjb21tYW5kIGxpbmUgcGFyc2luZy4gIEl0IGlzIGEgc2xpZ2h0bHkgbW9kaWZpZWQgdmVyc2lvbiBvZiBHcmVnCiAgV2FyZCdzIE9wdGlrIHBhY2thZ2UuCgotIFVzZXJEaWN0LnB5IG5vdyBkZWZpbmVzIGEgRGljdE1peGluIGNsYXNzIHdoaWNoIGRlZmluZXMgYWxsIGRpY3Rpb25hcnkKICBtZXRob2RzIGZvciBjbGFzc2VzIHRoYXQgYWxyZWFkeSBoYXZlIGEgbWluaW11bSBtYXBwaW5nIGludGVyZmFjZS4KICBUaGlzIGdyZWF0bHkgc2ltcGxpZmllcyB3cml0aW5nIGNsYXNzZXMgdGhhdCBuZWVkIHRvIGJlIHN1YnN0aXR1dGFibGUKICBmb3IgZGljdGlvbmFyaWVzIChzdWNoIGFzIHRoZSBzaGVsdmUgbW9kdWxlKS4KCi0gc2hlbHZlLnB5IG5vdyBzdWJjbGFzc2VzIGZyb20gVXNlckRpY3QuRGljdE1peGluLiAgTm93IHNoZWx2ZSBzdXBwb3J0cwogIGFsbCBkaWN0aW9uYXJ5IG1ldGhvZHMuICBUaGlzIGVhc2VzIHRoZSB0cmFuc2l0aW9uIHRvIHBlcnNpc3RlbnQKICBzdG9yYWdlIGZvciBzY3JpcHRzIG9yaWdpbmFsbHkgd3JpdHRlbiB3aXRoIGRpY3Rpb25hcmllcyBpbiBtaW5kLgoKLSBzaGVsdmUub3BlbiBhbmQgdGhlIHZhcmlvdXMgY2xhc3NlcyBpbiBzaGVsdmUucHkgbm93IGFjY2VwdCBhbiBvcHRpb25hbAogIGJpbmFyeSBmbGFnLCB3aGljaCBkZWZhdWx0cyB0byBGYWxzZS4gIElmIFRydWUsIHRoZSB2YWx1ZXMgc3RvcmVkIGluIHRoZQogIHNoZWxmIGFyZSBiaW5hcnkgcGlja2xlcy4KCi0gQSBuZXcgcGFja2FnZSwgbG9nZ2luZywgaW1wbGVtZW50cyB0aGUgbG9nZ2luZyBBUEkgZGVmaW5lZCBieSBQRVAKICAyODIuICBUaGUgY29kZSBpcyB3cml0dGVuIGJ5IFZpbmF5IFNhamlwLgoKLSBTdHJlYW1SZWFkZXIsIFN0cmVhbVJlYWRlcldyaXRlciBhbmQgU3RyZWFtUmVjb2RlciBpbiB0aGUgY29kZWNzCiAgbW9kdWxlcyBhcmUgaXRlcmF0b3JzIG5vdy4KCi0gZ3ppcC5weSBub3cgaGFuZGxlcyBmaWxlcyBleGNlZWRpbmcgMkdCLiAgRmlsZXMgb3ZlciA0R0IgYWxzbyB3b3JrCiAgbm93IChwcm92aWRlZCB0aGUgT1Mgc3VwcG9ydHMgaXQsIGFuZCBQeXRob24gaXMgY29uZmlndXJlZCB3aXRoIGxhcmdlCiAgZmlsZSBzdXBwb3J0KSwgYnV0IGluIHRoYXQgY2FzZSB0aGUgdW5kZXJseWluZyBnemlwIGZpbGUgZm9ybWF0IGNhbgogIHJlY29yZCBvbmx5IHRoZSBsZWFzdC1zaWduaWZpY2FudCAzMiBiaXRzIG9mIHRoZSBmaWxlIHNpemUsIHNvIHRoYXQKICBzb21lIHRvb2xzIHdvcmtpbmcgd2l0aCBnemlwcGVkIGZpbGVzIG1heSByZXBvcnQgYW4gaW5jb3JyZWN0IGZpbGUKICBzaXplLgoKLSB4bWwuc2F4LnNheHV0aWxzLnVuZXNjYXBlIGhhcyBiZWVuIGFkZGVkLCB0byByZXBsYWNlIGVudGl0eSByZWZlcmVuY2VzCiAgd2l0aCB0aGVpciBlbnRpdHkgdmFsdWUuCgotIFF1ZXVlLlF1ZXVlLntwdXQsZ2V0fSBub3cgc3VwcG9ydCBhbiBvcHRpb25hbCB0aW1lb3V0IGFyZ3VtZW50LgoKLSBWYXJpb3VzIGZlYXR1cmVzIG9mIFRrIDguNCBhcmUgZXhwb3NlZCBpbiBUa2ludGVyLnB5LiBUaGUgbXVsdGlwbGUKICBvcHRpb24gb2YgdGtGaWxlRGlhbG9nIGlzIGV4cG9zZWQgYXMgZnVuY3Rpb24gYXNrb3BlbmZpbGV7LG5hbWV9cy4KCi0gVmFyaW91cyBjb25maWd1cmUgbWV0aG9kcyBvZiBUa2ludGVyIGhhdmUgYmVlbiBzdHJlYW0tbGluZWQsIHNvIHRoYXQKICB0YWdfY29uZmlndXJlLCBpbWFnZV9jb25maWd1cmUsIHdpbmRvd19jb25maWd1cmUgbm93IHJldHVybiBhCiAgZGljdGlvbmFyeSB3aGVuIGludm9rZWQgd2l0aCBubyBhcmd1bWVudC4KCi0gSW1wb3J0aW5nIHRoZSByZWFkbGluZSBtb2R1bGUgbm93IG5vIGxvbmdlciBoYXMgdGhlIHNpZGUgZWZmZWN0IG9mCiAgY2FsbGluZyBzZXRsb2NhbGUoTENfQ1RZUEUsICIiKS4gIFRoZSBpbml0aWFsICJDIiBsb2NhbGUsIG9yCiAgd2hhdGV2ZXIgbG9jYWxlIGlzIGV4cGxpY2l0bHkgc2V0IGJ5IHRoZSB1c2VyLCBpcyBwcmVzZXJ2ZWQuICBJZiB5b3UKICB3YW50IHJlcHIoKSBvZiA4LWJpdCBzdHJpbmdzIGluIHlvdXIgcHJlZmVycmVkIGVuY29kaW5nIHRvIHByZXNlcnZlCiAgYWxsIHByaW50YWJsZSBjaGFyYWN0ZXJzIG9mIHRoYXQgZW5jb2RpbmcsIHlvdSBoYXZlIHRvIGFkZCB0aGUKICBmb2xsb3dpbmcgY29kZSB0byB5b3VyICRQWVRIT05TVEFSVFVQIGZpbGUgb3IgdG8geW91ciBhcHBsaWNhdGlvbidzCiAgbWFpbigpOgoKICAgIGltcG9ydCBsb2NhbGUKICAgIGxvY2FsZS5zZXRsb2NhbGUobG9jYWxlLkxDX0NUWVBFLCAiIikKCi0gc2h1dGlsLm1vdmUgd2FzIGFkZGVkLiBzaHV0aWwuY29weXRyZWUgbm93IHJlcG9ydHMgZXJyb3JzIGFzIGFuCiAgZXhjZXB0aW9uIGF0IHRoZSBlbmQsIGluc3RlYWQgb2YgcHJpbnRpbmcgZXJyb3IgbWVzc2FnZXMuCgotIEVuY29kaW5nIG5hbWUgbm9ybWFsaXphdGlvbiB3YXMgZ2VuZXJhbGl6ZWQgdG8gbm90IG9ubHkKICByZXBsYWNlIGh5cGhlbnMgd2l0aCB1bmRlcnNjb3JlcywgYnV0IGFsc28gYWxsIG90aGVyIG5vbi1hbHBoYW51bWVyaWMKICBjaGFyYWN0ZXJzICh3aXRoIHRoZSBleGNlcHRpb24gb2YgdGhlIGRvdCB3aGljaCBpcyB1c2VkIGZvciBQeXRob24KICBwYWNrYWdlIG5hbWVzIGR1cmluZyBsb29rdXApLiBUaGUgYWxpYXNlcy5weSBtYXBwaW5nIHdhcyB1cGRhdGVkCiAgdG8gdGhlIG5ldyBzdGFuZGFyZC4KCi0gbWltZXR5cGVzIGhhcyB0d28gbmV3IGZ1bmN0aW9uczogZ3Vlc3NfYWxsX2V4dGVuc2lvbnMoKSB3aGljaAogIHJldHVybnMgYSBsaXN0IG9mIGFsbCBrbm93biBleHRlbnNpb25zIGZvciBhIG1pbWUgdHlwZSwgYW5kCiAgYWRkX3R5cGUoKSB3aGljaCBhZGRzIG9uZSBtYXBwaW5nIGJldHdlZW4gYSBtaW1lIHR5cGUgYW5kCiAgYW4gZXh0ZW5zaW9uIHRvIHRoZSBkYXRhYmFzZS4KCi0gTmV3IG1vZHVsZTogc2V0cywgZGVmaW5lcyB0aGUgY2xhc3MgU2V0IHRoYXQgaW1wbGVtZW50cyBhIG11dGFibGUKICBzZXQgdHlwZSB1c2luZyB0aGUga2V5cyBvZiBhIGRpY3QgdG8gcmVwcmVzZW50IHRoZSBzZXQuICBUaGVyZSdzCiAgYWxzbyBhIGNsYXNzIEltbXV0YWJsZVNldCB3aGljaCBpcyB1c2VmdWwgd2hlbiB5b3UgbmVlZCBzZXRzIG9mIHNldHMKICBvciB3aGVuIHlvdSBuZWVkIHRvIHVzZSBzZXRzIGFzIGRpY3Qga2V5cywgYW5kIGEgY2xhc3MgQmFzZVNldCB3aGljaAogIGlzIHRoZSBiYXNlIGNsYXNzIG9mIHRoZSB0d28uCgotIEFkZGVkIHJhbmRvbS5zYW1wbGUocG9wdWxhdGlvbixrKSBmb3IgcmFuZG9tIHNhbXBsaW5nIHdpdGhvdXQgcmVwbGFjZW1lbnQuCiAgUmV0dXJucyBhIGsgbGVuZ3RoIGxpc3Qgb2YgdW5pcXVlIGVsZW1lbnRzIGNob3NlbiBmcm9tIHRoZSBwb3B1bGF0aW9uLgoKLSByYW5kb20ucmFuZHJhbmdlKC1zeXMubWF4aW50LTEsIHN5cy5tYXhpbnQpIG5vIGxvbmdlciByYWlzZXMKICBPdmVyZmxvd0Vycm9yLiAgVGhhdCBpcywgaXQgbm93IGFjY2VwdHMgYW55IGNvbWJpbmF0aW9uIG9mICdzdGFydCcKICBhbmQgJ3N0b3AnIGFyZ3VtZW50cyBzbyBsb25nIGFzIGVhY2ggaXMgaW4gdGhlIHJhbmdlIG9mIFB5dGhvbidzCiAgYm91bmRlZCBpbnRlZ2Vycy4KCi0gVGhhbmtzIHRvIFJheW1vbmQgSGV0dGluZ2VyLCByYW5kb20ucmFuZG9tKCkgbm93IHVzZXMgYSBuZXcgY29yZQogIGdlbmVyYXRvci4gIFRoZSBNZXJzZW5uZSBUd2lzdGVyIGFsZ29yaXRobSBpcyBpbXBsZW1lbnRlZCBpbiBDLAogIHRocmVhZHNhZmUsIGZhc3RlciB0aGFuIHRoZSBwcmV2aW91cyBnZW5lcmF0b3IsIGhhcyBhbiBhc3Ryb25vbWljYWxseQogIGxhcmdlIHBlcmlvZCAoMioqMTk5MzctMSksIGNyZWF0ZXMgcmFuZG9tIGZsb2F0cyB0byBmdWxsIDUzLWJpdAogIHByZWNpc2lvbiwgYW5kIG1heSBiZSB0aGUgbW9zdCB3aWRlbHkgdGVzdGVkIHJhbmRvbSBudW1iZXIgZ2VuZXJhdG9yCiAgaW4gZXhpc3RlbmNlLgoKICBUaGUgcmFuZG9tLmp1bXBhaGVhZChuKSBtZXRob2QgaGFzIGRpZmZlcmVudCBzZW1hbnRpY3MgZm9yIHRoZSBuZXcKICBnZW5lcmF0b3IuICBJbnN0ZWFkIG9mIGp1bXBpbmcgbiBzdGVwcyBhaGVhZCwgaXQgdXNlcyBuIGFuZCB0aGUKICBleGlzdGluZyBzdGF0ZSB0byBjcmVhdGUgYSBuZXcgc3RhdGUuICBUaGlzIG1lYW5zIHRoYXQganVtcGFoZWFkKCkKICBjb250aW51ZXMgdG8gc3VwcG9ydCBtdWx0aS10aHJlYWRlZCBjb2RlIG5lZWRpbmcgZ2VuZXJhdG9ycyBvZgogIG5vbi1vdmVybGFwcGluZyBzZXF1ZW5jZXMuICBIb3dldmVyLCBpdCB3aWxsIGJyZWFrIGNvZGUgd2hpY2ggcmVsaWVzCiAgb24ganVtcGFoZWFkIG1vdmluZyBhIHNwZWNpZmljIG51bWJlciBvZiBzdGVwcyBmb3J3YXJkLgoKICBUaGUgYXR0cmlidXRlcyByYW5kb20ud2hzZWVkIGFuZCByYW5kb20uX193aHNlZWQgaGF2ZSBubyBtZWFuaW5nIGZvcgogIHRoZSBuZXcgZ2VuZXJhdG9yLiAgQ29kZSB1c2luZyB0aGVzZSBhdHRyaWJ1dGVzIHNob3VsZCBzd2l0Y2ggdG8gYQogIG5ldyBjbGFzcywgcmFuZG9tLldpY2htYW5uSGlsbCB3aGljaCBpcyBwcm92aWRlZCBmb3IgYmFja3dhcmQKICBjb21wYXRpYmlsaXR5IGFuZCB0byBtYWtlIGFuIGFsdGVybmF0ZSBnZW5lcmF0b3IgYXZhaWxhYmxlLgoKLSBOZXcgImFsZ29yaXRobXMiIG1vZHVsZTogaGVhcHEsIGltcGxlbWVudHMgYSBoZWFwIHF1ZXVlLiAgVGhhbmtzIHRvCiAgS2V2aW4gTydDb25ub3IgZm9yIHRoZSBjb2RlIGFuZCBGcmFu529pcyBQaW5hcmQgZm9yIGFuIGVudGVydGFpbmluZwogIHdyaXRlLXVwIGV4cGxhaW5pbmcgdGhlIHRoZW9yeSBhbmQgcHJhY3RpY2FsIHVzZXMgb2YgaGVhcHMuCgotIE5ldyBlbmNvZGluZyBmb3IgdGhlIFBhbG0gT1MgY2hhcmFjdGVyIHNldDogcGFsbW9zLgoKLSBiaW5hc2NpaS5jcmMzMigpIGFuZCB0aGUgemlwZmlsZSBtb2R1bGUgaGFkIHByb2JsZW1zIG9uIHNvbWUgNjQtYml0CiAgcGxhdGZvcm1zLiAgVGhlc2UgaGF2ZSBiZWVuIGZpeGVkLiAgT24gYSBwbGF0Zm9ybSB3aXRoIDgtYnl0ZSBDIGxvbmdzLAogIGNyYzMyKCkgbm93IHJldHVybnMgYSBzaWduZWQtZXh0ZW5kZWQgNC1ieXRlIHJlc3VsdCwgc28gdGhhdCBpdHMgdmFsdWUKICBhcyBhIFB5dGhvbiBpbnQgaXMgZXF1YWwgdG8gdGhlIHZhbHVlIGNvbXB1dGVkIGEgMzItYml0IHBsYXRmb3JtLgoKLSB4bWwuZG9tLm1pbmlkb20udG94bWwgYW5kIHRvcHJldHR5eG1sIG5vdyB0YWtlIGFuIG9wdGlvbmFsIGVuY29kaW5nCiAgYXJndW1lbnQuCgotIFNvbWUgZml4ZXMgaW4gdGhlIGNvcHkgbW9kdWxlOiB3aGVuIGFuIG9iamVjdCBpcyBjb3BpZWQgdGhyb3VnaCBpdHMKICBfX3JlZHVjZV9fIG1ldGhvZCwgdGhlcmUgd2FzIG5vIGNoZWNrIGZvciBhIF9fc2V0c3RhdGVfXyBtZXRob2Qgb24KICB0aGUgcmVzdWx0IFtTRiBwYXRjaCA1NjUwODVdOyBkZWVwY29weSBzaG91bGQgdHJlYXQgaW5zdGFuY2VzIG9mCiAgY3VzdG9tIG1ldGFjbGFzc2VzIHRoZSBzYW1lIHdheSBpdCB0cmVhdHMgaW5zdGFuY2VzIG9mIHR5cGUgJ3R5cGUnCiAgW1NGIHBhdGNoIDU2MDc5NF0uCgotIFNvY2tldHMgbm93IHN1cHBvcnQgdGltZW91dCBtb2RlLiAgQWZ0ZXIgcy5zZXR0aW1lb3V0KFQpLCB3aGVyZSBUIGlzCiAgYSBmbG9hdCBleHByZXNzaW5nIHNlY29uZHMsIHN1YnNlcXVlbnQgb3BlcmF0aW9ucyByYWlzZSBhbiBleGNlcHRpb24KICBpZiB0aGV5IGNhbm5vdCBiZSBjb21wbGV0ZWQgd2l0aGluIFQgc2Vjb25kcy4gIFRvIGRpc2FibGUgdGltZW91dAogIG1vZGUsIHVzZSBzLnNldHRpbWVvdXQoTm9uZSkuICBUaGVyZSdzIGFsc28gYSBtb2R1bGUgZnVuY3Rpb24sCiAgc29ja2V0LnNldGRlZmF1bHR0aW1lb3V0KFQpLCB3aGljaCBzZXRzIHRoZSBkZWZhdWx0IGZvciBhbGwgc29ja2V0cwogIGNyZWF0ZWQgaGVuY2Vmb3J0aC4KCi0gZ2V0b3B0LmdudV9nZXRvcHQgd2FzIGFkZGVkLiAgVGhpcyBzdXBwb3J0cyBHTlUtc3R5bGUgb3B0aW9uCiAgcHJvY2Vzc2luZywgd2hlcmUgb3B0aW9ucyBjYW4gYmUgbWl4ZWQgd2l0aCBub24tb3B0aW9uIGFyZ3VtZW50cy4KCi0gU3RvcCB1c2luZyBzdHJpbmdzIGZvciBleGNlcHRpb25zLiAgU3RyaW5nIG9iamVjdHMgdXNlZCBmb3IKICBleGNlcHRpb25zIGFyZSBub3cgY2xhc3NlcyBkZXJpdmluZyBmcm9tIEV4Y2VwdGlvbi4gIFRoZSBvYmplY3RzCiAgY2hhbmdlZCB3ZXJlOiBUa2ludGVyLlRjbEVycm9yLCBiZGIuQmRiUXVpdCwgbWFjcGF0aC5ub3JtX2Vycm9yLAogIHRhYm5hbm55Lk5hbm55TmFnLCBhbmQgeGRybGliLkVycm9yLgoKLSBDb25zdGFudHMgQk9NX1VURjgsIEJPTV9VVEYxNiwgQk9NX1VURjE2X0xFLCBCT01fVVRGMTZfQkUsCiAgQk9NX1VURjMyLCBCT01fVVRGMzJfTEUgYW5kIEJPTV9VVEYzMl9CRSB0aGF0IHJlcHJlc2VudCB0aGUgQnl0ZQogIE9yZGVyIE1hcmsgaW4gVVRGLTgsIFVURi0xNiBhbmQgVVRGLTMyIGVuY29kaW5ncyBmb3IgbGl0dGxlIGFuZAogIGJpZyBlbmRpYW4gc3lzdGVtcyB3ZXJlIGFkZGVkIHRvIHRoZSBjb2RlY3MgbW9kdWxlLiBUaGUgb2xkIG5hbWVzCiAgQk9NMzJfKiBhbmQgQk9NNjRfKiB3ZXJlIG9mZiBieSBhIGZhY3RvciBvZiAyLgoKLSBBZGRlZCBjb252ZXJzaW9uIGZ1bmN0aW9ucyBtYXRoLmRlZ3JlZXMoKSBhbmQgbWF0aC5yYWRpYW5zKCkuCgotIG1hdGgubG9nKCkgbm93IHRha2VzIGFuIG9wdGlvbmFsIGFyZ3VtZW50OiAgbWF0aC5sb2coeFssIGJhc2VdKS4KCi0gZnRwbGliLnJldHJsaW5lcygpIG5vdyB0ZXN0cyBmb3IgY2FsbGJhY2sgaXMgTm9uZSByYXRoZXIgdGhhbiB0ZXN0aW5nCiAgZm9yIEZhbHNlLiAgV2FzIGNhdXNpbmcgYW4gZXJyb3Igd2hlbiBnaXZlbiBhIGNhbGxiYWNrIG9iamVjdCB3aGljaAogIHdhcyBjYWxsYWJsZSBidXQgYWxzbyByZXR1cm5lZCBsZW4oKSBhcyB6ZXJvLiAgVGhlIGNoYW5nZSBtYXkKICBjcmVhdGUgbmV3IGJyZWFrYWdlIGlmIHRoZSBjYWxsZXIgcmVsaWVkIG9uIHRoZSB1bmRvY3VtZW50ZWQgYmVoYXZpb3IKICBhbmQgY2FsbGVkIHdpdGggY2FsbGJhY2sgc2V0IHRvIFtdIG9yIHNvbWUgb3RoZXIgRmFsc2UgdmFsdWUgbm90CiAgaWRlbnRpY2FsIHRvIE5vbmUuCgotIHJhbmRvbS5nYXVzcygpIHVzZXMgYSBwaWVjZSBvZiBoaWRkZW4gc3RhdGUgdXNlZCBieSBub3RoaW5nIGVsc2UsCiAgYW5kIHRoZSAuc2VlZCgpIGFuZCAud2hzZWVkKCkgbWV0aG9kcyBmYWlsZWQgdG8gcmVzZXQgaXQuICBJbiBvdGhlcgogIHdvcmRzLCBzZXR0aW5nIHRoZSBzZWVkIGRpZG4ndCBjb21wbGV0ZWx5IGRldGVybWluZSB0aGUgc2VxdWVuY2Ugb2YKICByZXN1bHRzIHByb2R1Y2VkIGJ5IHJhbmRvbS5nYXVzcygpLiAgSXQgZG9lcyBub3cuICBQcm9ncmFtcyByZXBlYXRlZGx5CiAgbWl4aW5nIGNhbGxzIHRvIGEgc2VlZCBtZXRob2Qgd2l0aCBjYWxscyB0byBnYXVzcygpIG1heSBzZWUgZGlmZmVyZW50CiAgcmVzdWx0cyBub3cuCgotIFRoZSBwaWNrbGUuUGlja2xlciBjbGFzcyBncmV3IGEgY2xlYXJfbWVtbygpIG1ldGhvZCB0byBtaW1pYyB0aGF0CiAgcHJvdmlkZWQgYnkgY1BpY2tsZS5QaWNrbGVyLgoKLSBkaWZmbGliJ3MgU2VxdWVuY2VNYXRjaGVyIGNsYXNzIG5vdyBkb2VzIGEgZHluYW1pYyBhbmFseXNpcyBvZgogIHdoaWNoIGVsZW1lbnRzIGFyZSBzbyBmcmVxdWVudCBhcyB0byBjb25zdGl0dXRlIG5vaXNlLiAgRm9yCiAgY29tcGFyaW5nIGZpbGVzIGFzIHNlcXVlbmNlcyBvZiBsaW5lcywgdGhpcyBnZW5lcmFsbHkgd29ya3MgYmV0dGVyCiAgdGhhbiB0aGUgSVNfTElORV9KVU5LIGZ1bmN0aW9uLCBhbmQgZnVuY3Rpb24gbmRpZmYncyBsaW5lanVuawogIGFyZ3VtZW50IGRlZmF1bHRzIHRvIE5vbmUgbm93IGFzIGEgcmVzdWx0LiAgQSBoYXBweSBiZW5lZml0IGlzCiAgdGhhdCBTZXF1ZW5jZU1hdGNoZXIgbWF5IHJ1biBtdWNoIGZhc3RlciBub3cgd2hlbiBhcHBsaWVkCiAgdG8gbGFyZ2UgZmlsZXMgd2l0aCBtYW55IGR1cGxpY2F0ZSBsaW5lcyAoZm9yIGV4YW1wbGUsIEMgcHJvZ3JhbQogIHRleHQgd2l0aCBsb3RzIG9mIHJlcGVhdGVkICJ9IiBhbmQgInJldHVybiBOVUxMOyIgbGluZXMpLgoKLSBOZXcgVGV4dC5kdW1wKCkgbWV0aG9kIGluIFRraW50ZXIgbW9kdWxlLgoKLSBOZXcgZGlzdHV0aWxzIGNvbW1hbmRzIGZvciBidWlsZGluZyBwYWNrYWdlcnMgd2VyZSBhZGRlZCB0bwogIHN1cHBvcnQgcGtndG9vbCBvbiBTb2xhcmlzIGFuZCBzd2luc3RhbGwgb24gSFAtVVguCgotIGRpc3R1dGlscyBub3cgaGFzIGEgbmV3IGFic3RyYWN0IGJpbmFyeSBwYWNrYWdlciBiYXNlIGNsYXNzCiAgY29tbWFuZC9iZGlzdF9wYWNrYWdlciwgd2hpY2ggc2ltcGxpZmllcyB3cml0aW5nIHBhY2thZ2Vycy4KICBUaGlzIHdpbGwgaG9wZWZ1bGx5IHByb3ZpZGUgdGhlIG1pc3NpbmcgYml0cyB0byBlbmNvdXJhZ2UKICBwZW9wbGUgdG8gc3VibWl0IG1vcmUgcGFja2FnZXJzLCBlLmcuIGZvciBEZWJpYW4sIEZyZWVCU0QKICBhbmQgb3RoZXIgc3lzdGVtcy4KCi0gVGhlIFVURi0xNiwgLUxFIGFuZCAtQkUgc3RyZWFtIHJlYWRlcnMgbm93IHJhaXNlIGEKICBOb3RJbXBsZW1lbnRlZEVycm9yIGZvciBhbGwgY2FsbHMgdG8gLnJlYWRsaW5lKCkuIFByZXZpb3VzbHksIHRoZXkKICB1c2VkIHRvIGp1c3QgcHJvZHVjZSBnYXJiYWdlIG9yIGZhaWwgd2l0aCBhbiBlbmNvZGluZyBlcnJvciAtLQogIFVURi0xNiBpcyBhIDItYnl0ZSBlbmNvZGluZyBhbmQgdGhlIEMgbGliJ3MgbGluZSByZWFkaW5nIEFQSXMgZG9uJ3QKICB3b3JrIHdlbGwgd2l0aCB0aGVzZS4KCi0gY29tcGlsZWFsbCBub3cgc3VwcG9ydHMgcXVpZXQgb3BlcmF0aW9uLgoKLSBUaGUgQmFzZUhUVFBTZXJ2ZXIgbm93IGltcGxlbWVudHMgb3B0aW9uYWwgSFRUUC8xLjEgcGVyc2lzdGVudAogIGNvbm5lY3Rpb25zLgoKLSBzb2NrZXQgbW9kdWxlOiB0aGUgU1NMIHN1cHBvcnQgd2FzIGJyb2tlbiBvdXQgb2YgdGhlIG1haW4KICBfc29ja2V0IG1vZHVsZSBDIGhlbHBlciBhbmQgcGxhY2VkIGludG8gYSBuZXcgX3NzbCBoZWxwZXIKICB3aGljaCBub3cgZ2V0cyBpbXBvcnRlZCBieSBzb2NrZXQucHkgaWYgYXZhaWxhYmxlIGFuZCB3b3JraW5nLgoKLSBlbmNvZGluZ3MgcGFja2FnZTogYWRkZWQgYWxpYXNlcyBmb3IgYWxsIHN1cHBvcnRlZCBJQU5BIGNoYXJhY3RlcgogIHNldHMKCi0gZnRwbGliOiB0byBzYWZlZ3VhcmQgdGhlIHVzZXIncyBwcml2YWN5LCBhbm9ueW1vdXMgbG9naW4gd2lsbCB1c2UKICAiYW5vbnltb3VzQCIgYXMgZGVmYXVsdCBwYXNzd29yZCwgcmF0aGVyIHRoYW4gdGhlIHJlYWwgdXNlciBhbmQgaG9zdAogIG5hbWUuCgotIHdlYmJyb3dzZXI6IHRpZ2h0ZW5lZCB1cCB0aGUgY29tbWFuZCBwYXNzZWQgdG8gb3Muc3lzdGVtKCkgc28gdGhhdAogIGFyYml0cmFyeSBzaGVsbCBjb2RlIGNhbid0IGJlIGV4ZWN1dGVkIGJlY2F1c2UgYSBib2d1cyBVUkwgd2FzCiAgcGFzc2VkIGluLgoKLSBnZXR0ZXh0LnRyYW5zbGF0aW9uIGhhcyBhbiBvcHRpb25hbCBmYWxsYmFjayBhcmd1bWVudCwgYW5kCiAgZ2V0dGV4dC5maW5kIGFuIG9wdGlvbmFsIGFsbCBhcmd1bWVudC4gVHJhbnNsYXRpb25zIHdpbGwgbm93IGZhbGxiYWNrCiAgb24gYSBwZXItbWVzc2FnZSBiYXNpcy4gVGhlIG1vZHVsZSBzdXBwb3J0cyBwbHVyYWwgZm9ybXMsIGJ5IG1lYW5zCiAgb2YgZ2V0dGV4dC5bZF1uZ2V0dGV4dCBhbmQgVHJhbnNsYXRpb24uW3VdbmdldHRleHQuCgotIGRpc3R1dGlscyBiZGlzdCBjb21tYW5kcyBub3cgb2ZmZXIgYSAtLXNraXAtYnVpbGQgb3B0aW9uLgoKLSB3YXJuaW5ncy53YXJuIG5vdyBhY2NlcHRzIGEgV2FybmluZyBpbnN0YW5jZSBhcyBmaXJzdCBhcmd1bWVudC4KCi0gVGhlIHhtbC5zYXguZXhwYXRyZWFkZXIuRXhwYXRQYXJzZXIgY2xhc3Mgd2lsbCBubyBsb25nZXIgY3JlYXRlCiAgY2lyY3VsYXIgcmVmZXJlbmNlcyBieSB1c2luZyBpdHNlbGYgYXMgdGhlIGxvY2F0b3IgdGhhdCBnZXRzIHBhc3NlZAogIHRvIHRoZSBjb250ZW50IGhhbmRsZXIgaW1wbGVtZW50YXRpb24uICBbU0YgYnVnICM1MzU0NzRdCgotIFRoZSBlbWFpbC5QYXJzZXIuUGFyc2VyIGNsYXNzIG5vdyBwcm9wZXJseSBwYXJzZXMgc3RyaW5ncyByZWdhcmRsZXNzCiAgb2YgdGhlaXIgbGluZSBlbmRpbmdzLCB3aGljaCBjYW4gYmUgYW55IG9mIFxyLCBcbiwgb3IgXHJcbiAoQ1IsIExGLAogIG9yIENSTEYpLiAgQWxzbywgdGhlIEhlYWRlciBjbGFzcydzIGNvbnN0cnVjdG9yIGRlZmF1bHQgYXJndW1lbnRzCiAgaGFzIGNoYW5nZWQgc2xpZ2h0bHkgc28gdGhhdCBhbiBleHBsaWNpdCBtYXhsaW5lbGVuIHZhbHVlIGlzIGFsd2F5cwogIGhvbm9yZWQsIGFuZCBzbyB1bmljb2RlIGNvbnZlcnNpb24gZXJyb3IgaGFuZGxpbmcgY2FuIGJlIHNwZWNpZmllZC4KCi0gZGlzdHV0aWxzJyBidWlsZF9leHQgY29tbWFuZCBub3cgbGlua3MgQysrIGV4dGVuc2lvbnMgd2l0aCB0aGUgQysrCiAgY29tcGlsZXIgYXZhaWxhYmxlIGluIHRoZSBNYWtlZmlsZSBvciBDWFggZW52aXJvbm1lbnQgdmFyaWFibGUsIGlmCiAgcnVubmluZyB1bmRlciBcKm5peC4KCi0gTmV3IG1vZHVsZSBiejI6IHByb3ZpZGVzIGEgY29tcHJlaGVuc2l2ZSBpbnRlcmZhY2UgZm9yIHRoZSBiejIgY29tcHJlc3Npb24KICBsaWJyYXJ5LiAgSXQgaW1wbGVtZW50cyBhIGNvbXBsZXRlIGZpbGUgaW50ZXJmYWNlLCBvbmUtc2hvdCAoZGUpY29tcHJlc3Npb24KICBmdW5jdGlvbnMsIGFuZCB0eXBlcyBmb3Igc2VxdWVudGlhbCAoZGUpY29tcHJlc3Npb24uCgotIE5ldyBwZGIgY29tbWFuZCAncHAnIHdoaWNoIGlzIGxpa2UgJ3AnIGV4Y2VwdCB0aGF0IGl0IHByZXR0eS1wcmludHMKICB0aGUgdmFsdWUgb2YgaXRzIGV4cHJlc3Npb24gYXJndW1lbnQuCgotIE5vdyBiZGlzdF9ycG0gZGlzdHV0aWxzIGNvbW1hbmQgdW5kZXJzdGFuZHMgYSB2ZXJpZnlfc2NyaXB0IG9wdGlvbiBpbgogIHRoZSBjb25maWcgZmlsZSwgaW5jbHVkaW5nIHRoZSBjb250ZW50cyBvZiB0aGUgcmVmZXJyZWQgZmlsZW5hbWUgaW4KICB0aGUgIiV2ZXJpZnlzY3JpcHQiIHNlY3Rpb24gb2YgdGhlIHJwbSBzcGVjIGZpbGUuCgotIEZpeGVkIGJ1ZyAjNDk1Njk1OiB3ZWJicm93c2VyIG1vZHVsZSB3b3VsZCBydW4gZ3JhcGhpYyBicm93c2VycyBpbiBhCiAgdW5peCBlbnZpcm9ubWVudCBldmVuIGlmIERJU1BMQVkgd2FzIG5vdCBzZXQuIEFsc28sIHN1cHBvcnQgZm9yCiAgc2tpcHN0b25lIGJyb3dzZXIgd2FzIGluY2x1ZGVkLgoKLSBGaXhlZCBidWcgIzYzNjc2OTogcmV4ZWMgd291bGQgcnVuIHVuYWxsb3dlZCBjb2RlIGlmIHN1YmNsYXNzZXMgb2YKICBzdHJpbmdzIHdlcmUgdXNlZCBhcyBwYXJhbWV0ZXJzIGZvciBjZXJ0YWluIGZ1bmN0aW9ucy4KClRvb2xzL0RlbW9zCi0tLS0tLS0tLS0tCgotIHB5Z2V0dGV4dC5weSBub3cgc3VwcG9ydHMgZ2xvYmJpbmcgb24gV2luZG93cywgYW5kIGFjY2VwdHMgbW9kdWxlCiAgbmFtZXMgaW4gYWRkaXRpb24gdG8gYWNjZXB0aW5nIGZpbGUgbmFtZXMuCgotIFRoZSBTR0kgZGVtb3MgKERlbW8vc2dpKSBoYXZlIGJlZW4gcmVtb3ZlZC4gIE5vYm9keSB0aG91Z2h0IHRoZXkKICB3ZXJlIGludGVyZXN0aW5nIGFueSBtb3JlLiAgKFRoZSBTR0kgbGlicmFyeSBtb2R1bGVzIGFuZCBleHRlbnNpb25zCiAgYXJlIHN0aWxsIHRoZXJlOyBpdCBpcyBiZWxpZXZlZCB0aGF0IGF0IGxlYXN0IHNvbWUgb2YgdGhlc2UgYXJlCiAgc3RpbGwgdXNlZCBhbmQgdXNlZnVsLikKCi0gSURMRSBzdXBwb3J0cyB0aGUgbmV3IGVuY29kaW5nIGRlY2xhcmF0aW9ucyAoUEVQIDI2Myk7IGl0IGNhbiBhbHNvCiAgZGVhbCB3aXRoIGxlZ2FjeSA4LWJpdCBmaWxlcyBpZiB0aGV5IHVzZSB0aGUgbG9jYWxlJ3MgZW5jb2RpbmcuIEl0CiAgYWxsb3dzIG5vbi1BU0NJSSBzdHJpbmdzIGluIHRoZSBpbnRlcmFjdGl2ZSBzaGVsbCBhbmQgZXhlY3V0ZXMgdGhlbQogIGluIHRoZSBsb2NhbGUncyBlbmNvZGluZy4KCi0gZnJlZXplLnB5IG5vdyBwcm9kdWNlcyBiaW5hcmllcyB3aGljaCBjYW4gaW1wb3J0IHNoYXJlZCBtb2R1bGVzLAogIHVubGlrZSBiZWZvcmUgd2hlbiB0aGlzIGZhaWxlZCBkdWUgdG8gbWlzc2luZyBzeW1ib2wgZXhwb3J0cyBpbgogIHRoZSBnZW5lcmF0ZWQgYmluYXJ5LgoKQnVpbGQKLS0tLS0KCi0gT24gVW5peCwgSURMRSBpcyBub3cgaW5zdGFsbGVkIGF1dG9tYXRpY2FsbHkuCgotIFRoZSBmcGVjdGwgbW9kdWxlIGlzIG5vdCBidWlsdCBieSBkZWZhdWx0OyBpdCdzIGRhbmdlcm91cyBvciB1c2VsZXNzCiAgZXhjZXB0IGluIHRoZSBoYW5kcyBvZiBleHBlcnRzLgoKLSBUaGUgcHVibGljIFB5dGhvbiBDIEFQSSB3aWxsIGdlbmVyYWxseSBiZSBkZWNsYXJlZCB1c2luZyBQeUFQSV9GVU5DCiAgYW5kIFB5QVBJX0RBVEEgbWFjcm9zLCB3aGlsZSBQeXRob24gZXh0ZW5zaW9uIG1vZHVsZSBpbml0IGZ1bmN0aW9ucwogIHdpbGwgYmUgZGVjbGFyZWQgd2l0aCBQeU1PRElOSVRfRlVOQy4gIERMX0VYUE9SVC9ETF9JTVBPUlQgbWFjcm9zCiAgYXJlIGRlcHJlY2F0ZWQuCgotIEEgYnVnIHdhcyBmaXhlZCB0aGF0IGNvdWxkIGNhdXNlIENPVU5UX0FMTE9DUyBidWlsZHMgdG8gc2VnZmF1bHQsIG9yCiAgZ2V0IGludG8gaW5maW5pdGUgbG9vcHMsIHdoZW4gYSBuZXctc3R5bGUgY2xhc3MgZ290IGdhcmJhZ2UtY29sbGVjdGVkLgogIFVuZm9ydHVuYXRlbHksIHRvIGF2b2lkIHRoaXMsIHRoZSB3YXkgQ09VTlRfQUxMT0NTIHdvcmtzIHJlcXVpcmVzCiAgdGhhdCBuZXctc3R5bGUgY2xhc3NlcyBiZSBpbW1vcnRhbCBpbiBDT1VOVF9BTExPQ1MgYnVpbGRzLiAgTm90ZSB0aGF0CiAgQ09VTlRfQUxMT0NTIGlzIG5vdCBlbmFibGVkIGJ5IGRlZmF1bHQsIGluIGVpdGhlciByZWxlYXNlIG9yIGRlYnVnCiAgYnVpbGRzLCBhbmQgdGhhdCBuZXctc3R5bGUgY2xhc3NlcyBhcmUgaW1tb3J0YWwgb25seSBpbiBDT1VOVF9BTExPQ1MKICBidWlsZHMuCgotIENvbXBpbGluZyBvdXQgdGhlIGN5Y2xpYyBnYXJiYWdlIGNvbGxlY3RvciBpcyBubyBsb25nZXIgYW4gb3B0aW9uLgogIFRoZSBvbGQgc3ltYm9sIFdJVEhfQ1lDTEVfR0MgaXMgbm93IGlnbm9yZWQsIGFuZCBQeXRob24uaCBhcnJhbmdlcwogIHRoYXQgaXQncyBhbHdheXMgZGVmaW5lZCAoZm9yIHRoZSBiZW5lZml0IG9mIGFueSBleHRlbnNpb24gbW9kdWxlcwogIHRoYXQgbWF5IGJlIGNvbmRpdGlvbmFsaXppbmcgb24gaXQpLiAgQSBib251cyBpcyB0aGF0IGFueSBleHRlbnNpb24KICB0eXBlIHBhcnRpY2lwYXRpbmcgaW4gY3ljbGljIGdjIGNhbiBjaG9vc2UgdG8gcGFydGljaXBhdGUgaW4gdGhlCiAgUHlfVFJBU0hDQU4gbWVjaGFuaXNtIG5vdyB0b287IGluIHRoZSBhYnNlbmNlIG9mIGN5Y2xpYyBnYywgdGhpcyB1c2VkCiAgdG8gcmVxdWlyZSBlZGl0aW5nIHRoZSBjb3JlIHRvIHRlYWNoIHRoZSB0cmFzaGNhbiBtZWNoYW5pc20gYWJvdXQgdGhlCiAgbmV3IHR5cGUuCgotIEFjY29yZGluZyB0byBBbm5leCBGIG9mIHRoZSBjdXJyZW50IEMgc3RhbmRhcmQsCgogICAgVGhlIFN0YW5kYXJkIEMgbWFjcm8gSFVHRV9WQUwgYW5kIGl0cyBmbG9hdCBhbmQgbG9uZyBkb3VibGUgYW5hbG9ncywKICAgIEhVR0VfVkFMRiBhbmQgSFVHRV9WQUxMLCBleHBhbmQgdG8gZXhwcmVzc2lvbnMgd2hvc2UgdmFsdWVzIGFyZQogICAgcG9zaXRpdmUgaW5maW5pdGllcy4KCiAgUHl0aG9uIG9ubHkgdXNlcyB0aGUgZG91YmxlIEhVR0VfVkFMLCBhbmQgb25seSB0byAjZGVmaW5lIGl0cyBvd24gc3ltYm9sCiAgUHlfSFVHRV9WQUwuICBTb21lIHBsYXRmb3JtcyBoYXZlIGluY29ycmVjdCBkZWZpbml0aW9ucyBmb3IgSFVHRV9WQUwuCiAgcHlwb3J0LmggdXNlZCB0byB0cnkgdG8gd29ybSBhcm91bmQgdGhhdCwgYnV0IHRoZSB3b3JrYXJvdW5kcyB0cmlnZ2VyZWQKICBvdGhlciBidWdzIG9uIG90aGVyIHBsYXRmb3Jtcywgc28gd2UgZ2F2ZSB1cC4gIElmIHlvdXIgcGxhdGZvcm0gZGVmaW5lcwogIEhVR0VfVkFMIGluY29ycmVjdGx5LCB5b3UnbGwgbmVlZCB0byAjZGVmaW5lIFB5X0hVR0VfVkFMIHRvIHNvbWV0aGluZwogIHRoYXQgd29ya3Mgb24geW91ciBwbGF0Zm9ybS4gIFRoZSBvbmx5IGluc3RhbmNlIG9mIHRoaXMgSSdtIHN1cmUgYWJvdXQKICBpcyBvbiBhbiB1bmtub3duIHN1YnNldCBvZiBDcmF5IHN5c3RlbXMsIGRlc2NyaWJlZCBoZXJlOgoKICBodHRwOi8vd3d3LmNyYXkuY29tL3N3cHVicy9tYW51YWxzL1NOLTIxOTRfMi4wL2h0bWwtU04tMjE5NF8yLjAveDMxMzguaHRtCgogIFByZXN1bWFibHkgMi4zYTEgYnJlYWtzIHN1Y2ggc3lzdGVtcy4gIElmIGFueW9uZSB1c2VzIHN1Y2ggYSBzeXN0ZW0sIGhlbHAhCgotIFRoZSBjb25maWd1cmUgb3B0aW9uIC0td2l0aG91dC1kb2Mtc3RyaW5ncyBjYW4gYmUgdXNlZCB0byByZW1vdmUgdGhlCiAgZG9jIHN0cmluZ3MgZnJvbSB0aGUgYnVpbHRpbiBmdW5jdGlvbnMgYW5kIG1vZHVsZXM7IHRoaXMgcmVkdWNlcyB0aGUKICBzaXplIG9mIHRoZSBleGVjdXRhYmxlLgoKLSBUaGUgdW5pdmVyc2FsIG5ld2xpbmVzIG9wdGlvbiAoUEVQIDI3OCkgaXMgb24gYnkgZGVmYXVsdC4gIE9uIFVuaXgKICBpdCBjYW4gYmUgZGlzYWJsZWQgYnkgcGFzc2luZyAtLXdpdGhvdXQtdW5pdmVyc2FsLW5ld2xpbmVzIHRvIHRoZQogIGNvbmZpZ3VyZSBzY3JpcHQuICBPbiBvdGhlciBwbGF0Zm9ybXMsIHJlbW92ZQogIFdJVEhfVU5JVkVSU0FMX05FV0xJTkVTIGZyb20gcHljb25maWcuaC4KCi0gT24gVW5peCwgYSBzaGFyZWQgbGlicHl0aG9uMi4zLnNvIGNhbiBiZSBjcmVhdGVkIHdpdGggLS1lbmFibGUtc2hhcmVkLgoKLSBBbGwgdXNlcyBvZiB0aGUgQ0FDSEVfSEFTSCwgSU5URVJOX1NUUklOR1MsIGFuZCBET05UX1NIQVJFX1NIT1JUX1NUUklOR1MKICBwcmVwcm9jZXNzb3Igc3ltYm9scyB3ZXJlIGVsaW1pbmF0ZWQuICBUaGUgaW50ZXJuYWwgZGVjaXNpb25zIHRoZXkKICBjb250cm9sbGVkIHN0b3BwZWQgYmVpbmcgZXhwZXJpbWVudGFsIGxvbmcgYWdvLgoKLSBUaGUgdG9vbHMgdXNlZCB0byBidWlsZCB0aGUgZG9jdW1lbnRhdGlvbiBub3cgd29yayB1bmRlciBDeWd3aW4gYXMKICB3ZWxsIGFzIFVuaXguCgotIFRoZSBic2RkYiBhbmQgZGJtIG1vZHVsZSBidWlsZHMgaGF2ZSBiZWVuIGNoYW5nZWQgdG8gdHJ5IGFuZCBhdm9pZCB2ZXJzaW9uCiAgc2tldyBwcm9ibGVtcyBhbmQgZGlzYWJsZSBsaW5rYWdlIHdpdGggQmVya2VsZXkgREIgMS44NSB1bmxlc3MgdGhlCiAgaW5zdGFsbGVyIGtub3dzIHdoYXQgcy9oZSdzIGRvaW5nLiAgU2VlIHRoZSBzZWN0aW9uIG9uIGJ1aWxkaW5nIHRoZXNlCiAgbW9kdWxlcyBpbiB0aGUgUkVBRE1FIGZpbGUgZm9yIGRldGFpbHMuCgpDIEFQSQotLS0tLQoKLSBQeU51bWJlcl9DaGVjaygpIG5vdyByZXR1cm5zIHRydWUgZm9yIHN0cmluZyBhbmQgdW5pY29kZSBvYmplY3RzLgogIFRoaXMgaXMgYSByZXN1bHQgb2YgdGhlc2UgdHlwZXMgaGF2aW5nIGEgcGFydGlhbGx5IGRlZmluZWQKICB0cF9hc19udW1iZXIgc2xvdC4gIChUaGlzIGlzIG5vdCBhIGZlYXR1cmUsIGJ1dCBhbiBpbmRpY2F0aW9uIHRoYXQKICBQeU51bWJlcl9DaGVjaygpIGlzIG5vdCB2ZXJ5IHVzZWZ1bCB0byBkZXRlcm1pbmUgbnVtZXJpYyBiZWhhdmlvci4KICBJdCBtYXkgYmUgZGVwcmVjYXRlZC4pCgotIFRoZSBzdHJpbmcgb2JqZWN0J3MgbGF5b3V0IGhhcyBjaGFuZ2VkOiB0aGUgcG9pbnRlciBtZW1iZXIKICBvYl9zaW50ZXJuZWQgaGFzIGJlZW4gcmVwbGFjZWQgYnkgYW4gaW50IG1lbWJlciBvYl9zc3RhdGUuICBPbiBzb21lCiAgcGxhdGZvcm1zIChlLmcuIG1vc3QgNjQtYml0IHN5c3RlbXMpIHRoaXMgbWF5IGNoYW5nZSB0aGUgb2Zmc2V0IG9mCiAgdGhlIG9iX3N2YWwgbWVtYmVyLCBzbyBhcyBhIHByZWNhdXRpb24gdGhlIEFQSV9WRVJTSU9OIGhhcyBiZWVuCiAgaW5jcmVtZW50ZWQuICBUaGUgYXBwYXJlbnRseSB1bnVzZWQgZmVhdHVyZSBvZiAiaW5kaXJlY3QgaW50ZXJuZWQKICBzdHJpbmdzIiwgc3VwcG9ydGVkIGJ5IHRoZSBvYl9zaW50ZXJuZWQgbWVtYmVyLCBpcyBnb25lLiAgSW50ZXJuZWQKICBzdHJpbmdzIGFyZSBub3cgdXN1YWxseSBtb3J0YWw7IHRoZXJlcyBhIG5ldyBBUEksCiAgUHlTdHJpbmdfSW50ZXJuSW1tb3J0YWwoKSB0aGF0IGNyZWF0ZXMgaW1tb3J0YWwgaW50ZXJuZWQgc3RyaW5ncy4KICAoVGhlIG9iX3NzdGF0ZSBtZW1iZXIgY2FuIG9ubHkgdGFrZSB0aHJlZSB2YWx1ZXM7IGhvd2V2ZXIsIHdoaWxlCiAgbWFraW5nIGl0IGEgY2hhciBzYXZlcyBhIGZldyBieXRlcyBwZXIgc3RyaW5nIG9iamVjdCBvbiBhdmVyYWdlLCBpbgogIGl0IGFsc28gc2xvd2VkIHRoaW5ncyBkb3duIGEgYml0IGJlY2F1c2Ugb2Jfc3ZhbCB3YXMgbm8gbG9uZ2VyCiAgYWxpZ25lZC4pCgotIFRoZSBQeV9Jbml0TW9kdWxlKigpIGZ1bmN0aW9ucyBub3cgYWNjZXB0IE5VTEwgZm9yIHRoZSAnbWV0aG9kcycKICBhcmd1bWVudC4gIE1vZHVsZXMgd2l0aG91dCBnbG9iYWwgZnVuY3Rpb25zIGFyZSBiZWNvbWluZyBtb3JlIGNvbW1vbgogIG5vdyB0aGF0IGZhY3RvcmllcyBjYW4gYmUgdHlwZXMgcmF0aGVyIHRoYW4gZnVuY3Rpb25zLgoKLSBOZXcgQyBBUEkgUHlVbmljb2RlX0Zyb21PcmRpbmFsKCkgd2hpY2ggZXhwb3NlcyB1bmljaHIoKSBhdCBDCiAgbGV2ZWwuCgotIE5ldyBmdW5jdGlvbnMgUHlFcnJfU2V0RXhjRnJvbVdpbmRvd3NFcnIoKSBhbmQKICBQeUVycl9TZXRFeGNGcm9tV2luZG93c0VycldpdGhGaWxlbmFtZSgpLiBTaW1pbGFyIHRvCiAgUHlFcnJfU2V0RnJvbVdpbmRvd3NFcnJXaXRoRmlsZW5hbWUoKSBhbmQKICBQeUVycl9TZXRGcm9tV2luZG93c0VycigpLCBidXQgdGhleSBhbGxvdyB0byBzcGVjaWZ5CiAgdGhlIGV4Y2VwdGlvbiB0eXBlIHRvIHJhaXNlLiBBdmFpbGFibGUgb24gV2luZG93cy4KCi0gUHlfRmF0YWxFcnJvcigpIGlzIG5vdyBkZWNsYXJlZCBhcyB0YWtpbmcgYSBjb25zdCBjaGFyKiBhcmd1bWVudC4gIEl0CiAgd2FzIHByZXZpb3VzbHkgZGVjbGFyZWQgd2l0aG91dCBjb25zdC4gIFRoaXMgc2hvdWxkIG5vdCBhZmZlY3Qgd29ya2luZwogIGNvZGUuCgotIEFkZGVkIG5ldyBtYWNybyBQeVNlcXVlbmNlX0lURU0obywgaSkgdGhhdCBkaXJlY3RseSBjYWxscwogIHNxX2l0ZW0gd2l0aG91dCByZWNoZWNraW5nIHRoYXQgbyBpcyBhIHNlcXVlbmNlIGFuZCB3aXRob3V0CiAgYWRqdXN0aW5nIGZvciBuZWdhdGl2ZSBpbmRpY2VzLgoKLSBQeVJhbmdlX05ldygpIG5vdyByYWlzZXMgVmFsdWVFcnJvciBpZiB0aGUgZm91cnRoIGFyZ3VtZW50IGlzIG5vdCAxLgogIFRoaXMgaXMgcGFydCBvZiB0aGUgcmVtb3ZhbCBvZiBkZXByZWNhdGVkIGZlYXR1cmVzIG9mIHRoZSB4cmFuZ2UKICBvYmplY3QuCgotIFB5TnVtYmVyX0NvZXJjZSgpIGFuZCBQeU51bWJlcl9Db2VyY2VFeCgpIG5vdyBhbHNvIGludm9rZSB0aGUgdHlwZSdzCiAgY29lcmNpb24gaWYgYm90aCBhcmd1bWVudHMgaGF2ZSB0aGUgc2FtZSB0eXBlIGJ1dCB0aGlzIHR5cGUgaGFzIHRoZQogIENIRUNLVFlQRVMgZmxhZyBzZXQuICBUaGlzIGlzIHRvIGJldHRlciBzdXBwb3J0IHByb3hpZXMuCgotIFRoZSB0eXBlIG9mIHRwX2ZyZWUgaGFzIGJlZW4gY2hhbmdlZCBmcm9tICJgYHZvaWQgKCopKFB5T2JqZWN0ICopYGAiIHRvCiAgImBgdm9pZCAoKikodm9pZCAqKWBgIi4KCi0gUHlPYmplY3RfRGVsLCBQeU9iamVjdF9HQ19EZWwgYXJlIG5vdyBmdW5jdGlvbnMgaW5zdGVhZCBvZiBtYWNyb3MuCgotIEEgdHlwZSBjYW4gbm93IGluaGVyaXQgaXRzIG1ldGF0eXBlIGZyb20gaXRzIGJhc2UgdHlwZS4gIFByZXZpb3VzbHksCiAgd2hlbiBQeVR5cGVfUmVhZHkoKSB3YXMgY2FsbGVkLCBpZiBvYl90eXBlIHdhcyBmb3VuZCB0byBiZSBOVUxMLCBpdAogIHdhcyBhbHdheXMgc2V0IHRvICZQeVR5cGVfVHlwZTsgbm93IGl0IGlzIHNldCB0byBiYXNlLT5vYl90eXBlLAogIHdoZXJlIGJhc2UgaXMgdHBfYmFzZSwgZGVmYXVsdGluZyB0byAmUHlPYmplY3RfVHlwZS4KCi0gUHlUeXBlX1JlYWR5KCkgYWNjaWRlbnRhbGx5IGRpZCBub3QgaW5oZXJpdCB0cF9pc19nYzsgbm93IGl0IGRvZXMuCgotIFRoZSBQeUNvcmVfKiBmYW1pbHkgb2YgQVBJcyBoYXZlIGJlZW4gcmVtb3ZlZC4KCi0gVGhlICJ1IyIgcGFyc2VyIG1hcmtlciB3aWxsIG5vdyBwYXNzIHRocm91Z2ggVW5pY29kZSBvYmplY3RzIGFzLWlzCiAgd2l0aG91dCBnb2luZyB0aHJvdWdoIHRoZSBidWZmZXIgQVBJLgoKLSBUaGUgZW51bWVyYXRvcnMgb2YgY21wX29wIGhhdmUgYmVlbiByZW5hbWVkIHRvIHVzZSB0aGUgcHJlZml4IGBgUHlDbXBfYGAuCgotIEFuIG9sZCAjZGVmaW5lIG9mIEFOWSBhcyB2b2lkIGhhcyBiZWVuIHJlbW92ZWQgZnJvbSBweXBvcnQuaC4gIFRoaXMKICBoYXNuJ3QgYmVlbiB1c2VkIHNpbmNlIFB5dGhvbidzIHByZS1BTlNJIGRheXMsIGFuZCB0aGUgI2RlZmluZSBoYXMKICBiZWVuIG1hcmtlZCBhcyBvYnNvbGV0ZSBzaW5jZSB0aGVuLiAgU0YgYnVnIDQ5NTU0OCBzYXlzIGl0IGNyZWF0ZWQKICBjb25mbGljdHMgd2l0aCBvdGhlciBwYWNrYWdlcywgc28ga2VlcGluZyBpdCBhcm91bmQgd2Fzbid0IGhhcm1sZXNzLgoKLSBCZWNhdXNlIFB5dGhvbidzIG1hZ2ljIG51bWJlciBzY2hlbWUgYnJva2Ugb24gSmFudWFyeSAxc3QsIHdlIGRlY2lkZWQKICB0byBzdG9wIFB5dGhvbiBkZXZlbG9wbWVudC4gIFRoYW5rcyBmb3IgYWxsIHRoZSBmaXNoIQoKLSBTb21lIG9mIHVzIGRvbid0IGxpa2UgZmlzaCwgc28gd2UgY2hhbmdlZCBQeXRob24ncyBtYWdpYyBudW1iZXIKICBzY2hlbWUgdG8gYSBuZXcgb25lLiBTZWUgUHl0aG9uL2ltcG9ydC5jIGZvciBkZXRhaWxzLgoKTmV3IHBsYXRmb3JtcwotLS0tLS0tLS0tLS0tCgotIE9wZW5WTVMgaXMgbm93IHN1cHBvcnRlZC4KCi0gQXRoZU9TIGlzIG5vdyBzdXBwb3J0ZWQuCgotIHRoZSBFTVggcnVudGltZSBlbnZpcm9ubWVudCBvbiBPUy8yIGlzIG5vdyBzdXBwb3J0ZWQuCgotIEdOVS9IdXJkIGlzIG5vdyBzdXBwb3J0ZWQuCgpUZXN0cwotLS0tLQoKLSBUaGUgcmVncnRlc3QucHkgc2NyaXB0J3MgLXUgb3B0aW9uIG5vdyBwcm92aWRlcyBhIHdheSB0byBzYXkgImFsbG93CiAgYWxsIHJlc291cmNlcyBleGNlcHQgdGhpcyBvbmUuIiAgRm9yIGV4YW1wbGUsIHRvIGFsbG93IGV2ZXJ5dGhpbmcKICBleGNlcHQgYnNkZGIsIGdpdmUgdGhlIG9wdGlvbiAnLXVhbGwsLWJzZGRiJy4KCldpbmRvd3MKLS0tLS0tLQoKLSBUaGUgV2luZG93cyBkaXN0cmlidXRpb24gbm93IHNoaXBzIHdpdGggdmVyc2lvbiA0LjAuMTQgb2YgdGhlCiAgU2xlZXB5Y2F0IEJlcmtlbGV5IGRhdGFiYXNlIGxpYnJhcnkuICBUaGlzIHNob3VsZCBiZSBhIGh1Z2UKICBpbXByb3ZlbWVudCBvdmVyIHRoZSBwcmV2aW91cyBCZXJrZWxleSBEQiAxLjg1LCB3aGljaCBoYWQgbWFueQogIGJ1Z3MuCiAgWFhYIFdoYXQgYXJlIHRoZSBsaWNlbnNpbmcgaXNzdWVzIGhlcmU/CiAgWFhYIElmIGEgdXNlciBoYXMgYSBkYXRhYmFzZSBjcmVhdGVkIHdpdGggYSBwcmV2aW91cyB2ZXJpb24gb2YKICBYWFggICAgIFB5dGhvbiwgd2hhdCBtdXN0IHRoZXkgZG8gdG8gY29udmVydCBpdD8KICBYWFggSSdtIHN0aWxsIG5vdCBzdXJlIGhvdyB0byBsaW5rIHRoaXMgdGhpbmcgKHNlZSBQQ2J1aWxkL3JlYWRtZS50eHQpLgogIFhYWCBUaGUgdmVyc2lvbiAjIGlzIGxpa2VseSB0byBjaGFuZ2UgYmVmb3JlIDIuM2ExLgoKLSBUaGUgV2luZG93cyBkaXN0cmlidXRpb24gbm93IHNoaXBzIHdpdGggYSBTZWN1cmUgU29ja2V0cyBMaWJyYXJ5IChTTEwpCiAgIG1vZHVsZSAoX3NzbC5weWQpCgotIFRoZSBXaW5kb3dzIGRpc3RyaWJ1dGlvbiBub3cgc2hpcHMgd2l0aCBUY2wvVGsgdmVyc2lvbiA4LjQuMSAoaXQKICBwcmV2aW91c2x5IHNoaXBwZWQgd2l0aCBUY2wvVGsgOC4zLjIpLgoKLSBXaGVuIFB5dGhvbiBpcyBidWlsdCB1bmRlciBhIE1pY3Jvc29mdCBjb21waWxlciwgc3lzLnZlcnNpb24gbm93CiAgaW5jbHVkZXMgdGhlIGNvbXBpbGVyIHZlcnNpb24gbnVtYmVyIChfTVNDX1ZFUikuICBGb3IgZXhhbXBsZSwgdW5kZXIKICBNU1ZDIDYsIHN5cy52ZXJzaW9uIGNvbnN0YWlucyB0aGUgc3Vic3RyaW5nICJNU0Mgdi4xMjAwICIuICAxMjAwIGlzCiAgdGhlIHZhbHVlIG9mIF9NU0NfVkVSIHVuZGVyIE1TVkMgNi4KCi0gU29tZXRpbWVzIHRoZSB1bmluc3RhbGwgZXhlY3V0YWJsZSAoVU5XSVNFLkVYRSkgdmFuaXNoZXMuICBPbmUgY2F1c2UKICBvZiB0aGF0IGhhcyBiZWVuIGZpeGVkIGluIHRoZSBpbnN0YWxsZXIgKGRpc2FibGVkIFdpc2UncyAiZGVsZXRlIGluLQogIHVzZSBmaWxlcyIgdW5pbnN0YWxsIG9wdGlvbikuCgotIEZpeGVkIGEgYnVnIGluIHVybGxpYidzIHByb3h5IGhhbmRsaW5nIGluIFdpbmRvd3MuICBbU0YgYnVnICM1MDMwMzFdCgotIFRoZSBpbnN0YWxsZXIgbm93IGluc3RhbGxzIFN0YXJ0IG1lbnUgc2hvcnRjdXRzIHVuZGVyICh0aGUgbG9jYWwKICBlcXVpdmFsZW50IG9mKSAiQWxsIFVzZXJzIiB3aGVuIGRvaW5nIGFuIEFkbWluIGluc3RhbGwuCgotIGZpbGUudHJ1bmNhdGUoW25ld3NpemVdKSBub3cgd29ya3Mgb24gV2luZG93cyBmb3IgYWxsIG5ld3NpemUgdmFsdWVzLgogIEl0IHVzZWQgdG8gZmFpbCBpZiBuZXdzaXplIGRpZG4ndCBmaXQgaW4gMzIgYml0cywgcmVmbGVjdGluZyBhCiAgbGltaXRhdGlvbiBvZiBNUyBfY2hzaXplICh3aGljaCBpcyBubyBsb25nZXIgdXNlZCkuCgotIG9zLndhaXRwaWQoKSBpcyBub3cgaW1wbGVtZW50ZWQgZm9yIFdpbmRvd3MsIGFuZCBjYW4gYmUgdXNlZCB0byBibG9jawogIHVudGlsIGEgc3BlY2lmaWVkIHByb2Nlc3MgZXhpdHMuICBUaGlzIGlzIHNpbWlsYXIgdG8sIGJ1dCBub3QgZXhhY3RseQogIHRoZSBzYW1lIGFzLCBvcy53YWl0cGlkKCkgb24gUE9TSVggc3lzdGVtcy4gIElmIHlvdSdyZSB3YWl0aW5nIGZvcgogIGEgc3BlY2lmaWMgcHJvY2VzcyB3aG9zZSBwaWQgd2FzIG9idGFpbmVkIGZyb20gb25lIG9mIHRoZSBzcGF3bigpCiAgZnVuY3Rpb25zLCB0aGUgc2FtZSBQeXRob24gb3Mud2FpdHBpZCgpIGNvZGUgd29ya3MgYWNyb3NzIHBsYXRmb3Jtcy4KICBTZWUgdGhlIGRvY3MgZm9yIGRldGFpbHMuICBUaGUgZG9jcyB3ZXJlIGNoYW5nZWQgdG8gY2xhcmlmeSB0aGF0CiAgc3Bhd24gZnVuY3Rpb25zIHJldHVybiwgYW5kIHdhaXRwaWQgcmVxdWlyZXMsIGEgcHJvY2VzcyBoYW5kbGUgb24KICBXaW5kb3dzIChub3QgdGhlIHNhbWUgdGhpbmcgYXMgYSBXaW5kb3dzIHByb2Nlc3MgaWQpLgoKLSBOZXcgdGVtcGZpbGUuVGVtcG9yYXJ5RmlsZSBpbXBsZW1lbnRhdGlvbiBmb3IgV2luZG93czogIHRoaXMgZG9lc24ndAogIG5lZWQgYSBUZW1wb3JhcnlGaWxlV3JhcHBlciB3cmFwcGVyIGFueW1vcmUsIGFuZCBzaG91bGQgYmUgaW1tdW5lCiAgdG8gYSBuYXN0eSBwcm9ibGVtOiAgYmVmb3JlIDIuMywgaWYgeW91IGdvdCBhIHRlbXAgZmlsZSBvbiBXaW5kb3dzLCBpdAogIGdvdCB3cmFwcGVkIGluIGFuIG9iamVjdCB3aG9zZSBjbG9zZSgpIG1ldGhvZCBmaXJzdCBjbG9zZWQgdGhlCiAgdW5kZXJseWluZyBmaWxlLCB0aGVuIGRlbGV0ZWQgdGhlIGZpbGUuICBUaGlzIHVzdWFsbHkgd29ya2VkIGZpbmUuCiAgSG93ZXZlciwgdGhlIHNwYXduIGZhbWlseSBvZiBmdW5jdGlvbnMgb24gV2luZG93cyBjcmVhdGUgKGF0IGEgbG93IEMKICBsZXZlbCkgdGhlIHNhbWUgc2V0IG9mIG9wZW4gZmlsZXMgaW4gdGhlIHNwYXduZWQgcHJvY2VzcyBRIGFzIHdlcmUKICBvcGVuIGluIHRoZSBzcGF3bmluZyBwcm9jZXNzIFAuICBJZiBhIHRlbXAgZmlsZSBmIHdhcyBhbW9uZyB0aGVtLCB0aGVuCiAgZG9pbmcgZi5jbG9zZSgpIGluIFAgZmlyc3QgY2xvc2VkIFAncyBDLWxldmVsIGZpbGUgaGFuZGxlIG9uIGYsIGJ1dCBRJ3MKICBDLWxldmVsIGZpbGUgaGFuZGxlIG9uIGYgcmVtYWluZWQgb3Blbiwgc28gdGhlIGF0dGVtcHQgaW4gUCB0byBkZWxldGUgZgogIGJsZXcgdXAgd2l0aCBhICJQZXJtaXNzaW9uIGRlbmllZCIgZXJyb3IgKFdpbmRvd3MgZG9lc24ndCBhbGxvdwogIGRlbGV0aW5nIG9wZW4gZmlsZXMpLiAgVGhpcyB3YXMgc3VycHJpc2luZywgc3VidGxlLCBhbmQgZGlmZmljdWx0IHRvCiAgd29yayBhcm91bmQuCgotIFRoZSBvcyBtb2R1bGUgbm93IGV4cG9ydHMgYWxsIHRoZSBzeW1ib2xpYyBjb25zdGFudHMgdXNhYmxlIHdpdGggdGhlCiAgbG93LWxldmVsIG9zLm9wZW4oKSBvbiBXaW5kb3dzOiAgdGhlIG5ldyBjb25zdGFudHMgaW4gMi4zIGFyZQogIE9fTk9JTkhFUklULCBPX1NIT1JUX0xJVkVELCBPX1RFTVBPUkFSWSwgT19SQU5ET00gYW5kIE9fU0VRVUVOVElBTC4KICBUaGUgb3RoZXJzIHdlcmUgYWxzbyBhdmFpbGFibGUgaW4gMi4yOiAgT19BUFBFTkQsIE9fQklOQVJZLCBPX0NSRUFULAogIE9fRVhDTCwgT19SRE9OTFksIE9fUkRXUiwgT19URVhULCBPX1RSVU5DIGFuZCBPX1dST05MWS4gIENvbnRyYXJ5CiAgdG8gTWljcm9zb2Z0IGRvY3MsIE9fU0hPUlRfTElWRUQgZG9lcyBub3Qgc2VlbSB0byBpbXBseSBPX1RFTVBPUkFSWQogIChzbyBzcGVjaWZ5IGJvdGggaWYgeW91IHdhbnQgYm90aDsgbm90ZSB0aGF0IG5laXRoZXIgaXMgdXNlZnVsIHVubGVzcwogIHNwZWNpZmllZCB3aXRoIE9fQ1JFQVQgdG9vKS4KCk1hYwotLS0tCgotIE1hYy9SZWxub3RlcyBpcyBnb25lLCB0aGUgcmVsZWFzZSBub3RlcyBhcmUgbm93IGhlcmUuCgotIFRoZSBjdXJyZW50IG5hbWluZyBjb252ZW50aW9uIGZvciBQeXRob24gb24gdGhlIE1hY2ludG9zaCBpcyB0aGF0IE1hY1B5dGhvbgogIHJlZmVycyB0byB0aGUgdW5peC1iYXNlZCBPU1gtb25seSB2ZXJzaW9uLCBhbmQgTWFjUHl0aG9uLU9TOSByZWZlcnMgdG8gdGhlCiAgQ0ZNLWJhc2VkIHZlcnNpb24gdGhhdCBydW5zIG9uIGJvdGggT1M5IGFuZCBPU1guCgotIEFsbCBNYWNQeXRob24tT1M5IGZ1bmN0aW9uYWxpdHkgaXMgbm93IGF2YWlsYWJsZSBpbiBhbiBPU1ggdW5peCBidWlsZCwKICBpbmNsdWRpbmcgdGhlIENhcmJvbiBtb2R1bGVzLCB0aGUgSURFLCBPU0Egc3VwcG9ydCwgZXRjLiBBIGxvdCBvZiB0aGlzCiAgd2lsbCBvbmx5IHdvcmsgY29ycmVjdGx5IGluIGEgZnJhbWV3b3JrIGJ1aWxkLCB0aG91Z2gsIGJlY2F1c2UgeW91IGNhbm5vdAogIHRhbGsgdG8gdGhlIHdpbmRvdyBtYW5hZ2VyIHVubGVzcyB5b3VyIGFwcGxpY2F0aW9uIGlzIHJ1biBmcm9tIGEgLmFwcAogIGJ1bmRsZS4gVGhlcmUgaXMgYSBjb21tYW5kIGxpbmUgdG9vbCAicHl0aG9udyIgdGhhdCBydW5zIHlvdXIgc2NyaXB0CiAgd2l0aCBhbiBpbnRlcnByZXRlciBsaXZpbmcgaW4gc3VjaCBhIC5hcHAgYnVuZGxlLCB0aGlzIGludGVycHJldGVyIHNob3VsZAogIGJlIHVzZWQgdG8gcnVuIGFueSBQeXRob24gc2NyaXB0IHVzaW5nIHRoZSB3aW5kb3cgbWFuYWdlciAoaW5jbHVkaW5nCiAgVGtpbnRlciBvciB3eFB5dGhvbiBzY3JpcHRzKS4KCi0gTW9zdCBvZiBNYWMvTGliIGhhcyBtb3ZlZCB0byBMaWIvcGxhdC1tYWMsIHdoaWNoIGlzIGFnYWluIHVzZWQgYm90aCBpbgogIE1hY1B5dGhvbi1PU1ggYW5kIE1hY1B5dGhvbi1PUzkuIFRoZSBvbmx5IG1vZHVsZXMgcmVtYWluaW5nIGluIE1hYy9MaWIKICBhcmUgc3BlY2lmaWNhbGx5IGZvciBNYWNQeXRob24tT1M5IChDRk0gc3VwcG9ydCwgcHJlZmVyZW5jZSByZXNvdXJjZXMsIGV0YykuCgotIEEgbmV3IHV0aWxpdHkgUHl0aG9uTGF1bmNoZXIgd2lsbCBzdGFydCBhIFB5dGhvbiBpbnRlcnByZXRlciB3aGVuIGEgLnB5IG9yCiAgLnB5dyBzY3JpcHQgaXMgZG91YmxlLWNsaWNrZWQgaW4gdGhlIEZpbmRlci4gQnkgZGVmYXVsdCAucHkgc2NyaXB0cyBhcmUKICBydW4gd2l0aCBhIG5vcm1hbCBQeXRob24gaW50ZXJwcmV0ZXIgaW4gYSBUZXJtaW5hbCB3aW5kb3cgYW5kIC5weXcKICBmaWxlcyBhcmUgcnVuIHdpdGggYSB3aW5kb3ctYXdhcmUgcHl0aG9udyBpbnRlcnByZXRlciB3aXRob3V0IGEgVGVybWluYWwKICB3aW5kb3csIGJ1dCBhbGwgdGhpcyBjYW4gYmUgY3VzdG9taXplZC4KCi0gTWFjUHl0aG9uLU9TOSBpcyBub3cgQ2FyYm9uLW9ubHksIHNvIGl0IHJ1bnMgb24gTWFjIE9TIDkgb3IgTWFjIE9TIFggYW5kCiAgcG9zc2libHkgb24gTWFjIE9TIDguNiB3aXRoIHRoZSByaWdodCBDYXJib25MaWIgaW5zdGFsbGVkLCBidXQgbm90IG9uIGVhcmxpZXIKICByZWxlYXNlcy4KCi0gTWFueSB0b29scyBzdWNoIGFzIEJ1aWxkQXBwbGV0LnB5IGFuZCBnZW5zdWl0ZW1vZHVsZS5weSBub3cgc3VwcG9ydCBhIGNvbW1hbmQKICBsaW5lIGludGVyZmFjZSB0b28uCgotIEFsbCB0aGUgQ2FyYm9uIGNsYXNzZXMgYXJlIG5vdyBQRVAyNTMgY29tcGxpYW50LCBtZWFuaW5nIHRoYXQgeW91IGNhbgogIHN1YmNsYXNzIHRoZW0gZnJvbSBQeXRob24uIE1vc3Qgb2YgdGhlIGF0dHJpYnV0ZXMgaGF2ZSBnb25lLCB5b3Ugc2hvdWxkCiAgbm93IHVzZSB0aGUgYWNjZXNzb3IgZnVuY3Rpb24gY2FsbCBBUEksIHdoaWNoIGlzIGFsc28gd2hhdCBBcHBsZSdzCiAgZG9jdW1lbnRhdGlvbiB1c2VzLiBTb21lIGF0dHJpYnV0ZXMgc3VjaCBhcyBncmFmcG9ydC52aXNSZ24gYXJlIHN0aWxsCiAgYXZhaWxhYmxlIGZvciBjb252ZW5pZW5jZS4KCi0gTmV3IENhcmJvbiBtb2R1bGVzIEZpbGUgKGltcGxlbWVudGluZyB0aGUgQVBJcyBpbiBGaWxlcy5oIGFuZCBBbGlhc2VzLmgpCiAgYW5kIEZvbGRlciAoQVBJcyBmcm9tIEZvbGRlcnMuaCkuIFRoZSBvbGQgbWFjZnMgYnVpbHRpbiBtb2R1bGUgaXMKICBnb25lLCBhbmQgcmVwbGFjZWQgYnkgYSBQeXRob24gd3JhcHBlciBhcm91bmQgdGhlIG5ldyBtb2R1bGVzLgoKLSBQYXRobmFtZSBoYW5kbGluZyBzaG91bGQgbm93IGJlIGZ1bGx5IGNvbnNpc3RlbnQ6IE1hY1B5dGhvbi1PU1ggYWx3YXlzIHVzZXMKICB1bml4IHBhdGhuYW1lcyBhbmQgTWFjUHl0aG9uLU9TOSBhbHdheXMgdXNlcyBjb2xvbi1zZXBhcmF0ZWQgTWFjIHBhdGhuYW1lcwogIChhbHNvIHdoZW4gcnVubmluZyBvbiBNYWMgT1MgWCkuCgotIE5ldyBDYXJib24gbW9kdWxlcyBIZWxwIGFuZCBBSCBnaXZlIGFjY2VzcyB0byB0aGUgQ2FyYm9uIEhlbHAgTWFuYWdlci4KICBUaGVyZSBhcmUgaG9va3MgaW4gdGhlIElERSB0byBhbGxvdyBhY2Nlc3NpbmcgdGhlIFB5dGhvbiBkb2N1bWVudGF0aW9uCiAgKGFuZCBBcHBsZSdzIENhcmJvbiBhbmQgQ29jb2EgZG9jdW1lbnRhdGlvbikgdGhyb3VnaCB0aGUgSGVscCBWaWV3ZXIuCiAgU2VlIE1hYy9PU1gvUkVBRE1FIGZvciBjb252ZXJ0aW5nIHRoZSBQeXRob24gZG9jdW1lbnRhdGlvbiB0byBhCiAgSGVscCBWaWV3ZXIgY29tYXB0aWJsZSBmb3JtIGFuZCBpbnN0YWxsaW5nIGl0LgoKLSBPU0Egc3VwcG9ydCBoYXMgYmVlbiByZWRlc2lnbmVkIGFuZCB0aGUgZ2VuZXJhdGVkIFB5dGhvbiBjbGFzc2VzIG5vdwogIG1pcnJvciB0aGUgaW5oZXJpdGFuY2UgZGVmaW5lZCBieSB0aGUgdW5kZXJseWluZyBPU0EgY2xhc3Nlcy4KCi0gTWFjUHl0aG9uIG5vIGxvbmdlciBtYXBzIGJvdGggXHIgYW5kIFxuIHRvIFxuIG9uIGlucHV0IGZvciBhbnkgdGV4dCBmaWxlLgogIFRoaXMgZmVhdHVyZSBoYXMgYmVlbiByZXBsYWNlZCBieSB1bml2ZXJzYWwgbmV3bGluZSBzdXBwb3J0IChQRVAyNzgpLgoKLSBUaGUgZGVmYXVsdCBlbmNvZGluZyBmb3IgUHl0aG9uIHNvdXJjZWZpbGVzIGluIE1hY1B5dGhvbi1PUzkgaXMgbm8gbG9uZ2VyCiAgbWFjLXJvbWFuIChvciB3aGF0ZXZlciB5b3VyIGxvY2FsIE1hYyBlbmNvZGluZyB3YXMgYnV0ICJhc2NpaSIsIGxpa2Ugb24KICBvdGhlciBwbGF0Zm9ybXMuIElmIHlvdSByZWFsbHkgbmVlZCBzb3VyY2VmaWxlcyB3aXRoIE1hYyBjaGFyYWN0ZXJzIGluIHRoZW0KICB5b3UgY2FuIGNoYW5nZSB0aGlzIGluIHNpdGUucHkuCgpXaGF0J3MgTmV3IGluIFB5dGhvbiAyLjIgZmluYWw/Cj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCipSZWxlYXNlIGRhdGU6IDIxLURlYy0yMDAxKgoKVHlwZS9jbGFzcyB1bmlmaWNhdGlvbiBhbmQgbmV3LXN0eWxlIGNsYXNzZXMKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCi0gcGlja2xlLnB5LCBjUGlja2xlOiBhbGxvdyBwaWNrbGluZyBpbnN0YW5jZXMgb2YgbmV3LXN0eWxlIGNsYXNzZXMKICB3aXRoIGEgY3VzdG9tIG1ldGFjbGFzcy4KCkNvcmUgYW5kIGJ1aWx0aW5zCi0tLS0tLS0tLS0tLS0tLS0tCgotIHdlYWtyZWYgcHJveHkgb2JqZWN0OiB3aGVuIGNvbXBhcmluZywgdW53cmFwIGJvdGggYXJndW1lbnRzIGlmIGJvdGgKICBhcmUgcHJveGllcy4KCkV4dGVuc2lvbiBtb2R1bGVzCi0tLS0tLS0tLS0tLS0tLS0tCgotIGJpbmFzY2lpLmIyYV9iYXNlNjQoKTogZml4IGEgcG90ZW50aWFsIGJ1ZmZlciBvdmVycnVuIHdoZW4gZW5jb2RpbmcKICB2ZXJ5IHNob3J0IHN0cmluZ3MuCgotIGNQaWNrbGU6IHRoZSBvYnNjdXJlICJmYXN0IiBtb2RlIHdhcyBzdXNwZWN0ZWQgb2YgY2F1c2luZyBzdGFjawogIG92ZXJmbG93cyBvbiB0aGUgTWFjLiAgSG9wZWZ1bGx5IGZpeGVkIHRoaXMgYnkgc2V0dGluZyB0aGUgcmVjdXJzaW9uCiAgbGltaXQgbXVjaCBzbWFsbGVyLiAgSWYgdGhlIGxpbWl0IGlzIHRvbyBsb3cgKGl0IG9ubHkgYWZmZWN0cwogIHBlcmZvcm1hbmNlKSwgeW91IGNhbiBjaGFuZ2UgaXQgYnkgZGVmaW5pbmcgUFlfQ1BJQ0tMRV9GQVNUX0xJTUlUCiAgd2hlbiBjb21waWxpbmcgY1BpY2tsZS5jIChvciBpbiBweWNvbmZpZy5oKS4KCkxpYnJhcnkKLS0tLS0tLQoKLSBkdW1iZGJtLnB5OiBmaXhlZCBhIGR1bWIgb2xkIGJ1ZyAodGhlIGZpbGUgZGlkbid0IGdldCBzeW5jaGVkIGF0CiAgY2xvc2Ugb3IgZGVsZXRlIHRpbWUpLgoKLSByZmM4MjIucHk6IGZpeGVkIGEgYnVnIHdoZXJlIHRoZSBhZGRyZXNzICc8Picgd2FzIGNvbnZlcnRlZCB0byBOb25lCiAgaW5zdGVhZCBvZiBhbiBlbXB0eSBzdHJpbmcgKGFsc28gZml4ZXMgdGhlIGVtYWlsLlV0aWxzIG1vZHVsZSkuCgotIHhtbHJwY2xpYi5weTogdmVyc2lvbiAxLjAuMDsgdXNlcyBwcmVjaXNpb24gZm9yIGRvdWJsZXMuCgotIHRlc3Qgc3VpdGU6IHRoZSBwaWNrbGUgYW5kIGNQaWNrbGUgdGVzdHMgd2VyZSBub3QgZXhlY3V0aW5nIGFueSBjb2RlCiAgd2hlbiBydW4gZnJvbSB0aGUgc3RhbmRhcmQgcmVncmVzc2lvbiB0ZXN0LgoKVG9vbHMvRGVtb3MKLS0tLS0tLS0tLS0KCkJ1aWxkCi0tLS0tCgpDIEFQSQotLS0tLQoKTmV3IHBsYXRmb3JtcwotLS0tLS0tLS0tLS0tCgpUZXN0cwotLS0tLQoKV2luZG93cwotLS0tLS0tCgotIGRpc3R1dGlscyBwYWNrYWdlOiBmaXhlZCBicm9rZW4gV2luZG93cyBpbnN0YWxsZXJzIChiZGlzdF93aW5pbnN0KS4KCi0gdGVtcGZpbGUucHk6IHByZXZlbnQgbXlzdGVyaW91cyB3YXJuaW5ncyB3aGVuIFRlbXBvcmFyeUZpbGVXcmFwcGVyCiAgaW5zdGFuY2VzIGFyZSBkZWxldGVkIGF0IHByb2Nlc3MgZXhpdCB0aW1lLgoKLSBzb2NrZXQucHk6IHByZXZlbnQgbXlzdGVyaW91cyB3YXJuaW5ncyB3aGVuIHNvY2tldCBpbnN0YW5jZXMgYXJlCiAgZGVsZXRlZCBhdCBwcm9jZXNzIGV4aXQgdGltZS4KCi0gcG9zaXhtb2R1bGUuYzogZml4IGEgV2luZG93cyBjcmFzaCB3aXRoIHN0YXQoKSBvZiBhIGZpbGVuYW1lIGVuZGluZwogIGluIGJhY2tzbGFzaC4KCk1hYwotLS0tCgotIFRoZSBDYXJib24gdG9vbGJveCBtb2R1bGVzIGhhdmUgYmVlbiB1cGdyYWRlZCB0byBVbml2ZXJzYWwgSGVhZGVycwogIDMuNCwgYW5kIGV4cGVyaW1lbnRhbCBDb3JlR3JhcGhpY3MgYW5kIENhcmJvbkV2ZW50cyBtb2R1bGVzIGhhdmUKICBiZWVuIGFkZGVkLiAgQWxsIG9ubHkgZm9yIGZyYW1ld29yay1lbmFibGVkIE1hY09TWC4KCgpXaGF0J3MgTmV3IGluIFB5dGhvbiAyLjJjMT8KPT09PT09PT09PT09PT09PT09PT09PT09PT09CgoqUmVsZWFzZSBkYXRlOiAxNC1EZWMtMjAwMSoKClR5cGUvY2xhc3MgdW5pZmljYXRpb24gYW5kIG5ldy1zdHlsZSBjbGFzc2VzCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgotIEd1aWRvJ3MgdHV0b3JpYWwgaW50cm9kdWN0aW9uIHRvIHRoZSBuZXcgdHlwZS9jbGFzcyBmZWF0dXJlcyBoYXMKICBiZWVuIGV4dGVuc2l2ZWx5IHVwZGF0ZWQuICBTZWUKCiAgICAgIGh0dHA6Ly93d3cucHl0aG9uLm9yZy8yLjIvZGVzY3JpbnRyby5odG1sCgogIFRoYXQgcmVtYWlucyB0aGUgcHJpbWFyeSBkb2N1bWVudGF0aW9uIGluIHRoaXMgYXJlYS4KCi0gRml4ZWQgYSBsZWFrOiBpbnN0YW5jZSB2YXJpYWJsZXMgZGVjbGFyZWQgd2l0aCBfX3Nsb3RzX18gd2VyZSBuZXZlcgogIGRlbGV0ZWQhCgotIFRoZSAiZGVsZXRlIGF0dHJpYnV0ZSIgbWV0aG9kIG9mIGRlc2NyaXB0b3Igb2JqZWN0cyBpcyBjYWxsZWQKICBfX2RlbGV0ZV9fLCBub3QgX19kZWxfXy4gIEluIHByZXZpb3VzIHJlbGVhc2VzLCBpdCB3YXMgbWlzdGFrZW5seQogIGNhbGxlZCBfX2RlbF9fLCB3aGljaCBjcmVhdGVkIGFuIHVuZm9ydHVuYXRlIG92ZXJsb2FkaW5nIGNvbmRpdGlvbgogIHdpdGggZmluYWxpemVycy4gIChUaGUgImdldCBhdHRyaWJ1dGUiIGFuZCAic2V0IGF0dHJpYnV0ZSIgbWV0aG9kcwogIGFyZSBzdGlsbCBjYWxsZWQgX19nZXRfXyBhbmQgX19zZXRfXywgcmVzcGVjdGl2ZWx5LikKCi0gU29tZSBzdWJ0bGUgaXNzdWVzIHdpdGggdGhlIHN1cGVyIGJ1aWx0LWluIHdlcmUgZml4ZWQ6CgogIChhKSBXaGVuIHN1cGVyIGl0c2VsZiBpcyBzdWJjbGFzc2VkLCBpdHMgX19nZXRfXyBtZXRob2Qgd291bGQgc3RpbGwKICAgICAgcmV0dXJuIGFuIGluc3RhbmNlIG9mIHRoZSBiYXNlIGNsYXNzIChpLmUuLCBvZiBzdXBlcikuCgogIChiKSBzdXBlcihDLCBDKCkpLl9fY2xhc3NfXyB3b3VsZCByZXR1cm4gQyByYXRoZXIgdGhhbiBzdXBlci4gIFRoaXMKICAgICAgaXMgY29uZnVzaW5nLiAgVG8gZml4IHRoaXMsIEkgZGVjaWRlZCB0byBjaGFuZ2UgdGhlIHNlbWFudGljcyBvZgogICAgICBzdXBlciBzbyB0aGF0IGl0IG9ubHkgYXBwbGllcyB0byBjb2RlIGF0dHJpYnV0ZXMsIG5vdCB0byBkYXRhCiAgICAgIGF0dHJpYnV0ZXMuICBBZnRlciBhbGwsIG92ZXJyaWRpbmcgZGF0YSBhdHRyaWJ1dGVzIGlzIG5vdAogICAgICBzdXBwb3J0ZWQgYW55d2F5LgoKICAoYykgVGhlIF9fZ2V0X18gbWV0aG9kIGRpZG4ndCBjaGVjayB3aGV0aGVyIHRoZSBhcmd1bWVudCB3YXMgYW4KICAgICAgaW5zdGFuY2Ugb2YgdGhlIHR5cGUgdXNlZCBpbiBjcmVhdGlvbiBvZiB0aGUgc3VwZXIgaW5zdGFuY2UuCgotIFByZXZpb3VzbHksIGhhc2goKSBvZiBhbiBpbnN0YW5jZSBvZiBhIHN1YmNsYXNzIG9mIGEgbXV0YWJsZSB0eXBlCiAgKGxpc3Qgb3IgZGljdGlvbmFyeSkgd291bGQgcmV0dXJuIHNvbWUgdmFsdWUsIHJhdGhlciB0aGFuIHJhaXNpbmcKICBUeXBlRXJyb3IuICBUaGlzIGhhcyBiZWVuIGZpeGVkLiAgQWxzbywgZGlyZWN0bHkgY2FsbGluZwogIGRpY3QuX19oYXNoX18gYW5kIGxpc3QuX19oYXNoX18gbm93IHJhaXNlcyB0aGUgc2FtZSBUeXBlRXJyb3IKICAocHJldmlvdXNseSwgdGhlc2Ugd2VyZSB0aGUgc2FtZSBhcyBvYmplY3QuX19oYXNoX18pLgoKLSBOZXctc3R5bGUgb2JqZWN0cyBub3cgc3VwcG9ydCBkZWxldGluZyB0aGVpciBfX2RpY3RfXy4gIFRoaXMgaXMgZm9yCiAgYWxsIGludGVudHMgYW5kIHB1cnBvc2VzIGVxdWl2YWxlbnQgdG8gYXNzaWduaW5nIGEgYnJhbmQgbmV3IGVtcHR5CiAgZGljdGlvbmFyeSwgYnV0IHNhdmVzIHNwYWNlIGlmIHRoZSBvYmplY3QgaXMgbm90IHVzZWQgZnVydGhlci4KCkNvcmUgYW5kIGJ1aWx0aW5zCi0tLS0tLS0tLS0tLS0tLS0tCgotIC1RbmV3IG5vdyB3b3JrcyBhcyBkb2N1bWVudGVkIGluIFBFUCAyMzg6ICB3aGVuIC1RbmV3IGlzIHBhc3NlZCBvbgogIHRoZSBjb21tYW5kIGxpbmUsIGFsbCBvY2N1cnJlbmNlcyBvZiAiLyIgdXNlIHRydWUgZGl2aXNpb24gaW5zdGVhZAogIG9mIGNsYXNzaWMgZGl2aXNpb24uICBTZWUgdGhlIFBFUCBmb3IgZGV0YWlscy4gIE5vdGUgdGhhdCAiYWxsIgogIG1lYW5zIGFsbCBpbnN0YW5jZXMgaW4gbGlicmFyeSBhbmQgM3JkLXBhcnR5IG1vZHVsZXMsIGFzIHdlbGwgYXMgaW4KICB5b3VyIG93biBjb2RlLiAgQXMgdGhlIFBFUCBzYXlzLCAtUW5ldyBpcyBpbnRlbmRlZCBmb3IgdXNlIG9ubHkgaW4KICBlZHVjYXRpb25hbCBlbnZpcm9ubWVudHMgd2l0aCBjb250cm9sIG92ZXIgdGhlIGxpYnJhcmllcyBpbiB1c2UuCiAgTm90ZSB0aGF0IHRlc3RfY29lcmNpb24ucHkgaW4gdGhlIHN0YW5kYXJkIFB5dGhvbiB0ZXN0IHN1aXRlIGZhaWxzCiAgdW5kZXIgLVFuZXc7IHRoaXMgaXMgZXhwZWN0ZWQsIGFuZCB3b24ndCBiZSByZXBhaXJlZCB1bnRpbCB0cnVlCiAgZGl2aXNpb24gYmVjb21lcyB0aGUgZGVmYXVsdCAoaW4gdGhlIG1lYW50aW1lLCB0ZXN0X2NvZXJjaW9uIGlzCiAgdGVzdGluZyB0aGUgY3VycmVudCBydWxlcykuCgotIGNvbXBsZXgoKSBub3cgb25seSBhbGxvd3MgdGhlIGZpcnN0IGFyZ3VtZW50IHRvIGJlIGEgc3RyaW5nCiAgYXJndW1lbnQsIGFuZCByYWlzZXMgVHlwZUVycm9yIGlmIGVpdGhlciB0aGUgc2Vjb25kIGFyZyBpcyBhIHN0cmluZwogIG9yIGlmIHRoZSBzZWNvbmQgYXJnIGlzIHNwZWNpZmllZCB3aGVuIHRoZSBmaXJzdCBpcyBhIHN0cmluZy4KCkV4dGVuc2lvbiBtb2R1bGVzCi0tLS0tLS0tLS0tLS0tLS0tCgotIGdjLmdldF9yZWZlcmVudHMgd2FzIHJlbmFtZWQgdG8gZ2MuZ2V0X3JlZmVycmVycy4KCkxpYnJhcnkKLS0tLS0tLQoKLSBGdW5jdGlvbnMgaW4gdGhlIG9zLnNwYXduKCkgZmFtaWx5IG5vdyByZWxlYXNlIHRoZSBnbG9iYWwgaW50ZXJwcmV0ZXIKICBsb2NrIGFyb3VuZCBjYWxsaW5nIHRoZSBwbGF0Zm9ybSBzcGF3bi4gIFRoZXkgc2hvdWxkIGFsd2F5cyBoYXZlIGRvbmUKICB0aGlzLCBidXQgZGlkIG5vdCBiZWZvcmUgMi4yYzEuICBNdWx0aXRocmVhZGVkIHByb2dyYW1zIGNhbGxpbmcKICBhbiBvcy5zcGF3biBmdW5jdGlvbiB3aXRoIFBfV0FJVCB3aWxsIG5vIGxvbmdlciBibG9jayBhbGwgUHl0aG9uIHRocmVhZHMKICB1bnRpbCB0aGUgc3Bhd25lZCBwcm9ncmFtIGNvbXBsZXRlcy4gIEl0J3MgcG9zc2libGUgdGhhdCBzb21lIHByb2dyYW1zCiAgcmVsaWVzIG9uIGJsb2NraW5nLCBhbHRob3VnaCBtb3JlIGxpa2VseSBieSBhY2NpZGVudCB0aGFuIGJ5IGRlc2lnbi4KCi0gd2ViYnJvd3NlciBkZWZhdWx0cyB0byBuZXRzY2FwZS5leGUgb24gT1MvMiBub3cuCgotIFRpeC5SZXNpemVIYW5kbGUgZXhwb3NlcyBkZXRhY2hfd2lkZ2V0LCBoaWRlLCBhbmQgc2hvdy4KCi0gVGhlIGNoYXJzZXQgYWxpYXMgd2luZG93c18xMjUyIGhhcyBiZWVuIGFkZGVkLgoKLSB0eXBlcy5TdHJpbmdUeXBlcyBpcyBhIHR1cGxlIGNvbnRhaW5pbmcgdGhlIGRlZmluZWQgc3RyaW5nIHR5cGVzOwogIHVzdWFsbHkgdGhpcyB3aWxsIGJlIChzdHIsIHVuaWNvZGUpLCBidXQgaWYgUHl0aG9uIHdhcyBjb21waWxlZAogIHdpdGhvdXQgVW5pY29kZSBzdXBwb3J0IGl0IHdpbGwgYmUganVzdCAoc3RyLCkuCgotIFRoZSBwdWxsZG9tIGFuZCBtaW5pZG9tIG1vZHVsZXMgd2VyZSBzeW5jaHJvbml6ZWQgdG8gUHlYTUwuCgpUb29scy9EZW1vcwotLS0tLS0tLS0tLQoKLSBBIG5ldyBzY3JpcHQgY2FsbGVkIFRvb2xzL3NjcmlwdHMvZ29vZ2xlLnB5IHdhcyBhZGRlZCwgd2hpY2ggZmlyZXMKICBvZmYgYSBzZWFyY2ggb24gR29vZ2xlLgoKQnVpbGQKLS0tLS0KCi0gTm90ZSB0aGF0IHJlbGVhc2UgYnVpbGRzIG9mIFB5dGhvbiBzaG91bGQgYXJyYW5nZSB0byBkZWZpbmUgdGhlCiAgcHJlcHJvY2Vzc29yIHN5bWJvbCBOREVCVUcgb24gdGhlIGNvbW1hbmQgbGluZSAob3IgZXF1aXZhbGVudCkuCiAgSW4gdGhlIDIuMiBwcmUtcmVsZWFzZSBzZXJpZXMgd2UgdHJpZWQgdG8gZGVmaW5lIHRoaXMgYnkgbWFnaWMgaW4KICBQeXRob24uaCBpbnN0ZWFkLCBidXQgaXQgcHJvdmVkIHRvIGNhdXNlIHByb2JsZW1zIGZvciBleHRlbnNpb24KICBhdXRob3JzLiAgVGhlIFVuaXgsIFdpbmRvd3MgYW5kIE1hYyBidWlsZHMgbm93IGFsbCBkZWZpbmUgTkRFQlVHIGluCiAgcmVsZWFzZSBidWlsZHMgdmlhIGNtZGxpbmUgKG9yIGVxdWl2YWxlbnQpIGluc3RlYWQuICBQb3J0cyB0bwogIG90aGVyIHBsYXRmb3JtcyBzaG91bGQgZG8gbGlrZXdpc2UuCgotIEl0IGlzIG5vIGxvbmdlciBuZWNlc3NhcnkgdG8gdXNlIC0td2l0aC1zdWZmaXggd2hlbiBidWlsZGluZyBvbiBhCiAgY2FzZS1pbnNlbnNpdGl2ZSBmaWxlIHN5c3RlbSAoc3VjaCBhcyBNYWMgT1MgWCBIRlMrKS4gSW4gdGhlIGJ1aWxkCiAgZGlyZWN0b3J5IGFuIGV4dGVuc2lvbiBpcyB1c2VkLCBidXQgbm90IGluIHRoZSBpbnN0YWxsZWQgcHl0aG9uLgoKQyBBUEkKLS0tLS0KCi0gTmV3IGZ1bmN0aW9uIFB5RGljdF9NZXJnZUZyb21TZXEyKCkgZXhwb3NlcyB0aGUgYnVpbHRpbiBkaWN0CiAgY29uc3RydWN0b3IncyBsb2dpYyBmb3IgdXBkYXRpbmcgYSBkaWN0aW9uYXJ5IGZyb20gYW4gaXRlcmFibGUgb2JqZWN0CiAgcHJvZHVjaW5nIGtleS12YWx1ZSBwYWlycy4KCi0gUHlBcmdfUGFyc2VUdXBsZUFuZEtleXdvcmRzKCkgcmVxdWlyZXMgdGhhdCB0aGUgbnVtYmVyIG9mIGVudHJpZXMgaW4KICB0aGUga2V5d29yZCBsaXN0IGVxdWFsIHRoZSBudW1iZXIgb2YgYXJndW1lbnQgc3BlY2lmaWVycy4gIFRoaXMKICB3YXNuJ3QgY2hlY2tlZCBjb3JyZWN0bHksIGFuZCBQeUFyZ19QYXJzZVR1cGxlQW5kS2V5d29yZHMgY291bGQgZXZlbgogIGR1bXAgY29yZSBpbiBzb21lIGJhZCBjYXNlcy4gIFRoaXMgaGFzIGJlZW4gcmVwYWlyZWQuICBBcyBhIHJlc3VsdCwKICBQeUFyZ19QYXJzZVR1cGxlQW5kS2V5d29yZHMgbWF5IHJhaXNlIFJ1bnRpbWVFcnJvciBpbiBiYWQgY2FzZXMgdGhhdAogIHByZXZpb3VzbHkgd2VudCB1bmNoYWxsZW5nZWQuCgpOZXcgcGxhdGZvcm1zCi0tLS0tLS0tLS0tLS0KClRlc3RzCi0tLS0tCgpXaW5kb3dzCi0tLS0tLS0KCk1hYwotLS0tCgotIEluIHVuaXgtUHl0aG9uIG9uIE1hYyBPUyBYIChhbmQgZGFyd2luKSBzeXMucGxhdGZvcm0gaXMgbm93ICJkYXJ3aW4iLAogIHdpdGhvdXQgYW55IHRyYWlsaW5nIGRpZ2l0cy4KCi0gQ2hhbmdlZCBsb2dpYyBmb3IgZmluZGluZyBweXRob24gaG9tZSBpbiBNYWMgT1MgWCBmcmFtZXdvcmsgUHl0aG9ucy4KICBOb3cgc3lzLmV4ZWN1dGFibGUgcG9pbnRzIHRvIHRoZSBleGVjdXRhYmxlIGFnYWluLCBpbiBzdGVhZCBvZiB0bwogIHRoZSBzaGFyZWQgbGlicmFyeS4gVGhlIGxhdHRlciBpcyB1c2VkIG9ubHkgZm9yIGxvY2F0aW5nIHRoZSBweXRob24KICBob21lLgoKCldoYXQncyBOZXcgaW4gUHl0aG9uIDIuMmIyPwo9PT09PT09PT09PT09PT09PT09PT09PT09PT0KCipSZWxlYXNlIGRhdGU6IDE2LU5vdi0yMDAxKgoKVHlwZS9jbGFzcyB1bmlmaWNhdGlvbiBhbmQgbmV3LXN0eWxlIGNsYXNzZXMKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCi0gTXVsdGlwbGUgaW5oZXJpdGFuY2UgbWl4aW5nIG5ldy1zdHlsZSBhbmQgY2xhc3NpYyBjbGFzc2VzIGluIHRoZQogIGxpc3Qgb2YgYmFzZSBjbGFzc2VzIGlzIG5vdyBhbGxvd2VkLCBzbyB0aGlzIHdvcmtzIG5vdzoKCiAgICAgIGNsYXNzIENsYXNzaWM6IHBhc3MKICAgICAgY2xhc3MgTWl4ZWQoQ2xhc3NpYywgb2JqZWN0KTogcGFzcwoKICBUaGUgTVJPIChtZXRob2QgcmVzb2x1dGlvbiBvcmRlcikgZm9yIGVhY2ggYmFzZSBjbGFzcyBpcyByZXNwZWN0ZWQKICBhY2NvcmRpbmcgdG8gaXRzIGtpbmQsIGJ1dCB0aGUgTVJPIGZvciB0aGUgZGVyaXZlZCBjbGFzcyBpcyBjb21wdXRlZAogIHVzaW5nIG5ldy1zdHlsZSBNUk8gcnVsZXMgaWYgYW55IGJhc2UgY2xhc3MgaXMgYSBuZXctc3R5bGUgY2xhc3MuCiAgVGhpcyBuZWVkcyB0byBiZSBkb2N1bWVudGVkLgoKLSBUaGUgbmV3IGJ1aWx0aW4gZGljdGlvbmFyeSgpIGNvbnN0cnVjdG9yLCBhbmQgZGljdGlvbmFyeSB0eXBlLCBoYXZlCiAgYmVlbiByZW5hbWVkIHRvIGRpY3QuICBUaGlzIHJlZmxlY3RzIGEgZGVjYWRlIG9mIGNvbW1vbiB1c2FnZS4KCi0gZGljdCgpIG5vdyBhY2NlcHRzIGFuIGl0ZXJhYmxlIG9iamVjdCBwcm9kdWNpbmcgMi1zZXF1ZW5jZXMuICBGb3IKICBleGFtcGxlLCBkaWN0KGQuaXRlbXMoKSkgPT0gZCBmb3IgYW55IGRpY3Rpb25hcnkgZC4gIFRoZSBhcmd1bWVudCwKICBhbmQgdGhlIGVsZW1lbnRzIG9mIHRoZSBhcmd1bWVudCwgY2FuIGJlIGFueSBpdGVyYWJsZSBvYmplY3RzLgoKLSBOZXctc3R5bGUgY2xhc3NlcyBjYW4gbm93IGhhdmUgYSBfX2RlbF9fIG1ldGhvZCwgd2hpY2ggaXMgY2FsbGVkCiAgd2hlbiB0aGUgaW5zdGFuY2UgaXMgZGVsZXRlZCAoanVzdCBsaWtlIGZvciBjbGFzc2ljIGNsYXNzZXMpLgoKLSBBc3NpZ25tZW50IHRvIG9iamVjdC5fX2RpY3RfXyBpcyBub3cgcG9zc2libGUsIGZvciBvYmplY3RzIHRoYXQgYXJlCiAgaW5zdGFuY2VzIG9mIG5ldy1zdHlsZSBjbGFzc2VzIHRoYXQgaGF2ZSBhIF9fZGljdF9fICh1bmxlc3MgdGhlIGJhc2UKICBjbGFzcyBmb3JiaWRzIGl0KS4KCi0gTWV0aG9kcyBvZiBidWlsdC1pbiB0eXBlcyBub3cgcHJvcGVybHkgY2hlY2sgZm9yIGtleXdvcmQgYXJndW1lbnRzCiAgKGZvcm1lcmx5IHRoZXNlIHdlcmUgc2lsZW50bHkgaWdub3JlZCkuICBUaGUgb25seSBidWlsdC1pbiBtZXRob2RzCiAgdGhhdCB0YWtlIGtleXdvcmQgYXJndW1lbnRzIGFyZSBfX2NhbGxfXywgX19pbml0X18gYW5kIF9fbmV3X18uCgotIFRoZSBzb2NrZXQgZnVuY3Rpb24gaGFzIGJlZW4gY29udmVydGVkIHRvIGEgdHlwZTsgc2VlIGJlbG93LgoKQ29yZSBhbmQgYnVpbHRpbnMKLS0tLS0tLS0tLS0tLS0tLS0KCi0gQXNzaWdubWVudCB0byBfX2RlYnVnX18gcmFpc2VzIFN5bnRheEVycm9yIGF0IGNvbXBpbGUtdGltZS4gIFRoaXMKICB3YXMgcHJvbWlzZWQgd2hlbiAyLjFjMSB3YXMgcmVsZWFzZWQgYXMgIldoYXQncyBOZXcgaW4gUHl0aG9uIDIuMWMxIgogIChzZWUgYmVsb3cpIHNheXMuCgotIENsYXJpZmllZCB0aGUgZXJyb3IgbWVzc2FnZXMgZm9yIHVuc3VwcG9ydGVkIG9wZXJhbmRzIHRvIGFuIG9wZXJhdG9yCiAgKGxpa2UgMSArICcnKS4KCkV4dGVuc2lvbiBtb2R1bGVzCi0tLS0tLS0tLS0tLS0tLS0tCgotIG1tYXAgaGFzIGEgbmV3IGtleXdvcmQgYXJndW1lbnQsICJhY2Nlc3MiLCBhbGxvd2luZyBhIHVuaWZvcm0gd2F5IGZvcgogIGJvdGggV2luZG93cyBhbmQgVW5peCB1c2VycyB0byBjcmVhdGUgcmVhZC1vbmx5LCB3cml0ZS10aHJvdWdoIGFuZAogIGNvcHktb24td3JpdGUgbWVtb3J5IG1hcHBpbmdzLiAgVGhpcyB3YXMgcHJldmlvdXNseSBwb3NzaWJsZSBvbmx5IG9uCiAgVW5peC4gIEEgbmV3IGtleXdvcmQgYXJndW1lbnQgd2FzIHJlcXVpcmVkIHRvIHN1cHBvcnQgdGhpcyBpbiBhCiAgdW5pZm9ybSB3YXkgYmVjYXVzZSB0aGUgbW1hcCgpIHNpZ25hdHVyZXMgaGFkIGRpdmVyZ2VkIGFjcm9zcwogIHBsYXRmb3Jtcy4gIFRoYW5rcyB0byBKYXkgVCBNaWxsZXIgZm9yIHJlcGFpcmluZyB0aGlzIQoKLSBCeSBkZWZhdWx0LCB0aGUgZ2MuZ2FyYmFnZSBsaXN0IG5vdyBjb250YWlucyBvbmx5IHRob3NlIGluc3RhbmNlcyBpbgogIHVucmVhY2hhYmxlIGN5Y2xlcyB0aGF0IGhhdmUgX19kZWxfXyBtZXRob2RzOyBpbiAyLjEgaXQgY29udGFpbmVkIGFsbAogIGluc3RhbmNlcyBpbiB1bnJlYWNoYWJsZSBjeWNsZXMuICAiSW5zdGFuY2VzIiBoZXJlIGhhcyBiZWVuIGdlbmVyYWxpemVkCiAgdG8gaW5jbHVkZSBpbnN0YW5jZXMgb2YgYm90aCBuZXctc3R5bGUgYW5kIG9sZC1zdHlsZSBjbGFzc2VzLgoKLSBUaGUgc29ja2V0IG1vZHVsZSBkZWZpbmVzIGEgbmV3IG1ldGhvZCBmb3Igc29ja2V0IG9iamVjdHMsCiAgc2VuZGFsbCgpLiAgVGhpcyBpcyBsaWtlIHNlbmQoKSBidXQgbWF5IG1ha2UgbXVsdGlwbGUgY2FsbHMgdG8KICBzZW5kKCkgdW50aWwgYWxsIGRhdGEgaGFzIGJlZW4gc2VudC4gIEFsc28sIHRoZSBzb2NrZXQgZnVuY3Rpb24gaGFzCiAgYmVlbiBjb252ZXJ0ZWQgdG8gYSBzdWJjbGFzc2FibGUgdHlwZSwgbGlrZSBsaXN0IGFuZCB0dXBsZSAoZXRjLikKICBiZWZvcmUgaXQ7IHNvY2tldCBhbmQgU29ja2V0VHlwZSBhcmUgbm93IHRoZSBzYW1lIHRoaW5nLgoKLSBWYXJpb3VzIGJ1Z2ZpeGVzIHRvIHRoZSBjdXJzZXMgbW9kdWxlLiAgVGhlcmUgaXMgbm93IGEgdGVzdCBzdWl0ZQogIGZvciB0aGUgY3Vyc2VzIG1vZHVsZSAoeW91IGhhdmUgdG8gcnVuIGl0IG1hbnVhbGx5KS4KCi0gYmluYXNjaWkuYjJhX2Jhc2U2NCBubyBsb25nZXIgcGxhY2VzIGFuIGFyYml0cmFyeSByZXN0cmljdGlvbiBvZiA1NwogIGJ5dGVzIG9uIGl0cyBpbnB1dC4KCkxpYnJhcnkKLS0tLS0tLQoKLSB0a0ZpbGVEaWFsb2cgZXhwb3NlcyBhIERpcmVjdG9yeSBjbGFzcyBhbmQgYXNrZGlyZWN0b3J5CiAgY29udmVuaWVuY2UgZnVuY3Rpb24uCgotIFN5bWJvbGljIGdyb3VwIG5hbWVzIGluIHJlZ3VsYXIgZXhwcmVzc2lvbnMgbXVzdCBiZSB1bmlxdWUuICBGb3IKICBleGFtcGxlLCB0aGUgcmVnZXhwIHInKD9QPGFiYz4pKD9QPGFiYz4pJyBpcyBub3QgYWxsb3dlZCwgYmVjYXVzZSBhCiAgc2luZ2xlIG5hbWUgY2FuJ3QgbWVhbiBib3RoICJncm91cCAxIiBhbmQgImdyb3VwIDIiIHNpbXVsdGFuZW91c2x5LgogIFB5dGhvbiAyLjIgZGV0ZWN0cyB0aGlzIGVycm9yIGF0IHJlZ2V4cCBjb21waWxhdGlvbiB0aW1lOwogIHByZXZpb3VzbHksIHRoZSBlcnJvciB3ZW50IHVuZGV0ZWN0ZWQsIGFuZCByZXN1bHRzIHdlcmUKICB1bnByZWRpY3RhYmxlLiAgQWxzbyBpbiBzcmUsIHRoZSBwYXR0ZXJuLnNwbGl0KCksIHBhdHRlcm4uc3ViKCksIGFuZAogIHBhdHRlcm4uc3VibigpIG1ldGhvZHMgaGF2ZSBiZWVuIHJld3JpdHRlbiBpbiBDLiAgQWxzbywgYW4KICBleHBlcmltZW50YWwgZnVuY3Rpb24vbWV0aG9kIGZpbmRpdGVyKCkgaGFzIGJlZW4gYWRkZWQsIHdoaWNoIHdvcmtzCiAgbGlrZSBmaW5kYWxsKCkgYnV0IHJldHVybnMgYW4gaXRlcmF0b3IuCgotIFRpeCBleHBvc2VzIG1vcmUgY29tbWFuZHMgdGhyb3VnaCB0aGUgY2xhc3NlcyBEaXJTZWxlY3RCb3gsCiAgRGlyU2VsZWN0RGlhbG9nLCBMaXN0Tm90ZUJvb2ssIE1ldGVyLCBDaGVja0xpc3QsIGFuZCB0aGUKICBtZXRob2RzIHRpeF9hZGRiaXRtYXBkaXIsIHRpeF9jZ2V0LCB0aXhfY29uZmlndXJlLCB0aXhfZmlsZWRpYWxvZywKICB0aXhfZ2V0Yml0bWFwLCB0aXhfZ2V0aW1hZ2UsIHRpeF9vcHRpb25fZ2V0LCBhbmQgdGl4X3Jlc2V0b3B0aW9ucy4KCi0gVHJhY2ViYWNrIG9iamVjdHMgYXJlIG5vdyBzY2FubmVkIGJ5IGN5Y2xpYyBnYXJiYWdlIGNvbGxlY3Rpb24sIHNvCiAgY3ljbGVzIGNyZWF0ZWQgYnkgY2FzdWFsIHVzZSBvZiBzeXMuZXhjX2luZm8oKSBubyBsb25nZXIgY2F1c2UKICBwZXJtYW5lbnQgbWVtb3J5IGxlYWtzIChwcm92aWRlZCBnYXJiYWdlIGNvbGxlY3Rpb24gaXMgZW5hYmxlZCkuCgotIG9zLmV4dHNlcCAtLSBhIG5ldyB2YXJpYWJsZSBuZWVkZWQgYnkgdGhlIFJJU0NPUyBzdXBwb3J0LiAgSXQgaXMgdGhlCiAgc2VwYXJhdG9yIHVzZWQgYnkgZXh0ZW5zaW9ucywgYW5kIGlzICcuJyBvbiBhbGwgcGxhdGZvcm1zIGV4Y2VwdAogIFJJU0NPUywgd2hlcmUgaXQgaXMgJy8nLiAgVGhlcmUgaXMgbm8gbmVlZCB0byB1c2UgdGhpcyB2YXJpYWJsZQogIHVubGVzcyB5b3UgaGF2ZSBhIG1hc29jaGlzdGljIGRlc2lyZSB0byBwb3J0IHlvdXIgY29kZSB0byBSSVNDT1MuCgotIG1pbWV0eXBlcy5weSBoYXMgb3B0aW9uYWwgc3VwcG9ydCBmb3Igbm9uLXN0YW5kYXJkLCBidXQgY29tbW9ubHkKICBmb3VuZCB0eXBlcy4gIGd1ZXNzX3R5cGUoKSBhbmQgZ3Vlc3NfZXh0ZW5zaW9uKCkgbm93IGFjY2VwdCBhbgogIG9wdGlvbmFsICdzdHJpY3QnIGZsYWcsIGRlZmF1bHRpbmcgdG8gdHJ1ZSwgd2hpY2ggY29udHJvbHMgd2hldGhlcgogIHJlY29nbml6ZSBub24tc3RhbmRhcmQgdHlwZXMgb3Igbm90LiAgQSBmZXcgbm9uLXN0YW5kYXJkIHR5cGVzIHdlCiAga25vdyBhYm91dCBoYXZlIGJlZW4gYWRkZWQuICBBbHNvLCB3aGVuIHJ1biBhcyBhIHNjcmlwdCwgdGhlcmUgYXJlCiAgbmV3IC1sIGFuZCAtZSBvcHRpb25zLgoKLSBzdGF0Y2FjaGUgaXMgbm93IGRlcHJlY2F0ZWQuCgotIGVtYWlsLlV0aWxzLmZvcm1hdGRhdGUoKSBub3cgcHJvZHVjZXMgdGhlIHByZWZlcnJlZCBSRkMgMjgyMiBzdHlsZQogIGRhdGVzIHdpdGggbnVtZXJpYyB0aW1lem9uZXMgKGl0IHVzZWQgdG8gcHJvZHVjZSBvYnNvbGV0ZSBkYXRlcwogIGhhcmQgY29kZWQgdG8gIkdNVCIgdGltZXpvbmUpLiAgQW4gb3B0aW9uYWwgJ2xvY2FsdGltZScgZmxhZyBpcwogIGFkZGVkIHRvIHByb2R1Y2UgZGF0ZXMgaW4gdGhlIGxvY2FsIHRpbWV6b25lLCB3aXRoIGRheWxpZ2h0IHNhdmluZ3MKICB0aW1lIHByb3Blcmx5IHRha2VuIGludG8gYWNjb3VudC4KCi0gSW4gcGlja2xlIGFuZCBjUGlja2xlLCBpbnN0ZWFkIG9mIG1hc2tpbmcgZXJyb3JzIGluIGxvYWQoKSBieQogIHRyYW5zZm9ybWluZyB0aGVtIGludG8gU3lzdGVtRXJyb3IsIHdlIGxldCB0aGUgb3JpZ2luYWwgZXhjZXB0aW9uCiAgcHJvcGFnYXRlIG91dC4gIEFsc28sIGltcGxlbWVudCBzdXBwb3J0IGZvciBfX3NhZmVfZm9yX3VucGlja2xpbmdfXwogIGluIHBpY2tsZSwgYXMgaXQgYWxyZWFkeSB3YXMgc3VwcG9ydGVkIGluIGNQaWNrbGUuCgpUb29scy9EZW1vcwotLS0tLS0tLS0tLQoKQnVpbGQKLS0tLS0KCi0gVGhlIGRibSBtb2R1bGUgaXMgYnVpbHQgdXNpbmcgbGliZGIxIGlmIGF2YWlsYWJsZS4gIFRoZSBic2RkYiBtb2R1bGUKICBpcyBidWlsdCB3aXRoIGxpYmRiMyBpZiBhdmFpbGFibGUuCgotIE1pc2MvTWFrZWZpbGUucHJlLmluIGhhcyBiZWVuIHJlbW92ZWQgYnkgQkRGTCBwcm9ub3VuY2VtZW50LgoKQyBBUEkKLS0tLS0KCi0gTmV3IGZ1bmN0aW9uIFB5U2VxdWVuY2VfRmFzdF9HRVRfU0laRSgpIHJldHVybnMgdGhlIHNpemUgb2YgYSBub24tCiAgTlVMTCByZXN1bHQgZnJvbSBQeVNlcXVlbmNlX0Zhc3QoKSwgbW9yZSBxdWlja2x5IHRoYW4gY2FsbGluZwogIFB5U2VxdWVuY2VfU2l6ZSgpLgoKLSBOZXcgYXJndW1lbnQgdW5wYWNraW5nIGZ1bmN0aW9uIFB5QXJnX1VucGFja1R1cGxlKCkgYWRkZWQuCgotIE5ldyBmdW5jdGlvbnMgUHlPYmplY3RfQ2FsbEZ1bmN0aW9uT2JqQXJncygpIGFuZAogIFB5T2JqZWN0X0NhbGxNZXRob2RPYmpBcmdzKCkgaGF2ZSBiZWVuIGFkZGVkIHRvIG1ha2UgaXQgbW9yZQogIGNvbnZlbmllbnQgYW5kIGVmZmljaWVudCB0byBjYWxsIGZ1bmN0aW9ucyBhbmQgbWV0aG9kcyBmcm9tIEMuCgotIFB5QXJnX1BhcnNlVHVwbGVBbmRLZXl3b3JkcygpIG5vIGxvbmdlciBtYXNrcyBlcnJvcnMsIHNvIGl0J3MKICBwb3NzaWJsZSB0aGF0IHRoaXMgd2lsbCBwcm9wYWdhdGUgZXJyb3JzIGl0IGRpZG4ndCBiZWZvcmUuCgotIE5ldyBmdW5jdGlvbiBQeU9iamVjdF9DaGVja1JlYWRCdWZmZXIoKSwgd2hpY2ggcmV0dXJucyB0cnVlIGlmIGl0cwogIGFyZ3VtZW50IHN1cHBvcnRzIHRoZSBzaW5nbGUtc2VnbWVudCByZWFkYWJsZSBidWZmZXIgaW50ZXJmYWNlLgoKTmV3IHBsYXRmb3JtcwotLS0tLS0tLS0tLS0tCgotIFdlJ3ZlIGZpbmFsbHkgY29uZmlybWVkIHRoYXQgdGhpcyByZWxlYXNlIGJ1aWxkcyBvbiBIUC1VWCAxMS4wMCwKICAqd2l0aCogdGhyZWFkcywgYW5kIHBhc3NlcyB0aGUgdGVzdCBzdWl0ZS4KCi0gVGhhbmtzIHRvIGEgc2VyaWVzIG9mIHBhdGNoZXMgZnJvbSBNaWNoYWVsIE11bGxlciwgUHl0aG9uIG1heSBidWlsZAogIGFnYWluIHVuZGVyIE9TLzIgVmlzdWFsIEFnZSBDKysuCgotIFVwZGF0ZWQgUklTQ09TIHBvcnQgYnkgRGlldG1hciBTY2h3ZXJ0YmVyZ2VyLgoKVGVzdHMKLS0tLS0KCi0gQWRkZWQgYSB0ZXN0IHNjcmlwdCBmb3IgdGhlIGN1cnNlcyBtb2R1bGUuICBJdCBpc24ndCBydW4gYXV0b21hdGljYWxseTsKICByZWdydGVzdC5weSBtdXN0IGJlIHJ1biB3aXRoICctdSBjdXJzZXMnIHRvIGVuYWJsZSBpdC4KCldpbmRvd3MKLS0tLS0tLQoKTWFjCi0tLS0KCi0gUHl0aG9uU2NyaXB0IGhhcyBiZWVuIG1vdmVkIHRvIHVuc3VwcG9ydGVkIGFuZCBpcyBzbGF0ZWQgdG8gYmUKICByZW1vdmVkIGNvbXBsZXRlbHkgaW4gdGhlIG5leHQgcmVsZWFzZS4KCi0gSXQgc2hvdWxkIG5vdyBiZSBwb3NzaWJsZSB0byBidWlsZCBhcHBsZXRzIHRoYXQgd29yayBvbiBib3RoIE9TOSBhbmQKICBPU1guCgotIFRoZSBjb3JlIGlzIG5vdyBsaW5rZWQgd2l0aCBDb3JlU2VydmljZXMgbm90IENhcmJvbjsgYXMgYSBzaWRlCiAgcmVzdWx0LCBkZWZhdWx0IDhiaXQgZW5jb2Rpbmcgb24gT1NYIGlzIG5vdyBBU0NJSS4KCi0gUHl0aG9uIHNob3VsZCBub3cgYnVpbGQgb24gT1NYIDEwLjEuMQoKCldoYXQncyBOZXcgaW4gUHl0aG9uIDIuMmIxPwo9PT09PT09PT09PT09PT09PT09PT09PT09PT0KCipSZWxlYXNlIGRhdGU6IDE5LU9jdC0yMDAxKgoKVHlwZS9jbGFzcyB1bmlmaWNhdGlvbiBhbmQgbmV3LXN0eWxlIGNsYXNzZXMKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCi0gTmV3LXN0eWxlIGNsYXNzZXMgYXJlIG5vdyBhbHdheXMgZHluYW1pYyAoZXhjZXB0IGZvciBidWlsdC1pbiBhbmQKICBleHRlbnNpb24gdHlwZXMpLiAgVGhlcmUgaXMgbm8gbG9uZ2VyIGEgcGVyZm9ybWFuY2UgcGVuYWx0eSwgYW5kIEkKICBubyBsb25nZXIgc2VlIGFub3RoZXIgcmVhc29uIHRvIGtlZXAgdGhpcyBiYWdnYWdlIGFyb3VuZC4gIE9uZSByZWxpYwogIHJlbWFpbnM6IHRoZSBfX2RpY3RfXyBvZiBhIG5ldy1zdHlsZSBjbGFzcyBpcyBhIHJlYWQtb25seSBwcm94eTsgeW91CiAgbXVzdCBzZXQgdGhlIGNsYXNzJ3MgYXR0cmlidXRlIHRvIG1vZGlmeSBpdC4gIEFzIGEgY29uc2VxdWVuY2UsIHRoZQogIF9fZGVmaW5lZF9fIGF0dHJpYnV0ZSBvZiBuZXctc3R5bGUgdHlwZXMgbm8gbG9uZ2VyIGV4aXN0cywgZm9yIGxhY2sKICBvZiBuZWVkOiB0aGVyZSBpcyBvbmNlIGFnYWluIG9ubHkgb25lIF9fZGljdF9fIChhbHRob3VnaCBpbiB0aGUKICBmdXR1cmUgYSBfX2NhY2hlX18gbWF5IGJlIHJlc3VycmVjdGVkIHdpdGggYSBzaW1pbGFyIGZ1bmN0aW9uLCBpZiBJCiAgY2FuIHByb3ZlIHRoYXQgaXQgYWN0dWFsbHkgc3BlZWRzIHRoaW5ncyB1cCkuCgotIEMuX19kb2NfXyBub3cgd29ya3MgYXMgZXhwZWN0ZWQgZm9yIG5ldy1zdHlsZSBjbGFzc2VzIChpbiAyLjJhNCBpdAogIGFsd2F5cyByZXR1cm5lZCBOb25lLCBldmVuIHdoZW4gdGhlcmUgd2FzIGEgY2xhc3MgZG9jc3RyaW5nKS4KCi0gZG9jdGVzdCBub3cgZmluZHMgYW5kIHJ1bnMgZG9jc3RyaW5ncyBhdHRhY2hlZCB0byBuZXctc3R5bGUgY2xhc3NlcywKICBjbGFzcyBtZXRob2RzLCBzdGF0aWMgbWV0aG9kcywgYW5kIHByb3BlcnRpZXMuCgpDb3JlIGFuZCBidWlsdGlucwotLS0tLS0tLS0tLS0tLS0tLQoKLSBBIHZlcnkgc3VidGxlIHN5bnRhY3RpY2FsIHBpdGZhbGwgaW4gbGlzdCBjb21wcmVoZW5zaW9ucyB3YXMgZml4ZWQuCiAgRm9yIGV4YW1wbGU6IFthK2IgZm9yIGEgaW4gJ2FiYycsIGZvciBiIGluICdkZWYnXS4gIFRoZSBjb21tYSBpbgogIHRoaXMgZXhhbXBsZSBpcyBhIG1pc3Rha2UuICBQcmV2aW91c2x5LCB0aGlzIHdvdWxkIHNpbGVudGx5IGxldCAnYScKICBpdGVyYXRlIG92ZXIgdGhlIHNpbmdsZXRvbiB0dXBsZSAoJ2FiYycsKSwgeWllbGRpbmcgWydhYmNkJywgJ2FiY2UnLAogICdhYmNmJ10gcmF0aGVyIHRoYW4gdGhlIGludGVuZGVkIFsnYWQnLCAnYWUnLCAnYWYnLCAnYmQnLCAnYmUnLAogICdiZicsICdjZCcsICdjZScsICdjZiddLiAgTm93LCB0aGlzIGlzIGZsYWdnZWQgYXMgYSBzeW50YXggZXJyb3IuCiAgTm90ZSB0aGF0IFthIGZvciBhIGluIDxzaW5nbGV0b24+XSBpcyBhIGNvbnZvbHV0ZWQgd2F5IHRvIHNheQogIFs8c2luZ2xldG9uPl0gYW55d2F5LCBzbyBpdCdzIG5vdCBsaWtlIGFueSBleHByZXNzaXZlbmVzcyBpcyBsb3N0LgoKLSBnZXRhdHRyKG9iaiwgbmFtZSwgZGVmYXVsdCkgbm93IG9ubHkgY2F0Y2hlcyBBdHRyaWJ1dGVFcnJvciwgYXMKICBkb2N1bWVudGVkLCByYXRoZXIgdGhhbiByZXR1cm5pbmcgdGhlIGRlZmF1bHQgdmFsdWUgZm9yIGFsbAogIGV4Y2VwdGlvbnMgKHdoaWNoIGNvdWxkIG1hc2sgYnVncyBpbiBhIF9fZ2V0YXR0cl9fIGhvb2ssIGZvcgogIGV4YW1wbGUpLgoKLSBXZWFrIHJlZmVyZW5jZSBvYmplY3RzIGFyZSBub3cgcGFydCBvZiB0aGUgY29yZSBhbmQgb2ZmZXIgYSBDIEFQSS4KICBBIGJ1ZyB3aGljaCBjb3VsZCBhbGxvdyBhIGNvcmUgZHVtcCB3aGVuIGJpbmFyeSBvcGVyYXRpb25zIGludm9sdmVkCiAgcHJveHkgcmVmZXJlbmNlIGhhcyBiZWVuIGZpeGVkLiAgd2Vha3JlZi5SZWZlcmVuY2VFcnJvciBpcyBub3cgYQogIGJ1aWx0LWluIGV4Y2VwdGlvbi4KCi0gdW5pY29kZShvYmopIG5vdyBiZWhhdmVzIG1vcmUgbGlrZSBzdHIob2JqKSwgYWNjZXB0aW5nIGFyYml0cmFyeQogIG9iamVjdHMsIGFuZCBjYWxsaW5nIGEgX191bmljb2RlX18gbWV0aG9kIGlmIGl0IGV4aXN0cy4KICB1bmljb2RlKG9iaiwgZW5jb2RpbmcpIGFuZCB1bmljb2RlKG9iaiwgZW5jb2RpbmcsIGVycm9ycykgc3RpbGwKICByZXF1aXJlIGFuIDgtYml0IHN0cmluZyBvciBjaGFyYWN0ZXIgYnVmZmVyIGFyZ3VtZW50LgoKLSBpc2luc3RhbmNlKCkgbm93IGFsbG93cyBhbnkgb2JqZWN0IGFzIHRoZSBmaXJzdCBhcmd1bWVudCBhbmQgYQogIGNsYXNzLCBhIHR5cGUgb3Igc29tZXRoaW5nIHdpdGggYSBfX2Jhc2VzX18gdHVwbGUgYXR0cmlidXRlIGZvciB0aGUKICBzZWNvbmQgYXJndW1lbnQuICBUaGUgc2Vjb25kIGFyZ3VtZW50IG1heSBhbHNvIGJlIGEgdHVwbGUgb2YgYQogIGNsYXNzLCB0eXBlLCBvciBzb21ldGhpbmcgd2l0aCBfX2Jhc2VzX18sIGluIHdoaWNoIGNhc2UgaXNpbnN0YW5jZSgpCiAgd2lsbCByZXR1cm4gdHJ1ZSBpZiB0aGUgZmlyc3QgYXJndW1lbnQgaXMgYW4gaW5zdGFuY2Ugb2YgYW55IG9mIHRoZQogIHRoaW5ncyBjb250YWluZWQgaW4gdGhlIHNlY29uZCBhcmd1bWVudCB0dXBsZS4gIEUuZy4KCiAgaXNpbnN0YW5jZSh4LCAoQSwgQikpCgogIHJldHVybnMgdHJ1ZSBpZiB4IGlzIGFuIGluc3RhbmNlIG9mIEEgb3IgQi4KCkV4dGVuc2lvbiBtb2R1bGVzCi0tLS0tLS0tLS0tLS0tLS0tCgotIHRocmVhZC5zdGFydF9uZXdfdGhyZWFkKCkgbm93IHJldHVybnMgdGhlIHRocmVhZCBJRCAocHJldmlvdXNseSBOb25lKS4KCi0gYmluYXNjaWkgaGFzIG5vdyB0d28gcXVvcHJpIHN1cHBvcnQgZnVuY3Rpb25zLCBhMmJfcXAgYW5kIGIyYV9xcC4KCi0gcmVhZGxpbmUgbm93IHN1cHBvcnRzIHNldHRpbmcgdGhlIHN0YXJ0dXBfaG9vayBhbmQgdGhlCiAgcHJlX2V2ZW50X2hvb2ssIGFuZCBhZGRzIHRoZSBhZGRfaGlzdG9yeSgpIGZ1bmN0aW9uLgoKLSBvcyBhbmQgcG9zaXggc3VwcG9ydHMgY2hyb290KCksIHNldGdyb3VwcygpIGFuZCB1bnNldGVudigpIHdoZXJlCiAgYXZhaWxhYmxlLiAgVGhlIHN0YXQoKSwgZnN0YXQoKSwgc3RhdHZmcygpIGFuZCBmc3RhdHZmcygpIGZ1bmN0aW9ucwogIG5vdyByZXR1cm4gInBzZXVkby1zZXF1ZW5jZXMiIC0tIHRoZSB2YXJpb3VzIGZpZWxkcyBjYW4gbm93IGJlCiAgYWNjZXNzZWQgYXMgYXR0cmlidXRlcyAoZS5nLiBvcy5zdGF0KCIvIikuc3RfbXRpbWUpIGJ1dCBmb3IKICBiYWNrd2FyZHMgY29tcGF0aWJpbGl0eSB0aGV5IGFsc28gYmVoYXZlIGFzIGEgZml4ZWQtbGVuZ3RoIHNlcXVlbmNlLgogIFNvbWUgcGxhdGZvcm0tc3BlY2lmaWMgZmllbGRzIChlLmcuIHN0X3JkZXYpIGFyZSBvbmx5IGFjY2Vzc2libGUgYXMKICBhdHRyaWJ1dGVzLgoKLSB0aW1lOiBsb2NhbHRpbWUoKSwgZ210aW1lKCkgYW5kIHN0cnB0aW1lKCkgbm93IHJldHVybiBhCiAgcHNldWRvLXNlcXVlbmNlIHNpbWlsYXIgdG8gdGhlIG9zLnN0YXQoKSByZXR1cm4gdmFsdWUsIHdpdGgKICBhdHRyaWJ1dGVzIGxpa2UgdG1feWVhciBldGMuCgotIERlY29tcHJlc3Npb24gb2JqZWN0cyBpbiB0aGUgemxpYiBtb2R1bGUgbm93IGFjY2VwdCBhbiBvcHRpb25hbAogIHNlY29uZCBwYXJhbWV0ZXIgdG8gZGVjb21wcmVzcygpIHRoYXQgc3BlY2lmaWVzIHRoZSBtYXhpbXVtIGFtb3VudAogIG9mIG1lbW9yeSB0byB1c2UgZm9yIHRoZSB1bmNvbXByZXNzZWQgZGF0YS4KCi0gb3B0aW9uYWwgU1NMIHN1cHBvcnQgaW4gdGhlIHNvY2tldCBtb2R1bGUgbm93IGV4cG9ydHMgT3BlblNTTAogIGZ1bmN0aW9ucyBSQU5EX2FkZCgpLCBSQU5EX2VnZCgpLCBhbmQgUkFORF9zdGF0dXMoKS4gIFRoZXNlIGNhbGxzCiAgYXJlIHVzZWZ1bCBvbiBwbGF0Zm9ybXMgbGlrZSBTb2xhcmlzIHdoZXJlIE9wZW5TU0wgZG9lcyBub3QKICBhdXRvbWF0aWNhbGx5IHNlZWQgaXRzIFBSTkcuICBBbHNvLCB0aGUga2V5ZmlsZSBhbmQgY2VydGZpbGUKICBhcmd1bWVudHMgdG8gc29ja2V0LnNzbCgpIGFyZSBub3cgb3B0aW9uYWwuCgotIHBvc2l4bW9kdWxlIChhbmQgYnkgZXh0ZW5zaW9uLCB0aGUgb3MgbW9kdWxlIG9uIFBPU0lYIHBsYXRmb3Jtcykgbm93CiAgZXhwb3J0cyBPX0xBUkdFRklMRSwgT19ESVJFQ1QsIE9fRElSRUNUT1JZLCBhbmQgT19OT0ZPTExPVy4KCkxpYnJhcnkKLS0tLS0tLQoKLSBkb2N0ZXN0IG5vdyBleGNsdWRlcyBmdW5jdGlvbnMgYW5kIGNsYXNzZXMgbm90IGRlZmluZWQgYnkgdGhlIG1vZHVsZQogIGJlaW5nIHRlc3RlZCwgdGhhbmtzIHRvIFRpbSBIb2NoYmVyZy4KCi0gSG90U2hvdCwgYSBuZXcgcHJvZmlsZXIgaW1wbGVtZW50ZWQgdXNpbmcgYSBDLWJhc2VkIGNhbGxiYWNrLCBoYXMKICBiZWVuIGFkZGVkLiAgVGhpcyBzdWJzdGFudGlhbGx5IHJlZHVjZXMgdGhlIG92ZXJoZWFkIG9mIHByb2ZpbGluZywKICBidXQgaXQgaXMgc3RpbGwgcXVpdGUgcHJlbGltaW5hcnkuICBTdXBwb3J0IG1vZHVsZXMgYW5kCiAgZG9jdW1lbnRhdGlvbiB3aWxsIGJlIGFkZGVkIGluIHVwY29taW5nIHJlbGVhc2VzIChiZWZvcmUgMi4yIGZpbmFsKS4KCi0gcHJvZmlsZSBub3cgcHJvZHVjZXMgY29ycmVjdCBvdXRwdXQgaW4gc2l0dWF0aW9ucyB3aGVyZSBhbiBleGNlcHRpb24KICByYWlzZWQgaW4gUHl0aG9uIGlzIGNsZWFyZWQgYnkgQyBjb2RlIChlLmcuIGhhc2F0dHIoKSkuICBUaGlzIHVzZWQKICB0byBjYXVzZSB3cm9uZyBvdXRwdXQsIGluY2x1ZGluZyBzcHVyaW91cyBjbGFpbXMgb2YgcmVjdXJzaXZlCiAgZnVuY3Rpb25zIGFuZCBhdHRyaWJ1dGlvbiBvZiB0aW1lIHNwZW50IHRvIHRoZSB3cm9uZyBmdW5jdGlvbi4KCiAgVGhlIGNvZGUgYW5kIGRvY3VtZW50YXRpb24gZm9yIHRoZSBkZXJpdmVkIE9sZFByb2ZpbGUgYW5kIEhvdFByb2ZpbGUKICBwcm9maWxpbmcgY2xhc3NlcyB3YXMgcmVtb3ZlZC4gIFRoZSBjb2RlIGhhc24ndCB3b3JrZWQgZm9yIHllYXJzIChpZgogIHlvdSB0cmllZCB0byB1c2UgdGhlbSwgdGhleSByYWlzZWQgZXhjZXB0aW9ucykuICBPbGRQcm9maWxlCiAgaW50ZW5kZWQgdG8gcmVwcm9kdWNlIHRoZSBiZWhhdmlvciBvZiB0aGUgcHJvZmlsZXIgUHl0aG9uIHVzZWQgbW9yZQogIHRoYW4gNyB5ZWFycyBhZ28sIGFuZCBpc24ndCBpbnRlcmVzdGluZyBhbnltb3JlLiAgSG90UHJvZmlsZSBpbnRlbmRlZAogIHRvIHByb3ZpZGUgYSBmYXN0ZXIgcHJvZmlsZXIgKGJ1dCBwcm9kdWNpbmcgbGVzcyBpbmZvcm1hdGlvbiksIGFuZAogIHRoYXQncyBhIHdvcnRoeSBnb2FsIHdlIGludGVuZCB0byBtZWV0IHZpYSBhIGRpZmZlcmVudCBhcHByb2FjaCAoYnV0CiAgd2l0aG91dCBsb3NpbmcgaW5mb3JtYXRpb24pLgoKLSBQcm9maWxlLmNhbGlicmF0ZSgpIGhhcyBhIG5ldyBpbXBsZW1lbnRhdGlvbiB0aGF0IHNob3VsZCBkZWxpdmVyCiAgYSBtdWNoIGJldHRlciBzeXN0ZW0tc3BlY2lmaWMgY2FsaWJyYXRpb24gY29uc3RhbnQuICBUaGUgY29uc3RhbnQgY2FuCiAgbm93IGJlIHNwZWNpZmllZCBpbiBhbiBpbnN0YW5jZSBjb25zdHJ1Y3Rvciwgb3IgYXMgYSBQcm9maWxlIGNsYXNzIG9yCiAgaW5zdGFuY2UgdmFyaWFibGUsIGluc3RlYWQgb2YgYnkgZWRpdGluZyBwcm9maWxlLnB5J3Mgc291cmNlIGNvZGUuCiAgQ2FsaWJyYXRpb24gbXVzdCBzdGlsbCBiZSBkb25lIG1hbnVhbGx5IChzZWUgdGhlIGRvY3MgZm9yIHRoZSBwcm9maWxlCiAgbW9kdWxlKS4KCiAgTm90ZSB0aGF0IFByb2ZpbGUuY2FsaWJyYXRlKCkgbXVzdCBiZSBvdmVycmlkZW4gYnkgc3ViY2xhc3Nlcy4KICBJbXByb3ZpbmcgdGhlIGFjY3VyYWN5IHJlcXVpcmVkIGV4cGxvaXRpbmcgZGV0YWlsZWQga25vd2xlZGdlIG9mCiAgcHJvZmlsZXIgaW50ZXJuYWxzOyB0aGUgZWFybGllciBtZXRob2QgYWJzdHJhY3RlZCBhd2F5IHRoZSBkZXRhaWxzCiAgYW5kIG1lYXN1cmVkIGEgc2ltcGxpZmllZCBtb2RlbCBpbnN0ZWFkLCBidXQgY29uc2VxdWVudGx5IGNvbXB1dGVkCiAgYSBjb25zdGFudCB0b28gc21hbGwgYnkgYSBmYWN0b3Igb2YgMiBvbiBzb21lIG1vZGVybiBtYWNoaW5lcy4KCi0gcXVvcHJpJ3MgZW5jb2RlIGFuZCBkZWNvZGUgbWV0aG9kcyB0YWtlIGFuIG9wdGlvbmFsIGhlYWRlciBwYXJhbWV0ZXIsCiAgd2hpY2ggaW5kaWNhdGVzIHdoZXRoZXIgb3V0cHV0IGlzIGludGVuZGVkIGZvciB0aGUgaGVhZGVyICdRJwogIGVuY29kaW5nLgoKLSBUaGUgU29ja2V0U2VydmVyLlRocmVhZGluZ01peEluIGNsYXNzIG5vdyBjbG9zZXMgdGhlIHJlcXVlc3QgYWZ0ZXIKICBmaW5pc2hfcmVxdWVzdCgpIHJldHVybnMuICAoTm90IHdoZW4gaXQgZXJyb3JzIG91dCB0aG91Z2guKQoKLSBUaGUgbm50cGxpYiBtb2R1bGUncyBOTlRQLmJvZHkoKSBtZXRob2QgaGFzIGdyb3duIGEgJ2ZpbGUnIGFyZ3VtZW50CiAgdG8gYWxsb3cgc2F2aW5nIHRoZSBtZXNzYWdlIGJvZHkgdG8gYSBmaWxlLgoKLSBUaGUgZW1haWwgcGFja2FnZSBoYXMgYWRkZWQgYSBjbGFzcyBlbWFpbC5QYXJzZXIuSGVhZGVyUGFyc2VyIHdoaWNoCiAgb25seSBwYXJzZXMgaGVhZGVycyBhbmQgZG9lcyBub3QgcmVjdXJzZSBpbnRvIHRoZSBtZXNzYWdlJ3MgYm9keS4KICBBbHNvLCB0aGUgbW9kdWxlL2NsYXNzIE1JTUVBdWRpbyBoYXMgYmVlbiBhZGRlZCBmb3IgcmVwcmVzZW50aW5nCiAgYXVkaW8gZGF0YSAoY29udHJpYnV0ZWQgYnkgQW50aG9ueSBCYXh0ZXIpLgoKLSBmdHBsaWIgc2hvdWxkIGJlIGFibGUgdG8gaGFuZGxlIGZpbGVzID4gMkdCLgoKLSBDb25maWdQYXJzZXIuZ2V0Ym9vbGVhbigpIG5vdyBhbHNvIGludGVycHJldHMgVFJVRSwgRkFMU0UsIFlFUywgTk8sCiAgT04sIGFuZCBPRkYuCgotIHhtbC5kb20ubWluaWRvbSBOb2RlTGlzdCBvYmplY3RzIG5vdyBzdXBwb3J0IHRoZSBsZW5ndGggYXR0cmlidXRlCiAgYW5kIGl0ZW0oKSBtZXRob2QgYXMgcmVxdWlyZWQgYnkgdGhlIERPTSBzcGVjaWZpY2F0aW9ucy4KClRvb2xzL0RlbW9zCi0tLS0tLS0tLS0tCgotIERlbW8vZG5zIHdhcyByZW1vdmVkLiAgSXQgbm8gbG9uZ2VyIHNlcnZlcyBhbnkgcHVycG9zZTsgYSBwYWNrYWdlCiAgZGVyaXZlZCBmcm9tIGl0IGlzIG5vdyBtYWludGFpbmVkIGJ5IEFudGhvbnkgQmF4dGVyLCBzZWUKICBodHRwOi8vUHlETlMuU291cmNlRm9yZ2UubmV0LgoKLSBUaGUgZnJlZXplIHRvb2wgaGFzIGJlZW4gbWFkZSBtb3JlIHJvYnVzdCwgYW5kIHR3byBuZXcgb3B0aW9ucyBoYXZlCiAgYmVlbiBhZGRlZDogLVggYW5kIC1FLgoKQnVpbGQKLS0tLS0KCi0gY29uZmlndXJlIHdpbGwgdXNlIENYWCBpbiBMSU5LQ0MgaWYgQ1hYIGlzIHVzZWQgdG8gYnVpbGQgbWFpbigpIGFuZAogIHRoZSBzeXN0ZW0gcmVxdWlyZXMgdG8gbGluayBhIEMrKyBtYWluIHVzaW5nIHRoZSBDKysgY29tcGlsZXIuCgpDIEFQSQotLS0tLQoKLSBUaGUgZG9jdW1lbnRhdGlvbiBmb3IgdGhlIHRwX2NvbXBhcmUgc2xvdCBpcyB1cGRhdGVkIHRvIHJlcXVpcmUgdGhhdAogIHRoZSByZXR1cm4gdmFsdWUgbXVzdCBiZSAtMSwgMCwgMTsgYW4gYXJiaXRyYXJ5IG51bWJlciA8MCBvciA+MCBpcwogIG5vdCBjb3JyZWN0LiAgVGhpcyBpcyBub3QgeWV0IGVuZm9yY2VkIGJ1dCB3aWxsIGJlIGVuZm9yY2VkIGluCiAgUHl0aG9uIDIuMzsgZXZlbiBsYXRlciwgd2UgbWF5IHVzZSAtMiB0byBpbmRpY2F0ZSBlcnJvcnMgYW5kICsyIGZvcgogICJOb3RJbXBsZW1lbnRlZCIuICBSaWdodCBub3csIC0xIHNob3VsZCBiZSB1c2VkIGZvciBhbiBlcnJvciByZXR1cm4uCgotIFB5TG9uZ19Bc0xvbmdMb25nKCkgbm93IGFjY2VwdHMgaW50IChhcyB3ZWxsIGFzIGxvbmcpIGFyZ3VtZW50cy4KICBDb25zZXF1ZW50bHksIFB5QXJnX1BhcnNlVHVwbGUncyAnTCcgY29kZSBhbHNvIGFjY2VwdHMgaW50IChhcyB3ZWxsCiAgYXMgbG9uZykgYXJndW1lbnRzLgoKLSBQeVRocmVhZF9zdGFydF9uZXdfdGhyZWFkKCkgbm93IHJldHVybnMgYSBsb25nIGludCBnaXZpbmcgdGhlIHRocmVhZAogIElELCBpZiBvbmUgY2FuIGJlIGNhbGN1bGF0ZWQ7IGl0IHJldHVybnMgLTEgZm9yIGVycm9yLCAwIGlmIG5vCiAgdGhyZWFkIElEIGlzIGNhbGN1bGF0ZWQgKHRoaXMgaXMgYW4gaW5jb21wYXRpYmxlIGNoYW5nZSwgYnV0IG9ubHkKICB0aGUgdGhyZWFkIG1vZHVsZSB1c2VkIHRoaXMgQVBJKS4gIFRoaXMgY29kZSBoYXMgb25seSByZWFsbHkgYmVlbgogIHRlc3RlZCBvbiBMaW51eCBhbmQgV2luZG93czsgb3RoZXIgcGxhdGZvcm1zIHBsZWFzZSBiZXdhcmUgKGFuZAogIHJlcG9ydCBhbnkgYnVncyBvciBzdHJhbmdlIGJlaGF2aW9yKS4KCi0gUHlVbmljb2RlX0Zyb21FbmNvZGVkT2JqZWN0KCkgbm8gbG9uZ2VyIGFjY2VwdHMgVW5pY29kZSBvYmplY3RzIGFzCiAgaW5wdXQuCgpOZXcgcGxhdGZvcm1zCi0tLS0tLS0tLS0tLS0KClRlc3RzCi0tLS0tCgpXaW5kb3dzCi0tLS0tLS0KCi0gSW5zdGFsbGVyOiAgSWYgeW91IGluc3RhbGwgSURMRSwgYW5kIGRvbid0IGRpc2FibGUgZmlsZS1leHRlbnNpb24KICByZWdpc3RyYXRpb24sIGEgbmV3ICJFZGl0IHdpdGggSURMRSIgY29udGV4dCAocmlnaHQtY2xpY2spIG1lbnUgZW50cnkKICBpcyBjcmVhdGVkIGZvciAucHkgYW5kIC5weXcgZmlsZXMuCgotIFRoZSBzaWduYWwgbW9kdWxlIG5vdyBzdXBwb3J0cyBTSUdCUkVBSyBvbiBXaW5kb3dzLCB0aGFua3MgdG8gU3RldmVuCiAgU2NvdHQuICBOb3RlIHRoYXQgU0lHQlJFQUsgaXMgdW5pcXVlIHRvIFdpbmRvd3MuICBUaGUgZGVmYXVsdCBTSUdCUkVBSwogIGFjdGlvbiByZW1haW5zIHRvIGNhbGwgV2luMzIgRXhpdFByb2Nlc3MoKS4gIFRoaXMgY2FuIGJlIGNoYW5nZWQgdmlhCiAgc2lnbmFsLnNpZ25hbCgpLiAgRm9yIGV4YW1wbGU6OgoKICAgICAgIyBNYWtlIEN0cmwrQnJlYWsgcmFpc2UgS2V5Ym9hcmRJbnRlcnJ1cHQsIGxpa2UgUHl0aG9uJ3MgZGVmYXVsdCBDdHJsK0MKICAgICAgIyAoU0lHSU5UKSBiZWhhdmlvci4KICAgICAgaW1wb3J0IHNpZ25hbAogICAgICBzaWduYWwuc2lnbmFsKHNpZ25hbC5TSUdCUkVBSywgc2lnbmFsLmRlZmF1bHRfaW50X2hhbmRsZXIpCgogICAgICB0cnk6CiAgICAgICAgICB3aGlsZSAxOgogICAgICAgICAgICAgIHBhc3MKICAgICAgZXhjZXB0IEtleWJvYXJkSW50ZXJydXB0OgogICAgICAgICAgIyBXZSBnZXQgaGVyZSBvbiBDdHJsK0Mgb3IgQ3RybCtCcmVhayBub3c7IGlmIHdlIGhhZCBub3QgY2hhbmdlZAogICAgICAgICAgIyBTSUdCUkVBSywgb25seSBvbiBDdHJsK0MgKGFuZCBDdHJsK0JyZWFrIHdvdWxkIHRlcm1pbmF0ZSB0aGUKICAgICAgICAgICMgcHJvZ3JhbSB3aXRob3V0IHRoZSBwb3NzaWJpbGl0eSBmb3IgYW55IFB5dGhvbi1sZXZlbCBjbGVhbnVwKS4KICAgICAgICAgIHByaW50ICJDbGVhbiBleGl0IgoKCldoYXQncyBOZXcgaW4gUHl0aG9uIDIuMmE0Pwo9PT09PT09PT09PT09PT09PT09PT09PT09PT0KCipSZWxlYXNlIGRhdGU6IDI4LVNlcC0yMDAxKgoKVHlwZS9jbGFzcyB1bmlmaWNhdGlvbiBhbmQgbmV3LXN0eWxlIGNsYXNzZXMKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCi0gcHlkb2MgYW5kIGluc3BlY3QgYXJlIG5vdyBhd2FyZSBvZiBuZXctc3R5bGUgY2xhc3NlczsKICBlLmcuIGhlbHAobGlzdCkgYXQgdGhlIGludGVyYWN0aXZlIHByb21wdCBub3cgc2hvd3MgcHJvcGVyCiAgZG9jdW1lbnRhdGlvbiBmb3IgYWxsIG9wZXJhdGlvbnMgb24gbGlzdCBvYmplY3RzLgoKLSBBcHBsaWNhdGlvbnMgdXNpbmcgSmltIEZ1bHRvbidzIEV4dGVuc2lvbkNsYXNzIG1vZHVsZSBjYW4gbm93IHNhZmVseQogIGJlIHVzZWQgd2l0aCBQeXRob24gMi4yLiAgSW4gcGFydGljdWxhciwgWm9wZSAyLjQuMSBub3cgd29ya3Mgd2l0aAogIFB5dGhvbiAyLjIgKGFzIHdlbGwgYXMgd2l0aCBQeXRob24gMi4xLjEpLiAgVGhlIERlbW8vbWV0YWNsYXNzCiAgZXhhbXBsZXMgYWxzbyB3b3JrIGFnYWluLiAgSXQgaXMgaG9wZWQgdGhhdCBHdGsgYW5kIEJvb3N0IGFsc28gd29yawogIHdpdGggMi4yYTQgYW5kIGJleW9uZC4gIChJZiB5b3UgY2FuIGNvbmZpcm0gdGhpcywgcGxlYXNlIHdyaXRlCiAgd2VibWFzdGVyQHB5dGhvbi5vcmc7IGlmIHRoZXJlIGFyZSBzdGlsbCBwcm9ibGVtcywgcGxlYXNlIG9wZW4gYSBidWcKICByZXBvcnQgb24gU291cmNlRm9yZ2UuKQoKLSBwcm9wZXJ0eSgpIG5vdyB0YWtlcyA0IGtleXdvcmQgYXJndW1lbnRzOiAgZmdldCwgZnNldCwgZmRlbCBhbmQgZG9jLgogIFRoZXNlIG1hcCB0byByZWFkLW9ubHkgYXR0cmlidXRlcyAnZmdldCcsICdmc2V0JywgJ2ZkZWwnLCBhbmQgJ19fZG9jX18nCiAgaW4gdGhlIGNvbnN0cnVjdGVkIHByb3BlcnR5IG9iamVjdC4gIGZnZXQsIGZzZXQgYW5kIGZkZWwgd2VyZW4ndAogIGRpc2NvdmVyYWJsZSBmcm9tIFB5dGhvbiBpbiAyLjJhMy4gIF9fZG9jX18gaXMgbmV3LCBhbmQgYWxsb3dzIHRvCiAgYXNzb2NpYXRlIGEgZG9jc3RyaW5nIHdpdGggYSBwcm9wZXJ0eS4KCi0gQ29tcGFyaXNvbiBvdmVybG9hZGluZyBpcyBub3cgbW9yZSBjb21wbGV0ZWx5IGltcGxlbWVudGVkLiAgRm9yCiAgZXhhbXBsZSwgYSBzdHIgc3ViY2xhc3MgaW5zdGFuY2UgY2FuIHByb3Blcmx5IGJlIGNvbXBhcmVkIHRvIGEgc3RyCiAgaW5zdGFuY2UsIGFuZCBpdCBjYW4gcHJvcGVybHkgb3ZlcmxvYWQgY29tcGFyaXNvbi4gIERpdHRvIGZvciBtb3N0CiAgb3RoZXIgYnVpbHQtaW4gb2JqZWN0IHR5cGVzLgoKLSBUaGUgcmVwcigpIG9mIG5ldy1zdHlsZSBjbGFzc2VzIGhhcyBjaGFuZ2VkOyBpbnN0ZWFkIG9mIDx0eXBlCiAgJ00uRm9vJz4gYSBuZXctc3R5bGUgY2xhc3MgaXMgbm93IHJlbmRlcmVkIGFzIDxjbGFzcyAnTS5Gb28nPiwKICAqZXhjZXB0KiBmb3IgYnVpbHQtaW4gdHlwZXMsIHdoaWNoIGFyZSBzdGlsbCByZW5kZXJlZCBhcyA8dHlwZQogICdGb28nPiAodG8gYXZvaWQgdXBzZXR0aW5nIGV4aXN0aW5nIGNvZGUgdGhhdCBtaWdodCBwYXJzZSBvcgogIG90aGVyd2lzZSByZWx5IG9uIHJlcHIoKSBvZiBjZXJ0YWluIHR5cGUgb2JqZWN0cykuCgotIFRoZSByZXByKCkgb2YgbmV3LXN0eWxlIG9iamVjdHMgaXMgbm93IGFsd2F5cyA8Rm9vIG9iamVjdCBhdCBYWFg+OwogIHByZXZpb3VzbHksIGl0IHdhcyBzb21ldGltZXMgPEZvbyBpbnN0YW5jZSBhdCBYWFg+LgoKLSBGb3IgbmV3LXN0eWxlIGNsYXNzZXMsIHdoYXQgd2FzIHByZXZpb3VzbHkgY2FsbGVkIF9fZ2V0YXR0cl9fIGlzIG5vdwogIGNhbGxlZCBfX2dldGF0dHJpYnV0ZV9fLiAgVGhpcyBtZXRob2QsIGlmIGRlZmluZWQsIGlzIGNhbGxlZCBmb3IKICAqZXZlcnkqIGF0dHJpYnV0ZSBhY2Nlc3MuICBBIG5ldyBfX2dldGF0dHJfXyBob29rIG1vcmUgc2ltaWxhciB0byB0aGUKICBvbmUgaW4gY2xhc3NpYyBjbGFzc2VzIGlzIGRlZmluZWQgd2hpY2ggaXMgY2FsbGVkIG9ubHkgaWYgcmVndWxhcgogIGF0dHJpYnV0ZSBhY2Nlc3MgcmFpc2VzIEF0dHJpYnV0ZUVycm9yOyB0byBjYXRjaCAqYWxsKiBhdHRyaWJ1dGUKICBhY2Nlc3MsIHlvdSBjYW4gdXNlIF9fZ2V0YXR0cmlidXRlX18gKGZvciBuZXctc3R5bGUgY2xhc3NlcykuICBJZgogIGJvdGggYXJlIGRlZmluZWQsIF9fZ2V0YXR0cmlidXRlX18gaXMgY2FsbGVkIGZpcnN0LCBhbmQgaWYgaXQgcmFpc2VzCiAgQXR0cmlidXRlRXJyb3IsIF9fZ2V0YXR0cl9fIGlzIGNhbGxlZC4KCi0gVGhlIF9fY2xhc3NfXyBhdHRyaWJ1dGUgb2YgbmV3LXN0eWxlIG9iamVjdHMgY2FuIGJlIGFzc2lnbmVkIHRvLgogIFRoZSBuZXcgY2xhc3MgbXVzdCBoYXZlIHRoZSBzYW1lIEMtbGV2ZWwgb2JqZWN0IGxheW91dCBhcyB0aGUgb2xkCiAgY2xhc3MuCgotIFRoZSBidWlsdGluIGZpbGUgdHlwZSBjYW4gYmUgc3ViY2xhc3NlZCBub3cuICBJbiB0aGUgdXN1YWwgcGF0dGVybiwKICAiZmlsZSIgaXMgdGhlIG5hbWUgb2YgdGhlIGJ1aWx0aW4gdHlwZSwgYW5kIGZpbGUoKSBpcyBhIG5ldyBidWlsdGluCiAgY29uc3RydWN0b3IsIHdpdGggdGhlIHNhbWUgc2lnbmF0dXJlIGFzIHRoZSBidWlsdGluIG9wZW4oKSBmdW5jdGlvbi4KICBmaWxlKCkgaXMgbm93IHRoZSBwcmVmZXJyZWQgd2F5IHRvIG9wZW4gYSBmaWxlLgoKLSBQcmV2aW91c2x5LCBfX25ld19fIHdvdWxkIG9ubHkgc2VlIHNlcXVlbnRpYWwgYXJndW1lbnRzIHBhc3NlZCB0bwogIHRoZSB0eXBlIGluIGEgY29uc3RydWN0b3IgY2FsbDsgX19pbml0X18gd291bGQgc2VlIGJvdGggc2VxdWVudGlhbAogIGFuZCBrZXl3b3JkIGFyZ3VtZW50cy4gIFRoaXMgbWFkZSBubyBzZW5zZSB3aGF0c29ldmVyIGFueSBtb3JlLCBzbwogIG5vdyBib3RoIF9fbmV3X18gYW5kIF9faW5pdF9fIHNlZSBhbGwgYXJndW1lbnRzLgoKLSBQcmV2aW91c2x5LCBoYXNoKCkgYXBwbGllZCB0byBhbiBpbnN0YW5jZSBvZiBhIHN1YmNsYXNzIG9mIHN0ciBvcgogIHVuaWNvZGUgYWx3YXlzIHJldHVybmVkIDAuICBUaGlzIGhhcyBiZWVuIHJlcGFpcmVkLgoKLSBQcmV2aW91c2x5LCBhbiBvcGVyYXRpb24gb24gYW4gaW5zdGFuY2Ugb2YgYSBzdWJjbGFzcyBvZiBhbgogIGltbXV0YWJsZSB0eXBlIChpbnQsIGxvbmcsIGZsb2F0LCBjb21wbGV4LCB0dXBsZSwgc3RyLCB1bmljb2RlKSwKICB3aGVyZSB0aGUgc3VidHlwZSBkaWRuJ3Qgb3ZlcnJpZGUgdGhlIG9wZXJhdGlvbiAoYW5kIHNvIHRoZQogIG9wZXJhdGlvbiB3YXMgaGFuZGxlZCBieSB0aGUgYnVpbHRpbiB0eXBlKSwgY291bGQgcmV0dXJuIHRoYXQKICBpbnN0YW5jZSBpbnN0ZWFkIGEgdmFsdWUgb2YgdGhlIGJhc2UgdHlwZS4gIEZvciBleGFtcGxlLCBpZiBzIHdhcyBvZgogIGEgc3RyIHN1YmNsYXNzIHR5cGUsIHNbOl0gcmV0dXJuZWQgcyBhcy1pcy4gIE5vdyBpdCByZXR1cm5zIGEgc3RyCiAgd2l0aCB0aGUgc2FtZSB2YWx1ZSBhcyBzLgoKLSBQcm92aXNpb25hbCBzdXBwb3J0IGZvciBwaWNrbGluZyBuZXctc3R5bGUgb2JqZWN0cyBoYXMgYmVlbiBhZGRlZC4KCkNvcmUKLS0tLQoKLSBmaWxlLndyaXRlbGluZXMoKSBub3cgYWNjZXB0cyBhbnkgaXRlcmFibGUgb2JqZWN0IHByb2R1Y2luZyBzdHJpbmdzLgoKLSBQeVVuaWNvZGVfRnJvbUVuY29kZWRPYmplY3QoKSBub3cgd29ya3MgdmVyeSBtdWNoIGxpa2UKICBQeU9iamVjdF9TdHIob2JqKSBpbiB0aGF0IGl0IHRyaWVzIHRvIHVzZSBfX3N0cl9fL3RwX3N0cgogIG9uIHRoZSBvYmplY3QgaWYgdGhlIG9iamVjdCBpcyBub3QgYSBzdHJpbmcgb3IgYnVmZmVyLiBUaGlzCiAgbWFrZXMgdW5pY29kZSgpIGJlaGF2ZSBsaWtlIHN0cigpIHdoZW4gYXBwbGllZCB0byBub24tc3RyaW5nL2J1ZmZlcgogIG9iamVjdHMuCgotIFB5RmlsZV9Xcml0ZU9iamVjdCBub3cgcGFzc2VzIFVuaWNvZGUgb2JqZWN0cyB0byB0aGUgZmlsZSdzIHdyaXRlCiAgbWV0aG9kLiBBcyBhIHJlc3VsdCwgYWxsIGZpbGUtbGlrZSBvYmplY3RzIHdoaWNoIG1heSBiZSB0aGUgdGFyZ2V0CiAgb2YgYSBwcmludCBzdGF0ZW1lbnQgbXVzdCBzdXBwb3J0IFVuaWNvZGUgb2JqZWN0cywgaS5lLiB0aGV5IG11c3QKICBhdCBsZWFzdCBjb252ZXJ0IHRoZW0gaW50byBBU0NJSSBzdHJpbmdzLgoKLSBUaHJlYWQgc2NoZWR1bGluZyBvbiBTb2xhcmlzIHNob3VsZCBiZSBpbXByb3ZlZDsgaXQgaXMgbm8gbG9uZ2VyCiAgbmVjZXNzYXJ5IHRvIGluc2VydCBhIHNtYWxsIHNsZWVwIGF0IHRoZSBzdGFydCBvZiBhIHRocmVhZCBpbiBvcmRlcgogIHRvIGxldCBvdGhlciBydW5uYWJsZSB0aHJlYWRzIGJlIHNjaGVkdWxlZC4KCkxpYnJhcnkKLS0tLS0tLQoKLSBTdHJpbmdJTy5TdHJpbmdJTyBpbnN0YW5jZXMgYW5kIGNTdHJpbmdJTy5TdHJpbmdJTyBpbnN0YW5jZXMgc3VwcG9ydAogIHJlYWQgY2hhcmFjdGVyIGJ1ZmZlciBjb21wYXRpYmxlIG9iamVjdHMgZm9yIHRoZWlyIC53cml0ZSgpIG1ldGhvZHMuCiAgVGhlc2Ugb2JqZWN0cyBhcmUgY29udmVydGVkIHRvIHN0cmluZ3MgYW5kIHRoZW4gaGFuZGxlZCBhcyBzdWNoCiAgYnkgdGhlIGluc3RhbmNlcy4KCi0gVGhlICJlbWFpbCIgcGFja2FnZSBoYXMgYmVlbiBhZGRlZC4gIFRoaXMgaXMgYmFzaWNhbGx5IGEgcG9ydCBvZiB0aGUKICBtaW1lbGliIHBhY2thZ2UgPGh0dHA6Ly9zZi5uZXQvcHJvamVjdHMvbWltZWxpYj4gd2l0aCBBUEkgY2hhbmdlcwogIGFuZCBzb21lIGltcGxlbWVudGF0aW9ucyB1cGRhdGVkIHRvIHVzZSBpdGVyYXRvcnMgYW5kIGdlbmVyYXRvcnMuCgotIGRpZmZsaWIubmRpZmYoKSBhbmQgZGlmZmxpYi5EaWZmZXIuY29tcGFyZSgpIGFyZSBnZW5lcmF0b3JzIG5vdy4gIFRoaXMKICByZXN0b3JlcyB0aGUgYWJpbGl0eSBvZiBUb29scy9zY3JpcHRzL25kaWZmLnB5IHRvIHN0YXJ0IHByb2R1Y2luZyBvdXRwdXQKICBiZWZvcmUgdGhlIGVudGlyZSBjb21wYXJpc29uIGlzIGNvbXBsZXRlLgoKLSBTdHJpbmdJTy5TdHJpbmdJTyBpbnN0YW5jZXMgYW5kIGNTdHJpbmdJTy5TdHJpbmdJTyBpbnN0YW5jZXMgc3VwcG9ydAogIGl0ZXJhdGlvbiBqdXN0IGxpa2UgZmlsZSBvYmplY3RzIChpLmUuIHRoZWlyIC5yZWFkbGluZSgpIG1ldGhvZCBpcwogIGNhbGxlZCBmb3IgZWFjaCBpdGVyYXRpb24gdW50aWwgaXQgcmV0dXJucyBhbiBlbXB0eSBzdHJpbmcpLgoKLSBUaGUgY29kZWNzIG1vZHVsZSBoYXMgZ3Jvd24gZm91ciBuZXcgaGVscGVyIEFQSXMgdG8gYWNjZXNzCiAgYnVpbHRpbiBjb2RlY3M6IGdldGVuY29kZXIoKSwgZ2V0ZGVjb2RlcigpLCBnZXRyZWFkZXIoKSwKICBnZXR3cml0ZXIoKS4KCi0gU2ltcGxlWE1MUlBDU2VydmVyOiBhIG5ldyBtb2R1bGUgKGJhc2VkIHVwb24gU2ltcGxlSFRNTFNlcnZlcikKICBzaW1wbGlmaWVzIHdyaXRpbmcgWE1MIFJQQyBzZXJ2ZXJzLgoKLSBvcy5wYXRoLnJlYWxwYXRoKCk6IGEgbmV3IGZ1bmN0aW9uIHRoYXQgcmV0dXJucyB0aGUgYWJzb2x1dGUgcGF0aG5hbWUKICBhZnRlciBpbnRlcnByZXRhdGlvbiBvZiBzeW1ib2xpYyBsaW5rcy4gIE9uIG5vbi1Vbml4IHN5c3RlbXMsIHRoaXMKICBpcyBhbiBhbGlhcyBmb3Igb3MucGF0aC5hYnNwYXRoKCkuCgotIG9wZXJhdG9yLmluZGV4T2YoKSAoUHlTZXF1ZW5jZV9JbmRleCgpIGluIHRoZSBDIEFQSSkgbm93IHdvcmtzIHdpdGggYW55CiAgaXRlcmFibGUgb2JqZWN0LgoKLSBzbXRwbGliIG5vdyBzdXBwb3J0cyB2YXJpb3VzIGF1dGhlbnRpY2F0aW9uIGFuZCBzZWN1cml0eSBmZWF0dXJlcyBvZgogIHRoZSBTTVRQIHByb3RvY29sIHRocm91Z2ggdGhlIG5ldyBsb2dpbigpIGFuZCBzdGFydHRscygpIG1ldGhvZHMuCgotIGhtYWM6IGEgbmV3IG1vZHVsZSBpbXBsZW1lbnRpbmcga2V5ZWQgaGFzaGluZyBmb3IgbWVzc2FnZQogIGF1dGhlbnRpY2F0aW9uLgoKLSBtaW1ldHlwZXMgbm93IHJlY29nbml6ZXMgbW9yZSBleHRlbnNpb25zIGFuZCBmaWxlIHR5cGVzLiAgQXQgdGhlCiAgc2FtZSB0aW1lLCBzb21lIG1hcHBpbmdzIG5vdCBzYW5jdGlvbmVkIGJ5IElBTkEgd2VyZSByZW1vdmVkLgoKLSBUaGUgImNvbXBpbGVyIiBwYWNrYWdlIGhhcyBiZWVuIGJyb3VnaHQgdXAgdG8gZGF0ZSB0byB0aGUgc3RhdGUgb2YKICBQeXRob24gMi4yIGJ5dGVjb2RlIGdlbmVyYXRpb24uICBJdCBoYXMgYWxzbyBiZWVuIHByb21vdGVkIGZyb20gYQogIFRvb2wgdG8gYSBzdGFuZGFyZCBsaWJyYXJ5IHBhY2thZ2UuICAoVG9vbHMvY29tcGlsZXIgc3RpbGwgZXhpc3RzIGFzCiAgYSBzYW1wbGUgZHJpdmVyLikKCkJ1aWxkCi0tLS0tCgotIExhcmdlIGZpbGUgc3VwcG9ydCAoTEZTKSBpcyBub3cgYXV0b21hdGljIHdoZW4gdGhlIHBsYXRmb3JtIHN1cHBvcnRzCiAgaXQ7IG5vIG1vcmUgbWFudWFsIGNvbmZpZ3VyYXRpb24gdHdlYWtzIGFyZSBuZWVkZWQuICBPbiBMaW51eCwgYXQKICBsZWFzdCwgaXQncyBwb3NzaWJsZSB0byBoYXZlIGEgc3lzdGVtIHdob3NlIEMgbGlicmFyeSBzdXBwb3J0cyBsYXJnZQogIGZpbGVzIGJ1dCB3aG9zZSBrZXJuZWwgZG9lc24ndDsgaW4gdGhpcyBjYXNlLCBsYXJnZSBmaWxlIHN1cHBvcnQgaXMKICBzdGlsbCBlbmFibGVkIGJ1dCBkb2Vzbid0IGRvIHlvdSBhbnkgZ29vZCB1bmxlc3MgeW91IHVwZ3JhZGUgeW91cgogIGtlcm5lbCBvciBzaGFyZSB5b3VyIFB5dGhvbiBleGVjdXRhYmxlIHdpdGggYW5vdGhlciBzeXN0ZW0gd2hvc2UKICBrZXJuZWwgaGFzIGxhcmdlIGZpbGUgc3VwcG9ydC4KCi0gVGhlIGNvbmZpZ3VyZSBzY3JpcHQgbm93IHN1cHBsaWVzIHBsYXVzaWJsZSBkZWZhdWx0cyBpbiBhCiAgY3Jvc3MtY29tcGlsYXRpb24gZW52aXJvbm1lbnQuICBUaGlzIGRvZXNuJ3QgbWVhbiB0aGF0IHRoZSBzdXBwbGllZAogIHZhbHVlcyBhcmUgYWx3YXlzIGNvcnJlY3QsIG9yIHRoYXQgY3Jvc3MtY29tcGlsYXRpb24gbm93IHdvcmtzCiAgZmxhd2xlc3NseSAtLSBidXQgaXQncyBhIGZpcnN0IHN0ZXAgKGFuZCBpdCBzaHV0cyB1cCBtb3N0IG9mCiAgYXV0b2NvbmYncyB3YXJuaW5ncyBhYm91dCBBQ19UUllfUlVOKS4KCi0gVGhlIFVuaXggYnVpbGQgaXMgbm93IGEgYml0IGxlc3MgY2hhdHR5LCBjb3VydGVzeSBvZiB0aGUgcGFyc2VyCiAgZ2VuZXJhdG9yLiAgVGhlIGJ1aWxkIGlzIGNvbXBsZXRlbHkgc2lsZW50IChleGNlcHQgZm9yIGVycm9ycykgd2hlbgogIHVzaW5nICJtYWtlIC1zIiwgdGhhbmtzIHRvIGEgLXEgb3B0aW9uIHRvIHNldHVwLnB5LgoKQyBBUEkKLS0tLS0KCi0gVGhlICJzdHJ1Y3RtZW1iZXIiIEFQSSBub3cgc3VwcG9ydHMgc29tZSBuZXcgZmxhZyBiaXRzIHRvIGRlbnkgcmVhZAogIGFuZC9vciB3cml0ZSBhY2Nlc3MgdG8gYXR0cmlidXRlcyBpbiByZXN0cmljdGVkIGV4ZWN1dGlvbiBtb2RlLgoKTmV3IHBsYXRmb3JtcwotLS0tLS0tLS0tLS0tCgotIENvbXBhcSdzIGlQQVEgaGFuZGhlbGQsIHJ1bm5pbmcgdGhlICJmYW1pbGlhciIgTGludXggZGlzdHJpYnV0aW9uCiAgKGh0dHA6Ly9mYW1pbGlhci5oYW5kaGVsZHMub3JnKS4KClRlc3RzCi0tLS0tCgotIFRoZSAiY2xhc3NpYyIgc3RhbmRhcmQgdGVzdHMsIHdoaWNoIHdvcmsgYnkgY29tcGFyaW5nIHN0ZG91dCB0bwogIGFuIGV4cGVjdGVkLW91dHB1dCBmaWxlIHVuZGVyIExpYi90ZXN0L291dHB1dC8sIG5vIGxvbmdlciBzdG9wIGF0CiAgdGhlIGZpcnN0IG1pc21hdGNoLiAgSW5zdGVhZCB0aGUgdGVzdCBpcyBydW4gdG8gY29tcGxldGlvbiwgYW5kIGEKICB2YXJpYW50IG9mIG5kaWZmLXN0eWxlIGNvbXBhcmlzb24gaXMgdXNlZCB0byByZXBvcnQgYWxsIGRpZmZlcmVuY2VzLgogIFRoaXMgaXMgbXVjaCBlYXNpZXIgdG8gdW5kZXJzdGFuZCB0aGFuIHRoZSBwcmV2aW91cyBzdHlsZSBvZiByZXBvcnRpbmcuCgotIFRoZSB1bml0dGVzdC1iYXNlZCBzdGFuZGFyZCB0ZXN0cyBub3cgdXNlIHJlZ3J0ZXN0J3MgdGVzdF9tYWluKCkKICBjb252ZW50aW9uLCBpbnN0ZWFkIG9mIHJ1bm5pbmcgYXMgYSBzaWRlLWVmZmVjdCBvZiBtZXJlbHkgYmVpbmcKICBpbXBvcnRlZC4gIFRoaXMgYWxsb3dzIHRoZXNlIHRlc3RzIHRvIGJlIHJ1biBpbiBtb3JlIG5hdHVyYWwgYW5kCiAgZmxleGlibGUgd2F5cyBhcyB1bml0dGVzdHMsIG91dHNpZGUgdGhlIHJlZ3J0ZXN0IGZyYW1ld29yay4KCi0gcmVncnRlc3QucHkgaXMgbXVjaCBiZXR0ZXIgaW50ZWdyYXRlZCB3aXRoIHVuaXR0ZXN0IGFuZCBkb2N0ZXN0IG5vdywKICBlc3BlY2lhbGx5IGluIHJlZ2FyZCB0byByZXBvcnRpbmcgZXJyb3JzLgoKV2luZG93cwotLS0tLS0tCgotIExhcmdlIGZpbGUgc3VwcG9ydCBub3cgYWxzbyB3b3JrcyBmb3IgZmlsZXMgPiA0R0IsIG9uIGZpbGVzeXN0ZW1zCiAgdGhhdCBzdXBwb3J0IGl0IChOVEZTIHVuZGVyIFdpbmRvd3MgMjAwMCkuICBTZWUgIldoYXQncyBOZXcgaW4KICBQeXRob24gMi4yYTMiIGZvciBtb3JlIGRldGFpbC4KCgpXaGF0J3MgTmV3IGluIFB5dGhvbiAyLjJhMz8KPT09PT09PT09PT09PT09PT09PT09PT09PT09CgoqUmVsZWFzZSBEYXRlOiAwNy1TZXAtMjAwMSoKCkNvcmUKLS0tLQoKLSBDb252ZXJzaW9uIG9mIGxvbmcgdG8gZmxvYXQgbm93IHJhaXNlcyBPdmVyZmxvd0Vycm9yIGlmIHRoZSBsb25nIGlzIHRvbwogIGJpZyB0byByZXByZXNlbnQgYXMgYSBDIGRvdWJsZS4KCi0gVGhlIDMtYXJndW1lbnQgYnVpbHRpbiBwb3coKSBubyBsb25nZXIgYWxsb3dzIGEgdGhpcmQgbm9uLU5vbmUgYXJndW1lbnQKICBpZiBlaXRoZXIgb2YgdGhlIGZpcnN0IHR3byBhcmd1bWVudHMgaXMgYSBmbG9hdCwgb3IgaWYgYm90aCBhcmUgb2YKICBpbnRlZ2VyIHR5cGVzIGFuZCB0aGUgc2Vjb25kIGFyZ3VtZW50IGlzIG5lZ2F0aXZlIChpbiB3aGljaCBsYXR0ZXIgY2FzZQogIHRoZSBhcmd1bWVudHMgYXJlIGNvbnZlcnRlZCB0byBmbG9hdCwgc28gdGhpcyBpcyByZWFsbHkgdGhlIHNhbWUKICByZXN0cmljdGlvbikuCgotIFRoZSBidWlsdGluIGRpcigpIG5vdyByZXR1cm5zIG1vcmUgaW5mb3JtYXRpb24sIGFuZCBzb21ldGltZXMgbXVjaAogIG1vcmUsIGdlbmVyYWxseSBuYW1pbmcgYWxsIGF0dHJpYnV0ZXMgb2YgYW4gb2JqZWN0LCBhbmQgYWxsIGF0dHJpYnV0ZXMKICByZWFjaGFibGUgZnJvbSB0aGUgb2JqZWN0IHZpYSBpdHMgY2xhc3MsIGFuZCBmcm9tIGl0cyBjbGFzcydzIGJhc2UKICBjbGFzc2VzLCBhbmQgc28gb24gZnJvbSB0aGVtIHRvby4gIEV4YW1wbGU6ICBpbiAyLjJhMiwgZGlyKFtdKSByZXR1cm5lZAogIGFuIGVtcHR5IGxpc3QuICBJbiAyLjJhMywKCiAgPj4+IGRpcihbXSkKICBbJ19fYWRkX18nLCAnX19jbGFzc19fJywgJ19fY29udGFpbnNfXycsICdfX2RlbGF0dHJfXycsICdfX2RlbGl0ZW1fXycsCiAgICdfX2VxX18nLCAnX19nZV9fJywgJ19fZ2V0YXR0cl9fJywgJ19fZ2V0aXRlbV9fJywgJ19fZ2V0c2xpY2VfXycsCiAgICdfX2d0X18nLCAnX19oYXNoX18nLCAnX19pYWRkX18nLCAnX19pbXVsX18nLCAnX19pbml0X18nLCAnX19sZV9fJywKICAgJ19fbGVuX18nLCAnX19sdF9fJywgJ19fbXVsX18nLCAnX19uZV9fJywgJ19fbmV3X18nLCAnX19yZXByX18nLAogICAnX19ybXVsX18nLCAnX19zZXRhdHRyX18nLCAnX19zZXRpdGVtX18nLCAnX19zZXRzbGljZV9fJywgJ19fc3RyX18nLAogICAnYXBwZW5kJywgJ2NvdW50JywgJ2V4dGVuZCcsICdpbmRleCcsICdpbnNlcnQnLCAncG9wJywgJ3JlbW92ZScsCiAgICdyZXZlcnNlJywgJ3NvcnQnXQoKICBkaXIobW9kdWxlKSBjb250aW51ZXMgdG8gcmV0dXJuIG9ubHkgdGhlIG1vZHVsZSdzIGF0dHJpYnV0ZXMsIHRob3VnaC4KCi0gT3ZlcmZsb3dpbmcgb3BlcmF0aW9ucyBvbiBwbGFpbiBpbnRzIG5vdyByZXR1cm4gYSBsb25nIGludCByYXRoZXIKICB0aGFuIHJhaXNpbmcgT3ZlcmZsb3dFcnJvci4gIFRoaXMgaXMgYSBwYXJ0aWFsIGltcGxlbWVudGF0aW9uIG9mIFBFUAogIDIzNy4gIFlvdSBjYW4gdXNlIC1XZGVmYXVsdDo6T3ZlcmZsb3dXYXJuaW5nIHRvIGVuYWJsZSBhIHdhcm5pbmcgZm9yCiAgdGhpcyBzaXR1YXRpb24sIGFuZCAtV2Vycm9yOjpPdmVyZmxvd1dhcm5pbmcgdG8gcmV2ZXJ0IHRvIHRoZSBvbGQKICBPdmVyZmxvd0Vycm9yIGV4Y2VwdGlvbi4KCi0gQSBuZXcgY29tbWFuZCBsaW5lIG9wdGlvbiwgLVE8YXJnPiwgaXMgYWRkZWQgdG8gY29udHJvbCBydW4tdGltZQogIHdhcm5pbmdzIGZvciB0aGUgdXNlIG9mIGNsYXNzaWMgZGl2aXNpb24uICAoU2VlIFBFUCAyMzguKSAgUG9zc2libGUKICB2YWx1ZXMgYXJlIC1Rb2xkLCAtUXdhcm4sIC1Rd2FybmFsbCwgYW5kIC1RbmV3LiAgVGhlIGRlZmF1bHQgaXMKICAtUW9sZCwgbWVhbmluZyB0aGUgLyBvcGVyYXRvciBoYXMgaXRzIGNsYXNzaWMgbWVhbmluZyBhbmQgbm8KICB3YXJuaW5ncyBhcmUgaXNzdWVkLiAgVXNpbmcgLVF3YXJuIGlzc3VlcyBhIHJ1bi10aW1lIHdhcm5pbmcgYWJvdXQKICBhbGwgdXNlcyBvZiBjbGFzc2ljIGRpdmlzaW9uIGZvciBpbnQgYW5kIGxvbmcgYXJndW1lbnRzOyAtUXdhcm5hbGwKICBhbHNvIHdhcm5zIGFib3V0IGNsYXNzaWMgZGl2aXNpb24gZm9yIGZsb2F0IGFuZCBjb21wbGV4IGFyZ3VtZW50cwogIChmb3IgdXNlIHdpdGggZml4ZGl2LnB5KS4KICBbTm90ZTogIHRoZSByZW1haW5kZXIgb2YgdGhpcyBpdGVtIChwcmVzZXJ2ZWQgYmVsb3cpIGJlY2FtZQogIG9ic29sZXRlIGluIDIuMmMxIC0tIC1RbmV3IGhhcyBnbG9iYWwgZWZmZWN0IGluIDIuMl0gOjoKCiAgICBVc2luZyAtUW5ldyBpcyBxdWVzdGlvbmFibGU7IGl0IHR1cm5zIG9uIG5ldyBkaXZpc2lvbiBieSBkZWZhdWx0LCBidXQKICAgIG9ubHkgaW4gdGhlIF9fbWFpbl9fIG1vZHVsZS4gIFlvdSBjYW4gdXNlZnVsbHkgY29tYmluZSAtUXdhcm4gb3IKICAgIC1Rd2FybmFsbCBhbmQgLVFuZXc6IHRoaXMgZ2l2ZXMgdGhlIF9fbWFpbl9fIG1vZHVsZSBuZXcgZGl2aXNpb24sIGFuZAogICAgd2FybnMgYWJvdXQgY2xhc3NpYyBkaXZpc2lvbiBldmVyeXdoZXJlIGVsc2UuCgotIE1hbnkgYnVpbHQtaW4gdHlwZXMgY2FuIG5vdyBiZSBzdWJjbGFzc2VkLiAgVGhpcyBhcHBsaWVzIHRvIGludCwKICBsb25nLCBmbG9hdCwgc3RyLCB1bmljb2RlLCBhbmQgdHVwbGUuICAoVGhlIHR5cGVzIGNvbXBsZXgsIGxpc3QgYW5kCiAgZGljdGlvbmFyeSBjYW4gYWxzbyBiZSBzdWJjbGFzc2VkOyB0aGlzIHdhcyBpbnRyb2R1Y2VkIGVhcmxpZXIuKQogIE5vdGUgdGhhdCByZXN0cmljdGlvbnMgYXBwbHkgd2hlbiBzdWJjbGFzc2luZyBpbW11dGFibGUgYnVpbHQtaW4KICB0eXBlczogeW91IGNhbiBvbmx5IGFmZmVjdCB0aGUgdmFsdWUgb2YgdGhlIGluc3RhbmNlIGJ5IG92ZXJsb2FkaW5nCiAgX19uZXdfXy4gIFlvdSBjYW4gYWRkIG11dGFibGUgYXR0cmlidXRlcywgYW5kIHRoZSBzdWJjbGFzcyBpbnN0YW5jZXMKICB3aWxsIGhhdmUgYSBfX2RpY3RfXyBhdHRyaWJ1dGUsIGJ1dCB5b3UgY2Fubm90IGNoYW5nZSB0aGUgInZhbHVlIgogIChhcyBpbXBsZW1lbnRlZCBieSB0aGUgYmFzZSBjbGFzcykgb2YgYW4gaW1tdXRhYmxlIHN1YmNsYXNzIGluc3RhbmNlCiAgb25jZSBpdCBpcyBjcmVhdGVkLgoKLSBUaGUgZGljdGlvbmFyeSBjb25zdHJ1Y3RvciBub3cgdGFrZXMgYW4gb3B0aW9uYWwgYXJndW1lbnQsIGEKICBtYXBwaW5nLWxpa2Ugb2JqZWN0LCBhbmQgaW5pdGlhbGl6ZXMgdGhlIGRpY3Rpb25hcnkgZnJvbSBpdHMKICAoa2V5LCB2YWx1ZSkgcGFpcnMuCgotIEEgbmV3IGJ1aWx0LWluIHR5cGUsIHN1cGVyLCBoYXMgYmVlbiBhZGRlZC4gIFRoaXMgZmFjaWxpdGF0ZXMgbWFraW5nCiAgImNvb3BlcmF0aXZlIHN1cGVyIGNhbGxzIiBpbiBhIG11bHRpcGxlIGluaGVyaXRhbmNlIHNldHRpbmcuICBGb3IgYW4KICBleHBsYW5hdGlvbiwgc2VlIGh0dHA6Ly93d3cucHl0aG9uLm9yZy8yLjIvZGVzY3JpbnRyby5odG1sI2Nvb3BlcmF0aW9uCgotIEEgbmV3IGJ1aWx0LWluIHR5cGUsIHByb3BlcnR5LCBoYXMgYmVlbiBhZGRlZC4gIFRoaXMgZW5hYmxlcyB0aGUKICBjcmVhdGlvbiBvZiAicHJvcGVydGllcyIuICBUaGVzZSBhcmUgYXR0cmlidXRlcyBpbXBsZW1lbnRlZCBieQogIGdldHRlciBhbmQgc2V0dGVyIGZ1bmN0aW9ucyAob3Igb25seSBvbmUgb2YgdGhlc2UgZm9yIHJlYWQtb25seSBvcgogIHdyaXRlLW9ubHkgYXR0cmlidXRlcyksIHdpdGhvdXQgdGhlIG5lZWQgdG8gb3ZlcnJpZGUgX19nZXRhdHRyX18uCiAgU2VlIGh0dHA6Ly93d3cucHl0aG9uLm9yZy8yLjIvZGVzY3JpbnRyby5odG1sI3Byb3BlcnR5CgotIFRoZSBzeW50YXggb2YgZmxvYXRpbmctcG9pbnQgYW5kIGltYWdpbmFyeSBsaXRlcmFscyBoYXMgYmVlbgogIGxpYmVyYWxpemVkLCB0byBhbGxvdyBsZWFkaW5nIHplcm9lcy4gIEV4YW1wbGVzIG9mIGxpdGVyYWxzIG5vdwogIGxlZ2FsIHRoYXQgd2VyZSBTeW50YXhFcnJvcnMgYmVmb3JlOgoKICAgICAgMDAuMCAgICAwZTMgICAwMTAwaiAgIDA3LjUgICAwMDAwMDAwMDAwMDAwMDAwMDAwOC4KCi0gQW4gb2xkIHRva2VuaXplciBidWcgYWxsb3dlZCBmbG9hdGluZyBwb2ludCBsaXRlcmFscyB3aXRoIGFuIGluY29tcGxldGUKICBleHBvbmVudCwgc3VjaCBhcyAxZSBhbmQgMy4xZS0uICBTdWNoIGxpdGVyYWxzIG5vdyByYWlzZSBTeW50YXhFcnJvci4KCkxpYnJhcnkKLS0tLS0tLQoKLSB0ZWxuZXRsaWIgaW5jbHVkZXMgc3ltYm9saWMgbmFtZXMgZm9yIHRoZSBvcHRpb25zLCBhbmQgc3VwcG9ydCBmb3IKICBzZXR0aW5nIGFuIG9wdGlvbiBuZWdvdGlhdGlvbiBjYWxsYmFjay4gSXQgYWxzbyBzdXBwb3J0cyBwcm9jZXNzaW5nCiAgb2Ygc3Vib3B0aW9ucy4KCi0gVGhlIG5ldyBDIHN0YW5kYXJkIG5vIGxvbmdlciByZXF1aXJlcyB0aGF0IG1hdGggbGlicmFyaWVzIHNldCBlcnJubyB0bwogIEVSQU5HRSBvbiBvdmVyZmxvdy4gIEZvciBwbGF0Zm9ybSBsaWJyYXJpZXMgdGhhdCBleHBsb2l0IHRoaXMgbmV3CiAgZnJlZWRvbSwgUHl0aG9uJ3Mgb3ZlcmZsb3ctY2hlY2tpbmcgd2FzIHdob2xseSBicm9rZW4uICBBIG5ldyBvdmVyZmxvdy0KICBjaGVja2luZyBzY2hlbWUgYXR0ZW1wdHMgdG8gcmVwYWlyIHRoYXQsIGJ1dCBtYXkgbm90IGJlIHJlbGlhYmxlIG9uIGFsbAogIHBsYXRmb3JtcyAoQyBkb2Vzbid0IHNlZW0gdG8gcHJvdmlkZSBhbnl0aGluZyBib3RoIHVzZWZ1bCBhbmQgcG9ydGFibGUKICBpbiB0aGlzIGFyZWEgYW55bW9yZSkuCgotIEFzeW5jaHJvbm91cyB0aW1lb3V0IGFjdGlvbnMgYXJlIGF2YWlsYWJsZSB0aHJvdWdoIHRoZSBuZXcgY2xhc3MKICB0aHJlYWRpbmcuVGltZXIuCgotIG1hdGgubG9nIGFuZCBtYXRoLmxvZzEwIG5vdyByZXR1cm4gc2Vuc2libGUgcmVzdWx0cyBmb3IgZXZlbiBodWdlCiAgbG9uZyBhcmd1bWVudHMuICBGb3IgZXhhbXBsZSwgbWF0aC5sb2cxMCgxMCAqKiAxMDAwMCkgfj0gMTAwMDAuMC4KCi0gQSBuZXcgZnVuY3Rpb24sIGltcC5sb2NrX2hlbGQoKSwgcmV0dXJucyAxIHdoZW4gdGhlIGltcG9ydCBsb2NrIGlzCiAgY3VycmVudGx5IGhlbGQuICBTZWUgdGhlIGRvY3MgZm9yIHRoZSBpbXAgbW9kdWxlLgoKLSBwaWNrbGUsIGNQaWNrbGUgYW5kIG1hcnNoYWwgb24gMzItYml0IHBsYXRmb3JtcyBjYW4gbm93IGNvcnJlY3RseSByZWFkCiAgZHVtcHMgY29udGFpbmluZyBpbnRzIHdyaXR0ZW4gb24gcGxhdGZvcm1zIHdoZXJlIFB5dGhvbiBpbnRzIGFyZSA4IGJ5dGVzLgogIFdoZW4gcmVhZCBvbiBhIGJveCB3aGVyZSBQeXRob24gaW50cyBhcmUgNCBieXRlcywgc3VjaCB2YWx1ZXMgYXJlCiAgY29udmVydGVkIHRvIFB5dGhvbiBsb25ncy4KCi0gSW4gcmVzdHJpY3RlZCBleGVjdXRpb24gbW9kZSAodXNpbmcgdGhlIHJleGVjIG1vZHVsZSksIHVubWFyc2hhbGxpbmcKICBjb2RlIG9iamVjdHMgaXMgbm8gbG9uZ2VyIGFsbG93ZWQuICBUaGlzIHBsdWdzIGEgc2VjdXJpdHkgaG9sZS4KCi0gdW5pdHRlc3QuVGVzdFJlc3VsdCBpbnN0YW5jZXMgbm8gbG9uZ2VyIHN0b3JlIHJlZmVyZW5jZXMgdG8gdHJhY2ViYWNrcwogIGdlbmVyYXRlZCBieSB0ZXN0IGZhaWx1cmVzLiBUaGlzIHByZXZlbnRzIHVuZXhwZWN0ZWQgZGFuZ2xpbmcgcmVmZXJlbmNlcwogIHRvIG9iamVjdHMgdGhhdCBzaG91bGQgYmUgZ2FyYmFnZSBjb2xsZWN0ZWQgYmV0d2VlbiB0ZXN0cy4KClRvb2xzCi0tLS0tCgotIFRvb2xzL3NjcmlwdHMvZml4ZGl2LnB5IGhhcyBiZWVuIGFkZGVkIHdoaWNoIGNhbiBiZSB1c2VkIHRvIGZpeAogIGRpdmlzaW9uIG9wZXJhdG9ycyBhcyBwZXIgUEVQIDIzOC4KCkJ1aWxkCi0tLS0tCgotIElmIHlvdSBhcmUgYW4gYWR2ZW50dXJvdXMgcGVyc29uIHVzaW5nIE1hYyBPUyBYIHlvdSBtYXkgd2FudCB0byBsb29rIGF0CiAgTWFjL09TWC4gVGhlcmUgaXMgYSBNYWtlZmlsZSB0aGVyZSB0aGF0IHdpbGwgYnVpbGQgUHl0aG9uIGFzIGEgcmVhbCBNYWMKICBhcHBsaWNhdGlvbiwgd2hpY2ggY2FuIGJlIHVzZWQgZm9yIGV4cGVyaW1lbnRpbmcgd2l0aCBDYXJib24gb3IgQ29jb2EuCiAgRGlzY3Vzc2lvbiBvZiB0aGlzIG9uIHB5dGhvbm1hYy1zaWcsIHBsZWFzZS4KCkMgQVBJCi0tLS0tCgotIE5ldyBmdW5jdGlvbiBQeU9iamVjdF9EaXIob2JqKSwgbGlrZSBQeXRob24gX19idWlsdGluX18uZGlyKG9iaikuCgotIE5vdGUgdGhhdCBQeUxvbmdfQXNEb3VibGUgY2FuIGZhaWwhICBUaGlzIGhhcyBhbHdheXMgYmVlbiB0cnVlLCBidXQgbm8KICBjYWxsZXJzIGNoZWNrZWQgZm9yIGl0LiAgSXQncyBtb3JlIGxpa2VseSB0byBmYWlsIG5vdywgYmVjYXVzZSBvdmVyZmxvdwogIGVycm9ycyBhcmUgcHJvcGVybHkgZGV0ZWN0ZWQgbm93LiAgVGhlIHByb3BlciB3YXkgdG8gY2hlY2s6OgoKICAgICAgZG91YmxlIHggPSBQeUxvbmdfQXNEb3VibGUoc29tZV9sb25nX29iamVjdCk7CiAgICAgIGlmICh4ID09IC0xLjAgJiYgUHlFcnJfT2NjdXJyZWQoKSkgewogICAgICAgICAgICAgIC8qIFRoZSBjb252ZXJzaW9uIGZhaWxlZC4gKi8KICAgICAgfQoKLSBUaGUgR0MgQVBJIGhhcyBiZWVuIGNoYW5nZWQuICBFeHRlbnNpb25zIHRoYXQgdXNlIHRoZSBvbGQgQVBJIHdpbGwgc3RpbGwKICBjb21waWxlIGJ1dCB3aWxsIG5vdCBwYXJ0aWNpcGF0ZSBpbiBHQy4gIFRvIHVwZ3JhZGUgYW4gZXh0ZW5zaW9uCiAgbW9kdWxlOgoKICAgIC0gcmVuYW1lIFB5X1RQRkxBR1NfR0MgdG8gUHlUUEZMQUdTX0hBVkVfR0MKCiAgICAtIHVzZSBQeU9iamVjdF9HQ19OZXcgb3IgUHlPYmplY3RfR0NfTmV3VmFyIHRvIGFsbG9jYXRlIG9iamVjdHMgYW5kCiAgICAgIFB5T2JqZWN0X0dDX0RlbCB0byBkZWFsbG9jYXRlIHRoZW0KCiAgICAtIHJlbmFtZSBQeU9iamVjdF9HQ19Jbml0IHRvIFB5T2JqZWN0X0dDX1RyYWNrIGFuZCBQeU9iamVjdF9HQ19GaW5pCiAgICAgIHRvIFB5T2JqZWN0X0dDX1VuVHJhY2sKCiAgICAtIHJlbW92ZSBQeUdDX0hFQURfU0laRSBmcm9tIG9iamVjdCBzaXplIGNhbGN1bGF0aW9ucwoKICAgIC0gcmVtb3ZlIGNhbGxzIHRvIFB5T2JqZWN0X0FTX0dDIGFuZCBQeU9iamVjdF9GUk9NX0dDCgotIFR3byBuZXcgZnVuY3Rpb25zOiBQeVN0cmluZ19Gcm9tRm9ybWF0KCkgYW5kIFB5U3RyaW5nX0Zyb21Gb3JtYXRWKCkuCiAgVGhlc2UgY2FuIGJlIHVzZWQgc2FmZWx5IHRvIGNvbnN0cnVjdCBzdHJpbmcgb2JqZWN0cyBmcm9tIGEKICBzcHJpbnRmLXN0eWxlIGZvcm1hdCBzdHJpbmcgKHNpbWlsYXIgdG8gdGhlIGZvcm1hdCBzdHJpbmcgc3VwcG9ydGVkCiAgYnkgUHlFcnJfRm9ybWF0KCkpLgoKTmV3IHBsYXRmb3JtcwotLS0tLS0tLS0tLS0tCgotIFN0ZXBoZW4gSGFuc2VuIGNvbnRyaWJ1dGVkIHBhdGNoZXMgc3VmZmljaWVudCB0byBnZXQgYSBjbGVhbiBjb21waWxlCiAgdW5kZXIgQm9ybGFuZCBDIChXaW5kb3dzKSwgYnV0IGhlIHJlcG9ydHMgcHJvYmxlbXMgcnVubmluZyBpdCBhbmQgcmFuCiAgb3V0IG9mIHRpbWUgdG8gY29tcGxldGUgdGhlIHBvcnQuICBWb2x1bnRlZXJzPyAgRXhwZWN0IGEgTWVtb3J5RXJyb3IKICB3aGVuIGltcG9ydGluZyB0aGUgdHlwZXMgbW9kdWxlOyB0aGlzIGlzIHByb2JhYmx5IHNoYWxsb3csIGFuZAogIGNhdXNpbmcgbGF0ZXIgZmFpbHVyZXMgdG9vLgoKVGVzdHMKLS0tLS0KCldpbmRvd3MKLS0tLS0tLQoKLSBMYXJnZSBmaWxlIHN1cHBvcnQgaXMgbm93IGVuYWJsZWQgb24gV2luMzIgcGxhdGZvcm1zIGFzIHdlbGwgYXMgb24KICBXaW42NC4gIFRoaXMgbWVhbnMgdGhhdCwgZm9yIGV4YW1wbGUsIHlvdSBjYW4gdXNlIGYudGVsbCgpIGFuZCBmLnNlZWsoKQogIHRvIG1hbmlwdWxhdGUgZmlsZXMgbGFyZ2VyIHRoYW4gMiBnaWdhYnl0ZXMgKHByb3ZpZGVkIHlvdSBoYXZlIGVub3VnaAogIGRpc2sgc3BhY2UsIGFuZCBhcmUgdXNpbmcgYSBXaW5kb3dzIGZpbGVzeXN0ZW0gdGhhdCBzdXBwb3J0cyBsYXJnZQogIHBhcnRpdGlvbnMpLiAgV2luZG93cyBmaWxlc3lzdGVtIGxpbWl0czogIEZBVCBoYXMgYSAyR0IgKGdpZ2FieXRlKQogIGZpbGVzaXplIGxpbWl0LCBhbmQgbGFyZ2UgZmlsZSBzdXBwb3J0IG1ha2VzIG5vIGRpZmZlcmVuY2UgdGhlcmUuCiAgRkFUMzIncyBsaW1pdCBpcyA0R0IsIGFuZCBmaWxlcyA+PSAyR0IgYXJlIGVhc2llciB0byB1c2UgZnJvbSBQeXRob24gbm93LgogIE5URlMgaGFzIG5vIHByYWN0aWNhbCBsaW1pdCBvbiBmaWxlIHNpemUsIGFuZCBmaWxlcyBvZiBhbnkgc2l6ZSBjYW4gYmUKICB1c2VkIGZyb20gUHl0aG9uIG5vdy4KCi0gVGhlIHc5eHBvcGVuIGhhY2sgaXMgbm93IHVzZWQgb24gV2luZG93cyBOVCBhbmQgMjAwMCB0b28gd2hlbiBDT01QU1BFQwogIHBvaW50cyB0byBjb21tYW5kLmNvbSAocGF0Y2ggZnJvbSBCcmlhbiBRdWlubGFuKS4KCgpXaGF0J3MgTmV3IGluIFB5dGhvbiAyLjJhMj8KPT09PT09PT09PT09PT09PT09PT09PT09PT09CgoqUmVsZWFzZSBEYXRlOiAyMi1BdWctMjAwMSoKCkJ1aWxkCi0tLS0tCgotIFRpbSBQZXRlcnMgZGV2ZWxvcGVkIGEgYnJhbmQgbmV3IFdpbmRvd3MgaW5zdGFsbGVyIHVzaW5nIFdpc2UgOC4xLAogIGdlbmVyb3VzbHkgZG9uYXRlZCB0byB1cyBieSBXaXNlIFNvbHV0aW9ucy4KCi0gY29uZmlndXJlIHN1cHBvcnRzIGEgbmV3IG9wdGlvbiAtLWVuYWJsZS11bmljb2RlLCB3aXRoIHRoZSB2YWx1ZXMKICB1Y3MyIGFuZCB1Y3M0IChuZXcgaW4gMi4yYTEpLiBXaXRoIC0tZGlzYWJsZS11bmljb2RlLCB0aGUgVW5pY29kZQogIHR5cGUgYW5kIHN1cHBvcnRpbmcgY29kZSBpcyBjb21wbGV0ZWx5IHJlbW92ZWQgZnJvbSB0aGUgaW50ZXJwcmV0ZXIuCgotIEEgbmV3IGNvbmZpZ3VyZSBvcHRpb24gLS1lbmFibGUtZnJhbWV3b3JrIGJ1aWxkcyBhIE1hYyBPUyBYIGZyYW1ld29yaywKICB3aGljaCAibWFrZSBmcmFtZXdvcmtpbnN0YWxsIiB3aWxsIGluc3RhbGwuIFRoaXMgcHJvdmlkZXMgYSBzdGFydGluZwogIHBvaW50IGZvciBtb3JlIG1hYy1saWtlIGZ1bmN0aW9uYWxpdHksIGpvaW4gcHl0aG9ubWFjLXNpZ0BweXRob24ub3JnCiAgaWYgeW91IGFyZSBpbnRlcmVzdGVkIGluIGhlbHBpbmcuCgotIFRoZSBOZVhUIHBsYXRmb3JtIGlzIG5vIGxvbmdlciBzdXBwb3J0ZWQuCgotIFRoZSAnbmV3JyBtb2R1bGUgaXMgbm93IHN0YXRpY2FsbHkgbGlua2VkLgoKVG9vbHMKLS0tLS0KCi0gVGhlIG5ldyBUb29scy9zY3JpcHRzL2NsZWFuZnV0dXJlLnB5IGNhbiBiZSB1c2VkIHRvIGF1dG9tYXRpY2FsbHkKICBlZGl0IG91dCBvYnNvbGV0ZSBmdXR1cmUgc3RhdGVtZW50cyBmcm9tIFB5dGhvbiBzb3VyY2UgY29kZS4gIFNlZQogIHRoZSBtb2R1bGUgZG9jc3RyaW5nIGZvciBkZXRhaWxzLgoKVGVzdHMKLS0tLS0KCi0gcmVncnRlc3QucHkgbm93IGtub3dzIHdoaWNoIHRlc3RzIGFyZSBleHBlY3RlZCB0byBiZSBza2lwcGVkIG9uIHNvbWUKICBwbGF0Zm9ybXMsIGFsbG93aW5nIHRvIGdpdmUgY2xlYXJlciB0ZXN0IHJlc3VsdCBvdXRwdXQuICByZWdydGVzdAogIGFsc28gaGFzIG9wdGlvbmFsIC0tdXNlLy11IHN3aXRjaCB0byBydW4gbm9ybWFsbHkgZGlzYWJsZWQgdGVzdHMKICB3aGljaCByZXF1aXJlIG5ldHdvcmsgYWNjZXNzIG9yIGNvbnN1bWUgc2lnbmlmaWNhbnQgZGlzayByZXNvdXJjZXMuCgotIFNldmVyYWwgbmV3IHRlc3RzIGluIHRoZSBzdGFuZGFyZCB0ZXN0IHN1aXRlLCB3aXRoIHNwZWNpYWwgdGhhbmtzIHRvCiAgTmljayBNYXRoZXdzb24uCgpDb3JlCi0tLS0KCi0gVGhlIGZsb29yIGRpdmlzaW9uIG9wZXJhdG9yIC8vIGhhcyBiZWVuIGFkZGVkIGFzIG91dGxpbmVkIGluIFBFUAogIDIzOC4gIFRoZSAvIG9wZXJhdG9yIHN0aWxsIHByb3ZpZGVzIGNsYXNzaWMgZGl2aXNpb24gKGFuZCB3aWxsIHVudGlsCiAgUHl0aG9uIDMuMCkgdW5sZXNzICJmcm9tIF9fZnV0dXJlX18gaW1wb3J0IGRpdmlzaW9uIiBpcyBpbmNsdWRlZCwgaW4KICB3aGljaCBjYXNlIHRoZSAvIG9wZXJhdG9yIHdpbGwgcHJvdmlkZSB0cnVlIGRpdmlzaW9uLiAgVGhlIG9wZXJhdG9yCiAgbW9kdWxlIHByb3ZpZGVzIHRydWVkaXYoKSBhbmQgZmxvb3JkaXYoKSBmdW5jdGlvbnMuICBBdWdtZW50ZWQKICBhc3NpZ25tZW50IHZhcmlhbnRzIGFyZSBpbmNsdWRlZCwgYXMgYXJlIHRoZSBlcXVpdmFsZW50IG92ZXJsb2FkYWJsZQogIG1ldGhvZHMgYW5kIEMgQVBJIG1ldGhvZHMuICBTZWUgdGhlIFBFUCBmb3IgYSBmdWxsIGRpc2N1c3Npb246CiAgPGh0dHA6Ly9weXRob24uc2YubmV0L3BlcHMvcGVwLTAyMzguaHRtbD4KCi0gRnV0dXJlIHN0YXRlbWVudHMgYXJlIG5vdyBlZmZlY3RpdmUgaW4gc2ltdWxhdGVkIGludGVyYWN0aXZlIHNoZWxscwogIChsaWtlIElETEUpLiAgVGhpcyBzaG91bGQgImp1c3Qgd29yayIgYnkgbWFnaWMsIGJ1dCByZWFkIE1pY2hhZWwKICBIdWRzb24ncyAiRnV0dXJlIHN0YXRlbWVudHMgaW4gc2ltdWxhdGVkIHNoZWxscyIgUEVQIDI2NCBmb3IgZnVsbAogIGRldGFpbHM6ICA8aHR0cDovL3B5dGhvbi5zZi5uZXQvcGVwcy9wZXAtMDI2NC5odG1sPi4KCi0gVGhlIHR5cGUvY2xhc3MgdW5pZmljYXRpb24gKFBFUCAyNTItMjUzKSB3YXMgaW50ZWdyYXRlZCBpbnRvIHRoZQogIHRydW5rIGFuZCBpcyBub3Qgc28gdGVudGF0aXZlIGFueSBtb3JlICh0aGUgZXhhY3Qgc3BlY2lmaWNhdGlvbiBvZgogIHNvbWUgZmVhdHVyZXMgaXMgc3RpbGwgdGVudGF0aXZlKS4gIEEgbG90IG9mIHdvcmsgaGFzIGRvbmUgb24gZml4aW5nCiAgYnVncyBhbmQgYWRkaW5nIHJvYnVzdG5lc3MgYW5kIGZlYXR1cmVzIChwZXJmb3JtYW5jZSBzdGlsbCBoYXMgdG8KICBjb21lIGEgbG9uZyB3YXkpLgoKLSBXYXJuaW5ncyBhYm91dCBhIG1pc21hdGNoIGluIHRoZSBQeXRob24gQVBJIGR1cmluZyBleHRlbnNpb24gaW1wb3J0CiAgbm93IHVzZSB0aGUgUHl0aG9uIHdhcm5pbmcgZnJhbWV3b3JrICh3aGljaCBtYWtlcyBpdCBwb3NzaWJsZSB0bwogIHdyaXRlIGZpbHRlcnMgZm9yIHRoZXNlIHdhcm5pbmdzKS4KCi0gQSBmdW5jdGlvbidzIF9fZGljdF9fIChha2EgZnVuY19kaWN0KSB3aWxsIG5vdyBhbHdheXMgYmUgYQogIGRpY3Rpb25hcnkuICBJdCB1c2VkIHRvIGJlIHBvc3NpYmxlIHRvIGRlbGV0ZSBpdCBvciBzZXQgaXQgdG8gTm9uZSwKICBidXQgbm93IGJvdGggYWN0aW9ucyByYWlzZSBUeXBlRXJyb3JzLiAgSXQgaXMgc3RpbGwgbGVnYWwgdG8gc2V0IGl0CiAgdG8gYSBkaWN0aW9uYXJ5IG9iamVjdC4gIEdldHRpbmcgZnVuYy5fX2RpY3RfXyBiZWZvcmUgYW55IGF0dHJpYnV0ZXMKICBoYXZlIGJlZW4gYXNzaWduZWQgbm93IHJldHVybnMgYW4gZW1wdHkgZGljdGlvbmFyeSBpbnN0ZWFkIG9mIE5vbmUuCgotIEEgbmV3IGNvbW1hbmQgbGluZSBvcHRpb24sIC1FLCB3YXMgYWRkZWQgd2hpY2ggZGlzYWJsZXMgdGhlIHVzZSBvZgogIGFsbCBlbnZpcm9ubWVudCB2YXJpYWJsZXMsIG9yIGF0IGxlYXN0IHRob3NlIHRoYXQgYXJlIHNwZWNpZmljYWxseQogIHNpZ25pZmljYW50IHRvIFB5dGhvbi4gIFVzdWFsbHkgdGhvc2UgaGF2ZSBhIG5hbWUgc3RhcnRpbmcgd2l0aAogICJQWVRIT04iLiAgVGhpcyB3YXMgdXNlZCB0byBmaXggYSBwcm9ibGVtIHdoZXJlIHRoZSB0ZXN0cyBmYWlsIGlmCiAgdGhlIHVzZXIgaGFwcGVucyB0byBoYXZlIFBZVEhPTkhPTUUgb3IgUFlUSE9OUEFUSCBwb2ludGluZyB0byBhbgogIG9sZGVyIGRpc3RyaWJ1dGlvbi4KCkxpYnJhcnkKLS0tLS0tLQoKLSBOZXcgY2xhc3MgRGlmZmVyIGFuZCBuZXcgZnVuY3Rpb25zIG5kaWZmKCkgYW5kIHJlc3RvcmUoKSBpbiBkaWZmbGliLnB5LgogIFRoZXNlIHBhY2thZ2UgdGhlIGFsZ29yaXRobXMgdXNlZCBieSB0aGUgcG9wdWxhciBUb29scy9zY3JpcHRzL25kaWZmLnB5LAogIGZvciBwcm9ncmFtbWF0aWMgcmV1c2UuCgotIE5ldyBmdW5jdGlvbiB4bWwuc2F4LnNheHV0aWxzLnF1b3RlYXR0cigpOiAgUXVvdGUgYW4gWE1MIGF0dHJpYnV0ZQogIHZhbHVlIHVzaW5nIHRoZSBtaW5pbWFsIHF1b3RpbmcgcmVxdWlyZWQgZm9yIHRoZSB2YWx1ZTsgbW9yZQogIHJlbGlhYmxlIHRoYW4gdXNpbmcgeG1sLnNheC5zYXh1dGlscy5lc2NhcGUoKSBmb3IgYXR0cmlidXRlIHZhbHVlcy4KCi0gUmVhZGxpbmUgY29tcGxldGlvbiBzdXBwb3J0IGZvciBjbWQuQ21kIHdhcyBhZGRlZC4KCi0gQ2FsbGluZyBvcy50ZW1wbmFtKCkgb3Igb3MudG1wbmFtKCkgZ2VuZXJhdGUgUnVudGltZVdhcm5pbmdzLgoKLSBBZGRlZCBmdW5jdGlvbiB0aHJlYWRpbmcuQm91bmRlZFNlbWFwaG9yZSgpCgotIEFkZGVkIEthLVBpbmcgWWVlJ3MgY2dpdGIucHkgbW9kdWxlLgoKLSBUaGUgJ25ldycgbW9kdWxlIG5vdyBleHBvc2VzIHRoZSBDT194eHggZmxhZ3MuCgotIFRoZSBnYyBtb2R1bGUgb2ZmZXJzIHRoZSBnZXRfcmVmZXJlbnRzIGZ1bmN0aW9uLgoKTmV3IHBsYXRmb3JtcwotLS0tLS0tLS0tLS0tCgpDIEFQSQotLS0tLQoKLSBUd28gbmV3IEFQSXMgUHlPU19zbnByaW50ZigpIGFuZCBQeU9TX3ZzbnByaW50ZigpIHdlcmUgYWRkZWQKICB3aGljaCBwcm92aWRlIGEgY3Jvc3MtcGxhdGZvcm0gaW1wbGVtZW50YXRpb25zIGZvciB0aGUKICByZWxhdGl2ZWx5IG5ldyBzbnByaW50ZigpL3ZzbnByaW50ZigpIEMgbGliIEFQSXMuIEluIGNvbnRyYXN0IHRvCiAgdGhlIHN0YW5kYXJkIHNwcmludGYoKSBhbmQgdnNwcmludGYoKSBDIGxpYiBBUElzLCB0aGVzZSB2ZXJzaW9ucwogIGFwcGx5IGJvdW5kcyBjaGVja2luZyBvbiB0aGUgdXNlZCBidWZmZXIgd2hpY2ggZW5oYW5jZXMgcHJvdGVjdGlvbgogIGFnYWluc3QgYnVmZmVyIG92ZXJydW5zLgoKLSBVbmljb2RlIEFQSXMgbm93IHVzZSBuYW1lIG1hbmdsaW5nIHRvIGFzc3VyZSB0aGF0IG1peGluZyBpbnRlcnByZXRlcnMKICBhbmQgZXh0ZW5zaW9ucyB1c2luZyBkaWZmZXJlbnQgVW5pY29kZSB3aWR0aHMgaXMgcmVuZGVyZWQgbmV4dCB0bwogIGltcG9zc2libGUuIFRyeWluZyB0byBpbXBvcnQgYW4gaW5jb21wYXRpYmxlIFVuaWNvZGUtYXdhcmUgZXh0ZW5zaW9uCiAgd2lsbCByZXN1bHQgaW4gYW4gSW1wb3J0RXJyb3IuICBVbmljb2RlIGV4dGVuc2lvbnMgd3JpdGVycyBtdXN0IG1ha2UKICBzdXJlIHRvIGNoZWNrIHRoZSBVbmljb2RlIHdpZHRoIGNvbXBhdGliaWxpdHkgaW4gdGhlaXIgZXh0ZW5zaW9ucyBieQogIHVzaW5nIGF0IGxlYXN0IG9uZSBvZiB0aGUgbWFuZ2xlZCBVbmljb2RlIEFQSXMgaW4gdGhlIGV4dGVuc2lvbi4KCi0gVHdvIG5ldyBmbGFncyBNRVRIX05PQVJHUyBhbmQgTUVUSF9PIGFyZSBhdmFpbGFibGUgaW4gbWV0aG9kIGRlZmluaXRpb24KICB0YWJsZXMgdG8gc2ltcGxpZnkgaW1wbGVtZW50YXRpb24gb2YgbWV0aG9kcyB3aXRoIG5vIGFyZ3VtZW50cyBhbmQgYQogIHNpbmdsZSB1bnR5cGVkIGFyZ3VtZW50LiBDYWxsaW5nIHN1Y2ggbWV0aG9kcyBpcyBtb3JlIGVmZmljaWVudCB0aGFuCiAgY2FsbGluZyBjb3JyZXNwb25kaW5nIE1FVEhfVkFSQVJHUyBtZXRob2RzLiBNRVRIX09MREFSR1MgaXMgbm93CiAgZGVwcmVjYXRlZC4KCldpbmRvd3MKLS0tLS0tLQoKLSAiaW1wb3J0IG1vZHVsZSIgbm93IGNvbXBpbGVzIG1vZHVsZS5weXcgaWYgaXQgZXhpc3RzIGFuZCBub3RoaW5nIGVsc2UKICByZWxldmFudCBpcyBmb3VuZC4KCgpXaGF0J3MgTmV3IGluIFB5dGhvbiAyLjJhMT8KPT09PT09PT09PT09PT09PT09PT09PT09PT09CgoqUmVsZWFzZSBkYXRlOiAxOC1KdWwtMjAwMSoKCkNvcmUKLS0tLQoKLSBURU5UQVRJVkVMWSwgYSBsYXJnZSBhbW91bnQgb2YgY29kZSBpbXBsZW1lbnRpbmcgbXVjaCBvZiB3aGF0J3MKICBkZXNjcmliZWQgaW4gUEVQIDI1MiAoTWFraW5nIFR5cGVzIExvb2sgTW9yZSBMaWtlIENsYXNzZXMpIGFuZCBQRVAKICAyNTMgKFN1YnR5cGluZyBCdWlsdC1pbiBUeXBlcykgd2FzIGFkZGVkLiAgVGhpcyB3aWxsIGJlIHJlbGVhc2VkCiAgd2l0aCBQeXRob24gMi4yYTEuICBEb2N1bWVudGF0aW9uIHdpbGwgYmUgcHJvdmlkZWQgc2VwYXJhdGVseQogIHRocm91Z2ggaHR0cDovL3d3dy5weXRob24ub3JnLzIuMi8uICBUaGUgcHVycG9zZSBvZiByZWxlYXNpbmcgdGhpcwogIHdpdGggUHl0aG9uIDIuMmExIGlzIHRvIHRlc3QgYmFja3dhcmRzIGNvbXBhdGliaWxpdHkuICBJdCBpcwogIHBvc3NpYmxlLCB0aG91Z2ggbm90IGxpa2VseSwgdGhhdCBhIGRlY2lzaW9uIGlzIG1hZGUgbm90IHRvIHJlbGVhc2UKICB0aGlzIGNvZGUgYXMgcGFydCBvZiAyLjIgZmluYWwsIGlmIGFueSBzZXJpb3VzIGJhY2t3YXJkcwogIGluY29tcGF0aWJpbGl0aWVzIGFyZSBmb3VuZCBkdXJpbmcgYWxwaGEgdGVzdGluZyB0aGF0IGNhbm5vdCBiZQogIHJlcGFpcmVkLgoKLSBHZW5lcmF0b3JzIHdlcmUgYWRkZWQ7IHRoaXMgaXMgYSBuZXcgd2F5IHRvIGNyZWF0ZSBhbiBpdGVyYXRvciAoc2VlCiAgYmVsb3cpIHVzaW5nIHdoYXQgbG9va3MgbGlrZSBhIHNpbXBsZSBmdW5jdGlvbiBjb250YWluaW5nIG9uZSBvcgogIG1vcmUgJ3lpZWxkJyBzdGF0ZW1lbnRzLiAgU2VlIFBFUCAyNTUuICBTaW5jZSB0aGlzIGFkZHMgYSBuZXcKICBrZXl3b3JkIHRvIHRoZSBsYW5ndWFnZSwgdGhpcyBmZWF0dXJlIG11c3QgYmUgZW5hYmxlZCBieSBpbmNsdWRpbmcgYQogIGZ1dHVyZSBzdGF0ZW1lbnQ6ICJmcm9tIF9fZnV0dXJlX18gaW1wb3J0IGdlbmVyYXRvcnMiIChzZWUgUEVQIDIzNikuCiAgR2VuZXJhdG9ycyB3aWxsIGJlY29tZSBhIHN0YW5kYXJkIGZlYXR1cmUgaW4gYSBmdXR1cmUgcmVsZWFzZQogIChwcm9iYWJseSAyLjMpLiAgV2l0aG91dCB0aGlzIGZ1dHVyZSBzdGF0ZW1lbnQsICd5aWVsZCcgcmVtYWlucyBhbgogIG9yZGluYXJ5IGlkZW50aWZpZXIsIGJ1dCBhIHdhcm5pbmcgaXMgaXNzdWVkIGVhY2ggdGltZSBpdCBpcyB1c2VkLgogIChUaGVzZSB3YXJuaW5ncyBjdXJyZW50bHkgZG9uJ3QgY29uZm9ybSB0byB0aGUgd2FybmluZ3MgZnJhbWV3b3JrIG9mCiAgUEVQIDIzMDsgd2UgaW50ZW5kIHRvIGZpeCB0aGlzIGluIDIuMmEyLikKCi0gVGhlIFVURi0xNiBjb2RlYyB3YXMgbW9kaWZpZWQgdG8gYmUgbW9yZSBSRkMgY29tcGxpYW50LiBJdCB3aWxsIG5vdwogIG9ubHkgcmVtb3ZlIEJPTSBjaGFyYWN0ZXJzIGF0IHRoZSBzdGFydCBvZiB0aGUgc3RyaW5nIGFuZCB0aGVuCiAgb25seSBpZiBydW5uaW5nIGluIG5hdGl2ZSBtb2RlIChVVEYtMTYtTEUgYW5kIC1CRSB3b24ndCByZW1vdmUgYQogIGxlYWRpbmcgQk1PIGNoYXJhY3RlcikuCgotIFN0cmluZ3Mgbm93IGhhdmUgYSBuZXcgbWV0aG9kIC5kZWNvZGUoKSB0byBjb21wbGVtZW50IHRoZSBhbHJlYWR5CiAgZXhpc3RpbmcgLmVuY29kZSgpIG1ldGhvZC4gVGhlc2UgdHdvIG1ldGhvZHMgcHJvdmlkZSBkaXJlY3QgYWNjZXNzCiAgdG8gdGhlIGNvcnJlc3BvbmRpbmcgZGVjb2RlcnMgYW5kIGVuY29kZXJzIG9mIHRoZSByZWdpc3RlcmVkIGNvZGVjcy4KCiAgVG8gZW5oYW5jZSB0aGUgdXNhYmlsaXR5IG9mIHRoZSAuZW5jb2RlKCkgbWV0aG9kLCB0aGUgc3BlY2lhbAogIGNhc2luZyBvZiBVbmljb2RlIG9iamVjdCByZXR1cm4gdmFsdWVzIHdhcyBkcm9wcGVkIChVbmljb2RlIG9iamVjdHMKICB3ZXJlIGF1dG8tbWFnaWNhbGx5IGNvbnZlcnRlZCB0byBzdHJpbmcgdXNpbmcgdGhlIGRlZmF1bHQgZW5jb2RpbmcpLgoKICBCb3RoIG1ldGhvZHMgd2lsbCBub3cgcmV0dXJuIHdoYXRldmVyIHRoZSBjb2RlYyBpbiBjaGFyZ2Ugb2YgdGhlCiAgcmVxdWVzdGVkIGVuY29kaW5nIHJldHVybnMgYXMgb2JqZWN0LCBlLmcuIFVuaWNvZGUgY29kZWNzIHdpbGwKICByZXR1cm4gVW5pY29kZSBvYmplY3RzIHdoZW4gZGVjb2RpbmcgaXMgcmVxdWVzdGVkICgi5Pb8Ii5kZWNvZGUoImxhdGluLTEiKQogIHdpbGwgcmV0dXJuIHUi5Pb8IikuIFRoaXMgZW5hYmxlcyBjb2RlYyB3cml0ZXIgdG8gY3JlYXRlIGNvZGVjcwogIGZvciB2YXJpb3VzIHNpbXBsZSB0byB1c2UgY29udmVyc2lvbnMuCgogIE5ldyBjb2RlY3Mgd2VyZSBhZGRlZCB0byBkZW1vbnN0cmF0ZSB0aGVzZSBuZXcgZmVhdHVyZXMgKHRoZSAuZW5jb2RlKCkKICBhbmQgLmRlY29kZSgpIGNvbHVtbnMgaW5kaWNhdGUgdGhlIHR5cGUgb2YgdGhlIHJldHVybmVkIG9iamVjdHMpOgoKICArLS0tLS0tLS0tKy0tLS0tLS0tLS0tKy0tLS0tLS0tLS0tKy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKwogIHxOYW1lICAgICB8IC5lbmNvZGUoKSB8IC5kZWNvZGUoKSB8IERlc2NyaXB0aW9uICAgICAgICAgICAgICAgICB8CiAgKz09PT09PT09PSs9PT09PT09PT09PSs9PT09PT09PT09PSs9PT09PT09PT09PT09PT09PT09PT09PT09PT09PSsKICB8dXUgICAgICAgfCBzdHJpbmcgICAgfCBzdHJpbmcgICAgfCBVVSBjb2RlYyAoZS5nLiBmb3IgZW1haWwpICAgfAogICstLS0tLS0tLS0rLS0tLS0tLS0tLS0rLS0tLS0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rCiAgfGJhc2U2NCAgIHwgc3RyaW5nICAgIHwgc3RyaW5nICAgIHwgYmFzZTY0IGNvZGVjICAgICAgICAgICAgICAgIHwKICArLS0tLS0tLS0tKy0tLS0tLS0tLS0tKy0tLS0tLS0tLS0tKy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKwogIHxxdW9wcmkgICB8IHN0cmluZyAgICB8IHN0cmluZyAgICB8IHF1b3RlZC1wcmludGFibGUgY29kZWMgICAgICB8CiAgKy0tLS0tLS0tLSstLS0tLS0tLS0tLSstLS0tLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKICB8emxpYiAgICAgfCBzdHJpbmcgICAgfCBzdHJpbmcgICAgfCB6bGliIGNvbXByZXNzaW9uICAgICAgICAgICAgfAogICstLS0tLS0tLS0rLS0tLS0tLS0tLS0rLS0tLS0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rCiAgfGhleCAgICAgIHwgc3RyaW5nICAgIHwgc3RyaW5nICAgIHwgMi1ieXRlIGhleCBjb2RlYyAgICAgICAgICAgIHwKICArLS0tLS0tLS0tKy0tLS0tLS0tLS0tKy0tLS0tLS0tLS0tKy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKwogIHxyb3QtMTMgICB8IHN0cmluZyAgICB8IFVuaWNvZGUgICB8IFJPVC0xMyBVbmljb2RlIGNoYXJtYXAgY29kZWN8CiAgKy0tLS0tLS0tLSstLS0tLS0tLS0tLSstLS0tLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKCi0gU29tZSBvcGVyYXRpbmcgc3lzdGVtcyBub3cgc3VwcG9ydCB0aGUgY29uY2VwdCBvZiBhIGRlZmF1bHQgVW5pY29kZQogIGVuY29kaW5nIGZvciBmaWxlIHN5c3RlbSBvcGVyYXRpb25zLiAgTm90YWJseSwgV2luZG93cyBzdXBwb3J0cyAnbWJjcycKICBhcyB0aGUgZGVmYXVsdC4gIFRoZSBNYWNpbnRvc2ggd2lsbCBhbHNvIGFkb3B0IHRoaXMgY29uY2VwdCBpbiB0aGUgbWVkaXVtCiAgdGVybSwgYWx0aG91Z2ggdGhlIGRlZmF1bHQgZW5jb2RpbmcgZm9yIHRoYXQgcGxhdGZvcm0gd2lsbCBiZSBvdGhlciB0aGFuCiAgJ21iY3MnLgoKICBPbiBvcGVyYXRpbmcgc3lzdGVtIHRoYXQgc3VwcG9ydCBub24tQVNDSUkgZmlsZW5hbWVzLCBpdCBpcyBjb21tb24gZm9yCiAgZnVuY3Rpb25zIHRoYXQgcmV0dXJuIGZpbGVuYW1lcyAoc3VjaCBhcyBvcy5saXN0ZGlyKCkpIHRvIHJldHVybiBQeXRob24KICBzdHJpbmcgb2JqZWN0cyBwcmUtZW5jb2RlZCB1c2luZyB0aGUgZGVmYXVsdCBmaWxlIHN5c3RlbSBlbmNvZGluZyBmb3IKICB0aGUgcGxhdGZvcm0uICBBcyB0aGlzIGVuY29kaW5nIGlzIGxpa2VseSB0byBiZSBkaWZmZXJlbnQgZnJvbSBQeXRob24ncwogIGRlZmF1bHQgZW5jb2RpbmcsIGNvbnZlcnRpbmcgdGhpcyBuYW1lIHRvIGEgVW5pY29kZSBvYmplY3QgYmVmb3JlIHBhc3NpbmcKICBpdCBiYWNrIHRvIHRoZSBPcGVyYXRpbmcgU3lzdGVtIHdvdWxkIHJlc3VsdCBpbiBhIFVuaWNvZGUgZXJyb3IsIGFzIFB5dGhvbgogIHdvdWxkIGF0dGVtcHQgdG8gdXNlIGl0cyBkZWZhdWx0IGVuY29kaW5nIChnZW5lcmFsbHkgQVNDSUkpIHJhdGhlciB0aGFuCiAgdGhlIGRlZmF1bHQgZW5jb2RpbmcgZm9yIHRoZSBmaWxlIHN5c3RlbS4KCiAgSW4gZ2VuZXJhbCwgdGhpcyBjaGFuZ2Ugc2ltcGx5IHJlbW92ZXMgc3VycHJpc2VzIHdoZW4gd29ya2luZyB3aXRoCiAgVW5pY29kZSBhbmQgdGhlIGZpbGUgc3lzdGVtLCBtYWtpbmcgdGhlc2Ugb3BlcmF0aW9ucyB3b3JrIGFzIHlvdSBleHBlY3QsCiAgaW5jcmVhc2luZyB0aGUgdHJhbnNwYXJlbmN5IG9mIFVuaWNvZGUgb2JqZWN0cyBpbiB0aGlzIGNvbnRleHQuCiAgU2VlIFs/Pz8/XSBmb3IgbW9yZSBkZXRhaWxzLCBpbmNsdWRpbmcgZXhhbXBsZXMuCgotIEZsb2F0IChhbmQgY29tcGxleCkgbGl0ZXJhbHMgaW4gc291cmNlIGNvZGUgd2VyZSBldmFsdWF0ZWQgdG8gZnVsbAogIHByZWNpc2lvbiBvbmx5IHdoZW4gcnVubmluZyBmcm9tIGEgLnB5IGZpbGU7IHRoZSBzYW1lIGNvZGUgbG9hZGVkIGZyb20gYQogIC5weWMgKG9yIC5weW8pIGZpbGUgY291bGQgc3VmZmVyIG51bWVyaWMgZGlmZmVyZW5jZXMgc3RhcnRpbmcgYXQgYWJvdXQgdGhlCiAgMTJ0aCBzaWduaWZpY2FudCBkZWNpbWFsIGRpZ2l0LiAgRm9yIGV4YW1wbGUsIG9uIGEgbWFjaGluZSB3aXRoIElFRUUtNzU0CiAgZmxvYXRpbmcgYXJpdGhtZXRpYywKCiAgICAgIHggPSA5MDA3MTk5MjU0NzQwOTkyLjAKICAgICAgcHJpbnQgbG9uZyh4KQoKICBwcmludGVkIDkwMDcxOTkyNTQ3NDA5OTIgaWYgcnVuIGRpcmVjdGx5IGZyb20gLnB5LCBidXQgOTAwNzE5OTI1NDc0MDAwMAogIGlmIGZyb20gYSBjb21waWxlZCAoLnB5YyBvciAucHlvKSBmaWxlLiAgVGhpcyB3YXMgZHVlIHRvIG1hcnNoYWwgdXNpbmcKICBzdHIoZmxvYXQpIGluc3RlYWQgb2YgcmVwcihmbG9hdCkgd2hlbiBidWlsZGluZyBjb2RlIG9iamVjdHMuICBtYXJzaGFsCiAgbm93IHVzZXMgcmVwcihmbG9hdCkgaW5zdGVhZCwgd2hpY2ggc2hvdWxkIHJlcHJvZHVjZSBmbG9hdHMgdG8gZnVsbAogIG1hY2hpbmUgcHJlY2lzaW9uIChhc3N1bWluZyB0aGUgcGxhdGZvcm0gQyBmbG9hdDwtPnN0cmluZyBJL08gY29udmVyc2lvbgogIGZ1bmN0aW9ucyBhcmUgb2YgZ29vZCBxdWFsaXR5KS4KCiAgVGhpcyBtYXkgY2F1c2UgZmxvYXRpbmctcG9pbnQgcmVzdWx0cyB0byBjaGFuZ2UgaW4gc29tZSBjYXNlcywgYW5kCiAgdXN1YWxseSBmb3IgdGhlIGJldHRlciwgYnV0IG1heSBhbHNvIGNhdXNlIG51bWVyaWNhbGx5IHVuc3RhYmxlCiAgYWxnb3JpdGhtcyB0byBicmVhay4KCi0gVGhlIGltcGxlbWVudGF0aW9uIG9mIGRpY3RzIHN1ZmZlcnMgZmV3ZXIgY29sbGlzaW9ucywgd2hpY2ggaGFzIHNwZWVkCiAgYmVuZWZpdHMuICBIb3dldmVyLCB0aGUgb3JkZXIgaW4gd2hpY2ggZGljdCBlbnRyaWVzIGFwcGVhciBpbiBkaWN0LmtleXMoKSwKICBkaWN0LnZhbHVlcygpIGFuZCBkaWN0Lml0ZW1zKCkgbWF5IGRpZmZlciBmcm9tIHByZXZpb3VzIHJlbGVhc2VzIGZvciBhCiAgZ2l2ZW4gZGljdC4gIE5vdGhpbmcgaXMgZGVmaW5lZCBhYm91dCB0aGlzIG9yZGVyLCBzbyBubyBwcm9ncmFtIHNob3VsZAogIHJlbHkgb24gaXQuICBOZXZlcnRoZWxlc3MsIGl0J3MgZWFzeSB0byB3cml0ZSB0ZXN0IGNhc2VzIHRoYXQgcmVseSBvbiB0aGUKICBvcmRlciBieSBhY2NpZGVudCwgdHlwaWNhbGx5IGJlY2F1c2Ugb2YgcHJpbnRpbmcgdGhlIHN0cigpIG9yIHJlcHIoKSBvZiBhCiAgZGljdCB0byBhbiAiZXhwZWN0ZWQgcmVzdWx0cyIgZmlsZS4gIFNlZSBMaWIvdGVzdC90ZXN0X3N1cHBvcnQucHkncyBuZXcKICBzb3J0ZGljdChkaWN0KSBmdW5jdGlvbiBmb3IgYSBzaW1wbGUgd2F5IHRvIGRpc3BsYXkgYSBkaWN0IGluIHNvcnRlZAogIG9yZGVyLgoKLSBNYW55IG90aGVyIHNtYWxsIGNoYW5nZXMgdG8gZGljdHMgd2VyZSBtYWRlLCByZXN1bHRpbmcgaW4gZmFzdGVyCiAgb3BlcmF0aW9uIGFsb25nIHRoZSBtb3N0IGNvbW1vbiBjb2RlIHBhdGhzLgoKLSBEaWN0aW9uYXJ5IG9iamVjdHMgbm93IHN1cHBvcnQgdGhlICJpbiIgb3BlcmF0b3I6ICJ4IGluIGRpY3QiIG1lYW5zCiAgdGhlIHNhbWUgYXMgZGljdC5oYXNfa2V5KHgpLgoKLSBUaGUgdXBkYXRlKCkgbWV0aG9kIG9mIGRpY3Rpb25hcmllcyBub3cgYWNjZXB0cyBnZW5lcmljIG1hcHBpbmcKICBvYmplY3RzLiAgU3BlY2lmaWNhbGx5IHRoZSBhcmd1bWVudCBvYmplY3QgbXVzdCBzdXBwb3J0IHRoZSAua2V5cygpCiAgYW5kIF9fZ2V0aXRlbV9fKCkgbWV0aG9kcy4gIFRoaXMgYWxsb3dzIHlvdSB0byBzYXksIGZvciBleGFtcGxlLAogIHt9LnVwZGF0ZShVc2VyRGljdCgpKQoKLSBJdGVyYXRvcnMgd2VyZSBhZGRlZDsgdGhpcyBpcyBhIGdlbmVyYWxpemVkIHdheSBvZiBwcm92aWRpbmcgdmFsdWVzCiAgdG8gYSBmb3IgbG9vcC4gIFNlZSBQRVAgMjM0LiAgVGhlcmUncyBhIG5ldyBidWlsdC1pbiBmdW5jdGlvbiBpdGVyKCkKICB0byByZXR1cm4gYW4gaXRlcmF0b3IuICBUaGVyZSdzIGEgbmV3IHByb3RvY29sIHRvIGdldCB0aGUgbmV4dCB2YWx1ZQogIGZyb20gYW4gaXRlcmF0b3IgdXNpbmcgdGhlIG5leHQoKSBtZXRob2QgKGluIFB5dGhvbikgb3IgdGhlCiAgdHBfaXRlcm5leHQgc2xvdCAoaW4gQykuICBUaGVyZSdzIGEgbmV3IHByb3RvY29sIHRvIGdldCBpdGVyYXRvcnMKICB1c2luZyB0aGUgX19pdGVyX18oKSBtZXRob2QgKGluIFB5dGhvbikgb3IgdGhlIHRwX2l0ZXIgc2xvdCAoaW4gQykuCiAgSXRlcmF0aW5nIChpLmUuIGEgZm9yIGxvb3ApIG92ZXIgYSBkaWN0aW9uYXJ5IGdlbmVyYXRlcyBpdHMga2V5cy4KICBJdGVyYXRpbmcgb3ZlciBhIGZpbGUgZ2VuZXJhdGVzIGl0cyBsaW5lcy4KCi0gVGhlIGZvbGxvd2luZyBmdW5jdGlvbnMgd2VyZSBnZW5lcmFsaXplZCB0byB3b3JrIG5pY2VseSB3aXRoIGl0ZXJhdG9yCiAgYXJndW1lbnRzOjoKCiAgICBtYXAoKSwgZmlsdGVyKCksIHJlZHVjZSgpLCB6aXAoKQogICAgbGlzdCgpLCB0dXBsZSgpIChQeVNlcXVlbmNlX1R1cGxlKCkgYW5kIFB5U2VxdWVuY2VfRmFzdCgpIGluIEMgQVBJKQogICAgbWF4KCksIG1pbigpCiAgICBqb2luKCkgbWV0aG9kIG9mIHN0cmluZ3MKICAgIGV4dGVuZCgpIG1ldGhvZCBvZiBsaXN0cwogICAgJ3ggaW4geScgYW5kICd4IG5vdCBpbiB5JyAoUHlTZXF1ZW5jZV9Db250YWlucygpIGluIEMgQVBJKQogICAgb3BlcmF0b3IuY291bnRPZigpIChQeVNlcXVlbmNlX0NvdW50KCkgaW4gQyBBUEkpCiAgICByaWdodC1oYW5kIHNpZGUgb2YgYXNzaWdubWVudCBzdGF0ZW1lbnRzIHdpdGggbXVsdGlwbGUgdGFyZ2V0cywgc3VjaCBhcyA6OgogICAgICAgIHgsIHksIHogPSBzb21lX2l0ZXJhYmxlX29iamVjdF9yZXR1cm5pbmdfZXhhY3RseV8zX3ZhbHVlcwoKLSBBY2Nlc3NpbmcgbW9kdWxlIGF0dHJpYnV0ZXMgaXMgc2lnbmlmaWNhbnRseSBmYXN0ZXIgKGZvciBleGFtcGxlLAogIHJhbmRvbS5yYW5kb20gb3Igb3MucGF0aCBvciB5b3VyUHl0aG9uTW9kdWxlLnlvdXJBdHRyaWJ1dGUpLgoKLSBDb21wYXJpbmcgZGljdGlvbmFyeSBvYmplY3RzIHZpYSA9PSBhbmQgIT0gaXMgZmFzdGVyLCBhbmQgbm93IHdvcmtzIGV2ZW4KICBpZiB0aGUga2V5cyBhbmQgdmFsdWVzIGRvbid0IHN1cHBvcnQgY29tcGFyaXNvbnMgb3RoZXIgdGhhbiA9PS4KCi0gQ29tcGFyaW5nIGRpY3Rpb25hcmllcyBpbiB3YXlzIG90aGVyIHRoYW4gPT0gYW5kICE9IGlzIHNsb3dlcjogIHRoZXJlIHdlcmUKICBpbnNlY3VyaXRpZXMgaW4gdGhlIGRpY3QgY29tcGFyaXNvbiBpbXBsZW1lbnRhdGlvbiB0aGF0IGNvdWxkIGNhdXNlIFB5dGhvbgogIHRvIGNyYXNoIGlmIHRoZSBlbGVtZW50IGNvbXBhcmlzb24gcm91dGluZXMgZm9yIHRoZSBkaWN0IGtleXMgYW5kL29yCiAgdmFsdWVzIG11dGF0ZWQgdGhlIGRpY3RzLiAgTWFraW5nIHRoZSBjb2RlIGJ1bGxldHByb29mIHNsb3dlZCBpdCBkb3duLgoKLSBDb2xsaXNpb25zIGluIGRpY3RzIGFyZSByZXNvbHZlZCB2aWEgYSBuZXcgYXBwcm9hY2gsIHdoaWNoIGNhbiBoZWxwCiAgZHJhbWF0aWNhbGx5IGluIGJhZCBjYXNlcy4gIEZvciBleGFtcGxlLCBsb29raW5nIHVwIGV2ZXJ5IGtleSBpbiBhIGRpY3QKICBkIHdpdGggZC5rZXlzKCkgPT0gW2kgPDwgMTYgZm9yIGkgaW4gcmFuZ2UoMjAwMDApXSBpcyBhcHByb3hpbWF0ZWx5IDUwMHgKICBmYXN0ZXIgbm93LiAgVGhhbmtzIHRvIENocmlzdGlhbiBUaXNtZXIgZm9yIHBvaW50aW5nIG91dCB0aGUgY2F1c2UgYW5kCiAgdGhlIG5hdHVyZSBvZiBhbiBlZmZlY3RpdmUgY3VyZSAobGFzdCBEZWNlbWJlciEgYmV0dGVyIGxhdGUgdGhhbiBuZXZlcikuCgotIHJlcHIoKSBpcyBtdWNoIGZhc3RlciBmb3IgbGFyZ2UgY29udGFpbmVycyAoZGljdCwgbGlzdCwgdHVwbGUpLgoKCkxpYnJhcnkKLS0tLS0tLQoKLSBUaGUgY29uc3RhbnRzIGFzY2lpX2xldHRlcnMsIGFzY2lpX2xvd2VyY2FzZS4gYW5kIGFzY2lpX3VwcGVyY2FzZQogIHdlcmUgYWRkZWQgdG8gdGhlIHN0cmluZyBtb2R1bGUuICBUaGVzZSBhIGxvY2FsZS1pbmRlcGVuZGVudAogIGNvbnN0YW50cywgdW5saWtlIGxldHRlcnMsIGxvd2VyY2FzZSwgYW5kIHVwcGVyY2FzZS4gIFRoZXNlIGFyZSBub3cKICB1c2UgaW4gYXBwcm9wcmlhdGUgbG9jYXRpb25zIGluIHRoZSBzdGFuZGFyZCBsaWJyYXJ5LgoKLSBUaGUgZmxhZ3MgdXNlZCBpbiBkbG9wZW4gY2FsbHMgY2FuIG5vdyBiZSBjb25maWd1cmVkIHVzaW5nCiAgc3lzLnNldGRsb3BlbmZsYWdzIGFuZCBxdWVyaWVkIHVzaW5nIHN5cy5nZXRkbG9wZW5mbGFncy4KCi0gRnJlZHJpayBMdW5kaCdzIHhtbHJwY2xpYiBpcyBub3cgYSBzdGFuZGFyZCBsaWJyYXJ5IG1vZHVsZS4gIFRoaXMKICBwcm92aWRlcyBmdWxsIGNsaWVudC1zaWRlIFhNTC1SUEMgc3VwcG9ydC4gIEluIGFkZGl0aW9uLAogIERlbW8veG1scnBjLyBjb250YWlucyB0d28gc2VydmVyIGZyYW1ld29ya3MgKG9uZSBTb2NrZXRTZXJ2ZXItYmFzZWQsCiAgb25lIGFzeW5jb3JlLWJhc2VkKS4gIFRoYW5rcyB0byBFcmljIFJheW1vbmQgZm9yIHRoZSBkb2N1bWVudGF0aW9uLgoKLSBUaGUgeHJhbmdlKCkgb2JqZWN0IGlzIHNpbXBsaWZpZWQ6IGl0IG5vIGxvbmdlciBzdXBwb3J0cyBzbGljaW5nLAogIHJlcGV0aXRpb24sIGNvbXBhcmlzb25zLCBlZmZpY2llbnQgJ2luJyBjaGVja2luZywgdGhlIHRvbGlzdCgpCiAgbWV0aG9kLCBvciB0aGUgc3RhcnQsIHN0b3AgYW5kIHN0ZXAgYXR0cmlidXRlcy4gIFNlZSBQRVAgMjYwLgoKLSBBIG5ldyBmdW5jdGlvbiBmbm1hdGNoLmZpbHRlciB0byBmaWx0ZXIgbGlzdHMgb2YgZmlsZSBuYW1lcyB3YXMgYWRkZWQuCgotIGNhbGVuZGFyLnB5IHVzZXMgbW9udGggYW5kIGRheSBuYW1lcyBiYXNlZCBvbiB0aGUgY3VycmVudCBsb2NhbGUuCgotIHN0cm9wIGlzIG5vdyAqcmVhbGx5KiBvYnNvbGV0ZSAodGhpcyB3YXMgYW5ub3VuY2VkIGJlZm9yZSB3aXRoIDEuNiksCiAgYW5kIGlzc3VlcyBEZXByZWNhdGlvbldhcm5pbmcgd2hlbiB1c2VkIChleGNlcHQgZm9yIHRoZSBmb3VyIGl0ZW1zCiAgdGhhdCBhcmUgc3RpbGwgaW1wb3J0ZWQgaW50byBzdHJpbmcucHkpLgoKLSBDb29raWUucHkgbm93IHNvcnRzIGtleSt2YWx1ZSBwYWlycyBieSBrZXkgaW4gb3V0cHV0IHN0cmluZ3MuCgotIHBwcmludC5pc3JlY3Vyc2l2ZShvYmplY3QpIGRpZG4ndCBjb3JyZWN0bHkgaWRlbnRpZnkgcmVjdXJzaXZlIG9iamVjdHMuCiAgTm93IGl0IGRvZXMuCgotIHBwcmludCBmdW5jdGlvbnMgbm93IG11Y2ggZmFzdGVyIGZvciBsYXJnZSBjb250YWluZXJzICh0dXBsZSwgbGlzdCwgZGljdCkuCgotIE5ldyAncScgYW5kICdRJyBmb3JtYXQgY29kZXMgaW4gdGhlIHN0cnVjdCBtb2R1bGUsIGNvcnJlc3BvbmRpbmcgdG8gQwogIHR5cGVzICJsb25nIGxvbmciIGFuZCAidW5zaWduZWQgbG9uZyBsb25nIiAob24gV2luZG93cywgX19pbnQ2NCkuICBJbgogIG5hdGl2ZSBtb2RlLCB0aGVzZSBjYW4gYmUgdXNlZCBvbmx5IHdoZW4gdGhlIHBsYXRmb3JtIEMgY29tcGlsZXIgc3VwcG9ydHMKICB0aGVzZSB0eXBlcyAod2hlbiBIQVZFX0xPTkdfTE9ORyBpcyAjZGVmaW5lJ2QgYnkgdGhlIFB5dGhvbiBjb25maWcKICBwcm9jZXNzKSwgYW5kIHRoZW4gdGhleSBpbmhlcml0IHRoZSBzaXplcyBhbmQgYWxpZ25tZW50cyBvZiB0aGUgQyB0eXBlcy4KICBJbiBzdGFuZGFyZCBtb2RlLCAncScgYW5kICdRJyBhcmUgc3VwcG9ydGVkIG9uIGFsbCBwbGF0Zm9ybXMsIGFuZCBhcmUKICA4LWJ5dGUgaW50ZWdyYWwgdHlwZXMuCgotIFRoZSBzaXRlIG1vZHVsZSBpbnN0YWxscyBhIG5ldyBidWlsdC1pbiBmdW5jdGlvbiAnaGVscCcgdGhhdCBpbnZva2VzCiAgcHlkb2MuaGVscC4gIEl0IG11c3QgYmUgaW52b2tlZCBhcyAnaGVscCgpJzsgd2hlbiBpbnZva2VkIGFzICdoZWxwJywKICBpdCBkaXNwbGF5cyBhIG1lc3NhZ2UgcmVtaW5kaW5nIHRoZSB1c2VyIHRvIHVzZSAnaGVscCgpJyBvcgogICdoZWxwKG9iamVjdCknLgoKVGVzdHMKLS0tLS0KCi0gTmV3IHRlc3RfbXV0YW50cy5weSBydW5zIGRpY3QgY29tcGFyaXNvbnMgd2hlcmUgdGhlIGtleSBhbmQgdmFsdWUKICBjb21wYXJpc29uIG9wZXJhdG9ycyBtdXRhdGUgdGhlIGRpY3RzIHJhbmRvbWx5IGR1cmluZyBjb21wYXJpc29uLiAgVGhpcwogIHJhcGlkbHkgY2F1c2VzIFB5dGhvbiB0byBjcmFzaCB1bmRlciBlYXJsaWVyIHJlbGVhc2VzIChub3QgZm9yIHRoZSBmYWludAogIG9mIGhlYXJ0OiAgaXQgY2FuIGFsc28gY2F1c2UgV2luOXggdG8gZnJlZXplIG9yIHJlYm9vdCEpLgoKLSBOZXcgdGVzdF9wcHJpbnQucHkgdmVyaWZpZXMgdGhhdCBwcHJpbnQuaXNyZWN1cnNpdmUoKSBhbmQKICBwcHJpbnQuaXNyZWFkYWJsZSgpIHJldHVybiBzZW5zaWJsZSByZXN1bHRzLiAgQWxzbyB2ZXJpZmllcyB0aGF0IHNpbXBsZQogIGNhc2VzIHByb2R1Y2UgY29ycmVjdCBvdXRwdXQuCgpDIEFQSQotLS0tLQoKLSBSZW1vdmVkIHRoZSB1bnVzZWQgbGFzdF9pc19zdGlja3kgYXJndW1lbnQgZnJvbSB0aGUgaW50ZXJuYWwKICBfUHlUdXBsZV9SZXNpemUoKS4gIElmIHRoaXMgYWZmZWN0cyB5b3UsIHlvdSB3ZXJlIGNoZWF0aW5nLgoKLS0tLQoKKiooRm9yIGluZm9ybWF0aW9uIGFib3V0IG9sZGVyIHZlcnNpb25zLCBjb25zdWx0IHRoZSBISVNUT1JZIGZpbGUuKSoqCg==