V2hhdCdzIE5ldyBpbiBQeXRob24gMi4zIGFscGhhIDE/ClhYWCBSZWxlYXNlIGRhdGU6IERELU1NTS0yMDAyIFhYWAo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KClR5cGUvY2xhc3MgdW5pZmljYXRpb24gYW5kIG5ldy1zdHlsZSBjbGFzc2VzCgotIEFzc2lnbm1lbnQgdG8gX19jbGFzc19fIGlzIGRpc2FsbG93ZWQgaWYgZWl0aGVyIHRoZSBvbGQgYW5kIHRoZSBuZXcKICBjbGFzcyBpcyBhIHN0YXRpY2FsbHkgYWxsb2NhdGVkIHR5cGUgb2JqZWN0IChzdWNoIGFzIGRlZmluZWQgYnkgYW4KICBleHRlbnNpb24gbW9kdWxlKS4gIFRoaXMgcHJldmVudHMgYW5vbWFsaWVzIGxpa2UgMi5fX2NsYXNzX18gPSBib29sLgoKLSBOZXctc3R5bGUgb2JqZWN0IGNyZWF0aW9uIGFuZCBkZWFsbG9jYXRpb24gaGF2ZSBiZWVuIHNwZWQgdXAKICBzaWduaWZpY2FudGx5OyB0aGV5IGFyZSBub3cgZmFzdGVyIHRoYW4gY2xhc3NpYyBpbnN0YW5jZSBjcmVhdGlvbgogIGFuZCBkZWFsbG9jYXRpb24uCgotIFRoZSBfX3Nsb3RzX18gdmFyaWFibGUgY2FuIG5vdyBtZW50aW9uICJwcml2YXRlIiBuYW1lcywgYW5kIHRoZQogIHJpZ2h0IHRoaW5nIHdpbGwgaGFwcGVuIChlLmcuIF9fc2xvdHNfXyA9IFsiX19mb28iXSkuCgotIFRoZSBidWlsdC1pbnMgc2xpY2UoKSBhbmQgYnVmZmVyKCkgYXJlIG5vdyBjYWxsYWJsZSB0eXBlcy4gIFRoZQogIHR5cGVzIGNsYXNzb2JqIChmb3JtZXJseSBjbGFzcyksIGNvZGUsIGZ1bmN0aW9uLCBpbnN0YW5jZSwgYW5kCiAgaW5zdGFuY2VtZXRob2QgKGZvcm1lcmx5IGluc3RhbmNlLW1ldGhvZCksIHdoaWNoIGhhdmUgbm8gYnVpbHQtaW4KICBuYW1lcyBidXQgYXJlIGFjY2Vzc2libGUgdGhyb3VnaCB0aGUgdHlwZXMgbW9kdWxlLCBhcmUgbm93IGFsc28KICBjYWxsYWJsZS4gIFRoZSB0eXBlIGRpY3QtcHJveHkgaXMgcmVuYW1lZCB0byBkaWN0cHJveHkuCgotIEN5Y2xlcyBnb2luZyB0aHJvdWdoIHRoZSBfX2NsYXNzX18gbGluayBvZiBhIG5ldy1zdHlsZSBpbnN0YW5jZSBhcmUKICBub3cgZGV0ZWN0ZWQgYnkgdGhlIGdhcmJhZ2UgY29sbGVjdG9yLgoKLSBDbGFzc2VzIHVzaW5nIF9fc2xvdHNfXyBhcmUgbm93IHByb3Blcmx5IGdhcmJhZ2UgY29sbGVjdGVkLgogIFtTRiBidWcgNTE5NjIxXQoKLSBUaWdodGVuZWQgdGhlIF9fc2xvdHNfXyBydWxlczogYSBzbG90IG5hbWUgbXVzdCBiZSBhIHZhbGlkIFB5dGhvbgogIGlkZW50aWZpZXIuCgotIFRoZSBjb25zdHJ1Y3RvciBmb3IgdGhlIG1vZHVsZSB0eXBlIG5vdyByZXF1aXJlcyBhIG5hbWUgYXJndW1lbnQgYW5kCiAgdGFrZXMgYW4gb3B0aW9uYWwgZG9jc3RyaW5nIGFyZ3VtZW50LiAgUHJldmlvdXNseSwgdGhpcyBjb25zdHJ1Y3RvcgogIGlnbm9yZWQgaXRzIGFyZ3VtZW50cy4gIEFzIGEgY29uc2VxdWVuY2UsIGRlcml2aW5nIGEgY2xhc3MgZnJvbSBhCiAgbW9kdWxlIChub3QgZnJvbSB0aGUgbW9kdWxlIHR5cGUpIGlzIG5vdyBpbGxlZ2FsOyBwcmV2aW91c2x5IHRoaXMKICBjcmVhdGVkIGFuIHVubmFtZWQgbW9kdWxlLCBqdXN0IGxpa2UgaW52b2tpbmcgdGhlIG1vZHVsZSB0eXBlIGRpZC4KICBbU0YgYnVnIDU2MzA2MF0KCi0gQSBuZXcgdHlwZSBvYmplY3QsICdiYXNlc3RyaW5nJywgaXMgYWRkZWQuICBUaGlzIGlzIGEgY29tbW9uIGJhc2UgdHlwZQogIGZvciAnc3RyJyBhbmQgJ3VuaWNvZGUnLCBhbmQgY2FuIGJlIHVzZWQgaW5zdGVhZCBvZgogIHR5cGVzLlN0cmluZ1R5cGVzLCBlLmcuIHRvIHRlc3Qgd2hldGhlciBzb21ldGhpbmcgaXMgImEgc3RyaW5nIjoKICBpc2luc3RhbmNlKHgsIGJhc2VzdHJpbmcpIGlzIFRydWUgZm9yIFVuaWNvZGUgYW5kIDgtYml0IHN0cmluZ3MuICBUaGlzCiAgaXMgYW4gYWJzdHJhY3QgYmFzZSBjbGFzcyBhbmQgY2Fubm90IGJlIGluc3RhbnRpYXRlZCBkaXJlY3RseS4KCi0gQ2hhbmdlZCBuZXctc3R5bGUgY2xhc3MgaW5zdGFudGlhdGlvbiBzbyB0aGF0IHdoZW4gQydzIF9fbmV3X18KICBtZXRob2QgcmV0dXJucyBzb21ldGhpbmcgdGhhdCdzIG5vdCBhIEMgaW5zdGFuY2UsIGl0cyBfX2luaXRfXyBpcwogIG5vdCBjYWxsZWQuICBbU0YgYnVnICM1Mzc0NTBdCgotIEZpeGVkIHN1cGVyKCkgdG8gd29yayBjb3JyZWN0bHkgd2l0aCBjbGFzcyBtZXRob2RzLiAgW1NGIGJ1ZyAjNTM1NDQ0XQoKLSBJZiB5b3UgdHJ5IHRvIHBpY2tsZSBhbiBpbnN0YW5jZSBvZiBhIGNsYXNzIHRoYXQgaGFzIF9fc2xvdHNfXyBidXQKICBkb2Vzbid0IGRlZmluZSBvciBvdmVycmlkZSBfX2dldHN0YXRlX18sIGEgVHlwZUVycm9yIGlzIG5vdyByYWlzZWQuCiAgVGhpcyBpcyBkb25lIGJ5IGFkZGluZyBhIGJvem8gX19nZXRzdGF0ZV9fIHRvIHRoZSBjbGFzcyB0aGF0IGFsd2F5cwogIHJhaXNlcyBUeXBlRXJyb3IuICAoQmVmb3JlLCB0aGlzIHdvdWxkIGFwcGVhciB0byBiZSBwaWNrbGVkLCBidXQgdGhlCiAgc3RhdGUgb2YgdGhlIHNsb3RzIHdvdWxkIGJlIGxvc3QuKQoKQ29yZSBhbmQgYnVpbHRpbnMKCi0gQSBzdWJ0bGUgY2hhbmdlIHRvIHRoZSBzZW1hbnRpY3Mgb2YgdGhlIGJ1aWx0LWluIGZ1bmN0aW9uIGludGVybigpOgogIGludGVybmVkIHN0cmluZ3MgYXJlIG5vIGxvbmdlciBpbW1vcnRhbC4gIFlvdSBtdXN0IGtlZXAgYSByZWZlcmVuY2UKICB0byB0aGUgcmV0dXJuIHZhbHVlIGludGVybigpIGFyb3VuZCB0byBnZXQgdGhlIGJlbmVmaXQuCgotIFVzZSBvZiAnTm9uZScgYXMgYSB2YXJpYWJsZSwgYXJndW1lbnQgb3IgYXR0cmlidXRlIG5hbWUgbm93CiAgaXNzdWVzIGEgU3ludGF4V2FybmluZy4gIEluIHRoZSBmdXR1cmUsIE5vbmUgbWF5IGJlY29tZSBhIGtleXdvcmQuCgotIFNFVF9MSU5FTk8gaXMgZ29uZS4gIGNvX2xub3RhYiBpcyBub3cgY29uc3VsdGVkIHRvIGRldGVybWluZSB3aGVuIHRvCiAgY2FsbCB0aGUgdHJhY2UgZnVuY3Rpb24uICBDIGNvZGUgdGhhdCBhY2Nlc3NlZCBmX2xpbmVubyBzaG91bGQgY2FsbAogIFB5Q29kZV9BZGRyMkxpbmUgaW5zdGVhZCAoZl9saW5lbm8gaXMgc3RpbGwgdGhlcmUsIGJ1dCBub3Qga2VwdCB1cAogIHRvIGRhdGUpLgoKLSBUaGVyZSdzIGEgbmV3IHdhcm5pbmcgY2F0ZWdvcnksIEZ1dHVyZVdhcm5pbmcuICBUaGlzIGlzIHVzZWQgdG8gd2FybgogIGFib3V0IGEgbnVtYmVyIG9mIHNpdHVhdGlvbnMgd2hlcmUgdGhlIHZhbHVlIG9yIHNpZ24gb2YgYW4gaW50ZWdlcgogIHJlc3VsdCB3aWxsIGNoYW5nZSBpbiBQeXRob24gMi40IGFzIGEgcmVzdWx0IG9mIFBFUCAyMzcgKGludGVnZXIKICB1bmlmaWNhdGlvbikuICBUaGUgd2FybmluZ3MgaW1wbGVtZW50IHN0YWdlIEIwIG1lbnRpb25lZCBpbiB0aGF0CiAgUEVQLiAgVGhlIHdhcm5pbmdzIGFyZSBhYm91dCB0aGUgZm9sbG93aW5nIHNpdHVhdGlvbnM6CgogICAgLSBPY3RhbCBhbmQgaGV4IGxpdGVyYWxzIHdpdGhvdXQgJ0wnIHByZWZpeCBpbiB0aGUgaW5jbHVzaXZlIHJhbmdlCiAgICAgIFsweDgwMDAwMDAwLi4weGZmZmZmZmZmXTsgdGhlc2UgYXJlIGN1cnJlbnRseSBuZWdhdGl2ZSBpbnRzLCBidXQKICAgICAgaW4gUHl0aG9uIDIuNCB0aGV5IHdpbGwgYmUgcG9zaXRpdmUgbG9uZ3Mgd2l0aCB0aGUgc2FtZSBiaXQKICAgICAgcGF0dGVybi4KCiAgICAtIExlZnQgc2hpZnRzIG9uIGludGVnZXIgdmFsdWVzIHRoYXQgY2F1c2UgdGhlIG91dGNvbWUgdG8gbG9zZQogICAgICBiaXRzIG9yIGhhdmUgYSBkaWZmZXJlbnQgc2lnbiB0aGFuIHRoZSBsZWZ0IG9wZXJhbmQuICBUbyBiZQogICAgICBwcmVjaXNlOiB4PDxuIHdoZXJlIHRoaXMgY3VycmVudGx5IGRvZXNuJ3QgeWllbGQgdGhlIHNhbWUgdmFsdWUKICAgICAgYXMgbG9uZyh4KTw8bjsgaW4gUHl0aG9uIDIuNCwgdGhlIG91dGNvbWUgd2lsbCBiZSBsb25nKHgpPDxuLgoKICAgIC0gQ29udmVyc2lvbnMgZnJvbSBpbnRzIHRvIHN0cmluZyB0aGF0IHNob3cgbmVnYXRpdmUgdmFsdWVzIGFzCiAgICAgIHVuc2lnbmVkIGludHMgaW4gdGhlIGluY2x1c2l2ZSByYW5nZSBbMHg4MDAwMDAwMC4uMHhmZmZmZmZmZl07CiAgICAgIHRoaXMgYWZmZWN0cyB0aGUgZnVuY3Rpb25zIGhleCgpIGFuZCBvY3QoKSwgYW5kIHRoZSBzdHJpbmcKICAgICAgZm9ybWF0dGluZyBjb2RlcyAldSwgJW8sICV4LCBhbmQgJVguICBJbiBQeXRob24gMi40LCB0aGVzZSB3aWxsCiAgICAgIHNob3cgc2lnbmVkIHZhbHVlcyAoZS5nLiBoZXgoLTEpIGN1cnJlbnRseSByZXR1cm5zICIweGZmZmZmZmZmIjsKICAgICAgaW4gUHl0aG9uIDIuNCBpdCB3aWxsIHJldHVybiAiLTB4MSIpLgoKLSBXaGVuIG11bHRpcGx5aW5nIHZlcnkgbGFyZ2UgaW50ZWdlcnMsIGEgdmVyc2lvbiBvZiB0aGUgc28tY2FsbGVkCiAgS2FyYXRzdWJhIGFsZ29yaXRobSBpcyBub3cgdXNlZC4gIFRoaXMgaXMgbW9zdCBlZmZlY3RpdmUgaWYgdGhlCiAgaW5wdXRzIGhhdmUgcm91Z2hseSB0aGUgc2FtZSBzaXplLiAgSWYgdGhleSBib3RoIGhhdmUgYWJvdXQgTiBkaWdpdHMsCiAgS2FyYXRzdWJhIG11bHRpcGxpY2F0aW9uIGhhcyBPKE4qKjEuNTgpIHJ1bnRpbWUgKHRoZSBleHBvbmVudCBpcwogIGxvZ19iYXNlXzIoMykpIGluc3RlYWQgb2YgdGhlIHByZXZpb3VzIE8oTioqMikuICBNZWFzdXJlZCByZXN1bHRzIG1heQogIGJlIGJldHRlciBvciB3b3JzZSB0aGFuIHRoYXQsIGRlcGVuZGluZyBvbiBwbGF0Zm9ybSBxdWlya3MuICBCZXNpZGVzCiAgdGhlIE8oKSBpbXByb3ZlbWVudCBpbiByYXcgaW5zdHJ1Y3Rpb24gY291bnQsIHRoZSBLYXJhdHN1YmEgYWxnb3JpdGhtCiAgYXBwZWFycyB0byBoYXZlIG11Y2ggYmV0dGVyIGNhY2hlIGJlaGF2aW9yIG9uIGV4dHJlbWVseSBsYXJnZSBpbnRlZ2VycwogIChzdGFydGluZyBpbiB0aGUgYmFsbHBhcmsgb2YgYSBtaWxsaW9uIGJpdHMpLiAgTm90ZSB0aGF0IHRoaXMgaXMgYQogIHNpbXBsZSBpbXBsZW1lbnRhdGlvbiwgYW5kIHRoZXJlJ3Mgbm8gaW50ZW50IGhlcmUgdG8gY29tcGV0ZSB3aXRoLAogIGUuZy4sIEdNUC4gIEl0IGdpdmVzIGEgdmVyeSBuaWNlIHNwZWVkdXAgd2hlbiBpdCBhcHBsaWVzLCBidXQgYSBwYWNrYWdlCiAgZGV2b3RlZCB0byBmYXN0IGxhcmdlLWludGVnZXIgYXJpdGhtZXRpYyBzaG91bGQgcnVuIGNpcmNsZXMgYXJvdW5kIGl0LgoKLSB1JyVjJyB3aWxsIG5vdyByYWlzZSBhIFZhbHVlRXJyb3IgaW4gY2FzZSB0aGUgYXJndW1lbnQgaXMgYW4KICBpbnRlZ2VyIG91dHNpZGUgdGhlIHZhbGlkIHJhbmdlIG9mIFVuaWNvZGUgY29kZSBwb2ludCBvcmRpbmFscy4KCi0gVGhlIHRlbXBmaWxlIG1vZHVsZSBoYXMgYmVlbiBvdmVyaGF1bGVkIGZvciBlbmhhbmNlZCBzZWN1cml0eS4gIFRoZQogIG1rdGVtcCgpIGZ1bmN0aW9uIGlzIG5vdyBkZXByZWNhdGVkOyBuZXcsIHNhZmUgcmVwbGFjZW1lbnRzIGFyZQogIG1rc3RlbXAoKSAoZm9yIGZpbGVzKSBhbmQgbWtkdGVtcCgpIChmb3IgZGlyZWN0b3JpZXMpLCBhbmQgdGhlCiAgaGlnaGVyLWxldmVsIGZ1bmN0aW9ucyBOYW1lZFRlbXBvcmFyeUZpbGUoKSBhbmQgVGVtcG9yYXJ5RmlsZSgpLgogIFVzZSBvZiBzb21lIGdsb2JhbCB2YXJpYWJsZXMgaW4gdGhpcyBtb2R1bGUgaXMgYWxzbyBkZXByZWNhdGVkOyB0aGUKICBuZXcgZnVuY3Rpb25zIGhhdmUga2V5d29yZCBhcmd1bWVudHMgdG8gcHJvdmlkZSB0aGUgc2FtZQogIGZ1bmN0aW9uYWxpdHkuICBBbGwgTGliLCBUb29scyBhbmQgRGVtbyBtb2R1bGVzIHRoYXQgdXNlZCB0aGUgdW5zYWZlCiAgaW50ZXJmYWNlcyBoYXZlIGJlZW4gdXBkYXRlZCB0byB1c2UgdGhlIHNhZmUgcmVwbGFjZW1lbnRzLiAgVGhhbmtzCiAgdG8gWmFjayBXZWluYmVyZyEKCi0gV2hlbiB4IGlzIGFuIG9iamVjdCB3aG9zZSBjbGFzcyBpbXBsZW1lbnRzIF9fbXVsX18gYW5kIF9fcm11bF9fLAogIDEuMCp4IHdvdWxkIGNvcnJlY3RseSBpbnZva2UgX19ybXVsX18sIGJ1dCAxKnggd291bGQgZXJyb25lb3VzbHkKICBpbnZva2UgX19tdWxfXy4gIFRoaXMgd2FzIGR1ZSB0byB0aGUgc2VxdWVuY2UtcmVwZWF0IGNvZGUgaW4gdGhlIGludAogIHR5cGUuICBUaGlzIGhhcyBiZWVuIGZpeGVkIG5vdy4KCi0gUHJldmlvdXNseSwgInN0cjEgaW4gc3RyMiIgcmVxdWlyZWQgc3RyMSB0byBiZSBhIHN0cmluZyBvZiBsZW5ndGggMS4KICBUaGlzIHJlc3RyaWN0aW9uIGhhcyBiZWVuIHJlbGF4ZWQgdG8gYWxsb3cgc3RyMSB0byBiZSBhIHN0cmluZyBvZgogIGFueSBsZW5ndGguICBUaHVzICInZWwnIGluICdoZWxsbyB3b3JsZCciIHJldHVybnMgVHJ1ZSBub3cuCgotIEZpbGUgb2JqZWN0cyBhcmUgbm93IHRoZWlyIG93biBpdGVyYXRvcnMuICBGb3IgYSBmaWxlIGYsIGl0ZXIoZikgbm93CiAgcmV0dXJucyBmICh1bmxlc3MgZiBpcyBjbG9zZWQpLCBhbmQgZi5uZXh0KCkgaXMgc2ltaWxhciB0bwogIGYucmVhZGxpbmUoKSB3aGVuIEVPRiBpcyBub3QgcmVhY2hlZDsgaG93ZXZlciwgZi5uZXh0KCkgdXNlcyBhCiAgcmVhZGFoZWFkIGJ1ZmZlciB0aGF0IG1lc3NlcyB1cCB0aGUgZmlsZSBwb3NpdGlvbiwgc28gbWl4aW5nCiAgZi5uZXh0KCkgYW5kIGYucmVhZGxpbmUoKSAob3Igb3RoZXIgbWV0aG9kcykgZG9lc24ndCB3b3JrIHJpZ2h0LgogIENhbGxpbmcgZi5zZWVrKCkgZHJvcHMgdGhlIHJlYWRhaGVhZCBidWZmZXIsIGJ1dCBvdGhlciBvcGVyYXRpb25zCiAgZG9uJ3QuICBJdCBzbyBoYXBwZW5zIHRoYXQgdGhpcyBnaXZlcyBhIG5pY2UgYWRkaXRpb25hbCBzcGVlZCBib29zdAogIHRvICJmb3IgbGluZSBpbiBmaWxlOiI7IHRoZSB4cmVhZGxpbmVzIG1ldGhvZCBhbmQgY29ycmVzcG9uZGluZwogIG1vZHVsZSBhcmUgbm93IG9ic29sZXRlLiAgVGhhbmtzIHRvIE9yZW4gVGlyb3NoIQoKLSBFbmNvZGluZyBkZWNsYXJhdGlvbnMgKFBFUCAyNjMsIHBoYXNlIDEpIGhhdmUgYmVlbiBpbXBsZW1lbnRlZC4gIEEKICBjb21tZW50IG9mIHRoZSBmb3JtICIjIC0qLSBjb2Rpbmc6IDxlbmNvZGluZ25hbWU+IC0qLSIgaW4gdGhlIGZpcnN0CiAgb3Igc2Vjb25kIGxpbmUgb2YgYSBQeXRob24gc291cmNlIGZpbGUgaW5kaWNhdGVzIHRoZSBlbmNvZGluZy4KCi0gbGlzdC5zb3J0KCkgaGFzIGEgbmV3IGltcGxlbWVudGF0aW9uLiAgV2hpbGUgY3Jvc3MtcGxhdGZvcm0gcmVzdWx0cwogIG1heSB2YXJ5LCBhbmQgaW4gZGF0YS1kZXBlbmRlbnQgd2F5cywgdGhpcyBpcyBtdWNoIGZhc3RlciBvbiBtYW55CiAga2luZHMgb2YgcGFydGlhbGx5IG9yZGVyZWQgbGlzdHMgdGhhbiB0aGUgcHJldmlvdXMgaW1wbGVtZW50YXRpb24sCiAgYW5kIHJlcG9ydGVkIHRvIGJlIGp1c3QgYXMgZmFzdCBvbiByYW5kb21seSBvcmRlcmVkIGxpc3RzIG9uCiAgc2V2ZXJhbCBtYWpvciBwbGF0Zm9ybXMuICBUaGlzIHNvcnQgaXMgYWxzbyBzdGFibGUgKGlmIEE9PUIgYW5kIEEKICBwcmVjZWRlcyBCIGluIHRoZSBsaXN0IGF0IHRoZSBzdGFydCwgQSBwcmVjZWRlcyBCIGFmdGVyIHRoZSBzb3J0IHRvbyksCiAgYWx0aG91Z2ggdGhlIGxhbmd1YWdlIGRlZmluaXRpb24gZG9lcyBub3QgZ3VhcmFudGVlIHN0YWJpbGl0eS4gIEEKICBwb3RlbnRpYWwgZHJhd2JhY2sgaXMgdGhhdCBsaXN0LnNvcnQoKSBtYXkgcmVxdWlyZSB0ZW1wIHNwYWNlIG9mCiAgbGVuKGxpc3QpKjIgYnl0ZXMgKCo0IG9uIGEgNjQtYml0IG1hY2hpbmUpLiAgSXQncyB0aGVyZWZvcmUgcG9zc2libGUKICBmb3IgbGlzdC5zb3J0KCkgdG8gcmFpc2UgTWVtb3J5RXJyb3Igbm93LCBldmVuIGlmIGEgY29tcGFyaXNvbiBmdW5jdGlvbgogIGRvZXMgbm90LiAgU2VlIDxodHRwOi8vd3d3LnB5dGhvbi5vcmcvc2YvNTg3MDc2PiBmb3IgZnVsbCBkZXRhaWxzLgoKLSBBbGwgc3RhbmRhcmQgaXRlcmF0b3JzIG5vdyBlbnN1cmUgdGhhdCwgb25jZSBTdG9wSXRlcmF0aW9uIGhhcyBiZWVuCiAgcmFpc2VkLCBhbGwgZnV0dXJlIGNhbGxzIHRvIG5leHQoKSBvbiB0aGUgc2FtZSBpdGVyYXRvciB3aWxsIGFsc28KICByYWlzZSBTdG9wSXRlcmF0aW9uLiAgVGhlcmUgdXNlZCB0byBiZSB2YXJpb3VzIGNvdW50ZXJleGFtcGxlcyB0bwogIHRoaXMgYmVoYXZpb3IsIHdoaWNoIGNvdWxkIGNhdXNlZCBjb25mdXNpb24gb3Igc3VidGxlIHByb2dyYW0KICBicmVha2FnZSwgd2l0aG91dCBhbnkgYmVuZWZpdHMuICAoTm90ZSB0aGF0IHRoaXMgaXMgc3RpbGwgYW4KICBpdGVyYXRvcidzIHJlc3BvbnNpYmlsaXR5OyB0aGUgaXRlcmF0b3IgZnJhbWV3b3JrIGRvZXMgbm90IGVuZm9yY2UKICB0aGlzLikKCi0gQ3RybCtDIGhhbmRsaW5nIG9uIFdpbmRvd3MgaGFzIGJlZW4gbWFkZSBtb3JlIGNvbnNpc3RlbnQgd2l0aAogIG90aGVyIHBsYXRmb3Jtcy4gIEtleWJvYXJkSW50ZXJydXB0IGNhbiBub3cgcmVsaWFibHkgYmUgY2F1Z2h0LAogIGFuZCBDdHJsK0MgYXQgYW4gaW50ZXJhY3RpdmUgcHJvbXB0IG5vIGxvbmdlciB0ZXJtaW5hdGVzIHRoZQogIHByb2Nlc3MgdW5kZXIgTlQvMmsvWFAgKGl0IG5ldmVyIGRpZCB1bmRlciBXaW45eCkuICBDdHJsK0Mgd2lsbAogIGludGVycnVwdCB0aW1lLnNsZWVwKCkgaW4gdGhlIG1haW4gdGhyZWFkLCBhbmQgYW55IGNoaWxkIHByb2Nlc3NlcwogIGNyZWF0ZWQgdmlhIHRoZSBwb3BlbiBmYW1pbHkgKG9uIHdpbjJrOyB3ZSBjYW4ndCBtYWtlIHdpbjl4IHdvcmsKICByZWxpYWJseSkgYXJlIGFsc28gaW50ZXJydXB0ZWQgKGFzIGdlbmVyYWxseSBoYXBwZW5zIG9uIGZvciBMaW51eC9Vbml4LikKICBbU0YgYnVncyAyMzEyNzMsIDQzOTk5MiBhbmQgNTgxMjMyXQoKLSBTbGljZXMgYW5kIHJlcGV0aXRpb25zIG9mIGJ1ZmZlciBvYmplY3RzIG5vdyBjb25zaXN0ZW50bHkgcmV0dXJuCiAgYSBzdHJpbmcuICBGb3JtZXJseSwgc3RyaW5ncyB3b3VsZCBiZSByZXR1cm5lZCBtb3N0IG9mIHRoZSB0aW1lLAogIGJ1dCBhIGJ1ZmZlciBvYmplY3Qgd291bGQgYmUgcmV0dXJuZWQgd2hlbiB0aGUgcmVwZXRpdGlvbiBjb3VudAogIHdhcyBvbmUgb3Igd2hlbiB0aGUgc2xpY2UgcmFuZ2Ugd2FzIGFsbCBpbmNsdXNpdmUuCgotIFVuaWNvZGUgb2JqZWN0cyBpbiBzeXMucGF0aCBhcmUgbm8gbG9uZ2VyIGlnbm9yZWQgYnV0IHRyZWF0ZWQKICBhcyBkaXJlY3RvcnkgbmFtZXMuCgotIEZpeGVkIHN0cmluZy5zdGFydHN3aXRoIGFuZCBzdHJpbmcuZW5kc3dpdGggYnVpbHRpbiBtZXRob2RzCiAgc28gdGhleSBhY2NlcHQgbmVnYXRpdmUgaW5kaWNlcy4gIFtTRiBidWcgNDkzOTUxXQoKLSBGaXhlZCBhIGJ1ZyB3aXRoIGEgY29udGludWUgaW5zaWRlIGEgdHJ5IGJsb2NrIGFuZCBhIHlpZWxkIGluIHRoZQogIGZpbmFsbHkgY2xhdXNlLiAgW1NGIGJ1ZyA1Njc1MzhdCgotIE1vc3QgYnVpbHRpbiBzZXF1ZW5jZXMgbm93IHN1cHBvcnQgImV4dGVuZGVkIHNsaWNlcyIsIGkuZS4gc2xpY2VzCiAgd2l0aCBhIHRoaXJkICJzdHJpZGUiIHBhcmFtZXRlci4gIEZvciBleGFtcGxlLCAiaGVsbG8gd29ybGQiWzo6LTFdCiAgZ2l2ZXMgImRscm93IG9sbGVoIi4KCi0gQSBuZXcgd2FybmluZyBQZW5kaW5nRGVwcmVjYXRpb25XYXJuaW5nIHdhcyBhZGRlZCB0byBwcm92aWRlCiAgZGlyZWN0aW9uIG9uIGZlYXR1cmVzIHdoaWNoIGFyZSBpbiB0aGUgcHJvY2VzcyBvZiBiZWluZyBkZXByZWNhdGVkLgogIFRoZSB3YXJuaW5nIHdpbGwgbm90IGJlIHByaW50ZWQgYnkgZGVmYXVsdC4gIFRvIHNlZSB0aGUgcGVuZGluZwogIGRlcHJlY2F0aW9ucywgdXNlIC1XYWx3YXlzOjpQZW5kaW5nRGVwcmVjYXRpb25XYXJuaW5nOjoKICBhcyBhIGNvbW1hbmQgbGluZSBvcHRpb24gb3Igd2FybmluZ3MuZmlsdGVyd2FybmluZ3MoKSBpbiBjb2RlLgoKLSBEZXByZWNhdGVkIGZlYXR1cmVzIG9mIHhyYW5nZSBvYmplY3RzIGhhdmUgYmVlbiByZW1vdmVkIGFzCiAgcHJvbWlzZWQuICBUaGUgc3RhcnQsIHN0b3AsIGFuZCBzdGVwIGF0dHJpYnV0ZXMgYW5kIHRoZSB0b2xpc3QoKQogIG1ldGhvZCBubyBsb25nZXIgZXhpc3QuICB4cmFuZ2UgcmVwZXRpdGlvbiBhbmQgc2xpY2luZyBoYXZlIGJlZW4KICByZW1vdmVkLgoKLSBOZXcgYnVpbHRpbiBmdW5jdGlvbiBlbnVtZXJhdGUoeCksIGZyb20gUEVQIDI3OS4gIEV4YW1wbGU6CiAgZW51bWVyYXRlKCJhYmMiKSBpcyBhbiBpdGVyYXRvciByZXR1cm5pbmcgKDAsImEiKSwgKDEsImIiKSwgKDIsImMiKS4KICBUaGUgYXJndW1lbnQgY2FuIGJlIGFuIGFyYml0cmFyeSBpdGVyYWJsZSBvYmplY3QuCgotIFRoZSBhc3NlcnQgc3RhdGVtZW50IG5vIGxvbmdlciB0ZXN0cyBfX2RlYnVnX18gYXQgcnVudGltZS4gIFRoaXMgbWVhbnMKICB0aGF0IGFzc2VydCBzdGF0ZW1lbnRzIGNhbm5vdCBiZSBkaXNhYmxlZCBieSBhc3NpZ25pbmcgYSBmYWxzZSB2YWx1ZQogIHRvIF9fZGVidWdfXy4KCi0gQSBtZXRob2QgemZpbGwoKSB3YXMgYWRkZWQgdG8gc3RyIGFuZCB1bmljb2RlLCB0aGF0IGZpbGxzIGEgbnVtZXJpYwogIHN0cmluZyB0byB0aGUgbGVmdCB3aXRoIHplcm9zLiAgRm9yIGV4YW1wbGUsCiAgIisxMjMiLnpmaWxsKDYpIC0+ICIrMDAxMjMiLgoKLSBDb21wbGV4IG51bWJlcnMgc3VwcG9ydGVkIGRpdm1vZCgpIGFuZCB0aGUgLy8gYW5kICUgb3BlcmF0b3JzLCBidXQKICB0aGVzZSBtYWtlIG5vIHNlbnNlLiAgU2luY2UgdGhpcyB3YXMgZG9jdW1lbnRlZCwgdGhleSdyZSBiZWluZwogIGRlcHJlY2F0ZWQgbm93LgoKLSBTdHJpbmcgYW5kIHVuaWNvZGUgbWV0aG9kcyBsc3RyaXAoKSwgcnN0cmlwKCkgYW5kIHN0cmlwKCkgbm93IHRha2UKICBhbiBvcHRpb25hbCBhcmd1bWVudCB0aGF0IHNwZWNpZmllcyB0aGUgY2hhcmFjdGVycyB0byBzdHJpcC4gIEZvcgogIGV4YW1wbGUsICJGb28hISE/IT8hPyIucnN0cmlwKCI/ISIpIC0+ICJGb28iLgoKLSBBZGRlZCBhIG5ldyBkaWN0IG1ldGhvZCBwb3Aoa2V5KS4gIFRoaXMgcmVtb3ZlcyBhbmQgcmV0dXJucyB0aGUKICB2YWx1ZSBjb3JyZXNwb25kaW5nIHRvIGtleS4gIFtTRiBwYXRjaCAjNTM5OTQ5XQoKLSBBIG5ldyBidWlsdC1pbiB0eXBlLCBib29sLCBoYXMgYmVlbiBhZGRlZCwgYXMgd2VsbCBhcyBidWlsdC1pbgogIG5hbWVzIGZvciBpdHMgdHdvIHZhbHVlcywgVHJ1ZSBhbmQgRmFsc2UuICBDb21wYXJpc29ucyBhbmQgc3VuZHJ5CiAgb3RoZXIgb3BlcmF0aW9ucyB0aGF0IHJldHVybiBhIHRydXRoIHZhbHVlIGhhdmUgYmVlbiBjaGFuZ2VkIHRvCiAgcmV0dXJuIGEgYm9vbCBpbnN0ZWFkLiAgUmVhZCBQRVAgMjg1IGZvciBhbiBleHBsYW5hdGlvbiBvZiB3aHkgdGhpcwogIGlzIGJhY2t3YXJkIGNvbXBhdGlibGUuCgotIEZpeGVkIHR3byBidWdzIHJlcG9ydGVkIGFzIFNGICM1MzU5MDU6IHVuZGVyIGNlcnRhaW4gY29uZGl0aW9ucywKICBkZWFsbG9jYXRpbmcgYSBkZWVwbHkgbmVzdGVkIHN0cnVjdHVyZSBjb3VsZCBjYXVzZSBhIHNlZ2ZhdWx0IGluIHRoZQogIGdhcmJhZ2UgY29sbGVjdG9yLCBkdWUgdG8gaW50ZXJhY3Rpb24gd2l0aCB0aGUgInRyYXNoY2FuIiBjb2RlOwogIGFjY2VzcyB0byB0aGUgY3VycmVudCBmcmFtZSBkdXJpbmcgZGVzdHJ1Y3Rpb24gb2YgYSBsb2NhbCB2YXJpYWJsZQogIGNvdWxkIGFjY2VzcyBhIHBvaW50ZXIgdG8gZnJlZWQgbWVtb3J5LgoKLSBUaGUgb3B0aW9uYWwgb2JqZWN0IGFsbG9jYXRvciAoInB5bWFsbG9jIikgaGFzIGJlZW4gZW5hYmxlZCBieQogIGRlZmF1bHQuICBUaGUgcmVjb21tZW5kZWQgcHJhY3RpY2UgZm9yIG1lbW9yeSBhbGxvY2F0aW9uIGFuZAogIGRlYWxsb2NhdGlvbiBoYXMgYmVlbiBzdHJlYW1saW5lZC4gIEEgaGVhZGVyIGZpbGUgaXMgaW5jbHVkZWQsCiAgTWlzYy9weW1lbWNvbXBhdC5oLCB3aGljaCBjYW4gYmUgYnVuZGxlZCB3aXRoIDNyZCBwYXJ0eSBleHRlbnNpb25zCiAgYW5kIGxldHMgdGhlbSB1c2UgdGhlIHNhbWUgQVBJIHdpdGggUHl0aG9uIHZlcnNpb25zIGZyb20gMS41LjIKICBvbndhcmRzLgoKLSBQeUVycl9EaXNwbGF5IHdpbGwgcHJvdmlkZSBmaWxlIGFuZCBsaW5lIGluZm9ybWF0aW9uIGZvciBhbGwgZXhjZXB0aW9ucwogIHRoYXQgaGF2ZSBhbiBhdHRyaWJ1dGUgcHJpbnRfZmlsZV9hbmRfbGluZSwgbm90IGp1c3QgU3ludGF4RXJyb3JzLgoKLSBUaGUgVVRGLTggY29kZWMgd2lsbCBub3cgZW5jb2RlIGFuZCBkZWNvZGUgVW5pY29kZSBzdXJyb2dhdGVzCiAgY29ycmVjdGx5IGFuZCB3aXRob3V0IHJhaXNpbmcgZXhjZXB0aW9ucyBmb3IgdW5wYWlyZWQgb25lcy4KCi0gVW5pdmVyc2FsIG5ld2xpbmVzIChQRVAgMjc4KSBpcyBpbXBsZW1lbnRlZC4gIEJyaWVmbHksIHVzaW5nICdVJwogIGluc3RlYWQgb2YgJ3InIHdoZW4gb3BlbmluZyBhIHRleHQgZmlsZSBmb3IgcmVhZGluZyBjaGFuZ2VzIHRoZSBsaW5lCiAgZW5kaW5nIGNvbnZlbnRpb24gc28gdGhhdCBhbnkgb2YgJ1xyJywgJ1xyXG4nLCBhbmQgJ1xuJyBpcwogIHJlY29nbml6ZWQgKGV2ZW4gbWl4ZWQgaW4gb25lIGZpbGUpOyBhbGwgdGhyZWUgYXJlIGNvbnZlcnRlZCB0bwogICdcbicsIHRoZSBzdGFuZGFyZCBQeXRob24gbGluZSBlbmQgY2hhcmFjdGVyLgoKLSBmaWxlLnhyZWFkbGluZXMoKSBub3cgcmFpc2VzIGEgVmFsdWVFcnJvciBpZiB0aGUgZmlsZSBpcyBjbG9zZWQ6CiAgUHJldmlvdXNseSwgYW4geHJlYWRsaW5lcyBvYmplY3Qgd2FzIHJldHVybmVkIHdoaWNoIHdvdWxkIHJhaXNlCiAgYSBWYWx1ZUVycm9yIHdoZW4gdGhlIHhyZWFkbGluZXMubmV4dCgpIG1ldGhvZCB3YXMgY2FsbGVkLgoKLSBzeXMuZXhpdCgpIGluYWR2ZXJ0ZW50bHkgYWxsb3dlZCBtb3JlIHRoYW4gb25lIGFyZ3VtZW50LgogIEFuIGV4Y2VwdGlvbiB3aWxsIG5vdyBiZSByYWlzZWQgaWYgbW9yZSB0aGFuIG9uZSBhcmd1bWVudCBpcyB1c2VkLgoKRXh0ZW5zaW9uIG1vZHVsZXMKCi0gVGhlIHhyZWFkbGluZXMgbW9kdWxlIGlzIHNsYXRlZCBmb3Igb2Jzb2xlc2NlbmNlLgoKLSBUaGUgc3RycHRpbWUgZnVuY3Rpb24gaW4gdGhlIHRpbWUgbW9kdWxlIGlzIG5vdyBhbHdheXMgYXZhaWxhYmxlIChhCiAgUHl0aG9uIGltcGxlbWVudGF0aW9uIGlzIHVzZWQgd2hlbiB0aGUgQyBsaWJyYXJ5IGRvZXNuJ3QgZGVmaW5lIGl0KS4KCi0gVGhlICduZXcnIG1vZHVsZSBpcyBubyBsb25nZXIgYW4gZXh0ZW5zaW9uLCBidXQgYSBQeXRob24gbW9kdWxlIHRoYXQKICBvbmx5IGV4aXN0cyBmb3IgYmFja3dhcmRzIGNvbXBhdGliaWxpdHkuICBJdHMgY29udGVudHMgYXJlIG5vIGxvbmdlcgogIGZ1bmN0aW9ucyBidXQgY2FsbGFibGUgdHlwZSBvYmplY3RzLgoKLSBUaGUgYnNkZGIuKm9wZW4gZnVuY3Rpb25zIGNhbiBub3cgdGFrZSAnTm9uZScgYXMgYSBmaWxlbmFtZS4KICBUaGlzIHdpbGwgY3JlYXRlIGEgdGVtcG9yYXJ5IGluLW1lbW9yeSBic2RkYiB0aGF0IHdvbid0IGJlCiAgd3JpdHRlbiB0byBkaXNrLgoKLSBwb3NpeC5sY2hvd24sIHBvc2l4LmtpbGxwZywgcG9zaXgubWtub2QsIGFuZCBwb3NpeC5nZXRwZ2lkIGhhdmUgYmVlbgogIGFkZGVkIHdoZXJlIGF2YWlsYWJsZS4KCi0gVGhlIGxvY2FsZSBtb2R1bGUgbm93IGV4cG9zZXMgdGhlIEMgbGlicmFyeSdzIGdldHRleHQgaW50ZXJmYWNlLgoKLSBBIHNlY3VyaXR5IGhvbGUgKCJkb3VibGUgZnJlZSIpIHdhcyBmb3VuZCBpbiB6bGliLTEuMS4zLCBhIHBvcHVsYXIKICB0aGlyZCBwYXJ0eSBjb21wcmVzc2lvbiBsaWJyYXJ5IHVzZWQgYnkgc29tZSBQeXRob24gbW9kdWxlcy4gIFRoZQogIGhvbGUgd2FzIHF1aWNrbHkgcGx1Z2dlZCBpbiB6bGliLTEuMS40LCBhbmQgdGhlIFdpbmRvd3MgYnVpbGQgb2YKICBQeXRob24gbm93IHNoaXBzIHdpdGggemxpYi0xLjEuNC4KCi0gcHdkLCBncnAsIGFuZCByZXNvdXJjZSByZXR1cm4gZW5oYW5jZWQgdHVwbGVzIG5vdywgd2l0aCBzeW1ib2xpYwogIGZpZWxkIG5hbWVzLgoKLSBhcnJheS5hcnJheSBpcyBub3cgYSB0eXBlIG9iamVjdC4gQSBuZXcgZm9ybWF0IGNoYXJhY3RlcgogICd1JyBpbmRpY2F0ZXMgUHlfVU5JQ09ERSBhcnJheXMuIEZvciB0aG9zZSwgLnRvdW5pY29kZSBhbmQKICAuZnJvbXVuaWNvZGUgbWV0aG9kcyBhcmUgYXZhaWxhYmxlLiBBcnJheXMgbm93IHN1cHBvcnQgX19pYWRkX18KICBhbmQgX19pbXVsX18uCgotIGRsIG5vdyBidWlsZHMgb24gZXZlcnkgc3lzdGVtIHRoYXQgaGFzIGRsZmNuLmguICBGYWlsdXJlIGluIGNhc2UKICBvZiBzaXplb2YoaW50KSE9c2l6ZW9mKGxvbmcpIT1zaXplb2Yodm9pZCopIGlzIGRlbGF5ZWQgdW50aWwgZGwub3BlbgogIGlzIGNhbGxlZC4KCi0gc2lnbmFsLnNpZ3BlbmRpbmcsIHNpZ25hbC5zaWdwcm9jbWFzayBhbmQgc2lnbmFsLnNpZ3N1c3BlbmQgaGF2ZQogIGJlZW4gYWRkZWQgd2hlcmUgYXZhaWxhYmxlLgoKTGlicmFyeQoKLSBOZXcgbW9kdWxlOiBzZXRzLCBkZWZpbmVzIHRoZSBjbGFzcyBTZXQgdGhhdCBpbXBsZW1lbnRzIGEgbXV0YWJsZQogIHNldCB0eXBlIHVzaW5nIHRoZSBrZXlzIG9mIGEgZGljdCB0byByZXByZXNlbnQgdGhlIHNldC4gIFRoZXJlJ3MKICBhbHNvIGEgY2xhc3MgSW1tdXRhYmxlU2V0IHdoaWNoIGlzIHVzZWZ1bCB3aGVuIHlvdSBuZWVkIHNldHMgb2Ygc2V0cwogIG9yIHdoZW4geW91IG5lZWQgdG8gdXNlIHNldHMgYXMgZGljdCBrZXlzLCBhbmQgYSBjbGFzcyBCYXNlU2V0IHdoaWNoCiAgaXMgdGhlIGJhc2UgY2xhc3Mgb2YgdGhlIHR3by4gIChUaGlzIGlzIG5vdCBkb2N1bWVudGVkIHlldCwgYnV0CiAgaGVscChzZXRzKSBnaXZlcyBhIHdlYWx0aCBvZiBpbmZvcm1hdGlvbi4pCgotIEFkZGVkIG9wZXJhdG9yLnBvdyhhLGIpIHdoaWNoIGlzIGVxdWl2YWxlbnQgdG8gYSoqYi4KCi0gcmFuZG9tLnJhbmRyYW5nZSgtc3lzLm1heGludC0xLCBzeXMubWF4aW50KSBubyBsb25nZXIgcmFpc2VzCiAgT3ZlcmZsb3dFcnJvci4gIFRoYXQgaXMsIGl0IG5vdyBhY2NlcHRzIGFueSBjb21iaW5hdGlvbiBvZiAnc3RhcnQnCiAgYW5kICdzdG9wJyBhcmd1bWVudHMgc28gbG9uZyBhcyBlYWNoIGlzIGluIHRoZSByYW5nZSBvZiBQeXRob24ncwogIGJvdW5kZWQgaW50ZWdlcnMuCgotIE5ldyAiYWxnb3JpdGhtcyIgbW9kdWxlOiBoZWFwcSwgaW1wbGVtZW50cyBhIGhlYXAgcXVldWUuICBUaGFua3MgdG8KICBLZXZpbiBPJ0Nvbm5vciBmb3IgdGhlIGNvZGUgYW5kIEZyYW7nb2lzIFBpbmFyZCBmb3IgYW4gZW50ZXJ0YWluaW5nCiAgd3JpdGUtdXAgZXhwbGFpbmluZyB0aGUgdGhlb3J5IGFuZCBwcmFjdGljYWwgdXNlcyBvZiBoZWFwcy4KCi0gTmV3IGVuY29kaW5nIGZvciB0aGUgUGFsbSBPUyBjaGFyYWN0ZXIgc2V0OiBwYWxtb3MuCgotIGJpbmFzY2lpLmNyYzMyKCkgYW5kIHRoZSB6aXBmaWxlIG1vZHVsZSBoYWQgcHJvYmxlbXMgb24gc29tZSA2NC1iaXQKICBwbGF0Zm9ybXMuICBUaGVzZSBoYXZlIGJlZW4gZml4ZWQuICBPbiBhIHBsYXRmb3JtIHdpdGggOC1ieXRlIEMgbG9uZ3MsCiAgY3JjMzIoKSBub3cgcmV0dXJucyBhIHNpZ25lZC1leHRlbmRlZCA0LWJ5dGUgcmVzdWx0LCBzbyB0aGF0IGl0cyB2YWx1ZQogIGFzIGEgUHl0aG9uIGludCBpcyBlcXVhbCB0byB0aGUgdmFsdWUgY29tcHV0ZWQgYSAzMi1iaXQgcGxhdGZvcm0uCgotIHhtbC5kb20ubWluaWRvbS50b3htbCBhbmQgdG9wcmV0dHl4bWwgbm93IHRha2UgYW4gb3B0aW9uYWwgZW5jb2RpbmcKICBhcmd1bWVudC4KCi0gU29tZSBmaXhlcyBpbiB0aGUgY29weSBtb2R1bGU6IHdoZW4gYW4gb2JqZWN0IGlzIGNvcGllZCB0aHJvdWdoIGl0cwogIF9fcmVkdWNlX18gbWV0aG9kLCB0aGVyZSB3YXMgbm8gY2hlY2sgZm9yIGEgX19zZXRzdGF0ZV9fIG1ldGhvZCBvbgogIHRoZSByZXN1bHQgW1NGIHBhdGNoIDU2NTA4NV07IGRlZXBjb3B5IHNob3VsZCB0cmVhdCBpbnN0YW5jZXMgb2YKICBjdXN0b20gbWV0YWNsYXNzZXMgdGhlIHNhbWUgd2F5IGl0IHRyZWF0cyBpbnN0YW5jZXMgb2YgdHlwZSAndHlwZScKICBbU0YgcGF0Y2ggNTYwNzk0XS4KCi0gU29ja2V0cyBub3cgc3VwcG9ydCB0aW1lb3V0IG1vZGUuICBBZnRlciBzLnNldHRpbWVvdXQoVCksIHdoZXJlIFQgaXMKICBhIGZsb2F0IGV4cHJlc3Npbmcgc2Vjb25kcywgc3Vic2VxdWVudCBvcGVyYXRpb25zIHJhaXNlIGFuIGV4Y2VwdGlvbgogIGlmIHRoZXkgY2Fubm90IGJlIGNvbXBsZXRlZCB3aXRoaW4gVCBzZWNvbmRzLiAgVG8gZGlzYWJsZSB0aW1lb3V0CiAgbW9kZSwgdXNlIHMuc2V0dGltZW91dChOb25lKS4gIFRoZXJlJ3MgYWxzbyBhIG1vZHVsZSBmdW5jdGlvbiwKICBzb2NrZXQuc2V0ZGVmYXVsdHRpbWVvdXQoVCksIHdoaWNoIHNldHMgdGhlIGRlZmF1bHQgZm9yIGFsbCBzb2NrZXRzCiAgY3JlYXRlZCBoZW5jZWZvcnRoLgoKLSBnZXRvcHQuZ251X2dldG9wdCB3YXMgYWRkZWQuICBUaGlzIHN1cHBvcnRzIEdOVS1zdHlsZSBvcHRpb24KICBwcm9jZXNzaW5nLCB3aGVyZSBvcHRpb25zIGNhbiBiZSBtaXhlZCB3aXRoIG5vbi1vcHRpb24gYXJndW1lbnRzLgoKLSBTdG9wIHVzaW5nIHN0cmluZ3MgZm9yIGV4Y2VwdGlvbnMuICBTdHJpbmcgb2JqZWN0cyB1c2VkIGZvcgogIGV4Y2VwdGlvbnMgYXJlIG5vdyBjbGFzc2VzIGRlcml2aW5nIGZyb20gRXhjZXB0aW9uLiAgVGhlIG9iamVjdHMKICBjaGFuZ2VkIHdlcmU6IFRraW50ZXIuVGNsRXJyb3IsIGJkYi5CZGJRdWl0LCBtYWNwYXRoLm5vcm1fZXJyb3IsCiAgdGFibmFubnkuTmFubnlOYWcsIGFuZCB4ZHJsaWIuRXJyb3IuCgotIENvbnN0YW50cyBCT01fVVRGOCwgQk9NX1VURjE2LCBCT01fVVRGMTZfTEUsIEJPTV9VVEYxNl9CRSwKICBCT01fVVRGMzIsIEJPTV9VVEYzMl9MRSBhbmQgQk9NX1VURjMyX0JFIHRoYXQgcmVwcmVzZW50IHRoZSBCeXRlCiAgT3JkZXIgTWFyayBpbiBVVEYtOCwgVVRGLTE2IGFuZCBVVEYtMzIgZW5jb2RpbmdzIGZvciBsaXR0bGUgYW5kCiAgYmlnIGVuZGlhbiBzeXN0ZW1zIHdlcmUgYWRkZWQgdG8gdGhlIGNvZGVjcyBtb2R1bGUuIFRoZSBvbGQgbmFtZXMKICBCT00zMl8qIGFuZCBCT002NF8qIHdlcmUgb2ZmIGJ5IGEgZmFjdG9yIG9mIDIuCgotIEFkZGVkIGNvbnZlcnNpb24gZnVuY3Rpb25zIG1hdGguZGVncmVlcygpIGFuZCBtYXRoLnJhZGlhbnMoKS4KCi0gZnRwbGliLnJldHJsaW5lcygpIG5vdyB0ZXN0cyBmb3IgY2FsbGJhY2sgaXMgTm9uZSByYXRoZXIgdGhhbiB0ZXN0aW5nCiAgZm9yIEZhbHNlLiAgV2FzIGNhdXNpbmcgYW4gZXJyb3Igd2hlbiBnaXZlbiBhIGNhbGxiYWNrIG9iamVjdCB3aGljaAogIHdhcyBjYWxsYWJsZSBidXQgYWxzbyByZXR1cm5lZCBsZW4oKSBhcyB6ZXJvLiAgVGhlIGNoYW5nZSBtYXkKICBjcmVhdGUgbmV3IGJyZWFrYWdlIGlmIHRoZSBjYWxsZXIgcmVsaWVkIG9uIHRoZSB1bmRvY3VtZW50ZWQgYmVoYXZpb3IKICBhbmQgY2FsbGVkIHdpdGggY2FsbGJhY2sgc2V0IHRvIFtdIG9yIHNvbWUgb3RoZXIgRmFsc2UgdmFsdWUgbm90CiAgaWRlbnRpY2FsIHRvIE5vbmUuCgotIHJhbmRvbS5nYXVzcygpIHVzZXMgYSBwaWVjZSBvZiBoaWRkZW4gc3RhdGUgdXNlZCBieSBub3RoaW5nIGVsc2UsCiAgYW5kIHRoZSAuc2VlZCgpIGFuZCAud2hzZWVkKCkgbWV0aG9kcyBmYWlsZWQgdG8gcmVzZXQgaXQuICBJbiBvdGhlcgogIHdvcmRzLCBzZXR0aW5nIHRoZSBzZWVkIGRpZG4ndCBjb21wbGV0ZWx5IGRldGVybWluZSB0aGUgc2VxdWVuY2Ugb2YKICByZXN1bHRzIHByb2R1Y2VkIGJ5IHJhbmRvbS5nYXVzcygpLiAgSXQgZG9lcyBub3cuICBQcm9ncmFtcyByZXBlYXRlZGx5CiAgbWl4aW5nIGNhbGxzIHRvIGEgc2VlZCBtZXRob2Qgd2l0aCBjYWxscyB0byBnYXVzcygpIG1heSBzZWUgZGlmZmVyZW50CiAgcmVzdWx0cyBub3cuCgotIFRoZSBwaWNrbGUuUGlja2xlciBjbGFzcyBncmV3IGEgY2xlYXJfbWVtbygpIG1ldGhvZCB0byBtaW1pYyB0aGF0CiAgcHJvdmlkZWQgYnkgY1BpY2tsZS5QaWNrbGVyLgoKLSBkaWZmbGliJ3MgU2VxdWVuY2VNYXRjaGVyIGNsYXNzIG5vdyBkb2VzIGEgZHluYW1pYyBhbmFseXNpcyBvZgogIHdoaWNoIGVsZW1lbnRzIGFyZSBzbyBmcmVxdWVudCBhcyB0byBjb25zdGl0dXRlIG5vaXNlLiAgRm9yCiAgY29tcGFyaW5nIGZpbGVzIGFzIHNlcXVlbmNlcyBvZiBsaW5lcywgdGhpcyBnZW5lcmFsbHkgd29ya3MgYmV0dGVyCiAgdGhhbiB0aGUgSVNfTElORV9KVU5LIGZ1bmN0aW9uLCBhbmQgZnVuY3Rpb24gbmRpZmYncyBsaW5lanVuawogIGFyZ3VtZW50IGRlZmF1bHRzIHRvIE5vbmUgbm93IGFzIGEgcmVzdWx0LiAgQSBoYXBweSBiZW5lZml0IGlzCiAgdGhhdCBTZXF1ZW5jZU1hdGNoZXIgbWF5IHJ1biBtdWNoIGZhc3RlciBub3cgd2hlbiBhcHBsaWVkCiAgdG8gbGFyZ2UgZmlsZXMgd2l0aCBtYW55IGR1cGxpY2F0ZSBsaW5lcyAoZm9yIGV4YW1wbGUsIEMgcHJvZ3JhbQogIHRleHQgd2l0aCBsb3RzIG9mIHJlcGVhdGVkICJ9IiBhbmQgInJldHVybiBOVUxMOyIgbGluZXMpLgoKLSBOZXcgVGV4dC5kdW1wKCkgbWV0aG9kIGluIFRraW50ZXIgbW9kdWxlLgoKLSBOZXcgZGlzdHV0aWxzIGNvbW1hbmRzIGZvciBidWlsZGluZyBwYWNrYWdlcnMgd2VyZSBhZGRlZCB0bwogIHN1cHBvcnQgcGtndG9vbCBvbiBTb2xhcmlzIGFuZCBzd2luc3RhbGwgb24gSFAtVVguCgotIGRpc3R1dGlscyBub3cgaGFzIGEgbmV3IGFic3RyYWN0IGJpbmFyeSBwYWNrYWdlciBiYXNlIGNsYXNzCiAgY29tbWFuZC9iZGlzdF9wYWNrYWdlciwgd2hpY2ggc2ltcGxpZmllcyB3cml0aW5nIHBhY2thZ2Vycy4KICBUaGlzIHdpbGwgaG9wZWZ1bGx5IHByb3ZpZGUgdGhlIG1pc3NpbmcgYml0cyB0byBlbmNvdXJhZ2UKICBwZW9wbGUgdG8gc3VibWl0IG1vcmUgcGFja2FnZXJzLCBlLmcuIGZvciBEZWJpYW4sIEZyZWVCU0QKICBhbmQgb3RoZXIgc3lzdGVtcy4KCi0gVGhlIFVURi0xNiwgLUxFIGFuZCAtQkUgc3RyZWFtIHJlYWRlcnMgbm93IHJhaXNlIGEKICBOb3RJbXBsZW1lbnRlZEVycm9yIGZvciBhbGwgY2FsbHMgdG8gLnJlYWRsaW5lKCkuIFByZXZpb3VzbHksIHRoZXkKICB1c2VkIHRvIGp1c3QgcHJvZHVjZSBnYXJiYWdlIG9yIGZhaWwgd2l0aCBhbiBlbmNvZGluZyBlcnJvciAtLQogIFVURi0xNiBpcyBhIDItYnl0ZSBlbmNvZGluZyBhbmQgdGhlIEMgbGliJ3MgbGluZSByZWFkaW5nIEFQSXMgZG9uJ3QKICB3b3JrIHdlbGwgd2l0aCB0aGVzZS4KCi0gY29tcGlsZWFsbCBub3cgc3VwcG9ydHMgcXVpZXQgb3BlcmF0aW9uLgoKLSBUaGUgQmFzZUhUVFBTZXJ2ZXIgbm93IGltcGxlbWVudHMgb3B0aW9uYWwgSFRUUC8xLjEgcGVyc2lzdGVudAogIGNvbm5lY3Rpb25zLgoKLSBzb2NrZXQgbW9kdWxlOiB0aGUgU1NMIHN1cHBvcnQgd2FzIGJyb2tlbiBvdXQgb2YgdGhlIG1haW4KICBfc29ja2V0IG1vZHVsZSBDIGhlbHBlciBhbmQgcGxhY2VkIGludG8gYSBuZXcgX3NzbCBoZWxwZXIKICB3aGljaCBub3cgZ2V0cyBpbXBvcnRlZCBieSBzb2NrZXQucHkgaWYgYXZhaWxhYmxlIGFuZCB3b3JraW5nLgoKLSBlbmNvZGluZ3MgcGFja2FnZTogYWRkZWQgYWxpYXNlcyBmb3IgYWxsIHN1cHBvcnRlZCBJQU5BIGNoYXJhY3RlcgogIHNldHMKCi0gZnRwbGliOiB0byBzYWZlZ3VhcmQgdGhlIHVzZXIncyBwcml2YWN5LCBhbm9ueW1vdXMgbG9naW4gd2lsbCB1c2UKICAiYW5vbnltb3VzQCIgYXMgZGVmYXVsdCBwYXNzd29yZCwgcmF0aGVyIHRoYW4gdGhlIHJlYWwgdXNlciBhbmQgaG9zdAogIG5hbWUuCgotIHdlYmJyb3dzZXI6IHRpZ2h0ZW5lZCB1cCB0aGUgY29tbWFuZCBwYXNzZWQgdG8gb3Muc3lzdGVtKCkgc28gdGhhdAogIGFyYml0cmFyeSBzaGVsbCBjb2RlIGNhbid0IGJlIGV4ZWN1dGVkIGJlY2F1c2UgYSBib2d1cyBVUkwgd2FzCiAgcGFzc2VkIGluLgoKLSBnZXR0ZXh0LnRyYW5zbGF0aW9uIGhhcyBhbiBvcHRpb25hbCBmYWxsYmFjayBhcmd1bWVudCwgYW5kCiAgZ2V0dGV4dC5maW5kIGFuIG9wdGlvbmFsIGFsbCBhcmd1bWVudC4gVHJhbnNsYXRpb25zIHdpbGwgbm93IGZhbGxiYWNrCiAgb24gYSBwZXItbWVzc2FnZSBiYXNpcy4KCi0gZGlzdHV0aWxzIGJkaXN0IGNvbW1hbmRzIG5vdyBvZmZlciBhIC0tc2tpcC1idWlsZCBvcHRpb24uCgotIHdhcm5pbmdzLndhcm4gbm93IGFjY2VwdHMgYSBXYXJuaW5nIGluc3RhbmNlIGFzIGZpcnN0IGFyZ3VtZW50LgoKLSBUaGUgeG1sLnNheC5leHBhdHJlYWRlci5FeHBhdFBhcnNlciBjbGFzcyB3aWxsIG5vIGxvbmdlciBjcmVhdGUKICBjaXJjdWxhciByZWZlcmVuY2VzIGJ5IHVzaW5nIGl0c2VsZiBhcyB0aGUgbG9jYXRvciB0aGF0IGdldHMgcGFzc2VkCiAgdG8gdGhlIGNvbnRlbnQgaGFuZGxlciBpbXBsZW1lbnRhdGlvbi4gIFtTRiBidWcgIzUzNTQ3NF0KCi0gVGhlIGVtYWlsLlBhcnNlci5QYXJzZXIgY2xhc3Mgbm93IHByb3Blcmx5IHBhcnNlcyBzdHJpbmdzIHJlZ2FyZGxlc3MKICBvZiB0aGVpciBsaW5lIGVuZGluZ3MsIHdoaWNoIGNhbiBiZSBhbnkgb2YgXHIsIFxuLCBvciBcclxuIChDUiwgTEYsCiAgb3IgQ1JMRikuICBBbHNvLCB0aGUgSGVhZGVyIGNsYXNzJ3MgY29uc3RydWN0b3IgZGVmYXVsdCBhcmd1bWVudHMKICBoYXMgY2hhbmdlZCBzbGlnaHRseSBzbyB0aGF0IGFuIGV4cGxpY2l0IG1heGxpbmVsZW4gdmFsdWUgaXMgYWx3YXlzCiAgaG9ub3JlZC4KClRvb2xzL0RlbW9zCgotIElETEUgc3VwcG9ydHMgdGhlIG5ldyBlbmNvZGluZyBkZWNsYXJhdGlvbnMgKFBFUCAyNjMpOyBpdCBjYW4gYWxzbwogIGRlYWwgd2l0aCBsZWdhY3kgOC1iaXQgZmlsZXMgaWYgdGhleSB1c2UgdGhlIGxvY2FsZSdzIGVuY29kaW5nLiBJdAogIGFsbG93cyBub24tQVNDSUkgc3RyaW5ncyBpbiB0aGUgaW50ZXJhY3RpdmUgc2hlbGwgYW5kIGV4ZWN1dGVzIHRoZW0KICBpbiB0aGUgbG9jYWxlJ3MgZW5jb2RpbmcuCgotIGZyZWV6ZS5weSBub3cgcHJvZHVjZXMgYmluYXJpZXMgd2hpY2ggY2FuIGltcG9ydCBzaGFyZWQgbW9kdWxlcywKICB1bmxpa2UgYmVmb3JlIHdoZW4gdGhpcyBmYWlsZWQgZHVlIHRvIG1pc3Npbmcgc3ltYm9sIGV4cG9ydHMgaW4KICB0aGUgZ2VuZXJhdGVkIGJpbmFyeS4KCkJ1aWxkCgotIFRoZSBwdWJsaWMgUHl0aG9uIEMgQVBJIHdpbGwgZ2VuZXJhbGx5IGJlIGRlY2xhcmVkIHVzaW5nIFB5QVBJX0ZVTkMKICAgYW5kIFB5QVBJX0RBVEEgbWFjcm9zLCB3aGlsZSBQeXRob24gZXh0ZW5zaW9uIG1vZHVsZSBpbml0IGZ1bmN0aW9ucwogICB3aWxsIGJlIGRlY2xhcmVkIHdpdGggUHlNT0RJTklUX0ZVTkMuICBETF9FWFBPUlQvRExfSU1QT1JUIG1hY3JvcwogICBhcmUgZGVwcmVjYXRlZC4KCi0gQSBidWcgd2FzIGZpeGVkIHRoYXQgY291bGQgY2F1c2UgQ09VTlRfQUxMT0NTIGJ1aWxkcyB0byBzZWdmYXVsdCwgb3IKICBnZXQgaW50byBpbmZpbml0ZSBsb29wcywgd2hlbiBhIG5ldy1zdHlsZSBjbGFzcyBnb3QgZ2FyYmFnZS1jb2xsZWN0ZWQuCiAgVW5mb3J0dW5hdGVseSwgdG8gYXZvaWQgdGhpcywgdGhlIHdheSBDT1VOVF9BTExPQ1Mgd29ya3MgcmVxdWlyZXMKICB0aGF0IG5ldy1zdHlsZSBjbGFzc2VzIGJlIGltbW9ydGFsIGluIENPVU5UX0FMTE9DUyBidWlsZHMuICBOb3RlIHRoYXQKICBDT1VOVF9BTExPQ1MgaXMgbm90IGVuYWJsZWQgYnkgZGVmYXVsdCwgaW4gZWl0aGVyIHJlbGVhc2Ugb3IgZGVidWcKICBidWlsZHMsIGFuZCB0aGF0IG5ldy1zdHlsZSBjbGFzc2VzIGFyZSBpbW1vcnRhbCBvbmx5IGluIENPVU5UX0FMTE9DUwogIGJ1aWxkcy4KCi0gQ29tcGlsaW5nIG91dCB0aGUgY3ljbGljIGdhcmJhZ2UgY29sbGVjdG9yIGlzIG5vIGxvbmdlciBhbiBvcHRpb24uCiAgVGhlIG9sZCBzeW1ib2wgV0lUSF9DWUNMRV9HQyBpcyBub3cgaWdub3JlZCwgYW5kIFB5dGhvbi5oIGFycmFuZ2VzCiAgdGhhdCBpdCdzIGFsd2F5cyBkZWZpbmVkIChmb3IgdGhlIGJlbmVmaXQgb2YgYW55IGV4dGVuc2lvbiBtb2R1bGVzCiAgdGhhdCBtYXkgYmUgY29uZGl0aW9uYWxpemluZyBvbiBpdCkuICBBIGJvbnVzIGlzIHRoYXQgYW55IGV4dGVuc2lvbgogIHR5cGUgcGFydGljaXBhdGluZyBpbiBjeWNsaWMgZ2MgY2FuIGNob29zZSB0byBwYXJ0aWNpcGF0ZSBpbiB0aGUKICBQeV9UUkFTSENBTiBtZWNoYW5pc20gbm93IHRvbzsgaW4gdGhlIGFic2VuY2Ugb2YgY3ljbGljIGdjLCB0aGlzIHVzZWQKICB0byByZXF1aXJlIGVkaXRpbmcgdGhlIGNvcmUgdG8gdGVhY2ggdGhlIHRyYXNoY2FuIG1lY2hhbmlzbSBhYm91dCB0aGUKICBuZXcgdHlwZS4KCi0gQWNjb3JkaW5nIHRvIEFubmV4IEYgb2YgdGhlIGN1cnJlbnQgQyBzdGFuZGFyZCwKCiAgICBUaGUgU3RhbmRhcmQgQyBtYWNybyBIVUdFX1ZBTCBhbmQgaXRzIGZsb2F0IGFuZCBsb25nIGRvdWJsZSBhbmFsb2dzLAogICAgSFVHRV9WQUxGIGFuZCBIVUdFX1ZBTEwsIGV4cGFuZCB0byBleHByZXNzaW9ucyB3aG9zZSB2YWx1ZXMgYXJlCiAgICBwb3NpdGl2ZSBpbmZpbml0aWVzLgoKICBQeXRob24gb25seSB1c2VzIHRoZSBkb3VibGUgSFVHRV9WQUwsIGFuZCBvbmx5IHRvICNkZWZpbmUgaXRzIG93biBzeW1ib2wKICBQeV9IVUdFX1ZBTC4gIFNvbWUgcGxhdGZvcm1zIGhhdmUgaW5jb3JyZWN0IGRlZmluaXRpb25zIGZvciBIVUdFX1ZBTC4KICBweXBvcnQuaCB1c2VkIHRvIHRyeSB0byB3b3JtIGFyb3VuZCB0aGF0LCBidXQgdGhlIHdvcmthcm91bmRzIHRyaWdnZXJlZAogIG90aGVyIGJ1Z3Mgb24gb3RoZXIgcGxhdGZvcm1zLCBzbyB3ZSBnYXZlIHVwLiAgSWYgeW91ciBwbGF0Zm9ybSBkZWZpbmVzCiAgSFVHRV9WQUwgaW5jb3JyZWN0bHksIHlvdSdsbCBuZWVkIHRvICNkZWZpbmUgUHlfSFVHRV9WQUwgdG8gc29tZXRoaW5nCiAgdGhhdCB3b3JrcyBvbiB5b3VyIHBsYXRmb3JtLiAgVGhlIG9ubHkgaW5zdGFuY2Ugb2YgdGhpcyBJJ20gc3VyZSBhYm91dAogIGlzIG9uIGFuIHVua25vd24gc3Vic2V0IG9mIENyYXkgc3lzdGVtcywgZGVzY3JpYmVkIGhlcmU6CgogIGh0dHA6Ly93d3cuY3JheS5jb20vc3dwdWJzL21hbnVhbHMvU04tMjE5NF8yLjAvaHRtbC1TTi0yMTk0XzIuMC94MzEzOC5odG0KCiAgUHJlc3VtYWJseSAyLjNhMSBicmVha3Mgc3VjaCBzeXN0ZW1zLiAgSWYgYW55b25lIHVzZXMgc3VjaCBhIHN5c3RlbSwgaGVscCEKCi0gVGhlIGNvbmZpZ3VyZSBvcHRpb24gLS13aXRob3V0LWRvYy1zdHJpbmdzIGNhbiBiZSB1c2VkIHRvIHJlbW92ZSB0aGUKICBkb2Mgc3RyaW5ncyBmcm9tIHRoZSBidWlsdGluIGZ1bmN0aW9ucyBhbmQgbW9kdWxlczsgdGhpcyByZWR1Y2VzIHRoZQogIHNpemUgb2YgdGhlIGV4ZWN1dGFibGUuCgotIFRoZSB1bml2ZXJzYWwgbmV3bGluZXMgb3B0aW9uIChQRVAgMjc4KSBpcyBvbiBieSBkZWZhdWx0LiAgT24gVW5peAogIGl0IGNhbiBiZSBkaXNhYmxlZCBieSBwYXNzaW5nIC0td2l0aG91dC11bml2ZXJzYWwtbmV3bGluZXMgdG8gdGhlCiAgY29uZmlndXJlIHNjcmlwdC4gIE9uIG90aGVyIHBsYXRmb3JtcywgcmVtb3ZlCiAgV0lUSF9VTklWRVJTQUxfTkVXTElORVMgZnJvbSBweWNvbmZpZy5oLgoKLSBPbiBVbml4LCBhIHNoYXJlZCBsaWJweXRob24yLjMuc28gY2FuIGJlIGNyZWF0ZWQgd2l0aCAtLWVuYWJsZS1zaGFyZWQuCgotIEFsbCB1c2VzIG9mIHRoZSBDQUNIRV9IQVNILCBJTlRFUk5fU1RSSU5HUywgYW5kIERPTlRfU0hBUkVfU0hPUlRfU1RSSU5HUwogIHByZXByb2Nlc3NvciBzeW1ib2xzIHdlcmUgZWxpbWluYXRlZC4gIFRoZSBpbnRlcm5hbCBkZWNpc2lvbnMgdGhleQogIGNvbnRyb2xsZWQgc3RvcHBlZCBiZWluZyBleHBlcmltZW50YWwgbG9uZyBhZ28uCgotIFRoZSB0b29scyB1c2VkIHRvIGJ1aWxkIHRoZSBkb2N1bWVudGF0aW9uIG5vdyB3b3JrIHVuZGVyIEN5Z3dpbiBhcwogIHdlbGwgYXMgVW5peC4KCi0gVGhlIGJzZGRiIGFuZCBkYm0gbW9kdWxlIGJ1aWxkcyBoYXZlIGJlZW4gY2hhbmdlZCB0byB0cnkgYW5kIGF2b2lkIHZlcnNpb24KICBza2V3IHByb2JsZW1zIGFuZCBkaXNhYmxlIGxpbmthZ2Ugd2l0aCBCZXJrZWxleSBEQiAxLjg1IHVubGVzcyB0aGUKICBpbnN0YWxsZXIga25vd3Mgd2hhdCBzL2hlJ3MgZG9pbmcuICBTZWUgdGhlIHNlY3Rpb24gb24gYnVpbGRpbmcgdGhlc2UKICBtb2R1bGVzIGluIHRoZSBSRUFETUUgZmlsZSBmb3IgZGV0YWlscy4KCkMgQVBJCgotIFRoZSBzdHJpbmcgb2JqZWN0J3MgbGF5b3V0IGhhcyBjaGFuZ2VkOiB0aGUgcG9pbnRlciBtZW1iZXIKICBvYl9zaW50ZXJuZWQgaGFzIGJlZW4gcmVwbGFjZWQgYnkgYW4gaW50IG1lbWJlciBvYl9zc3RhdGUuICBPbiBzb21lCiAgcGxhdGZvcm1zIChlLmcuIG1vc3QgNjQtYml0IHN5c3RlbXMpIHRoaXMgbWF5IGNoYW5nZSB0aGUgb2Zmc2V0IG9mCiAgdGhlIG9iX3N2YWwgbWVtYmVyLCBzbyBhcyBhIHByZWNhdXRpb24gdGhlIEFQSV9WRVJTSU9OIGhhcyBiZWVuCiAgaW5jcmVtZW50ZWQuICBUaGUgYXBwYXJlbnRseSB1bnVzZWQgZmVhdHVyZSBvZiAiaW5kaXJlY3QgaW50ZXJuZWQKICBzdHJpbmdzIiwgc3VwcG9ydGVkIGJ5IHRoZSBvYl9zaW50ZXJuZWQgbWVtYmVyLCBpcyBnb25lLiAgSW50ZXJuZWQKICBzdHJpbmdzIGFyZSBub3cgdXN1YWxseSBtb3J0YWw7IHRoZXJlcyBhIG5ldyBBUEksCiAgUHlTdHJpbmdfSW50ZXJuSW1tb3J0YWwoKSB0aGF0IGNyZWF0ZXMgaW1tb3J0YWwgaW50ZXJuZWQgc3RyaW5ncy4KICAoVGhlIG9iX3NzdGF0ZSBtZW1iZXIgY2FuIG9ubHkgdGFrZSB0aHJlZSB2YWx1ZXM7IGhvd2V2ZXIsIHdoaWxlCiAgbWFraW5nIGl0IGEgY2hhciBzYXZlcyBhIGZldyBieXRlcyBwZXIgc3RyaW5nIG9iamVjdCBvbiBhdmVyYWdlLCBpbgogIGl0IGFsc28gc2xvd2VkIHRoaW5ncyBkb3duIGEgYml0IGJlY2F1c2Ugb2Jfc3ZhbCB3YXMgbm8gbG9uZ2VyCiAgYWxpZ25lZC4pCgotIFRoZSBQeV9Jbml0TW9kdWxlKigpIGZ1bmN0aW9ucyBub3cgYWNjZXB0IE5VTEwgZm9yIHRoZSAnbWV0aG9kcycKICBhcmd1bWVudC4gIE1vZHVsZXMgd2l0aG91dCBnbG9iYWwgZnVuY3Rpb25zIGFyZSBiZWNvbWluZyBtb3JlIGNvbW1vbgogIG5vdyB0aGF0IGZhY3RvcmllcyBjYW4gYmUgdHlwZXMgcmF0aGVyIHRoYW4gZnVuY3Rpb25zLgoKLSBOZXcgQyBBUEkgUHlVbmljb2RlX0Zyb21PcmRpbmFsKCkgd2hpY2ggZXhwb3NlcyB1bmljaHIoKSBhdCBDCiAgbGV2ZWwuCgotIE5ldyBmdW5jdGlvbnMgUHlFcnJfU2V0RXhjRnJvbVdpbmRvd3NFcnIoKSBhbmQKICBQeUVycl9TZXRFeGNGcm9tV2luZG93c0VycldpdGhGaWxlbmFtZSgpLiBTaW1pbGFyIHRvCiAgUHlFcnJfU2V0RnJvbVdpbmRvd3NFcnJXaXRoRmlsZW5hbWUoKSBhbmQKICBQeUVycl9TZXRGcm9tV2luZG93c0VycigpLCBidXQgdGhleSBhbGxvdyB0byBzcGVjaWZ5CiAgdGhlIGV4Y2VwdGlvbiB0eXBlIHRvIHJhaXNlLiBBdmFpbGFibGUgb24gV2luZG93cy4KCi0gUHlfRmF0YWxFcnJvcigpIGlzIG5vdyBkZWNsYXJlZCBhcyB0YWtpbmcgYSBjb25zdCBjaGFyKiBhcmd1bWVudC4gIEl0CiAgd2FzIHByZXZpb3VzbHkgZGVjbGFyZWQgd2l0aG91dCBjb25zdC4gIFRoaXMgc2hvdWxkIG5vdCBhZmZlY3Qgd29ya2luZwogIGNvZGUuCgotIEFkZGVkIG5ldyBtYWNybyBQeVNlcXVlbmNlX0lURU0obywgaSkgdGhhdCBkaXJlY3RseSBjYWxscwogIHNxX2l0ZW0gd2l0aG91dCByZWNoZWNraW5nIHRoYXQgbyBpcyBhIHNlcXVlbmNlIGFuZCB3aXRob3V0CiAgYWRqdXN0aW5nIGZvciBuZWdhdGl2ZSBpbmRpY2VzLgoKLSBQeVJhbmdlX05ldygpIG5vdyByYWlzZXMgVmFsdWVFcnJvciBpZiB0aGUgZm91cnRoIGFyZ3VtZW50IGlzIG5vdCAxLgogIFRoaXMgaXMgcGFydCBvZiB0aGUgcmVtb3ZhbCBvZiBkZXByZWNhdGVkIGZlYXR1cmVzIG9mIHRoZSB4cmFuZ2UKICBvYmplY3QuCgotIFB5TnVtYmVyX0NvZXJjZSgpIGFuZCBQeU51bWJlcl9Db2VyY2VFeCgpIG5vdyBhbHNvIGludm9rZSB0aGUgdHlwZSdzCiAgY29lcmNpb24gaWYgYm90aCBhcmd1bWVudHMgaGF2ZSB0aGUgc2FtZSB0eXBlIGJ1dCB0aGlzIHR5cGUgaGFzIHRoZQogIENIRUNLVFlQRVMgZmxhZyBzZXQuICBUaGlzIGlzIHRvIGJldHRlciBzdXBwb3J0IHByb3hpZXMuCgotIFRoZSB0eXBlIG9mIHRwX2ZyZWUgaGFzIGJlZW4gY2hhbmdlZCBmcm9tICJ2b2lkICgqKShQeU9iamVjdCAqKSIgdG8KICAidm9pZCAoKikodm9pZCAqKSIuCgotIFB5T2JqZWN0X0RlbCwgUHlPYmplY3RfR0NfRGVsIGFyZSBub3cgZnVuY3Rpb25zIGluc3RlYWQgb2YgbWFjcm9zLgoKLSBBIHR5cGUgY2FuIG5vdyBpbmhlcml0IGl0cyBtZXRhdHlwZSBmcm9tIGl0cyBiYXNlIHR5cGUuICBQcmV2aW91c2x5LAogIHdoZW4gUHlUeXBlX1JlYWR5KCkgd2FzIGNhbGxlZCwgaWYgb2JfdHlwZSB3YXMgZm91bmQgdG8gYmUgTlVMTCwgaXQKICB3YXMgYWx3YXlzIHNldCB0byAmUHlUeXBlX1R5cGU7IG5vdyBpdCBpcyBzZXQgdG8gYmFzZS0+b2JfdHlwZSwKICB3aGVyZSBiYXNlIGlzIHRwX2Jhc2UsIGRlZmF1bHRpbmcgdG8gJlB5T2JqZWN0X1R5cGUuCgotIFB5VHlwZV9SZWFkeSgpIGFjY2lkZW50YWxseSBkaWQgbm90IGluaGVyaXQgdHBfaXNfZ2M7IG5vdyBpdCBkb2VzLgoKLSBUaGUgUHlDb3JlXyogZmFtaWx5IG9mIEFQSXMgaGF2ZSBiZWVuIHJlbW92ZWQuCgotIFRoZSAidSMiIHBhcnNlciBtYXJrZXIgd2lsbCBub3cgcGFzcyB0aHJvdWdoIFVuaWNvZGUgb2JqZWN0cyBhcy1pcwogIHdpdGhvdXQgZ29pbmcgdGhyb3VnaCB0aGUgYnVmZmVyIEFQSS4KCi0gVGhlIGVudW1lcmF0b3JzIG9mIGNtcF9vcCBoYXZlIGJlZW4gcmVuYW1lZCB0byB1c2UgdGhlIHByZWZpeCBQeUNtcF8uCgotIEFuIG9sZCAjZGVmaW5lIG9mIEFOWSBhcyB2b2lkIGhhcyBiZWVuIHJlbW92ZWQgZnJvbSBweXBvcnQuaC4gIFRoaXMKICBoYXNuJ3QgYmVlbiB1c2VkIHNpbmNlIFB5dGhvbidzIHByZS1BTlNJIGRheXMsIGFuZCB0aGUgI2RlZmluZSBoYXMKICBiZWVuIG1hcmtlZCBhcyBvYnNvbGV0ZSBzaW5jZSB0aGVuLiAgU0YgYnVnIDQ5NTU0OCBzYXlzIGl0IGNyZWF0ZWQKICBjb25mbGljdHMgd2l0aCBvdGhlciBwYWNrYWdlcywgc28ga2VlcGluZyBpdCBhcm91bmQgd2Fzbid0IGhhcm1sZXNzLgoKLSBCZWNhdXNlIFB5dGhvbidzIG1hZ2ljIG51bWJlciBzY2hlbWUgYnJva2Ugb24gSmFudWFyeSAxc3QsIHdlIGRlY2lkZWQKICB0byBzdG9wIFB5dGhvbiBkZXZlbG9wbWVudC4gIFRoYW5rcyBmb3IgYWxsIHRoZSBmaXNoIQoKLSBTb21lIG9mIHVzIGRvbid0IGxpa2UgZmlzaCwgc28gd2UgY2hhbmdlZCBQeXRob24ncyBtYWdpYyBudW1iZXIKICBzY2hlbWUgdG8gYSBuZXcgb25lLiBTZWUgUHl0aG9uL2ltcG9ydC5jIGZvciBkZXRhaWxzLgoKTmV3IHBsYXRmb3JtcwoKLSBBdGhlT1MgaXMgbm93IHN1cHBvcnRlZC4KCi0gdGhlIEVNWCBydW50aW1lIGVudmlyb25tZW50IG9uIE9TLzIgaXMgbm93IHN1cHBvcnRlZC4KCi0gR05VL0h1cmQgaXMgbm93IHN1cHBvcnRlZC4KClRlc3RzCgpXaW5kb3dzCgotIFNvbWV0aW1lcyB0aGUgdW5pbnN0YWxsIGV4ZWN1dGFibGUgKFVOV0lTRS5FWEUpIHZhbmlzaGVzLiAgT25lIGNhdXNlCiAgb2YgdGhhdCBoYXMgYmVlbiBmaXhlZCBpbiB0aGUgaW5zdGFsbGVyIChkaXNhYmxlZCBXaXNlJ3MgImRlbGV0ZSBpbi0KICB1c2UgZmlsZXMiIHVuaW5zdGFsbCBvcHRpb24pLgoKLSBGaXhlZCBhIGJ1ZyBpbiB1cmxsaWIncyBwcm94eSBoYW5kbGluZyBpbiBXaW5kb3dzLiAgW1NGIGJ1ZyAjNTAzMDMxXQoKLSBUaGUgaW5zdGFsbGVyIG5vdyBpbnN0YWxscyBTdGFydCBtZW51IHNob3J0Y3V0cyB1bmRlciAodGhlIGxvY2FsCiAgZXF1aXZhbGVudCBvZikgIkFsbCBVc2VycyIgd2hlbiBkb2luZyBhbiBBZG1pbiBpbnN0YWxsLgoKLSBmaWxlLnRydW5jYXRlKFtuZXdzaXplXSkgbm93IHdvcmtzIG9uIFdpbmRvd3MgZm9yIGFsbCBuZXdzaXplIHZhbHVlcy4KICBJdCB1c2VkIHRvIGZhaWwgaWYgbmV3c2l6ZSBkaWRuJ3QgZml0IGluIDMyIGJpdHMsIHJlZmxlY3RpbmcgYQogIGxpbWl0YXRpb24gb2YgTVMgX2Noc2l6ZSAod2hpY2ggaXMgbm8gbG9uZ2VyIHVzZWQpLgoKLSBvcy53YWl0cGlkKCkgaXMgbm93IGltcGxlbWVudGVkIGZvciBXaW5kb3dzLCBhbmQgY2FuIGJlIHVzZWQgdG8gYmxvY2sKICB1bnRpbCBhIHNwZWNpZmllZCBwcm9jZXNzIGV4aXRzLiAgVGhpcyBpcyBzaW1pbGFyIHRvLCBidXQgbm90IGV4YWN0bHkKICB0aGUgc2FtZSBhcywgb3Mud2FpdHBpZCgpIG9uIFBPU0lYIHN5c3RlbXMuICBJZiB5b3UncmUgd2FpdGluZyBmb3IKICBhIHNwZWNpZmljIHByb2Nlc3Mgd2hvc2UgcGlkIHdhcyBvYnRhaW5lZCBmcm9tIG9uZSBvZiB0aGUgc3Bhd24oKQogIGZ1bmN0aW9ucywgdGhlIHNhbWUgUHl0aG9uIG9zLndhaXRwaWQoKSBjb2RlIHdvcmtzIGFjcm9zcyBwbGF0Zm9ybXMuCiAgU2VlIHRoZSBkb2NzIGZvciBkZXRhaWxzLiAgVGhlIGRvY3Mgd2VyZSBjaGFuZ2VkIHRvIGNsYXJpZnkgdGhhdAogIHNwYXduIGZ1bmN0aW9ucyByZXR1cm4sIGFuZCB3YWl0cGlkIHJlcXVpcmVzLCBhIHByb2Nlc3MgaGFuZGxlIG9uCiAgV2luZG93cyAobm90IHRoZSBzYW1lIHRoaW5nIGFzIGEgV2luZG93cyBwcm9jZXNzIGlkKS4KCi0gTmV3IHRlbXBmaWxlLlRlbXBvcmFyeUZpbGUgaW1wbGVtZW50YXRpb24gZm9yIFdpbmRvd3M6ICB0aGlzIGRvZXNuJ3QKICBuZWVkIGEgVGVtcG9yYXJ5RmlsZVdyYXBwZXIgd3JhcHBlciBhbnltb3JlLCBhbmQgc2hvdWxkIGJlIGltbXVuZQogIHRvIGEgbmFzdHkgcHJvYmxlbTogIGJlZm9yZSAyLjMsIGlmIHlvdSBnb3QgYSB0ZW1wIGZpbGUgb24gV2luZG93cywgaXQKICBnb3Qgd3JhcHBlZCBpbiBhbiBvYmplY3Qgd2hvc2UgY2xvc2UoKSBtZXRob2QgZmlyc3QgY2xvc2VkIHRoZQogIHVuZGVybHlpbmcgZmlsZSwgdGhlbiBkZWxldGVkIHRoZSBmaWxlLiAgVGhpcyB1c3VhbGx5IHdvcmtlZCBmaW5lLgogIEhvd2V2ZXIsIHRoZSBzcGF3biBmYW1pbHkgb2YgZnVuY3Rpb25zIG9uIFdpbmRvd3MgY3JlYXRlIChhdCBhIGxvdyBDCiAgbGV2ZWwpIHRoZSBzYW1lIHNldCBvZiBvcGVuIGZpbGVzIGluIHRoZSBzcGF3bmVkIHByb2Nlc3MgUSBhcyB3ZXJlCiAgb3BlbiBpbiB0aGUgc3Bhd25pbmcgcHJvY2VzcyBQLiAgSWYgYSB0ZW1wIGZpbGUgZiB3YXMgYW1vbmcgdGhlbSwgdGhlbgogIGRvaW5nIGYuY2xvc2UoKSBpbiBQIGZpcnN0IGNsb3NlZCBQJ3MgQy1sZXZlbCBmaWxlIGhhbmRsZSBvbiBmLCBidXQgUSdzCiAgQy1sZXZlbCBmaWxlIGhhbmRsZSBvbiBmIHJlbWFpbmVkIG9wZW4sIHNvIHRoZSBhdHRlbXB0IGluIFAgdG8gZGVsZXRlIGYKICBibGV3IHVwIHdpdGggYSAiUGVybWlzc2lvbiBkZW5pZWQiIGVycm9yIChXaW5kb3dzIGRvZXNuJ3QgYWxsb3cKICBkZWxldGluZyBvcGVuIGZpbGVzKS4gIFRoaXMgd2FzIHN1cnByaXNpbmcsIHN1YnRsZSwgYW5kIGRpZmZpY3VsdCB0bwogIHdvcmsgYXJvdW5kLgoKLSBUaGUgb3MgbW9kdWxlIG5vdyBleHBvcnRzIGFsbCB0aGUgc3ltYm9saWMgY29uc3RhbnRzIHVzYWJsZSB3aXRoIHRoZQogIGxvdy1sZXZlbCBvcy5vcGVuKCkgb24gV2luZG93czogIHRoZSBuZXcgY29uc3RhbnRzIGluIDIuMyBhcmUKICBPX05PSU5IRVJJVCwgT19TSE9SVF9MSVZFRCwgT19URU1QT1JBUlksIE9fUkFORE9NIGFuZCBPX1NFUVVFTlRJQUwuCiAgVGhlIG90aGVycyB3ZXJlIGFsc28gYXZhaWxhYmxlIGluIDIuMjogIE9fQVBQRU5ELCBPX0JJTkFSWSwgT19DUkVBVCwKICBPX0VYQ0wsIE9fUkRPTkxZLCBPX1JEV1IsIE9fVEVYVCwgT19UUlVOQyBhbmQgT19XUk9OTFkuICBDb250cmFyeQogIHRvIE1pY3Jvc29mdCBkb2NzLCBPX1NIT1JUX0xJVkVEIGRvZXMgbm90IHNlZW0gdG8gaW1wbHkgT19URU1QT1JBUlkKICAoc28gc3BlY2lmeSBib3RoIGlmIHlvdSB3YW50IGJvdGg7IG5vdGUgdGhhdCBuZWl0aGVyIGlzIHVzZWZ1bCB1bmxlc3MKICBzcGVjaWZpZWQgd2l0aCBPX0NSRUFUIHRvbykuCgpNYWMKCgpXaGF0J3MgTmV3IGluIFB5dGhvbiAyLjIgZmluYWw/ClJlbGVhc2UgZGF0ZTogMjEtRGVjLTIwMDEKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKVHlwZS9jbGFzcyB1bmlmaWNhdGlvbiBhbmQgbmV3LXN0eWxlIGNsYXNzZXMKCi0gcGlja2xlLnB5LCBjUGlja2xlOiBhbGxvdyBwaWNrbGluZyBpbnN0YW5jZXMgb2YgbmV3LXN0eWxlIGNsYXNzZXMKICB3aXRoIGEgY3VzdG9tIG1ldGFjbGFzcy4KCkNvcmUgYW5kIGJ1aWx0aW5zCgotIHdlYWtyZWYgcHJveHkgb2JqZWN0OiB3aGVuIGNvbXBhcmluZywgdW53cmFwIGJvdGggYXJndW1lbnRzIGlmIGJvdGgKICBhcmUgcHJveGllcy4KCkV4dGVuc2lvbiBtb2R1bGVzCgotIGJpbmFzY2lpLmIyYV9iYXNlNjQoKTogZml4IGEgcG90ZW50aWFsIGJ1ZmZlciBvdmVycnVuIHdoZW4gZW5jb2RpbmcKICB2ZXJ5IHNob3J0IHN0cmluZ3MuCgotIGNQaWNrbGU6IHRoZSBvYnNjdXJlICJmYXN0IiBtb2RlIHdhcyBzdXNwZWN0ZWQgb2YgY2F1c2luZyBzdGFjawogIG92ZXJmbG93cyBvbiB0aGUgTWFjLiAgSG9wZWZ1bGx5IGZpeGVkIHRoaXMgYnkgc2V0dGluZyB0aGUgcmVjdXJzaW9uCiAgbGltaXQgbXVjaCBzbWFsbGVyLiAgSWYgdGhlIGxpbWl0IGlzIHRvbyBsb3cgKGl0IG9ubHkgYWZmZWN0cwogIHBlcmZvcm1hbmNlKSwgeW91IGNhbiBjaGFuZ2UgaXQgYnkgZGVmaW5pbmcgUFlfQ1BJQ0tMRV9GQVNUX0xJTUlUCiAgd2hlbiBjb21waWxpbmcgY1BpY2tsZS5jIChvciBpbiBweWNvbmZpZy5oKS4KCkxpYnJhcnkKCi0gZHVtYmRibS5weTogZml4ZWQgYSBkdW1iIG9sZCBidWcgKHRoZSBmaWxlIGRpZG4ndCBnZXQgc3luY2hlZCBhdAogIGNsb3NlIG9yIGRlbGV0ZSB0aW1lKS4KCi0gcmZjODIyLnB5OiBmaXhlZCBhIGJ1ZyB3aGVyZSB0aGUgYWRkcmVzcyAnPD4nIHdhcyBjb252ZXJ0ZWQgdG8gTm9uZQogIGluc3RlYWQgb2YgYW4gZW1wdHkgc3RyaW5nIChhbHNvIGZpeGVzIHRoZSBlbWFpbC5VdGlscyBtb2R1bGUpLgoKLSB4bWxycGNsaWIucHk6IHZlcnNpb24gMS4wLjA7IHVzZXMgcHJlY2lzaW9uIGZvciBkb3VibGVzLgoKLSB0ZXN0IHN1aXRlOiB0aGUgcGlja2xlIGFuZCBjUGlja2xlIHRlc3RzIHdlcmUgbm90IGV4ZWN1dGluZyBhbnkgY29kZQogIHdoZW4gcnVuIGZyb20gdGhlIHN0YW5kYXJkIHJlZ3Jlc3Npb24gdGVzdC4KClRvb2xzL0RlbW9zCgpCdWlsZAoKQyBBUEkKCk5ldyBwbGF0Zm9ybXMKClRlc3RzCgpXaW5kb3dzCgotIGRpc3R1dGlscyBwYWNrYWdlOiBmaXhlZCBicm9rZW4gV2luZG93cyBpbnN0YWxsZXJzIChiZGlzdF93aW5pbnN0KS4KCi0gdGVtcGZpbGUucHk6IHByZXZlbnQgbXlzdGVyaW91cyB3YXJuaW5ncyB3aGVuIFRlbXBvcmFyeUZpbGVXcmFwcGVyCiAgaW5zdGFuY2VzIGFyZSBkZWxldGVkIGF0IHByb2Nlc3MgZXhpdCB0aW1lLgoKLSBzb2NrZXQucHk6IHByZXZlbnQgbXlzdGVyaW91cyB3YXJuaW5ncyB3aGVuIHNvY2tldCBpbnN0YW5jZXMgYXJlCiAgZGVsZXRlZCBhdCBwcm9jZXNzIGV4aXQgdGltZS4KCi0gcG9zaXhtb2R1bGUuYzogZml4IGEgV2luZG93cyBjcmFzaCB3aXRoIHN0YXQoKSBvZiBhIGZpbGVuYW1lIGVuZGluZwogIGluIGJhY2tzbGFzaC4KCk1hYwoKLSBUaGUgQ2FyYm9uIHRvb2xib3ggbW9kdWxlcyBoYXZlIGJlZW4gdXBncmFkZWQgdG8gVW5pdmVyc2FsIEhlYWRlcnMKICAzLjQsIGFuZCBleHBlcmltZW50YWwgQ29yZUdyYXBoaWNzIGFuZCBDYXJib25FdmVudHMgbW9kdWxlcyBoYXZlCiAgYmVlbiBhZGRlZC4gIEFsbCBvbmx5IGZvciBmcmFtZXdvcmstZW5hYmxlZCBNYWNPU1guCgoKV2hhdCdzIE5ldyBpbiBQeXRob24gMi4yYzE/ClJlbGVhc2UgZGF0ZTogMTQtRGVjLTIwMDEKPT09PT09PT09PT09PT09PT09PT09PT09PT09CgpUeXBlL2NsYXNzIHVuaWZpY2F0aW9uIGFuZCBuZXctc3R5bGUgY2xhc3NlcwoKLSBHdWlkbydzIHR1dG9yaWFsIGludHJvZHVjdGlvbiB0byB0aGUgbmV3IHR5cGUvY2xhc3MgZmVhdHVyZXMgaGFzCiAgYmVlbiBleHRlbnNpdmVseSB1cGRhdGVkLiAgU2VlCgogICAgICBodHRwOi8vd3d3LnB5dGhvbi5vcmcvMi4yL2Rlc2NyaW50cm8uaHRtbAoKICBUaGF0IHJlbWFpbnMgdGhlIHByaW1hcnkgZG9jdW1lbnRhdGlvbiBpbiB0aGlzIGFyZWEuCgotIEZpeGVkIGEgbGVhazogaW5zdGFuY2UgdmFyaWFibGVzIGRlY2xhcmVkIHdpdGggX19zbG90c19fIHdlcmUgbmV2ZXIKICBkZWxldGVkIQoKLSBUaGUgImRlbGV0ZSBhdHRyaWJ1dGUiIG1ldGhvZCBvZiBkZXNjcmlwdG9yIG9iamVjdHMgaXMgY2FsbGVkCiAgX19kZWxldGVfXywgbm90IF9fZGVsX18uICBJbiBwcmV2aW91cyByZWxlYXNlcywgaXQgd2FzIG1pc3Rha2VubHkKICBjYWxsZWQgX19kZWxfXywgd2hpY2ggY3JlYXRlZCBhbiB1bmZvcnR1bmF0ZSBvdmVybG9hZGluZyBjb25kaXRpb24KICB3aXRoIGZpbmFsaXplcnMuICAoVGhlICJnZXQgYXR0cmlidXRlIiBhbmQgInNldCBhdHRyaWJ1dGUiIG1ldGhvZHMKICBhcmUgc3RpbGwgY2FsbGVkIF9fZ2V0X18gYW5kIF9fc2V0X18sIHJlc3BlY3RpdmVseS4pCgotIFNvbWUgc3VidGxlIGlzc3VlcyB3aXRoIHRoZSBzdXBlciBidWlsdC1pbiB3ZXJlIGZpeGVkOgoKICAoYSkgV2hlbiBzdXBlciBpdHNlbGYgaXMgc3ViY2xhc3NlZCwgaXRzIF9fZ2V0X18gbWV0aG9kIHdvdWxkIHN0aWxsCiAgICAgIHJldHVybiBhbiBpbnN0YW5jZSBvZiB0aGUgYmFzZSBjbGFzcyAoaS5lLiwgb2Ygc3VwZXIpLgoKICAoYikgc3VwZXIoQywgQygpKS5fX2NsYXNzX18gd291bGQgcmV0dXJuIEMgcmF0aGVyIHRoYW4gc3VwZXIuICBUaGlzCiAgICAgIGlzIGNvbmZ1c2luZy4gIFRvIGZpeCB0aGlzLCBJIGRlY2lkZWQgdG8gY2hhbmdlIHRoZSBzZW1hbnRpY3Mgb2YKICAgICAgc3VwZXIgc28gdGhhdCBpdCBvbmx5IGFwcGxpZXMgdG8gY29kZSBhdHRyaWJ1dGVzLCBub3QgdG8gZGF0YQogICAgICBhdHRyaWJ1dGVzLiAgQWZ0ZXIgYWxsLCBvdmVycmlkaW5nIGRhdGEgYXR0cmlidXRlcyBpcyBub3QKICAgICAgc3VwcG9ydGVkIGFueXdheS4KCiAgKGMpIFRoZSBfX2dldF9fIG1ldGhvZCBkaWRuJ3QgY2hlY2sgd2hldGhlciB0aGUgYXJndW1lbnQgd2FzIGFuCiAgICAgIGluc3RhbmNlIG9mIHRoZSB0eXBlIHVzZWQgaW4gY3JlYXRpb24gb2YgdGhlIHN1cGVyIGluc3RhbmNlLgoKLSBQcmV2aW91c2x5LCBoYXNoKCkgb2YgYW4gaW5zdGFuY2Ugb2YgYSBzdWJjbGFzcyBvZiBhIG11dGFibGUgdHlwZQogIChsaXN0IG9yIGRpY3Rpb25hcnkpIHdvdWxkIHJldHVybiBzb21lIHZhbHVlLCByYXRoZXIgdGhhbiByYWlzaW5nCiAgVHlwZUVycm9yLiAgVGhpcyBoYXMgYmVlbiBmaXhlZC4gIEFsc28sIGRpcmVjdGx5IGNhbGxpbmcKICBkaWN0Ll9faGFzaF9fIGFuZCBsaXN0Ll9faGFzaF9fIG5vdyByYWlzZXMgdGhlIHNhbWUgVHlwZUVycm9yCiAgKHByZXZpb3VzbHksIHRoZXNlIHdlcmUgdGhlIHNhbWUgYXMgb2JqZWN0Ll9faGFzaF9fKS4KCi0gTmV3LXN0eWxlIG9iamVjdHMgbm93IHN1cHBvcnQgZGVsZXRpbmcgdGhlaXIgX19kaWN0X18uICBUaGlzIGlzIGZvcgogIGFsbCBpbnRlbnRzIGFuZCBwdXJwb3NlcyBlcXVpdmFsZW50IHRvIGFzc2lnbmluZyBhIGJyYW5kIG5ldyBlbXB0eQogIGRpY3Rpb25hcnksIGJ1dCBzYXZlcyBzcGFjZSBpZiB0aGUgb2JqZWN0IGlzIG5vdCB1c2VkIGZ1cnRoZXIuCgpDb3JlIGFuZCBidWlsdGlucwoKLSAtUW5ldyBub3cgd29ya3MgYXMgZG9jdW1lbnRlZCBpbiBQRVAgMjM4OiAgd2hlbiAtUW5ldyBpcyBwYXNzZWQgb24KICB0aGUgY29tbWFuZCBsaW5lLCBhbGwgb2NjdXJyZW5jZXMgb2YgIi8iIHVzZSB0cnVlIGRpdmlzaW9uIGluc3RlYWQKICBvZiBjbGFzc2ljIGRpdmlzaW9uLiAgU2VlIHRoZSBQRVAgZm9yIGRldGFpbHMuICBOb3RlIHRoYXQgImFsbCIKICBtZWFucyBhbGwgaW5zdGFuY2VzIGluIGxpYnJhcnkgYW5kIDNyZC1wYXJ0eSBtb2R1bGVzLCBhcyB3ZWxsIGFzIGluCiAgeW91ciBvd24gY29kZS4gIEFzIHRoZSBQRVAgc2F5cywgLVFuZXcgaXMgaW50ZW5kZWQgZm9yIHVzZSBvbmx5IGluCiAgZWR1Y2F0aW9uYWwgZW52aXJvbm1lbnRzIHdpdGggY29udHJvbCBvdmVyIHRoZSBsaWJyYXJpZXMgaW4gdXNlLgogIE5vdGUgdGhhdCB0ZXN0X2NvZXJjaW9uLnB5IGluIHRoZSBzdGFuZGFyZCBQeXRob24gdGVzdCBzdWl0ZSBmYWlscwogIHVuZGVyIC1RbmV3OyB0aGlzIGlzIGV4cGVjdGVkLCBhbmQgd29uJ3QgYmUgcmVwYWlyZWQgdW50aWwgdHJ1ZQogIGRpdmlzaW9uIGJlY29tZXMgdGhlIGRlZmF1bHQgKGluIHRoZSBtZWFudGltZSwgdGVzdF9jb2VyY2lvbiBpcwogIHRlc3RpbmcgdGhlIGN1cnJlbnQgcnVsZXMpLgoKLSBjb21wbGV4KCkgbm93IG9ubHkgYWxsb3dzIHRoZSBmaXJzdCBhcmd1bWVudCB0byBiZSBhIHN0cmluZwogIGFyZ3VtZW50LCBhbmQgcmFpc2VzIFR5cGVFcnJvciBpZiBlaXRoZXIgdGhlIHNlY29uZCBhcmcgaXMgYSBzdHJpbmcKICBvciBpZiB0aGUgc2Vjb25kIGFyZyBpcyBzcGVjaWZpZWQgd2hlbiB0aGUgZmlyc3QgaXMgYSBzdHJpbmcuCgpFeHRlbnNpb24gbW9kdWxlcwoKLSBnYy5nZXRfcmVmZXJlbnRzIHdhcyByZW5hbWVkIHRvIGdjLmdldF9yZWZlcnJlcnMuCgpMaWJyYXJ5CgotIEZ1bmN0aW9ucyBpbiB0aGUgb3Muc3Bhd24oKSBmYW1pbHkgbm93IHJlbGVhc2UgdGhlIGdsb2JhbCBpbnRlcnByZXRlcgogIGxvY2sgYXJvdW5kIGNhbGxpbmcgdGhlIHBsYXRmb3JtIHNwYXduLiAgVGhleSBzaG91bGQgYWx3YXlzIGhhdmUgZG9uZQogIHRoaXMsIGJ1dCBkaWQgbm90IGJlZm9yZSAyLjJjMS4gIE11bHRpdGhyZWFkZWQgcHJvZ3JhbXMgY2FsbGluZwogIGFuIG9zLnNwYXduIGZ1bmN0aW9uIHdpdGggUF9XQUlUIHdpbGwgbm8gbG9uZ2VyIGJsb2NrIGFsbCBQeXRob24gdGhyZWFkcwogIHVudGlsIHRoZSBzcGF3bmVkIHByb2dyYW0gY29tcGxldGVzLiAgSXQncyBwb3NzaWJsZSB0aGF0IHNvbWUgcHJvZ3JhbXMKICByZWxpZXMgb24gYmxvY2tpbmcsIGFsdGhvdWdoIG1vcmUgbGlrZWx5IGJ5IGFjY2lkZW50IHRoYW4gYnkgZGVzaWduLgoKLSB3ZWJicm93c2VyIGRlZmF1bHRzIHRvIG5ldHNjYXBlLmV4ZSBvbiBPUy8yIG5vdy4KCi0gVGl4LlJlc2l6ZUhhbmRsZSBleHBvc2VzIGRldGFjaF93aWRnZXQsIGhpZGUsIGFuZCBzaG93LgoKLSBUaGUgY2hhcnNldCBhbGlhcyB3aW5kb3dzXzEyNTIgaGFzIGJlZW4gYWRkZWQuCgotIHR5cGVzLlN0cmluZ1R5cGVzIGlzIGEgdHVwbGUgY29udGFpbmluZyB0aGUgZGVmaW5lZCBzdHJpbmcgdHlwZXM7CiAgdXN1YWxseSB0aGlzIHdpbGwgYmUgKHN0ciwgdW5pY29kZSksIGJ1dCBpZiBQeXRob24gd2FzIGNvbXBpbGVkCiAgd2l0aG91dCBVbmljb2RlIHN1cHBvcnQgaXQgd2lsbCBiZSBqdXN0IChzdHIsKS4KCi0gVGhlIHB1bGxkb20gYW5kIG1pbmlkb20gbW9kdWxlcyB3ZXJlIHN5bmNocm9uaXplZCB0byBQeVhNTC4KClRvb2xzL0RlbW9zCgotIEEgbmV3IHNjcmlwdCBjYWxsZWQgVG9vbHMvc2NyaXB0cy9nb29nbGUucHkgd2FzIGFkZGVkLCB3aGljaCBmaXJlcwogIG9mZiBhIHNlYXJjaCBvbiBHb29nbGUuCgpCdWlsZAoKLSBOb3RlIHRoYXQgcmVsZWFzZSBidWlsZHMgb2YgUHl0aG9uIHNob3VsZCBhcnJhbmdlIHRvIGRlZmluZSB0aGUKICBwcmVwcm9jZXNzb3Igc3ltYm9sIE5ERUJVRyBvbiB0aGUgY29tbWFuZCBsaW5lIChvciBlcXVpdmFsZW50KS4KICBJbiB0aGUgMi4yIHByZS1yZWxlYXNlIHNlcmllcyB3ZSB0cmllZCB0byBkZWZpbmUgdGhpcyBieSBtYWdpYyBpbgogIFB5dGhvbi5oIGluc3RlYWQsIGJ1dCBpdCBwcm92ZWQgdG8gY2F1c2UgcHJvYmxlbXMgZm9yIGV4dGVuc2lvbgogIGF1dGhvcnMuICBUaGUgVW5peCwgV2luZG93cyBhbmQgTWFjIGJ1aWxkcyBub3cgYWxsIGRlZmluZSBOREVCVUcgaW4KICByZWxlYXNlIGJ1aWxkcyB2aWEgY21kbGluZSAob3IgZXF1aXZhbGVudCkgaW5zdGVhZC4gIFBvcnRzIHRvCiAgb3RoZXIgcGxhdGZvcm1zIHNob3VsZCBkbyBsaWtld2lzZS4KCi0gSXQgaXMgbm8gbG9uZ2VyIG5lY2Vzc2FyeSB0byB1c2UgLS13aXRoLXN1ZmZpeCB3aGVuIGJ1aWxkaW5nIG9uIGEKICBjYXNlLWluc2Vuc2l0aXZlIGZpbGUgc3lzdGVtIChzdWNoIGFzIE1hYyBPUyBYIEhGUyspLiBJbiB0aGUgYnVpbGQKICBkaXJlY3RvcnkgYW4gZXh0ZW5zaW9uIGlzIHVzZWQsIGJ1dCBub3QgaW4gdGhlIGluc3RhbGxlZCBweXRob24uCgpDIEFQSQoKLSBOZXcgZnVuY3Rpb24gUHlEaWN0X01lcmdlRnJvbVNlcTIoKSBleHBvc2VzIHRoZSBidWlsdGluIGRpY3QKICBjb25zdHJ1Y3RvcidzIGxvZ2ljIGZvciB1cGRhdGluZyBhIGRpY3Rpb25hcnkgZnJvbSBhbiBpdGVyYWJsZSBvYmplY3QKICBwcm9kdWNpbmcga2V5LXZhbHVlIHBhaXJzLgoKLSBQeUFyZ19QYXJzZVR1cGxlQW5kS2V5d29yZHMoKSByZXF1aXJlcyB0aGF0IHRoZSBudW1iZXIgb2YgZW50cmllcyBpbgogIHRoZSBrZXl3b3JkIGxpc3QgZXF1YWwgdGhlIG51bWJlciBvZiBhcmd1bWVudCBzcGVjaWZpZXJzLiAgVGhpcwogIHdhc24ndCBjaGVja2VkIGNvcnJlY3RseSwgYW5kIFB5QXJnX1BhcnNlVHVwbGVBbmRLZXl3b3JkcyBjb3VsZCBldmVuCiAgZHVtcCBjb3JlIGluIHNvbWUgYmFkIGNhc2VzLiAgVGhpcyBoYXMgYmVlbiByZXBhaXJlZC4gIEFzIGEgcmVzdWx0LAogIFB5QXJnX1BhcnNlVHVwbGVBbmRLZXl3b3JkcyBtYXkgcmFpc2UgUnVudGltZUVycm9yIGluIGJhZCBjYXNlcyB0aGF0CiAgcHJldmlvdXNseSB3ZW50IHVuY2hhbGxlbmdlZC4KCk5ldyBwbGF0Zm9ybXMKClRlc3RzCgpXaW5kb3dzCgpNYWMKCi0gSW4gdW5peC1QeXRob24gb24gTWFjIE9TIFggKGFuZCBkYXJ3aW4pIHN5cy5wbGF0Zm9ybSBpcyBub3cgImRhcndpbiIsCiAgd2l0aG91dCBhbnkgdHJhaWxpbmcgZGlnaXRzLgoKLSBDaGFuZ2VkIGxvZ2ljIGZvciBmaW5kaW5nIHB5dGhvbiBob21lIGluIE1hYyBPUyBYIGZyYW1ld29yayBQeXRob25zLgogIE5vdyBzeXMuZXhlY3V0YWJsZSBwb2ludHMgdG8gdGhlIGV4ZWN1dGFibGUgYWdhaW4sIGluIHN0ZWFkIG9mIHRvCiAgdGhlIHNoYXJlZCBsaWJyYXJ5LiBUaGUgbGF0dGVyIGlzIHVzZWQgb25seSBmb3IgbG9jYXRpbmcgdGhlIHB5dGhvbgogIGhvbWUuCgoKV2hhdCdzIE5ldyBpbiBQeXRob24gMi4yYjI/ClJlbGVhc2UgZGF0ZTogMTYtTm92LTIwMDEKPT09PT09PT09PT09PT09PT09PT09PT09PT09CgpUeXBlL2NsYXNzIHVuaWZpY2F0aW9uIGFuZCBuZXctc3R5bGUgY2xhc3NlcwoKLSBNdWx0aXBsZSBpbmhlcml0YW5jZSBtaXhpbmcgbmV3LXN0eWxlIGFuZCBjbGFzc2ljIGNsYXNzZXMgaW4gdGhlCiAgbGlzdCBvZiBiYXNlIGNsYXNzZXMgaXMgbm93IGFsbG93ZWQsIHNvIHRoaXMgd29ya3Mgbm93OgoKICAgICAgY2xhc3MgQ2xhc3NpYzogcGFzcwogICAgICBjbGFzcyBNaXhlZChDbGFzc2ljLCBvYmplY3QpOiBwYXNzCgogIFRoZSBNUk8gKG1ldGhvZCByZXNvbHV0aW9uIG9yZGVyKSBmb3IgZWFjaCBiYXNlIGNsYXNzIGlzIHJlc3BlY3RlZAogIGFjY29yZGluZyB0byBpdHMga2luZCwgYnV0IHRoZSBNUk8gZm9yIHRoZSBkZXJpdmVkIGNsYXNzIGlzIGNvbXB1dGVkCiAgdXNpbmcgbmV3LXN0eWxlIE1STyBydWxlcyBpZiBhbnkgYmFzZSBjbGFzcyBpcyBhIG5ldy1zdHlsZSBjbGFzcy4KICBUaGlzIG5lZWRzIHRvIGJlIGRvY3VtZW50ZWQuCgotIFRoZSBuZXcgYnVpbHRpbiBkaWN0aW9uYXJ5KCkgY29uc3RydWN0b3IsIGFuZCBkaWN0aW9uYXJ5IHR5cGUsIGhhdmUKICBiZWVuIHJlbmFtZWQgdG8gZGljdC4gIFRoaXMgcmVmbGVjdHMgYSBkZWNhZGUgb2YgY29tbW9uIHVzYWdlLgoKLSBkaWN0KCkgbm93IGFjY2VwdHMgYW4gaXRlcmFibGUgb2JqZWN0IHByb2R1Y2luZyAyLXNlcXVlbmNlcy4gIEZvcgogIGV4YW1wbGUsIGRpY3QoZC5pdGVtcygpKSA9PSBkIGZvciBhbnkgZGljdGlvbmFyeSBkLiAgVGhlIGFyZ3VtZW50LAogIGFuZCB0aGUgZWxlbWVudHMgb2YgdGhlIGFyZ3VtZW50LCBjYW4gYmUgYW55IGl0ZXJhYmxlIG9iamVjdHMuCgotIE5ldy1zdHlsZSBjbGFzc2VzIGNhbiBub3cgaGF2ZSBhIF9fZGVsX18gbWV0aG9kLCB3aGljaCBpcyBjYWxsZWQKICB3aGVuIHRoZSBpbnN0YW5jZSBpcyBkZWxldGVkIChqdXN0IGxpa2UgZm9yIGNsYXNzaWMgY2xhc3NlcykuCgotIEFzc2lnbm1lbnQgdG8gb2JqZWN0Ll9fZGljdF9fIGlzIG5vdyBwb3NzaWJsZSwgZm9yIG9iamVjdHMgdGhhdCBhcmUKICBpbnN0YW5jZXMgb2YgbmV3LXN0eWxlIGNsYXNzZXMgdGhhdCBoYXZlIGEgX19kaWN0X18gKHVubGVzcyB0aGUgYmFzZQogIGNsYXNzIGZvcmJpZHMgaXQpLgoKLSBNZXRob2RzIG9mIGJ1aWx0LWluIHR5cGVzIG5vdyBwcm9wZXJseSBjaGVjayBmb3Iga2V5d29yZCBhcmd1bWVudHMKICAoZm9ybWVybHkgdGhlc2Ugd2VyZSBzaWxlbnRseSBpZ25vcmVkKS4gIFRoZSBvbmx5IGJ1aWx0LWluIG1ldGhvZHMKICB0aGF0IHRha2Uga2V5d29yZCBhcmd1bWVudHMgYXJlIF9fY2FsbF9fLCBfX2luaXRfXyBhbmQgX19uZXdfXy4KCi0gVGhlIHNvY2tldCBmdW5jdGlvbiBoYXMgYmVlbiBjb252ZXJ0ZWQgdG8gYSB0eXBlOyBzZWUgYmVsb3cuCgpDb3JlIGFuZCBidWlsdGlucwoKLSBBc3NpZ25tZW50IHRvIF9fZGVidWdfXyByYWlzZXMgU3ludGF4RXJyb3IgYXQgY29tcGlsZS10aW1lLiAgVGhpcwogIHdhcyBwcm9taXNlZCB3aGVuIDIuMWMxIHdhcyByZWxlYXNlZCBhcyAiV2hhdCdzIE5ldyBpbiBQeXRob24gMi4xYzEiCiAgKHNlZSBiZWxvdykgc2F5cy4KCi0gQ2xhcmlmaWVkIHRoZSBlcnJvciBtZXNzYWdlcyBmb3IgdW5zdXBwb3J0ZWQgb3BlcmFuZHMgdG8gYW4gb3BlcmF0b3IKICAobGlrZSAxICsgJycpLgoKRXh0ZW5zaW9uIG1vZHVsZXMKCi0gbW1hcCBoYXMgYSBuZXcga2V5d29yZCBhcmd1bWVudCwgImFjY2VzcyIsIGFsbG93aW5nIGEgdW5pZm9ybSB3YXkgZm9yCiAgYm90aCBXaW5kb3dzIGFuZCBVbml4IHVzZXJzIHRvIGNyZWF0ZSByZWFkLW9ubHksIHdyaXRlLXRocm91Z2ggYW5kCiAgY29weS1vbi13cml0ZSBtZW1vcnkgbWFwcGluZ3MuICBUaGlzIHdhcyBwcmV2aW91c2x5IHBvc3NpYmxlIG9ubHkgb24KICBVbml4LiAgQSBuZXcga2V5d29yZCBhcmd1bWVudCB3YXMgcmVxdWlyZWQgdG8gc3VwcG9ydCB0aGlzIGluIGEKICB1bmlmb3JtIHdheSBiZWNhdXNlIHRoZSBtbWFwKCkgc2lnbmF0dXJlcyBoYWQgZGl2ZXJnZWQgYWNyb3NzCiAgcGxhdGZvcm1zLiAgVGhhbmtzIHRvIEpheSBUIE1pbGxlciBmb3IgcmVwYWlyaW5nIHRoaXMhCgotIEJ5IGRlZmF1bHQsIHRoZSBnYy5nYXJiYWdlIGxpc3Qgbm93IGNvbnRhaW5zIG9ubHkgdGhvc2UgaW5zdGFuY2VzIGluCiAgdW5yZWFjaGFibGUgY3ljbGVzIHRoYXQgaGF2ZSBfX2RlbF9fIG1ldGhvZHM7IGluIDIuMSBpdCBjb250YWluZWQgYWxsCiAgaW5zdGFuY2VzIGluIHVucmVhY2hhYmxlIGN5Y2xlcy4gICJJbnN0YW5jZXMiIGhlcmUgaGFzIGJlZW4gZ2VuZXJhbGl6ZWQKICB0byBpbmNsdWRlIGluc3RhbmNlcyBvZiBib3RoIG5ldy1zdHlsZSBhbmQgb2xkLXN0eWxlIGNsYXNzZXMuCgotIFRoZSBzb2NrZXQgbW9kdWxlIGRlZmluZXMgYSBuZXcgbWV0aG9kIGZvciBzb2NrZXQgb2JqZWN0cywKICBzZW5kYWxsKCkuICBUaGlzIGlzIGxpa2Ugc2VuZCgpIGJ1dCBtYXkgbWFrZSBtdWx0aXBsZSBjYWxscyB0bwogIHNlbmQoKSB1bnRpbCBhbGwgZGF0YSBoYXMgYmVlbiBzZW50LiAgQWxzbywgdGhlIHNvY2tldCBmdW5jdGlvbiBoYXMKICBiZWVuIGNvbnZlcnRlZCB0byBhIHN1YmNsYXNzYWJsZSB0eXBlLCBsaWtlIGxpc3QgYW5kIHR1cGxlIChldGMuKQogIGJlZm9yZSBpdDsgc29ja2V0IGFuZCBTb2NrZXRUeXBlIGFyZSBub3cgdGhlIHNhbWUgdGhpbmcuCgotIFZhcmlvdXMgYnVnZml4ZXMgdG8gdGhlIGN1cnNlcyBtb2R1bGUuICBUaGVyZSBpcyBub3cgYSB0ZXN0IHN1aXRlCiAgZm9yIHRoZSBjdXJzZXMgbW9kdWxlICh5b3UgaGF2ZSB0byBydW4gaXQgbWFudWFsbHkpLgoKLSBiaW5hc2NpaS5iMmFfYmFzZTY0IG5vIGxvbmdlciBwbGFjZXMgYW4gYXJiaXRyYXJ5IHJlc3RyaWN0aW9uIG9mIDU3CiAgYnl0ZXMgb24gaXRzIGlucHV0LgoKTGlicmFyeQoKLSB0a0ZpbGVEaWFsb2cgZXhwb3NlcyBhIERpcmVjdG9yeSBjbGFzcyBhbmQgYXNrZGlyZWN0b3J5CiAgY29udmVuaWVuY2UgZnVuY3Rpb24uCgotIFN5bWJvbGljIGdyb3VwIG5hbWVzIGluIHJlZ3VsYXIgZXhwcmVzc2lvbnMgbXVzdCBiZSB1bmlxdWUuICBGb3IKICBleGFtcGxlLCB0aGUgcmVnZXhwIHInKD9QPGFiYz4pKD9QPGFiYz4pJyBpcyBub3QgYWxsb3dlZCwgYmVjYXVzZSBhCiAgc2luZ2xlIG5hbWUgY2FuJ3QgbWVhbiBib3RoICJncm91cCAxIiBhbmQgImdyb3VwIDIiIHNpbXVsdGFuZW91c2x5LgogIFB5dGhvbiAyLjIgZGV0ZWN0cyB0aGlzIGVycm9yIGF0IHJlZ2V4cCBjb21waWxhdGlvbiB0aW1lOwogIHByZXZpb3VzbHksIHRoZSBlcnJvciB3ZW50IHVuZGV0ZWN0ZWQsIGFuZCByZXN1bHRzIHdlcmUKICB1bnByZWRpY3RhYmxlLiAgQWxzbyBpbiBzcmUsIHRoZSBwYXR0ZXJuLnNwbGl0KCksIHBhdHRlcm4uc3ViKCksIGFuZAogIHBhdHRlcm4uc3VibigpIG1ldGhvZHMgaGF2ZSBiZWVuIHJld3JpdHRlbiBpbiBDLiAgQWxzbywgYW4KICBleHBlcmltZW50YWwgZnVuY3Rpb24vbWV0aG9kIGZpbmRpdGVyKCkgaGFzIGJlZW4gYWRkZWQsIHdoaWNoIHdvcmtzCiAgbGlrZSBmaW5kYWxsKCkgYnV0IHJldHVybnMgYW4gaXRlcmF0b3IuCgotIFRpeCBleHBvc2VzIG1vcmUgY29tbWFuZHMgdGhyb3VnaCB0aGUgY2xhc3NlcyBEaXJTZWxlY3RCb3gsCiAgRGlyU2VsZWN0RGlhbG9nLCBMaXN0Tm90ZUJvb2ssIE1ldGVyLCBDaGVja0xpc3QsIGFuZCB0aGUKICBtZXRob2RzIHRpeF9hZGRiaXRtYXBkaXIsIHRpeF9jZ2V0LCB0aXhfY29uZmlndXJlLCB0aXhfZmlsZWRpYWxvZywKICB0aXhfZ2V0Yml0bWFwLCB0aXhfZ2V0aW1hZ2UsIHRpeF9vcHRpb25fZ2V0LCBhbmQgdGl4X3Jlc2V0b3B0aW9ucy4KCi0gVHJhY2ViYWNrIG9iamVjdHMgYXJlIG5vdyBzY2FubmVkIGJ5IGN5Y2xpYyBnYXJiYWdlIGNvbGxlY3Rpb24sIHNvCiAgY3ljbGVzIGNyZWF0ZWQgYnkgY2FzdWFsIHVzZSBvZiBzeXMuZXhjX2luZm8oKSBubyBsb25nZXIgY2F1c2UKICBwZXJtYW5lbnQgbWVtb3J5IGxlYWtzIChwcm92aWRlZCBnYXJiYWdlIGNvbGxlY3Rpb24gaXMgZW5hYmxlZCkuCgotIG9zLmV4dHNlcCAtLSBhIG5ldyB2YXJpYWJsZSBuZWVkZWQgYnkgdGhlIFJJU0NPUyBzdXBwb3J0LiAgSXQgaXMgdGhlCiAgc2VwYXJhdG9yIHVzZWQgYnkgZXh0ZW5zaW9ucywgYW5kIGlzICcuJyBvbiBhbGwgcGxhdGZvcm1zIGV4Y2VwdAogIFJJU0NPUywgd2hlcmUgaXQgaXMgJy8nLiAgVGhlcmUgaXMgbm8gbmVlZCB0byB1c2UgdGhpcyB2YXJpYWJsZQogIHVubGVzcyB5b3UgaGF2ZSBhIG1hc29jaGlzdGljIGRlc2lyZSB0byBwb3J0IHlvdXIgY29kZSB0byBSSVNDT1MuCgotIG1pbWV0eXBlcy5weSBoYXMgb3B0aW9uYWwgc3VwcG9ydCBmb3Igbm9uLXN0YW5kYXJkLCBidXQgY29tbW9ubHkKICBmb3VuZCB0eXBlcy4gIGd1ZXNzX3R5cGUoKSBhbmQgZ3Vlc3NfZXh0ZW5zaW9uKCkgbm93IGFjY2VwdCBhbgogIG9wdGlvbmFsIGBzdHJpY3QnIGZsYWcsIGRlZmF1bHRpbmcgdG8gdHJ1ZSwgd2hpY2ggY29udHJvbHMgd2hldGhlcgogIHJlY29nbml6ZSBub24tc3RhbmRhcmQgdHlwZXMgb3Igbm90LiAgQSBmZXcgbm9uLXN0YW5kYXJkIHR5cGVzIHdlCiAga25vdyBhYm91dCBoYXZlIGJlZW4gYWRkZWQuICBBbHNvLCB3aGVuIHJ1biBhcyBhIHNjcmlwdCwgdGhlcmUgYXJlCiAgbmV3IC1sIGFuZCAtZSBvcHRpb25zLgoKLSBzdGF0Y2FjaGUgaXMgbm93IGRlcHJlY2F0ZWQuCgotIGVtYWlsLlV0aWxzLmZvcm1hdGRhdGUoKSBub3cgcHJvZHVjZXMgdGhlIHByZWZlcnJlZCBSRkMgMjgyMiBzdHlsZQogIGRhdGVzIHdpdGggbnVtZXJpYyB0aW1lem9uZXMgKGl0IHVzZWQgdG8gcHJvZHVjZSBvYnNvbGV0ZSBkYXRlcwogIGhhcmQgY29kZWQgdG8gIkdNVCIgdGltZXpvbmUpLiAgQW4gb3B0aW9uYWwgYGxvY2FsdGltZScgZmxhZyBpcwogIGFkZGVkIHRvIHByb2R1Y2UgZGF0ZXMgaW4gdGhlIGxvY2FsIHRpbWV6b25lLCB3aXRoIGRheWxpZ2h0IHNhdmluZ3MKICB0aW1lIHByb3Blcmx5IHRha2VuIGludG8gYWNjb3VudC4KCi0gSW4gcGlja2xlIGFuZCBjUGlja2xlLCBpbnN0ZWFkIG9mIG1hc2tpbmcgZXJyb3JzIGluIGxvYWQoKSBieQogIHRyYW5zZm9ybWluZyB0aGVtIGludG8gU3lzdGVtRXJyb3IsIHdlIGxldCB0aGUgb3JpZ2luYWwgZXhjZXB0aW9uCiAgcHJvcGFnYXRlIG91dC4gIEFsc28sIGltcGxlbWVudCBzdXBwb3J0IGZvciBfX3NhZmVfZm9yX3VucGlja2xpbmdfXwogIGluIHBpY2tsZSwgYXMgaXQgYWxyZWFkeSB3YXMgc3VwcG9ydGVkIGluIGNQaWNrbGUuCgpUb29scy9EZW1vcwoKQnVpbGQKCi0gVGhlIGRibSBtb2R1bGUgaXMgYnVpbHQgdXNpbmcgbGliZGIxIGlmIGF2YWlsYWJsZS4gIFRoZSBic2RkYiBtb2R1bGUKICBpcyBidWlsdCB3aXRoIGxpYmRiMyBpZiBhdmFpbGFibGUuCgotIE1pc2MvTWFrZWZpbGUucHJlLmluIGhhcyBiZWVuIHJlbW92ZWQgYnkgQkRGTCBwcm9ub3VuY2VtZW50LgoKQyBBUEkKCi0gTmV3IGZ1bmN0aW9uIFB5U2VxdWVuY2VfRmFzdF9HRVRfU0laRSgpIHJldHVybnMgdGhlIHNpemUgb2YgYSBub24tCiAgTlVMTCByZXN1bHQgZnJvbSBQeVNlcXVlbmNlX0Zhc3QoKSwgbW9yZSBxdWlja2x5IHRoYW4gY2FsbGluZwogIFB5U2VxdWVuY2VfU2l6ZSgpLgoKLSBOZXcgYXJndW1lbnQgdW5wYWNraW5nIGZ1bmN0aW9uIFB5QXJnX1VucGFja1R1cGxlKCkgYWRkZWQuCgotIE5ldyBmdW5jdGlvbnMgUHlPYmplY3RfQ2FsbEZ1bmN0aW9uT2JqQXJncygpIGFuZAogIFB5T2JqZWN0X0NhbGxNZXRob2RPYmpBcmdzKCkgaGF2ZSBiZWVuIGFkZGVkIHRvIG1ha2UgaXQgbW9yZQogIGNvbnZlbmllbnQgYW5kIGVmZmljaWVudCB0byBjYWxsIGZ1bmN0aW9ucyBhbmQgbWV0aG9kcyBmcm9tIEMuCgotIFB5QXJnX1BhcnNlVHVwbGVBbmRLZXl3b3JkcygpIG5vIGxvbmdlciBtYXNrcyBlcnJvcnMsIHNvIGl0J3MKICBwb3NzaWJsZSB0aGF0IHRoaXMgd2lsbCBwcm9wYWdhdGUgZXJyb3JzIGl0IGRpZG4ndCBiZWZvcmUuCgotIE5ldyBmdW5jdGlvbiBQeU9iamVjdF9DaGVja1JlYWRCdWZmZXIoKSwgd2hpY2ggcmV0dXJucyB0cnVlIGlmIGl0cwogIGFyZ3VtZW50IHN1cHBvcnRzIHRoZSBzaW5nbGUtc2VnbWVudCByZWFkYWJsZSBidWZmZXIgaW50ZXJmYWNlLgoKTmV3IHBsYXRmb3JtcwoKLSBXZSd2ZSBmaW5hbGx5IGNvbmZpcm1lZCB0aGF0IHRoaXMgcmVsZWFzZSBidWlsZHMgb24gSFAtVVggMTEuMDAsCiAgKndpdGgqIHRocmVhZHMsIGFuZCBwYXNzZXMgdGhlIHRlc3Qgc3VpdGUuCgotIFRoYW5rcyB0byBhIHNlcmllcyBvZiBwYXRjaGVzIGZyb20gTWljaGFlbCBNdWxsZXIsIFB5dGhvbiBtYXkgYnVpbGQKICBhZ2FpbiB1bmRlciBPUy8yIFZpc3VhbCBBZ2UgQysrLgoKLSBVcGRhdGVkIFJJU0NPUyBwb3J0IGJ5IERpZXRtYXIgU2Nod2VydGJlcmdlci4KClRlc3RzCgotIEFkZGVkIGEgdGVzdCBzY3JpcHQgZm9yIHRoZSBjdXJzZXMgbW9kdWxlLiAgSXQgaXNuJ3QgcnVuIGF1dG9tYXRpY2FsbHk7CiAgcmVncnRlc3QucHkgbXVzdCBiZSBydW4gd2l0aCAnLXUgY3Vyc2VzJyB0byBlbmFibGUgaXQuCgpXaW5kb3dzCgpNYWMKCi0gUHl0aG9uU2NyaXB0IGhhcyBiZWVuIG1vdmVkIHRvIHVuc3VwcG9ydGVkIGFuZCBpcyBzbGF0ZWQgdG8gYmUKICByZW1vdmVkIGNvbXBsZXRlbHkgaW4gdGhlIG5leHQgcmVsZWFzZS4KCi0gSXQgc2hvdWxkIG5vdyBiZSBwb3NzaWJsZSB0byBidWlsZCBhcHBsZXRzIHRoYXQgd29yayBvbiBib3RoIE9TOSBhbmQKICBPU1guCgotIFRoZSBjb3JlIGlzIG5vdyBsaW5rZWQgd2l0aCBDb3JlU2VydmljZXMgbm90IENhcmJvbjsgYXMgYSBzaWRlCiAgcmVzdWx0LCBkZWZhdWx0IDhiaXQgZW5jb2Rpbmcgb24gT1NYIGlzIG5vdyBBU0NJSS4KCi0gUHl0aG9uIHNob3VsZCBub3cgYnVpbGQgb24gT1NYIDEwLjEuMQoKCldoYXQncyBOZXcgaW4gUHl0aG9uIDIuMmIxPwpSZWxlYXNlIGRhdGU6IDE5LU9jdC0yMDAxCj09PT09PT09PT09PT09PT09PT09PT09PT09PQoKVHlwZS9jbGFzcyB1bmlmaWNhdGlvbiBhbmQgbmV3LXN0eWxlIGNsYXNzZXMKCi0gTmV3LXN0eWxlIGNsYXNzZXMgYXJlIG5vdyBhbHdheXMgZHluYW1pYyAoZXhjZXB0IGZvciBidWlsdC1pbiBhbmQKICBleHRlbnNpb24gdHlwZXMpLiAgVGhlcmUgaXMgbm8gbG9uZ2VyIGEgcGVyZm9ybWFuY2UgcGVuYWx0eSwgYW5kIEkKICBubyBsb25nZXIgc2VlIGFub3RoZXIgcmVhc29uIHRvIGtlZXAgdGhpcyBiYWdnYWdlIGFyb3VuZC4gIE9uZSByZWxpYwogIHJlbWFpbnM6IHRoZSBfX2RpY3RfXyBvZiBhIG5ldy1zdHlsZSBjbGFzcyBpcyBhIHJlYWQtb25seSBwcm94eTsgeW91CiAgbXVzdCBzZXQgdGhlIGNsYXNzJ3MgYXR0cmlidXRlIHRvIG1vZGlmeSBpdC4gIEFzIGEgY29uc2VxdWVuY2UsIHRoZQogIF9fZGVmaW5lZF9fIGF0dHJpYnV0ZSBvZiBuZXctc3R5bGUgdHlwZXMgbm8gbG9uZ2VyIGV4aXN0cywgZm9yIGxhY2sKICBvZiBuZWVkOiB0aGVyZSBpcyBvbmNlIGFnYWluIG9ubHkgb25lIF9fZGljdF9fIChhbHRob3VnaCBpbiB0aGUKICBmdXR1cmUgYSBfX2NhY2hlX18gbWF5IGJlIHJlc3VycmVjdGVkIHdpdGggYSBzaW1pbGFyIGZ1bmN0aW9uLCBpZiBJCiAgY2FuIHByb3ZlIHRoYXQgaXQgYWN0dWFsbHkgc3BlZWRzIHRoaW5ncyB1cCkuCgotIEMuX19kb2NfXyBub3cgd29ya3MgYXMgZXhwZWN0ZWQgZm9yIG5ldy1zdHlsZSBjbGFzc2VzIChpbiAyLjJhNCBpdAogIGFsd2F5cyByZXR1cm5lZCBOb25lLCBldmVuIHdoZW4gdGhlcmUgd2FzIGEgY2xhc3MgZG9jc3RyaW5nKS4KCi0gZG9jdGVzdCBub3cgZmluZHMgYW5kIHJ1bnMgZG9jc3RyaW5ncyBhdHRhY2hlZCB0byBuZXctc3R5bGUgY2xhc3NlcywKICBjbGFzcyBtZXRob2RzLCBzdGF0aWMgbWV0aG9kcywgYW5kIHByb3BlcnRpZXMuCgpDb3JlIGFuZCBidWlsdGlucwoKLSBBIHZlcnkgc3VidGxlIHN5bnRhY3RpY2FsIHBpdGZhbGwgaW4gbGlzdCBjb21wcmVoZW5zaW9ucyB3YXMgZml4ZWQuCiAgRm9yIGV4YW1wbGU6IFthK2IgZm9yIGEgaW4gJ2FiYycsIGZvciBiIGluICdkZWYnXS4gIFRoZSBjb21tYSBpbgogIHRoaXMgZXhhbXBsZSBpcyBhIG1pc3Rha2UuICBQcmV2aW91c2x5LCB0aGlzIHdvdWxkIHNpbGVudGx5IGxldCAnYScKICBpdGVyYXRlIG92ZXIgdGhlIHNpbmdsZXRvbiB0dXBsZSAoJ2FiYycsKSwgeWllbGRpbmcgWydhYmNkJywgJ2FiY2UnLAogICdhYmNmJ10gcmF0aGVyIHRoYW4gdGhlIGludGVuZGVkIFsnYWQnLCAnYWUnLCAnYWYnLCAnYmQnLCAnYmUnLAogICdiZicsICdjZCcsICdjZScsICdjZiddLiAgTm93LCB0aGlzIGlzIGZsYWdnZWQgYXMgYSBzeW50YXggZXJyb3IuCiAgTm90ZSB0aGF0IFthIGZvciBhIGluIDxzaW5nbGV0b24+XSBpcyBhIGNvbnZvbHV0ZWQgd2F5IHRvIHNheQogIFs8c2luZ2xldG9uPl0gYW55d2F5LCBzbyBpdCdzIG5vdCBsaWtlIGFueSBleHByZXNzaXZlbmVzcyBpcyBsb3N0LgoKLSBnZXRhdHRyKG9iaiwgbmFtZSwgZGVmYXVsdCkgbm93IG9ubHkgY2F0Y2hlcyBBdHRyaWJ1dGVFcnJvciwgYXMKICBkb2N1bWVudGVkLCByYXRoZXIgdGhhbiByZXR1cm5pbmcgdGhlIGRlZmF1bHQgdmFsdWUgZm9yIGFsbAogIGV4Y2VwdGlvbnMgKHdoaWNoIGNvdWxkIG1hc2sgYnVncyBpbiBhIF9fZ2V0YXR0cl9fIGhvb2ssIGZvcgogIGV4YW1wbGUpLgoKLSBXZWFrIHJlZmVyZW5jZSBvYmplY3RzIGFyZSBub3cgcGFydCBvZiB0aGUgY29yZSBhbmQgb2ZmZXIgYSBDIEFQSS4KICBBIGJ1ZyB3aGljaCBjb3VsZCBhbGxvdyBhIGNvcmUgZHVtcCB3aGVuIGJpbmFyeSBvcGVyYXRpb25zIGludm9sdmVkCiAgcHJveHkgcmVmZXJlbmNlIGhhcyBiZWVuIGZpeGVkLiAgd2Vha3JlZi5SZWZlcmVuY2VFcnJvciBpcyBub3cgYQogIGJ1aWx0LWluIGV4Y2VwdGlvbi4KCi0gdW5pY29kZShvYmopIG5vdyBiZWhhdmVzIG1vcmUgbGlrZSBzdHIob2JqKSwgYWNjZXB0aW5nIGFyYml0cmFyeQogIG9iamVjdHMsIGFuZCBjYWxsaW5nIGEgX191bmljb2RlX18gbWV0aG9kIGlmIGl0IGV4aXN0cy4KICB1bmljb2RlKG9iaiwgZW5jb2RpbmcpIGFuZCB1bmljb2RlKG9iaiwgZW5jb2RpbmcsIGVycm9ycykgc3RpbGwKICByZXF1aXJlIGFuIDgtYml0IHN0cmluZyBvciBjaGFyYWN0ZXIgYnVmZmVyIGFyZ3VtZW50LgoKLSBpc2luc3RhbmNlKCkgbm93IGFsbG93cyBhbnkgb2JqZWN0IGFzIHRoZSBmaXJzdCBhcmd1bWVudCBhbmQgYQogIGNsYXNzLCBhIHR5cGUgb3Igc29tZXRoaW5nIHdpdGggYSBfX2Jhc2VzX18gdHVwbGUgYXR0cmlidXRlIGZvciB0aGUKICBzZWNvbmQgYXJndW1lbnQuICBUaGUgc2Vjb25kIGFyZ3VtZW50IG1heSBhbHNvIGJlIGEgdHVwbGUgb2YgYQogIGNsYXNzLCB0eXBlLCBvciBzb21ldGhpbmcgd2l0aCBfX2Jhc2VzX18sIGluIHdoaWNoIGNhc2UgaXNpbnN0YW5jZSgpCiAgd2lsbCByZXR1cm4gdHJ1ZSBpZiB0aGUgZmlyc3QgYXJndW1lbnQgaXMgYW4gaW5zdGFuY2Ugb2YgYW55IG9mIHRoZQogIHRoaW5ncyBjb250YWluZWQgaW4gdGhlIHNlY29uZCBhcmd1bWVudCB0dXBsZS4gIEUuZy4KCiAgaXNpbnN0YW5jZSh4LCAoQSwgQikpCgogIHJldHVybnMgdHJ1ZSBpZiB4IGlzIGFuIGluc3RhbmNlIG9mIEEgb3IgQi4KCkV4dGVuc2lvbiBtb2R1bGVzCgotIHRocmVhZC5zdGFydF9uZXdfdGhyZWFkKCkgbm93IHJldHVybnMgdGhlIHRocmVhZCBJRCAocHJldmlvdXNseSBOb25lKS4KCi0gYmluYXNjaWkgaGFzIG5vdyB0d28gcXVvcHJpIHN1cHBvcnQgZnVuY3Rpb25zLCBhMmJfcXAgYW5kIGIyYV9xcC4KCi0gcmVhZGxpbmUgbm93IHN1cHBvcnRzIHNldHRpbmcgdGhlIHN0YXJ0dXBfaG9vayBhbmQgdGhlCiAgcHJlX2V2ZW50X2hvb2ssIGFuZCBhZGRzIHRoZSBhZGRfaGlzdG9yeSgpIGZ1bmN0aW9uLgoKLSBvcyBhbmQgcG9zaXggc3VwcG9ydHMgY2hyb290KCksIHNldGdyb3VwcygpIGFuZCB1bnNldGVudigpIHdoZXJlCiAgYXZhaWxhYmxlLiAgVGhlIHN0YXQoKSwgZnN0YXQoKSwgc3RhdHZmcygpIGFuZCBmc3RhdHZmcygpIGZ1bmN0aW9ucwogIG5vdyByZXR1cm4gInBzZXVkby1zZXF1ZW5jZXMiIC0tIHRoZSB2YXJpb3VzIGZpZWxkcyBjYW4gbm93IGJlCiAgYWNjZXNzZWQgYXMgYXR0cmlidXRlcyAoZS5nLiBvcy5zdGF0KCIvIikuc3RfbXRpbWUpIGJ1dCBmb3IKICBiYWNrd2FyZHMgY29tcGF0aWJpbGl0eSB0aGV5IGFsc28gYmVoYXZlIGFzIGEgZml4ZWQtbGVuZ3RoIHNlcXVlbmNlLgogIFNvbWUgcGxhdGZvcm0tc3BlY2lmaWMgZmllbGRzIChlLmcuIHN0X3JkZXYpIGFyZSBvbmx5IGFjY2Vzc2libGUgYXMKICBhdHRyaWJ1dGVzLgoKLSB0aW1lOiBsb2NhbHRpbWUoKSwgZ210aW1lKCkgYW5kIHN0cnB0aW1lKCkgbm93IHJldHVybiBhCiAgcHNldWRvLXNlcXVlbmNlIHNpbWlsYXIgdG8gdGhlIG9zLnN0YXQoKSByZXR1cm4gdmFsdWUsIHdpdGgKICBhdHRyaWJ1dGVzIGxpa2UgdG1feWVhciBldGMuCgotIERlY29tcHJlc3Npb24gb2JqZWN0cyBpbiB0aGUgemxpYiBtb2R1bGUgbm93IGFjY2VwdCBhbiBvcHRpb25hbAogIHNlY29uZCBwYXJhbWV0ZXIgdG8gZGVjb21wcmVzcygpIHRoYXQgc3BlY2lmaWVzIHRoZSBtYXhpbXVtIGFtb3VudAogIG9mIG1lbW9yeSB0byB1c2UgZm9yIHRoZSB1bmNvbXByZXNzZWQgZGF0YS4KCi0gb3B0aW9uYWwgU1NMIHN1cHBvcnQgaW4gdGhlIHNvY2tldCBtb2R1bGUgbm93IGV4cG9ydHMgT3BlblNTTAogIGZ1bmN0aW9ucyBSQU5EX2FkZCgpLCBSQU5EX2VnZCgpLCBhbmQgUkFORF9zdGF0dXMoKS4gIFRoZXNlIGNhbGxzCiAgYXJlIHVzZWZ1bCBvbiBwbGF0Zm9ybXMgbGlrZSBTb2xhcmlzIHdoZXJlIE9wZW5TU0wgZG9lcyBub3QKICBhdXRvbWF0aWNhbGx5IHNlZWQgaXRzIFBSTkcuICBBbHNvLCB0aGUga2V5ZmlsZSBhbmQgY2VydGZpbGUKICBhcmd1bWVudHMgdG8gc29ja2V0LnNzbCgpIGFyZSBub3cgb3B0aW9uYWwuCgotIHBvc2l4bW9kdWxlIChhbmQgYnkgZXh0ZW5zaW9uLCB0aGUgb3MgbW9kdWxlIG9uIFBPU0lYIHBsYXRmb3Jtcykgbm93CiAgZXhwb3J0cyBPX0xBUkdFRklMRSwgT19ESVJFQ1QsIE9fRElSRUNUT1JZLCBhbmQgT19OT0ZPTExPVy4KCkxpYnJhcnkKCi0gZG9jdGVzdCBub3cgZXhjbHVkZXMgZnVuY3Rpb25zIGFuZCBjbGFzc2VzIG5vdCBkZWZpbmVkIGJ5IHRoZSBtb2R1bGUKICBiZWluZyB0ZXN0ZWQsIHRoYW5rcyB0byBUaW0gSG9jaGJlcmcuCgotIEhvdFNob3QsIGEgbmV3IHByb2ZpbGVyIGltcGxlbWVudGVkIHVzaW5nIGEgQy1iYXNlZCBjYWxsYmFjaywgaGFzCiAgYmVlbiBhZGRlZC4gIFRoaXMgc3Vic3RhbnRpYWxseSByZWR1Y2VzIHRoZSBvdmVyaGVhZCBvZiBwcm9maWxpbmcsCiAgYnV0IGl0IGlzIHN0aWxsIHF1aXRlIHByZWxpbWluYXJ5LiAgU3VwcG9ydCBtb2R1bGVzIGFuZAogIGRvY3VtZW50YXRpb24gd2lsbCBiZSBhZGRlZCBpbiB1cGNvbWluZyByZWxlYXNlcyAoYmVmb3JlIDIuMiBmaW5hbCkuCgotIHByb2ZpbGUgbm93IHByb2R1Y2VzIGNvcnJlY3Qgb3V0cHV0IGluIHNpdHVhdGlvbnMgd2hlcmUgYW4gZXhjZXB0aW9uCiAgcmFpc2VkIGluIFB5dGhvbiBpcyBjbGVhcmVkIGJ5IEMgY29kZSAoZS5nLiBoYXNhdHRyKCkpLiAgVGhpcyB1c2VkCiAgdG8gY2F1c2Ugd3Jvbmcgb3V0cHV0LCBpbmNsdWRpbmcgc3B1cmlvdXMgY2xhaW1zIG9mIHJlY3Vyc2l2ZQogIGZ1bmN0aW9ucyBhbmQgYXR0cmlidXRpb24gb2YgdGltZSBzcGVudCB0byB0aGUgd3JvbmcgZnVuY3Rpb24uCgogIFRoZSBjb2RlIGFuZCBkb2N1bWVudGF0aW9uIGZvciB0aGUgZGVyaXZlZCBPbGRQcm9maWxlIGFuZCBIb3RQcm9maWxlCiAgcHJvZmlsaW5nIGNsYXNzZXMgd2FzIHJlbW92ZWQuICBUaGUgY29kZSBoYXNuJ3Qgd29ya2VkIGZvciB5ZWFycyAoaWYKICB5b3UgdHJpZWQgdG8gdXNlIHRoZW0sIHRoZXkgcmFpc2VkIGV4Y2VwdGlvbnMpLiAgT2xkUHJvZmlsZQogIGludGVuZGVkIHRvIHJlcHJvZHVjZSB0aGUgYmVoYXZpb3Igb2YgdGhlIHByb2ZpbGVyIFB5dGhvbiB1c2VkIG1vcmUKICB0aGFuIDcgeWVhcnMgYWdvLCBhbmQgaXNuJ3QgaW50ZXJlc3RpbmcgYW55bW9yZS4gIEhvdFByb2ZpbGUgaW50ZW5kZWQKICB0byBwcm92aWRlIGEgZmFzdGVyIHByb2ZpbGVyIChidXQgcHJvZHVjaW5nIGxlc3MgaW5mb3JtYXRpb24pLCBhbmQKICB0aGF0J3MgYSB3b3J0aHkgZ29hbCB3ZSBpbnRlbmQgdG8gbWVldCB2aWEgYSBkaWZmZXJlbnQgYXBwcm9hY2ggKGJ1dAogIHdpdGhvdXQgbG9zaW5nIGluZm9ybWF0aW9uKS4KCi0gUHJvZmlsZS5jYWxpYnJhdGUoKSBoYXMgYSBuZXcgaW1wbGVtZW50YXRpb24gdGhhdCBzaG91bGQgZGVsaXZlcgogIGEgbXVjaCBiZXR0ZXIgc3lzdGVtLXNwZWNpZmljIGNhbGlicmF0aW9uIGNvbnN0YW50LiAgVGhlIGNvbnN0YW50IGNhbgogIG5vdyBiZSBzcGVjaWZpZWQgaW4gYW4gaW5zdGFuY2UgY29uc3RydWN0b3IsIG9yIGFzIGEgUHJvZmlsZSBjbGFzcyBvcgogIGluc3RhbmNlIHZhcmlhYmxlLCBpbnN0ZWFkIG9mIGJ5IGVkaXRpbmcgcHJvZmlsZS5weSdzIHNvdXJjZSBjb2RlLgogIENhbGlicmF0aW9uIG11c3Qgc3RpbGwgYmUgZG9uZSBtYW51YWxseSAoc2VlIHRoZSBkb2NzIGZvciB0aGUgcHJvZmlsZQogIG1vZHVsZSkuCgogIE5vdGUgdGhhdCBQcm9maWxlLmNhbGlicmF0ZSgpIG11c3QgYmUgb3ZlcnJpZGVuIGJ5IHN1YmNsYXNzZXMuCiAgSW1wcm92aW5nIHRoZSBhY2N1cmFjeSByZXF1aXJlZCBleHBsb2l0aW5nIGRldGFpbGVkIGtub3dsZWRnZSBvZgogIHByb2ZpbGVyIGludGVybmFsczsgdGhlIGVhcmxpZXIgbWV0aG9kIGFic3RyYWN0ZWQgYXdheSB0aGUgZGV0YWlscwogIGFuZCBtZWFzdXJlZCBhIHNpbXBsaWZpZWQgbW9kZWwgaW5zdGVhZCwgYnV0IGNvbnNlcXVlbnRseSBjb21wdXRlZAogIGEgY29uc3RhbnQgdG9vIHNtYWxsIGJ5IGEgZmFjdG9yIG9mIDIgb24gc29tZSBtb2Rlcm4gbWFjaGluZXMuCgotIHF1b3ByaSdzIGVuY29kZSBhbmQgZGVjb2RlIG1ldGhvZHMgdGFrZSBhbiBvcHRpb25hbCBoZWFkZXIgcGFyYW1ldGVyLAogIHdoaWNoIGluZGljYXRlcyB3aGV0aGVyIG91dHB1dCBpcyBpbnRlbmRlZCBmb3IgdGhlIGhlYWRlciAnUScKICBlbmNvZGluZy4KCi0gVGhlIFNvY2tldFNlcnZlci5UaHJlYWRpbmdNaXhJbiBjbGFzcyBub3cgY2xvc2VzIHRoZSByZXF1ZXN0IGFmdGVyCiAgZmluaXNoX3JlcXVlc3QoKSByZXR1cm5zLiAgKE5vdCB3aGVuIGl0IGVycm9ycyBvdXQgdGhvdWdoLikKCi0gVGhlIG5udHBsaWIgbW9kdWxlJ3MgTk5UUC5ib2R5KCkgbWV0aG9kIGhhcyBncm93biBhIGBmaWxlJyBhcmd1bWVudAogIHRvIGFsbG93IHNhdmluZyB0aGUgbWVzc2FnZSBib2R5IHRvIGEgZmlsZS4KCi0gVGhlIGVtYWlsIHBhY2thZ2UgaGFzIGFkZGVkIGEgY2xhc3MgZW1haWwuUGFyc2VyLkhlYWRlclBhcnNlciB3aGljaAogIG9ubHkgcGFyc2VzIGhlYWRlcnMgYW5kIGRvZXMgbm90IHJlY3Vyc2UgaW50byB0aGUgbWVzc2FnZSdzIGJvZHkuCiAgQWxzbywgdGhlIG1vZHVsZS9jbGFzcyBNSU1FQXVkaW8gaGFzIGJlZW4gYWRkZWQgZm9yIHJlcHJlc2VudGluZwogIGF1ZGlvIGRhdGEgKGNvbnRyaWJ1dGVkIGJ5IEFudGhvbnkgQmF4dGVyKS4KCi0gZnRwbGliIHNob3VsZCBiZSBhYmxlIHRvIGhhbmRsZSBmaWxlcyA+IDJHQi4KCi0gQ29uZmlnUGFyc2VyLmdldGJvb2xlYW4oKSBub3cgYWxzbyBpbnRlcnByZXRzIFRSVUUsIEZBTFNFLCBZRVMsIE5PLAogIE9OLCBhbmQgT0ZGLgoKLSB4bWwuZG9tLm1pbmlkb20gTm9kZUxpc3Qgb2JqZWN0cyBub3cgc3VwcG9ydCB0aGUgbGVuZ3RoIGF0dHJpYnV0ZQogIGFuZCBpdGVtKCkgbWV0aG9kIGFzIHJlcXVpcmVkIGJ5IHRoZSBET00gc3BlY2lmaWNhdGlvbnMuCgpUb29scy9EZW1vcwoKLSBEZW1vL2RucyB3YXMgcmVtb3ZlZC4gIEl0IG5vIGxvbmdlciBzZXJ2ZXMgYW55IHB1cnBvc2U7IGEgcGFja2FnZQogIGRlcml2ZWQgZnJvbSBpdCBpcyBub3cgbWFpbnRhaW5lZCBieSBBbnRob255IEJheHRlciwgc2VlCiAgaHR0cDovL1B5RE5TLlNvdXJjZUZvcmdlLm5ldC4KCi0gVGhlIGZyZWV6ZSB0b29sIGhhcyBiZWVuIG1hZGUgbW9yZSByb2J1c3QsIGFuZCB0d28gbmV3IG9wdGlvbnMgaGF2ZQogIGJlZW4gYWRkZWQ6IC1YIGFuZCAtRS4KCkJ1aWxkCgotIGNvbmZpZ3VyZSB3aWxsIHVzZSBDWFggaW4gTElOS0NDIGlmIENYWCBpcyB1c2VkIHRvIGJ1aWxkIG1haW4oKSBhbmQKICB0aGUgc3lzdGVtIHJlcXVpcmVzIHRvIGxpbmsgYSBDKysgbWFpbiB1c2luZyB0aGUgQysrIGNvbXBpbGVyLgoKQyBBUEkKCi0gVGhlIGRvY3VtZW50YXRpb24gZm9yIHRoZSB0cF9jb21wYXJlIHNsb3QgaXMgdXBkYXRlZCB0byByZXF1aXJlIHRoYXQKICB0aGUgcmV0dXJuIHZhbHVlIG11c3QgYmUgLTEsIDAsIDE7IGFuIGFyYml0cmFyeSBudW1iZXIgPDAgb3IgPjAgaXMKICBub3QgY29ycmVjdC4gIFRoaXMgaXMgbm90IHlldCBlbmZvcmNlZCBidXQgd2lsbCBiZSBlbmZvcmNlZCBpbgogIFB5dGhvbiAyLjM7IGV2ZW4gbGF0ZXIsIHdlIG1heSB1c2UgLTIgdG8gaW5kaWNhdGUgZXJyb3JzIGFuZCArMiBmb3IKICAiTm90SW1wbGVtZW50ZWQiLiAgUmlnaHQgbm93LCAtMSBzaG91bGQgYmUgdXNlZCBmb3IgYW4gZXJyb3IgcmV0dXJuLgoKLSBQeUxvbmdfQXNMb25nTG9uZygpIG5vdyBhY2NlcHRzIGludCAoYXMgd2VsbCBhcyBsb25nKSBhcmd1bWVudHMuCiAgQ29uc2VxdWVudGx5LCBQeUFyZ19QYXJzZVR1cGxlJ3MgJ0wnIGNvZGUgYWxzbyBhY2NlcHRzIGludCAoYXMgd2VsbAogIGFzIGxvbmcpIGFyZ3VtZW50cy4KCi0gUHlUaHJlYWRfc3RhcnRfbmV3X3RocmVhZCgpIG5vdyByZXR1cm5zIGEgbG9uZyBpbnQgZ2l2aW5nIHRoZSB0aHJlYWQKICBJRCwgaWYgb25lIGNhbiBiZSBjYWxjdWxhdGVkOyBpdCByZXR1cm5zIC0xIGZvciBlcnJvciwgMCBpZiBubwogIHRocmVhZCBJRCBpcyBjYWxjdWxhdGVkICh0aGlzIGlzIGFuIGluY29tcGF0aWJsZSBjaGFuZ2UsIGJ1dCBvbmx5CiAgdGhlIHRocmVhZCBtb2R1bGUgdXNlZCB0aGlzIEFQSSkuICBUaGlzIGNvZGUgaGFzIG9ubHkgcmVhbGx5IGJlZW4KICB0ZXN0ZWQgb24gTGludXggYW5kIFdpbmRvd3M7IG90aGVyIHBsYXRmb3JtcyBwbGVhc2UgYmV3YXJlIChhbmQKICByZXBvcnQgYW55IGJ1Z3Mgb3Igc3RyYW5nZSBiZWhhdmlvcikuCgotIFB5VW5pY29kZV9Gcm9tRW5jb2RlZE9iamVjdCgpIG5vIGxvbmdlciBhY2NlcHRzIFVuaWNvZGUgb2JqZWN0cyBhcwogIGlucHV0LgoKTmV3IHBsYXRmb3JtcwoKVGVzdHMKCldpbmRvd3MKCi0gSW5zdGFsbGVyOiAgSWYgeW91IGluc3RhbGwgSURMRSwgYW5kIGRvbid0IGRpc2FibGUgZmlsZS1leHRlbnNpb24KICByZWdpc3RyYXRpb24sIGEgbmV3ICJFZGl0IHdpdGggSURMRSIgY29udGV4dCAocmlnaHQtY2xpY2spIG1lbnUgZW50cnkKICBpcyBjcmVhdGVkIGZvciAucHkgYW5kIC5weXcgZmlsZXMuCgotIFRoZSBzaWduYWwgbW9kdWxlIG5vdyBzdXBwb3J0cyBTSUdCUkVBSyBvbiBXaW5kb3dzLCB0aGFua3MgdG8gU3RldmVuCiAgU2NvdHQuICBOb3RlIHRoYXQgU0lHQlJFQUsgaXMgdW5pcXVlIHRvIFdpbmRvd3MuICBUaGUgZGVmYXVsdCBTSUdCUkVBSwogIGFjdGlvbiByZW1haW5zIHRvIGNhbGwgV2luMzIgRXhpdFByb2Nlc3MoKS4gIFRoaXMgY2FuIGJlIGNoYW5nZWQgdmlhCiAgc2lnbmFsLnNpZ25hbCgpLiAgRm9yIGV4YW1wbGU6CgogICMgTWFrZSBDdHJsK0JyZWFrIHJhaXNlIEtleWJvYXJkSW50ZXJydXB0LCBsaWtlIFB5dGhvbidzIGRlZmF1bHQgQ3RybCtDCiAgIyAoU0lHSU5UKSBiZWhhdmlvci4KICBpbXBvcnQgc2lnbmFsCiAgc2lnbmFsLnNpZ25hbChzaWduYWwuU0lHQlJFQUssCiAgICAgICAgICAgICAgICBzaWduYWwuZGVmYXVsdF9pbnRfaGFuZGxlcikKCiAgdHJ5OgogICAgICB3aGlsZSAxOgogICAgICAgICAgcGFzcwogIGV4Y2VwdCBLZXlib2FyZEludGVycnVwdDoKICAgICAgIyBXZSBnZXQgaGVyZSBvbiBDdHJsK0Mgb3IgQ3RybCtCcmVhayBub3c7IGlmIHdlIGhhZCBub3QgY2hhbmdlZAogICAgICAjIFNJR0JSRUFLLCBvbmx5IG9uIEN0cmwrQyAoYW5kIEN0cmwrQnJlYWsgd291bGQgdGVybWluYXRlIHRoZQogICAgICAjIHByb2dyYW0gd2l0aG91dCB0aGUgcG9zc2liaWxpdHkgZm9yIGFueSBQeXRob24tbGV2ZWwgY2xlYW51cCkuCiAgICAgIHByaW50ICJDbGVhbiBleGl0IgoKCldoYXQncyBOZXcgaW4gUHl0aG9uIDIuMmE0PwpSZWxlYXNlIGRhdGU6IDI4LVNlcC0yMDAxCj09PT09PT09PT09PT09PT09PT09PT09PT09PQoKVHlwZS9jbGFzcyB1bmlmaWNhdGlvbiBhbmQgbmV3LXN0eWxlIGNsYXNzZXMKCi0gcHlkb2MgYW5kIGluc3BlY3QgYXJlIG5vdyBhd2FyZSBvZiBuZXctc3R5bGUgY2xhc3NlczsKICBlLmcuIGhlbHAobGlzdCkgYXQgdGhlIGludGVyYWN0aXZlIHByb21wdCBub3cgc2hvd3MgcHJvcGVyCiAgZG9jdW1lbnRhdGlvbiBmb3IgYWxsIG9wZXJhdGlvbnMgb24gbGlzdCBvYmplY3RzLgoKLSBBcHBsaWNhdGlvbnMgdXNpbmcgSmltIEZ1bHRvbidzIEV4dGVuc2lvbkNsYXNzIG1vZHVsZSBjYW4gbm93IHNhZmVseQogIGJlIHVzZWQgd2l0aCBQeXRob24gMi4yLiAgSW4gcGFydGljdWxhciwgWm9wZSAyLjQuMSBub3cgd29ya3Mgd2l0aAogIFB5dGhvbiAyLjIgKGFzIHdlbGwgYXMgd2l0aCBQeXRob24gMi4xLjEpLiAgVGhlIERlbW8vbWV0YWNsYXNzCiAgZXhhbXBsZXMgYWxzbyB3b3JrIGFnYWluLiAgSXQgaXMgaG9wZWQgdGhhdCBHdGsgYW5kIEJvb3N0IGFsc28gd29yawogIHdpdGggMi4yYTQgYW5kIGJleW9uZC4gIChJZiB5b3UgY2FuIGNvbmZpcm0gdGhpcywgcGxlYXNlIHdyaXRlCiAgd2VibWFzdGVyQHB5dGhvbi5vcmc7IGlmIHRoZXJlIGFyZSBzdGlsbCBwcm9ibGVtcywgcGxlYXNlIG9wZW4gYSBidWcKICByZXBvcnQgb24gU291cmNlRm9yZ2UuKQoKLSBwcm9wZXJ0eSgpIG5vdyB0YWtlcyA0IGtleXdvcmQgYXJndW1lbnRzOiAgZmdldCwgZnNldCwgZmRlbCBhbmQgZG9jLgogIFRoZXNlIG1hcCB0byByZWFkLW9ubHkgYXR0cmlidXRlcyAnZmdldCcsICdmc2V0JywgJ2ZkZWwnLCBhbmQgJ19fZG9jX18nCiAgaW4gdGhlIGNvbnN0cnVjdGVkIHByb3BlcnR5IG9iamVjdC4gIGZnZXQsIGZzZXQgYW5kIGZkZWwgd2VyZW4ndAogIGRpc2NvdmVyYWJsZSBmcm9tIFB5dGhvbiBpbiAyLjJhMy4gIF9fZG9jX18gaXMgbmV3LCBhbmQgYWxsb3dzIHRvCiAgYXNzb2NpYXRlIGEgZG9jc3RyaW5nIHdpdGggYSBwcm9wZXJ0eS4KCi0gQ29tcGFyaXNvbiBvdmVybG9hZGluZyBpcyBub3cgbW9yZSBjb21wbGV0ZWx5IGltcGxlbWVudGVkLiAgRm9yCiAgZXhhbXBsZSwgYSBzdHIgc3ViY2xhc3MgaW5zdGFuY2UgY2FuIHByb3Blcmx5IGJlIGNvbXBhcmVkIHRvIGEgc3RyCiAgaW5zdGFuY2UsIGFuZCBpdCBjYW4gcHJvcGVybHkgb3ZlcmxvYWQgY29tcGFyaXNvbi4gIERpdHRvIGZvciBtb3N0CiAgb3RoZXIgYnVpbHQtaW4gb2JqZWN0IHR5cGVzLgoKLSBUaGUgcmVwcigpIG9mIG5ldy1zdHlsZSBjbGFzc2VzIGhhcyBjaGFuZ2VkOyBpbnN0ZWFkIG9mIDx0eXBlCiAgJ00uRm9vJz4gYSBuZXctc3R5bGUgY2xhc3MgaXMgbm93IHJlbmRlcmVkIGFzIDxjbGFzcyAnTS5Gb28nPiwKICAqZXhjZXB0KiBmb3IgYnVpbHQtaW4gdHlwZXMsIHdoaWNoIGFyZSBzdGlsbCByZW5kZXJlZCBhcyA8dHlwZQogICdGb28nPiAodG8gYXZvaWQgdXBzZXR0aW5nIGV4aXN0aW5nIGNvZGUgdGhhdCBtaWdodCBwYXJzZSBvcgogIG90aGVyd2lzZSByZWx5IG9uIHJlcHIoKSBvZiBjZXJ0YWluIHR5cGUgb2JqZWN0cykuCgotIFRoZSByZXByKCkgb2YgbmV3LXN0eWxlIG9iamVjdHMgaXMgbm93IGFsd2F5cyA8Rm9vIG9iamVjdCBhdCBYWFg+OwogIHByZXZpb3VzbHksIGl0IHdhcyBzb21ldGltZXMgPEZvbyBpbnN0YW5jZSBhdCBYWFg+LgoKLSBGb3IgbmV3LXN0eWxlIGNsYXNzZXMsIHdoYXQgd2FzIHByZXZpb3VzbHkgY2FsbGVkIF9fZ2V0YXR0cl9fIGlzIG5vdwogIGNhbGxlZCBfX2dldGF0dHJpYnV0ZV9fLiAgVGhpcyBtZXRob2QsIGlmIGRlZmluZWQsIGlzIGNhbGxlZCBmb3IKICAqZXZlcnkqIGF0dHJpYnV0ZSBhY2Nlc3MuICBBIG5ldyBfX2dldGF0dHJfXyBob29rIG1vcmUgc2ltaWxhciB0byB0aGUKICBvbmUgaW4gY2xhc3NpYyBjbGFzc2VzIGlzIGRlZmluZWQgd2hpY2ggaXMgY2FsbGVkIG9ubHkgaWYgcmVndWxhcgogIGF0dHJpYnV0ZSBhY2Nlc3MgcmFpc2VzIEF0dHJpYnV0ZUVycm9yOyB0byBjYXRjaCAqYWxsKiBhdHRyaWJ1dGUKICBhY2Nlc3MsIHlvdSBjYW4gdXNlIF9fZ2V0YXR0cmlidXRlX18gKGZvciBuZXctc3R5bGUgY2xhc3NlcykuICBJZgogIGJvdGggYXJlIGRlZmluZWQsIF9fZ2V0YXR0cmlidXRlX18gaXMgY2FsbGVkIGZpcnN0LCBhbmQgaWYgaXQgcmFpc2VzCiAgQXR0cmlidXRlRXJyb3IsIF9fZ2V0YXR0cl9fIGlzIGNhbGxlZC4KCi0gVGhlIF9fY2xhc3NfXyBhdHRyaWJ1dGUgb2YgbmV3LXN0eWxlIG9iamVjdHMgY2FuIGJlIGFzc2lnbmVkIHRvLgogIFRoZSBuZXcgY2xhc3MgbXVzdCBoYXZlIHRoZSBzYW1lIEMtbGV2ZWwgb2JqZWN0IGxheW91dCBhcyB0aGUgb2xkCiAgY2xhc3MuCgotIFRoZSBidWlsdGluIGZpbGUgdHlwZSBjYW4gYmUgc3ViY2xhc3NlZCBub3cuICBJbiB0aGUgdXN1YWwgcGF0dGVybiwKICAiZmlsZSIgaXMgdGhlIG5hbWUgb2YgdGhlIGJ1aWx0aW4gdHlwZSwgYW5kIGZpbGUoKSBpcyBhIG5ldyBidWlsdGluCiAgY29uc3RydWN0b3IsIHdpdGggdGhlIHNhbWUgc2lnbmF0dXJlIGFzIHRoZSBidWlsdGluIG9wZW4oKSBmdW5jdGlvbi4KICBmaWxlKCkgaXMgbm93IHRoZSBwcmVmZXJyZWQgd2F5IHRvIG9wZW4gYSBmaWxlLgoKLSBQcmV2aW91c2x5LCBfX25ld19fIHdvdWxkIG9ubHkgc2VlIHNlcXVlbnRpYWwgYXJndW1lbnRzIHBhc3NlZCB0bwogIHRoZSB0eXBlIGluIGEgY29uc3RydWN0b3IgY2FsbDsgX19pbml0X18gd291bGQgc2VlIGJvdGggc2VxdWVudGlhbAogIGFuZCBrZXl3b3JkIGFyZ3VtZW50cy4gIFRoaXMgbWFkZSBubyBzZW5zZSB3aGF0c29ldmVyIGFueSBtb3JlLCBzbwogIG5vdyBib3RoIF9fbmV3X18gYW5kIF9faW5pdF9fIHNlZSBhbGwgYXJndW1lbnRzLgoKLSBQcmV2aW91c2x5LCBoYXNoKCkgYXBwbGllZCB0byBhbiBpbnN0YW5jZSBvZiBhIHN1YmNsYXNzIG9mIHN0ciBvcgogIHVuaWNvZGUgYWx3YXlzIHJldHVybmVkIDAuICBUaGlzIGhhcyBiZWVuIHJlcGFpcmVkLgoKLSBQcmV2aW91c2x5LCBhbiBvcGVyYXRpb24gb24gYW4gaW5zdGFuY2Ugb2YgYSBzdWJjbGFzcyBvZiBhbgogIGltbXV0YWJsZSB0eXBlIChpbnQsIGxvbmcsIGZsb2F0LCBjb21wbGV4LCB0dXBsZSwgc3RyLCB1bmljb2RlKSwKICB3aGVyZSB0aGUgc3VidHlwZSBkaWRuJ3Qgb3ZlcnJpZGUgdGhlIG9wZXJhdGlvbiAoYW5kIHNvIHRoZQogIG9wZXJhdGlvbiB3YXMgaGFuZGxlZCBieSB0aGUgYnVpbHRpbiB0eXBlKSwgY291bGQgcmV0dXJuIHRoYXQKICBpbnN0YW5jZSBpbnN0ZWFkIGEgdmFsdWUgb2YgdGhlIGJhc2UgdHlwZS4gIEZvciBleGFtcGxlLCBpZiBzIHdhcyBvZgogIGEgc3RyIHN1YmNsYXNzIHR5cGUsIHNbOl0gcmV0dXJuZWQgcyBhcy1pcy4gIE5vdyBpdCByZXR1cm5zIGEgc3RyCiAgd2l0aCB0aGUgc2FtZSB2YWx1ZSBhcyBzLgoKLSBQcm92aXNpb25hbCBzdXBwb3J0IGZvciBwaWNrbGluZyBuZXctc3R5bGUgb2JqZWN0cyBoYXMgYmVlbiBhZGRlZC4KCkNvcmUKCi0gZmlsZS53cml0ZWxpbmVzKCkgbm93IGFjY2VwdHMgYW55IGl0ZXJhYmxlIG9iamVjdCBwcm9kdWNpbmcgc3RyaW5ncy4KCi0gUHlVbmljb2RlX0Zyb21FbmNvZGVkT2JqZWN0KCkgbm93IHdvcmtzIHZlcnkgbXVjaCBsaWtlCiAgUHlPYmplY3RfU3RyKG9iaikgaW4gdGhhdCBpdCB0cmllcyB0byB1c2UgX19zdHJfXy90cF9zdHIKICBvbiB0aGUgb2JqZWN0IGlmIHRoZSBvYmplY3QgaXMgbm90IGEgc3RyaW5nIG9yIGJ1ZmZlci4gVGhpcwogIG1ha2VzIHVuaWNvZGUoKSBiZWhhdmUgbGlrZSBzdHIoKSB3aGVuIGFwcGxpZWQgdG8gbm9uLXN0cmluZy9idWZmZXIKICBvYmplY3RzLgoKLSBQeUZpbGVfV3JpdGVPYmplY3Qgbm93IHBhc3NlcyBVbmljb2RlIG9iamVjdHMgdG8gdGhlIGZpbGUncyB3cml0ZQogIG1ldGhvZC4gQXMgYSByZXN1bHQsIGFsbCBmaWxlLWxpa2Ugb2JqZWN0cyB3aGljaCBtYXkgYmUgdGhlIHRhcmdldAogIG9mIGEgcHJpbnQgc3RhdGVtZW50IG11c3Qgc3VwcG9ydCBVbmljb2RlIG9iamVjdHMsIGkuZS4gdGhleSBtdXN0CiAgYXQgbGVhc3QgY29udmVydCB0aGVtIGludG8gQVNDSUkgc3RyaW5ncy4KCi0gVGhyZWFkIHNjaGVkdWxpbmcgb24gU29sYXJpcyBzaG91bGQgYmUgaW1wcm92ZWQ7IGl0IGlzIG5vIGxvbmdlcgogIG5lY2Vzc2FyeSB0byBpbnNlcnQgYSBzbWFsbCBzbGVlcCBhdCB0aGUgc3RhcnQgb2YgYSB0aHJlYWQgaW4gb3JkZXIKICB0byBsZXQgb3RoZXIgcnVubmFibGUgdGhyZWFkcyBiZSBzY2hlZHVsZWQuCgpMaWJyYXJ5CgotIFN0cmluZ0lPLlN0cmluZ0lPIGluc3RhbmNlcyBhbmQgY1N0cmluZ0lPLlN0cmluZ0lPIGluc3RhbmNlcyBzdXBwb3J0CiAgcmVhZCBjaGFyYWN0ZXIgYnVmZmVyIGNvbXBhdGlibGUgb2JqZWN0cyBmb3IgdGhlaXIgLndyaXRlKCkgbWV0aG9kcy4KICBUaGVzZSBvYmplY3RzIGFyZSBjb252ZXJ0ZWQgdG8gc3RyaW5ncyBhbmQgdGhlbiBoYW5kbGVkIGFzIHN1Y2gKICBieSB0aGUgaW5zdGFuY2VzLgoKLSBUaGUgImVtYWlsIiBwYWNrYWdlIGhhcyBiZWVuIGFkZGVkLiAgVGhpcyBpcyBiYXNpY2FsbHkgYSBwb3J0IG9mIHRoZQogIG1pbWVsaWIgcGFja2FnZSA8aHR0cDovL3NmLm5ldC9wcm9qZWN0cy9taW1lbGliPiB3aXRoIEFQSSBjaGFuZ2VzCiAgYW5kIHNvbWUgaW1wbGVtZW50YXRpb25zIHVwZGF0ZWQgdG8gdXNlIGl0ZXJhdG9ycyBhbmQgZ2VuZXJhdG9ycy4KCi0gZGlmZmxpYi5uZGlmZigpIGFuZCBkaWZmbGliLkRpZmZlci5jb21wYXJlKCkgYXJlIGdlbmVyYXRvcnMgbm93LiAgVGhpcwogIHJlc3RvcmVzIHRoZSBhYmlsaXR5IG9mIFRvb2xzL3NjcmlwdHMvbmRpZmYucHkgdG8gc3RhcnQgcHJvZHVjaW5nIG91dHB1dAogIGJlZm9yZSB0aGUgZW50aXJlIGNvbXBhcmlzb24gaXMgY29tcGxldGUuCgotIFN0cmluZ0lPLlN0cmluZ0lPIGluc3RhbmNlcyBhbmQgY1N0cmluZ0lPLlN0cmluZ0lPIGluc3RhbmNlcyBzdXBwb3J0CiAgaXRlcmF0aW9uIGp1c3QgbGlrZSBmaWxlIG9iamVjdHMgKGkuZS4gdGhlaXIgLnJlYWRsaW5lKCkgbWV0aG9kIGlzCiAgY2FsbGVkIGZvciBlYWNoIGl0ZXJhdGlvbiB1bnRpbCBpdCByZXR1cm5zIGFuIGVtcHR5IHN0cmluZykuCgotIFRoZSBjb2RlY3MgbW9kdWxlIGhhcyBncm93biBmb3VyIG5ldyBoZWxwZXIgQVBJcyB0byBhY2Nlc3MKICBidWlsdGluIGNvZGVjczogZ2V0ZW5jb2RlcigpLCBnZXRkZWNvZGVyKCksIGdldHJlYWRlcigpLAogIGdldHdyaXRlcigpLgoKLSBTaW1wbGVYTUxSUENTZXJ2ZXI6IGEgbmV3IG1vZHVsZSAoYmFzZWQgdXBvbiBTaW1wbGVIVE1MU2VydmVyKQogIHNpbXBsaWZpZXMgd3JpdGluZyBYTUwgUlBDIHNlcnZlcnMuCgotIG9zLnBhdGgucmVhbHBhdGgoKTogYSBuZXcgZnVuY3Rpb24gdGhhdCByZXR1cm5zIHRoZSBhYnNvbHV0ZSBwYXRobmFtZQogIGFmdGVyIGludGVycHJldGF0aW9uIG9mIHN5bWJvbGljIGxpbmtzLiAgT24gbm9uLVVuaXggc3lzdGVtcywgdGhpcwogIGlzIGFuIGFsaWFzIGZvciBvcy5wYXRoLmFic3BhdGgoKS4KCi0gb3BlcmF0b3IuaW5kZXhPZigpIChQeVNlcXVlbmNlX0luZGV4KCkgaW4gdGhlIEMgQVBJKSBub3cgd29ya3Mgd2l0aCBhbnkKICBpdGVyYWJsZSBvYmplY3QuCgotIHNtdHBsaWIgbm93IHN1cHBvcnRzIHZhcmlvdXMgYXV0aGVudGljYXRpb24gYW5kIHNlY3VyaXR5IGZlYXR1cmVzIG9mCiAgdGhlIFNNVFAgcHJvdG9jb2wgdGhyb3VnaCB0aGUgbmV3IGxvZ2luKCkgYW5kIHN0YXJ0dGxzKCkgbWV0aG9kcy4KCi0gaG1hYzogYSBuZXcgbW9kdWxlIGltcGxlbWVudGluZyBrZXllZCBoYXNoaW5nIGZvciBtZXNzYWdlCiAgYXV0aGVudGljYXRpb24uCgotIG1pbWV0eXBlcyBub3cgcmVjb2duaXplcyBtb3JlIGV4dGVuc2lvbnMgYW5kIGZpbGUgdHlwZXMuICBBdCB0aGUKICBzYW1lIHRpbWUsIHNvbWUgbWFwcGluZ3Mgbm90IHNhbmN0aW9uZWQgYnkgSUFOQSB3ZXJlIHJlbW92ZWQuCgotIFRoZSAiY29tcGlsZXIiIHBhY2thZ2UgaGFzIGJlZW4gYnJvdWdodCB1cCB0byBkYXRlIHRvIHRoZSBzdGF0ZSBvZgogIFB5dGhvbiAyLjIgYnl0ZWNvZGUgZ2VuZXJhdGlvbi4gIEl0IGhhcyBhbHNvIGJlZW4gcHJvbW90ZWQgZnJvbSBhCiAgVG9vbCB0byBhIHN0YW5kYXJkIGxpYnJhcnkgcGFja2FnZS4gIChUb29scy9jb21waWxlciBzdGlsbCBleGlzdHMgYXMKICBhIHNhbXBsZSBkcml2ZXIuKQoKVG9vbHMKCkJ1aWxkCgotIExhcmdlIGZpbGUgc3VwcG9ydCAoTEZTKSBpcyBub3cgYXV0b21hdGljIHdoZW4gdGhlIHBsYXRmb3JtIHN1cHBvcnRzCiAgaXQ7IG5vIG1vcmUgbWFudWFsIGNvbmZpZ3VyYXRpb24gdHdlYWtzIGFyZSBuZWVkZWQuICBPbiBMaW51eCwgYXQKICBsZWFzdCwgaXQncyBwb3NzaWJsZSB0byBoYXZlIGEgc3lzdGVtIHdob3NlIEMgbGlicmFyeSBzdXBwb3J0cyBsYXJnZQogIGZpbGVzIGJ1dCB3aG9zZSBrZXJuZWwgZG9lc24ndDsgaW4gdGhpcyBjYXNlLCBsYXJnZSBmaWxlIHN1cHBvcnQgaXMKICBzdGlsbCBlbmFibGVkIGJ1dCBkb2Vzbid0IGRvIHlvdSBhbnkgZ29vZCB1bmxlc3MgeW91IHVwZ3JhZGUgeW91cgogIGtlcm5lbCBvciBzaGFyZSB5b3VyIFB5dGhvbiBleGVjdXRhYmxlIHdpdGggYW5vdGhlciBzeXN0ZW0gd2hvc2UKICBrZXJuZWwgaGFzIGxhcmdlIGZpbGUgc3VwcG9ydC4KCi0gVGhlIGNvbmZpZ3VyZSBzY3JpcHQgbm93IHN1cHBsaWVzIHBsYXVzaWJsZSBkZWZhdWx0cyBpbiBhCiAgY3Jvc3MtY29tcGlsYXRpb24gZW52aXJvbm1lbnQuICBUaGlzIGRvZXNuJ3QgbWVhbiB0aGF0IHRoZSBzdXBwbGllZAogIHZhbHVlcyBhcmUgYWx3YXlzIGNvcnJlY3QsIG9yIHRoYXQgY3Jvc3MtY29tcGlsYXRpb24gbm93IHdvcmtzCiAgZmxhd2xlc3NseSAtLSBidXQgaXQncyBhIGZpcnN0IHN0ZXAgKGFuZCBpdCBzaHV0cyB1cCBtb3N0IG9mCiAgYXV0b2NvbmYncyB3YXJuaW5ncyBhYm91dCBBQ19UUllfUlVOKS4KCi0gVGhlIFVuaXggYnVpbGQgaXMgbm93IGEgYml0IGxlc3MgY2hhdHR5LCBjb3VydGVzeSBvZiB0aGUgcGFyc2VyCiAgZ2VuZXJhdG9yLiAgVGhlIGJ1aWxkIGlzIGNvbXBsZXRlbHkgc2lsZW50IChleGNlcHQgZm9yIGVycm9ycykgd2hlbgogIHVzaW5nICJtYWtlIC1zIiwgdGhhbmtzIHRvIGEgLXEgb3B0aW9uIHRvIHNldHVwLnB5LgoKQyBBUEkKCi0gVGhlICJzdHJ1Y3RtZW1iZXIiIEFQSSBub3cgc3VwcG9ydHMgc29tZSBuZXcgZmxhZyBiaXRzIHRvIGRlbnkgcmVhZAogIGFuZC9vciB3cml0ZSBhY2Nlc3MgdG8gYXR0cmlidXRlcyBpbiByZXN0cmljdGVkIGV4ZWN1dGlvbiBtb2RlLgoKTmV3IHBsYXRmb3JtcwoKLSBDb21wYXEncyBpUEFRIGhhbmRoZWxkLCBydW5uaW5nIHRoZSAiZmFtaWxpYXIiIExpbnV4IGRpc3RyaWJ1dGlvbgogIChodHRwOi8vZmFtaWxpYXIuaGFuZGhlbGRzLm9yZykuCgpUZXN0cwoKLSBUaGUgImNsYXNzaWMiIHN0YW5kYXJkIHRlc3RzLCB3aGljaCB3b3JrIGJ5IGNvbXBhcmluZyBzdGRvdXQgdG8KICBhbiBleHBlY3RlZC1vdXRwdXQgZmlsZSB1bmRlciBMaWIvdGVzdC9vdXRwdXQvLCBubyBsb25nZXIgc3RvcCBhdAogIHRoZSBmaXJzdCBtaXNtYXRjaC4gIEluc3RlYWQgdGhlIHRlc3QgaXMgcnVuIHRvIGNvbXBsZXRpb24sIGFuZCBhCiAgdmFyaWFudCBvZiBuZGlmZi1zdHlsZSBjb21wYXJpc29uIGlzIHVzZWQgdG8gcmVwb3J0IGFsbCBkaWZmZXJlbmNlcy4KICBUaGlzIGlzIG11Y2ggZWFzaWVyIHRvIHVuZGVyc3RhbmQgdGhhbiB0aGUgcHJldmlvdXMgc3R5bGUgb2YgcmVwb3J0aW5nLgoKLSBUaGUgdW5pdHRlc3QtYmFzZWQgc3RhbmRhcmQgdGVzdHMgbm93IHVzZSByZWdydGVzdCdzIHRlc3RfbWFpbigpCiAgY29udmVudGlvbiwgaW5zdGVhZCBvZiBydW5uaW5nIGFzIGEgc2lkZS1lZmZlY3Qgb2YgbWVyZWx5IGJlaW5nCiAgaW1wb3J0ZWQuICBUaGlzIGFsbG93cyB0aGVzZSB0ZXN0cyB0byBiZSBydW4gaW4gbW9yZSBuYXR1cmFsIGFuZAogIGZsZXhpYmxlIHdheXMgYXMgdW5pdHRlc3RzLCBvdXRzaWRlIHRoZSByZWdydGVzdCBmcmFtZXdvcmsuCgotIHJlZ3J0ZXN0LnB5IGlzIG11Y2ggYmV0dGVyIGludGVncmF0ZWQgd2l0aCB1bml0dGVzdCBhbmQgZG9jdGVzdCBub3csCiAgZXNwZWNpYWxseSBpbiByZWdhcmQgdG8gcmVwb3J0aW5nIGVycm9ycy4KCldpbmRvd3MKCi0gTGFyZ2UgZmlsZSBzdXBwb3J0IG5vdyBhbHNvIHdvcmtzIGZvciBmaWxlcyA+IDRHQiwgb24gZmlsZXN5c3RlbXMKICB0aGF0IHN1cHBvcnQgaXQgKE5URlMgdW5kZXIgV2luZG93cyAyMDAwKS4gIFNlZSAiV2hhdCdzIE5ldyBpbgogIFB5dGhvbiAyLjJhMyIgZm9yIG1vcmUgZGV0YWlsLgoKCldoYXQncyBOZXcgaW4gUHl0aG9uIDIuMmEzPwpSZWxlYXNlIERhdGU6IDA3LVNlcC0yMDAxCj09PT09PT09PT09PT09PT09PT09PT09PT09PQoKQ29yZQoKLSBDb252ZXJzaW9uIG9mIGxvbmcgdG8gZmxvYXQgbm93IHJhaXNlcyBPdmVyZmxvd0Vycm9yIGlmIHRoZSBsb25nIGlzIHRvbwogIGJpZyB0byByZXByZXNlbnQgYXMgYSBDIGRvdWJsZS4KCi0gVGhlIDMtYXJndW1lbnQgYnVpbHRpbiBwb3coKSBubyBsb25nZXIgYWxsb3dzIGEgdGhpcmQgbm9uLU5vbmUgYXJndW1lbnQKICBpZiBlaXRoZXIgb2YgdGhlIGZpcnN0IHR3byBhcmd1bWVudHMgaXMgYSBmbG9hdCwgb3IgaWYgYm90aCBhcmUgb2YKICBpbnRlZ2VyIHR5cGVzIGFuZCB0aGUgc2Vjb25kIGFyZ3VtZW50IGlzIG5lZ2F0aXZlIChpbiB3aGljaCBsYXR0ZXIgY2FzZQogIHRoZSBhcmd1bWVudHMgYXJlIGNvbnZlcnRlZCB0byBmbG9hdCwgc28gdGhpcyBpcyByZWFsbHkgdGhlIHNhbWUKICByZXN0cmljdGlvbikuCgotIFRoZSBidWlsdGluIGRpcigpIG5vdyByZXR1cm5zIG1vcmUgaW5mb3JtYXRpb24sIGFuZCBzb21ldGltZXMgbXVjaAogIG1vcmUsIGdlbmVyYWxseSBuYW1pbmcgYWxsIGF0dHJpYnV0ZXMgb2YgYW4gb2JqZWN0LCBhbmQgYWxsIGF0dHJpYnV0ZXMKICByZWFjaGFibGUgZnJvbSB0aGUgb2JqZWN0IHZpYSBpdHMgY2xhc3MsIGFuZCBmcm9tIGl0cyBjbGFzcydzIGJhc2UKICBjbGFzc2VzLCBhbmQgc28gb24gZnJvbSB0aGVtIHRvby4gIEV4YW1wbGU6ICBpbiAyLjJhMiwgZGlyKFtdKSByZXR1cm5lZAogIGFuIGVtcHR5IGxpc3QuICBJbiAyLjJhMywKCiAgPj4+IGRpcihbXSkKICBbJ19fYWRkX18nLCAnX19jbGFzc19fJywgJ19fY29udGFpbnNfXycsICdfX2RlbGF0dHJfXycsICdfX2RlbGl0ZW1fXycsCiAgICdfX2VxX18nLCAnX19nZV9fJywgJ19fZ2V0YXR0cl9fJywgJ19fZ2V0aXRlbV9fJywgJ19fZ2V0c2xpY2VfXycsCiAgICdfX2d0X18nLCAnX19oYXNoX18nLCAnX19pYWRkX18nLCAnX19pbXVsX18nLCAnX19pbml0X18nLCAnX19sZV9fJywKICAgJ19fbGVuX18nLCAnX19sdF9fJywgJ19fbXVsX18nLCAnX19uZV9fJywgJ19fbmV3X18nLCAnX19yZXByX18nLAogICAnX19ybXVsX18nLCAnX19zZXRhdHRyX18nLCAnX19zZXRpdGVtX18nLCAnX19zZXRzbGljZV9fJywgJ19fc3RyX18nLAogICAnYXBwZW5kJywgJ2NvdW50JywgJ2V4dGVuZCcsICdpbmRleCcsICdpbnNlcnQnLCAncG9wJywgJ3JlbW92ZScsCiAgICdyZXZlcnNlJywgJ3NvcnQnXQoKICBkaXIobW9kdWxlKSBjb250aW51ZXMgdG8gcmV0dXJuIG9ubHkgdGhlIG1vZHVsZSdzIGF0dHJpYnV0ZXMsIHRob3VnaC4KCi0gT3ZlcmZsb3dpbmcgb3BlcmF0aW9ucyBvbiBwbGFpbiBpbnRzIG5vdyByZXR1cm4gYSBsb25nIGludCByYXRoZXIKICB0aGFuIHJhaXNpbmcgT3ZlcmZsb3dFcnJvci4gIFRoaXMgaXMgYSBwYXJ0aWFsIGltcGxlbWVudGF0aW9uIG9mIFBFUAogIDIzNy4gIFlvdSBjYW4gdXNlIC1XZGVmYXVsdDo6T3ZlcmZsb3dXYXJuaW5nIHRvIGVuYWJsZSBhIHdhcm5pbmcgZm9yCiAgdGhpcyBzaXR1YXRpb24sIGFuZCAtV2Vycm9yOjpPdmVyZmxvd1dhcm5pbmcgdG8gcmV2ZXJ0IHRvIHRoZSBvbGQKICBPdmVyZmxvd0Vycm9yIGV4Y2VwdGlvbi4KCi0gQSBuZXcgY29tbWFuZCBsaW5lIG9wdGlvbiwgLVE8YXJnPiwgaXMgYWRkZWQgdG8gY29udHJvbCBydW4tdGltZQogIHdhcm5pbmdzIGZvciB0aGUgdXNlIG9mIGNsYXNzaWMgZGl2aXNpb24uICAoU2VlIFBFUCAyMzguKSAgUG9zc2libGUKICB2YWx1ZXMgYXJlIC1Rb2xkLCAtUXdhcm4sIC1Rd2FybmFsbCwgYW5kIC1RbmV3LiAgVGhlIGRlZmF1bHQgaXMKICAtUW9sZCwgbWVhbmluZyB0aGUgLyBvcGVyYXRvciBoYXMgaXRzIGNsYXNzaWMgbWVhbmluZyBhbmQgbm8KICB3YXJuaW5ncyBhcmUgaXNzdWVkLiAgVXNpbmcgLVF3YXJuIGlzc3VlcyBhIHJ1bi10aW1lIHdhcm5pbmcgYWJvdXQKICBhbGwgdXNlcyBvZiBjbGFzc2ljIGRpdmlzaW9uIGZvciBpbnQgYW5kIGxvbmcgYXJndW1lbnRzOyAtUXdhcm5hbGwKICBhbHNvIHdhcm5zIGFib3V0IGNsYXNzaWMgZGl2aXNpb24gZm9yIGZsb2F0IGFuZCBjb21wbGV4IGFyZ3VtZW50cwogIChmb3IgdXNlIHdpdGggZml4ZGl2LnB5KS4KICBbTm90ZTogIHRoZSByZW1haW5kZXIgb2YgdGhpcyBwYXJhZ3JhcGggKHByZXNlcnZlZCBiZWxvdykgYmVjYW1lCiAgIG9ic29sZXRlIGluIDIuMmMxIC0tIC1RbmV3IGhhcyBnbG9iYWwgZWZmZWN0IGluIDIuMl0KICA8b2Jzb2xldGU+CiAgVXNpbmcgLVFuZXcgaXMgcXVlc3Rpb25hYmxlOyBpdCB0dXJucyBvbiBuZXcgZGl2aXNpb24gYnkgZGVmYXVsdCwgYnV0CiAgb25seSBpbiB0aGUgX19tYWluX18gbW9kdWxlLiAgWW91IGNhbiB1c2VmdWxseSBjb21iaW5lIC1Rd2FybiBvcgogIC1Rd2FybmFsbCBhbmQgLVFuZXc6IHRoaXMgZ2l2ZXMgdGhlIF9fbWFpbl9fIG1vZHVsZSBuZXcgZGl2aXNpb24sIGFuZAogIHdhcm5zIGFib3V0IGNsYXNzaWMgZGl2aXNpb24gZXZlcnl3aGVyZSBlbHNlLgogIDwvb2Jzb2xldGU+CgotIE1hbnkgYnVpbHQtaW4gdHlwZXMgY2FuIG5vdyBiZSBzdWJjbGFzc2VkLiAgVGhpcyBhcHBsaWVzIHRvIGludCwKICBsb25nLCBmbG9hdCwgc3RyLCB1bmljb2RlLCBhbmQgdHVwbGUuICAoVGhlIHR5cGVzIGNvbXBsZXgsIGxpc3QgYW5kCiAgZGljdGlvbmFyeSBjYW4gYWxzbyBiZSBzdWJjbGFzc2VkOyB0aGlzIHdhcyBpbnRyb2R1Y2VkIGVhcmxpZXIuKQogIE5vdGUgdGhhdCByZXN0cmljdGlvbnMgYXBwbHkgd2hlbiBzdWJjbGFzc2luZyBpbW11dGFibGUgYnVpbHQtaW4KICB0eXBlczogeW91IGNhbiBvbmx5IGFmZmVjdCB0aGUgdmFsdWUgb2YgdGhlIGluc3RhbmNlIGJ5IG92ZXJsb2FkaW5nCiAgX19uZXdfXy4gIFlvdSBjYW4gYWRkIG11dGFibGUgYXR0cmlidXRlcywgYW5kIHRoZSBzdWJjbGFzcyBpbnN0YW5jZXMKICB3aWxsIGhhdmUgYSBfX2RpY3RfXyBhdHRyaWJ1dGUsIGJ1dCB5b3UgY2Fubm90IGNoYW5nZSB0aGUgInZhbHVlIgogIChhcyBpbXBsZW1lbnRlZCBieSB0aGUgYmFzZSBjbGFzcykgb2YgYW4gaW1tdXRhYmxlIHN1YmNsYXNzIGluc3RhbmNlCiAgb25jZSBpdCBpcyBjcmVhdGVkLgoKLSBUaGUgZGljdGlvbmFyeSBjb25zdHJ1Y3RvciBub3cgdGFrZXMgYW4gb3B0aW9uYWwgYXJndW1lbnQsIGEKICBtYXBwaW5nLWxpa2Ugb2JqZWN0LCBhbmQgaW5pdGlhbGl6ZXMgdGhlIGRpY3Rpb25hcnkgZnJvbSBpdHMKICAoa2V5LCB2YWx1ZSkgcGFpcnMuCgotIEEgbmV3IGJ1aWx0LWluIHR5cGUsIHN1cGVyLCBoYXMgYmVlbiBhZGRlZC4gIFRoaXMgZmFjaWxpdGF0ZXMgbWFraW5nCiAgImNvb3BlcmF0aXZlIHN1cGVyIGNhbGxzIiBpbiBhIG11bHRpcGxlIGluaGVyaXRhbmNlIHNldHRpbmcuICBGb3IgYW4KICBleHBsYW5hdGlvbiwgc2VlIGh0dHA6Ly93d3cucHl0aG9uLm9yZy8yLjIvZGVzY3JpbnRyby5odG1sI2Nvb3BlcmF0aW9uCgotIEEgbmV3IGJ1aWx0LWluIHR5cGUsIHByb3BlcnR5LCBoYXMgYmVlbiBhZGRlZC4gIFRoaXMgZW5hYmxlcyB0aGUKICBjcmVhdGlvbiBvZiAicHJvcGVydGllcyIuICBUaGVzZSBhcmUgYXR0cmlidXRlcyBpbXBsZW1lbnRlZCBieQogIGdldHRlciBhbmQgc2V0dGVyIGZ1bmN0aW9ucyAob3Igb25seSBvbmUgb2YgdGhlc2UgZm9yIHJlYWQtb25seSBvcgogIHdyaXRlLW9ubHkgYXR0cmlidXRlcyksIHdpdGhvdXQgdGhlIG5lZWQgdG8gb3ZlcnJpZGUgX19nZXRhdHRyX18uCiAgU2VlIGh0dHA6Ly93d3cucHl0aG9uLm9yZy8yLjIvZGVzY3JpbnRyby5odG1sI3Byb3BlcnR5CgotIFRoZSBzeW50YXggb2YgZmxvYXRpbmctcG9pbnQgYW5kIGltYWdpbmFyeSBsaXRlcmFscyBoYXMgYmVlbgogIGxpYmVyYWxpemVkLCB0byBhbGxvdyBsZWFkaW5nIHplcm9lcy4gIEV4YW1wbGVzIG9mIGxpdGVyYWxzIG5vdwogIGxlZ2FsIHRoYXQgd2VyZSBTeW50YXhFcnJvcnMgYmVmb3JlOgoKICAgICAgMDAuMCAgICAwZTMgICAwMTAwaiAgIDA3LjUgICAwMDAwMDAwMDAwMDAwMDAwMDAwOC4KCi0gQW4gb2xkIHRva2VuaXplciBidWcgYWxsb3dlZCBmbG9hdGluZyBwb2ludCBsaXRlcmFscyB3aXRoIGFuIGluY29tcGxldGUKICBleHBvbmVudCwgc3VjaCBhcyAxZSBhbmQgMy4xZS0uICBTdWNoIGxpdGVyYWxzIG5vdyByYWlzZSBTeW50YXhFcnJvci4KCkxpYnJhcnkKCi0gdGVsbmV0bGliIGluY2x1ZGVzIHN5bWJvbGljIG5hbWVzIGZvciB0aGUgb3B0aW9ucywgYW5kIHN1cHBvcnQgZm9yCiAgc2V0dGluZyBhbiBvcHRpb24gbmVnb3RpYXRpb24gY2FsbGJhY2suCgotIFRoZSBuZXcgQyBzdGFuZGFyZCBubyBsb25nZXIgcmVxdWlyZXMgdGhhdCBtYXRoIGxpYnJhcmllcyBzZXQgZXJybm8gdG8KICBFUkFOR0Ugb24gb3ZlcmZsb3cuICBGb3IgcGxhdGZvcm0gbGlicmFyaWVzIHRoYXQgZXhwbG9pdCB0aGlzIG5ldwogIGZyZWVkb20sIFB5dGhvbidzIG92ZXJmbG93LWNoZWNraW5nIHdhcyB3aG9sbHkgYnJva2VuLiAgQSBuZXcgb3ZlcmZsb3ctCiAgY2hlY2tpbmcgc2NoZW1lIGF0dGVtcHRzIHRvIHJlcGFpciB0aGF0LCBidXQgbWF5IG5vdCBiZSByZWxpYWJsZSBvbiBhbGwKICBwbGF0Zm9ybXMgKEMgZG9lc24ndCBzZWVtIHRvIHByb3ZpZGUgYW55dGhpbmcgYm90aCB1c2VmdWwgYW5kIHBvcnRhYmxlCiAgaW4gdGhpcyBhcmVhIGFueW1vcmUpLgoKLSBBc3luY2hyb25vdXMgdGltZW91dCBhY3Rpb25zIGFyZSBhdmFpbGFibGUgdGhyb3VnaCB0aGUgbmV3IGNsYXNzCiAgdGhyZWFkaW5nLlRpbWVyLgoKLSBtYXRoLmxvZyBhbmQgbWF0aC5sb2cxMCBub3cgcmV0dXJuIHNlbnNpYmxlIHJlc3VsdHMgZm9yIGV2ZW4gaHVnZQogIGxvbmcgYXJndW1lbnRzLiAgRm9yIGV4YW1wbGUsIG1hdGgubG9nMTAoMTAgKiogMTAwMDApIH49IDEwMDAwLjAuCgotIEEgbmV3IGZ1bmN0aW9uLCBpbXAubG9ja19oZWxkKCksIHJldHVybnMgMSB3aGVuIHRoZSBpbXBvcnQgbG9jayBpcwogIGN1cnJlbnRseSBoZWxkLiAgU2VlIHRoZSBkb2NzIGZvciB0aGUgaW1wIG1vZHVsZS4KCi0gcGlja2xlLCBjUGlja2xlIGFuZCBtYXJzaGFsIG9uIDMyLWJpdCBwbGF0Zm9ybXMgY2FuIG5vdyBjb3JyZWN0bHkgcmVhZAogIGR1bXBzIGNvbnRhaW5pbmcgaW50cyB3cml0dGVuIG9uIHBsYXRmb3JtcyB3aGVyZSBQeXRob24gaW50cyBhcmUgOCBieXRlcy4KICBXaGVuIHJlYWQgb24gYSBib3ggd2hlcmUgUHl0aG9uIGludHMgYXJlIDQgYnl0ZXMsIHN1Y2ggdmFsdWVzIGFyZQogIGNvbnZlcnRlZCB0byBQeXRob24gbG9uZ3MuCgotIEluIHJlc3RyaWN0ZWQgZXhlY3V0aW9uIG1vZGUgKHVzaW5nIHRoZSByZXhlYyBtb2R1bGUpLCB1bm1hcnNoYWxsaW5nCiAgY29kZSBvYmplY3RzIGlzIG5vIGxvbmdlciBhbGxvd2VkLiAgVGhpcyBwbHVncyBhIHNlY3VyaXR5IGhvbGUuCgotIHVuaXR0ZXN0LlRlc3RSZXN1bHQgaW5zdGFuY2VzIG5vIGxvbmdlciBzdG9yZSByZWZlcmVuY2VzIHRvIHRyYWNlYmFja3MKICBnZW5lcmF0ZWQgYnkgdGVzdCBmYWlsdXJlcy4gVGhpcyBwcmV2ZW50cyB1bmV4cGVjdGVkIGRhbmdsaW5nIHJlZmVyZW5jZXMKICB0byBvYmplY3RzIHRoYXQgc2hvdWxkIGJlIGdhcmJhZ2UgY29sbGVjdGVkIGJldHdlZW4gdGVzdHMuCgpUb29scwoKLSBUb29scy9zY3JpcHRzL2ZpeGRpdi5weSBoYXMgYmVlbiBhZGRlZCB3aGljaCBjYW4gYmUgdXNlZCB0byBmaXgKICBkaXZpc2lvbiBvcGVyYXRvcnMgYXMgcGVyIFBFUCAyMzguCgpCdWlsZAoKLSBJZiB5b3UgYXJlIGFuIGFkdmVudHVyb3VzIHBlcnNvbiB1c2luZyBNYWMgT1MgWCB5b3UgbWF5IHdhbnQgdG8gbG9vayBhdAogIE1hYy9PU1guIFRoZXJlIGlzIGEgTWFrZWZpbGUgdGhlcmUgdGhhdCB3aWxsIGJ1aWxkIFB5dGhvbiBhcyBhIHJlYWwgTWFjCiAgYXBwbGljYXRpb24sIHdoaWNoIGNhbiBiZSB1c2VkIGZvciBleHBlcmltZW50aW5nIHdpdGggQ2FyYm9uIG9yIENvY29hLgogIERpc2N1c3Npb24gb2YgdGhpcyBvbiBweXRob25tYWMtc2lnLCBwbGVhc2UuCgpDIEFQSQoKLSBOZXcgZnVuY3Rpb24gUHlPYmplY3RfRGlyKG9iaiksIGxpa2UgUHl0aG9uIF9fYnVpbHRpbl9fLmRpcihvYmopLgoKLSBOb3RlIHRoYXQgUHlMb25nX0FzRG91YmxlIGNhbiBmYWlsISAgVGhpcyBoYXMgYWx3YXlzIGJlZW4gdHJ1ZSwgYnV0IG5vCiAgY2FsbGVycyBjaGVja2VkIGZvciBpdC4gIEl0J3MgbW9yZSBsaWtlbHkgdG8gZmFpbCBub3csIGJlY2F1c2Ugb3ZlcmZsb3cKICBlcnJvcnMgYXJlIHByb3Blcmx5IGRldGVjdGVkIG5vdy4gIFRoZSBwcm9wZXIgd2F5IHRvIGNoZWNrOgoKICBkb3VibGUgeCA9IFB5TG9uZ19Bc0RvdWJsZShzb21lX2xvbmdfb2JqZWN0KTsKICBpZiAoeCA9PSAtMS4wICYmIFB5RXJyX09jY3VycmVkKCkpIHsKICAgICAgICAgIC8qIFRoZSBjb252ZXJzaW9uIGZhaWxlZC4gKi8KICB9CgotIFRoZSBHQyBBUEkgaGFzIGJlZW4gY2hhbmdlZC4gIEV4dGVuc2lvbnMgdGhhdCB1c2UgdGhlIG9sZCBBUEkgd2lsbCBzdGlsbAogIGNvbXBpbGUgYnV0IHdpbGwgbm90IHBhcnRpY2lwYXRlIGluIEdDLiAgVG8gdXBncmFkZSBhbiBleHRlbnNpb24KICBtb2R1bGU6CgogICAgLSByZW5hbWUgUHlfVFBGTEFHU19HQyB0byBQeVRQRkxBR1NfSEFWRV9HQwoKICAgIC0gdXNlIFB5T2JqZWN0X0dDX05ldyBvciBQeU9iamVjdF9HQ19OZXdWYXIgdG8gYWxsb2NhdGUgb2JqZWN0cyBhbmQKICAgICAgUHlPYmplY3RfR0NfRGVsIHRvIGRlYWxsb2NhdGUgdGhlbQoKICAgIC0gcmVuYW1lIFB5T2JqZWN0X0dDX0luaXQgdG8gUHlPYmplY3RfR0NfVHJhY2sgYW5kIFB5T2JqZWN0X0dDX0ZpbmkKICAgICAgdG8gUHlPYmplY3RfR0NfVW5UcmFjawoKICAgIC0gcmVtb3ZlIFB5R0NfSEVBRF9TSVpFIGZyb20gb2JqZWN0IHNpemUgY2FsY3VsYXRpb25zCgogICAgLSByZW1vdmUgY2FsbHMgdG8gUHlPYmplY3RfQVNfR0MgYW5kIFB5T2JqZWN0X0ZST01fR0MKCi0gVHdvIG5ldyBmdW5jdGlvbnM6IFB5U3RyaW5nX0Zyb21Gb3JtYXQoKSBhbmQgUHlTdHJpbmdfRnJvbUZvcm1hdFYoKS4KICBUaGVzZSBjYW4gYmUgdXNlZCBzYWZlbHkgdG8gY29uc3RydWN0IHN0cmluZyBvYmplY3RzIGZyb20gYQogIHNwcmludGYtc3R5bGUgZm9ybWF0IHN0cmluZyAoc2ltaWxhciB0byB0aGUgZm9ybWF0IHN0cmluZyBzdXBwb3J0ZWQKICBieSBQeUVycl9Gb3JtYXQoKSkuCgpOZXcgcGxhdGZvcm1zCgotIFN0ZXBoZW4gSGFuc2VuIGNvbnRyaWJ1dGVkIHBhdGNoZXMgc3VmZmljaWVudCB0byBnZXQgYSBjbGVhbiBjb21waWxlCiAgdW5kZXIgQm9ybGFuZCBDIChXaW5kb3dzKSwgYnV0IGhlIHJlcG9ydHMgcHJvYmxlbXMgcnVubmluZyBpdCBhbmQgcmFuCiAgb3V0IG9mIHRpbWUgdG8gY29tcGxldGUgdGhlIHBvcnQuICBWb2x1bnRlZXJzPyAgRXhwZWN0IGEgTWVtb3J5RXJyb3IKICB3aGVuIGltcG9ydGluZyB0aGUgdHlwZXMgbW9kdWxlOyB0aGlzIGlzIHByb2JhYmx5IHNoYWxsb3csIGFuZAogIGNhdXNpbmcgbGF0ZXIgZmFpbHVyZXMgdG9vLgoKVGVzdHMKCldpbmRvd3MKCi0gTGFyZ2UgZmlsZSBzdXBwb3J0IGlzIG5vdyBlbmFibGVkIG9uIFdpbjMyIHBsYXRmb3JtcyBhcyB3ZWxsIGFzIG9uCiAgV2luNjQuICBUaGlzIG1lYW5zIHRoYXQsIGZvciBleGFtcGxlLCB5b3UgY2FuIHVzZSBmLnRlbGwoKSBhbmQgZi5zZWVrKCkKICB0byBtYW5pcHVsYXRlIGZpbGVzIGxhcmdlciB0aGFuIDIgZ2lnYWJ5dGVzIChwcm92aWRlZCB5b3UgaGF2ZSBlbm91Z2gKICBkaXNrIHNwYWNlLCBhbmQgYXJlIHVzaW5nIGEgV2luZG93cyBmaWxlc3lzdGVtIHRoYXQgc3VwcG9ydHMgbGFyZ2UKICBwYXJ0aXRpb25zKS4gIFdpbmRvd3MgZmlsZXN5c3RlbSBsaW1pdHM6ICBGQVQgaGFzIGEgMkdCIChnaWdhYnl0ZSkKICBmaWxlc2l6ZSBsaW1pdCwgYW5kIGxhcmdlIGZpbGUgc3VwcG9ydCBtYWtlcyBubyBkaWZmZXJlbmNlIHRoZXJlLgogIEZBVDMyJ3MgbGltaXQgaXMgNEdCLCBhbmQgZmlsZXMgPj0gMkdCIGFyZSBlYXNpZXIgdG8gdXNlIGZyb20gUHl0aG9uIG5vdy4KICBOVEZTIGhhcyBubyBwcmFjdGljYWwgbGltaXQgb24gZmlsZSBzaXplLCBhbmQgZmlsZXMgb2YgYW55IHNpemUgY2FuIGJlCiAgdXNlZCBmcm9tIFB5dGhvbiBub3cuCgotIFRoZSB3OXhwb3BlbiBoYWNrIGlzIG5vdyB1c2VkIG9uIFdpbmRvd3MgTlQgYW5kIDIwMDAgdG9vIHdoZW4gQ09NUFNQRUMKICBwb2ludHMgdG8gY29tbWFuZC5jb20gKHBhdGNoIGZyb20gQnJpYW4gUXVpbmxhbikuCgoKV2hhdCdzIE5ldyBpbiBQeXRob24gMi4yYTI/ClJlbGVhc2UgRGF0ZTogMjItQXVnLTIwMDEKPT09PT09PT09PT09PT09PT09PT09PT09PT09CgpCdWlsZAoKLSBUaW0gUGV0ZXJzIGRldmVsb3BlZCBhIGJyYW5kIG5ldyBXaW5kb3dzIGluc3RhbGxlciB1c2luZyBXaXNlIDguMSwKICBnZW5lcm91c2x5IGRvbmF0ZWQgdG8gdXMgYnkgV2lzZSBTb2x1dGlvbnMuCgotIGNvbmZpZ3VyZSBzdXBwb3J0cyBhIG5ldyBvcHRpb24gLS1lbmFibGUtdW5pY29kZSwgd2l0aCB0aGUgdmFsdWVzCiAgdWNzMiBhbmQgdWNzNCAobmV3IGluIDIuMmExKS4gV2l0aCAtLWRpc2FibGUtdW5pY29kZSwgdGhlIFVuaWNvZGUKICB0eXBlIGFuZCBzdXBwb3J0aW5nIGNvZGUgaXMgY29tcGxldGVseSByZW1vdmVkIGZyb20gdGhlIGludGVycHJldGVyLgoKLSBBIG5ldyBjb25maWd1cmUgb3B0aW9uIC0tZW5hYmxlLWZyYW1ld29yayBidWlsZHMgYSBNYWMgT1MgWCBmcmFtZXdvcmssCiAgd2hpY2ggIm1ha2UgZnJhbWV3b3JraW5zdGFsbCIgd2lsbCBpbnN0YWxsLiBUaGlzIHByb3ZpZGVzIGEgc3RhcnRpbmcKICBwb2ludCBmb3IgbW9yZSBtYWMtbGlrZSBmdW5jdGlvbmFsaXR5LCBqb2luIHB5dGhvbm1hYy1zaWdAcHl0aG9uLm9yZwogIGlmIHlvdSBhcmUgaW50ZXJlc3RlZCBpbiBoZWxwaW5nLgoKLSBUaGUgTmVYVCBwbGF0Zm9ybSBpcyBubyBsb25nZXIgc3VwcG9ydGVkLgoKLSBUaGUgYG5ldycgbW9kdWxlIGlzIG5vdyBzdGF0aWNhbGx5IGxpbmtlZC4KClRvb2xzCgotIFRoZSBuZXcgVG9vbHMvc2NyaXB0cy9jbGVhbmZ1dHVyZS5weSBjYW4gYmUgdXNlZCB0byBhdXRvbWF0aWNhbGx5CiAgZWRpdCBvdXQgb2Jzb2xldGUgZnV0dXJlIHN0YXRlbWVudHMgZnJvbSBQeXRob24gc291cmNlIGNvZGUuICBTZWUKICB0aGUgbW9kdWxlIGRvY3N0cmluZyBmb3IgZGV0YWlscy4KClRlc3RzCgotIHJlZ3J0ZXN0LnB5IG5vdyBrbm93cyB3aGljaCB0ZXN0cyBhcmUgZXhwZWN0ZWQgdG8gYmUgc2tpcHBlZCBvbiBzb21lCiAgcGxhdGZvcm1zLCBhbGxvd2luZyB0byBnaXZlIGNsZWFyZXIgdGVzdCByZXN1bHQgb3V0cHV0LiAgcmVncnRlc3QKICBhbHNvIGhhcyBvcHRpb25hbCAtLXVzZS8tdSBzd2l0Y2ggdG8gcnVuIG5vcm1hbGx5IGRpc2FibGVkIHRlc3RzCiAgd2hpY2ggcmVxdWlyZSBuZXR3b3JrIGFjY2VzcyBvciBjb25zdW1lIHNpZ25pZmljYW50IGRpc2sgcmVzb3VyY2VzLgoKLSBTZXZlcmFsIG5ldyB0ZXN0cyBpbiB0aGUgc3RhbmRhcmQgdGVzdCBzdWl0ZSwgd2l0aCBzcGVjaWFsIHRoYW5rcyB0bwogIE5pY2sgTWF0aGV3c29uLgoKQ29yZQoKLSBUaGUgZmxvb3IgZGl2aXNpb24gb3BlcmF0b3IgLy8gaGFzIGJlZW4gYWRkZWQgYXMgb3V0bGluZWQgaW4gUEVQCiAgMjM4LiAgVGhlIC8gb3BlcmF0b3Igc3RpbGwgcHJvdmlkZXMgY2xhc3NpYyBkaXZpc2lvbiAoYW5kIHdpbGwgdW50aWwKICBQeXRob24gMy4wKSB1bmxlc3MgImZyb20gX19mdXR1cmVfXyBpbXBvcnQgZGl2aXNpb24iIGlzIGluY2x1ZGVkLCBpbgogIHdoaWNoIGNhc2UgdGhlIC8gb3BlcmF0b3Igd2lsbCBwcm92aWRlIHRydWUgZGl2aXNpb24uICBUaGUgb3BlcmF0b3IKICBtb2R1bGUgcHJvdmlkZXMgdHJ1ZWRpdigpIGFuZCBmbG9vcmRpdigpIGZ1bmN0aW9ucy4gIEF1Z21lbnRlZAogIGFzc2lnbm1lbnQgdmFyaWFudHMgYXJlIGluY2x1ZGVkLCBhcyBhcmUgdGhlIGVxdWl2YWxlbnQgb3ZlcmxvYWRhYmxlCiAgbWV0aG9kcyBhbmQgQyBBUEkgbWV0aG9kcy4gIFNlZSB0aGUgUEVQIGZvciBhIGZ1bGwgZGlzY3Vzc2lvbjoKICA8aHR0cDovL3B5dGhvbi5zZi5uZXQvcGVwcy9wZXAtMDIzOC5odG1sPgoKLSBGdXR1cmUgc3RhdGVtZW50cyBhcmUgbm93IGVmZmVjdGl2ZSBpbiBzaW11bGF0ZWQgaW50ZXJhY3RpdmUgc2hlbGxzCiAgKGxpa2UgSURMRSkuICBUaGlzIHNob3VsZCAianVzdCB3b3JrIiBieSBtYWdpYywgYnV0IHJlYWQgTWljaGFlbAogIEh1ZHNvbidzICJGdXR1cmUgc3RhdGVtZW50cyBpbiBzaW11bGF0ZWQgc2hlbGxzIiBQRVAgMjY0IGZvciBmdWxsCiAgZGV0YWlsczogIDxodHRwOi8vcHl0aG9uLnNmLm5ldC9wZXBzL3BlcC0wMjY0Lmh0bWw+LgoKLSBUaGUgdHlwZS9jbGFzcyB1bmlmaWNhdGlvbiAoUEVQIDI1Mi0yNTMpIHdhcyBpbnRlZ3JhdGVkIGludG8gdGhlCiAgdHJ1bmsgYW5kIGlzIG5vdCBzbyB0ZW50YXRpdmUgYW55IG1vcmUgKHRoZSBleGFjdCBzcGVjaWZpY2F0aW9uIG9mCiAgc29tZSBmZWF0dXJlcyBpcyBzdGlsbCB0ZW50YXRpdmUpLiAgQSBsb3Qgb2Ygd29yayBoYXMgZG9uZSBvbiBmaXhpbmcKICBidWdzIGFuZCBhZGRpbmcgcm9idXN0bmVzcyBhbmQgZmVhdHVyZXMgKHBlcmZvcm1hbmNlIHN0aWxsIGhhcyB0bwogIGNvbWUgYSBsb25nIHdheSkuCgotIFdhcm5pbmdzIGFib3V0IGEgbWlzbWF0Y2ggaW4gdGhlIFB5dGhvbiBBUEkgZHVyaW5nIGV4dGVuc2lvbiBpbXBvcnQKICBub3cgdXNlIHRoZSBQeXRob24gd2FybmluZyBmcmFtZXdvcmsgKHdoaWNoIG1ha2VzIGl0IHBvc3NpYmxlIHRvCiAgd3JpdGUgZmlsdGVycyBmb3IgdGhlc2Ugd2FybmluZ3MpLgoKLSBBIGZ1bmN0aW9uJ3MgX19kaWN0X18gKGFrYSBmdW5jX2RpY3QpIHdpbGwgbm93IGFsd2F5cyBiZSBhCiAgZGljdGlvbmFyeS4gIEl0IHVzZWQgdG8gYmUgcG9zc2libGUgdG8gZGVsZXRlIGl0IG9yIHNldCBpdCB0byBOb25lLAogIGJ1dCBub3cgYm90aCBhY3Rpb25zIHJhaXNlIFR5cGVFcnJvcnMuICBJdCBpcyBzdGlsbCBsZWdhbCB0byBzZXQgaXQKICB0byBhIGRpY3Rpb25hcnkgb2JqZWN0LiAgR2V0dGluZyBmdW5jLl9fZGljdF9fIGJlZm9yZSBhbnkgYXR0cmlidXRlcwogIGhhdmUgYmVlbiBhc3NpZ25lZCBub3cgcmV0dXJucyBhbiBlbXB0eSBkaWN0aW9uYXJ5IGluc3RlYWQgb2YgTm9uZS4KCi0gQSBuZXcgY29tbWFuZCBsaW5lIG9wdGlvbiwgLUUsIHdhcyBhZGRlZCB3aGljaCBkaXNhYmxlcyB0aGUgdXNlIG9mCiAgYWxsIGVudmlyb25tZW50IHZhcmlhYmxlcywgb3IgYXQgbGVhc3QgdGhvc2UgdGhhdCBhcmUgc3BlY2lmaWNhbGx5CiAgc2lnbmlmaWNhbnQgdG8gUHl0aG9uLiAgVXN1YWxseSB0aG9zZSBoYXZlIGEgbmFtZSBzdGFydGluZyB3aXRoCiAgIlBZVEhPTiIuICBUaGlzIHdhcyB1c2VkIHRvIGZpeCBhIHByb2JsZW0gd2hlcmUgdGhlIHRlc3RzIGZhaWwgaWYKICB0aGUgdXNlciBoYXBwZW5zIHRvIGhhdmUgUFlUSE9OSE9NRSBvciBQWVRIT05QQVRIIHBvaW50aW5nIHRvIGFuCiAgb2xkZXIgZGlzdHJpYnV0aW9uLgoKTGlicmFyeQoKLSBOZXcgY2xhc3MgRGlmZmVyIGFuZCBuZXcgZnVuY3Rpb25zIG5kaWZmKCkgYW5kIHJlc3RvcmUoKSBpbiBkaWZmbGliLnB5LgogIFRoZXNlIHBhY2thZ2UgdGhlIGFsZ29yaXRobXMgdXNlZCBieSB0aGUgcG9wdWxhciBUb29scy9zY3JpcHRzL25kaWZmLnB5LAogIGZvciBwcm9ncmFtbWF0aWMgcmV1c2UuCgotIE5ldyBmdW5jdGlvbiB4bWwuc2F4LnNheHV0aWxzLnF1b3RlYXR0cigpOiAgUXVvdGUgYW4gWE1MIGF0dHJpYnV0ZQogIHZhbHVlIHVzaW5nIHRoZSBtaW5pbWFsIHF1b3RpbmcgcmVxdWlyZWQgZm9yIHRoZSB2YWx1ZTsgbW9yZQogIHJlbGlhYmxlIHRoYW4gdXNpbmcgeG1sLnNheC5zYXh1dGlscy5lc2NhcGUoKSBmb3IgYXR0cmlidXRlIHZhbHVlcy4KCi0gUmVhZGxpbmUgY29tcGxldGlvbiBzdXBwb3J0IGZvciBjbWQuQ21kIHdhcyBhZGRlZC4KCi0gQ2FsbGluZyBvcy50ZW1wbmFtKCkgb3Igb3MudG1wbmFtKCkgZ2VuZXJhdGUgUnVudGltZVdhcm5pbmdzLgoKLSBBZGRlZCBmdW5jdGlvbiB0aHJlYWRpbmcuQm91bmRlZFNlbWFwaG9yZSgpCgotIEFkZGVkIEthLVBpbmcgWWVlJ3MgY2dpdGIucHkgbW9kdWxlLgoKLSBUaGUgYG5ldycgbW9kdWxlIG5vdyBleHBvc2VzIHRoZSBDT194eHggZmxhZ3MuCgotIFRoZSBnYyBtb2R1bGUgb2ZmZXJzIHRoZSBnZXRfcmVmZXJlbnRzIGZ1bmN0aW9uLgoKTmV3IHBsYXRmb3JtcwoKQyBBUEkKCi0gVHdvIG5ldyBBUElzIFB5T1Nfc25wcmludGYoKSBhbmQgUHlPU192c25wcmludGYoKSB3ZXJlIGFkZGVkCiAgd2hpY2ggcHJvdmlkZSBhIGNyb3NzLXBsYXRmb3JtIGltcGxlbWVudGF0aW9ucyBmb3IgdGhlCiAgcmVsYXRpdmVseSBuZXcgc25wcmludGYoKS92c25wcmludGYoKSBDIGxpYiBBUElzLiBJbiBjb250cmFzdCB0bwogIHRoZSBzdGFuZGFyZCBzcHJpbnRmKCkgYW5kIHZzcHJpbnRmKCkgQyBsaWIgQVBJcywgdGhlc2UgdmVyc2lvbnMKICBhcHBseSBib3VuZHMgY2hlY2tpbmcgb24gdGhlIHVzZWQgYnVmZmVyIHdoaWNoIGVuaGFuY2VzIHByb3RlY3Rpb24KICBhZ2FpbnN0IGJ1ZmZlciBvdmVycnVucy4KCi0gVW5pY29kZSBBUElzIG5vdyB1c2UgbmFtZSBtYW5nbGluZyB0byBhc3N1cmUgdGhhdCBtaXhpbmcgaW50ZXJwcmV0ZXJzCiAgYW5kIGV4dGVuc2lvbnMgdXNpbmcgZGlmZmVyZW50IFVuaWNvZGUgd2lkdGhzIGlzIHJlbmRlcmVkIG5leHQgdG8KICBpbXBvc3NpYmxlLiBUcnlpbmcgdG8gaW1wb3J0IGFuIGluY29tcGF0aWJsZSBVbmljb2RlLWF3YXJlIGV4dGVuc2lvbgogIHdpbGwgcmVzdWx0IGluIGFuIEltcG9ydEVycm9yLiAgVW5pY29kZSBleHRlbnNpb25zIHdyaXRlcnMgbXVzdCBtYWtlCiAgc3VyZSB0byBjaGVjayB0aGUgVW5pY29kZSB3aWR0aCBjb21wYXRpYmlsaXR5IGluIHRoZWlyIGV4dGVuc2lvbnMgYnkKICB1c2luZyBhdCBsZWFzdCBvbmUgb2YgdGhlIG1hbmdsZWQgVW5pY29kZSBBUElzIGluIHRoZSBleHRlbnNpb24uCgotIFR3byBuZXcgZmxhZ3MgTUVUSF9OT0FSR1MgYW5kIE1FVEhfTyBhcmUgYXZhaWxhYmxlIGluIG1ldGhvZCBkZWZpbml0aW9uCiAgdGFibGVzIHRvIHNpbXBsaWZ5IGltcGxlbWVudGF0aW9uIG9mIG1ldGhvZHMgd2l0aCBubyBhcmd1bWVudHMgYW5kIGEKICBzaW5nbGUgdW50eXBlZCBhcmd1bWVudC4gQ2FsbGluZyBzdWNoIG1ldGhvZHMgaXMgbW9yZSBlZmZpY2llbnQgdGhhbgogIGNhbGxpbmcgY29ycmVzcG9uZGluZyBNRVRIX1ZBUkFSR1MgbWV0aG9kcy4gTUVUSF9PTERBUkdTIGlzIG5vdwogIGRlcHJlY2F0ZWQuCgpXaW5kb3dzCgotICJpbXBvcnQgbW9kdWxlIiBub3cgY29tcGlsZXMgbW9kdWxlLnB5dyBpZiBpdCBleGlzdHMgYW5kIG5vdGhpbmcgZWxzZQogIHJlbGV2YW50IGlzIGZvdW5kLgoKCldoYXQncyBOZXcgaW4gUHl0aG9uIDIuMmExPwpSZWxlYXNlIGRhdGU6IDE4LUp1bC0yMDAxCj09PT09PT09PT09PT09PT09PT09PT09PT09PQoKQ29yZQoKLSBURU5UQVRJVkVMWSwgYSBsYXJnZSBhbW91bnQgb2YgY29kZSBpbXBsZW1lbnRpbmcgbXVjaCBvZiB3aGF0J3MKICBkZXNjcmliZWQgaW4gUEVQIDI1MiAoTWFraW5nIFR5cGVzIExvb2sgTW9yZSBMaWtlIENsYXNzZXMpIGFuZCBQRVAKICAyNTMgKFN1YnR5cGluZyBCdWlsdC1pbiBUeXBlcykgd2FzIGFkZGVkLiAgVGhpcyB3aWxsIGJlIHJlbGVhc2VkCiAgd2l0aCBQeXRob24gMi4yYTEuICBEb2N1bWVudGF0aW9uIHdpbGwgYmUgcHJvdmlkZWQgc2VwYXJhdGVseQogIHRocm91Z2ggaHR0cDovL3d3dy5weXRob24ub3JnLzIuMi8uICBUaGUgcHVycG9zZSBvZiByZWxlYXNpbmcgdGhpcwogIHdpdGggUHl0aG9uIDIuMmExIGlzIHRvIHRlc3QgYmFja3dhcmRzIGNvbXBhdGliaWxpdHkuICBJdCBpcwogIHBvc3NpYmxlLCB0aG91Z2ggbm90IGxpa2VseSwgdGhhdCBhIGRlY2lzaW9uIGlzIG1hZGUgbm90IHRvIHJlbGVhc2UKICB0aGlzIGNvZGUgYXMgcGFydCBvZiAyLjIgZmluYWwsIGlmIGFueSBzZXJpb3VzIGJhY2t3YXJkcwogIGluY29tcGF0aWJpbGl0aWVzIGFyZSBmb3VuZCBkdXJpbmcgYWxwaGEgdGVzdGluZyB0aGF0IGNhbm5vdCBiZQogIHJlcGFpcmVkLgoKLSBHZW5lcmF0b3JzIHdlcmUgYWRkZWQ7IHRoaXMgaXMgYSBuZXcgd2F5IHRvIGNyZWF0ZSBhbiBpdGVyYXRvciAoc2VlCiAgYmVsb3cpIHVzaW5nIHdoYXQgbG9va3MgbGlrZSBhIHNpbXBsZSBmdW5jdGlvbiBjb250YWluaW5nIG9uZSBvcgogIG1vcmUgJ3lpZWxkJyBzdGF0ZW1lbnRzLiAgU2VlIFBFUCAyNTUuICBTaW5jZSB0aGlzIGFkZHMgYSBuZXcKICBrZXl3b3JkIHRvIHRoZSBsYW5ndWFnZSwgdGhpcyBmZWF0dXJlIG11c3QgYmUgZW5hYmxlZCBieSBpbmNsdWRpbmcgYQogIGZ1dHVyZSBzdGF0ZW1lbnQ6ICJmcm9tIF9fZnV0dXJlX18gaW1wb3J0IGdlbmVyYXRvcnMiIChzZWUgUEVQIDIzNikuCiAgR2VuZXJhdG9ycyB3aWxsIGJlY29tZSBhIHN0YW5kYXJkIGZlYXR1cmUgaW4gYSBmdXR1cmUgcmVsZWFzZQogIChwcm9iYWJseSAyLjMpLiAgV2l0aG91dCB0aGlzIGZ1dHVyZSBzdGF0ZW1lbnQsICd5aWVsZCcgcmVtYWlucyBhbgogIG9yZGluYXJ5IGlkZW50aWZpZXIsIGJ1dCBhIHdhcm5pbmcgaXMgaXNzdWVkIGVhY2ggdGltZSBpdCBpcyB1c2VkLgogIChUaGVzZSB3YXJuaW5ncyBjdXJyZW50bHkgZG9uJ3QgY29uZm9ybSB0byB0aGUgd2FybmluZ3MgZnJhbWV3b3JrIG9mCiAgUEVQIDIzMDsgd2UgaW50ZW5kIHRvIGZpeCB0aGlzIGluIDIuMmEyLikKCi0gVGhlIFVURi0xNiBjb2RlYyB3YXMgbW9kaWZpZWQgdG8gYmUgbW9yZSBSRkMgY29tcGxpYW50LiBJdCB3aWxsIG5vdwogIG9ubHkgcmVtb3ZlIEJPTSBjaGFyYWN0ZXJzIGF0IHRoZSBzdGFydCBvZiB0aGUgc3RyaW5nIGFuZCB0aGVuCiAgb25seSBpZiBydW5uaW5nIGluIG5hdGl2ZSBtb2RlIChVVEYtMTYtTEUgYW5kIC1CRSB3b24ndCByZW1vdmUgYQogIGxlYWRpbmcgQk1PIGNoYXJhY3RlcikuCgotIFN0cmluZ3Mgbm93IGhhdmUgYSBuZXcgbWV0aG9kIC5kZWNvZGUoKSB0byBjb21wbGVtZW50IHRoZSBhbHJlYWR5CiAgZXhpc3RpbmcgLmVuY29kZSgpIG1ldGhvZC4gVGhlc2UgdHdvIG1ldGhvZHMgcHJvdmlkZSBkaXJlY3QgYWNjZXNzCiAgdG8gdGhlIGNvcnJlc3BvbmRpbmcgZGVjb2RlcnMgYW5kIGVuY29kZXJzIG9mIHRoZSByZWdpc3RlcmVkIGNvZGVjcy4KCiAgVG8gZW5oYW5jZSB0aGUgdXNhYmlsaXR5IG9mIHRoZSAuZW5jb2RlKCkgbWV0aG9kLCB0aGUgc3BlY2lhbAogIGNhc2luZyBvZiBVbmljb2RlIG9iamVjdCByZXR1cm4gdmFsdWVzIHdhcyBkcm9wcGVkIChVbmljb2RlIG9iamVjdHMKICB3ZXJlIGF1dG8tbWFnaWNhbGx5IGNvbnZlcnRlZCB0byBzdHJpbmcgdXNpbmcgdGhlIGRlZmF1bHQgZW5jb2RpbmcpLgoKICBCb3RoIG1ldGhvZHMgd2lsbCBub3cgcmV0dXJuIHdoYXRldmVyIHRoZSBjb2RlYyBpbiBjaGFyZ2Ugb2YgdGhlCiAgcmVxdWVzdGVkIGVuY29kaW5nIHJldHVybnMgYXMgb2JqZWN0LCBlLmcuIFVuaWNvZGUgY29kZWNzIHdpbGwKICByZXR1cm4gVW5pY29kZSBvYmplY3RzIHdoZW4gZGVjb2RpbmcgaXMgcmVxdWVzdGVkICgi5Pb8Ii5kZWNvZGUoImxhdGluLTEiKQogIHdpbGwgcmV0dXJuIHUi5Pb8IikuIFRoaXMgZW5hYmxlcyBjb2RlYyB3cml0ZXIgdG8gY3JlYXRlIGNvZGVjcwogIGZvciB2YXJpb3VzIHNpbXBsZSB0byB1c2UgY29udmVyc2lvbnMuCgogIE5ldyBjb2RlY3Mgd2VyZSBhZGRlZCB0byBkZW1vbnN0cmF0ZSB0aGVzZSBuZXcgZmVhdHVyZXMgKHRoZSAuZW5jb2RlKCkKICBhbmQgLmRlY29kZSgpIGNvbHVtbnMgaW5kaWNhdGUgdGhlIHR5cGUgb2YgdGhlIHJldHVybmVkIG9iamVjdHMpOgoKICBOYW1lICAgICB8IC5lbmNvZGUoKSB8IC5kZWNvZGUoKSB8IERlc2NyaXB0aW9uCiAgLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogIHV1ICAgICAgIHwgc3RyaW5nICAgIHwgc3RyaW5nICAgIHwgVVUgY29kZWMgKGUuZy4gZm9yIGVtYWlsKQogIGJhc2U2NCAgIHwgc3RyaW5nICAgIHwgc3RyaW5nICAgIHwgYmFzZTY0IGNvZGVjCiAgcXVvcHJpICAgfCBzdHJpbmcgICAgfCBzdHJpbmcgICAgfCBxdW90ZWQtcHJpbnRhYmxlIGNvZGVjCiAgemxpYiAgICAgfCBzdHJpbmcgICAgfCBzdHJpbmcgICAgfCB6bGliIGNvbXByZXNzaW9uCiAgaGV4ICAgICAgfCBzdHJpbmcgICAgfCBzdHJpbmcgICAgfCAyLWJ5dGUgaGV4IGNvZGVjCiAgcm90LTEzICAgfCBzdHJpbmcgICAgfCBVbmljb2RlICAgfCBST1QtMTMgVW5pY29kZSBjaGFybWFwIGNvZGVjCgotIFNvbWUgb3BlcmF0aW5nIHN5c3RlbXMgbm93IHN1cHBvcnQgdGhlIGNvbmNlcHQgb2YgYSBkZWZhdWx0IFVuaWNvZGUKICBlbmNvZGluZyBmb3IgZmlsZSBzeXN0ZW0gb3BlcmF0aW9ucy4gIE5vdGFibHksIFdpbmRvd3Mgc3VwcG9ydHMgJ21iY3MnCiAgYXMgdGhlIGRlZmF1bHQuICBUaGUgTWFjaW50b3NoIHdpbGwgYWxzbyBhZG9wdCB0aGlzIGNvbmNlcHQgaW4gdGhlIG1lZGl1bQogIHRlcm0sIGFsdGhvdWdoIHRoZSBkZWZhdWx0IGVuY29kaW5nIGZvciB0aGF0IHBsYXRmb3JtIHdpbGwgYmUgb3RoZXIgdGhhbgogICdtYmNzJy4KCiAgT24gb3BlcmF0aW5nIHN5c3RlbSB0aGF0IHN1cHBvcnQgbm9uLUFTQ0lJIGZpbGVuYW1lcywgaXQgaXMgY29tbW9uIGZvcgogIGZ1bmN0aW9ucyB0aGF0IHJldHVybiBmaWxlbmFtZXMgKHN1Y2ggYXMgb3MubGlzdGRpcigpKSB0byByZXR1cm4gUHl0aG9uCiAgc3RyaW5nIG9iamVjdHMgcHJlLWVuY29kZWQgdXNpbmcgdGhlIGRlZmF1bHQgZmlsZSBzeXN0ZW0gZW5jb2RpbmcgZm9yCiAgdGhlIHBsYXRmb3JtLiAgQXMgdGhpcyBlbmNvZGluZyBpcyBsaWtlbHkgdG8gYmUgZGlmZmVyZW50IGZyb20gUHl0aG9uJ3MKICBkZWZhdWx0IGVuY29kaW5nLCBjb252ZXJ0aW5nIHRoaXMgbmFtZSB0byBhIFVuaWNvZGUgb2JqZWN0IGJlZm9yZSBwYXNzaW5nCiAgaXQgYmFjayB0byB0aGUgT3BlcmF0aW5nIFN5c3RlbSB3b3VsZCByZXN1bHQgaW4gYSBVbmljb2RlIGVycm9yLCBhcyBQeXRob24KICB3b3VsZCBhdHRlbXB0IHRvIHVzZSBpdHMgZGVmYXVsdCBlbmNvZGluZyAoZ2VuZXJhbGx5IEFTQ0lJKSByYXRoZXIgdGhhbgogIHRoZSBkZWZhdWx0IGVuY29kaW5nIGZvciB0aGUgZmlsZSBzeXN0ZW0uCgogIEluIGdlbmVyYWwsIHRoaXMgY2hhbmdlIHNpbXBseSByZW1vdmVzIHN1cnByaXNlcyB3aGVuIHdvcmtpbmcgd2l0aAogIFVuaWNvZGUgYW5kIHRoZSBmaWxlIHN5c3RlbSwgbWFraW5nIHRoZXNlIG9wZXJhdGlvbnMgd29yayBhcyB5b3UgZXhwZWN0LAogIGluY3JlYXNpbmcgdGhlIHRyYW5zcGFyZW5jeSBvZiBVbmljb2RlIG9iamVjdHMgaW4gdGhpcyBjb250ZXh0LgogIFNlZSBbPz8/P10gZm9yIG1vcmUgZGV0YWlscywgaW5jbHVkaW5nIGV4YW1wbGVzLgoKLSBGbG9hdCAoYW5kIGNvbXBsZXgpIGxpdGVyYWxzIGluIHNvdXJjZSBjb2RlIHdlcmUgZXZhbHVhdGVkIHRvIGZ1bGwKICBwcmVjaXNpb24gb25seSB3aGVuIHJ1bm5pbmcgZnJvbSBhIC5weSBmaWxlOyB0aGUgc2FtZSBjb2RlIGxvYWRlZCBmcm9tIGEKICAucHljIChvciAucHlvKSBmaWxlIGNvdWxkIHN1ZmZlciBudW1lcmljIGRpZmZlcmVuY2VzIHN0YXJ0aW5nIGF0IGFib3V0IHRoZQogIDEydGggc2lnbmlmaWNhbnQgZGVjaW1hbCBkaWdpdC4gIEZvciBleGFtcGxlLCBvbiBhIG1hY2hpbmUgd2l0aCBJRUVFLTc1NAogIGZsb2F0aW5nIGFyaXRobWV0aWMsCgogICAgICB4ID0gOTAwNzE5OTI1NDc0MDk5Mi4wCiAgICAgIHByaW50IGxvbmcoeCkKCiAgcHJpbnRlZCA5MDA3MTk5MjU0NzQwOTkyIGlmIHJ1biBkaXJlY3RseSBmcm9tIC5weSwgYnV0IDkwMDcxOTkyNTQ3NDAwMDAKICBpZiBmcm9tIGEgY29tcGlsZWQgKC5weWMgb3IgLnB5bykgZmlsZS4gIFRoaXMgd2FzIGR1ZSB0byBtYXJzaGFsIHVzaW5nCiAgc3RyKGZsb2F0KSBpbnN0ZWFkIG9mIHJlcHIoZmxvYXQpIHdoZW4gYnVpbGRpbmcgY29kZSBvYmplY3RzLiAgbWFyc2hhbAogIG5vdyB1c2VzIHJlcHIoZmxvYXQpIGluc3RlYWQsIHdoaWNoIHNob3VsZCByZXByb2R1Y2UgZmxvYXRzIHRvIGZ1bGwKICBtYWNoaW5lIHByZWNpc2lvbiAoYXNzdW1pbmcgdGhlIHBsYXRmb3JtIEMgZmxvYXQ8LT5zdHJpbmcgSS9PIGNvbnZlcnNpb24KICBmdW5jdGlvbnMgYXJlIG9mIGdvb2QgcXVhbGl0eSkuCgogIFRoaXMgbWF5IGNhdXNlIGZsb2F0aW5nLXBvaW50IHJlc3VsdHMgdG8gY2hhbmdlIGluIHNvbWUgY2FzZXMsIGFuZAogIHVzdWFsbHkgZm9yIHRoZSBiZXR0ZXIsIGJ1dCBtYXkgYWxzbyBjYXVzZSBudW1lcmljYWxseSB1bnN0YWJsZQogIGFsZ29yaXRobXMgdG8gYnJlYWsuCgotIFRoZSBpbXBsZW1lbnRhdGlvbiBvZiBkaWN0cyBzdWZmZXJzIGZld2VyIGNvbGxpc2lvbnMsIHdoaWNoIGhhcyBzcGVlZAogIGJlbmVmaXRzLiAgSG93ZXZlciwgdGhlIG9yZGVyIGluIHdoaWNoIGRpY3QgZW50cmllcyBhcHBlYXIgaW4gZGljdC5rZXlzKCksCiAgZGljdC52YWx1ZXMoKSBhbmQgZGljdC5pdGVtcygpIG1heSBkaWZmZXIgZnJvbSBwcmV2aW91cyByZWxlYXNlcyBmb3IgYQogIGdpdmVuIGRpY3QuICBOb3RoaW5nIGlzIGRlZmluZWQgYWJvdXQgdGhpcyBvcmRlciwgc28gbm8gcHJvZ3JhbSBzaG91bGQKICByZWx5IG9uIGl0LiAgTmV2ZXJ0aGVsZXNzLCBpdCdzIGVhc3kgdG8gd3JpdGUgdGVzdCBjYXNlcyB0aGF0IHJlbHkgb24gdGhlCiAgb3JkZXIgYnkgYWNjaWRlbnQsIHR5cGljYWxseSBiZWNhdXNlIG9mIHByaW50aW5nIHRoZSBzdHIoKSBvciByZXByKCkgb2YgYQogIGRpY3QgdG8gYW4gImV4cGVjdGVkIHJlc3VsdHMiIGZpbGUuICBTZWUgTGliL3Rlc3QvdGVzdF9zdXBwb3J0LnB5J3MgbmV3CiAgc29ydGRpY3QoZGljdCkgZnVuY3Rpb24gZm9yIGEgc2ltcGxlIHdheSB0byBkaXNwbGF5IGEgZGljdCBpbiBzb3J0ZWQKICBvcmRlci4KCi0gTWFueSBvdGhlciBzbWFsbCBjaGFuZ2VzIHRvIGRpY3RzIHdlcmUgbWFkZSwgcmVzdWx0aW5nIGluIGZhc3RlcgogIG9wZXJhdGlvbiBhbG9uZyB0aGUgbW9zdCBjb21tb24gY29kZSBwYXRocy4KCi0gRGljdGlvbmFyeSBvYmplY3RzIG5vdyBzdXBwb3J0IHRoZSAiaW4iIG9wZXJhdG9yOiAieCBpbiBkaWN0IiBtZWFucwogIHRoZSBzYW1lIGFzIGRpY3QuaGFzX2tleSh4KS4KCi0gVGhlIHVwZGF0ZSgpIG1ldGhvZCBvZiBkaWN0aW9uYXJpZXMgbm93IGFjY2VwdHMgZ2VuZXJpYyBtYXBwaW5nCiAgb2JqZWN0cy4gIFNwZWNpZmljYWxseSB0aGUgYXJndW1lbnQgb2JqZWN0IG11c3Qgc3VwcG9ydCB0aGUgLmtleXMoKQogIGFuZCBfX2dldGl0ZW1fXygpIG1ldGhvZHMuICBUaGlzIGFsbG93cyB5b3UgdG8gc2F5LCBmb3IgZXhhbXBsZSwKICB7fS51cGRhdGUoVXNlckRpY3QoKSkKCi0gSXRlcmF0b3JzIHdlcmUgYWRkZWQ7IHRoaXMgaXMgYSBnZW5lcmFsaXplZCB3YXkgb2YgcHJvdmlkaW5nIHZhbHVlcwogIHRvIGEgZm9yIGxvb3AuICBTZWUgUEVQIDIzNC4gIFRoZXJlJ3MgYSBuZXcgYnVpbHQtaW4gZnVuY3Rpb24gaXRlcigpCiAgdG8gcmV0dXJuIGFuIGl0ZXJhdG9yLiAgVGhlcmUncyBhIG5ldyBwcm90b2NvbCB0byBnZXQgdGhlIG5leHQgdmFsdWUKICBmcm9tIGFuIGl0ZXJhdG9yIHVzaW5nIHRoZSBuZXh0KCkgbWV0aG9kIChpbiBQeXRob24pIG9yIHRoZQogIHRwX2l0ZXJuZXh0IHNsb3QgKGluIEMpLiAgVGhlcmUncyBhIG5ldyBwcm90b2NvbCB0byBnZXQgaXRlcmF0b3JzCiAgdXNpbmcgdGhlIF9faXRlcl9fKCkgbWV0aG9kIChpbiBQeXRob24pIG9yIHRoZSB0cF9pdGVyIHNsb3QgKGluIEMpLgogIEl0ZXJhdGluZyAoaS5lLiBhIGZvciBsb29wKSBvdmVyIGEgZGljdGlvbmFyeSBnZW5lcmF0ZXMgaXRzIGtleXMuCiAgSXRlcmF0aW5nIG92ZXIgYSBmaWxlIGdlbmVyYXRlcyBpdHMgbGluZXMuCgotIFRoZSBmb2xsb3dpbmcgZnVuY3Rpb25zIHdlcmUgZ2VuZXJhbGl6ZWQgdG8gd29yayBuaWNlbHkgd2l0aCBpdGVyYXRvcgogIGFyZ3VtZW50czoKICAgIG1hcCgpLCBmaWx0ZXIoKSwgcmVkdWNlKCksIHppcCgpCiAgICBsaXN0KCksIHR1cGxlKCkgKFB5U2VxdWVuY2VfVHVwbGUoKSBhbmQgUHlTZXF1ZW5jZV9GYXN0KCkgaW4gQyBBUEkpCiAgICBtYXgoKSwgbWluKCkKICAgIGpvaW4oKSBtZXRob2Qgb2Ygc3RyaW5ncwogICAgZXh0ZW5kKCkgbWV0aG9kIG9mIGxpc3RzCiAgICAneCBpbiB5JyBhbmQgJ3ggbm90IGluIHknIChQeVNlcXVlbmNlX0NvbnRhaW5zKCkgaW4gQyBBUEkpCiAgICBvcGVyYXRvci5jb3VudE9mKCkgKFB5U2VxdWVuY2VfQ291bnQoKSBpbiBDIEFQSSkKICAgIHJpZ2h0LWhhbmQgc2lkZSBvZiBhc3NpZ25tZW50IHN0YXRlbWVudHMgd2l0aCBtdWx0aXBsZSB0YXJnZXRzLCBzdWNoIGFzCiAgICAgICAgeCwgeSwgeiA9IHNvbWVfaXRlcmFibGVfb2JqZWN0X3JldHVybmluZ19leGFjdGx5XzNfdmFsdWVzCgotIEFjY2Vzc2luZyBtb2R1bGUgYXR0cmlidXRlcyBpcyBzaWduaWZpY2FudGx5IGZhc3RlciAoZm9yIGV4YW1wbGUsCiAgcmFuZG9tLnJhbmRvbSBvciBvcy5wYXRoIG9yIHlvdXJQeXRob25Nb2R1bGUueW91ckF0dHJpYnV0ZSkuCgotIENvbXBhcmluZyBkaWN0aW9uYXJ5IG9iamVjdHMgdmlhID09IGFuZCAhPSBpcyBmYXN0ZXIsIGFuZCBub3cgd29ya3MgZXZlbgogIGlmIHRoZSBrZXlzIGFuZCB2YWx1ZXMgZG9uJ3Qgc3VwcG9ydCBjb21wYXJpc29ucyBvdGhlciB0aGFuID09LgoKLSBDb21wYXJpbmcgZGljdGlvbmFyaWVzIGluIHdheXMgb3RoZXIgdGhhbiA9PSBhbmQgIT0gaXMgc2xvd2VyOiAgdGhlcmUgd2VyZQogIGluc2VjdXJpdGllcyBpbiB0aGUgZGljdCBjb21wYXJpc29uIGltcGxlbWVudGF0aW9uIHRoYXQgY291bGQgY2F1c2UgUHl0aG9uCiAgdG8gY3Jhc2ggaWYgdGhlIGVsZW1lbnQgY29tcGFyaXNvbiByb3V0aW5lcyBmb3IgdGhlIGRpY3Qga2V5cyBhbmQvb3IKICB2YWx1ZXMgbXV0YXRlZCB0aGUgZGljdHMuICBNYWtpbmcgdGhlIGNvZGUgYnVsbGV0cHJvb2Ygc2xvd2VkIGl0IGRvd24uCgotIENvbGxpc2lvbnMgaW4gZGljdHMgYXJlIHJlc29sdmVkIHZpYSBhIG5ldyBhcHByb2FjaCwgd2hpY2ggY2FuIGhlbHAKICBkcmFtYXRpY2FsbHkgaW4gYmFkIGNhc2VzLiAgRm9yIGV4YW1wbGUsIGxvb2tpbmcgdXAgZXZlcnkga2V5IGluIGEgZGljdAogIGQgd2l0aCBkLmtleXMoKSA9PSBbaSA8PCAxNiBmb3IgaSBpbiByYW5nZSgyMDAwMCldIGlzIGFwcHJveGltYXRlbHkgNTAweAogIGZhc3RlciBub3cuICBUaGFua3MgdG8gQ2hyaXN0aWFuIFRpc21lciBmb3IgcG9pbnRpbmcgb3V0IHRoZSBjYXVzZSBhbmQKICB0aGUgbmF0dXJlIG9mIGFuIGVmZmVjdGl2ZSBjdXJlIChsYXN0IERlY2VtYmVyISBiZXR0ZXIgbGF0ZSB0aGFuIG5ldmVyKS4KCi0gcmVwcigpIGlzIG11Y2ggZmFzdGVyIGZvciBsYXJnZSBjb250YWluZXJzIChkaWN0LCBsaXN0LCB0dXBsZSkuCgoKTGlicmFyeQoKLSBUaGUgY29uc3RhbnRzIGFzY2lpX2xldHRlcnMsIGFzY2lpX2xvd2VyY2FzZS4gYW5kIGFzY2lpX3VwcGVyY2FzZQogIHdlcmUgYWRkZWQgdG8gdGhlIHN0cmluZyBtb2R1bGUuICBUaGVzZSBhIGxvY2FsZS1pbmRlcGVuZGVudAogIGNvbnN0YW50cywgdW5saWtlIGxldHRlcnMsIGxvd2VyY2FzZSwgYW5kIHVwcGVyY2FzZS4gIFRoZXNlIGFyZSBub3cKICB1c2UgaW4gYXBwcm9wcmlhdGUgbG9jYXRpb25zIGluIHRoZSBzdGFuZGFyZCBsaWJyYXJ5LgoKLSBUaGUgZmxhZ3MgdXNlZCBpbiBkbG9wZW4gY2FsbHMgY2FuIG5vdyBiZSBjb25maWd1cmVkIHVzaW5nCiAgc3lzLnNldGRsb3BlbmZsYWdzIGFuZCBxdWVyaWVkIHVzaW5nIHN5cy5nZXRkbG9wZW5mbGFncy4KCi0gRnJlZHJpayBMdW5kaCdzIHhtbHJwY2xpYiBpcyBub3cgYSBzdGFuZGFyZCBsaWJyYXJ5IG1vZHVsZS4gIFRoaXMKICBwcm92aWRlcyBmdWxsIGNsaWVudC1zaWRlIFhNTC1SUEMgc3VwcG9ydC4gIEluIGFkZGl0aW9uLAogIERlbW8veG1scnBjLyBjb250YWlucyB0d28gc2VydmVyIGZyYW1ld29ya3MgKG9uZSBTb2NrZXRTZXJ2ZXItYmFzZWQsCiAgb25lIGFzeW5jb3JlLWJhc2VkKS4gIFRoYW5rcyB0byBFcmljIFJheW1vbmQgZm9yIHRoZSBkb2N1bWVudGF0aW9uLgoKLSBUaGUgeHJhbmdlKCkgb2JqZWN0IGlzIHNpbXBsaWZpZWQ6IGl0IG5vIGxvbmdlciBzdXBwb3J0cyBzbGljaW5nLAogIHJlcGV0aXRpb24sIGNvbXBhcmlzb25zLCBlZmZpY2llbnQgJ2luJyBjaGVja2luZywgdGhlIHRvbGlzdCgpCiAgbWV0aG9kLCBvciB0aGUgc3RhcnQsIHN0b3AgYW5kIHN0ZXAgYXR0cmlidXRlcy4gIFNlZSBQRVAgMjYwLgoKLSBBIG5ldyBmdW5jdGlvbiBmbm1hdGNoLmZpbHRlciB0byBmaWx0ZXIgbGlzdHMgb2YgZmlsZSBuYW1lcyB3YXMgYWRkZWQuCgotIGNhbGVuZGFyLnB5IHVzZXMgbW9udGggYW5kIGRheSBuYW1lcyBiYXNlZCBvbiB0aGUgY3VycmVudCBsb2NhbGUuCgotIHN0cm9wIGlzIG5vdyAqcmVhbGx5KiBvYnNvbGV0ZSAodGhpcyB3YXMgYW5ub3VuY2VkIGJlZm9yZSB3aXRoIDEuNiksCiAgYW5kIGlzc3VlcyBEZXByZWNhdGlvbldhcm5pbmcgd2hlbiB1c2VkIChleGNlcHQgZm9yIHRoZSBmb3VyIGl0ZW1zCiAgdGhhdCBhcmUgc3RpbGwgaW1wb3J0ZWQgaW50byBzdHJpbmcucHkpLgoKLSBDb29raWUucHkgbm93IHNvcnRzIGtleSt2YWx1ZSBwYWlycyBieSBrZXkgaW4gb3V0cHV0IHN0cmluZ3MuCgotIHBwcmludC5pc3JlY3Vyc2l2ZShvYmplY3QpIGRpZG4ndCBjb3JyZWN0bHkgaWRlbnRpZnkgcmVjdXJzaXZlIG9iamVjdHMuCiAgTm93IGl0IGRvZXMuCgotIHBwcmludCBmdW5jdGlvbnMgbm93IG11Y2ggZmFzdGVyIGZvciBsYXJnZSBjb250YWluZXJzICh0dXBsZSwgbGlzdCwgZGljdCkuCgotIE5ldyAncScgYW5kICdRJyBmb3JtYXQgY29kZXMgaW4gdGhlIHN0cnVjdCBtb2R1bGUsIGNvcnJlc3BvbmRpbmcgdG8gQwogIHR5cGVzICJsb25nIGxvbmciIGFuZCAidW5zaWduZWQgbG9uZyBsb25nIiAob24gV2luZG93cywgX19pbnQ2NCkuICBJbgogIG5hdGl2ZSBtb2RlLCB0aGVzZSBjYW4gYmUgdXNlZCBvbmx5IHdoZW4gdGhlIHBsYXRmb3JtIEMgY29tcGlsZXIgc3VwcG9ydHMKICB0aGVzZSB0eXBlcyAod2hlbiBIQVZFX0xPTkdfTE9ORyBpcyAjZGVmaW5lJ2QgYnkgdGhlIFB5dGhvbiBjb25maWcKICBwcm9jZXNzKSwgYW5kIHRoZW4gdGhleSBpbmhlcml0IHRoZSBzaXplcyBhbmQgYWxpZ25tZW50cyBvZiB0aGUgQyB0eXBlcy4KICBJbiBzdGFuZGFyZCBtb2RlLCAncScgYW5kICdRJyBhcmUgc3VwcG9ydGVkIG9uIGFsbCBwbGF0Zm9ybXMsIGFuZCBhcmUKICA4LWJ5dGUgaW50ZWdyYWwgdHlwZXMuCgotIFRoZSBzaXRlIG1vZHVsZSBpbnN0YWxscyBhIG5ldyBidWlsdC1pbiBmdW5jdGlvbiAnaGVscCcgdGhhdCBpbnZva2VzCiAgcHlkb2MuaGVscC4gIEl0IG11c3QgYmUgaW52b2tlZCBhcyAnaGVscCgpJzsgd2hlbiBpbnZva2VkIGFzICdoZWxwJywKICBpdCBkaXNwbGF5cyBhIG1lc3NhZ2UgcmVtaW5kaW5nIHRoZSB1c2VyIHRvIHVzZSAnaGVscCgpJyBvcgogICdoZWxwKG9iamVjdCknLgoKVGVzdHMKCi0gTmV3IHRlc3RfbXV0YW50cy5weSBydW5zIGRpY3QgY29tcGFyaXNvbnMgd2hlcmUgdGhlIGtleSBhbmQgdmFsdWUKICBjb21wYXJpc29uIG9wZXJhdG9ycyBtdXRhdGUgdGhlIGRpY3RzIHJhbmRvbWx5IGR1cmluZyBjb21wYXJpc29uLiAgVGhpcwogIHJhcGlkbHkgY2F1c2VzIFB5dGhvbiB0byBjcmFzaCB1bmRlciBlYXJsaWVyIHJlbGVhc2VzIChub3QgZm9yIHRoZSBmYWludAogIG9mIGhlYXJ0OiAgaXQgY2FuIGFsc28gY2F1c2UgV2luOXggdG8gZnJlZXplIG9yIHJlYm9vdCEpLgoKLSBOZXcgdGVzdF9wcHJpbnQucHkgdmVyaWZpZXMgdGhhdCBwcHJpbnQuaXNyZWN1cnNpdmUoKSBhbmQKICBwcHJpbnQuaXNyZWFkYWJsZSgpIHJldHVybiBzZW5zaWJsZSByZXN1bHRzLiAgQWxzbyB2ZXJpZmllcyB0aGF0IHNpbXBsZQogIGNhc2VzIHByb2R1Y2UgY29ycmVjdCBvdXRwdXQuCgpDIEFQSQoKLSBSZW1vdmVkIHRoZSB1bnVzZWQgbGFzdF9pc19zdGlja3kgYXJndW1lbnQgZnJvbSB0aGUgaW50ZXJuYWwKICBfUHlUdXBsZV9SZXNpemUoKS4gIElmIHRoaXMgYWZmZWN0cyB5b3UsIHlvdSB3ZXJlIGNoZWF0aW5nLgoKCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCgpXaGF0J3MgTmV3IGluIFB5dGhvbiAyLjEgKGZpbmFsKT8KPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpXZSBvbmx5IGNoYW5nZWQgYSBmZXcgdGhpbmdzIHNpbmNlIHRoZSBsYXN0IHJlbGVhc2UgY2FuZGlkYXRlLCBhbGwgaW4KUHl0aG9uIGxpYnJhcnkgY29kZToKCi0gQSBidWcgaW4gdGhlIGxvY2FsZSBtb2R1bGUgd2FzIGZpeGVkIHRoYXQgYWZmZWN0ZWQgbG9jYWxlcyB3aGljaAogIGRlZmluZSBubyBncm91cGluZyBmb3IgbnVtZXJpYyBmb3JtYXR0aW5nLgoKLSBBIGZldyBidWdzIGluIHRoZSB3ZWFrcmVmIG1vZHVsZSdzIGltcGxlbWVudGF0aW9ucyBvZiB3ZWFrCiAgZGljdGlvbmFyaWVzIChXZWFrVmFsdWVEaWN0aW9uYXJ5IGFuZCBXZWFrS2V5RGljdGlvbmFyeSkgd2VyZSBmaXhlZCwKICBhbmQgdGhlIHRlc3Qgc3VpdGUgd2FzIHVwZGF0ZWQgdG8gY2hlY2sgZm9yIHRoZXNlIGJ1Z3MuCgotIEFuIG9sZCBidWcgaW4gdGhlIG9zLnBhdGgud2FsaygpIGZ1bmN0aW9uIChpbnRyb2R1Y2VkIGluIFB5dGhvbgogIDIuMCEpIHdhcyBmaXhlZDogYSBub24tZXhpc3RlbnQgZmlsZSB3b3VsZCBjYXVzZSBhbiBleGNlcHRpb24KICBpbnN0ZWFkIG9mIGJlaW5nIGlnbm9yZWQuCgotIEZpeGVkIGEgZmV3IGJ1Z3MgaW4gdGhlIG5ldyBzeW10YWJsZSBtb2R1bGUgZm91bmQgYnkgTmVpbCBOb3J3aXR6J3MKICBQeUNoZWNrZXIuCgoKV2hhdCdzIE5ldyBpbiBQeXRob24gMi4xYzI/Cj09PT09PT09PT09PT09PT09PT09PT09PT09PQoKQSBmbHVycnkgb2Ygc21hbGwgY2hhbmdlcywgYW5kIG9uZSBzaG93c3RvcHBlciBmaXhlZCBpbiB0aGUgbmljayBvZgp0aW1lIG1hZGUgaXQgbmVjZXNzYXJ5IHRvIHJlbGVhc2UgYW5vdGhlciByZWxlYXNlIGNhbmRpZGF0ZS4gIFRoZSBsaXN0CmhlcmUgaXMgdGhlICpjb21wbGV0ZSogbGlzdCBvZiBwYXRjaGVzIChleGNlcHQgdmVyc2lvbiB1cGRhdGVzKToKCkNvcmUKCi0gVGltIGRpc2NvdmVyZWQgYSBuYXN0eSBidWcgaW4gdGhlIGRpY3Rpb25hcnkgY29kZSwgY2F1c2VkIGJ5CiAgUHlEaWN0X05leHQoKSBjYWxsaW5nIGRpY3RfcmVzaXplKCksIGFuZCB0aGUgR0MgY29kZSdzIHVzZSBvZgogIFB5RGljdF9OZXh0KCkgdmlvbGF0aW5nIGFuIGFzc3VtcHRpb24gaW4gZGljdF9pdGVtcygpLiAgVGhpcyB3YXMKICBmaXhlZCB3aXRoIGNvbnNpZGVyYWJsZSBhbW91bnRzIG9mIGJhbmQtYWlkLCBidXQgdGhlIG5ldCBlZmZlY3QgaXMgYQogIHNhbmVyIGFuZCBtb3JlIHJvYnVzdCBpbXBsZW1lbnRhdGlvbi4KCi0gTWFkZSBhIGJ1bmNoIG9mIHN5bWJvbHMgc3RhdGljIHRoYXQgd2VyZSBhY2NpZGVudGFsbHkgZ2xvYmFsLgoKQnVpbGQgYW5kIFBvcnRzCgotIFRoZSBzZXR1cC5weSBzY3JpcHQgZGlkbid0IGNoZWNrIGZvciBhIG5ldyBlbm91Z2ggdmVyc2lvbiBvZiB6bGliCiAgKDEuMS4zIGlzIG5lZWRlZCkuICBOb3cgaXQgZG9lcy4KCi0gQ2hhbmdlZCAibWFrZSBjbGVhbiIgdGFyZ2V0IHRvIGFsc28gcmVtb3ZlIHNoYXJlZCBsaWJyYXJpZXMuCgotIEFkZGVkIGEgbW9yZSBnZW5lcmFsIHdhcm5pbmcgYWJvdXQgdGhlIFNHSSBJcml4IG9wdGltaXplciB0byBSRUFETUUuCgpMaWJyYXJ5CgotIEZpeCBhIGJ1ZyBpbiB1cmxsaWIuYmFzZWpvaW4oImh0dHA6Ly9ob3N0IiwgIi4uL2ZpbGUuaHRtbCIpIHdoaWNoCiAgb21pdHRlZCB0aGUgc2xhc2ggYmV0d2VlbiBob3N0IGFuZCBmaWxlLmh0bWwuCgotIFRoZSBtYWlsYm94IG1vZHVsZSdzIF9NYWlsYm94IGNsYXNzIGNvbnRhaW5lZCBhIGNvbXBsZXRlbHkgYnJva2VuCiAgYW5kIHVuZG9jdW1lbnRlZCBzZWVrKCkgbWV0aG9kLiAgUmlwcGVkIGl0IG91dC4KCi0gRml4ZWQgYSBidW5jaCBvZiB0eXBvcyBpbiB2YXJpb3VzIGxpYnJhcnkgbW9kdWxlcyAodXJsbGliMiwgc210cGQsCiAgc2dtbGxpYiwgbmV0cmMsIGNodW5rKSBmb3VuZCBieSBOZWlsIE5vcndpdHoncyBQeUNoZWNrZXIuCgotIEZpeGVkIGEgZmV3IGxhc3QtbWludXRlIGJ1Z3MgaW4gdW5pdHRlc3QuCgpFeHRlbnNpb25zCgotIFJldmVydGVkIHRoZSBwYXRjaCB0byB0aGUgT3BlblNTTCBjb2RlIGluIHNvY2tldG1vZHVsZS5jIHRvIHN1cHBvcnQKICBSQU5EX3N0YXR1cygpIGFuZCB0aGUgRUdELCBhbmQgdGhlIHN1YnNlcXVlbnQgcGF0Y2ggdGhhdCB0cmllZCB0bwogIGZpeCBpdCBmb3IgcHJlLTAuOS41IHZlcnNpb25zOyB0aGUgcHJvYmxlbSB3aXRoIHRoZSBwYXRjaCBpcyB0aGF0IG9uCiAgc29tZSBzeXN0ZW1zIGl0IGlzc3VlcyBhIHdhcm5pbmcgd2hlbmV2ZXIgc29ja2V0IGlzIGltcG9ydGVkLCBhbmQKICB0aGF0J3MgdW5hY2NlcHRhYmxlLgoKVGVzdHMKCi0gRml4ZWQgdGhlIHBpY2tsZSB0ZXN0cyB0byB3b3JrIHdpdGggImltcG9ydCB0ZXN0LnRlc3RfcGlja2xlIi4KCi0gVHdlYWtlZCB0ZXN0X2xvY2FsZS5weSB0byBhY3R1YWxseSBydW4gdGhlIHRlc3QgV2luZG93cy4KCi0gSW4gZGlzdHV0aWxzL2FyY2hpdmVfdXRpbC5weSwgY2FsbCB6aXBmaWxlLlppcEZpbGUoKSB3aXRoIG1vZGUgInciLAogIG5vdCAid2IiICh3aGljaCBpcyBub3QgYSB2YWxpZCBtb2RlIGF0IGFsbCkuCgotIEZpeCBwc3RhdHMgYnJvd3NlciBjcmFzaGVzLiAgSW1wb3J0IHJlYWRsaW5lIGlmIGl0IGV4aXN0cyB0byBtYWtlCiAgdGhlIHVzZXIgaW50ZXJmYWNlIG5pY2VyLgoKLSBBZGQgImltcG9ydCB0aHJlYWQiIHRvIHRoZSB0b3Agb2YgdGVzdCBtb2R1bGVzIHRoYXQgaW1wb3J0IHRoZQogIHRocmVhZGluZyBtb2R1bGUgKHRlc3RfYXN5bmNoYXQgYW5kIHRlc3RfdGhyZWFkZWR0ZW1wZmlsZSkuICBUaGlzCiAgcHJldmVudHMgdGVzdCBmYWlsdXJlcyBjYXVzZWQgYnkgYSBicm9rZW4gdGhyZWFkaW5nIG1vZHVsZSByZXN1bHRpbmcKICBmcm9tIGEgcHJldmlvdXNseSBjYXVnaHQgZmFpbGVkIGltcG9ydC4KCi0gQ2hhbmdlZCB0ZXN0X2FzeW5jaGF0LnB5IHRvIHNldCB0aGUgU09fUkVVU0VBRERSIG9wdGlvbjsgdGhpcyB3YXMKICBuZWVkZWQgb24gc29tZSBwbGF0Zm9ybXMgKGUuZy4gU29sYXJpcyA4KSB3aGVuIHRoZSB0ZXN0cyBhcmUgcnVuCiAgdHdpY2UgaW4gc3VjY2Vzc2lvbi4KCi0gU2tpcCByYXRoZXIgdGhhbiBmYWlsIHRlc3Rfc3VuYXVkaW9kZXYgaWYgbm8gYXVkaW8gZGV2aWNlIGlzIGZvdW5kLgoKCldoYXQncyBOZXcgaW4gUHl0aG9uIDIuMWMxPwo9PT09PT09PT09PT09PT09PT09PT09PT09PT0KClRoaXMgbGlzdCB3YXMgc2lnbmlmaWNhbnRseSB1cGRhdGVkIHdoZW4gMi4xYzIgd2FzIHJlbGVhc2VkOyB0aGUgMi4xYzEKcmVsZWFzZSBkaWRuJ3QgbWVudGlvbiBtb3N0IGNoYW5nZXMgdGhhdCB3ZXJlIGFjdHVhbGx5IHBhcnQgb2YgMi4xYzE6CgpMZWdhbAoKLSBDb3B5cmlnaHQgd2FzIGFzc2lnbmVkIHRvIHRoZSBQeXRob24gU29mdHdhcmUgRm91bmRhdGlvbiAoUFNGKSBhbmQgYQogIFBTRiBsaWNlbnNlICh2ZXJ5IHNpbWlsYXIgdG8gdGhlIENOUkkgbGljZW5zZSkgd2FzIGFkZGVkLgoKLSBUaGUgQ05SSSBjb3B5cmlnaHQgbm90aWNlIHdhcyB1cGRhdGVkIHRvIGluY2x1ZGUgMjAwMS4KCkNvcmUKCi0gQWZ0ZXIgYSBwdWJsaWMgb3V0Y3J5LCBhc3NpZ25tZW50IHRvIF9fZGVidWdfXyBpcyBubyBsb25nZXIgaWxsZWdhbDsKICBpbnN0ZWFkLCBhIHdhcm5pbmcgaXMgaXNzdWVkLiAgSXQgd2lsbCBiZWNvbWUgaWxsZWdhbCBpbiAyLjIuCgotIEZpeGVkIGEgY29yZSBkdW1wIHdpdGggIiUjeCIgJSAwLCBhbmQgY2hhbmdlZCB0aGUgc2VtYW50aWNzIHNvIHRoYXQKICAiJSN4IiBub3cgYWx3YXlzIHByZXBlbmRzICIweCIsIGV2ZW4gaWYgdGhlIHZhbHVlIGlzIHplcm8uCgotIEZpeGVkIHNvbWUgbml0cyBpbiB0aGUgYnl0ZWNvZGUgY29tcGlsZXIuCgotIEZpeGVkIGNvcmUgZHVtcHMgd2hlbiBjYWxsaW5nIGNlcnRhaW4ga2luZHMgb2Ygbm9uLWZ1bmN0aW9ucy4KCi0gRml4ZWQgdmFyaW91cyBjb3JlIGR1bXBzIGNhdXNlZCBieSByZWZlcmVuY2UgY291bnQgYnVncy4KCkJ1aWxkIGFuZCBQb3J0cwoKLSBVc2UgSU5TVEFMTF9TQ1JJUFQgdG8gaW5zdGFsbCBzY3JpcHQgZmlsZXMuCgotIE5ldyBwb3J0OiBTQ08gVW5peHdhcmUgNywgYnkgQmlsbHkgRy4gQWxsaWUuCgotIFVwZGF0ZWQgUklTQ09TIHBvcnQuCgotIFVwZGF0ZWQgQmVPUyBwb3J0IGFuZCBub3Rlcy4KCi0gVmFyaW91cyBvdGhlciBwb3J0aW5nIHByb2JsZW1zIHJlc29sdmVkLgoKTGlicmFyeQoKLSBUaGUgVEVSTUlPUyBhbmQgU09DS0VUIG1vZHVsZXMgYXJlIG5vdyB0cnVseSBvYnNvbGV0ZSBhbmQKICB1bm5lY2Vzc2FyeS4gIFRoZWlyIHN5bWJvbHMgYXJlIGluY29ycG9yYXRlZCBpbiB0aGUgdGVybWlvcyBhbmQKICBzb2NrZXQgbW9kdWxlcy4KCi0gRml4ZWQgc29tZSA2NC1iaXQgYnVncyBpbiBwaWNrbGUsIGNQaWNrbGUsIGFuZCBzdHJ1Y3QsIGFuZCBhZGRlZAogIGJldHRlciB0ZXN0cyBmb3IgcGlja2xpbmcuCgotIHRocmVhZGluZzogbWFrZSBDb25kaXRpb24ud2FpdCgpIHJvYnVzdCBhZ2FpbnN0IEtleWJvYXJkSW50ZXJydXB0LgoKLSB6aXBmaWxlOiBhZGQgc3VwcG9ydCB0byB6aXBmaWxlIHRvIHN1cHBvcnQgb3BlbmluZyBhbiBhcmNoaXZlCiAgcmVwcmVzZW50ZWQgYnkgYW4gb3BlbiBmaWxlIHJhdGhlciB0aGFuIGEgZmlsZSBuYW1lLiAgRml4IGJ1ZyB3aGVyZQogIHRoZSBhcmNoaXZlIHdhcyBub3QgcHJvcGVybHkgY2xvc2VkLiAgRml4ZWQgYSBidWcgaW4gdGhpcyBidWdmaXgKICB3aGVyZSBmbHVzaCgpIHdhcyBjYWxsZWQgZm9yIGEgcmVhZC1vbmx5IGZpbGUuCgotIGltcHV0aWw6IGFkZGVkIGFuIHVuaW5zdGFsbCgpIG1ldGhvZCB0byB0aGUgSW1wb3J0TWFuYWdlci4KCi0gQ2FudmFzOiBmaXhlZCBidWdzIGluIGxvd2VyKCkgYW5kIHRrcmFpc2UoKSBtZXRob2RzLgoKLSBTb2NrZXRTZXJ2ZXI6IEFQSSBjaGFuZ2UgKGFkZGVkIG92ZXJyaWRhYmxlIGNsb3NlX3JlcXVlc3QoKSBtZXRob2QpCiAgc28gdGhhdCB0aGUgVENQIHNlcnZlciBjYW4gZXhwbGljaXRseSBjbG9zZSB0aGUgcmVxdWVzdC4KCi0gcHN0YXRzOiBFcmljIFJheW1vbmQgYWRkZWQgYSBzaW1wbGUgaW50ZXJhY3RpdmUgc3RhdGlzdGljcyBicm93c2VyLAogIGludm9rZWQgd2hlbiB0aGUgbW9kdWxlIGlzIHJ1biBhcyBhIHNjcmlwdC4KCi0gbG9jYWxlOiBmaXhlZCBhIHByb2JsZW0gaW4gZm9ybWF0KCkuCgotIHdlYmJyb3dzZXI6IG1hZGUgaXQgd29yayB3aGVuIHRoZSBCUk9XU0VSIGVudmlyb25tZW50IHZhcmlhYmxlIGhhcyBhCiAgdmFsdWUgbGlrZSAiL3Vzci9iaW4vbmV0c2NhcGUiLiAgTWFkZSBpdCBhdXRvLWRldGVjdCBLb25xdWVyb3IgZm9yCiAgS0RFIDIuICBGaXhlZCBzb21lIG90aGVyIG5pdHMuCgotIHVuaXR0ZXN0OiBjaGFuZ2VzIHRvIGFsbG93IHVzaW5nIGEgZGlmZmVyZW50IGV4Y2VwdGlvbiB0aGFuCiAgQXNzZXJ0aW9uRXJyb3IsIGFuZCBhZGRlZCBhIGZldyBtb3JlIGZ1bmN0aW9uIGFsaWFzZXMuICBTb21lIG90aGVyCiAgc21hbGwgY2hhbmdlcy4KCi0gdXJsbGliLCB1cmxsaWIyOiBmaXhlZCByZWRpcmVjdCBwcm9ibGVtcyBhbmQgYSBjb3VwbGVvZiBvdGhlciBuaXRzLgoKLSBhc3luY2hhdDogZml4ZWQgYSBjcml0aWNhbCBidWcgaW4gYXN5bmNoYXQgdGhhdCBzbGlwcGVkIHRocm91Z2ggdGhlCiAgMi4xYjIgcmVsZWFzZS4gIEZpeGVkIGFub3RoZXIgcmFyZSBidWcuCgotIEZpeCBzb21lIHVucXVhbGlmaWVkIGV4Y2VwdDogY2xhdXNlcyAoYWx3YXlzIGEgYmFkIGNvZGUgZXhhbXBsZSkuCgpYTUwKCi0gcHlleHBhdDogbmV3IEFQSSBnZXRfdmVyc2lvbl9zdHJpbmcoKS4KCi0gRml4ZWQgc29tZSBtaW5pZG9tIGJ1Z3MuCgpFeHRlbnNpb25zCgotIEZpeGVkIGEgY29yZSBkdW1wIGluIF93ZWFrcmVmLiAgUmVtb3ZlZCB0aGUgd2Vha3JlZi5tYXBwaW5nKCkKICBmdW5jdGlvbiAoaXQgYWRkcyBub3RoaW5nIHRvIHRoZSBBUEkpLgoKLSBSYXRpb25hbGl6ZWQgdGhlIHVzZSBvZiBoZWFkZXIgZmlsZXMgaW4gdGhlIHJlYWRsaW5lIG1vZHVsZSwgdG8gbWFrZQogIGl0IGNvbXBpbGUgKGFsYmVpdCB3aXRoIHNvbWUgd2FybmluZ3MpIHdpdGggdGhlIHZlcnkgcmVjZW50IHJlYWRsaW5lCiAgNC4yLCB3aXRob3V0IGJyZWFraW5nIGZvciBlYXJsaWVyIHZlcnNpb25zLgoKLSBIb3BlZnVsbHkgZml4ZWQgYSBidWZmZXJpbmcgcHJvYmxlbSBpbiBsaW51eGF1ZGlvZGV2LgoKLSBBdHRlbXB0ZWQgYSBmaXggdG8gbWFrZSB0aGUgT3BlblNTTCBzdXBwb3J0IGluIHRoZSBzb2NrZXQgbW9kdWxlCiAgd29yayBhZ2FpbiB3aXRoIHByZS0wLjkuNSB2ZXJzaW9ucyBvZiBPcGVuU1NMLgoKVGVzdHMKCi0gQWRkZWQgYSB0ZXN0IGNhc2UgZm9yIGFzeW5jaGF0IGFuZCBhc3luY29yZS4KCi0gUmVtb3ZlZCBjb3VwbGluZyBiZXR3ZWVuIHRlc3RzIHdoZXJlIG9uZSB0ZXN0IGZhaWxpbmcgY291bGQgYnJlYWsKICBhbm90aGVyLgoKVG9vbHMKCi0gUGluZyBhZGRlZCBhbiBpbnRlcmFjdGl2ZSBoZWxwIGJyb3dzZXIgdG8gcHlkb2MsIGZpeGVkIHNvbWUgbml0cwogIGluIHRoZSByZXN0IG9mIHRoZSBweWRvYyBjb2RlLCBhbmQgYWRkZWQgc29tZSBmZWF0dXJlcyB0byBoaXMKICBpbnNwZWN0IG1vZHVsZS4KCi0gQW4gdXBkYXRlZCBweXRob24tbW9kZS5lbCB2ZXJzaW9uIDQuMSB3aGljaCBpbnRlZ3JhdGVzIEtlbgogIE1hbmhlaW1lcidzIHBkYnRyYWNrLmVsLiAgVGhpcyBtYWtlcyBkZWJ1Z2dpbmcgUHl0aG9uIGNvZGUgdmlhIHBkYgogIG11Y2ggbmljZXIgaW4gWEVtYWNzIGFuZCBFbWFjcy4gIFdoZW4gc3RlcHBpbmcgdGhyb3VnaCB5b3VyIHByb2dyYW0KICB3aXRoIHBkYiwgaW4gZWl0aGVyIHRoZSBzaGVsbCB3aW5kb3cgb3IgdGhlICpQeXRob24qIHdpbmRvdywgdGhlCiAgc291cmNlIGZpbGUgYW5kIGxpbmUgd2lsbCBiZSB0cmFja2VkIGJ5IGFuIGFycm93LiAgVmVyeSBjb29sIQoKLSBJRExFOiBzeW50YXggd2FybmluZ3MgaW4gaW50ZXJhY3RpdmUgbW9kZSBhcmUgY2hhbmdlZCBpbnRvIGVycm9ycy4KCi0gU29tZSBpbXByb3ZlbWVudHMgdG8gVG9vbHMvd2ViY2hlY2tlciAoaWdub3JlIHNvbWUgbW9yZSBVUkwgdHlwZXMsCiAgZm9sbG93IHNvbWUgbW9yZSBsaW5rcykuCgotIEJyb3VnaHQgdGhlIFRvb2xzL2NvbXBpbGVyIHBhY2thZ2UgdXAgdG8gZGF0ZS4KCgpXaGF0J3MgTmV3IGluIFB5dGhvbiAyLjEgYmV0YSAyPwo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKKFVubGlzdGVkIGFyZSBtYW55IGZpeGVkIGJ1Z3MsIG1vcmUgZG9jdW1lbnRhdGlvbiwgZXRjLikKCkNvcmUgbGFuZ3VhZ2UsIGJ1aWx0aW5zLCBhbmQgaW50ZXJwcmV0ZXIKCi0gVGhlIG5lc3RlZCBzY29wZXMgd29yayAoZW5hYmxlZCBieSAiZnJvbSBfX2Z1dHVyZV9fIGltcG9ydAogIG5lc3RlZF9zY29wZXMiKSBpcyBjb21wbGV0ZWQ7IGluIHBhcnRpY3VsYXIsIHRoZSBmdXR1cmUgbm93IGV4dGVuZHMKICBpbnRvIGNvZGUgZXhlY3V0ZWQgdGhyb3VnaCBleGVjLCBldmFsKCkgYW5kIGV4ZWNmaWxlKCksIGFuZCBpbnRvIHRoZQogIGludGVyYWN0aXZlIGludGVycHJldGVyLgoKLSBXaGVuIGNhbGxpbmcgYSBiYXNlIGNsYXNzIG1ldGhvZCAoZS5nLiBCYXNlQ2xhc3MuX19pbml0X18oc2VsZikpLAogIHRoaXMgaXMgbm93IGFsbG93ZWQgZXZlbiBpZiBzZWxmIGlzIG5vdCBzdHJpY3RseSBzcG9rZW4gYSBjbGFzcwogIGluc3RhbmNlIChlLmcuIHdoZW4gdXNpbmcgbWV0YWNsYXNzZXMgb3IgdGhlIERvbiBCZWF1ZHJ5IGhvb2spLgoKLSBTbGljZSBvYmplY3RzIGFyZSBub3cgY29tcGFyYWJsZSBidXQgbm90IGhhc2hhYmxlOyB0aGlzIHByZXZlbnRzCiAgZGljdFs6XSBmcm9tIGJlaW5nIGFjY2VwdGVkIGJ1dCBtZWFuaW5nbGVzcy4KCi0gQ29tcGxleCBkaXZpc2lvbiBpcyBub3cgY2FsY3VsYXRlZCB1c2luZyBsZXNzIGJyYWluZGVhZCBhbGdvcml0aG1zLgogIFRoaXMgZG9lc24ndCBjaGFuZ2Ugc2VtYW50aWNzIGV4Y2VwdCBpdCdzIG1vcmUgbGlrZWx5IHRvIGdpdmUgdXNlZnVsCiAgcmVzdWx0cyBpbiBleHRyZW1lIGNhc2VzLiAgQ29tcGxleCByZXByKCkgbm93IHVzZXMgZnVsbCBwcmVjaXNpb24KICBsaWtlIGZsb2F0IHJlcHIoKS4KCi0gc2dtbGxpYi5weSBub3cgY2FsbHMgaGFuZGxlX2RlY2woKSBmb3Igc2ltcGxlIDwhLi4uPiBkZWNsYXJhdGlvbnMuCgotIEl0IGlzIGlsbGVnYWwgdG8gYXNzaWduIHRvIHRoZSBuYW1lIF9fZGVidWdfXywgd2hpY2ggaXMgc2V0IHdoZW4gdGhlCiAgaW50ZXJwcmV0ZXIgc3RhcnRzLiAgSXQgaXMgZWZmZWN0aXZlbHkgYSBjb21waWxlLXRpbWUgY29uc3RhbnQuCgotIEEgd2FybmluZyB3aWxsIGJlIGlzc3VlZCBpZiBhIGdsb2JhbCBzdGF0ZW1lbnQgZm9yIGEgdmFyaWFibGUKICBmb2xsb3dzIGEgdXNlIG9yIGFzc2lnbm1lbnQgb2YgdGhhdCB2YXJpYWJsZS4KClN0YW5kYXJkIGxpYnJhcnkKCi0gdW5pdHRlc3QucHksIGEgdW5pdCB0ZXN0aW5nIGZyYW1ld29yayBieSBTdGV2ZSBQdXJjZWxsIChQeVVOSVQsCiAgaW5zcGlyZWQgYnkgSlVuaXQpLCBpcyBub3cgcGFydCBvZiB0aGUgc3RhbmRhcmQgbGlicmFyeS4gIFlvdSBub3cKICBoYXZlIGEgY2hvaWNlIG9mIHR3byB0ZXN0aW5nIGZyYW1ld29ya3M6IHVuaXR0ZXN0IHJlcXVpcmVzIHlvdSB0bwogIHdyaXRlIHRlc3RjYXNlcyBhcyBzZXBhcmF0ZSBjb2RlLCBkb2N0ZXN0IGdhdGhlcnMgdGhlbSBmcm9tCiAgZG9jc3RyaW5ncy4gIEJvdGggYXBwcm9hY2hlcyBoYXZlIHRoZWlyIGFkdmFudGFnZXMgYW5kCiAgZGlzYWR2YW50YWdlcy4KCi0gQSBuZXcgbW9kdWxlIFRpeCB3YXMgYWRkZWQsIHdoaWNoIHdyYXBzIHRoZSBUaXggZXh0ZW5zaW9uIGxpYnJhcnkKICBmb3IgVGsuICBXaXRoIHRoYXQgbW9kdWxlLCBpdCBpcyBub3QgbmVjZXNzYXJ5IHRvIHN0YXRpY2FsbHkgbGluawogIFRpeCB3aXRoIF90a2ludGVyLCBzaW5jZSBUaXggd2lsbCBiZSBsb2FkZWQgd2l0aCBUY2wncyAicGFja2FnZQogIHJlcXVpcmUiIGNvbW1hbmQuICBTZWUgRGVtby90aXgvLgoKLSB0enBhcnNlLnB5IGlzIG5vdyBvYnNvbGV0ZS4KCi0gSW4gZ3ppcC5weSwgdGhlIHNlZWsoKSBhbmQgdGVsbCgpIG1ldGhvZHMgYXJlIHJlbW92ZWQgLS0gdGhleSB3ZXJlCiAgbm9uLWZ1bmN0aW9uYWwgYW55d2F5LCBhbmQgaXQncyBiZXR0ZXIgaWYgY2FsbGVycyBjYW4gdGVzdCBmb3IgdGhlaXIKICBleGlzdGVuY2Ugd2l0aCBoYXNhdHRyKCkuCgpQeXRob24vQyBBUEkKCi0gUHlEaWN0X05leHQoKTogaXQgaXMgbm93IHNhZmUgdG8gY2FsbCBQeURpY3RfU2V0SXRlbSgpIHdpdGggYSBrZXkKICB0aGF0J3MgYWxyZWFkeSBpbiB0aGUgZGljdGlvbmFyeSBkdXJpbmcgYSBQeURpY3RfTmV4dCgpIGl0ZXJhdGlvbi4KICBUaGlzIHVzZWQgdG8gZmFpbCBvY2Nhc2lvbmFsbHkgd2hlbiBhIGRpY3Rpb25hcnkgcmVzaXplIG9wZXJhdGlvbgogIGNvdWxkIGJlIHRyaWdnZXJlZCB0aGF0IHdvdWxkIHJlaGFzaCBhbGwgdGhlIGtleXMuICBBbGwgb3RoZXIKICBtb2RpZmljYXRpb25zIHRvIHRoZSBkaWN0aW9uYXJ5IGFyZSBzdGlsbCBvZmYtbGltaXRzIGR1cmluZyBhCiAgUHlEaWN0X05leHQoKSBpdGVyYXRpb24hCgotIE5ldyBleHRlbmRlZCBBUElzIHJlbGF0ZWQgdG8gcGFzc2luZyBjb21waWxlciB2YXJpYWJsZXMgYXJvdW5kLgoKLSBOZXcgYWJzdHJhY3QgQVBJcyBQeU9iamVjdF9Jc0luc3RhbmNlKCksIFB5T2JqZWN0X0lzU3ViY2xhc3MoKQogIGltcGxlbWVudCBpc2luc3RhbmNlKCkgYW5kIGlzc3ViY2xhc3MoKS4KCi0gUHlfQnVpbGRWYWx1ZSgpIG5vdyBoYXMgYSAiRCIgY29udmVyc2lvbiB0byBjcmVhdGUgYSBQeXRob24gY29tcGxleAogIG51bWJlciBmcm9tIGEgUHlfY29tcGxleCBDIHZhbHVlLgoKLSBFeHRlbnNpb25zIHR5cGVzIHdoaWNoIHN1cHBvcnQgd2VhayByZWZlcmVuY2VzIG11c3Qgbm93IHNldCB0aGUKICBmaWVsZCBhbGxvY2F0ZWQgZm9yIHRoZSB3ZWFrIHJlZmVyZW5jZSBtYWNoaW5lcnkgdG8gTlVMTCB0aGVtc2VsdmVzOwogIHRoaXMgaXMgZG9uZSB0byBhdm9pZCB0aGUgY29zdCBvZiBjaGVja2luZyBlYWNoIG9iamVjdCBmb3IgaGF2aW5nIGEKICB3ZWFrbHkgcmVmZXJlbmNhYmxlIHR5cGUgaW4gUHlPYmplY3RfSU5JVCgpLCBzaW5jZSBtb3N0IHR5cGVzIGFyZQogIG5vdCB3ZWFrbHkgcmVmZXJlbmNhYmxlLgoKLSBQeUZyYW1lX0Zhc3RUb0xvY2FscygpIGFuZCBQeUZyYW1lX0xvY2Fsc1RvRmFzdCgpIGNvcHkgYmluZGluZ3MgZm9yCiAgZnJlZSB2YXJpYWJsZXMgYW5kIGNlbGwgdmFyaWFibGVzIHRvIGFuZCBmcm9tIHRoZSBmcmFtZSdzIGZfbG9jYWxzLgoKLSBWYXJpYW50cyBvZiBzZXZlcmFsIGZ1bmN0aW9ucyBkZWZpbmVkIGluIHB5dGhvbnJ1bi5oIGhhdmUgYmVlbiBhZGRlZAogIHRvIHN1cHBvcnQgdGhlIG5lc3RlZF9zY29wZXMgZnV0dXJlIHN0YXRlbWVudC4gIFRoZSB2YXJpYW50cyBhbGwgZW5kCiAgaW4gRmxhZ3MgYW5kIHRha2UgYW4gZXh0cmEgYXJndW1lbnQsIGEgUHlDb21waWxlckZsYWdzICo7IGV4YW1wbGVzOgogIFB5UnVuX0FueUZpbGVFeEZsYWdzKCksIFB5UnVuX0ludGVyYWN0aXZlTG9vcEZsYWdzKCkuICBUaGVzZQogIHZhcmlhbnRzIG1heSBiZSByZW1vdmVkIGluIFB5dGhvbiAyLjIsIHdoZW4gbmVzdGVkIHNjb3BlcyBhcmUKICBtYW5kYXRvcnkuCgpEaXN0dXRpbHMKCi0gdGhlIHNkaXN0IGNvbW1hbmQgbm93IHdyaXRlcyBhIFBLRy1JTkZPIGZpbGUsIGFzIGRlc2NyaWJlZCBpbiBQRVAgMjQxLAogIGludG8gdGhlIHJlbGVhc2UgdHJlZS4KCi0gc2V2ZXJhbCBlbmhhbmNlbWVudHMgdG8gdGhlIGJkaXN0X3dpbmluc3QgY29tbWFuZCBmcm9tIFRob21hcyBIZWxsZXIKICAoYW4gdW5pbnN0YWxsZXIsIG1vcmUgY3VzdG9taXphdGlvbiBvZiB0aGUgaW5zdGFsbGVyJ3MgZGlzcGxheSkKCi0gZnJvbSBKYWNrIEphbnNlbjogYWRkZWQgTWFjLXNwZWNpZmljIGNvZGUgdG8gZ2VuZXJhdGUgYSBkaWFsb2cgZm9yCiAgdXNlcnMgdG8gc3BlY2lmeSB0aGUgY29tbWFuZC1saW5lIChiZWNhdXNlIHByb3ZpZGluZyBhIGNvbW1hbmQtbGluZSB3aXRoCiAgTWFjUHl0aG9uIGlzIGF3a3dhcmQpLiAgSmFjayBhbHNvIG1hZGUgdmFyaW91cyBmaXhlcyBmb3IgdGhlIE1hYwogIGFuZCB0aGUgTWV0cm93ZXJrcyBjb21waWxlci4KCi0gYWRkZWQgJ3BsYXRmb3JtcycgYW5kICdrZXl3b3JkcycgdG8gdGhlIHNldCBvZiBtZXRhZGF0YSB0aGF0IGNhbiBiZQogIHNwZWNpZmllZCBmb3IgYSBkaXN0cmlidXRpb24uCgotIGFwcGxpZWQgcGF0Y2hlcyBmcm9tIEphc29uIFRpc2hsZXIgdG8gbWFrZSB0aGUgY29tcGlsZXIgY2xhc3Mgd29yayB3aXRoCiAgQ3lnd2luLgoKCldoYXQncyBOZXcgaW4gUHl0aG9uIDIuMSBiZXRhIDE/Cj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpDb3JlIGxhbmd1YWdlLCBidWlsdGlucywgYW5kIGludGVycHJldGVyCgotIEZvbGxvd2luZyBhbiBvdXRjcnkgZnJvbSB0aGUgY29tbXVuaXR5IGFib3V0IHRoZSBhbW91bnQgb2YgY29kZQogIGJyb2tlbiBieSB0aGUgbmVzdGVkIHNjb3BlcyBmZWF0dXJlIGludHJvZHVjZWQgaW4gMi4xYTIsIHdlIGRlY2lkZWQKICB0byBtYWtlIHRoaXMgZmVhdHVyZSBvcHRpb25hbCwgYW5kIHRvIHdhaXQgdW50aWwgUHl0aG9uIDIuMiAob3IgYXQKICBsZWFzdCA2IG1vbnRocykgdG8gbWFrZSBpdCBzdGFuZGFyZC4gIFRoZSBvcHRpb24gY2FuIGJlIGVuYWJsZWQgb24gYQogIHBlci1tb2R1bGUgYmFzaXMgYnkgYWRkaW5nICJmcm9tIF9fZnV0dXJlX18gaW1wb3J0IG5lc3RlZF9zY29wZXMiIGF0CiAgdGhlIGJlZ2lubmluZyBvZiBhIG1vZHVsZSAoYmVmb3JlIGFueSBvdGhlciBzdGF0ZW1lbnRzLCBidXQgYWZ0ZXIKICBjb21tZW50cyBhbmQgYW4gb3B0aW9uYWwgZG9jc3RyaW5nKS4gIFNlZSBQRVAgMjM2IChCYWNrIHRvIHRoZQogIF9fZnV0dXJlX18pIGZvciBhIGRlc2NyaXB0aW9uIG9mIHRoZSBfX2Z1dHVyZV9fIHN0YXRlbWVudC4gIFBFUCAyMjcKICAoU3RhdGljYWxseSBOZXN0ZWQgU2NvcGVzKSBoYXMgYmVlbiB1cGRhdGVkIHRvIHJlZmxlY3QgdGhpcyBjaGFuZ2UsCiAgYW5kIHRvIGNsYXJpZnkgdGhlIHNlbWFudGljcyBpbiBhIG51bWJlciBvZiBlbmRjYXNlcy4KCi0gVGhlIG5lc3RlZCBzY29wZXMgY29kZSwgd2hlbiBlbmFibGVkLCBoYXMgYmVlbiBoYXJkZW5lZCwgYW5kIG1vc3QKICBidWdzIGFuZCBtZW1vcnkgbGVha3MgaW4gaXQgaGF2ZSBiZWVuIGZpeGVkLgoKLSBDb21waWxlLXRpbWUgd2FybmluZ3MgYXJlIG5vdyBnZW5lcmF0ZWQgZm9yIGEgbnVtYmVyIG9mIGNvbmRpdGlvbnMKICB0aGF0IHdpbGwgYnJlYWsgb3IgY2hhbmdlIGluIG1lYW5pbmcgd2hlbiBuZXN0ZWQgc2NvcGVzIGFyZSBlbmFibGVkOgoKICAtIFVzaW5nICJmcm9tLi4uaW1wb3J0ICoiIG9yICJleGVjIiB3aXRob3V0IGluLWNsYXVzZSBpbiBhIGZ1bmN0aW9uCiAgICBzY29wZSB0aGF0IGFsc28gZGVmaW5lcyBhIGxhbWJkYSBvciBuZXN0ZWQgZnVuY3Rpb24gd2l0aCBvbmUgb3IKICAgIG1vcmUgZnJlZSAobm9uLWxvY2FsKSB2YXJpYWJsZXMuICBUaGUgcHJlc2VuY2Ugb2YgdGhlIGltcG9ydCogb3IKICAgIGJhcmUgZXhlYyBtYWtlcyBpdCBpbXBvc3NpYmxlIGZvciB0aGUgY29tcGlsZXIgdG8gZGV0ZXJtaW5lIHRoZQogICAgZXhhY3Qgc2V0IG9mIGxvY2FsIHZhcmlhYmxlcyBpbiB0aGUgb3V0ZXIgc2NvcGUsIHdoaWNoIG1ha2VzIGl0CiAgICBpbXBvc3NpYmxlIHRvIGRldGVybWluZSB0aGUgYmluZGluZ3MgZm9yIGZyZWUgdmFyaWFibGVzIGluIHRoZQogICAgaW5uZXIgc2NvcGUuICBUbyBhdm9pZCB0aGUgd2FybmluZyBhYm91dCBpbXBvcnQgKiwgY2hhbmdlIGl0IGludG8KICAgIGFuIGltcG9ydCBvZiBleHBsaWNpdGx5IG5hbWUgb2JqZWN0LCBvciBtb3ZlIHRoZSBpbXBvcnQqIHN0YXRlbWVudAogICAgdG8gdGhlIGdsb2JhbCBzY29wZTsgdG8gYXZvaWQgdGhlIHdhcm5pbmcgYWJvdXQgYmFyZSBleGVjLCB1c2UKICAgIGV4ZWMuLi5pbi4uLiAoYSBnb29kIGlkZWEgYW55d2F5IC0tIHRoZXJlJ3MgYSBwb3NzaWJpbGl0eSB0aGF0CiAgICBiYXJlIGV4ZWMgd2lsbCBiZSBkZXByZWNhdGVkIGluIHRoZSBmdXR1cmUpLgoKICAtIFVzZSBvZiBhIGdsb2JhbCB2YXJpYWJsZSBpbiBhIG5lc3RlZCBzY29wZSB3aXRoIHRoZSBzYW1lIG5hbWUgYXMgYQogICAgbG9jYWwgdmFyaWFibGUgaW4gYSBzdXJyb3VuZGluZyBzY29wZS4gIFRoaXMgd2lsbCBjaGFuZ2UgaW4KICAgIG1lYW5pbmcgd2l0aCBuZXN0ZWQgc2NvcGVzOiB0aGUgbmFtZSBpbiB0aGUgaW5uZXIgc2NvcGUgd2lsbAogICAgcmVmZXJlbmNlIHRoZSB2YXJpYWJsZSBpbiB0aGUgb3V0ZXIgc2NvcGUgcmF0aGVyIHRoYW4gdGhlIGdsb2JhbAogICAgb2YgdGhlIHNhbWUgbmFtZS4gIFRvIGF2b2lkIHRoZSB3YXJuaW5nLCBlaXRoZXIgcmVuYW1lIHRoZSBvdXRlcgogICAgdmFyaWFibGUsIG9yIHVzZSBhIGdsb2JhbCBzdGF0ZW1lbnQgaW4gdGhlIGlubmVyIGZ1bmN0aW9uLgoKLSBBbiBvcHRpb25hbCBvYmplY3QgYWxsb2NhdG9yIGhhcyBiZWVuIGluY2x1ZGVkLiAgVGhpcyBhbGxvY2F0b3IgaXMKICBvcHRpbWl6ZWQgZm9yIFB5dGhvbiBvYmplY3RzIGFuZCBzaG91bGQgYmUgZmFzdGVyIGFuZCB1c2UgbGVzcyBtZW1vcnkKICB0aGFuIHRoZSBzdGFuZGFyZCBzeXN0ZW0gYWxsb2NhdG9yLiAgSXQgaXMgbm90IGVuYWJsZWQgYnkgZGVmYXVsdAogIGJlY2F1c2Ugb2YgcG9zc2libGUgdGhyZWFkIHNhZmV0eSBwcm9ibGVtcy4gIFRoZSBhbGxvY2F0b3IgaXMgb25seQogIHByb3RlY3RlZCBieSB0aGUgUHl0aG9uIGludGVycHJldGVyIGxvY2sgYW5kIGl0IGlzIHBvc3NpYmxlIHRoYXQgc29tZQogIGV4dGVuc2lvbiBtb2R1bGVzIHJlcXVpcmUgYSB0aHJlYWQgc2FmZSBhbGxvY2F0b3IuICBUaGUgb2JqZWN0CiAgYWxsb2NhdG9yIGNhbiBiZSBlbmFibGVkIGJ5IHByb3ZpZGluZyB0aGUgIi0td2l0aC1weW1hbGxvYyIgb3B0aW9uIHRvCiAgY29uZmlndXJlLgoKU3RhbmRhcmQgbGlicmFyeQoKLSBweWV4cGF0IG5vdyBkZXRlY3RzIHRoZSBleHBhdCB2ZXJzaW9uIGlmIGV4cGF0LmggZGVmaW5lcyBpdC4gQQogIG51bWJlciBvZiBhZGRpdGlvbmFsIGhhbmRsZXJzIGFyZSBwcm92aWRlZCwgd2hpY2ggYXJlIG9ubHkgYXZhaWxhYmxlCiAgc2luY2UgZXhwYXQgMS45NS4gSW4gYWRkaXRpb24sIHRoZSBtZXRob2RzIFNldFBhcmFtRW50aXR5UGFyc2luZyBhbmQKICBHZXRJbnB1dENvbnRleHQgb2YgUGFyc2VyIG9iamVjdHMgYXJlIGF2YWlsYWJsZSB3aXRoIDEuOTUueAogIG9ubHkuIFBhcnNlciBvYmplY3RzIG5vdyBwcm92aWRlIHRoZSBvcmRlcmVkX2F0dHJpYnV0ZXMgYW5kCiAgc3BlY2lmaWVkX2F0dHJpYnV0ZXMgYXR0cmlidXRlcy4gQSBuZXcgbW9kdWxlIGV4cGF0Lm1vZGVsIHdhcyBhZGRlZCwKICB3aGljaCBvZmZlcnMgYSBudW1iZXIgb2YgYWRkaXRpb25hbCBjb25zdGFudHMgaWYgMS45NS54IGlzIHVzZWQuCgotIHhtbC5kb20gb2ZmZXJzIHRoZSBuZXcgZnVuY3Rpb25zIHJlZ2lzdGVyRE9NSW1wbGVtZW50YXRpb24gYW5kCiAgZ2V0RE9NSW1wbGVtZW50YXRpb24uCgotIHhtbC5kb20ubWluaWRvbSBvZmZlcnMgYSB0b3ByZXR0eXhtbCBtZXRob2QuIEEgbnVtYmVyIG9mIERPTQogIGNvbmZvcm1hbmNlIGlzc3VlcyBoYXZlIGJlZW4gcmVzb2x2ZWQuIEluIHBhcnRpY3VsYXIsIEVsZW1lbnQgbm93CiAgaGFzIGFuIGhhc0F0dHJpYnV0ZXMgbWV0aG9kLCBhbmQgdGhlIGhhbmRsaW5nIG9mIG5hbWVzcGFjZXMgd2FzCiAgaW1wcm92ZWQuCgotIEthLVBpbmcgWWVlIGNvbnRyaWJ1dGVkIHR3byBuZXcgbW9kdWxlczogaW5zcGVjdC5weSwgYSBtb2R1bGUgZm9yCiAgZ2V0dGluZyBpbmZvcm1hdGlvbiBhYm91dCBsaXZlIFB5dGhvbiBjb2RlLCBhbmQgcHlkb2MucHksIGEgbW9kdWxlCiAgZm9yIGludGVyYWN0aXZlbHkgY29udmVydGluZyBkb2NzdHJpbmdzIHRvIEhUTUwgb3IgdGV4dC4KICBUb29scy9zY3JpcHRzL3B5ZG9jLCB3aGljaCBpcyBub3cgYXV0b21hdGljYWxseSBpbnN0YWxsZWQgaW50bwogIDxwcmVmaXg+L2JpbiwgdXNlcyBweWRvYy5weSB0byBkaXNwbGF5IGRvY3VtZW50YXRpb247IHRyeSBydW5uaW5nCiAgInB5ZG9jIC1oIiBmb3IgaW5zdHJ1Y3Rpb25zLiAgInB5ZG9jIC1nIiBwb3BzIHVwIGEgc21hbGwgR1VJIHRoYXQKICBsZXRzIHlvdSBicm93c2UgdGhlIG1vZHVsZSBkb2NzdHJpbmdzIHVzaW5nIGEgd2ViIGJyb3dzZXIuCgotIE5ldyBsaWJyYXJ5IG1vZHVsZSBkaWZmbGliLnB5LCBwcmltYXJpbHkgcGFja2FnaW5nIHRoZSBTZXF1ZW5jZU1hdGNoZXIKICBjbGFzcyBhdCB0aGUgaGVhcnQgb2YgdGhlIHBvcHVsYXIgbmRpZmYucHkgZmlsZS1jb21wYXJpc29uIHRvb2wuCgotIGRvY3Rlc3QucHkgKGEgZnJhbWV3b3JrIGZvciB2ZXJpZnlpbmcgUHl0aG9uIGNvZGUgZXhhbXBsZXMgaW4gZG9jc3RyaW5ncykKICBpcyBub3cgcGFydCBvZiB0aGUgc3RkIGxpYnJhcnkuCgpXaW5kb3dzIGNoYW5nZXMKCi0gQSBuZXcgZW50cnkgaW4gdGhlIFN0YXJ0IG1lbnUsICJNb2R1bGUgRG9jcyIsIHJ1bnMgInB5ZG9jIC1nIiAtLSBhCiAgc21hbGwgR1VJIHRoYXQgbGV0cyB5b3UgYnJvd3NlIHRoZSBtb2R1bGUgZG9jc3RyaW5ncyB1c2luZyB5b3VyCiAgZGVmYXVsdCB3ZWIgYnJvd3Nlci4KCi0gSW1wb3J0IGlzIG5vdyBjYXNlLXNlbnNpdGl2ZS4gIFBFUCAyMzUgKEltcG9ydCBvbiBDYXNlLUluc2Vuc2l0aXZlCiAgUGxhdGZvcm1zKSBpcyBpbXBsZW1lbnRlZC4gIFNlZQoKICAgICAgaHR0cDovL3B5dGhvbi5zb3VyY2Vmb3JnZS5uZXQvcGVwcy9wZXAtMDIzNS5odG1sCgogIGZvciBmdWxsIGRldGFpbHMsIGVzcGVjaWFsbHkgdGhlICJDdXJyZW50IExvd2VyLUxlZnQgU2VtYW50aWNzIiBzZWN0aW9uLgogIFRoZSBuZXcgV2luZG93cyBpbXBvcnQgcnVsZXMgYXJlIHNpbXBsZXIgdGhhbiBiZWZvcmU6CgogIEEuIElmIHRoZSBQWVRIT05DQVNFT0sgZW52aXJvbm1lbnQgdmFyaWFibGUgZXhpc3RzLCBzYW1lIGFzCiAgICAgYmVmb3JlOiAgc2lsZW50bHkgYWNjZXB0IHRoZSBmaXJzdCBjYXNlLWluc2Vuc2l0aXZlIG1hdGNoIG9mIGFueQogICAgIGtpbmQ7IHJhaXNlIEltcG9ydEVycm9yIGlmIG5vbmUgZm91bmQuCgogIEIuIEVsc2Ugc2VhcmNoIHN5cy5wYXRoIGZvciB0aGUgZmlyc3QgY2FzZS1zZW5zaXRpdmUgbWF0Y2g7IHJhaXNlCiAgICAgSW1wb3J0RXJyb3IgaWYgbm9uZSBmb3VuZC4KCiAgVGhlIHNhbWUgcnVsZXMgaGF2ZSBiZWVuIGltcGxlbWVudGVkIG9uIG90aGVyIHBsYXRmb3JtcyB3aXRoIGNhc2UtCiAgaW5zZW5zaXRpdmUgYnV0IGNhc2UtcHJlc2VydmluZyBmaWxlc3lzdGVtcyB0b28gKGluY2x1ZGluZyBDeWd3aW4sIGFuZAogIHNldmVyYWwgZmxhdm9ycyBvZiBNYWNpbnRvc2ggb3BlcmF0aW5nIHN5c3RlbXMpLgoKLSB3aW5zb3VuZCBtb2R1bGU6ICBVbmRlciBXaW45eCwgd2luc291bmQuQmVlcCgpIG5vdyBhdHRlbXB0cyB0byBzaW11bGF0ZQogIHdoYXQgaXQncyBzdXBwb3NlZCB0byBkbyAoYW5kIGRvZXMgZG8gdW5kZXIgTlQgYW5kIDIwMDApIHZpYSBkaXJlY3QKICBwb3J0IG1hbmlwdWxhdGlvbi4gIEl0J3MgdW5rbm93biB3aGV0aGVyIHRoaXMgd2lsbCB3b3JrIG9uIGFsbCBzeXN0ZW1zLAogIGJ1dCBpdCBkb2VzIHdvcmsgb24gbXkgV2luOThTRSBzeXN0ZW1zIG5vdyBhbmQgd2FzIGtub3duIHRvIGJlIHVzZWxlc3Mgb24KICBhbGwgV2luOXggc3lzdGVtcyBiZWZvcmUuCgotIEJ1aWxkOiAgU3VicHJvamVjdCBfdGVzdCAoZWZmZWN0aXZlbHkpIHJlbmFtZWQgdG8gX3Rlc3RjYXBpLgoKTmV3IHBsYXRmb3JtcwoKLSAyLjEgc2hvdWxkIGNvbXBpbGUgYW5kIHJ1biBvdXQgb2YgdGhlIGJveCB1bmRlciBNYWNPUyBYLCBldmVuIHVzaW5nIEhGUysuCiAgVGhhbmtzIHRvIFN0ZXZlbiBNYWpld3NraSEKCi0gMi4xIHNob3VsZCBjb21waWxlIGFuZCBydW4gb3V0IG9mIHRoZSBib3ggb24gQ3lnd2luLiAgVGhhbmtzIHRvIEphc29uCiAgVGlzaGxlciEKCi0gMi4xIGNvbnRhaW5zIG5ldyBmaWxlcyBhbmQgcGF0Y2hlcyBmb3IgUklTQ09TLCB0aGFua3MgdG8gRGlldG1hcgogIFNjaHdlcnRiZXJnZXIhICBTZWUgUklTQ09TL1JFQURNRSBmb3IgbW9yZSBpbmZvcm1hdGlvbiAtLSBpdCBzZWVtcwogIHRoYXQgYmVjYXVzZSBvZiB0aGUgYml6YXJyZSBmaWxlbmFtZSBjb252ZW50aW9ucyBvbiBSSVNDT1MsIG5vIHBvcnQKICB0byB0aGF0IHBsYXRmb3JtIGlzIGVhc3kuCgoKV2hhdCdzIE5ldyBpbiBQeXRob24gMi4xIGFscGhhIDI/Cj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKQ29yZSBsYW5ndWFnZSwgYnVpbHRpbnMsIGFuZCBpbnRlcnByZXRlcgoKLSBTY29wZXMgbmVzdC4gIElmIGEgbmFtZSBpcyB1c2VkIGluIGEgZnVuY3Rpb24gb3IgY2xhc3MsIGJ1dCBpcyBub3QKICBsb2NhbCwgdGhlIGRlZmluaXRpb24gaW4gdGhlIG5lYXJlc3QgZW5jbG9zaW5nIGZ1bmN0aW9uIHNjb3BlIHdpbGwKICBiZSB1c2VkLiAgT25lIGNvbnNlcXVlbmNlIG9mIHRoaXMgY2hhbmdlIGlzIHRoYXQgbGFtYmRhIHN0YXRlbWVudHMKICBjb3VsZCByZWZlcmVuY2UgdmFyaWFibGVzIGluIHRoZSBuYW1lc3BhY2VzIHdoZXJlIHRoZSBsYW1iZGEgaXMKICBkZWZpbmVkLiAgSW4gc29tZSB1bnVzdWFsIGNhc2VzLCB0aGlzIGNoYW5nZSB3aWxsIGJyZWFrIGNvZGUuCgogIEluIGFsbCBwcmV2aW91cyB2ZXJzaW9uIG9mIFB5dGhvbiwgbmFtZXMgd2VyZSByZXNvbHZlZCBpbiBleGFjdGx5CiAgdGhyZWUgbmFtZXNwYWNlcyAtLSB0aGUgbG9jYWwgbmFtZXNwYWNlLCB0aGUgZ2xvYmFsIG5hbWVzcGFjZSwgYW5kCiAgdGhlIGJ1aWx0aW4gbmFtZXNwYWNlLiAgQWNjb3JkaW5nIHRvIHRoaXMgb2xkIGRlZmluaXRpb24sIGlmIGEKICBmdW5jdGlvbiBBIGlzIGRlZmluZWQgd2l0aGluIGEgZnVuY3Rpb24gQiwgdGhlIG5hbWVzIGJvdW5kIGluIEIgYXJlCiAgbm90IHZpc2libGUgaW4gQS4gIFRoZSBuZXcgcnVsZXMgbWFrZSBuYW1lcyBib3VuZCBpbiBCIHZpc2libGUgaW4gQSwKICB1bmxlc3MgQSBjb250YWlucyBhIG5hbWUgYmluZGluZyB0aGF0IGhpZGVzIHRoZSBiaW5kaW5nIGluIEIuCgogIFNlY3Rpb24gNC4xIG9mIHRoZSByZWZlcmVuY2UgbWFudWFsIGRlc2NyaWJlcyB0aGUgbmV3IHNjb3BpbmcgcnVsZXMKICBpbiBkZXRhaWwuICBUaGUgdGVzdCBzY3JpcHQgaW4gTGliL3Rlc3QvdGVzdF9zY29wZS5weSBkZW1vbnN0cmF0ZXMKICBzb21lIG9mIHRoZSBlZmZlY3RzIG9mIHRoZSBjaGFuZ2UuCgogIFRoZSBuZXcgcnVsZXMgd2lsbCBjYXVzZSBleGlzdGluZyBjb2RlIHRvIGJyZWFrIGlmIGl0IGRlZmluZXMgbmVzdGVkCiAgZnVuY3Rpb25zIHdoZXJlIGFuIG91dGVyIGZ1bmN0aW9uIGhhcyBsb2NhbCB2YXJpYWJsZXMgd2l0aCB0aGUgc2FtZQogIG5hbWUgYXMgZ2xvYmFscyBvciBidWlsdGlucyB1c2VkIGJ5IHRoZSBpbm5lciBmdW5jdGlvbi4gIEV4YW1wbGU6CgogICAgZGVmIG11bmdlKHN0cik6CiAgICAgICAgZGVmIGhlbHBlcih4KToKICAgICAgICAgICAgcmV0dXJuIHN0cih4KQogICAgICAgIGlmIHR5cGUoc3RyKSAhPSB0eXBlKCcnKToKICAgICAgICAgICAgc3RyID0gaGVscGVyKHN0cikKICAgICAgICByZXR1cm4gc3RyLnN0cmlwKCkKCiAgVW5kZXIgdGhlIG9sZCBydWxlcywgdGhlIG5hbWUgc3RyIGluIGhlbHBlcigpIGlzIGJvdW5kIHRvIHRoZQogIGJ1aWx0aW4gZnVuY3Rpb24gc3RyKCkuICBVbmRlciB0aGUgbmV3IHJ1bGVzLCBpdCB3aWxsIGJlIGJvdW5kIHRvCiAgdGhlIGFyZ3VtZW50IG5hbWVkIHN0ciBhbmQgYW4gZXJyb3Igd2lsbCBvY2N1ciB3aGVuIGhlbHBlcigpIGlzCiAgY2FsbGVkLgoKLSBUaGUgY29tcGlsZXIgd2lsbCByZXBvcnQgYSBTeW50YXhFcnJvciBpZiAiZnJvbSAuLi4gaW1wb3J0ICoiIG9jY3VycwogIGluIGEgZnVuY3Rpb24gb3IgY2xhc3Mgc2NvcGUuICBUaGUgbGFuZ3VhZ2UgcmVmZXJlbmNlIGhhcyBkb2N1bWVudGVkCiAgdGhhdCB0aGlzIGNhc2UgaXMgaWxsZWdhbCwgYnV0IHRoZSBjb21waWxlciBuZXZlciBjaGVja2VkIGZvciBpdC4KICBUaGUgcmVjZW50IGludHJvZHVjdGlvbiBvZiBuZXN0ZWQgc2NvcGUgbWFrZXMgdGhlIG1lYW5pbmcgb2YgdGhpcwogIGZvcm0gb2YgbmFtZSBiaW5kaW5nIGFtYmlndW91cy4gIEluIGEgZnV0dXJlIHJlbGVhc2UsIHRoZSBjb21waWxlcgogIG1heSBhbGxvdyB0aGlzIGZvcm0gd2hlbiB0aGVyZSBpcyBubyBwb3NzaWJpbGl0eSBvZiBhbWJpZ3VpdHkuCgotIHJlcHIoc3RyaW5nKSBpcyBlYXNpZXIgdG8gcmVhZCwgbm93IHVzaW5nIGhleCBlc2NhcGVzIGluc3RlYWQgb2Ygb2N0YWwsCiAgYW5kIHVzaW5nIFx0LCBcbiBhbmQgXHIgaW5zdGVhZCBvZiBcMDExLCBcMDEyIGFuZCBcMDE1IChyZXNwZWN0aXZlbHkpOgoKICA+Pj4gIlx0ZXhhbXBsZSBcclxuIiArIGNocigwKSArIGNocigyNTUpCiAgJ1x0ZXhhbXBsZSBcclxuXHgwMFx4ZmYnICAgICAgICAgIyBpbiAyLjEKICAnXDAxMWV4YW1wbGUgXDAxNVwwMTJcMDAwXDM3NycgICAjIGluIDIuMAoKLSBGdW5jdGlvbnMgYXJlIG5vdyBjb21wYXJlZCBhbmQgaGFzaGVkIGJ5IGlkZW50aXR5LCBub3QgYnkgdmFsdWUsIHNpbmNlCiAgdGhlIGZ1bmNfY29kZSBhdHRyaWJ1dGUgaXMgd3JpdGFibGUuCgotIFdlYWsgcmVmZXJlbmNlcyAoUEVQIDIwNSkgaGF2ZSBiZWVuIGFkZGVkLiAgVGhpcyBpbnZvbHZlcyBhIGZldwogIGNoYW5nZXMgaW4gdGhlIGNvcmUsIGFuIGV4dGVuc2lvbiBtb2R1bGUgKF93ZWFrcmVmKSwgYW5kIGEgUHl0aG9uCiAgbW9kdWxlICh3ZWFrcmVmKS4gIFRoZSB3ZWFrcmVmIG1vZHVsZSBpcyB0aGUgcHVibGljIGludGVyZmFjZS4gIEl0CiAgaW5jbHVkZXMgc3VwcG9ydCBmb3IgImV4cGxpY2l0IiB3ZWFrIHJlZmVyZW5jZXMsIHByb3h5IG9iamVjdHMsIGFuZAogIG1hcHBpbmdzIHdpdGggd2Vha2x5IGhlbGQgdmFsdWVzLgoKLSBBICdjb250aW51ZScgc3RhdGVtZW50IGNhbiBub3cgYXBwZWFyIGluIGEgdHJ5IGJsb2NrIHdpdGhpbiB0aGUgYm9keQogIG9mIGEgbG9vcC4gIEl0IGlzIHN0aWxsIG5vdCBwb3NzaWJsZSB0byB1c2UgY29udGludWUgaW4gYSBmaW5hbGx5CiAgY2xhdXNlLgoKU3RhbmRhcmQgbGlicmFyeQoKLSBtYWlsYm94LnB5IG5vdyBoYXMgYSBuZXcgY2xhc3MsIFBvcnRhYmxlVW5peE1haWxib3ggd2hpY2ggaXMKICBpZGVudGljYWwgdG8gVW5peE1haWxib3ggYnV0IHVzZXMgYSBtb3JlIHBvcnRhYmxlIHNjaGVtZSBmb3IKICBkZXRlcm1pbmluZyBGcm9tXyBzZXBhcmF0b3JzLiAgQWxzbywgdGhlIGNvbnN0cnVjdG9ycyBmb3IgYWxsIHRoZQogIGNsYXNzZXMgaW4gdGhpcyBtb2R1bGUgaGF2ZSBhIG5ldyBvcHRpb25hbCBgZmFjdG9yeScgYXJndW1lbnQsIHdoaWNoCiAgaXMgYSBjYWxsYWJsZSB1c2VkIHdoZW4gbmV3IG1lc3NhZ2UgY2xhc3NlcyBtdXN0IGJlIGluc3RhbnRpYXRlZCBieQogIHRoZSBuZXh0KCkgbWV0aG9kLgoKLSByYW5kb20ucHkgaXMgbm93IHNlbGYtY29udGFpbmVkLCBhbmQgb2ZmZXJzIGFsbCB0aGUgZnVuY3Rpb25hbGl0eSBvZgogIHRoZSBub3ctZGVwcmVjYXRlZCB3aHJhbmRvbS5weS4gIFNlZSB0aGUgZG9jcyBmb3IgZGV0YWlscy4gIHJhbmRvbS5weQogIGFsc28gc3VwcG9ydHMgbmV3IGZ1bmN0aW9ucyBnZXRzdGF0ZSgpIGFuZCBzZXRzdGF0ZSgpLCBmb3Igc2F2aW5nCiAgYW5kIHJlc3RvcmluZyB0aGUgaW50ZXJuYWwgc3RhdGUgb2YgdGhlIGdlbmVyYXRvcjsgYW5kIGp1bXBhaGVhZChuKSwKICBmb3IgcXVpY2tseSBmb3JjaW5nIHRoZSBpbnRlcm5hbCBzdGF0ZSB0byBiZSB0aGUgc2FtZSBhcyBpZiBuIGNhbGxzIHRvCiAgcmFuZG9tKCkgaGFkIGJlZW4gbWFkZS4gIFRoZSBsYXR0ZXIgaXMgcGFydGljdWxhcmx5IHVzZWZ1bCBmb3IgbXVsdGktCiAgdGhyZWFkZWQgcHJvZ3JhbXMsIGNyZWF0aW5nIG9uZSBpbnN0YW5jZSBvZiB0aGUgcmFuZG9tLlJhbmRvbSgpIGNsYXNzIGZvcgogIGVhY2ggdGhyZWFkLCB0aGVuIHVzaW5nIC5qdW1wYWhlYWQoKSB0byBmb3JjZSBlYWNoIGluc3RhbmNlIHRvIHVzZSBhCiAgbm9uLW92ZXJsYXBwaW5nIHNlZ21lbnQgb2YgdGhlIGZ1bGwgcGVyaW9kLgoKLSByYW5kb20ucHkncyBzZWVkKCkgZnVuY3Rpb24gaXMgbmV3LiAgRm9yIGJpdC1mb3ItYml0IGNvbXBhdGliaWxpdHkgd2l0aAogIHByaW9yIHJlbGVhc2VzLCB1c2UgdGhlIHdoc2VlZCBmdW5jdGlvbiBpbnN0ZWFkLiAgVGhlIG5ldyBzZWVkIGZ1bmN0aW9uCiAgYWRkcmVzc2VzIHR3byBwcm9ibGVtczogICgxKSBUaGUgb2xkIGZ1bmN0aW9uIGNvdWxkbid0IHByb2R1Y2UgbW9yZSB0aGFuCiAgYWJvdXQgMioqMjQgZGlzdGluY3QgaW50ZXJuYWwgc3RhdGVzOyB0aGUgbmV3IG9uZSBhYm91dCAyKio0NSAodGhlIGJlc3QKICB0aGF0IGNhbiBiZSBkb25lIGluIHRoZSBXaWNobWFubi1IaWxsIGdlbmVyYXRvcikuICAoMikgVGhlIG9sZCBmdW5jdGlvbgogIHNvbWV0aW1lcyBwcm9kdWNlZCBpZGVudGljYWwgaW50ZXJuYWwgc3RhdGVzIHdoZW4gcGFzc2VkIGRpc3RpbmN0CiAgaW50ZWdlcnMsIGFuZCB0aGVyZSB3YXMgbm8gc2ltcGxlIHdheSB0byBwcmVkaWN0IHdoZW4gdGhhdCB3b3VsZCBoYXBwZW47CiAgdGhlIG5ldyBvbmUgZ3VhcmFudGVlcyB0byBwcm9kdWNlIGRpc3RpbmN0IGludGVybmFsIHN0YXRlcyBmb3IgYWxsCiAgYXJndW1lbnRzIGluIFswLCAyNzgxNDQzMTQ4NjU3NkwpLgoKLSBUaGUgc29ja2V0IG1vZHVsZSBub3cgc3VwcG9ydHMgcmF3IHBhY2tldHMgb24gTGludXguICBUaGUgc29ja2V0CiAgZmFtaWx5IGlzIEFGX1BBQ0tFVC4KCi0gdGVzdF9jYXBpLnB5IGlzIGEgc3RhcnQgYXQgcnVubmluZyB0ZXN0cyBvZiB0aGUgUHl0aG9uIEMgQVBJLiAgVGhlIHRlc3RzCiAgYXJlIGltcGxlbWVudGVkIGJ5IHRoZSBuZXcgTW9kdWxlcy9fdGVzdG1vZHVsZS5jLgoKLSBBIG5ldyBleHRlbnNpb24gbW9kdWxlLCBfc3ltdGFibGUsIHByb3ZpZGVzIHByb3Zpc2lvbmFsIGFjY2VzcyB0byB0aGUKICBpbnRlcm5hbCBzeW1ib2wgdGFibGUgdXNlZCBieSB0aGUgUHl0aG9uIGNvbXBpbGVyLiAgQSBoaWdoZXItbGV2ZWwKICBpbnRlcmZhY2Ugd2lsbCBiZSBhZGRlZCBvbiB0b3Agb2YgX3N5bXRhYmxlIGluIGEgZnV0dXJlIHJlbGVhc2UuCgotIFJlbW92ZWQgdGhlIG9ic29sZXRlIHNvdW5kZXggbW9kdWxlLgoKLSB4bWwuZG9tLm1pbmlkb20gbm93IHVzZXMgdGhlIHN0YW5kYXJkIERPTSBleGNlcHRpb25zLiBOb2RlIHN1cHBvcnRzCiAgdGhlIGlzU2FtZU5vZGUgbWV0aG9kOyBOYW1lZE5vZGVNYXAgdGhlIGdldCBtZXRob2QuCgotIHhtbC5zYXguZXhwYXRyZWFkZXIgc3VwcG9ydHMgdGhlIGxleGljYWwgaGFuZGxlciBwcm9wZXJ0eTsgaXQKICBnZW5lcmF0ZXMgY29tbWVudCwgc3RhcnRDREFUQSwgYW5kIGVuZENEQVRBIGV2ZW50cy4KCldpbmRvd3MgY2hhbmdlcwoKLSBCdWlsZCBwcm9jZWR1cmU6ICB0aGUgemxpYiBwcm9qZWN0IGlzIGJ1aWx0IGluIGEgZGlmZmVyZW50IHdheSB0aGF0CiAgZW5zdXJlcyB0aGUgemxpYiBoZWFkZXIgZmlsZXMgdXNlZCBjYW4gbm8gbG9uZ2VyIGdldCBvdXQgb2Ygc3luY2ggd2l0aAogIHRoZSB6bGliIGJpbmFyeSB1c2VkLiAgU2VlIFBDYnVpbGRccmVhZG1lLnR4dCBmb3IgZGV0YWlscy4gIFlvdXIgb2xkCiAgemxpYi1yZWxhdGVkIGRpcmVjdG9yaWVzIGNhbiBiZSBkZWxldGVkOyB5b3UnbGwgbmVlZCB0byBkb3dubG9hZCBmcmVzaAogIHNvdXJjZSBmb3IgemxpYiBhbmQgdW5wYWNrIGl0IGludG8gYSBuZXcgZGlyZWN0b3J5LgoKLSBCdWlsZDogIE5ldyBzdWJwcm9qZWN0IF90ZXN0IGZvciB0aGUgYmVuZWZpdCBvZiB0ZXN0X2NhcGkucHkgKHNlZSBhYm92ZSkuCgotIEJ1aWxkOiAgTmV3IHN1YnByb2plY3QgX3N5bXRhYmxlLCBmb3IgbmV3IERMTCBfc3ltdGFibGUucHlkIChhIG5hc2NlbnQKICBpbnRlcmZhY2UgdG8gc29tZSBQeXRob24gY29tcGlsZXIgaW50ZXJuYWxzKS4KCi0gQnVpbGQ6ICBTdWJwcm9qZWN0IHVjbmhhc2ggaXMgZ29uZSwgc2luY2UgdGhlIGNvZGUgd2FzIGZvbGRlZCBpbnRvIHRoZQogIHVuaWNvZGVkYXRhIHN1YnByb2plY3QuCgpXaGF0J3MgTmV3IGluIFB5dGhvbiAyLjEgYWxwaGEgMT8KPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpDb3JlIGxhbmd1YWdlLCBidWlsdGlucywgYW5kIGludGVycHJldGVyCgotIFRoZXJlIGlzIGEgbmV3IFVuaWNvZGUgY29tcGFuaW9uIHRvIHRoZSBQeU9iamVjdF9TdHIoKSBBUEkKICBjYWxsZWQgUHlPYmplY3RfVW5pY29kZSgpLiBJdCBiZWhhdmVzIGluIHRoZSBzYW1lIHdheSBhcyB0aGUKICBmb3JtZXIsIGJ1dCBhc3N1cmVzIHRoYXQgdGhlIHJldHVybmVkIHZhbHVlIGlzIGFuIFVuaWNvZGUgb2JqZWN0CiAgKGFwcGx5aW5nIHRoZSB1c3VhbCBjb2VyY2lvbiBpZiBuZWNlc3NhcnkpLgoKLSBUaGUgY29tcGFyaXNvbiBvcGVyYXRvcnMgc3VwcG9ydCAicmljaCBjb21wYXJpc29uIG92ZXJsb2FkaW5nIiAoUEVQCiAgMjA3KS4gIEMgZXh0ZW5zaW9uIHR5cGVzIGNhbiBwcm92aWRlIGEgcmljaCBjb21wYXJpc29uIGZ1bmN0aW9uIGluCiAgdGhlIG5ldyB0cF9yaWNoY29tcGFyZSBzbG90IGluIHRoZSB0eXBlIG9iamVjdC4gIFRoZSBjbXAoKSBmdW5jdGlvbgogIGFuZCB0aGUgQyBmdW5jdGlvbiBQeU9iamVjdF9Db21wYXJlKCkgZmlyc3QgdHJ5IHRoZSBuZXcgcmljaAogIGNvbXBhcmlzb24gb3BlcmF0b3JzIGJlZm9yZSB0cnlpbmcgdGhlIG9sZCAzLXdheSBjb21wYXJpc29uLiAgVGhlcmUKICBpcyBhbHNvIGEgbmV3IEMgQVBJIFB5T2JqZWN0X1JpY2hDb21wYXJlKCkgKHdoaWNoIGFsc28gZmFsbHMgYmFjayBvbgogIHRoZSBvbGQgMy13YXkgY29tcGFyaXNvbiwgYnV0IGRvZXMgbm90IGNvbnN0cmFpbiB0aGUgb3V0Y29tZSBvZiB0aGUKICByaWNoIGNvbXBhcmlzb24gdG8gYSBCb29sZWFuIHJlc3VsdCkuCgogIFRoZSByaWNoIGNvbXBhcmlzb24gZnVuY3Rpb24gdGFrZXMgdHdvIG9iamVjdHMgKGF0IGxlYXN0IG9uZSBvZgogIHdoaWNoIGlzIGd1YXJhbnRlZWQgdG8gaGF2ZSB0aGUgdHlwZSB0aGF0IHByb3ZpZGVkIHRoZSBmdW5jdGlvbikgYW5kCiAgYW4gaW50ZWdlciBpbmRpY2F0aW5nIHRoZSBvcGNvZGUsIHdoaWNoIGNhbiBiZSBQeV9MVCwgUHlfTEUsIFB5X0VRLAogIFB5X05FLCBQeV9HVCwgUHlfR0UgKGZvciA8LCA8PSwgPT0sICE9LCA+LCA+PSksIGFuZCByZXR1cm5zIGEgUHl0aG9uCiAgb2JqZWN0LCB3aGljaCBtYXkgYmUgTm90SW1wbGVtZW50ZWQgKGluIHdoaWNoIGNhc2UgdGhlIHRwX2NvbXBhcmUKICBzbG90IGZ1bmN0aW9uIGlzIHVzZWQgYXMgYSBmYWxsYmFjaywgaWYgZGVmaW5lZCkuCgogIENsYXNzZXMgY2FuIG92ZXJsb2FkIGluZGl2aWR1YWwgY29tcGFyaXNvbiBvcGVyYXRvcnMgYnkgZGVmaW5pbmcgb25lCiAgb3IgbW9yZSBvZiB0aGUgbWV0aG9kc19fbHRfXywgX19sZV9fLCBfX2VxX18sIF9fbmVfXywgX19ndF9fLAogIF9fZ2VfXy4gIFRoZXJlIGFyZSBubyBleHBsaWNpdCAicmVmbGVjdGVkIGFyZ3VtZW50IiB2ZXJzaW9ucyBvZgogIHRoZXNlOyBpbnN0ZWFkLCBfX2x0X18gYW5kIF9fZ3RfXyBhcmUgZWFjaCBvdGhlcidzIHJlZmxlY3Rpb24sCiAgbGlrZXdpc2UgZm9yX19sZV9fIGFuZCBfX2dlX187IF9fZXFfXyBhbmQgX19uZV9fIGFyZSB0aGVpciBvd24KICByZWZsZWN0aW9uIChzaW1pbGFyIGF0IHRoZSBDIGxldmVsKS4gIE5vIG90aGVyIGltcGxpY2F0aW9ucyBhcmUKICBtYWRlOyBpbiBwYXJ0aWN1bGFyLCBQeXRob24gZG9lcyBub3QgYXNzdW1lIHRoYXQgPT0gaXMgdGhlIEJvb2xlYW4KICBpbnZlcnNlIG9mICE9LCBvciB0aGF0IDwgaXMgdGhlIEJvb2xlYW4gaW52ZXJzZSBvZiA+PS4gIFRoaXMgbWFrZXMKICBpdCBwb3NzaWJsZSB0byBkZWZpbmUgdHlwZXMgd2l0aCBwYXJ0aWFsIG9yZGVyaW5ncy4KCiAgQ2xhc3NlcyBvciB0eXBlcyB0aGF0IHdhbnQgdG8gaW1wbGVtZW50IChpbillcXVhbGl0eSB0ZXN0cyBidXQgbm90CiAgdGhlIG9yZGVyaW5nIG9wZXJhdG9ycyAoaS5lLiB1bm9yZGVyZWQgdHlwZXMpIHNob3VsZCBpbXBsZW1lbnQgPT0KICBhbmQgIT0sIGFuZCByYWlzZSBhbiBlcnJvciBmb3IgdGhlIG9yZGVyaW5nIG9wZXJhdG9ycy4KCiAgSXQgaXMgcG9zc2libGUgdG8gZGVmaW5lIHR5cGVzIHdob3NlIHJpY2ggY29tcGFyaXNvbiByZXN1bHRzIGFyZSBub3QKICBCb29sZWFuOyBlLmcuIGEgbWF0cml4IHR5cGUgbWlnaHQgd2FudCB0byByZXR1cm4gYSBtYXRyaXggb2YgYml0cwogIGZvciBBIDwgQiwgZ2l2aW5nIGVsZW1lbnR3aXNlIGNvbXBhcmlzb25zLiAgU3VjaCB0eXBlcyBzaG91bGQgZW5zdXJlCiAgdGhhdCBhbnkgaW50ZXJwcmV0YXRpb24gb2YgdGhlaXIgdmFsdWUgaW4gYSBCb29sZWFuIGNvbnRleHQgcmFpc2VzCiAgYW4gZXhjZXB0aW9uLCBlLmcuIGJ5IGRlZmluaW5nIF9fbm9uemVyb19fIChvciB0aGUgdHBfbm9uemVybyBzbG90CiAgYXQgdGhlIEMgbGV2ZWwpIHRvIGFsd2F5cyByYWlzZSBhbiBleGNlcHRpb24uCgotIENvbXBsZXggbnVtYmVycyB1c2UgcmljaCBjb21wYXJpc29ucyB0byBkZWZpbmUgPT0gYW5kICE9IGJ1dCByYWlzZQogIGFuIGV4Y2VwdGlvbiBmb3IgPCwgPD0sID4gYW5kID49LiAgVW5mb3J0dW5hdGVseSwgdGhpcyBhbHNvIG1lYW5zCiAgdGhhdCBjbXAoKSBvZiB0d28gY29tcGxleCBudW1iZXJzIHJhaXNlcyBhbiBleGNlcHRpb24gd2hlbiB0aGUgdHdvCiAgbnVtYmVycyBkaWZmZXIuICBTaW5jZSBpdCBpcyBub3QgbWF0aGVtYXRpY2FsbHkgbWVhbmluZ2Z1bCB0byBjb21wYXJlCiAgY29tcGxleCBudW1iZXJzIGV4Y2VwdCBmb3IgZXF1YWxpdHksIEkgaG9wZSB0aGF0IHRoaXMgZG9lc24ndCBicmVhawogIHRvbyBtdWNoIGNvZGUuCgotIFRoZSBvdXRjb21lIG9mIGNvbXBhcmluZyBub24tbnVtZXJpYyBvYmplY3RzIG9mIGRpZmZlcmVudCB0eXBlcyBpcwogIG5vdCBkZWZpbmVkIGJ5IHRoZSBsYW5ndWFnZSwgb3RoZXIgdGhhbiB0aGF0IGl0J3MgYXJiaXRyYXJ5IGJ1dAogIGNvbnNpc3RlbnQgKHNlZSB0aGUgUmVmZXJlbmNlIE1hbnVhbCkuICBBbiBpbXBsZW1lbnRhdGlvbiBkZXRhaWwgY2hhbmdlZAogIGluIDIuMWExIHN1Y2ggdGhhdCBOb25lIG5vdyBjb21wYXJlcyBsZXNzIHRoYW4gYW55IG90aGVyIG9iamVjdC4gIENvZGUKICByZWx5aW5nIG9uIHRoaXMgbmV3IGJlaGF2aW9yIChsaWtlIGNvZGUgdGhhdCByZWxpZWQgb24gdGhlIHByZXZpb3VzCiAgYmVoYXZpb3IpIGRvZXMgc28gYXQgaXRzIG93biByaXNrLgoKLSBGdW5jdGlvbnMgYW5kIG1ldGhvZHMgbm93IHN1cHBvcnQgZ2V0dGluZyBhbmQgc2V0dGluZyBhcmJpdHJhcmlseQogIG5hbWVkIGF0dHJpYnV0ZXMgKFBFUCAyMzIpLiAgRnVuY3Rpb25zIGhhdmUgYSBuZXcgX19kaWN0X18KICAoYS5rLmEuIGZ1bmNfZGljdCkgd2hpY2ggaG9sZCB0aGUgZnVuY3Rpb24gYXR0cmlidXRlcy4gIE1ldGhvZHMgZ2V0CiAgYW5kIHNldCBhdHRyaWJ1dGVzIG9uIHRoZWlyIHVuZGVybHlpbmcgaW1fZnVuYy4gIEl0IGlzIGEgVHlwZUVycm9yCiAgdG8gc2V0IGFuIGF0dHJpYnV0ZSBvbiBhIGJvdW5kIG1ldGhvZC4KCi0gVGhlIHhyYW5nZSgpIG9iamVjdCBpbXBsZW1lbnRhdGlvbiBoYXMgYmVlbiBpbXByb3ZlZCBzbyB0aGF0CiAgeHJhbmdlKHN5cy5tYXhpbnQpIGNhbiBiZSB1c2VkIG9uIDY0LWJpdCBwbGF0Zm9ybXMuICBUaGVyZSdzIHN0aWxsIGEKICBsaW1pdGF0aW9uIHRoYXQgaW4gdGhpcyBjYXNlIGxlbih4cmFuZ2Uoc3lzLm1heGludCkpIGNhbid0IGJlCiAgY2FsY3VsYXRlZCwgYnV0IHRoZSBjb21tb24gaWRpb20gImZvciBpIGluIHhyYW5nZShzeXMubWF4aW50KSIgd2lsbAogIHdvcmsgZmluZSBhcyBsb25nIGFzIHRoZSBpbmRleCBpIGRvZXNuJ3QgYWN0dWFsbHkgcmVhY2ggMioqMzEuCiAgKFB5dGhvbiB1c2VzIHJlZ3VsYXIgaW50cyBmb3Igc2VxdWVuY2UgYW5kIHN0cmluZyBpbmRpY2VzOyBmaXhpbmcKICB0aGF0IGlzIG11Y2ggbW9yZSB3b3JrLikKCi0gVHdvIGNoYW5nZXMgdG8gZnJvbS4uLmltcG9ydDoKCiAgMSkgImZyb20gTSBpbXBvcnQgWCIgbm93IHdvcmtzIGV2ZW4gaWYgKGFmdGVyIGxvYWRpbmcgbW9kdWxlIE0pCiAgICAgc3lzLm1vZHVsZXNbJ00nXSBpcyBub3QgYSByZWFsIG1vZHVsZTsgaXQncyBiYXNpY2FsbHkgYSBnZXRhdHRyKCkKICAgICBvcGVyYXRpb24gd2l0aCBBdHRyaWJ1dGVFcnJvciBleGNlcHRpb25zIGNoYW5nZWQgaW50byBJbXBvcnRFcnJvci4KCiAgMikgImZyb20gTSBpbXBvcnQgKiIgbm93IGxvb2tzIGZvciBNLl9fYWxsX18gdG8gZGVjaWRlIHdoaWNoIG5hbWVzIHRvCiAgICAgaW1wb3J0OyBpZiBNLl9fYWxsX18gZG9lc24ndCBleGlzdCwgaXQgdXNlcyBNLl9fZGljdF9fLmtleXMoKSBidXQKICAgICBmaWx0ZXJzIG91dCBuYW1lcyBzdGFydGluZyB3aXRoICdfJyBhcyBiZWZvcmUuICBXaGV0aGVyIG9yIG5vdAogICAgIF9fYWxsX18gZXhpc3RzLCB0aGVyZSdzIG5vIHJlc3RyaWN0aW9uIG9uIHRoZSB0eXBlIG9mIE0uCgotIEZpbGUgb2JqZWN0cyBoYXZlIGEgbmV3IG1ldGhvZCwgeHJlYWRsaW5lcygpLiAgVGhpcyBpcyB0aGUgZmFzdGVzdAogIHdheSB0byBpdGVyYXRlIG92ZXIgYWxsIGxpbmVzIGluIGEgZmlsZToKCiAgZm9yIGxpbmUgaW4gZmlsZS54cmVhZGxpbmVzKCk6CiAgICAgIC4uLmRvIHNvbWV0aGluZyB0byBsaW5lLi4uCgogIFNlZSB0aGUgeHJlYWRsaW5lcyBtb2R1bGUgKG1lbnRpb25lZCBiZWxvdykgZm9yIGhvdyB0byBkbyB0aGlzIGZvcgogIG90aGVyIGZpbGUtbGlrZSBvYmplY3RzLgoKLSBFdmVuIGlmIHlvdSBkb24ndCB1c2UgZmlsZS54cmVhZGxpbmVzKCksIHlvdSBtYXkgZXhwZWN0IGEgc3BlZWR1cCBvbgogIGxpbmUtYnktbGluZSBpbnB1dC4gIFRoZSBmaWxlLnJlYWRsaW5lKCkgbWV0aG9kIGhhcyBiZWVuIG9wdGltaXplZAogIHF1aXRlIGEgYml0IGluIHBsYXRmb3JtLXNwZWNpZmljIHdheXM6ICBvbiBzeXN0ZW1zIChsaWtlIExpbnV4KSB0aGF0CiAgc3VwcG9ydCBmbG9ja2ZpbGUoKSwgZ2V0Y191bmxvY2tlZCgpLCBhbmQgZnVubG9ja2ZpbGUoKSwgdGhvc2UgYXJlCiAgdXNlZCBieSBkZWZhdWx0LiAgT24gc3lzdGVtcyAobGlrZSBXaW5kb3dzKSB3aXRob3V0IGdldGNfdW5sb2NrZWQoKSwKICBhIGNvbXBsaWNhdGVkIChidXQgc3RpbGwgdGhyZWFkLXNhZmUpIG1ldGhvZCB1c2luZyBmZ2V0cygpIGlzIHVzZWQgYnkKICBkZWZhdWx0LgoKICBZb3UgY2FuIGZvcmNlIHVzZSBvZiB0aGUgZmdldHMoKSBtZXRob2QgYnkgI2RlZmluZSdpbmcKICBVU0VfRkdFVFNfSU5fR0VUTElORSBhdCBidWlsZCB0aW1lIChpdCBtYXkgYmUgZmFzdGVyIHRoYW4KICBnZXRjX3VubG9ja2VkKCkpLgoKICBZb3UgY2FuIGZvcmNlIGZnZXRzKCkgbm90IHRvIGJlIHVzZWQgYnkgI2RlZmluZSdpbmcKICBET05UX1VTRV9GR0VUU19JTl9HRVRMSU5FICh0aGlzIGlzIHRoZSBmaXJzdCB0aGluZyB0byB0cnkgaWYgc3RkIHRlc3QKICB0ZXN0X2J1ZmlvLnB5IGZhaWxzIC0tIGFuZCBsZXQgdXMga25vdyBpZiBpdCBkb2VzISkuCgotIEluIGFkZGl0aW9uLCB0aGUgZmlsZWlucHV0IG1vZHVsZSwgd2hpbGUgc3RpbGwgc2xvd2VyIHRoYW4gdGhlIG90aGVyCiAgbWV0aG9kcyBvbiBtb3N0IHBsYXRmb3JtcywgaGFzIGJlZW4gc3BlZCB1cCB0b28sIGJ5IHVzaW5nCiAgZmlsZS5yZWFkbGluZXMoc2l6ZWhpbnQpLgoKLSBTdXBwb3J0IGZvciBydW4tdGltZSB3YXJuaW5ncyBoYXMgYmVlbiBhZGRlZCwgaW5jbHVkaW5nIGEgbmV3CiAgY29tbWFuZCBsaW5lIG9wdGlvbiAoLVcpIHRvIHNwZWNpZnkgdGhlIGRpc3Bvc2l0aW9uIG9mIHdhcm5pbmdzLgogIFNlZSB0aGUgZGVzY3JpcHRpb24gb2YgdGhlIHdhcm5pbmdzIG1vZHVsZSBiZWxvdy4KCi0gRXh0ZW5zaXZlIGNoYW5nZXMgaGF2ZSBiZWVuIG1hZGUgdG8gdGhlIGNvZXJjaW9uIGNvZGUuICBUaGlzIG1vc3RseQogIGFmZmVjdHMgZXh0ZW5zaW9uIG1vZHVsZXMgKHdoaWNoIGNhbiBub3cgaW1wbGVtZW50IG1peGVkLXR5cGUKICBudW1lcmljYWwgb3BlcmF0b3JzIHdpdGhvdXQgaGF2aW5nIHRvIHVzZSBjb2VyY2lvbiksIGJ1dAogIG9jY2FzaW9uYWxseSwgaW4gYm91bmRhcnkgY2FzZXMgdGhlIGNvZXJjaW9uIHNlbWFudGljcyBoYXZlIGNoYW5nZWQKICBzdWJ0bHkuICBTaW5jZSB0aGlzIHdhcyBhIHRlcnJpYmxlIGdyYXkgYXJlYSBvZiB0aGUgbGFuZ3VhZ2UsIHRoaXMKICBpcyBjb25zaWRlcmVkIGFuIGltcHJvdmVtZW50LiAgQWxzbyBub3RlIHRoYXQgX19yY21wX18gaXMgbm8gbG9uZ2VyCiAgc3VwcG9ydGVkIC0tIGluc3RlYWQgb2YgY2FsbGluZyBfX3JjbXBfXywgX19jbXBfXyBpcyBjYWxsZWQgd2l0aAogIHJlZmxlY3RlZCBhcmd1bWVudHMuCgotIEluIGNvbm5lY3Rpb24gd2l0aCB0aGUgY29lcmNpb24gY2hhbmdlcywgYSBuZXcgYnVpbHQtaW4gc2luZ2xldG9uCiAgb2JqZWN0LCBOb3RJbXBsZW1lbnRlZCBpcyBkZWZpbmVkLiAgVGhpcyBjYW4gYmUgcmV0dXJuZWQgZm9yCiAgb3BlcmF0aW9ucyB0aGF0IHdpc2ggdG8gaW5kaWNhdGUgdGhleSBhcmUgbm90IGltcGxlbWVudGVkIGZvciBhCiAgcGFydGljdWxhciBjb21iaW5hdGlvbiBvZiBhcmd1bWVudHMuICBGcm9tIEMsIHRoaXMgaXMKICBQeV9Ob3RJbXBsZW1lbnRlZC4KCi0gVGhlIGludGVycHJldGVyIGFjY2VwdHMgbm93IGJ5dGVjb2RlIGZpbGVzIG9uIHRoZSBjb21tYW5kIGxpbmUgZXZlbgogIGlmIHRoZXkgZG8gbm90IGhhdmUgYSAucHljIG9yIC5weW8gZXh0ZW5zaW9uLiBPbiBMaW51eCwgYWZ0ZXIgZXhlY3V0aW5nCgppbXBvcnQgaW1wLHN5cyxzdHJpbmcKbWFnaWMgPSBzdHJpbmcuam9pbihbIlxceCUuMngiICUgb3JkKGMpIGZvciBjIGluIGltcC5nZXRfbWFnaWMoKV0sIiIpCnJlZyA9ICc6cHljOk06OiVzOjolczonICUgKG1hZ2ljLCBzeXMuZXhlY3V0YWJsZSkKb3BlbigiL3Byb2Mvc3lzL2ZzL2JpbmZtdF9taXNjL3JlZ2lzdGVyIiwid2IiKS53cml0ZShyZWcpCgogIGFueSBieXRlIGNvZGUgZmlsZSBjYW4gYmUgdXNlZCBhcyBhbiBleGVjdXRhYmxlIChpLmUuIGFzIGFuIGFyZ3VtZW50CiAgdG8gZXhlY3ZlKDIpKS4KCi0gJVt4WG9dIGZvcm1hdHMgb2YgbmVnYXRpdmUgUHl0aG9uIGxvbmdzIG5vdyBwcm9kdWNlIGEgc2lnbgogIGNoYXJhY3Rlci4gIEluIDEuNiBhbmQgZWFybGllciwgdGhleSBuZXZlciBwcm9kdWNlZCBhIHNpZ24sCiAgYW5kIHJhaXNlZCBhbiBlcnJvciBpZiB0aGUgdmFsdWUgb2YgdGhlIGxvbmcgd2FzIHRvbyBsYXJnZQogIHRvIGZpdCBpbiBhIFB5dGhvbiBpbnQuICBJbiAyLjAsIHRoZXkgcHJvZHVjZWQgYSBzaWduIGlmIGFuZAogIG9ubHkgaWYgdG9vIGxhcmdlIHRvIGZpdCBpbiBhbiBpbnQuICBUaGlzIHdhcyBpbmNvbnNpc3RlbnQKICBhY3Jvc3MgcGxhdGZvcm1zIChiZWNhdXNlIHRoZSBzaXplIG9mIGFuIGludCB2YXJpZXMgYWNyb3NzCiAgcGxhdGZvcm1zKSwgYW5kIGluY29uc2lzdGVudCB3aXRoIGhleCgpIGFuZCBvY3QoKS4gIEV4YW1wbGU6CgogID4+PiAiJXgiICUgLTB4NDJMCiAgJy00MicgICAgICAjIGluIDIuMQogICdmZmZmZmZiZScgIyBpbiAyLjAgYW5kIGJlZm9yZSwgb24gMzItYml0IG1hY2hpbmVzCiAgPj4+IGhleCgtMHg0MkwpCiAgJy0weDQyTCcgICAjIGluIGFsbCB2ZXJzaW9ucyBvZiBQeXRob24KCiAgVGhlIGJlaGF2aW9yIG9mICVkIGZvcm1hdHMgZm9yIG5lZ2F0aXZlIFB5dGhvbiBsb25ncyByZW1haW5zCiAgdGhlIHNhbWUgYXMgaW4gMi4wIChhbHRob3VnaCBpbiAxLjYgYW5kIGJlZm9yZSwgdGhleSByYWlzZWQKICBhbiBlcnJvciBpZiB0aGUgbG9uZyBkaWRuJ3QgZml0IGluIGEgUHl0aG9uIGludCkuCgogICV1IGZvcm1hdHMgZG9uJ3QgbWFrZSBzZW5zZSBmb3IgUHl0aG9uIGxvbmdzLCBidXQgYXJlIGFsbG93ZWQKICBhbmQgdHJlYXRlZCB0aGUgc2FtZSBhcyAlZCBpbiAyLjEuICBJbiAyLjAsIGEgbmVnYXRpdmUgbG9uZwogIGZvcm1hdHRlZCB2aWEgJXUgcHJvZHVjZWQgYSBzaWduIGlmIGFuZCBvbmx5IGlmIHRvbyBsYXJnZSB0bwogIGZpdCBpbiBhbiBpbnQuICBJbiAxLjYgYW5kIGVhcmxpZXIsIGEgbmVnYXRpdmUgbG9uZyBmb3JtYXR0ZWQKICB2aWEgJXUgcmFpc2VkIGFuIGVycm9yIGlmIGl0IHdhcyB0b28gYmlnIHRvIGZpdCBpbiBhbiBpbnQuCgotIERpY3Rpb25hcnkgb2JqZWN0cyBoYXZlIGFuIG9kZCBuZXcgbWV0aG9kLCBwb3BpdGVtKCkuICBUaGlzIHJlbW92ZXMKICBhbiBhcmJpdHJhcnkgaXRlbSBmcm9tIHRoZSBkaWN0aW9uYXJ5IGFuZCByZXR1cm5zIGl0IChpbiB0aGUgZm9ybSBvZgogIGEgKGtleSwgdmFsdWUpIHBhaXIpLiAgVGhpcyBjYW4gYmUgdXNlZnVsIGZvciBhbGdvcml0aG1zIHRoYXQgdXNlIGEKICBkaWN0aW9uYXJ5IGFzIGEgYmFnIG9mICJ0byBkbyIgaXRlbXMgYW5kIHJlcGVhdGVkbHkgbmVlZCB0byBwaWNrIG9uZQogIGl0ZW0uICBTdWNoIGFsZ29yaXRobXMgbm9ybWFsbHkgZW5kIHVwIHJ1bm5pbmcgaW4gcXVhZHJhdGljIHRpbWU7CiAgdXNpbmcgcG9waXRlbSgpIHRoZXkgY2FuIHVzdWFsbHkgYmUgbWFkZSB0byBydW4gaW4gbGluZWFyIHRpbWUuCgpTdGFuZGFyZCBsaWJyYXJ5CgotIEluIHRoZSB0aW1lIG1vZHVsZSwgdGhlIHRpbWUgYXJndW1lbnQgdG8gdGhlIGZ1bmN0aW9ucyBzdHJmdGltZSwKICBsb2NhbHRpbWUsIGdtdGltZSwgYXNjdGltZSBhbmQgY3RpbWUgaXMgbm93IG9wdGlvbmFsLCBkZWZhdWx0aW5nIHRvCiAgdGhlIGN1cnJlbnQgdGltZSAoaW4gdGhlIGxvY2FsIHRpbWV6b25lKS4KCi0gVGhlIGZ0cGxpYiBtb2R1bGUgbm93IGRlZmF1bHRzIHRvIHBhc3NpdmUgbW9kZSwgd2hpY2ggaXMgZGVlbWVkIGEKICBtb3JlIHVzZWZ1bCBkZWZhdWx0IGdpdmVuIHRoYXQgY2xpZW50cyBhcmUgb2Z0ZW4gaW5zaWRlIGZpcmV3YWxscwogIHRoZXNlIGRheXMuICBOb3RlIHRoYXQgdGhpcyBjb3VsZCBicmVhayBpZiBmdHBsaWIgaXMgdXNlZCB0byBjb25uZWN0CiAgdG8gYSAqc2VydmVyKiB0aGF0IGlzIGluc2lkZSBhIGZpcmV3YWxsLCBmcm9tIG91dHNpZGU7IHRoaXMgaXMKICBleHBlY3RlZCB0byBiZSBhIHZlcnkgcmFyZSBzaXR1YXRpb24uICBUbyBmaXggdGhhdCwgeW91IGNhbiBjYWxsCiAgZnRwLnNldF9wYXN2KDApLgoKLSBUaGUgbW9kdWxlIHNpdGUgbm93IHRyZWF0cyAucHRoIGZpbGVzIG5vdCBvbmx5IGZvciBwYXRoIGNvbmZpZ3VyYXRpb24sCiAgYnV0IGFsc28gc3VwcG9ydHMgZXh0ZW5zaW9ucyB0byB0aGUgaW5pdGlhbGl6YXRpb24gY29kZTogTGluZXMgc3RhcnRpbmcKICB3aXRoIGltcG9ydCBhcmUgZXhlY3V0ZWQuCgotIFRoZXJlJ3MgYSBuZXcgbW9kdWxlLCB3YXJuaW5ncywgd2hpY2ggaW1wbGVtZW50cyBhIG1lY2hhbmlzbSBmb3IKICBpc3N1aW5nIGFuZCBmaWx0ZXJpbmcgd2FybmluZ3MuICBUaGVyZSBhcmUgc29tZSBuZXcgYnVpbHQtaW4KICBleGNlcHRpb25zIHRoYXQgc2VydmUgYXMgd2FybmluZyBjYXRlZ29yaWVzLCBhbmQgYSBuZXcgY29tbWFuZCBsaW5lCiAgb3B0aW9uLCAtVywgdG8gY29udHJvbCB3YXJuaW5ncyAoZS5nLiAtV2kgaWdub3JlcyBhbGwgd2FybmluZ3MsIC1XZQogIHR1cm5zIHdhcm5pbmdzIGludG8gZXJyb3JzKS4gIHdhcm5pbmdzLndhcm4obWVzc2FnZVssIGNhdGVnb3J5XSkKICBpc3N1ZXMgYSB3YXJuaW5nIG1lc3NhZ2U7IHRoaXMgY2FuIGFsc28gYmUgY2FsbGVkIGZyb20gQyBhcwogIFB5RXJyX1dhcm4oY2F0ZWdvcnksIG1lc3NhZ2UpLgoKLSBBIG5ldyBtb2R1bGUgeHJlYWRsaW5lcyB3YXMgYWRkZWQuICBUaGlzIGV4cG9ydHMgYSBzaW5nbGUgZmFjdG9yeQogIGZ1bmN0aW9uLCB4cmVhZGxpbmVzKCkuICBUaGUgaW50ZW50aW9uIGlzIHRoYXQgdGhpcyBjb2RlIGlzIHRoZQogIGFic29sdXRlbHkgZmFzdGVzdCB3YXkgdG8gaXRlcmF0ZSBvdmVyIGFsbCBsaW5lcyBpbiBhbiBvcGVuCiAgZmlsZSgtbGlrZSkgb2JqZWN0OgoKICBpbXBvcnQgeHJlYWRsaW5lcwogIGZvciBsaW5lIGluIHhyZWFkbGluZXMueHJlYWRsaW5lcyhmaWxlKToKICAgICAgLi4uZG8gc29tZXRoaW5nIHRvIGxpbmUuLi4KCiAgVGhpcyBpcyBlcXVpdmFsZW50IHRvIHRoZSBwcmV2aW91cyB0aGUgc3BlZWQgcmVjb3JkIGhvbGRlciB1c2luZwogIGZpbGUucmVhZGxpbmVzKHNpemVoaW50KS4gIE5vdGUgdGhhdCBpZiBmaWxlIGlzIGEgcmVhbCBmaWxlIG9iamVjdAogIChhcyBvcHBvc2VkIHRvIGEgZmlsZS1saWtlIG9iamVjdCksIHRoaXMgaXMgZXF1aXZhbGVudDoKCiAgZm9yIGxpbmUgaW4gZmlsZS54cmVhZGxpbmVzKCk6CiAgICAgIC4uLmRvIHNvbWV0aGluZyB0byBsaW5lLi4uCgotIFRoZSBiaXNlY3QgbW9kdWxlIGhhcyBuZXcgZnVuY3Rpb25zIGJpc2VjdF9sZWZ0LCBpbnNvcnRfbGVmdCwKICBiaXNlY3RfcmlnaHQgYW5kIGluc29ydF9yaWdodC4gIFRoZSBvbGQgbmFtZXMgYmlzZWN0IGFuZCBpbnNvcnQKICBhcmUgbm93IGFsaWFzZXMgZm9yIGJpc2VjdF9yaWdodCBhbmQgaW5zb3J0X3JpZ2h0LiAgWFhYX3JpZ2h0CiAgYW5kIFhYWF9sZWZ0IG1ldGhvZHMgZGlmZmVyIGluIHdoYXQgaGFwcGVucyB3aGVuIHRoZSBuZXcgZWxlbWVudAogIGNvbXBhcmVzIGVxdWFsIHRvIG9uZSBvciBtb3JlIGVsZW1lbnRzIGFscmVhZHkgaW4gdGhlIGxpc3Q6ICB0aGUKICBYWFhfbGVmdCBtZXRob2RzIGluc2VydCB0byB0aGUgbGVmdCwgdGhlIFhYWF9yaWdodCBtZXRob2RzIHRvIHRoZQogIHJpZ2h0LiAgQ29kZSB0aGF0IGRvZXNuJ3QgY2FyZSB3aGVyZSBlcXVhbCBlbGVtZW50cyBlbmQgdXAgc2hvdWxkCiAgY29udGludWUgdG8gdXNlIHRoZSBvbGQsIHNob3J0IG5hbWVzICgiYmlzZWN0IiBhbmQgImluc29ydCIpLgoKLSBUaGUgbmV3IGN1cnNlcy5wYW5lbCBtb2R1bGUgd3JhcHMgdGhlIHBhbmVsIGxpYnJhcnkgdGhhdCBmb3JtcyBwYXJ0CiAgb2YgU1lTViBjdXJzZXMgYW5kIG5jdXJzZXMuICBDb250cmlidXRlZCBieSBUaG9tYXMgR2VsbGVrdW0uCgotIFRoZSBTb2NrZXRTZXJ2ZXIgbW9kdWxlIG5vdyBzZXRzIHRoZSBhbGxvd19yZXVzZV9hZGRyZXNzIGZsYWcgYnkKICBkZWZhdWx0IGluIHRoZSBUQ1BTZXJ2ZXIgY2xhc3MuCgotIEEgbmV3IGZ1bmN0aW9uLCBzeXMuX2dldGZyYW1lKCksIHJldHVybnMgdGhlIHN0YWNrIGZyYW1lIHBvaW50ZXIgb2YKICB0aGUgY2FsbGVyLiAgVGhpcyBpcyBpbnRlbmRlZCBvbmx5IGFzIGEgYnVpbGRpbmcgYmxvY2sgZm9yCiAgaGlnaGVyLWxldmVsIG1lY2hhbmlzbXMgc3VjaCBhcyBzdHJpbmcgaW50ZXJwb2xhdGlvbi4KCi0gVGhlIHB5ZXhwYXQgbW9kdWxlIHN1cHBvcnRzIGEgbnVtYmVyIG9mIG5ldyBoYW5kbGVycywgd2hpY2ggYXJlCiAgYXZhaWxhYmxlIG9ubHkgaW4gZXhwYXQgMS4yLiBJZiBpbnZvY2F0aW9uIG9mIGEgY2FsbGJhY2sgZmFpbHMsIGl0CiAgd2lsbCByZXBvcnQgYW4gYWRkaXRpb25hbCBmcmFtZSBpbiB0aGUgdHJhY2ViYWNrLiBQYXJzZXIgb2JqZWN0cwogIHBhcnRpY2lwYXRlIG5vdyBpbiBnYXJiYWdlIGNvbGxlY3Rpb24uIElmIGV4cGF0IHJlcG9ydHMgYW4gdW5rbm93bgogIGVuY29kaW5nLCBweWV4cGF0IHdpbGwgdHJ5IHRvIHVzZSBhIFB5dGhvbiBjb2RlYzsgdGhhdCB3b3JrcyBvbmx5CiAgZm9yIHNpbmdsZS1ieXRlIGNoYXJzZXRzLiBUaGUgcGFyc2VyIHR5cGUgb2JqZWN0cyBpcyBleHBvc2VkIGFzCiAgWE1MUGFyc2VyT2JqZWN0LgoKLSB4bWwuZG9tIG5vdyBvZmZlcnMgc3RhbmRhcmQgZGVmaW5pdGlvbnMgZm9yIHN5bWJvbGljIG5vZGUgdHlwZSBhbmQKICBleGNlcHRpb24gY29kZSBjb25zdGFudHMsIGFuZCBhIGhpZXJhcmNoeSBvZiBET00gZXhjZXB0aW9ucy4gbWluaWRvbQogIHdhcyBhZGp1c3RlZCB0byB1c2UgdGhlbS4KCi0gVGhlIGNvbmZvcm1hbmNlIG9mIHhtbC5kb20ubWluaWRvbSB0byB0aGUgRE9NIHNwZWNpZmljYXRpb24gd2FzCiAgaW1wcm92ZWQuIEl0IGRldGVjdHMgYSBudW1iZXIgb2YgYWRkaXRpb25hbCBlcnJvciBjYXNlczsgdGhlCiAgcHJldmlvdXMvbmV4dCByZWxhdGlvbnNoaXAgd29ya3MgZXZlbiB3aGVuIHRoZSB0cmVlIGlzIG1vZGlmaWVkOwogIE5vZGUgc3VwcG9ydHMgdGhlIG5vcm1hbGl6ZSgpIG1ldGhvZDsgTmFtZWROb2RlTWFwLCBEb2N1bWVudFR5cGUgYW5kCiAgRE9NSW1wbGVtZW50YXRpb24gY2xhc3NlcyB3ZXJlIGFkZGVkOyBFbGVtZW50IHN1cHBvcnRzIHRoZQogIGhhc0F0dHJpYnV0ZSBhbmQgaGFzQXR0cmlidXRlTlMgbWV0aG9kczsgYW5kIFRleHQgc3VwcG9ydHMgdGhlIHNwbGl0VGV4dAogIG1ldGhvZC4KCkJ1aWxkIGlzc3VlcwoKLSBGb3IgVW5peCAoYW5kIFVuaXgtY29tcGF0aWJsZSkgYnVpbGRzLCBjb25maWd1cmF0aW9uIGFuZCBidWlsZGluZyBvZgogIGV4dGVuc2lvbiBtb2R1bGVzIGlzIG5vdyBncmVhdGx5IGF1dG9tYXRlZC4gIFJhdGhlciB0aGFuIGhhdmluZyB0bwogIGVkaXQgdGhlIE1vZHVsZXMvU2V0dXAgZmlsZSB0byBpbmRpY2F0ZSB3aGljaCBtb2R1bGVzIHNob3VsZCBiZQogIGJ1aWx0IGFuZCB3aGVyZSB0aGVpciBpbmNsdWRlIGZpbGVzIGFuZCBsaWJyYXJpZXMgYXJlLCBhCiAgZGlzdHV0aWxzLWJhc2VkIHNldHVwLnB5IHNjcmlwdCBub3cgdGFrZXMgY2FyZSBvZiBidWlsZGluZyBtb3N0CiAgZXh0ZW5zaW9uIG1vZHVsZXMuICBBbGwgZXh0ZW5zaW9uIG1vZHVsZXMgYnVpbHQgdGhpcyB3YXkgYXJlIGJ1aWx0CiAgYXMgc2hhcmVkIGxpYnJhcmllcy4gIE9ubHkgYSBmZXcgbW9kdWxlcyB0aGF0IG11c3QgYmUgbGlua2VkCiAgc3RhdGljYWxseSBhcmUgc3RpbGwgbGlzdGVkIGluIHRoZSBTZXR1cCBmaWxlOyB5b3Ugd29uJ3QgbmVlZCB0bwogIGVkaXQgdGhlaXIgY29uZmlndXJhdGlvbi4KCi0gUHl0aG9uIHNob3VsZCBub3cgYnVpbGQgb3V0IG9mIHRoZSBib3ggb24gQ3lnd2luLiAgSWYgaXQgZG9lc24ndCwKICBtYWlsIHRvIEphc29uIFRpc2hsZXIgKGpsdDYzIGF0IHVzZXJzLnNvdXJjZWZvcmdlLm5ldCkuCgotIFB5dGhvbiBub3cgYWx3YXlzIHVzZXMgaXRzIG93biAocmVuYW1lZCkgaW1wbGVtZW50YXRpb24gb2YgZ2V0b3B0KCkKICAtLSB0aGVyZSdzIHRvbyBtdWNoIHZhcmlhdGlvbiBhbW9uZyBDIGxpYnJhcnkgZ2V0b3B0KCkKICBpbXBsZW1lbnRhdGlvbnMuCgotIEMrKyBjb21waWxlcnMgYXJlIGJldHRlciBzdXBwb3J0ZWQ7IHRoZSBDWFggbWFjcm8gaXMgYWx3YXlzIHNldCB0byBhCiAgQysrIGNvbXBpbGVyIGlmIG9uZSBpcyBmb3VuZC4KCldpbmRvd3MgY2hhbmdlcwoKLSBzZWxlY3QgbW9kdWxlOiAgQnkgZGVmYXVsdCB1bmRlciBXaW5kb3dzLCBhIHNlbGVjdCgpIGNhbGwKICBjYW4gc3BlY2lmeSBubyBtb3JlIHRoYW4gNjQgc29ja2V0cy4gIFB5dGhvbiBub3cgYm9vc3RzCiAgdGhpcyBNaWNyb3NvZnQgZGVmYXVsdCB0byA1MTIuICBJZiB5b3UgbmVlZCBldmVuIG1vcmUgdGhhbgogIHRoYXQsIHNlZSB0aGUgTVMgZG9jcyAoeW91J2xsIG5lZWQgdG8gI2RlZmluZSBGRF9TRVRTSVpFCiAgYW5kIHJlY29tcGlsZSBQeXRob24gZnJvbSBzb3VyY2UpLgoKLSBTdXBwb3J0IGZvciBXaW5kb3dzIDMuMSwgRE9TIGFuZCBPUy8yIGlzIGdvbmUuICBUaGUgTGliL2Rvcy04eDMKICBzdWJkaXJlY3RvcnkgaXMgbm8gbW9yZSEKCgpXaGF0J3MgTmV3IGluIFB5dGhvbiAyLjA/Cj09PT09PT09PT09PT09PT09PT09PT09PT0KCkJlbG93IGlzIGEgbGlzdCBvZiBhbGwgcmVsZXZhbnQgY2hhbmdlcyBzaW5jZSByZWxlYXNlIDEuNi4gIE9sZGVyCmNoYW5nZXMgYXJlIGluIHRoZSBmaWxlIEhJU1RPUlkuICBJZiB5b3UgYXJlIG1ha2luZyB0aGUganVtcCBkaXJlY3RseQpmcm9tIFB5dGhvbiAxLjUuMiB0byAyLjAsIG1ha2Ugc3VyZSB0byByZWFkIHRoZSBzZWN0aW9uIGZvciAxLjYgaW4gdGhlCkhJU1RPUlkgZmlsZSEgIE1hbnkgaW1wb3J0YW50IGNoYW5nZXMgbGlzdGVkIHRoZXJlLgoKQWx0ZXJuYXRpdmVseSwgYSBnb29kIG92ZXJ2aWV3IG9mIHRoZSBjaGFuZ2VzIGJldHdlZW4gMS41LjIgYW5kIDIuMCBpcwp0aGUgZG9jdW1lbnQgIldoYXQncyBOZXcgaW4gUHl0aG9uIDIuMCIgYnkgS3VjaGxpbmcgYW5kIE1vc2hlIFphZGthOgpodHRwOi8vc3RhcnNoaXAucHl0aG9uLm5ldC9jcmV3L2Ftay9weXRob24vd3JpdGluZy9uZXctcHl0aG9uLy4KCi0tR3VpZG8gdmFuIFJvc3N1bSAoaG9tZSBwYWdlOiBodHRwOi8vd3d3LnB5dGhvbmxhYnMuY29tL35ndWlkby8pCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpXaGF0J3MgbmV3IGluIDIuMCAoc2luY2UgcmVsZWFzZSBjYW5kaWRhdGUgMSk/Cj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KClN0YW5kYXJkIGxpYnJhcnkKCi0gVGhlIGNvcHlfcmVnIG1vZHVsZSB3YXMgbW9kaWZpZWQgdG8gY2xhcmlmeSBpdHMgaW50ZW5kZWQgdXNlOiB0bwogIHJlZ2lzdGVyIHBpY2tsZSBzdXBwb3J0IGZvciBleHRlbnNpb24gdHlwZXMsIG5vdCBmb3IgY2xhc3Nlcy4KICBwaWNrbGUoKSB3aWxsIHJhaXNlIGEgVHlwZUVycm9yIGlmIGl0IGlzIHBhc3NlZCBhIGNsYXNzLgoKLSBGaXhlZCBhIGJ1ZyBpbiBnZXR0ZXh0J3MgIm5vcm1hbGl6ZSBhbmQgZXhwYW5kIiBjb2RlIHRoYXQgcHJldmVudGVkCiAgaXQgZnJvbSBmaW5kaW5nIGFuIGV4aXN0aW5nIC5tbyBmaWxlLgoKLSBSZXN0b3JlZCBzdXBwb3J0IGZvciBIVFRQLzAuOSBzZXJ2ZXJzIGluIGh0dHBsaWIuCgotIFRoZSBtYXRoIG1vZHVsZSB3YXMgY2hhbmdlZCB0byBzdG9wIHJhaXNpbmcgT3ZlcmZsb3dFcnJvciBpbiBjYXNlIG9mCiAgdW5kZXJmbG93LCBhbmQgcmV0dXJuIDAgaW5zdGVhZCBpbiB1bmRlcmZsb3cgY2FzZXMuICBXaGV0aGVyIFB5dGhvbgogIHVzZWQgdG8gcmFpc2UgT3ZlcmZsb3dFcnJvciBpbiBjYXNlIG9mIHVuZGVyZmxvdyB3YXMgcGxhdGZvcm0tCiAgZGVwZW5kZW50IChpdCBkaWQgd2hlbiB0aGUgcGxhdGZvcm0gbWF0aCBsaWJyYXJ5IHNldCBlcnJubyB0byBFUkFOR0UKICBvbiB1bmRlcmZsb3cpLgoKLSBGaXhlZCBhIGJ1ZyBpbiBTdHJpbmdJTyB0aGF0IG9jY3VycmVkIHdoZW4gdGhlIGZpbGUgcG9zaXRpb24gd2FzIG5vdAogIGF0IHRoZSBlbmQgb2YgdGhlIGZpbGUgYW5kIHdyaXRlKCkgd2FzIGNhbGxlZCB3aXRoIGVub3VnaCBkYXRhIHRvCiAgZXh0ZW5kIHBhc3QgdGhlIGVuZCBvZiB0aGUgZmlsZS4KCi0gRml4ZWQgYSBidWcgdGhhdCBjYXVzZWQgVGtpbnRlciBlcnJvciBtZXNzYWdlcyB0byBnZXQgbG9zdCBvbgogIFdpbmRvd3MuICBUaGUgYnVnIHdhcyBmaXhlZCBieSByZXBsYWNpbmcgZGlyZWN0IHVzZSBvZgogIGludGVycC0+cmVzdWx0IHdpdGggVGNsX0dldFN0cmluZ1Jlc3VsdChpbnRlcnApLgoKLSBGaXhlZCBidWcgaW4gdXJsbGliMiB0aGF0IGNhdXNlZCBpdCB0byBmYWlsIHdoZW4gaXQgcmVjZWl2ZWQgYW4gSFRUUAogIHJlZGlyZWN0IHJlc3BvbnNlLgoKLSBTZXZlcmFsIGNoYW5nZXMgd2VyZSBtYWRlIHRvIGRpc3R1dGlsczogU29tZSBkZWJ1Z2dpbmcgY29kZSB3YXMKICByZW1vdmVkIGZyb20gdXRpbC4gIEZpeGVkIHRoZSBpbnN0YWxsZXIgdXNlZCB3aGVuIGFuIGV4dGVybmFsIHppcAogIHByb2dyYW0gKGxpa2UgV2luWmlwKSBpcyBub3QgZm91bmQ7IHRoZSBzb3VyY2UgY29kZSBmb3IgdGhpcwogIGluc3RhbGxlciBpcyBpbiBNaXNjL2Rpc3R1dGlscy4gIGNoZWNrX2xpYigpIHdhcyBtb2RpZmllZCB0byBiZWhhdmUKICBtb3JlIGxpa2UgQUNfQ0hFQ0tfTElCIGJ5IGFkZCBvdGhlcl9saWJyYXJpZXMoKSBhcyBhIHBhcmFtZXRlci4gIFRoZQogIHRlc3QgZm9yIHdoZXRoZXIgaW5zdGFsbGVkIG1vZHVsZXMgYXJlIG9uIHN5cy5wYXRoIHdhcyBjaGFuZ2VkIHRvCiAgdXNlIGJvdGggbm9ybWNhc2UoKSBhbmQgbm9ybXBhdGgoKS4KCi0gU2V2ZXJhbCBtaW5vciBidWdzIHdlcmUgZml4ZWQgaW4gdGhlIHhtbCBwYWNrYWdlICh0aGUgbWluaWRvbSwKICBwdWxsZG9tLCBleHBhdHJlYWRlciwgYW5kIHNheHV0aWxzIG1vZHVsZXMpLgoKLSBUaGUgcmVncmVzc2lvbiB0ZXN0IGRyaXZlciAocmVncnRlc3QucHkpIGJlaGF2aW9yIHdoZW4gaW52b2tlZCB3aXRoCiAgLWwgY2hhbmdlZDogSXQgbm93IHJlcG9ydHMgYSBjb3VudCBvZiBvYmplY3RzIHRoYXQgYXJlIHJlY29nbml6ZWQgYXMKICBnYXJiYWdlIGJ1dCBub3QgZnJlZWQgYnkgdGhlIGdhcmJhZ2UgY29sbGVjdG9yLgoKLSBUaGUgcmVncmVzc2lvbiB0ZXN0IGZvciB0aGUgbWF0aCBtb2R1bGUgd2FzIGNoYW5nZWQgdG8gdGVzdAogIGV4Y2VwdGlvbmFsIGJlaGF2aW9yIHdoZW4gdGhlIHRlc3QgaXMgcnVuIGluIHZlcmJvc2UgbW9kZS4gIFB5dGhvbgogIGNhbm5vdCB5ZXQgZ3VhcmFudGVlIGNvbnNpc3RlbnQgZXhjZXB0aW9uIGJlaGF2aW9yIGFjcm9zcyBwbGF0Zm9ybXMsCiAgc28gdGhlIGV4Y2VwdGlvbiBwYXJ0IG9mIHRlc3RfbWF0aCBpcyBydW4gb25seSBpbiB2ZXJib3NlIG1vZGUsIGFuZAogIG1heSBmYWlsIG9uIHlvdXIgcGxhdGZvcm0uCgpJbnRlcm5hbHMKCi0gUHlPU19DaGVja1N0YWNrKCkgaGFzIGJlZW4gZGlzYWJsZWQgb24gV2luNjQsIHdoZXJlIGl0IGNhdXNlZAogIHRlc3Rfc3JlIHRvIGZhaWwuCgpCdWlsZCBpc3N1ZXMKCi0gQ2hhbmdlZCBjb21waWxlciBmbGFncywgc28gdGhhdCBnY2MgaXMgYWx3YXlzIGludm9rZWQgd2l0aCAtV2FsbCBhbmQKICAtV3N0cmljdC1wcm90b3R5cGVzLiAgVXNlcnMgY29tcGlsaW5nIFB5dGhvbiB3aXRoIEdDQyBzaG91bGQgc2VlCiAgZXhhY3RseSBvbmUgd2FybmluZywgZXhjZXB0IGlmIHRoZXkgaGF2ZSBwYXNzZWQgY29uZmlndXJlIHRoZQogIC0td2l0aC1weWRlYnVnIGZsYWcuICBUaGUgZXhwZWN0ZWQgd2FybmluZyBpcyBmb3IgZ2V0b3B0KCkgaW4KICBNb2R1bGVzL21haW4uYy4gIFRoaXMgd2FybmluZyB3aWxsIGJlIGZpeGVkIGZvciBQeXRob24gMi4xLgoKLSBGaXhlZCBjb25maWd1cmUgdG8gYWRkIC10aHJlYWRzIGFyZ3VtZW50IGR1cmluZyBsaW5raW5nIG9uIE9TRjEuCgpUb29scyBhbmQgb3RoZXIgbWlzY2VsbGFueQoKLSBUaGUgY29tcGlsZXIgaW4gVG9vbHMvY29tcGlsZXIgd2FzIHVwZGF0ZWQgdG8gc3VwcG9ydCB0aGUgbmV3CiAgbGFuZ3VhZ2UgZmVhdHVyZXMgaW50cm9kdWNlZCBpbiAyLjA6IGV4dGVuZGVkIHByaW50IHN0YXRlbWVudCwgbGlzdAogIGNvbXByZWhlbnNpb25zLCBhbmQgYXVnbWVudGVkIGFzc2lnbm1lbnRzLiAgVGhlIG5ldyBjb21waWxlciBzaG91bGQKICBhbHNvIGJlIGJhY2t3YXJkcyBjb21wYXRpYmxlIHdpdGggUHl0aG9uIDEuNS4yOyB0aGUgY29tcGlsZXIgd2lsbAogIGFsd2F5cyBnZW5lcmF0ZSBjb2RlIGZvciB0aGUgdmVyc2lvbiBvZiB0aGUgaW50ZXJwcmV0ZXIgaXQgcnVucwogIHVuZGVyLgoKV2hhdCdzIG5ldyBpbiAyLjAgcmVsZWFzZSBjYW5kaWRhdGUgMSAoc2luY2UgYmV0YSAyKT8KPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCldoYXQgaXMgcmVsZWFzZSBjYW5kaWRhdGUgMT8KCldlIGJlbGlldmUgdGhhdCByZWxlYXNlIGNhbmRpZGF0ZSAxIHdpbGwgZml4IGFsbCBrbm93biBidWdzIHRoYXQgd2UKaW50ZW5kIHRvIGZpeCBmb3IgdGhlIDIuMCBmaW5hbCByZWxlYXNlLiAgVGhpcyByZWxlYXNlIHNob3VsZCBiZSBhIGJpdAptb3JlIHN0YWJsZSB0aGFuIHRoZSBwcmV2aW91cyBiZXRhcy4gIFdlIHdvdWxkIGxpa2UgdG8gc2VlIGV2ZW4gbW9yZQp3aWRlc3ByZWFkIHRlc3RpbmcgYmVmb3JlIHRoZSBmaW5hbCByZWxlYXNlLCBzbyB3ZSBhcmUgcHJvZHVjaW5nIHRoaXMKcmVsZWFzZSBjYW5kaWRhdGUuICBUaGUgZmluYWwgcmVsZWFzZSB3aWxsIGJlIGV4YWN0bHkgdGhlIHNhbWUgdW5sZXNzCmFueSBzaG93LXN0b3BwaW5nIChvciBicm93biBiYWcpIGJ1Z3MgYXJlIGZvdW5kIGJ5IHRlc3RlcnMgb2YgdGhlCnJlbGVhc2UgY2FuZGlkYXRlLgoKQWxsIHRoZSBjaGFuZ2VzIHNpbmNlIHRoZSBsYXN0IGJldGEgcmVsZWFzZSBhcmUgYnVnIGZpeGVzIG9yIGNoYW5nZXMKdG8gc3VwcG9ydCBidWlsZGluZyBQeXRob24gZm9yIHNwZWNpZmljIHBsYXRmb3Jtcy4KCkNvcmUgbGFuZ3VhZ2UsIGJ1aWx0aW5zLCBhbmQgaW50ZXJwcmV0ZXIKCi0gQSBidWcgdGhhdCBjYXVzZWQgY3Jhc2hlcyB3aGVuIF9fY29lcmNlX18gd2FzIHVzZWQgd2l0aCBhdWdtZW50ZWQKICBhc3NpZ25tZW50LCBlLmcuICs9LCB3YXMgZml4ZWQuCgotIFJhaXNlIFplcm9EaXZpc2lvbkVycm9yIHdoZW4gcmFpc2luZyB6ZXJvIHRvIGEgbmVnYXRpdmUgbnVtYmVyLAogIGUuZy4gMC4wICoqIC0yLjAuICBOb3RlIHRoYXQgbWF0aC5wb3cgaXMgdW5yZWxhdGVkIHRvIHRoZSBidWlsdGluCiAgcG93ZXIgb3BlcmF0b3IgYW5kIHRoZSByZXN1bHQgb2YgbWF0aC5wb3coMC4wLCAtMi4wKSB3aWxsIHZhcnkgYnkKICBwbGF0Zm9ybS4gIE9uIExpbnV4LCBpdCByYWlzZXMgYSBWYWx1ZUVycm9yLgoKLSBBIGJ1ZyBpbiBVbmljb2RlIHN0cmluZyBpbnRlcnBvbGF0aW9uIHdhcyBmaXhlZCB0aGF0IG9jY2FzaW9uYWxseQogIGNhdXNlZCBlcnJvcnMgd2l0aCBmb3JtYXRzIGluY2x1ZGluZyAiJSUiLiAgRm9yIGV4YW1wbGUsIHRoZQogIGZvbGxvd2luZyBleHByZXNzaW9uICIlJSAlcyIgJSB1ImFiYyIgbm8gbG9uZ2VyIHJhaXNlcyBhIFR5cGVFcnJvci4KCi0gQ29tcGlsYXRpb24gb2YgZGVlcGx5IG5lc3RlZCBleHByZXNzaW9ucyByYWlzZXMgTWVtb3J5RXJyb3IgaW5zdGVhZAogIG9mIFN5bnRheEVycm9yLCBlLmcuIGV2YWwoIlsiICogNTAgKyAiXSIgKiA1MCkuCgotIEluIDIuMGIyIG9uIFdpbmRvd3MsIHRoZSBpbnRlcnByZXRlciB3cm90ZSAucHljIGZpbGVzIGluIHRleHQgbW9kZSwKICByZW5kZXJpbmcgdGhlbSB1c2VsZXNzLiAgVGhleSBhcmUgbm93IHdyaXR0ZW4gaW4gYmluYXJ5IG1vZGUgYWdhaW4uCgpTdGFuZGFyZCBsaWJyYXJ5CgotIEtleXdvcmQgYXJndW1lbnRzIGFyZSBub3cgYWNjZXB0ZWQgZm9yIG1vc3QgcGF0dGVybiBhbmQgbWF0Y2ggb2JqZWN0CiAgbWV0aG9kcyBpbiBTUkUsIHRoZSBzdGFuZGFyZCByZWd1bGFyIGV4cHJlc3Npb24gZW5naW5lLgoKLSBJbiBTUkUsIGZpeGVkIGVycm9yIHdpdGggbmVnYXRpdmUgbG9va2FoZWFkIGFuZCBsb29rYmVoaW5kIHRoYXQKICBtYW5pZmVzdGVkIGl0c2VsZiBhcyBhIHJ1bnRpbWUgZXJyb3IgaW4gcGF0dGVybnMgbGlrZSAiKD88IWFiYykoZGVmKSIuCgotIFNldmVyYWwgYnVncyBpbiB0aGUgVW5pY29kZSBoYW5kbGluZyBhbmQgZXJyb3IgaGFuZGxpbmcgaW4gX3RraW50ZXIKICB3ZXJlIGZpeGVkLgoKLSBGaXggbWVtb3J5IG1hbmFnZW1lbnQgZXJyb3JzIGluIE1lcmdlKCkgYW5kIFRrYXBwX0NhbGwoKSByb3V0aW5lcy4KCi0gU2V2ZXJhbCBjaGFuZ2VzIHdlcmUgbWFkZSB0byBjU3RyaW5nSU8gdG8gbWFrZSBpdCBjb21wYXRpYmxlIHdpdGgKICB0aGUgZmlsZS1saWtlIG9iamVjdCBpbnRlcmZhY2UgYW5kIHdpdGggU3RyaW5nSU8uICBJZiBvcGVyYXRpb25zIGFyZQogIHBlcmZvcm1lZCBvbiBhIGNsb3NlZCBvYmplY3QsIGFuIGV4Y2VwdGlvbiBpcyByYWlzZWQuICBUaGUgdHJ1bmNhdGUKICBtZXRob2Qgbm93IGFjY2VwdHMgYSBwb3NpdGlvbiBhcmd1bWVudCBhbmQgcmVhZGxpbmUgYWNjZXB0cyBhIHNpemUKICBhcmd1bWVudC4KCi0gVGhlcmUgd2VyZSBtYW55IGNoYW5nZXMgbWFkZSB0byB0aGUgbGludXhhdWRpb2RldiBtb2R1bGUgYW5kIGl0cwogIHRlc3Qgc3VpdGU7IGFzIGEgcmVzdWx0LCBhIHNob3J0LCB1bmV4cGVjdGVkIGF1ZGlvIHNhbXBsZSBzaG91bGQgbm93CiAgcGxheSB3aGVuIHRoZSByZWdyZXNzaW9uIHRlc3QgaXMgcnVuLgoKICBOb3RlIHRoYXQgdGhpcyBtb2R1bGUgaXMgbmFtZWQgcG9vcmx5LCBiZWNhdXNlIGl0IHNob3VsZCB3b3JrCiAgY29ycmVjdGx5IG9uIGFueSBwbGF0Zm9ybSB0aGF0IHN1cHBvcnRzIHRoZSBPcGVuIFNvdW5kIFN5c3RlbQogIChPU1MpLgoKICBUaGUgbW9kdWxlIG5vdyByYWlzZXMgZXhjZXB0aW9ucyB3aGVuIGVycm9ycyBvY2N1ciBpbnN0ZWFkIG9mCiAgY3Jhc2hpbmcuICBJdCBhbHNvIGRlZmluZXMgdGhlIEFGTVRfQV9MQVcgZm9ybWF0IChsb2dhcml0aG1pYyBBLWxhdwogIGF1ZGlvKSBhbmQgZGVmaW5lcyBhIGdldHB0cigpIG1ldGhvZCB0aGF0IGNhbGxzIHRoZQogIFNORENUTF9EU1BfR0VUeFBUUiBpb2N0bCBkZWZpbmVkIGluIHRoZSBPU1MgUHJvZ3JhbW1lcidzIEd1aWRlLgoKLSBUaGUgbGlicmFyeV92ZXJzaW9uIGF0dHJpYnV0ZSwgaW50cm9kdWNlZCBpbiBhbiBlYXJsaWVyIGJldGEsIHdhcwogIHJlbW92ZWQgYmVjYXVzZSBpdCBjYW4gbm90IGJlIHN1cHBvcnRlZCB3aXRoIGVhcmx5IHZlcnNpb25zIG9mIHRoZSBDCiAgcmVhZGxpbmUgbGlicmFyeSwgd2hpY2ggcHJvdmlkZXMgbm8gd2F5IHRvIGRldGVybWluZSB0aGUgdmVyc2lvbiBhdAogIGNvbXBpbGUtdGltZS4KCi0gVGhlIGJpbmFzY2lpIG1vZHVsZSBpcyBub3cgZW5hYmxlZCBvbiBXaW42NC4KCi0gdG9rZW5pemUucHkgbm8gbG9uZ2VyIHN1ZmZlcnMgInJlY3Vyc2lvbiBkZXB0aCIgZXJyb3JzIHdoZW4gcGFyc2luZwogIHByb2dyYW1zIHdpdGggdmVyeSBsb25nIHN0cmluZyBsaXRlcmFscy4KCkludGVybmFscwoKLSBGaXhlZCBzZXZlcmFsIGJ1ZmZlciBvdmVyZmxvdyB2dWxuZXJhYmlsaXRpZXMgaW4gY2FsY3VsYXRlX3BhdGgoKSwKICB3aGljaCBpcyBjYWxsZWQgd2hlbiB0aGUgaW50ZXJwcmV0ZXIgc3RhcnRzIHVwIHRvIGRldGVybWluZSB3aGVyZQogIHRoZSBzdGFuZGFyZCBsaWJyYXJ5IGlzIGluc3RhbGxlZC4gIFRoZXNlIHZ1bG5lcmFiaWxpdGllcyBhZmZlY3QgYWxsCiAgcHJldmlvdXMgdmVyc2lvbnMgb2YgUHl0aG9uIGFuZCBjYW4gYmUgZXhwbG9pdGVkIGJ5IHNldHRpbmcgdmVyeQogIGxvbmcgdmFsdWVzIGZvciBQWVRIT05IT01FIG9yIGFyZ3ZbMF0uICBUaGUgcmlzayBpcyBncmVhdGVzdCBmb3IgYQogIHNldHVpZCBQeXRob24gc2NyaXB0LCBhbHRob3VnaCB1c2Ugb2YgdGhlIHdyYXBwZXIgaW4KICBNaXNjL3NldHVpZC1wcm9nLmMgd2lsbCBlbGltaW5hdGUgdGhlIHZ1bG5lcmFiaWxpdHkuCgotIEZpeGVkIGdhcmJhZ2UgY29sbGVjdGlvbiBidWdzIGluIGluc3RhbmNlIGNyZWF0aW9uIHRoYXQgd2VyZQogIHRyaWdnZXJlZCB3aGVuIGVycm9ycyBvY2N1cnJlZCBkdXJpbmcgaW5pdGlhbGl6YXRpb24uICBUaGUgc29sdXRpb24sCiAgYXBwbGllZCBpbiBjUGlja2xlIGFuZCBpbiBQeUluc3RhbmNlX05ldygpLCBpcyB0byBjYWxsCiAgUHlPYmplY3RfR0NfSW5pdCgpIGFmdGVyIHRoZSBpbml0aWFsaXphdGlvbiBvZiB0aGUgb2JqZWN0J3MKICBjb250YWluZXIgYXR0cmlidXRlcyBpcyBjb21wbGV0ZS4KCi0gcHlleHBhdCBhZGRzIGRlZmluaXRpb25zIG9mIFB5TW9kdWxlX0FkZFN0cmluZ0NvbnN0YW50IGFuZAogIFB5TW9kdWxlX0FkZE9iamVjdCBpZiB0aGUgUHl0aG9uIHZlcnNpb24gaXMgbGVzcyB0aGFuIDIuMCwgd2hpY2gKICBwcm92aWRlcyBjb21wYXRpYmlsaXR5IHdpdGggUHlYTUwgb24gUHl0aG9uIDEuNS4yLgoKLSBJZiB0aGUgcGxhdGZvcm0gaGFzIGEgYm9ndXMgZGVmaW5pdGlvbiBmb3IgTE9OR19CSVQgKHRoZSBudW1iZXIgb2YKICBiaXRzIGluIGEgbG9uZyksIGFuIGVycm9yIHdpbGwgYmUgcmVwb3J0ZWQgYXQgY29tcGlsZSB0aW1lLgoKLSBGaXggYnVncyBpbiBfUHlUdXBsZV9SZXNpemUoKSB3aGljaCBjYXVzZWQgaGFyZC10by1pbnRlcnByZXQgZ2FyYmFnZQogIGNvbGxlY3Rpb24gY3Jhc2hlcyBhbmQgcG9zc2libHkgb3RoZXIsIHVucmVwb3J0ZWQgY3Jhc2hlcy4KCi0gRml4ZWQgYSBtZW1vcnkgbGVhayBpbiBfUHlVbmljb2RlX0ZpbmkoKS4KCkJ1aWxkIGlzc3VlcwoKLSBjb25maWd1cmUgbm93IGFjY2VwdHMgYSAtLXdpdGgtc3VmZml4IG9wdGlvbiB0aGF0IHNwZWNpZmllcyB0aGUKICBleGVjdXRhYmxlIHN1ZmZpeC4gIFRoaXMgaXMgdXNlZnVsIGZvciBidWlsZHMgb24gQ3lnd2luIGFuZCBNYWMgT1MKICBYLCBmb3IgZXhhbXBsZS4KCi0gVGhlIG1tYXAuUEFHRVNJWkUgY29uc3RhbnQgaXMgbm93IGluaXRpYWxpemVkIHVzaW5nIHN5c2NvbmYgd2hlbgogIHBvc3NpYmxlLCB3aGljaCBlbGltaW5hdGVzIGEgZGVwZW5kZW5jeSBvbiAtbHVjYiBmb3IgUmVsaWFudCBVTklYLgoKLSBUaGUgbWQ1IGZpbGUgc2hvdWxkIG5vdyBjb21waWxlIG9uIGFsbCBwbGF0Zm9ybXMuCgotIFRoZSBzZWxlY3QgbW9kdWxlIG5vdyBjb21waWxlcyBvbiBwbGF0Zm9ybXMgdGhhdCBkbyBub3QgZGVmaW5lCiAgUE9MTFJETk9STSBhbmQgcmVsYXRlZCBjb25zdGFudHMuCgotIERhcndpbiAoTWFjIE9TIFgpOiAgSW5pdGlhbCBzdXBwb3J0IGZvciBzdGF0aWMgYnVpbGRzIG9uIHRoaXMKICBwbGF0Zm9ybS4KCi0gQmVPUzogQSBudW1iZXIgb2YgY2hhbmdlcyB3ZXJlIG1hZGUgdG8gdGhlIGJ1aWxkIGFuZCBpbnN0YWxsYXRpb24KICBwcm9jZXNzLiAgYXItZmFrZSBub3cgb3BlcmF0ZXMgb24gYSBkaXJlY3Rvcnkgb2Ygb2JqZWN0IGZpbGVzLgogIGRsX2V4cG9ydC5oIGlzIGdvbmUsIGFuZCBpdHMgbWFjcm9zIG5vdyBhcHBlYXIgb24gdGhlIG13Y2MgY29tbWFuZAogIGxpbmUgZHVyaW5nIGJ1aWxkIG9uIFBQQyBCZU9TLgoKLSBQbGF0Zm9ybSBkaXJlY3RvcnkgaW4gbGliL3B5dGhvbjIuMCBpcyAicGxhdC1iZW9zNSIgKG9yCiAgInBsYXQtYmVvczQiLCBpZiBidWlsZGluZyBvbiBCZU9TIDQuNSksIHJhdGhlciB0aGFuICJwbGF0LWJlb3MiLgoKLSBDeWd3aW46IFN1cHBvcnQgZm9yIHNoYXJlZCBsaWJyYXJpZXMsIFRraW50ZXIsIGFuZCBzb2NrZXRzLgoKLSBTdW5PUyA0LjEuNF9KTDogRml4IHRlc3QgZm9yIGRpcmVjdG9yeSBleGlzdGVuY2UgaW4gY29uZmlndXJlLgoKVG9vbHMgYW5kIG90aGVyIG1pc2NlbGxhbnkKCi0gUmVtb3ZlZCBkZWJ1Z2dpbmcgcHJpbnRzIGZyb20gbWFpbiB1c2VkIHdpdGggZnJlZXplLgoKLSBJRExFIGF1dG8taW5kZW50IG5vIGxvbmdlciBjcmFzaGVzIHdoZW4gaXQgZW5jb3VudGVycyBVbmljb2RlCiAgY2hhcmFjdGVycy4KCldoYXQncyBuZXcgaW4gMi4wIGJldGEgMiAoc2luY2UgYmV0YSAxKT8KPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKQ29yZSBsYW5ndWFnZSwgYnVpbHRpbnMsIGFuZCBpbnRlcnByZXRlcgoKLSBBZGQgc3VwcG9ydCBmb3IgdW5ib3VuZGVkIGludHMgaW4gJWQsaSx1LHgsWCxvIGZvcm1hdHM7IGZvciBleGFtcGxlCiAgIiVkIiAlIDJMKio2NCA9PSAiMTg0NDY3NDQwNzM3MDk1NTE2MTYiLgoKLSBBZGQgLWggYW5kIC1WIGNvbW1hbmQgbGluZSBvcHRpb25zIHRvIHByaW50IHRoZSB1c2FnZSBtZXNzYWdlIGFuZAogIFB5dGhvbiB2ZXJzaW9uIG51bWJlciBhbmQgZXhpdCBpbW1lZGlhdGVseS4KCi0gZXZhbCgpIGFuZCBleGVjIGFjY2VwdCBVbmljb2RlIG9iamVjdHMgYXMgY29kZSBwYXJhbWV0ZXJzLgoKLSBnZXRhdHRyKCkgYW5kIHNldGF0dHIoKSBub3cgYWxzbyBhY2NlcHQgVW5pY29kZSBvYmplY3RzIGZvciB0aGUKICBhdHRyaWJ1dGUgbmFtZSwgd2hpY2ggYXJlIGNvbnZlcnRlZCB0byBzdHJpbmdzIHVzaW5nIHRoZSBkZWZhdWx0CiAgZW5jb2RpbmcgYmVmb3JlIGxvb2t1cC4KCi0gTXVsdGlwbGljYXRpb24gb24gc3RyaW5nIGFuZCBVbmljb2RlIG5vdyBkb2VzIHByb3BlciBib3VuZHMKICBjaGVja2luZzsgZS5nLiAnYScgKiA2NTUzNiAqIDY1NTM2IHdpbGwgcmFpc2UgVmFsdWVFcnJvciwgInJlcGVhdGVkCiAgc3RyaW5nIGlzIHRvbyBsb25nLiIKCi0gQmV0dGVyIGVycm9yIG1lc3NhZ2Ugd2hlbiBjb250aW51ZSBpcyBmb3VuZCBpbiB0cnkgc3RhdGVtZW50IGluIGEKICBsb29wLgoKClN0YW5kYXJkIGxpYnJhcnkgYW5kIGV4dGVuc2lvbnMKCi0gc29ja2V0IG1vZHVsZTogdGhlIE9wZW5TU0wgY29kZSBub3cgYWRkcyBzdXBwb3J0IGZvciBSQU5EX3N0YXR1cygpCiAgYW5kIEVHRCAoRW50cm9weSBHYXRoZXJpbmcgRGV2aWNlKS4KCi0gYXJyYXk6IHJldmVyc2UoKSBtZXRob2Qgb2YgYXJyYXkgbm93IHdvcmtzLiAgYnVmZmVyX2luZm8oKSBub3cgZG9lcwogIGFyZ3VtZW50IGNoZWNraW5nOyBpdCBzdGlsbCB0YWtlcyBubyBhcmd1bWVudHMuCgotIGFzeW5jb3JlL2FzeW5jaGF0OiBJbmNsdWRlZCBtb3N0IHJlY2VudCB2ZXJzaW9uIGZyb20gU2FtIFJ1c2hpbmcuCgotIGNnaTogQWNjZXB0ICcmJyBvciAnOycgYXMgc2VwYXJhdG9yIGNoYXJhY3RlcnMgd2hlbiBwYXJzaW5nIGZvcm0gZGF0YS4KCi0gQ0dJSFRUUFNlcnZlcjogTm93IHdvcmtzIG9uIFdpbmRvd3MgKGFuZCBwZXJoYXBzIGV2ZW4gTWFjKS4KCi0gQ29uZmlnUGFyc2VyOiBXaGVuIHJlYWRpbmcgdGhlIGZpbGUsIG9wdGlvbnMgc3BlbGxlZCBpbiB1cHBlciBjYXNlCiAgbGV0dGVycyBhcmUgbm93IGNvcnJlY3RseSBjb252ZXJ0ZWQgdG8gbG93ZXJjYXNlLgoKLSBjb3B5OiBDb3B5IFVuaWNvZGUgb2JqZWN0cyBhdG9taWNhbGx5LgoKLSBjUGlja2xlOiBGYWlsIGdyYWNlZnVsbHkgd2hlbiBjb3B5X3JlZyBjYW4ndCBiZSBpbXBvcnRlZC4KCi0gY1N0cmluZ0lPOiBJbXBsZW1lbnRlZCByZWFkbGluZXMoKSBtZXRob2QuCgotIGRibTogQWRkIGdldCgpIGFuZCBzZXRkZWZhdWx0KCkgbWV0aG9kcyB0byBkYm0gb2JqZWN0LiAgQWRkIGNvbnN0YW50CiAgYGxpYnJhcnknIHRvIG1vZHVsZSB0aGF0IG5hbWVzIHRoZSBsaWJyYXJ5IHVzZWQuICBBZGRlZCBkb2Mgc3RyaW5ncwogIGFuZCBtZXRob2QgbmFtZXMgdG8gZXJyb3IgbWVzc2FnZXMuICBVc2VzIGNvbmZpZ3VyZSB0byBkZXRlcm1pbmUKICB3aGljaCBuZGJtLmggZmlsZSB0byBpbmNsdWRlOyBCZXJrZWxleSBEQidzIG5iZG0gYW5kIEdEQk0ncyBuZGJtIGlzCiAgbm93IGF2YWlsYWJsZSBvcHRpb25zLgoKLSBkaXN0dXRpbHM6IFVwZGF0ZSB0byB2ZXJzaW9uIDAuOS4zLgoKLSBkbDogQWRkIHNldmVyYWwgZGwuUlRMRF8gY29uc3RhbnRzLgoKLSBmcGVjdGw6IE5vdyBzdXBwb3J0ZWQgb24gRnJlZUJTRC4KCi0gZ2M6IEFkZCBERUJVR19TQVZFQUxMIG9wdGlvbi4gIFdoZW4gZW5hYmxlZCBhbGwgZ2FyYmFnZSBvYmplY3RzCiAgZm91bmQgYnkgdGhlIGNvbGxlY3RvciB3aWxsIGJlIHNhdmVkIGluIGdjLmdhcmJhZ2UuICBUaGlzIGlzIHVzZWZ1bAogIGZvciBkZWJ1Z2dpbmcgYSBwcm9ncmFtIHRoYXQgY3JlYXRlcyByZWZlcmVuY2UgY3ljbGVzLgoKLSBodHRwbGliOiBUaHJlZSBjaGFuZ2VzOiBSZXN0b3JlIHN1cHBvcnQgZm9yIHNldF9kZWJ1Z2xldmVsIGZlYXR1cmUKICBvZiBIVFRQIGNsYXNzLiAgRG8gbm90IGNsb3NlIHNvY2tldCBvbiB6ZXJvLWxlbmd0aCByZXNwb25zZS4gIERvIG5vdAogIGNyYXNoIHdoZW4gc2VydmVyIHNlbmRzIGludmFsaWQgY29udGVudC1sZW5ndGggaGVhZGVyLgoKLSBtYWlsYm94OiBNYWlsYm94IGNsYXNzIGNvbmZvcm1zIGJldHRlciB0byBxbWFpbCBzcGVjaWZpY2F0aW9ucy4KCi0gbWFyc2hhbDogV2hlbiByZWFkaW5nIGEgc2hvcnQsIHNpZ24tZXh0ZW5kIG9uIHBsYXRmb3JtcyB3aGVyZSBzaG9ydHMKICBhcmUgYmlnZ2VyIHRoYW4gMTYgYml0cy4gIFdoZW4gcmVhZGluZyBhIGxvbmcsIHJlcGFpciB0aGUgdW5wb3J0YWJsZQogIHNpZ24gZXh0ZW5zaW9uIHRoYXQgd2FzIGJlaW5nIGRvbmUgZm9yIDY0LWJpdCBtYWNoaW5lcy4gIChJdCBhc3N1bWVkCiAgdGhhdCBzaWduZWQgcmlnaHQgc2hpZnQgc2lnbi1leHRlbmRzLikKCi0gb3BlcmF0b3I6IEFkZCBjb250YWlucygpLCBpbnZlcnQoKSwgX19pbnZlcnRfXygpIGFzIGFsaWFzZXMgZm9yCiAgX19jb250YWluc19fKCksIGludigpLCBhbmQgX19pbnZfXygpIHJlc3BlY3RpdmVseS4KCi0gb3M6IEFkZCBzdXBwb3J0IGZvciBwb3BlbjIoKSBhbmQgcG9wZW4zKCkgb24gYWxsIHBsYXRmb3JtcyB3aGVyZQogIGZvcmsoKSBleGlzdHMuICAocG9wZW40KCkgaXMgc3RpbGwgaW4gdGhlIHdvcmtzLikKCi0gb3M6IChXaW5kb3dzIG9ubHk6KSBBZGQgc3RhcnRmaWxlKCkgZnVuY3Rpb24gdGhhdCBhY3RzIGxpa2UgZG91YmxlLQogIGNsaWNraW5nIG9uIGEgZmlsZSBpbiBFeHBsb3JlciAob3IgcGFzc2luZyB0aGUgZmlsZSBuYW1lIHRvIHRoZQogIERPUyAic3RhcnQiIGNvbW1hbmQpLgoKLSBvcy5wYXRoOiAoV2luZG93cywgRE9TOikgVHJlYXQgdHJhaWxpbmcgY29sb24gY29ycmVjdGx5IGluCiAgb3MucGF0aC5qb2luLiAgb3MucGF0aC5qb2luKCJhOiIsICJiIikgeWllbGRzICJhOmIiLgoKLSBwaWNrbGU6IE5vdyByYWlzZXMgVmFsdWVFcnJvciB3aGVuIGFuIGludmFsaWQgcGlja2xlIHRoYXQgY29udGFpbnMKICBhIG5vbi1zdHJpbmcgcmVwciB3aGVyZSBhIHN0cmluZyByZXByIHdhcyBleHBlY3RlZC4gIFRoaXMgYmVoYXZpb3IKICBtYXRjaGVzIGNQaWNrbGUuCgotIHBvc2l4ZmlsZTogUmVtb3ZlIGJyb2tlbiBfX2RlbF9fKCkgbWV0aG9kLgoKLSBweV9jb21waWxlOiBzdXBwb3J0IENSK0xGIGxpbmUgdGVybWluYXRvcnMgaW4gc291cmNlIGZpbGUuCgotIHJlYWRsaW5lOiBEb2VzIG5vdCBpbW1lZGlhdGVseSBleGl0IHdoZW4gXkMgaXMgaGl0IHdoZW4gcmVhZGxpbmUgYW5kCiAgdGhyZWFkcyBhcmUgY29uZmlndXJlZC4gIEFkZHMgZGVmaW5pdGlvbiBvZiBybF9saWJyYXJ5X3ZlcnNpb24uICAoVGhlCiAgbGF0dGVyIGFkZGl0aW9uIHJlcXVpcmVzIEdOVSByZWFkbGluZSAyLjIgb3IgbGF0ZXIuKQoKLSByZmM4MjI6IERvbWFpbiBsaXRlcmFscyByZXR1cm5lZCBieSBBZGRybGlzdENsYXNzIG1ldGhvZAogIGdldGRvbWFpbmxpdGVyYWwoKSBhcmUgbm93IHByb3Blcmx5IHdyYXBwZWQgaW4gYnJhY2tldHMuCgotIHNpdGU6IHN5cy5zZXRkZWZhdWx0ZW5jb2RpbmcoKSBzaG91bGQgb25seSBiZSBjYWxsZWQgaW4gY2FzZSB0aGUKICBzdGFuZGFyZCBkZWZhdWx0IGVuY29kaW5nICgiYXNjaWkiKSBpcyBjaGFuZ2VkLiBUaGlzIHNhdmVzIHF1aXRlIGEKICBmZXcgY3ljbGVzIGR1cmluZyBzdGFydHVwIHNpbmNlIHRoZSBmaXJzdCBjYWxsIHRvCiAgc2V0ZGVmYXVsdGVuY29kaW5nKCkgd2lsbCBpbml0aWFsaXplIHRoZSBjb2RlYyByZWdpc3RyeSBhbmQgdGhlCiAgZW5jb2RpbmdzIHBhY2thZ2UuCgotIHNvY2tldDogU3VwcG9ydCBmb3Igc2l6ZSBoaW50IGluIHJlYWRsaW5lcygpIG1ldGhvZCBvZiBvYmplY3QgcmV0dXJuZWQKICBieSBtYWtlZmlsZSgpLgoKLSBzcmU6IEFkZGVkIGV4cGVyaW1lbnRhbCBleHBhbmQoKSBtZXRob2QgdG8gbWF0Y2ggb2JqZWN0cy4gIERvZXMgbm90CiAgdXNlIGJ1ZmZlciBpbnRlcmZhY2Ugb24gVW5pY29kZSBzdHJpbmdzLiAgRG9lcyBub3QgaGFuZyBpZiBncm91cCBpZAogIGlzIGZvbGxvd2VkIGJ5IHdoaXRlc3BhY2UuCgotIFN0cmluZ0lPOiBTaXplIGhpbnQgaW4gcmVhZGxpbmVzKCkgaXMgbm93IHN1cHBvcnRlZCBhcyBkb2N1bWVudGVkLgoKLSBzdHJ1Y3Q6IENoZWNrIHJhbmdlcyBmb3IgYnl0ZXMgYW5kIHNob3J0cy4KCi0gdXJsbGliOiBJbXByb3ZlZCBoYW5kbGluZyBvZiB3aW4zMiBwcm94eSBzZXR0aW5ncy4gRml4ZWQgcXVvdGUgYW5kCiAgcXVvdGVfcGx1cyBmdW5jdGlvbnMgc28gdGhhdCB0aGUgYWx3YXlzIGVuY29kZSBhIGNvbW1hLgoKLSBUa2ludGVyOiBJbWFnZSBvYmplY3RzIGFyZSBub3cgZ3VhcmFudGVlZCB0byBoYXZlIHVuaXF1ZSBpZHMuICBTZXQKICBldmVudC5kZWx0YSB0byB6ZXJvIGlmIFRrIHZlcnNpb24gZG9lc24ndCBzdXBwb3J0IG1vdXNld2hlZWwuCiAgUmVtb3ZlZCBzb21lIGRlYnVnZ2luZyBwcmludHMuCgotIFVzZXJMaXN0OiBub3cgaW1wbGVtZW50cyBfX2NvbnRhaW5zX18oKS4KCi0gd2ViYnJvd3NlcjogT24gV2luZG93cywgdXNlIG9zLnN0YXJ0ZmlsZSgpIGluc3RlYWQgb2Ygb3MucG9wZW4oKSwKICB3aGljaCB3b3JrcyBhcm91bmQgYSBidWcgaW4gTm9ydG9uIEFudGlWaXJ1cyAyMDAwIHRoYXQgbGVhZHMgZGlyZWN0bHkKICB0byBhIEJsdWUgU2NyZWVuIGZyZWV6ZS4KCi0geG1sOiBOZXcgdmVyc2lvbiBkZXRlY3Rpb24gY29kZSBhbGxvd3MgUHlYTUwgdG8gb3ZlcnJpZGUgc3RhbmRhcmQKICBYTUwgcGFja2FnZSBpZiBQeVhNTCB2ZXJzaW9uIGlzIGdyZWF0ZXIgdGhhbiAwLjYuMS4KCi0geG1sLmRvbTogRE9NIGxldmVsIDEgc3VwcG9ydCBmb3IgYmFzaWMgWE1MLiAgSW5jbHVkZXMgeG1sLmRvbS5taW5pZG9tCiAgKGNvbnZlbnRpb25hbCBET00pLCBhbmQgeG1sLmRvbS5wdWxsZG9tLCB3aGljaCBhbGxvd3MgYnVpbGRpbmcgdGhlIERPTQogIHRyZWUgb25seSBmb3Igbm9kZXMgd2hpY2ggYXJlIHN1ZmZpY2llbnRseSBpbnRlcmVzdGluZyB0byBhIHNwZWNpZmljCiAgYXBwbGljYXRpb24uICBEb2VzIG5vdCBwcm92aWRlIHRoZSBIVE1MLXNwZWNpZmljIGV4dGVuc2lvbnMuICBTdGlsbAogIHVuZG9jdW1lbnRlZC4KCi0geG1sLnNheDogU0FYIDIgc3VwcG9ydCBmb3IgUHl0aG9uLCBpbmNsdWRpbmcgYWxsIHRoZSBoYW5kbGVyCiAgaW50ZXJmYWNlcyBuZWVkZWQgdG8gcHJvY2VzcyBYTUwgMS4wIGNvbXBsaWFudCBYTUwuICBTb21lCiAgZG9jdW1lbnRhdGlvbiBpcyBhbHJlYWR5IGF2YWlsYWJsZS4KCi0gcHlleHBhdDogUmVuYW1lZCB0byB4bWwucGFyc2Vycy5leHBhdCBzaW5jZSB0aGlzIGlzIHBhcnQgb2YgdGhlIG5ldywKICBwYWNrYWdpemVkIFhNTCBzdXBwb3J0LgoKCkMgQVBJCgotIEFkZCB0aHJlZSBuZXcgY29udmVuaWVuY2UgZnVuY3Rpb25zIGZvciBtb2R1bGUgaW5pdGlhbGl6YXRpb24gLS0KICBQeU1vZHVsZV9BZGRPYmplY3QoKSwgUHlNb2R1bGVfQWRkSW50Q29uc3RhbnQoKSwgYW5kCiAgUHlNb2R1bGVfQWRkU3RyaW5nQ29uc3RhbnQoKS4KCi0gQ2xlYW5lZCB1cCBkZWZpbml0aW9uIG9mIE5VTEwgaW4gQyBzb3VyY2UgY29kZTsgYWxsIGRlZmluaXRpb25zIHdlcmUKICByZW1vdmVkIGFuZCBhZGQgI2Vycm9yIHRvIFB5dGhvbi5oIGlmIE5VTEwgaXNuJ3QgZGVmaW5lZCBhZnRlcgogICNpbmNsdWRlIG9mIHN0ZGlvLmguCgotIFB5X1BST1RPKCkgbWFjcm9zIHRoYXQgd2VyZSByZW1vdmVkIGluIDIuMGIxIGhhdmUgYmVlbiByZXN0b3JlZCBmb3IKICBiYWNrd2FyZHMgY29tcGF0aWJpbGl0eSAoYXQgdGhlIHNvdXJjZSBsZXZlbCkgd2l0aCBvbGQgZXh0ZW5zaW9ucy4KCi0gQSB3cmFwcGVyIEFQSSB3YXMgYWRkZWQgZm9yIHNpZ25hbCgpIGFuZCBzaWdhY3Rpb24oKS4gIEluc3RlYWQgb2YKICBlaXRoZXIgZnVuY3Rpb24sIGFsd2F5cyB1c2UgUHlPU19nZXRzaWcoKSB0byBnZXQgYSBzaWduYWwgaGFuZGxlcgogIGFuZCBQeU9TX3NldHNpZygpIHRvIHNldCBvbmUuICBBIG5ldyBjb252ZW5pZW5jZSB0eXBlZGVmCiAgUHlPU19zaWdoYW5kbGVyX3QgaXMgZGVmaW5lZCBmb3IgdGhlIHR5cGUgb2Ygc2lnbmFsIGhhbmRsZXJzLgoKLSBBZGQgUHlTdHJpbmdfQXNTdHJpbmdBbmRTaXplKCkgZnVuY3Rpb24gdGhhdCBwcm92aWRlcyBhY2Nlc3MgdG8gdGhlCiAgaW50ZXJuYWwgZGF0YSBidWZmZXIgYW5kIHNpemUgb2YgYSBzdHJpbmcgb2JqZWN0IC0tIG9yIHRoZSBkZWZhdWx0CiAgZW5jb2RlZCB2ZXJzaW9uIG9mIGEgVW5pY29kZSBvYmplY3QuCgotIFB5U3RyaW5nX1NpemUoKSBhbmQgUHlTdHJpbmdfQXNTdHJpbmcoKSBhY2NlcHQgVW5pY29kZSBvYmplY3RzLgoKLSBUaGUgc3RhbmRhcmQgaGVhZGVyIDxsaW1pdHMuaD4gaXMgbm93IGluY2x1ZGVkIGJ5IFB5dGhvbi5oIChpZiBpdAogIGV4aXN0cykuICBJTlRfTUFYIGFuZCBMT05HX01BWCB3aWxsIGFsd2F5cyBiZSBkZWZpbmVkLCBldmVuIGlmCiAgPGxpbWl0cy5oPiBpcyBub3QgYXZhaWxhYmxlLgoKLSBQeUZsb2F0X0Zyb21TdHJpbmcgdGFrZXMgYSBzZWNvbmQgYXJndW1lbnQsIHBlbmQsIHRoYXQgd2FzCiAgZWZmZWN0aXZlbHkgdXNlbGVzcy4gIEl0IGlzIG5vdyBvZmZpY2lhbGx5IHVzZWxlc3MgYnV0IHByZXNlcnZlZCBmb3IKICBiYWNrd2FyZHMgY29tcGF0aWJpbGl0eS4gIElmIHRoZSBwZW5kIGFyZ3VtZW50IGlzIG5vdCBOVUxMLCAqcGVuZCBpcwogIHNldCB0byBOVUxMLgoKLSBQeU9iamVjdF9HZXRBdHRyKCkgYW5kIFB5T2JqZWN0X1NldEF0dHIoKSBub3cgYWNjZXB0IFVuaWNvZGUgb2JqZWN0cwogIGZvciB0aGUgYXR0cmlidXRlIG5hbWUuICBTZWUgbm90ZSBvbiBnZXRhdHRyKCkgYWJvdmUuCgotIEEgZmV3IGJ1ZyBmaXhlcyB0byBhcmd1bWVudCBwcm9jZXNzaW5nIGZvciBVbmljb2RlLgogIFB5QXJnX1BhcnNlVHVwbGVBbmRLZXl3b3JkcygpIG5vdyBhY2NlcHRzICJlcyMiIGFuZCAiZXMiLgogIFB5QXJnX1BhcnNlKCkgc3BlY2lhbCBjYXNlcyAicyMiIGZvciBVbmljb2RlIG9iamVjdHM7IGl0IHJldHVybnMgYQogIHBvaW50ZXIgdG8gdGhlIGRlZmF1bHQgZW5jb2RlZCBzdHJpbmcgZGF0YSBpbnN0ZWFkIG9mIHRvIHRoZSByYXcKICBVVEYtMTYuCgotIFB5X0J1aWxkVmFsdWUgYWNjZXB0cyBCIGZvcm1hdCAoZm9yIGJnZW4tZ2VuZXJhdGVkIGNvZGUpLgoKCkludGVybmFscwoKLSBPbiBVbml4LCBmaXggY29kZSBmb3IgZmluZGluZyBQeXRob24gaW5zdGFsbGF0aW9uIGRpcmVjdG9yeSBzbyB0aGF0CiAgaXQgd29ya3Mgd2hlbiBhcmd2WzBdIGlzIGEgcmVsYXRpdmUgcGF0aC4KCi0gQWRkZWQgYSB0cnVlIHVuaWNvZGVfaW50ZXJuYWxfZW5jb2RlKCkgZnVuY3Rpb24gYW5kIGZpeGVkIHRoZQogIHVuaWNvZGVfaW50ZXJuYWxfZGVjb2RlIGZ1bmN0aW9uKCkgdG8gc3VwcG9ydCBVbmljb2RlIG9iamVjdHMgZGlyZWN0bHkKICByYXRoZXIgdGhhbiBieSBnZW5lcmF0aW5nIGEgY29weSBvZiB0aGUgb2JqZWN0LgoKLSBTZXZlcmFsIG9mIHRoZSBpbnRlcm5hbCBVbmljb2RlIHRhYmxlcyBhcmUgbXVjaCBzbWFsbGVyIG5vdywgYW5kCiAgdGhlIHNvdXJjZSBjb2RlIHNob3VsZCBiZSBtdWNoIGZyaWVuZGxpZXIgdG8gd2Vha2VyIGNvbXBpbGVycy4KCi0gSW4gdGhlIGdhcmJhZ2UgY29sbGVjdG9yOiBGaXhlZCBidWcgaW4gY29sbGVjdGlvbiBvZiB0dXBsZXMuICBGaXhlZAogIGJ1ZyB0aGF0IGNhdXNlZCBzb21lIGluc3RhbmNlcyB0byBiZSByZW1vdmVkIGZyb20gdGhlIGNvbnRhaW5lciBzZXQKICB3aGlsZSB0aGV5IHdlcmUgc3RpbGwgbGl2ZS4gIEZpeGVkIHBhcnNpbmcgaW4gZ2Muc2V0X2RlYnVnKCkgZm9yCiAgcGxhdGZvcm1zIHdoZXJlIHNpemVvZihsb25nKSA+IHNpemVvZihpbnQpLgoKLSBGaXhlZCByZWZjb3VudCBwcm9ibGVtIGluIGluc3RhbmNlIGRlYWxsb2NhdGlvbiB0aGF0IG9ubHkgb2NjdXJyZWQKICB3aGVuIFB5X1JFRl9ERUJVRyB3YXMgZGVmaW5lZCBhbmQgUHlfVFJBQ0VfUkVGUyB3YXMgbm90LgoKLSBPbiBXaW5kb3dzLCBnZXRweXRob25yZWdwYXRoIGlzIG5vdyBwcm90ZWN0ZWQgYWdhaW5zdCBudWxsIGRhdGEgaW4KICByZWdpc3RyeSBrZXkuCgotIE9uIFVuaXgsIGNyZWF0ZSAucHljLy5weW8gZmlsZXMgd2l0aCBPX0VYQ0wgZmxhZyB0byBhdm9pZCBhIHJhY2UKICBjb25kaXRpb24uCgoKQnVpbGQgYW5kIHBsYXRmb3JtLXNwZWNpZmljIGlzc3VlcwoKLSBCZXR0ZXIgc3VwcG9ydCBvZiBHTlUgUHRoIHZpYSAtLXdpdGgtcHRoIGNvbmZpZ3VyZSBvcHRpb24uCgotIFB5dGhvbi9DIEFQSSBub3cgcHJvcGVybHkgZXhwb3NlZCB0byBkeW5hbWljYWxseS1sb2FkZWQgZXh0ZW5zaW9uCiAgbW9kdWxlcyBvbiBSZWxpYW50IFVOSVguCgotIENoYW5nZXMgZm9yIHRoZSBiZW5lZml0IG9mIFN1bk9TIDQuMS40IChyZWFsbHkhKS4gIG1tYXBtb2R1bGUuYzoKICBEb24ndCBkZWZpbmUgTVNfU1lOQyB0byBiZSB6ZXJvIHdoZW4gaXQgaXMgdW5kZWZpbmVkLiAgQWRkZWQgbWlzc2luZwogIHByb3RvdHlwZXMgaW4gcG9zaXhtb2R1bGUuYy4KCi0gSW1wcm92ZWQgc3VwcG9ydCBmb3IgSFAtVVggYnVpbGQuICBUaHJlYWRzIHNob3VsZCBub3cgYmUgY29ycmVjdGx5CiAgY29uZmlndXJlZCAob24gSFAtVVggMTAuMjAgYW5kIDExLjAwKS4KCi0gRml4IGxhcmdlZmlsZSBzdXBwb3J0IG9uIG9sZGVyIE5ldEJTRCBzeXN0ZW1zIGFuZCBPcGVuQlNEIGJ5IGFkZGluZwogIGRlZmluZSBmb3IgVEVMTDY0LgoKClRvb2xzIGFuZCBvdGhlciBtaXNjZWxsYW55CgotIGZ0cG1pcnJvcjogQ2FsbCB0byBtYWluKCkgaXMgd3JhcHBlZCBpbiBpZiBfX25hbWVfXyA9PSAiX19tYWluX18iLgoKLSBmcmVlemU6IFRoZSBtb2R1bGVmaW5kZXIgbm93IHdvcmtzIHdpdGggMi4wIG9wY29kZXMuCgotIElETEU6CiAgTW92ZSBoYWNrZXJ5IG9mIHN5cy5hcmd2IHVudGlsIGFmdGVyIHRoZSBUayBpbnN0YW5jZSBoYXMgYmVlbgogIGNyZWF0ZWQsIHdoaWNoIGFsbG93cyB0aGUgYXBwbGljYXRpb24tc3BlY2lmaWMgVGtpbnRlcgogIGluaXRpYWxpemF0aW9uIHRvIGJlIGV4ZWN1dGVkIGlmIHByZXNlbnQ7IGFsc28gcGFzcyBhbiBleHBsaWNpdAogIGNsYXNzTmFtZSBwYXJhbWV0ZXIgdG8gdGhlIFRrKCkgY29uc3RydWN0b3IuCgoKV2hhdCdzIG5ldyBpbiAyLjAgYmV0YSAxPwo9PT09PT09PT09PT09PT09PT09PT09PT09CgpTb3VyY2UgSW5jb21wYXRpYmlsaXRpZXMKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpOb25lLiAgTm90ZSB0aGF0IDEuNiBpbnRyb2R1Y2VkIHNldmVyYWwgaW5jb21wYXRpYmlsaXRpZXMgd2l0aCAxLjUuMiwKc3VjaCBhcyBzaW5nbGUtYXJndW1lbnQgYXBwZW5kKCksIGNvbm5lY3QoKSBhbmQgYmluZCgpLCBhbmQgY2hhbmdlcyB0bwpzdHIobG9uZykgYW5kIHJlcHIoZmxvYXQpLgoKCkJpbmFyeSBJbmNvbXBhdGliaWxpdGllcwotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCi0gVGhpcmQgcGFydHkgZXh0ZW5zaW9ucyBidWlsdCBmb3IgUHl0aG9uIDEuNS54IG9yIDEuNiBjYW5ub3QgYmUgdXNlZAp3aXRoIFB5dGhvbiAyLjA7IHRoZXNlIGV4dGVuc2lvbnMgd2lsbCBoYXZlIHRvIGJlIHJlYnVpbHQgZm9yIFB5dGhvbgoyLjAuCgotIE9uIFdpbmRvd3MsIGF0dGVtcHRpbmcgdG8gaW1wb3J0IGEgdGhpcmQgcGFydHkgZXh0ZW5zaW9uIGJ1aWx0IGZvcgpQeXRob24gMS41Lnggb3IgMS42IHJlc3VsdHMgaW4gYW4gaW1tZWRpYXRlIGNyYXNoOyB0aGVyZSdzIG5vdCBtdWNoIHdlCmNhbiBkbyBhYm91dCB0aGlzLiAgQ2hlY2sgeW91ciBQWVRIT05QQVRIIGVudmlyb25tZW50IHZhcmlhYmxlIQoKLSBQeXRob24gYnl0ZWNvZGUgZmlsZXMgKCoucHljIGFuZCAqLnB5bykgYXJlIG5vdCBjb21wYXRpYmxlIGJldHdlZW4KcmVsZWFzZXMuCgoKT3ZlcnZpZXcgb2YgQ2hhbmdlcyBTaW5jZSAxLjYKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KClRoZXJlIGFyZSBtYW55IG5ldyBtb2R1bGVzIChpbmNsdWRpbmcgYnJhbmQgbmV3IFhNTCBzdXBwb3J0IHRocm91Z2gKdGhlIHhtbCBwYWNrYWdlLCBhbmQgaTE4biBzdXBwb3J0IHRocm91Z2ggdGhlIGdldHRleHQgbW9kdWxlKTsgYSBsaXN0Cm9mIGFsbCBuZXcgbW9kdWxlcyBpcyBpbmNsdWRlZCBiZWxvdy4gIExvdHMgb2YgYnVncyBoYXZlIGJlZW4gZml4ZWQuCgpUaGUgcHJvY2VzcyBmb3IgbWFraW5nIG1ham9yIG5ldyBjaGFuZ2VzIHRvIHRoZSBsYW5ndWFnZSBoYXMgY2hhbmdlZApzaW5jZSBQeXRob24gMS42LiAgRW5oYW5jZW1lbnRzIG11c3Qgbm93IGJlIGRvY3VtZW50ZWQgYnkgYSBQeXRob24KRW5oYW5jZW1lbnQgUHJvcG9zYWwgKFBFUCkgYmVmb3JlIHRoZXkgY2FuIGJlIGFjY2VwdGVkLgoKVGhlcmUgYXJlIHNldmVyYWwgaW1wb3J0YW50IHN5bnRheCBlbmhhbmNlbWVudHMsIGRlc2NyaWJlZCBpbiBtb3JlCmRldGFpbCBiZWxvdzoKCiAgLSBBdWdtZW50ZWQgYXNzaWdubWVudCwgZS5nLiB4ICs9IDEKCiAgLSBMaXN0IGNvbXByZWhlbnNpb25zLCBlLmcuIFt4KioyIGZvciB4IGluIHJhbmdlKDEwKV0KCiAgLSBFeHRlbmRlZCBpbXBvcnQgc3RhdGVtZW50LCBlLmcuIGltcG9ydCBNb2R1bGUgYXMgTmFtZQoKICAtIEV4dGVuZGVkIHByaW50IHN0YXRlbWVudCwgZS5nLiBwcmludCA+PiBmaWxlLCAiSGVsbG8iCgpPdGhlciBpbXBvcnRhbnQgY2hhbmdlczoKCiAgLSBPcHRpb25hbCBjb2xsZWN0aW9uIG9mIGN5Y2xpY2FsIGdhcmJhZ2UKClB5dGhvbiBFbmhhbmNlbWVudCBQcm9wb3NhbCAoUEVQKQotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KClBFUCBzdGFuZHMgZm9yIFB5dGhvbiBFbmhhbmNlbWVudCBQcm9wb3NhbC4gIEEgUEVQIGlzIGEgZGVzaWduCmRvY3VtZW50IHByb3ZpZGluZyBpbmZvcm1hdGlvbiB0byB0aGUgUHl0aG9uIGNvbW11bml0eSwgb3IgZGVzY3JpYmluZwphIG5ldyBmZWF0dXJlIGZvciBQeXRob24uICBUaGUgUEVQIHNob3VsZCBwcm92aWRlIGEgY29uY2lzZSB0ZWNobmljYWwKc3BlY2lmaWNhdGlvbiBvZiB0aGUgZmVhdHVyZSBhbmQgYSByYXRpb25hbGUgZm9yIHRoZSBmZWF0dXJlLgoKV2UgaW50ZW5kIFBFUHMgdG8gYmUgdGhlIHByaW1hcnkgbWVjaGFuaXNtcyBmb3IgcHJvcG9zaW5nIG5ldwpmZWF0dXJlcywgZm9yIGNvbGxlY3RpbmcgY29tbXVuaXR5IGlucHV0IG9uIGFuIGlzc3VlLCBhbmQgZm9yCmRvY3VtZW50aW5nIHRoZSBkZXNpZ24gZGVjaXNpb25zIHRoYXQgaGF2ZSBnb25lIGludG8gUHl0aG9uLiAgVGhlIFBFUAphdXRob3IgaXMgcmVzcG9uc2libGUgZm9yIGJ1aWxkaW5nIGNvbnNlbnN1cyB3aXRoaW4gdGhlIGNvbW11bml0eSBhbmQKZG9jdW1lbnRpbmcgZGlzc2VudGluZyBvcGluaW9ucy4KClRoZSBQRVBzIGFyZSBhdmFpbGFibGUgYXQgaHR0cDovL3B5dGhvbi5zb3VyY2Vmb3JnZS5uZXQvcGVwcy8uCgpBdWdtZW50ZWQgQXNzaWdubWVudAotLS0tLS0tLS0tLS0tLS0tLS0tLQoKVGhpcyBtdXN0IGhhdmUgYmVlbiB0aGUgbW9zdC1yZXF1ZXN0ZWQgZmVhdHVyZSBvZiB0aGUgcGFzdCB5ZWFycyEKRWxldmVuIG5ldyBhc3NpZ25tZW50IG9wZXJhdG9ycyB3ZXJlIGFkZGVkOgoKICAgICs9IC09ICo9IC89ICU9ICoqPSA8PD0gPj49ICY9IF49IHw9CgpGb3IgZXhhbXBsZSwKCiAgICBBICs9IEIKCmlzIHNpbWlsYXIgdG8KCiAgICBBID0gQSArIEIKCmV4Y2VwdCB0aGF0IEEgaXMgZXZhbHVhdGVkIG9ubHkgb25jZSAocmVsZXZhbnQgd2hlbiBBIGlzIHNvbWV0aGluZwpsaWtlIGRpY3RbaW5kZXhdLmF0dHIpLgoKSG93ZXZlciwgaWYgQSBpcyBhIG11dGFibGUgb2JqZWN0LCBBIG1heSBiZSBtb2RpZmllZCBpbiBwbGFjZS4gIFRodXMsCmlmIEEgaXMgYSBudW1iZXIgb3IgYSBzdHJpbmcsIEEgKz0gQiBoYXMgdGhlIHNhbWUgZWZmZWN0IGFzIEEgPSBBK0IKKGV4Y2VwdCBBIGlzIG9ubHkgZXZhbHVhdGVkIG9uY2UpOyBidXQgaWYgYSBpcyBhIGxpc3QsIEEgKz0gQiBoYXMgdGhlCnNhbWUgZWZmZWN0IGFzIEEuZXh0ZW5kKEIpIQoKQ2xhc3NlcyBhbmQgYnVpbHQtaW4gb2JqZWN0IHR5cGVzIGNhbiBvdmVycmlkZSB0aGUgbmV3IG9wZXJhdG9ycyBpbgpvcmRlciB0byBpbXBsZW1lbnQgdGhlIGluLXBsYWNlIGJlaGF2aW9yOyB0aGUgbm90LWluLXBsYWNlIGJlaGF2aW9yIGlzCnVzZWQgYXV0b21hdGljYWxseSBhcyBhIGZhbGxiYWNrIHdoZW4gYW4gb2JqZWN0IGRvZXNuJ3QgaW1wbGVtZW50IHRoZQppbi1wbGFjZSBiZWhhdmlvci4gIEZvciBjbGFzc2VzLCB0aGUgbWV0aG9kIG5hbWUgaXMgZGVyaXZlZCBmcm9tIHRoZQptZXRob2QgbmFtZSBmb3IgdGhlIGNvcnJlc3BvbmRpbmcgbm90LWluLXBsYWNlIG9wZXJhdG9yIGJ5IGluc2VydGluZwphbiAnaScgaW4gZnJvbnQgb2YgdGhlIG5hbWUsIGUuZy4gX19pYWRkX18gaW1wbGVtZW50cyBpbi1wbGFjZQpfX2FkZF9fLgoKQXVnbWVudGVkIGFzc2lnbm1lbnQgd2FzIGltcGxlbWVudGVkIGJ5IFRob21hcyBXb3V0ZXJzLgoKCkxpc3QgQ29tcHJlaGVuc2lvbnMKLS0tLS0tLS0tLS0tLS0tLS0tLQoKVGhpcyBpcyBhIGZsZXhpYmxlIG5ldyBub3RhdGlvbiBmb3IgbGlzdHMgd2hvc2UgZWxlbWVudHMgYXJlIGNvbXB1dGVkCmZyb20gYW5vdGhlciBsaXN0IChvciBsaXN0cykuICBUaGUgc2ltcGxlc3QgZm9ybSBpczoKCiAgICBbPGV4cHJlc3Npb24+IGZvciA8dmFyaWFibGU+IGluIDxzZXF1ZW5jZT5dCgpGb3IgZXhhbXBsZSwgW2kqKjIgZm9yIGkgaW4gcmFuZ2UoNCldIHlpZWxkcyB0aGUgbGlzdCBbMCwgMSwgNCwgOV0uClRoaXMgaXMgbW9yZSBlZmZpY2llbnQgdGhhbiBhIGZvciBsb29wIHdpdGggYSBsaXN0LmFwcGVuZCgpIGNhbGwuCgpZb3UgY2FuIGFsc28gYWRkIGEgY29uZGl0aW9uOgoKICAgIFs8ZXhwcmVzc2lvbj4gZm9yIDx2YXJpYWJsZT4gaW4gPHNlcXVlbmNlPiBpZiA8Y29uZGl0aW9uPl0KCkZvciBleGFtcGxlLCBbdyBmb3IgdyBpbiB3b3JkcyBpZiB3ID09IHcubG93ZXIoKV0gd291bGQgeWllbGQgdGhlIGxpc3QKb2Ygd29yZHMgdGhhdCBjb250YWluIG5vIHVwcGVyY2FzZSBjaGFyYWN0ZXJzLiAgVGhpcyBpcyBtb3JlIGVmZmljaWVudAp0aGFuIGEgZm9yIGxvb3Agd2l0aCBhbiBpZiBzdGF0ZW1lbnQgYW5kIGEgbGlzdC5hcHBlbmQoKSBjYWxsLgoKWW91IGNhbiBhbHNvIGhhdmUgbmVzdGVkIGZvciBsb29wcyBhbmQgbW9yZSB0aGFuIG9uZSAnaWYnIGNsYXVzZS4gIEZvcgpleGFtcGxlLCBoZXJlJ3MgYSBmdW5jdGlvbiB0aGF0IGZsYXR0ZW5zIGEgc2VxdWVuY2Ugb2Ygc2VxdWVuY2VzOjoKCiAgICBkZWYgZmxhdHRlbihzZXEpOgogICAgICAgIHJldHVybiBbeCBmb3Igc3Vic2VxIGluIHNlcSBmb3IgeCBpbiBzdWJzZXFdCgogICAgZmxhdHRlbihbWzBdLCBbMSwyLDNdLCBbNCw1XSwgWzYsNyw4LDldLCBbXV0pCgpUaGlzIHByaW50cwoKICAgIFswLCAxLCAyLCAzLCA0LCA1LCA2LCA3LCA4LCA5XQoKTGlzdCBjb21wcmVoZW5zaW9ucyBvcmlnaW5hdGVkIGFzIGEgcGF0Y2ggc2V0IGZyb20gR3JlZyBFd2luZzsgU2tpcApNb250YW5hcm8gYW5kIFRob21hcyBXb3V0ZXJzIGFsc28gY29udHJpYnV0ZWQuICBEZXNjcmliZWQgYnkgUEVQIDIwMi4KCgpFeHRlbmRlZCBJbXBvcnQgU3RhdGVtZW50Ci0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCk1hbnkgcGVvcGxlIGhhdmUgYXNrZWQgZm9yIGEgd2F5IHRvIGltcG9ydCBhIG1vZHVsZSB1bmRlciBhIGRpZmZlcmVudApuYW1lLiAgVGhpcyBjYW4gYmUgYWNjb21wbGlzaGVkIGxpa2UgdGhpczoKCiAgICBpbXBvcnQgZm9vCiAgICBiYXIgPSBmb28KICAgIGRlbCBmb28KCmJ1dCB0aGlzIGNvbW1vbiBpZGlvbSBnZXRzIG9sZCBxdWlja2x5LiAgQSBzaW1wbGUgZXh0ZW5zaW9uIG9mIHRoZQppbXBvcnQgc3RhdGVtZW50IG5vdyBhbGxvd3MgdGhpcyB0byBiZSB3cml0dGVuIGFzIGZvbGxvd3M6CgogICAgaW1wb3J0IGZvbyBhcyBiYXIKClRoZXJlJ3MgYWxzbyBhIHZhcmlhbnQgZm9yICdmcm9tIC4uLiBpbXBvcnQnOgoKICAgIGZyb20gZm9vIGltcG9ydCBiYXIgYXMgc3BhbQoKVGhpcyBhbHNvIHdvcmtzIHdpdGggcGFja2FnZXM7IGUuZy4geW91IGNhbiB3cml0ZSB0aGlzOgoKICAgIGltcG9ydCB0ZXN0LnJlZ3J0ZXN0IGFzIHJlZ3J0ZXN0CgpOb3RlIHRoYXQgJ2FzJyBpcyBub3QgYSBuZXcga2V5d29yZCAtLSBpdCBpcyByZWNvZ25pemVkIG9ubHkgaW4gdGhpcwpjb250ZXh0ICh0aGlzIGlzIG9ubHkgcG9zc2libGUgYmVjYXVzZSB0aGUgc3ludGF4IGZvciB0aGUgaW1wb3J0CnN0YXRlbWVudCBkb2Vzbid0IGludm9sdmUgZXhwcmVzc2lvbnMpLgoKSW1wbGVtZW50ZWQgYnkgVGhvbWFzIFdvdXRlcnMuICBEZXNjcmliZWQgYnkgUEVQIDIyMS4KCgpFeHRlbmRlZCBQcmludCBTdGF0ZW1lbnQKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpFYXNpbHkgdGhlIG1vc3QgY29udHJvdmVyc2lhbCBuZXcgZmVhdHVyZSwgdGhpcyBleHRlbnNpb24gdG8gdGhlIHByaW50CnN0YXRlbWVudCBhZGRzIGFuIG9wdGlvbiB0byBtYWtlIHRoZSBvdXRwdXQgZ28gdG8gYSBkaWZmZXJlbnQgZmlsZQp0aGFuIHRoZSBkZWZhdWx0IHN5cy5zdGRvdXQuCgpGb3IgZXhhbXBsZSwgdG8gd3JpdGUgYW4gZXJyb3IgbWVzc2FnZSB0byBzeXMuc3RkZXJyLCB5b3UgY2FuIG5vdwp3cml0ZToKCiAgICBwcmludCA+PiBzeXMuc3RkZXJyLCAiRXJyb3I6IGJhZCBkb2chIgoKQXMgYSBzcGVjaWFsIGZlYXR1cmUsIGlmIHRoZSBleHByZXNzaW9uIHVzZWQgdG8gaW5kaWNhdGUgdGhlIGZpbGUKZXZhbHVhdGVzIHRvIE5vbmUsIHRoZSBjdXJyZW50IHZhbHVlIG9mIHN5cy5zdGRvdXQgaXMgdXNlZC4gIFRodXM6CgogICAgcHJpbnQgPj4gTm9uZSwgIkhlbGxvIHdvcmxkIgoKaXMgZXF1aXZhbGVudCB0bwoKICAgIHByaW50ICJIZWxsbyB3b3JsZCIKCkRlc2lnbiBhbmQgaW1wbGVtZW50YXRpb24gYnkgQmFycnkgV2Fyc2F3LiAgRGVzY3JpYmVkIGJ5IFBFUCAyMTQuCgoKT3B0aW9uYWwgQ29sbGVjdGlvbiBvZiBDeWNsaWNhbCBHYXJiYWdlCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKUHl0aG9uIGlzIG5vdyBlcXVpcHBlZCB3aXRoIGEgZ2FyYmFnZSBjb2xsZWN0b3IgdGhhdCBjYW4gaHVudCBkb3duCmN5Y2xpY2FsIHJlZmVyZW5jZXMgYmV0d2VlbiBQeXRob24gb2JqZWN0cy4gIEl0J3Mgbm8gcmVwbGFjZW1lbnQgZm9yCnJlZmVyZW5jZSBjb3VudGluZzsgaW4gZmFjdCwgaXQgZGVwZW5kcyBvbiB0aGUgcmVmZXJlbmNlIGNvdW50cyBiZWluZwpjb3JyZWN0LCBhbmQgZGVjaWRlcyB0aGF0IGEgc2V0IG9mIG9iamVjdHMgYmVsb25nIHRvIGEgY3ljbGUgaWYgYWxsCnRoZWlyIHJlZmVyZW5jZSBjb3VudHMgY2FuIGJlIGFjY291bnRlZCBmb3IgZnJvbSB0aGVpciByZWZlcmVuY2VzIHRvCmVhY2ggb3RoZXIuICBUaGlzIGRldmlvdXMgc2NoZW1lIHdhcyBmaXJzdCBwcm9wb3NlZCBieSBFcmljIFRpZWRlbWFubiwKYW5kIGJyb3VnaHQgdG8gaW1wbGVtZW50YXRpb24gYnkgTmVpbCBTY2hlbWVuYXVlci4KClRoZXJlJ3MgYSBtb2R1bGUgImdjIiB0aGF0IGxldHMgeW91IGNvbnRyb2wgc29tZSBwYXJhbWV0ZXJzIG9mIHRoZQpnYXJiYWdlIGNvbGxlY3Rpb24uICBUaGVyZSdzIGFsc28gYW4gb3B0aW9uIHRvIHRoZSBjb25maWd1cmUgc2NyaXB0CnRoYXQgbGV0cyB5b3UgZW5hYmxlIG9yIGRpc2FibGUgdGhlIGdhcmJhZ2UgY29sbGVjdGlvbi4gIEluIDIuMGIxLAppdCdzIG9uIGJ5IGRlZmF1bHQsIHNvIHRoYXQgd2UgKGhvcGVmdWxseSkgY2FuIGNvbGxlY3QgZGVjZW50IHVzZXIKZXhwZXJpZW5jZSB3aXRoIHRoaXMgbmV3IGZlYXR1cmUuICBUaGVyZSBhcmUgc29tZSBxdWVzdGlvbnMgYWJvdXQgaXRzCnBlcmZvcm1hbmNlLiAgSWYgaXQgcHJvdmVzIHRvIGJlIHRvbyBtdWNoIG9mIGEgcHJvYmxlbSwgd2UnbGwgdHVybiBpdApvZmYgYnkgZGVmYXVsdCBpbiB0aGUgZmluYWwgMi4wIHJlbGVhc2UuCgoKU21hbGxlciBDaGFuZ2VzCi0tLS0tLS0tLS0tLS0tLQoKQSBuZXcgZnVuY3Rpb24gemlwKCkgd2FzIGFkZGVkLiAgemlwKHNlcTEsIHNlcTIsIC4uLikgaXMgZXF1aXZhbGVudCB0bwptYXAoTm9uZSwgc2VxMSwgc2VxMiwgLi4uKSB3aGVuIHRoZSBzZXF1ZW5jZXMgaGF2ZSB0aGUgc2FtZSBsZW5ndGg7CmkuZS4gemlwKFsxLDIsM10sIFsxMCwyMCwzMF0pIHJldHVybnMgWygxLDEwKSwgKDIsMjApLCAoMywzMCldLiAgV2hlbgp0aGUgbGlzdHMgYXJlIG5vdCBhbGwgdGhlIHNhbWUgbGVuZ3RoLCB0aGUgc2hvcnRlc3QgbGlzdCB3aW5zOgp6aXAoWzEsMiwzXSwgWzEwLDIwXSkgcmV0dXJucyBbKDEsMTApLCAoMiwyMCldLiAgU2VlIFBFUCAyMDEuCgpzeXMudmVyc2lvbl9pbmZvIGlzIGEgdHVwbGUgKG1ham9yLCBtaW5vciwgbWljcm8sIGxldmVsLCBzZXJpYWwpLgoKRGljdGlvbmFyaWVzIGhhdmUgYW4gb2RkIG5ldyBtZXRob2QsIHNldGRlZmF1bHQoa2V5LCBkZWZhdWx0KS4KZGljdC5zZXRkZWZhdWx0KGtleSwgZGVmYXVsdCkgcmV0dXJucyBkaWN0W2tleV0gaWYgaXQgZXhpc3RzOyBpZiBub3QsCml0IHNldHMgZGljdFtrZXldIHRvIGRlZmF1bHQgYW5kIHJldHVybnMgdGhhdCB2YWx1ZS4gIFRodXM6CgogICAgZGljdC5zZXRkZWZhdWx0KGtleSwgW10pLmFwcGVuZChpdGVtKQoKZG9lcyB0aGUgc2FtZSB3b3JrIGFzIHRoaXMgY29tbW9uIGlkaW9tOgoKICAgIGlmIG5vdCBkaWN0Lmhhc19rZXkoa2V5KToKICAgICAgICBkaWN0W2tleV0gPSBbXQogICAgZGljdFtrZXldLmFwcGVuZChpdGVtKQoKVGhlcmUgYXJlIHR3byBuZXcgdmFyaWFudHMgb2YgU3ludGF4RXJyb3IgdGhhdCBhcmUgcmFpc2VkIGZvcgppbmRlbnRhdGlvbi1yZWxhdGVkIGVycm9yczogSW5kZW50YXRpb25FcnJvciBhbmQgVGFiRXJyb3IuCgpDaGFuZ2VkIFx4IHRvIGNvbnN1bWUgZXhhY3RseSB0d28gaGV4IGRpZ2l0czsgc2VlIFBFUCAyMjMuICBBZGRlZCBcVQplc2NhcGUgdGhhdCBjb25zdW1lcyBleGFjdGx5IGVpZ2h0IGhleCBkaWdpdHMuCgpUaGUgbGltaXRzIG9uIHRoZSBzaXplIG9mIGV4cHJlc3Npb25zIGFuZCBmaWxlIGluIFB5dGhvbiBzb3VyY2UgY29kZQpoYXZlIGJlZW4gcmFpc2VkIGZyb20gMioqMTYgdG8gMioqMzIuICBQcmV2aW91cyB2ZXJzaW9ucyBvZiBQeXRob24Kd2VyZSBsaW1pdGVkIGJlY2F1c2UgdGhlIG1heGltdW0gYXJndW1lbnQgc2l6ZSB0aGUgUHl0aG9uIFZNIGFjY2VwdGVkCndhcyAyKioxNi4gIFRoaXMgbGltaXRlZCB0aGUgc2l6ZSBvZiBvYmplY3QgY29uc3RydWN0b3IgZXhwcmVzc2lvbnMsCmUuZy4gWzEsMiwzXSBvciB7J2EnOjEsICdiJzoyfSwgYW5kIHRoZSBzaXplIG9mIHNvdXJjZSBmaWxlcy4gIFRoaXMKbGltaXQgd2FzIHJhaXNlZCB0aGFua3MgdG8gYSBwYXRjaCBieSBDaGFybGVzIFdhbGRtYW4gdGhhdCBlZmZlY3RpdmVseQpmaXhlcyB0aGUgcHJvYmxlbS4gIEl0IGlzIG5vdyBtdWNoIG1vcmUgbGlrZWx5IHRoYXQgeW91IHdpbGwgYmUKbGltaXRlZCBieSBhdmFpbGFibGUgbWVtb3J5IHRoYW4gYnkgYW4gYXJiaXRyYXJ5IGxpbWl0IGluIFB5dGhvbi4KClRoZSBpbnRlcnByZXRlcidzIG1heGltdW0gcmVjdXJzaW9uIGRlcHRoIGNhbiBiZSBtb2RpZmllZCBieSBQeXRob24KcHJvZ3JhbXMgdXNpbmcgc3lzLmdldHJlY3Vyc2lvbmxpbWl0IGFuZCBzeXMuc2V0cmVjdXJzaW9ubGltaXQuICBUaGlzCmxpbWl0IGlzIHRoZSBtYXhpbXVtIG51bWJlciBvZiByZWN1cnNpdmUgY2FsbHMgdGhhdCBjYW4gYmUgbWFkZSBieQpQeXRob24gY29kZS4gIFRoZSBsaW1pdCBleGlzdHMgdG8gcHJldmVudCBpbmZpbml0ZSByZWN1cnNpb24gZnJvbQpvdmVyZmxvd2luZyB0aGUgQyBzdGFjayBhbmQgY2F1c2luZyBhIGNvcmUgZHVtcC4gIFRoZSBkZWZhdWx0IHZhbHVlIGlzCjEwMDAuICBUaGUgbWF4aW11bSBzYWZlIHZhbHVlIGZvciBhIHBhcnRpY3VsYXIgcGxhdGZvcm0gY2FuIGJlIGZvdW5kCmJ5IHJ1bm5pbmcgTWlzYy9maW5kX3JlY3Vyc2lvbmxpbWl0LnB5LgoKTmV3IE1vZHVsZXMgYW5kIFBhY2thZ2VzCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKYXRleGl0IC0gZm9yIHJlZ2lzdGVyaW5nIGZ1bmN0aW9ucyB0byBiZSBjYWxsZWQgd2hlbiBQeXRob24gZXhpdHMuCgppbXB1dGlsIC0gR3JlZyBTdGVpbidzIGFsdGVybmF0aXZlIEFQSSBmb3Igd3JpdGluZyBjdXN0b20gaW1wb3J0Cmhvb2tzLgoKcHlleHBhdCAtIGFuIGludGVyZmFjZSB0byB0aGUgRXhwYXQgWE1MIHBhcnNlciwgY29udHJpYnV0ZWQgYnkgUGF1bApQcmVzY29kLgoKeG1sIC0gYSBuZXcgcGFja2FnZSB3aXRoIFhNTCBzdXBwb3J0IGNvZGUgb3JnYW5pemVkIChzbyBmYXIpIGluIHRocmVlCnN1YnBhY2thZ2VzOiB4bWwuZG9tLCB4bWwuc2F4LCBhbmQgeG1sLnBhcnNlcnMuICBEZXNjcmliaW5nIHRoZXNlCndvdWxkIGZpbGwgYSB2b2x1bWUuICBUaGVyZSdzIGEgc3BlY2lhbCBmZWF0dXJlIHdoZXJlYnkgYQp1c2VyLWluc3RhbGxlZCBwYWNrYWdlIG5hbWVkIF94bWxwbHVzIG92ZXJyaWRlcyB0aGUgc3RhbmRhcmQKeG1scGFja2FnZTsgdGhpcyBpcyBpbnRlbmRlZCB0byBnaXZlIHRoZSBYTUwgU0lHIGEgaG9vayB0byBkaXN0cmlidXRlCmJhY2t3YXJkcy1jb21wYXRpYmxlIHVwZGF0ZXMgdG8gdGhlIHN0YW5kYXJkIHhtbCBwYWNrYWdlLgoKd2ViYnJvd3NlciAtIGEgcGxhdGZvcm0taW5kZXBlbmRlbnQgQVBJIHRvIGxhdW5jaCBhIHdlYiBicm93c2VyLgoKCkNoYW5nZWQgTW9kdWxlcwotLS0tLS0tLS0tLS0tLS0KCmFycmF5IC0tIG5ldyBtZXRob2RzIGZvciBhcnJheSBvYmplY3RzOiBjb3VudCwgZXh0ZW5kLCBpbmRleCwgcG9wLCBhbmQKcmVtb3ZlCgpiaW5hc2NpaSAtLSBuZXcgZnVuY3Rpb25zIGIyYV9oZXggYW5kIGEyYl9oZXggdGhhdCBjb252ZXJ0IGJldHdlZW4KYmluYXJ5IGRhdGEgYW5kIGl0cyBoZXggcmVwcmVzZW50YXRpb24KCmNhbGVuZGFyIC0tIE1hbnkgbmV3IGZ1bmN0aW9ucyB0aGF0IHN1cHBvcnQgZmVhdHVyZXMgaW5jbHVkaW5nIGNvbnRyb2wKb3ZlciB3aGljaCBkYXkgb2YgdGhlIHdlZWsgaXMgdGhlIGZpcnN0IGRheSwgcmV0dXJuaW5nIHN0cmluZ3MgaW5zdGVhZApvZiBwcmludGluZyB0aGVtLiAgQWxzbyBuZXcgc3ltYm9saWMgY29uc3RhbnRzIGZvciBkYXlzIG9mIHdlZWssCmUuZy4gTU9OREFZLCAuLi4sIFNVTkRBWS4KCmNnaSAtLSBGaWVsZFN0b3JhZ2Ugb2JqZWN0cyBoYXZlIGEgZ2V0dmFsdWUgbWV0aG9kIHRoYXQgd29ya3MgbGlrZSBhCmRpY3Rpb25hcnkncyBnZXQgbWV0aG9kIGFuZCByZXR1cm5zIHRoZSB2YWx1ZSBhdHRyaWJ1dGUgb2YgdGhlIG9iamVjdC4KCkNvbmZpZ1BhcnNlciAtLSBUaGUgcGFyc2VyIG9iamVjdCBoYXMgbmV3IG1ldGhvZHMgaGFzX29wdGlvbiwKcmVtb3ZlX3NlY3Rpb24sIHJlbW92ZV9vcHRpb24sIHNldCwgYW5kIHdyaXRlLiAgVGhleSBhbGxvdyB0aGUgbW9kdWxlCnRvIGJlIHVzZWQgZm9yIHdyaXRpbmcgY29uZmlnIGZpbGVzIGFzIHdlbGwgYXMgcmVhZGluZyB0aGVtLgoKZnRwbGliIC0tIG50cmFuc2ZlcmNtZCgpLCB0cmFuc2ZlcmNtZCgpLCBhbmQgcmV0cmJpbmFyeSgpIGFsbCBub3cKb3B0aW9uYWxseSBzdXBwb3J0IHRoZSBSRkMgOTU5IFJFU1QgY29tbWFuZC4KCmd6aXAgLS0gcmVhZGxpbmUgYW5kIHJlYWRsaW5lcyBub3cgYWNjZXB0IG9wdGlvbmFsIHNpemUgYXJndW1lbnRzCgpodHRwbGliIC0tIE5ldyBpbnRlcmZhY2VzIGFuZCBzdXBwb3J0IGZvciBIVFRQLzEuMSBieSBHcmVnIFN0ZWluLiAgU2VlCnRoZSBtb2R1bGUgZG9jIHN0cmluZ3MgZm9yIGRldGFpbHMuCgpsb2NhbGUgLS0gaW1wbGVtZW50IGdldGRlZmF1bHRsb2NhbGUgZm9yIFdpbjMyIGFuZCBNYWNpbnRvc2gKCm1hcnNoYWwgLS0gbm8gbG9uZ2VyIGR1bXBzIGNvcmUgd2hlbiBtYXJzaGFsaW5nIGRlZXBseSBuZXN0ZWQgb3IKcmVjdXJzaXZlIGRhdGEgc3RydWN0dXJlcwoKb3MgLS0gbmV3IGZ1bmN0aW9ucyBpc2F0dHksIHNldGV1aWQsIHNldGVnaWQsIHNldHJldWlkLCBzZXRyZWdpZAoKb3MvcG9wZW4yIC0tIHBvcGVuMi9wb3BlbjMvcG9wZW40IHN1cHBvcnQgdW5kZXIgV2luZG93cy4gIHBvcGVuMi9wb3BlbjMKc3VwcG9ydCB1bmRlciBVbml4LgoKb3MvcHR5IC0tIHN1cHBvcnQgZm9yIG9wZW5wdHkgYW5kIGZvcmtwdHkKCm9zLnBhdGggLS0gZml4IHNlbWFudGljcyBvZiBvcy5wYXRoLmNvbW1vbnByZWZpeAoKc210cGxpYiAtLSBzdXBwb3J0IGZvciBzZW5kaW5nIHZlcnkgbG9uZyBtZXNzYWdlcwoKc29ja2V0IC0tIG5ldyBmdW5jdGlvbiBnZXRmcWRuKCkKCnJlYWRsaW5lIC0tIG5ldyBmdW5jdGlvbnMgdG8gcmVhZCwgd3JpdGUgYW5kIHRydW5jYXRlIGhpc3RvcnkgZmlsZXMuClRoZSByZWFkbGluZSBzZWN0aW9uIG9mIHRoZSBsaWJyYXJ5IHJlZmVyZW5jZSBtYW51YWwgY29udGFpbnMgYW4KZXhhbXBsZS4KCnNlbGVjdCAtLSBhZGQgaW50ZXJmYWNlIHRvIHBvbGwgc3lzdGVtIGNhbGwKCnNodXRpbCAtLSBuZXcgY29weWZpbGVvYmogZnVuY3Rpb24KClNpbXBsZUhUVFBTZXJ2ZXIsIENHSUhUVFBTZXJ2ZXIgLS0gRml4IHByb2JsZW1zIHdpdGggYnVmZmVyaW5nIGluIHRoZQpIVFRQIHNlcnZlci4KClRraW50ZXIgLS0gb3B0aW1pemF0aW9uIG9mIGZ1bmN0aW9uIGZsYXR0ZW4KCnVybGxpYiAtLSBzY2FucyBlbnZpcm9ubWVudCB2YXJpYWJsZXMgZm9yIHByb3h5IGNvbmZpZ3VyYXRpb24sCmUuZy4gaHR0cF9wcm94eS4KCndoaWNoZGIgLS0gcmVjb2duaXplcyBkdW1iZGJtIGZvcm1hdAoKCk9ic29sZXRlIE1vZHVsZXMKLS0tLS0tLS0tLS0tLS0tLQoKTm9uZS4gIEhvd2V2ZXIgbm90ZSB0aGF0IDEuNiBtYWRlIGEgd2hvbGUgc2xldyBvZiBtb2R1bGVzIG9ic29sZXRlOgpzdGR3aW4sIHNvdW5kZXgsIGNtbCwgY21wY2FjaGUsIGRpcmNhY2hlLCBkdW1wLCBmaW5kLCBncmVwLCBwYWNrbWFpbCwKcG9seSwgem1vZCwgc3Ryb3AsIHV0aWwsIHdoYXRzb3VuZC4KCgpDaGFuZ2VkLCBOZXcsIE9ic29sZXRlIFRvb2xzCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCk5vbmUuCgoKQy1sZXZlbCBDaGFuZ2VzCi0tLS0tLS0tLS0tLS0tLQoKU2V2ZXJhbCBjbGVhbnVwIGpvYnMgd2VyZSBjYXJyaWVkIG91dCB0aHJvdWdob3V0IHRoZSBzb3VyY2UgY29kZS4KCkFsbCBDIGNvZGUgd2FzIGNvbnZlcnRlZCB0byBBTlNJIEM7IHdlIGdvdCByaWQgb2YgYWxsIHVzZXMgb2YgdGhlClB5X1BST1RPKCkgbWFjcm8sIHdoaWNoIG1ha2VzIHRoZSBoZWFkZXIgZmlsZXMgYSBsb3QgbW9yZSByZWFkYWJsZS4KCk1vc3Qgb2YgdGhlIHBvcnRhYmlsaXR5IGhhY2tzIHdlcmUgbW92ZWQgdG8gYSBuZXcgaGVhZGVyIGZpbGUsCnB5cG9ydC5oOyBzZXZlcmFsIG90aGVyIG5ldyBoZWFkZXIgZmlsZXMgd2VyZSBhZGRlZCBhbmQgc29tZSBvbGQKaGVhZGVyIGZpbGVzIHdlcmUgcmVtb3ZlZCwgaW4gYW4gYXR0ZW1wdCB0byBjcmVhdGUgYSBtb3JlIHJhdGlvbmFsIHNldApvZiBoZWFkZXIgZmlsZXMuICAoRmV3IG9mIHRoZXNlIGV2ZXIgbmVlZCB0byBiZSBpbmNsdWRlZCBleHBsaWNpdGx5Owp0aGV5IGFyZSBhbGwgaW5jbHVkZWQgYnkgUHl0aG9uLmguKQoKVHJlbnQgTWljayBlbnN1cmVkIHBvcnRhYmlsaXR5IHRvIDY0LWJpdCBwbGF0Zm9ybXMsIHVuZGVyIGJvdGggTGludXgKYW5kIFdpbjY0LCBlc3BlY2lhbGx5IGZvciB0aGUgbmV3IEludGVsIEl0YW5pdW0gcHJvY2Vzc29yLiAgTWljayBhbHNvCmFkZGVkIGxhcmdlIGZpbGUgc3VwcG9ydCBmb3IgTGludXg2NCBhbmQgV2luNjQuCgpUaGUgQyBBUElzIHRvIHJldHVybiBhbiBvYmplY3QncyBzaXplIGhhdmUgYmVlbiB1cGRhdGUgdG8gY29uc2lzdGVudGx5CnVzZSB0aGUgZm9ybSBQeVhYWF9TaXplLCBlLmcuIFB5U2VxdWVuY2VfU2l6ZSBhbmQgUHlEaWN0X1NpemUuICBJbgpwcmV2aW91cyB2ZXJzaW9ucywgdGhlIGFic3RyYWN0IGludGVyZmFjZXMgdXNlZCBQeVhYWF9MZW5ndGggYW5kIHRoZQpjb25jcmV0ZSBpbnRlcmZhY2VzIHVzZWQgUHlYWFhfU2l6ZS4gIFRoZSBvbGQgbmFtZXMsCmUuZy4gUHlPYmplY3RfTGVuZ3RoLCBhcmUgc3RpbGwgYXZhaWxhYmxlIGZvciBiYWNrd2FyZHMgY29tcGF0aWJpbGl0eQphdCB0aGUgQVBJIGxldmVsLCBidXQgYXJlIGRlcHJlY2F0ZWQuCgpUaGUgUHlPU19DaGVja1N0YWNrIGZ1bmN0aW9uIGhhcyBiZWVuIGltcGxlbWVudGVkIG9uIFdpbmRvd3MgYnkKRnJlZHJpayBMdW5kaC4gIEl0IHByZXZlbnRzIFB5dGhvbiBmcm9tIGZhaWxpbmcgd2l0aCBhIHN0YWNrIG92ZXJmbG93Cm9uIFdpbmRvd3MuCgpUaGUgR0MgY2hhbmdlcyByZXN1bHRlZCBpbiBjcmVhdGlvbiBvZiB0d28gbmV3IHNsb3RzIG9uIG9iamVjdCwKdHBfdHJhdmVyc2UgYW5kIHRwX2NsZWFyLiAgVGhlIGF1Z21lbnRlZCBhc3NpZ25tZW50IGNoYW5nZXMgcmVzdWx0IGluCnRoZSBjcmVhdGlvbiBvZiBhIG5ldyBzbG90IGZvciBlYWNoIGluLXBsYWNlIG9wZXJhdG9yLgoKVGhlIEdDIEFQSSBjcmVhdGVzIG5ldyByZXF1aXJlbWVudHMgZm9yIGNvbnRhaW5lciB0eXBlcyBpbXBsZW1lbnRlZCBpbgpDIGV4dGVuc2lvbiBtb2R1bGVzLiAgU2VlIEluY2x1ZGUvb2JqaW1wbC5oIGZvciBkZXRhaWxzLgoKUHlFcnJfRm9ybWF0IGhhcyBiZWVuIHVwZGF0ZWQgdG8gYXV0b21hdGljYWxseSBjYWxjdWxhdGUgdGhlIHNpemUgb2YKdGhlIGJ1ZmZlciBuZWVkZWQgdG8gaG9sZCB0aGUgZm9ybWF0dGVkIHJlc3VsdCBzdHJpbmcuICBUaGlzIGNoYW5nZQpwcmV2ZW50cyBjcmFzaGVzIGNhdXNlZCBieSBwcm9ncmFtbWVyIGVycm9yLgoKTmV3IEMgQVBJIGNhbGxzOiBQeU9iamVjdF9Bc0ZpbGVEZXNjcmlwdG9yLCBQeUVycl9Xcml0ZVVucmFpc2FibGUuCgpQeVJ1bl9BbnlGaWxlRXgsIFB5UnVuX1NpbXBsZUZpbGVFeCwgUHlSdW5fRmlsZUV4IC0tIE5ldyBmdW5jdGlvbnMKdGhhdCBhcmUgdGhlIHNhbWUgYXMgdGhlaXIgbm9uLUV4IGNvdW50ZXJwYXJ0cyBleGNlcHQgdGhleSB0YWtlIGFuCmV4dHJhIGZsYWcgYXJndW1lbnQgdGhhdCB0ZWxscyB0aGVtIHRvIGNsb3NlIHRoZSBmaWxlIHdoZW4gZG9uZS4KClhYWCBUaGVyZSB3ZXJlIG90aGVyIEFQSSBjaGFuZ2VzIHRoYXQgc2hvdWxkIGJlIGZsZXNoZWQgb3V0IGhlcmUuCgoKV2luZG93cyBDaGFuZ2VzCi0tLS0tLS0tLS0tLS0tLQoKTmV3IHBvcGVuMi9wb3BlbjMvcGVvcGVuNCBpbiBvcyBtb2R1bGUgKHNlZSBDaGFuZ2VkIE1vZHVsZXMgYWJvdmUpLgoKb3MucG9wZW4gaXMgbXVjaCBtb3JlIHVzYWJsZSBvbiBXaW5kb3dzIDk1IGFuZCA5OC4gIFNlZSBNaWNyb3NvZnQKS25vd2xlZGdlIEJhc2UgYXJ0aWNsZSBRMTUwOTU2LiAgVGhlIFdpbjl4IHdvcmthcm91bmQgZGVzY3JpYmVkIHRoZXJlCmlzIGltcGxlbWVudGVkIGJ5IHRoZSBuZXcgdzl4cG9wZW4uZXhlIGhlbHBlciBpbiB0aGUgcm9vdCBvZiB5b3VyClB5dGhvbiBpbnN0YWxsYXRpb24uICBOb3RlIHRoYXQgUHl0aG9uIHVzZXMgdGhpcyBpbnRlcm5hbGx5OyBpdCBpcyBub3QKYSBzdGFuZGFsb25lIHByb2dyYW0uCgpBZG1pbmlzdHJhdG9yIHByaXZpbGVnZXMgYXJlIG5vIGxvbmdlciByZXF1aXJlZCB0byBpbnN0YWxsIFB5dGhvbgpvbiBXaW5kb3dzIE5UIG9yIFdpbmRvd3MgMjAwMC4gIElmIHlvdSBoYXZlIGFkbWluaXN0cmF0b3IgcHJpdmlsZWdlcywKUHl0aG9uJ3MgcmVnaXN0cnkgaW5mbyB3aWxsIGJlIHdyaXR0ZW4gdW5kZXIgSEtFWV9MT0NBTF9NQUNISU5FLgpPdGhlcndpc2UgdGhlIGluc3RhbGxlciBiYWNrcyBvZmYgdG8gd3JpdGluZyBQeXRob24ncyByZWdpc3RyeSBpbmZvCnVuZGVyIEhLRVlfQ1VSUkVOVF9VU0VSLiAgVGhlIGxhdHRlciBpcyBzdWZmaWNpZW50IGZvciBhbGwgIm5vcm1hbCIKdXNlcyBvZiBQeXRob24sIGJ1dCB3aWxsIHByZXZlbnQgc29tZSBhZHZhbmNlZCB1c2VzIGZyb20gd29ya2luZwooZm9yIGV4YW1wbGUsIHJ1bm5pbmcgYSBQeXRob24gc2NyaXB0IGFzIGFuIE5UIHNlcnZpY2UsIG9yIHBvc3NpYmx5CmZyb20gQ0dJKS4KCltUaGlzIHdhcyBuZXcgaW4gMS42XSBUaGUgaW5zdGFsbGVyIG5vIGxvbmdlciBydW5zIGEgc2VwYXJhdGUgVGNsL1RrCmluc3RhbGxlcjsgaW5zdGVhZCwgaXQgaW5zdGFsbHMgdGhlIG5lZWRlZCBUY2wvVGsgZmlsZXMgZGlyZWN0bHkgaW4gdGhlClB5dGhvbiBkaXJlY3RvcnkuICBJZiB5b3UgYWxyZWFkeSBoYXZlIGEgVGNsL1RrIGluc3RhbGxhdGlvbiwgdGhpcwp3YXN0ZXMgc29tZSBkaXNrIHNwYWNlIChhYm91dCA0IE1lZ3MpIGJ1dCBhdm9pZHMgcHJvYmxlbXMgd2l0aApjb25mbGljdGluZyBUY2wvVGsgaW5zdGFsbGF0aW9ucywgYW5kIG1ha2VzIGl0IG11Y2ggZWFzaWVyIGZvciBQeXRob24KdG8gZW5zdXJlIHRoYXQgVGNsL1RrIGNhbiBmaW5kIGFsbCBpdHMgZmlsZXMuCgpbVGhpcyB3YXMgbmV3IGluIDEuNl0gVGhlIFdpbmRvd3MgaW5zdGFsbGVyIG5vdyBpbnN0YWxscyBieSBkZWZhdWx0IGluClxQeXRob24yMFwgb24gdGhlIGRlZmF1bHQgdm9sdW1lLCBpbnN0ZWFkIG9mIFxQcm9ncmFtIEZpbGVzXFB5dGhvbi0yLjBcLgoKClVwZGF0ZXMgdG8gdGhlIGNoYW5nZXMgYmV0d2VlbiAxLjUuMiBhbmQgMS42Ci0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpUaGUgMS42IE5FV1MgZmlsZSBjYW4ndCBiZSBjaGFuZ2VkIGFmdGVyIHRoZSByZWxlYXNlIGlzIGRvbmUsIHNvIGhlcmUKaXMgc29tZSBsYXRlLWJyZWFraW5nIG5ld3M6CgpOZXcgQVBJcyBpbiBsb2NhbGUucHk6IG5vcm1hbGl6ZSgpLCBnZXRkZWZhdWx0bG9jYWxlKCksIHJlc2V0bG9jYWxlKCksCmFuZCBjaGFuZ2VzIHRvIGdldGxvY2FsZSgpIGFuZCBzZXRsb2NhbGUoKS4KClRoZSBuZXcgbW9kdWxlIGlzIG5vdyBlbmFibGVkIHBlciBkZWZhdWx0LgoKSXQgaXMgbm90IHRydWUgdGhhdCB0aGUgZW5jb2RpbmdzIGNvZGVjcyBjYW5ub3QgYmUgdXNlZCBmb3Igbm9ybWFsCnN0cmluZ3M6IHRoZSBzdHJpbmcuZW5jb2RlKCkgKHdoaWNoIGlzIGFsc28gcHJlc2VudCBvbiA4LWJpdCBzdHJpbmdzCiEpIGFsbG93cyB1c2luZyB0aGVtIGZvciA4LWJpdCBzdHJpbmdzIHRvbywgZS5nLiB0byBjb252ZXJ0IGZpbGVzIGZyb20KY3AxMjUyIChXaW5kb3dzKSB0byBsYXRpbi0xIG9yIHZpY2UtdmVyc2EuCgpKYXBhbmVzZSBjb2RlY3MgYXJlIGF2YWlsYWJsZSBmcm9tIFRhbWl0byBLQUpJWUFNQToKaHR0cDovL3BzZXVkby5ncmFkLnNjY3MuY2h1a3lvLXUuYWMuanAvfmthaml5YW1hL3B5dGhvbi8KCgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Cg==