LyoKKiBDb3B5cmlnaHQgqSB7MTk5Ny0xOTk5fSwgSW50ZXJuYXRpb25hbCBCdXNpbmVzcyBNYWNoaW5lcyBDb3Jwb3JhdGlvbiBhbmQgb3RoZXJzLiBBbGwgUmlnaHRzIFJlc2VydmVkLgoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgoqCiogRmlsZSBOVU1GTVQuSAoqCiogTW9kaWZpY2F0aW9uIEhpc3Rvcnk6CioKKiAgIERhdGUgICAgICAgIE5hbWUgICAgICAgIERlc2NyaXB0aW9uCiogICAwMi8xOS85NyAgICBhbGl1ICAgICAgICBDb252ZXJ0ZWQgZnJvbSBqYXZhLgoqICAgMDMvMTgvOTcgICAgY2xodWFuZyAgICAgVXBkYXRlZCBwZXIgQysrIGltcGxlbWVudGF0aW9uLgoqICAgMDQvMTcvOTcgICAgYWxpdSAgICAgICAgQ2hhbmdlZCBEaWdpdENvdW50IHRvIGludCBwZXIgY29kZSByZXZpZXcuCiogICAgMDcvMjAvOTggICAgc3RlcGhlbiAgICAgICAgSkRLIDEuMiBzeW5jIHVwLiBBZGRlZCBzY2llbnRpZmljIHN1cHBvcnQuCiogICAgICAgICAgICAgICAgICAgICAgICAgICAgQ2hhbmdlZCBuYW1pbmcgY29udmVudGlvbnMgdG8gbWF0Y2ggQysrIGd1aWRlbGluZXMKKiAgICAgICAgICAgICAgICAgICAgICAgICAgICBEZXJlY2F0ZWQgSmF2YSBzdHlsZSBjb25zdGFudHMgKGVnLCBJTlRFR0VSX0ZJRUxEKQoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgoqLwogCiNpZm5kZWYgTlVNRk1UX0gKI2RlZmluZSBOVU1GTVRfSAogCgojaW5jbHVkZSAidW5pY29kZS91dHlwZXMuaCIKI2luY2x1ZGUgInVuaWNvZGUvdW5pc3RyLmgiCiNpbmNsdWRlICJ1bmljb2RlL2Zvcm1hdC5oIgoKY2xhc3MgTG9jYWxlOwoKLyoqCiAqIEFic3RyYWN0IGJhc2UgY2xhc3MgZm9yIGFsbCBudW1iZXIgZm9ybWF0cy4gIFByb3ZpZGVzIGludGVyZmFjZSBmb3IKICogZm9ybWF0dGluZyBhbmQgcGFyc2luZyBhIG51bWJlci4gIEFsc28gcHJvdmlkZXMgbWV0aG9kcyBmb3IKICogZGV0ZXJtaW5pbmcgd2hpY2ggbG9jYWxlcyBoYXZlIG51bWJlciBmb3JtYXRzLCBhbmQgd2hhdCB0aGVpciBuYW1lcwogKiBhcmUuCiAqIDxQPgogKiBOdW1iZXJGb3JtYXQgaGVscHMgeW91IHRvIGZvcm1hdCBhbmQgcGFyc2UgbnVtYmVycyBmb3IgYW55IGxvY2FsZS4KICogWW91ciBjb2RlIGNhbiBiZSBjb21wbGV0ZWx5IGluZGVwZW5kZW50IG9mIHRoZSBsb2NhbGUgY29udmVudGlvbnMKICogZm9yIGRlY2ltYWwgcG9pbnRzLCB0aG91c2FuZHMtc2VwYXJhdG9ycywgb3IgZXZlbiB0aGUgcGFydGljdWxhcgogKiBkZWNpbWFsIGRpZ2l0cyB1c2VkLCBvciB3aGV0aGVyIHRoZSBudW1iZXIgZm9ybWF0IGlzIGV2ZW4gZGVjaW1hbC4KICogPFA+CiAqIFRvIGZvcm1hdCBhIG51bWJlciBmb3IgdGhlIGN1cnJlbnQgTG9jYWxlLCB1c2Ugb25lIG9mIHRoZSBzdGF0aWMKICogZmFjdG9yeSBtZXRob2RzOgogKiA8cHJlPgogKiAuICAgZG91YmxlIG15TnVtYmVyID0gNy4wOwogKiAuICAgVW5pY29kZVN0cmluZyBteVN0cmluZzsKICogLiAgIFVFcnJvckNvZGUgc3VjY2VzcyA9IFVfWkVST19FUlJPUjsKICogLiAgIE51bWJlckZvcm1hdCogbmYgPSBOdW1iZXJGb3JtYXQ6OmNyZWF0ZUluc3RhbmNlKHN1Y2Nlc3MpCiAqIC4gICBuZi0+Zm9ybWF0KG15TnVtYmVyLCBteVN0cmluZyk7CiAqIC4gICBjb3V0ICZsdDsmbHQ7ICIgRXhhbXBsZSAxOiAiICZsdDsmbHQ7IG15U3RyaW5nICZsdDsmbHQ7IGVuZGw7CiAqIDwvcHJlPgogKiBJZiB5b3UgYXJlIGZvcm1hdHRpbmcgbXVsdGlwbGUgbnVtYmVycywgaXQgaXMgbW9yZSBlZmZpY2llbnQgdG8gZ2V0CiAqIHRoZSBmb3JtYXQgYW5kIHVzZSBpdCBtdWx0aXBsZSB0aW1lcyBzbyB0aGF0IHRoZSBzeXN0ZW0gZG9lc24ndAogKiBoYXZlIHRvIGZldGNoIHRoZSBpbmZvcm1hdGlvbiBhYm91dCB0aGUgbG9jYWwgbGFuZ3VhZ2UgYW5kIGNvdW50cnkKICogY29udmVudGlvbnMgbXVsdGlwbGUgdGltZXMuCiAqIDxwcmU+CiAqIC4gICAgVW5pY29kZVN0cmluZyBteVN0cmluZzsKICogLiAgICBVRXJyb3JDb2RlIHN1Y2Nlc3MgPSBVX1pFUk9fRVJST1I7CiAqIC4gICAgbmYgPSBOdW1iZXJGb3JtYXQ6OmNyZWF0ZUluc3RhbmNlKCBzdWNjZXNzICk7CiAqIC4gICAgaW50MzJfdCBhW10gPSB7IDEyMywgMzMzMywgLTEyMzQ1NjcgfTsKICogLiAgICBjb25zdCBpbnQzMl90IGFfbGVuID0gc2l6ZW9mKGEpIC8gc2l6ZW9mKGFbMF0pOwogKiAuICAgIG15U3RyaW5nLnJlbW92ZSgpOwogKiAuICAgIGZvciAoaW50MzJfdCBpID0gMDsgaSA8IGFfbGVuOyBpKyspIHsKICogLiAgICAgICAgbmYtPmZvcm1hdChhW2ldLCBteVN0cmluZyk7CiAqIC4gICAgICAgIG15U3RyaW5nICs9ICIgOyAiOwogKiAuICAgIH0KICogLiAgICBjb3V0ICZsdDsmbHQ7ICIgRXhhbXBsZSAyOiAiICZsdDsmbHQ7IG15U3RyaW5nICZsdDsmbHQ7IGVuZGw7CiAqIDwvcHJlPgogKiBUbyBmb3JtYXQgYSBudW1iZXIgZm9yIGEgZGlmZmVyZW50IExvY2FsZSwgc3BlY2lmeSBpdCBpbiB0aGUKICogY2FsbCB0byBjcmVhdGVJbnN0YW5jZSgpLgogKiA8cHJlPgogKiAuICAgIG5mID0gTnVtYmVyRm9ybWF0OjpjcmVhdGVJbnN0YW5jZSggTG9jYWxlOjpGUkVOQ0gsIHN1Y2Nlc3MgKTsKICogPC9wcmU+CiAqIFlvdSBjYW4gdXNlIGEgTnVtYmVyRm9ybWF0IHRvIHBhcnNlIGFsc28uCiAqIDxwcmU+CiAqIC4gICBVRXJyb3JDb2RlIHN1Y2Nlc3M7CiAqIC4gICBGb3JtYXR0YWJsZSByZXN1bHQoLTk5OSk7ICAvLyBpbml0aWFsaXplZCB3aXRoIGVycm9yIGNvZGUKICogLiAgIG5mLT5wYXJzZShteVN0cmluZywgcmVzdWx0LCBzdWNjZXNzKTsKICogPC9wcmU+CiAqIFVzZSBjcmVhdGVJbnN0YW5jZSB0byBnZXQgdGhlIG5vcm1hbCBudW1iZXIgZm9ybWF0IGZvciB0aGF0IGNvdW50cnkuCiAqIFRoZXJlIGFyZSBvdGhlciBzdGF0aWMgZmFjdG9yeSBtZXRob2RzIGF2YWlsYWJsZS4gIFVzZSBnZXRDdXJyZW5jeQogKiB0byBnZXQgdGhlIGN1cnJlbmN5IG51bWJlciBmb3JtYXQgZm9yIHRoYXQgY291bnRyeS4gIFVzZSBnZXRQZXJjZW50CiAqIHRvIGdldCBhIGZvcm1hdCBmb3IgZGlzcGxheWluZyBwZXJjZW50YWdlcy4gV2l0aCB0aGlzIGZvcm1hdCwgYQogKiBmcmFjdGlvbiBmcm9tIDAuNTMgaXMgZGlzcGxheWVkIGFzIDUzJS4KICogPFA+CiAqIFlvdSBjYW4gYWxzbyBjb250cm9sIHRoZSBkaXNwbGF5IG9mIG51bWJlcnMgd2l0aCBzdWNoIG1ldGhvZHMgYXMKICogZ2V0TWluaW11bUZyYWN0aW9uRGlnaXRzLiAgSWYgeW91IHdhbnQgZXZlbiBtb3JlIGNvbnRyb2wgb3ZlciB0aGUKICogZm9ybWF0IG9yIHBhcnNpbmcsIG9yIHdhbnQgdG8gZ2l2ZSB5b3VyIHVzZXJzIG1vcmUgY29udHJvbCwgeW91IGNhbgogKiB0cnkgY2FzdGluZyB0aGUgTnVtYmVyRm9ybWF0IHlvdSBnZXQgZnJvbSB0aGUgZmFjdG9yeSBtZXRob2RzIHRvIGEKICogRGVjaW1hbE51bWJlckZvcm1hdC4gVGhpcyB3aWxsIHdvcmsgZm9yIHRoZSB2YXN0IG1ham9yaXR5IG9mCiAqIGNvdW50cmllczsganVzdCByZW1lbWJlciB0byBwdXQgaXQgaW4gYSB0cnkgYmxvY2sgaW4gY2FzZSB5b3UKICogZW5jb3VudGVyIGFuIHVudXN1YWwgb25lLgogKiA8UD4KICogWW91IGNhbiBhbHNvIHVzZSBmb3JtcyBvZiB0aGUgcGFyc2UgYW5kIGZvcm1hdCBtZXRob2RzIHdpdGgKICogUGFyc2VQb3NpdGlvbiBhbmQgRmllbGRQb3NpdGlvbiB0byBhbGxvdyB5b3UgdG86CiAqIDx1bCB0eXBlPXJvdW5kPgogKiAgIDxsaT4oYSkgcHJvZ3Jlc3NpdmVseSBwYXJzZSB0aHJvdWdoIHBpZWNlcyBvZiBhIHN0cmluZy4KICogICA8bGk+KGIpIGFsaWduIHRoZSBkZWNpbWFsIHBvaW50IGFuZCBvdGhlciBhcmVhcy4KICogPC91bD4KICogRm9yIGV4YW1wbGUsIHlvdSBjYW4gYWxpZ24gbnVtYmVycyBpbiB0d28gd2F5cy4KICogPFA+CiAqIElmIHlvdSBhcmUgdXNpbmcgYSBtb25vc3BhY2VkIGZvbnQgd2l0aCBzcGFjaW5nIGZvciBhbGlnbm1lbnQsIHlvdQogKiBjYW4gcGFzcyB0aGUgRmllbGRQb3NpdGlvbiBpbiB5b3VyIGZvcm1hdCBjYWxsLCB3aXRoIGZpZWxkID0KICogSU5URUdFUl9GSUVMRC4gT24gb3V0cHV0LCBnZXRFbmRJbmRleCB3aWxsIGJlIHNldCB0byB0aGUgb2Zmc2V0CiAqIGJldHdlZW4gdGhlIGxhc3QgY2hhcmFjdGVyIG9mIHRoZSBpbnRlZ2VyIGFuZCB0aGUgZGVjaW1hbC4gQWRkCiAqIChkZXNpcmVkU3BhY2VDb3VudCAtIGdldEVuZEluZGV4KSBzcGFjZXMgYXQgdGhlIGZyb250IG9mIHRoZQogKiBzdHJpbmcuCiAqIDxQPgogKiBJZiB5b3UgYXJlIHVzaW5nIHByb3BvcnRpb25hbCBmb250cywgaW5zdGVhZCBvZiBwYWRkaW5nIHdpdGgKICogc3BhY2VzLCBtZWFzdXJlIHRoZSB3aWR0aCBvZiB0aGUgc3RyaW5nIGluIHBpeGVscyBmcm9tIHRoZSBzdGFydCB0bwogKiBnZXRFbmRJbmRleC4gIFRoZW4gbW92ZSB0aGUgcGVuIGJ5IChkZXNpcmVkUGl4ZWxXaWR0aCAtCiAqIHdpZHRoVG9BbGlnbm1lbnRQb2ludCkgYmVmb3JlIGRyYXdpbmcgdGhlIHRleHQuICBJdCBhbHNvIHdvcmtzCiAqIHdoZXJlIHRoZXJlIGlzIG5vIGRlY2ltYWwsIGJ1dCBwb3NzaWJseSBhZGRpdGlvbmFsIGNoYXJhY3RlcnMgYXQKICogdGhlIGVuZCwgZS5nLiB3aXRoIHBhcmVudGhlc2VzIGluIG5lZ2F0aXZlIG51bWJlcnM6ICIoMTIpIiBmb3IgLTEyLgogKi8KY2xhc3MgVV9JMThOX0FQSSBOdW1iZXJGb3JtYXQgOiBwdWJsaWMgRm9ybWF0IHsKcHVibGljOgoKICAgIC8qKgogICAgICogQWxpZ25tZW50IEZpZWxkIGNvbnN0YW50cyB1c2VkIHRvIGNvbnN0cnVjdCBhIEZpZWxkUG9zaXRpb24gb2JqZWN0LgogICAgICogU2lnbmlmaWVzIHRoYXQgdGhlIHBvc2l0aW9uIG9mIHRoZSBpbnRlZ2VyIHBhcnQgb3IgZnJhY3Rpb24gcGFydCBvZgogICAgICogYSBmb3JtYXR0ZWQgbnVtYmVyIHNob3VsZCBiZSByZXR1cm5lZC4KICAgICAqCiAgICAgKiBAc2VlIEZpZWxkUG9zaXRpb24KICAgICAqLwogICAgZW51bSBFQWxpZ25tZW50RmllbGRzIHsKICAgICAgICBrSW50ZWdlckZpZWxkLAogICAgICAgIGtGcmFjdGlvbkZpZWxkLAoKCiAgICAvKioKICAgICAqIFRoZXNlIGNvbnN0YW50cyBhcmUgcHJvdmlkZWQgZm9yIGJhY2t3YXJkcyBjb21wYXRpYmlsaXR5IG9ubHksCiAgICAgKiBhbmQgYXJlIGRlcHJlY2F0ZWQuICBQbGVhc2UgdXNlIHRoZSBDKysgc3R5bGUgY29uc3RhbnRzIGRlZmluZWQgYWJvdmUuCiAgICAgKi8gICAgICAgCiAgICAgICAgSU5URUdFUl9GSUVMRCAgICAgICAgPSBrSW50ZWdlckZpZWxkLAogICAgICAgIEZSQUNUSU9OX0ZJRUxEICAgICAgICA9IGtGcmFjdGlvbkZpZWxkCiAgICB9OwoKICAgIHZpcnR1YWwgfk51bWJlckZvcm1hdCgpOwoKICAgIC8qKgogICAgICogUmV0dXJuIHRydWUgaWYgdGhlIGdpdmVuIEZvcm1hdCBvYmplY3RzIGFyZSBzZW1hbnRpY2FsbHkgZXF1YWwuCiAgICAgKiBPYmplY3RzIG9mIGRpZmZlcmVudCBzdWJjbGFzc2VzIGFyZSBjb25zaWRlcmVkIHVuZXF1YWwuCiAgICAgKi8KICAgIHZpcnR1YWwgYm9vbF90IG9wZXJhdG9yPT0oY29uc3QgRm9ybWF0JiBvdGhlcikgY29uc3Q7CgogICAgLyoqCiAgICAgKiBGb3JtYXQgYW4gb2JqZWN0IHRvIHByb2R1Y2UgYSBzdHJpbmcuICBUaGlzIG1ldGhvZCBoYW5kbGVzCiAgICAgKiBGb3JtYXR0YWJsZSBvYmplY3RzIHdpdGggbnVtZXJpYyB0eXBlcy4gSWYgdGhlIEZvcm1hdHRhYmxlCiAgICAgKiBvYmplY3QgdHlwZSBpcyBub3QgYSBudW1lcmljIHR5cGUsIHRoZW4gaXQgcmV0dXJucyBhIGZhaWxpbmcKICAgICAqIFVFcnJvckNvZGUuCiAgICAgKgogICAgICogQHBhcmFtIG9iaiAgICAgICAgICAgVGhlIG9iamVjdCB0byBmb3JtYXQuCiAgICAgKiBAcGFyYW0gdG9BcHBlbmRUbyAgICBXaGVyZSB0aGUgdGV4dCBpcyB0byBiZSBhcHBlbmRlZC4KICAgICAqIEBwYXJhbSBwb3MgICAgICAgICAgIE9uIGlucHV0OiBhbiBhbGlnbm1lbnQgZmllbGQsIGlmIGRlc2lyZWQuCiAgICAgKiAgICAgICAgICAgICAgICAgICAgICBPbiBvdXRwdXQ6IHRoZSBvZmZzZXRzIG9mIHRoZSBhbGlnbm1lbnQgZmllbGQuCiAgICAgKiBAcGFyYW0gc3RhdHVzICAgICAgICBPdXRwdXQgcGFyYW0gZmlsbGVkIHdpdGggc3VjY2Vzcy9mYWlsdXJlIHN0YXR1cy4KICAgICAqIEByZXR1cm4gICAgICAgICAgICAgIFRoZSB2YWx1ZSBwYXNzZWQgaW4gYXMgdG9BcHBlbmRUbyAodGhpcyBhbGxvd3MgY2hhaW5pbmcsCiAgICAgKiAgICAgICAgICAgICAgICAgICAgICBhcyB3aXRoIFVuaWNvZGVTdHJpbmc6OmFwcGVuZCgpKQogICAgICovCiAgICB2aXJ0dWFsIFVuaWNvZGVTdHJpbmcmIGZvcm1hdChjb25zdCBGb3JtYXR0YWJsZSYgb2JqLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVW5pY29kZVN0cmluZyYgdG9BcHBlbmRUbywKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEZpZWxkUG9zaXRpb24mIHBvcywKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFVFcnJvckNvZGUmIHN0YXR1cykgY29uc3Q7CgogICAgLyoqCiAgICAgKiBQYXJzZSBhIHN0cmluZyB0byBwcm9kdWNlIGFuIG9iamVjdC4gIFRoaXMgbWV0aG9kcyBoYW5kbGVzCiAgICAgKiBwYXJzaW5nIG9mIG51bWVyaWMgc3RyaW5ncyBpbnRvIEZvcm1hdHRhYmxlIG9iamVjdHMgd2l0aCBudW1lcmljCiAgICAgKiB0eXBlcy4KICAgICAqIDxQPgogICAgICogQmVmb3JlIGNhbGxpbmcsIHNldCBwYXJzZV9wb3MuaW5kZXggdG8gdGhlIG9mZnNldCB5b3Ugd2FudCB0bwogICAgICogc3RhcnQgcGFyc2luZyBhdCBpbiB0aGUgc291cmNlLiBBZnRlciBjYWxsaW5nLCBwYXJzZV9wb3MuaW5kZXgKICAgICAqIGlzIHRoZSBlbmQgb2YgdGhlIHRleHQgeW91IHBhcnNlZC4gIElmIGVycm9yIG9jY3VycywgaW5kZXggaXMKICAgICAqIHVuY2hhbmdlZC4KICAgICAqIDxQPgogICAgICogV2hlbiBwYXJzaW5nLCBsZWFkaW5nIHdoaXRlc3BhY2UgaXMgZGlzY2FyZGVkICh3aXRoIHN1Y2Nlc3NmdWwKICAgICAqIHBhcnNlKSwgd2hpbGUgdHJhaWxpbmcgd2hpdGVzcGFjZSBpcyBsZWZ0IGFzIGlzLgogICAgICogPFA+CiAgICAgKiBTZWUgRm9ybWF0OjpwYXJzZU9iamVjdCgpIGZvciBtb3JlLgogICAgICoKICAgICAqIEBwYXJhbSBzb3VyY2UgICAgVGhlIHN0cmluZyB0byBiZSBwYXJzZWQgaW50byBhbiBvYmplY3QuCiAgICAgKiBAcGFyYW0gcmVzdWx0ICAgIEZvcm1hdHRhYmxlIHRvIGJlIHNldCB0byB0aGUgcGFyc2UgcmVzdWx0LgogICAgICogICAgICAgICAgICAgICAgICBJZiBwYXJzZSBmYWlscywgcmV0dXJuIGNvbnRlbnRzIGFyZSB1bmRlZmluZWQuCiAgICAgKiBAcGFyYW0gcGFyc2VfcG9zIFRoZSBwb3NpdGlvbiB0byBzdGFydCBwYXJzaW5nIGF0LiBVcG9uIHJldHVybgogICAgICogICAgICAgICAgICAgICAgICB0aGlzIHBhcmFtIGlzIHNldCB0byB0aGUgcG9zaXRpb24gYWZ0ZXIgdGhlCiAgICAgKiAgICAgICAgICAgICAgICAgIGxhc3QgY2hhcmFjdGVyIHN1Y2Nlc3NmdWxseSBwYXJzZWQuIElmIHRoZQogICAgICogICAgICAgICAgICAgICAgICBzb3VyY2UgaXMgbm90IHBhcnNlZCBzdWNjZXNzZnVsbHksIHRoaXMgcGFyYW0KICAgICAqICAgICAgICAgICAgICAgICAgd2lsbCByZW1haW4gdW5jaGFuZ2VkLgogICAgICogQHJldHVybiAgICAgICAgICBBIG5ld2x5IGNyZWF0ZWQgRm9ybWF0dGFibGUqIG9iamVjdCwgb3IgTlVMTAogICAgICogICAgICAgICAgICAgICAgICBvbiBmYWlsdXJlLiAgVGhlIGNhbGxlciBvd25zIHRoaXMgYW5kIHNob3VsZAogICAgICogICAgICAgICAgICAgICAgICBkZWxldGUgaXQgd2hlbiBkb25lLgogICAgICovCiAgICB2aXJ0dWFsIHZvaWQgcGFyc2VPYmplY3QoY29uc3QgVW5pY29kZVN0cmluZyYgc291cmNlLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgIEZvcm1hdHRhYmxlJiByZXN1bHQsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgUGFyc2VQb3NpdGlvbiYgcGFyc2VfcG9zKSBjb25zdDsKCiAgICAvKioKICAgICAqIEZvcm1hdCBhIGRvdWJsZSBvciBsb25nIG51bWJlci4gVGhlc2UgbWV0aG9kcyBjYWxsIHRoZSBOdW1iZXJGb3JtYXQKICAgICAqIHB1cmUgdmlydHVhbCBmb3JtYXQoKSBtZXRob2RzIHdpdGggdGhlIGRlZmF1bHQgRmllbGRQb3NpdGlvbi4KICAgICAqCiAgICAgKiBAcGFyYW0gbnVtYmVyICAgIFRoZSB2YWx1ZSB0byBiZSBmb3JtYXR0ZWQuCiAgICAgKiBAcGFyYW0gb3V0cHV0ICAgIE91dHB1dCBwYXJhbSB3aXRoIHRoZSBmb3JtYXR0ZWQgc3RyaW5nLgogICAgICogQHJldHVybiAgICAgICAgICBBIHJlZmVyZW5jZSB0byAnb3V0cHV0JyBwYXJhbS4KICAgICAqLwogICAgVW5pY29kZVN0cmluZyYgZm9ybWF0KCAgZG91YmxlIG51bWJlciwKICAgICAgICAgICAgICAgICAgICAgICAgICAgIFVuaWNvZGVTdHJpbmcmIG91dHB1dCkgY29uc3Q7CgogICAgVW5pY29kZVN0cmluZyYgZm9ybWF0KCAgaW50MzJfdCBudW1iZXIsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICBVbmljb2RlU3RyaW5nJiBvdXRwdXQpIGNvbnN0OwoKICAgLyoqCiAgICAqIEZvcm1hdCBhIGRvdWJsZSBvciBsb25nIG51bWJlci4gQ29uY3JldGUgc3ViY2xhc3NlcyBtdXN0IGltcGxlbWVudAogICAgKiB0aGVzZSBwdXJlIHZpcnR1YWwgbWV0aG9kcy4KICAgICoKICAgICogQHBhcmFtIG51bWJlciAgICAgVGhlIHZhbHVlIHRvIGJlIGZvcm1hdHRlZC4KICAgICogQHBhcmFtIHRvQXBwZW5kVG8gVGhlIHN0cmluZyB0byBhcHBlbmQgdGhlIGZvcm1hdHRlZCBzdHJpbmcgdG8uCiAgICAqICAgICAgICAgICAgICAgICAgIFRoaXMgaXMgYW4gb3V0cHV0IHBhcmFtZXRlci4KICAgICogQHBhcmFtIHBvcyAgICAgICAgT24gaW5wdXQ6IGFuIGFsaWdubWVudCBmaWVsZCwgaWYgZGVzaXJlZC4KICAgICogICAgICAgICAgICAgICAgICAgT24gb3V0cHV0OiB0aGUgb2Zmc2V0cyBvZiB0aGUgYWxpZ25tZW50IGZpZWxkLgogICAgKiBAcmV0dXJuICAgICAgICAgICBBIHJlZmVyZW5jZSB0byAndG9BcHBlbmRUbycuCiAgICAqLwogICAgdmlydHVhbCBVbmljb2RlU3RyaW5nJiBmb3JtYXQoZG91YmxlIG51bWJlciwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFVuaWNvZGVTdHJpbmcmIHRvQXBwZW5kVG8sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBGaWVsZFBvc2l0aW9uJiBwb3MpIGNvbnN0ID0gMDsKICAgIHZpcnR1YWwgVW5pY29kZVN0cmluZyYgZm9ybWF0KGludDMyX3QgbnVtYmVyLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVW5pY29kZVN0cmluZyYgdG9BcHBlbmRUbywKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEZpZWxkUG9zaXRpb24mIHBvcykgY29uc3QgPSAwOwoKICAgIC8qKgogICAgICogUmVkZWNsYXJlZCBGb3JtYXQgbWV0aG9kLgogICAgICovCiAgICBVbmljb2RlU3RyaW5nJiBmb3JtYXQoY29uc3QgRm9ybWF0dGFibGUmIG9iaiwKICAgICAgICAgICAgICAgICAgICAgICAgICBVbmljb2RlU3RyaW5nJiByZXN1bHQsCiAgICAgICAgICAgICAgICAgICAgICAgICAgVUVycm9yQ29kZSYgc3RhdHVzKSBjb25zdDsKCiAgIC8qKgogICAgKiBSZXR1cm4gYSBsb25nIGlmIHBvc3NpYmxlIChlLmcuIHdpdGhpbiByYW5nZSBMT05HX01BWCwKICAgICogTE9OR19NQVhdLCBhbmQgd2l0aCBubyBkZWNpbWFscyksIG90aGVyd2lzZSBhIGRvdWJsZS4gIElmCiAgICAqIEludGVnZXJPbmx5IGlzIHNldCwgd2lsbCBzdG9wIGF0IGEgZGVjaW1hbCBwb2ludCAob3IgZXF1aXZhbGVudDsKICAgICogZS5nLiBmb3IgcmF0aW9uYWwgbnVtYmVycyAiMSAyLzMiLCB3aWxsIHN0b3AgYWZ0ZXIgdGhlIDEpLgogICAgKiA8UD4KICAgICogSWYgbm8gb2JqZWN0IGNhbiBiZSBwYXJzZWQsIGluZGV4IGlzIHVuY2hhbmdlZCwgYW5kIE5VTEwgaXMKICAgICogcmV0dXJuZWQuCiAgICAqIDxQPgogICAgKiBUaGlzIGlzIGEgcHVyZSB2aXJ0dWFsIHdoaWNoIGNvbmNyZXRlIHN1YmNsYXNzZXMgbXVzdCBpbXBsZW1lbnQuCiAgICAqCiAgICAqIEBwYXJhbSB0ZXh0ICAgICAgICAgICBUaGUgdGV4dCB0byBiZSBwYXJzZWQuCiAgICAqIEBwYXJhbSByZXN1bHQgICAgICAgICBGb3JtYXR0YWJsZSB0byBiZSBzZXQgdG8gdGhlIHBhcnNlIHJlc3VsdC4KICAgICogICAgICAgICAgICAgICAgICAgICAgIElmIHBhcnNlIGZhaWxzLCByZXR1cm4gY29udGVudHMgYXJlIHVuZGVmaW5lZC4KICAgICogQHBhcmFtIHBhcnNlUG9zaXRpb24gIFRoZSBwb3NpdGlvbiB0byBzdGFydCBwYXJzaW5nIGF0IG9uIGlucHV0LgogICAgKiAgICAgICAgICAgICAgICAgICAgICAgT24gb3V0cHV0LCBtb3ZlZCB0byBhZnRlciB0aGUgbGFzdCBzdWNjZXNzZnVsbHkKICAgICogICAgICAgICAgICAgICAgICAgICAgIHBhcnNlIGNoYXJhY3Rlci4gT24gcGFyc2UgZmFpbHVyZSwgZG9lcyBub3QgY2hhbmdlLgogICAgKiBAcmV0dXJuICAgICAgICAgICAgICAgQSBGb3JtYXR0YWJsZSBvYmplY3Qgb2YgbnVtZXJpYyB0eXBlLiAgVGhlIGNhbGxlcgogICAgKiAgICAgICAgICAgICAgICAgICAgICAgb3ducyB0aGlzIGFuIG11c3QgZGVsZXRlIGl0LiAgTlVMTCBvbiBmYWlsdXJlLgogICAgKi8KICAgIHZpcnR1YWwgdm9pZCBwYXJzZShjb25zdCBVbmljb2RlU3RyaW5nJiB0ZXh0LAogICAgICAgICAgICAgICAgICAgICAgIEZvcm1hdHRhYmxlJiByZXN1bHQsCiAgICAgICAgICAgICAgICAgICAgICAgUGFyc2VQb3NpdGlvbiYgcGFyc2VQb3NpdGlvbikgY29uc3QgPSAwOwoKICAgIC8qKgogICAgICogUGFyc2UgYSBzdHJpbmcgYXMgYSBudW1lcmljIHZhbHVlLCBhbmQgcmV0dXJuIGEgRm9ybWF0dGFibGUKICAgICAqIG51bWVyaWMgb2JqZWN0LiBUaGlzIG1ldGhvZCBwYXJzZXMgaW50ZWdlcnMgb25seSBpZiBJbnRlZ2VyT25seQogICAgICogaXMgc2V0LgogICAgICoKICAgICAqIEBwYXJhbSB0ZXh0ICAgICAgICAgIFRoZSB0ZXh0IHRvIGJlIHBhcnNlZC4KICAgICAqIEBwYXJhbSByZXN1bHQgICAgICAgIEZvcm1hdHRhYmxlIHRvIGJlIHNldCB0byB0aGUgcGFyc2UgcmVzdWx0LgogICAgICogICAgICAgICAgICAgICAgICAgICAgSWYgcGFyc2UgZmFpbHMsIHJldHVybiBjb250ZW50cyBhcmUgdW5kZWZpbmVkLgogICAgICogQHBhcmFtIHN0YXR1cyAgICAgICAgU3VjY2VzcyBvciBmYWlsdXJlIG91dHB1dCBwYXJhbWV0ZXIuCiAgICAgKiBAcmV0dXJuICAgICAgICAgICAgICBBIEZvcm1hdHRhYmxlIG9iamVjdCBvZiBudW1lcmljIHR5cGUuICBUaGUgY2FsbGVyCiAgICAgKiAgICAgICAgICAgICAgICAgICAgICBvd25zIHRoaXMgYW4gbXVzdCBkZWxldGUgaXQuICBOVUxMIG9uIGZhaWx1cmUuCiAgICAgKiBAc2VlICAgICAgICAgICAgICAgICBOdW1iZXJGb3JtYXQ6OmlzUGFyc2VJbnRlZ2VyT25seQogICAgICovCiAgICB2aXJ0dWFsIHZvaWQgcGFyc2UoIGNvbnN0IFVuaWNvZGVTdHJpbmcmIHRleHQsCiAgICAgICAgICAgICAgICAgICAgICAgIEZvcm1hdHRhYmxlJiByZXN1bHQsCiAgICAgICAgICAgICAgICAgICAgICAgIFVFcnJvckNvZGUmIHN0YXR1cykgY29uc3Q7CgogICAgLyoqCiAgICAgKiBSZXR1cm4gdHJ1ZSBpZiB0aGlzIGZvcm1hdCB3aWxsIHBhcnNlIG51bWJlcnMgYXMgaW50ZWdlcnMKICAgICAqIG9ubHkuICBGb3IgZXhhbXBsZSBpbiB0aGUgRW5nbGlzaCBsb2NhbGUsIHdpdGggUGFyc2VJbnRlZ2VyT25seQogICAgICogdHJ1ZSwgdGhlIHN0cmluZyAiMTIzNC4iIHdvdWxkIGJlIHBhcnNlZCBhcyB0aGUgaW50ZWdlciB2YWx1ZQogICAgICogMTIzNCBhbmQgcGFyc2luZyB3b3VsZCBzdG9wIGF0IHRoZSAiLiIgY2hhcmFjdGVyLiAgT2YgY291cnNlLAogICAgICogdGhlIGV4YWN0IGZvcm1hdCBhY2NlcHRlZCBieSB0aGUgcGFyc2Ugb3BlcmF0aW9uIGlzIGxvY2FsZQogICAgICogZGVwZW5kYW50IGFuZCBkZXRlcm1pbmVkIGJ5IHN1Yi1jbGFzc2VzIG9mIE51bWJlckZvcm1hdC4KICAgICAqLwogICAgYm9vbF90IGlzUGFyc2VJbnRlZ2VyT25seSh2b2lkKSBjb25zdDsKCiAgICAvKioKICAgICAqIFNldHMgd2hldGhlciBvciBub3QgbnVtYmVycyBzaG91bGQgYmUgcGFyc2VkIGFzIGludGVnZXJzIG9ubHkuCiAgICAgKiBAc2VlIGlzUGFyc2VJbnRlZ2VyT25seQogICAgICovCiAgICB2aXJ0dWFsIHZvaWQgc2V0UGFyc2VJbnRlZ2VyT25seShib29sX3QgdmFsdWUpOwoKICAgIC8qKgogICAgICogUmV0dXJucyB0aGUgZGVmYXVsdCBudW1iZXIgZm9ybWF0IGZvciB0aGUgY3VycmVudCBkZWZhdWx0CiAgICAgKiBsb2NhbGUuICBUaGUgZGVmYXVsdCBmb3JtYXQgaXMgb25lIG9mIHRoZSBzdHlsZXMgcHJvdmlkZWQgYnkKICAgICAqIHRoZSBvdGhlciBmYWN0b3J5IG1ldGhvZHM6IGdldE51bWJlckluc3RhbmNlLAogICAgICogZ2V0Q3VycmVuY3lJbnN0YW5jZSBvciBnZXRQZXJjZW50SW5zdGFuY2UuICBFeGFjdGx5IHdoaWNoIG9uZQogICAgICogaXMgbG9jYWxlIGRlcGVuZGFudC4KICAgICAqLwogICAgc3RhdGljIE51bWJlckZvcm1hdCogY3JlYXRlSW5zdGFuY2UoVUVycm9yQ29kZSYpOwoKICAgIC8qKgogICAgICogUmV0dXJucyB0aGUgZGVmYXVsdCBudW1iZXIgZm9ybWF0IGZvciB0aGUgc3BlY2lmaWVkIGxvY2FsZS4KICAgICAqIFRoZSBkZWZhdWx0IGZvcm1hdCBpcyBvbmUgb2YgdGhlIHN0eWxlcyBwcm92aWRlZCBieSB0aGUgb3RoZXIKICAgICAqIGZhY3RvcnkgbWV0aG9kczogZ2V0TnVtYmVySW5zdGFuY2UsIGdldEN1cnJlbmN5SW5zdGFuY2Ugb3IKICAgICAqIGdldFBlcmNlbnRJbnN0YW5jZS4gIEV4YWN0bHkgd2hpY2ggb25lIGlzIGxvY2FsZSBkZXBlbmRhbnQuCiAgICAgKi8KICAgIHN0YXRpYyBOdW1iZXJGb3JtYXQqIGNyZWF0ZUluc3RhbmNlKGNvbnN0IExvY2FsZSYgaW5Mb2NhbGUsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBVRXJyb3JDb2RlJik7CgogICAgLyoqCiAgICAgKiBSZXR1cm5zIGEgY3VycmVuY3kgZm9ybWF0IGZvciB0aGUgY3VycmVudCBkZWZhdWx0IGxvY2FsZS4KICAgICAqLwogICAgc3RhdGljIE51bWJlckZvcm1hdCogY3JlYXRlQ3VycmVuY3lJbnN0YW5jZShVRXJyb3JDb2RlJik7CgogICAgLyoqCiAgICAgKiBSZXR1cm5zIGEgY3VycmVuY3kgZm9ybWF0IGZvciB0aGUgc3BlY2lmaWVkIGxvY2FsZS4KICAgICAqLwogICAgc3RhdGljIE51bWJlckZvcm1hdCogY3JlYXRlQ3VycmVuY3lJbnN0YW5jZShjb25zdCBMb2NhbGUmIGluTG9jYWxlLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBVRXJyb3JDb2RlJik7CgogICAgLyoqCiAgICAgKiBSZXR1cm5zIGEgcGVyY2VudGFnZSBmb3JtYXQgZm9yIHRoZSBjdXJyZW50IGRlZmF1bHQgbG9jYWxlLgogICAgICovCiAgICBzdGF0aWMgTnVtYmVyRm9ybWF0KiBjcmVhdGVQZXJjZW50SW5zdGFuY2UoVUVycm9yQ29kZSYpOwoKICAgIC8qKgogICAgICogUmV0dXJucyBhIHBlcmNlbnRhZ2UgZm9ybWF0IGZvciB0aGUgc3BlY2lmaWVkIGxvY2FsZS4KICAgICAqLwogICAgc3RhdGljIE51bWJlckZvcm1hdCogY3JlYXRlUGVyY2VudEluc3RhbmNlKGNvbnN0IExvY2FsZSYgaW5Mb2NhbGUsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVUVycm9yQ29kZSYpOwoKICAgIC8qKgogICAgICogUmV0dXJucyBhIHNjaWVudGlmaWMgZm9ybWF0IGZvciB0aGUgY3VycmVudCBkZWZhdWx0IGxvY2FsZS4KICAgICAqLwogICAgc3RhdGljIE51bWJlckZvcm1hdCogY3JlYXRlU2NpZW50aWZpY0luc3RhbmNlKFVFcnJvckNvZGUmKTsKCiAgICAvKioKICAgICAqIFJldHVybnMgYSBzY2llbnRpZmljIGZvcm1hdCBmb3IgdGhlIHNwZWNpZmllZCBsb2NhbGUuCiAgICAgKi8KICAgIHN0YXRpYyBOdW1iZXJGb3JtYXQqIGNyZWF0ZVNjaWVudGlmaWNJbnN0YW5jZShjb25zdCBMb2NhbGUmIGluTG9jYWxlLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBVRXJyb3JDb2RlJik7CgogICAgLyoqCiAgICAgKiBHZXQgdGhlIHNldCBvZiBMb2NhbGVzIGZvciB3aGljaCBOdW1iZXJGb3JtYXRzIGFyZSBpbnN0YWxsZWQuCiAgICAgKi8KICAgIHN0YXRpYyBjb25zdCBMb2NhbGUqIGdldEF2YWlsYWJsZUxvY2FsZXMoaW50MzJfdCYgY291bnQpOwoKICAgIC8qKgogICAgICogUmV0dXJucyB0cnVlIGlmIGdyb3VwaW5nIGlzIHVzZWQgaW4gdGhpcyBmb3JtYXQuIEZvciBleGFtcGxlLAogICAgICogaW4gdGhlIEVuZ2xpc2ggbG9jYWxlLCB3aXRoIGdyb3VwaW5nIG9uLCB0aGUgbnVtYmVyIDEyMzQ1NjcKICAgICAqIG1pZ2h0IGJlIGZvcm1hdHRlZCBhcyAiMSwyMzQsNTY3Ii4gVGhlIGdyb3VwaW5nIHNlcGFyYXRvciBhcwogICAgICogd2VsbCBhcyB0aGUgc2l6ZSBvZiBlYWNoIGdyb3VwIGlzIGxvY2FsZSBkZXBlbmRhbnQgYW5kIGlzCiAgICAgKiBkZXRlcm1pbmVkIGJ5IHN1Yi1jbGFzc2VzIG9mIE51bWJlckZvcm1hdC4KICAgICAqIEBzZWUgc2V0R3JvdXBpbmdVc2VkCiAgICAgKi8KICAgIGJvb2xfdCBpc0dyb3VwaW5nVXNlZCh2b2lkKSBjb25zdDsKCiAgICAvKioKICAgICAqIFNldCB3aGV0aGVyIG9yIG5vdCBncm91cGluZyB3aWxsIGJlIHVzZWQgaW4gdGhpcyBmb3JtYXQuCiAgICAgKiBAc2VlIGdldEdyb3VwaW5nVXNlZAogICAgICovCiAgICB2aXJ0dWFsIHZvaWQgc2V0R3JvdXBpbmdVc2VkKGJvb2xfdCBuZXdWYWx1ZSk7CgogICAgLyoqCiAgICAgKiBSZXR1cm5zIHRoZSBtYXhpbXVtIG51bWJlciBvZiBkaWdpdHMgYWxsb3dlZCBpbiB0aGUgaW50ZWdlciBwb3J0aW9uIG9mIGEKICAgICAqIG51bWJlci4KICAgICAqIEBzZWUgc2V0TWF4aW11bUludGVnZXJEaWdpdHMKICAgICAqLwogICAgaW50MzJfdCBnZXRNYXhpbXVtSW50ZWdlckRpZ2l0cyh2b2lkKSBjb25zdDsKCiAgICAvKioKICAgICAqIFNldHMgdGhlIG1heGltdW0gbnVtYmVyIG9mIGRpZ2l0cyBhbGxvd2VkIGluIHRoZSBpbnRlZ2VyIHBvcnRpb24gb2YgYQogICAgICogbnVtYmVyLiBtYXhpbXVtSW50ZWdlckRpZ2l0cyBtdXN0IGJlID49IG1pbmltdW1JbnRlZ2VyRGlnaXRzLiAgSWYgdGhlCiAgICAgKiBuZXcgdmFsdWUgZm9yIG1heGltdW1JbnRlZ2VyRGlnaXRzIGlzIGxlc3MgdGhhbiB0aGUgY3VycmVudCB2YWx1ZQogICAgICogb2YgbWluaW11bUludGVnZXJEaWdpdHMsIHRoZW4gbWluaW11bUludGVnZXJEaWdpdHMgd2lsbCBhbHNvIGJlIHNldCB0bwogICAgICogdGhlIG5ldyB2YWx1ZS4KICAgICAqCiAgICAgKiBAc2VlIGdldE1heGltdW1JbnRlZ2VyRGlnaXRzCiAgICAgKi8KICAgIHZpcnR1YWwgdm9pZCBzZXRNYXhpbXVtSW50ZWdlckRpZ2l0cyhpbnQzMl90IG5ld1ZhbHVlKTsKCiAgICAvKioKICAgICAqIFJldHVybnMgdGhlIG1pbmltdW0gbnVtYmVyIG9mIGRpZ2l0cyBhbGxvd2VkIGluIHRoZSBpbnRlZ2VyIHBvcnRpb24gb2YgYQogICAgICogbnVtYmVyLgogICAgICogQHNlZSBzZXRNaW5pbXVtSW50ZWdlckRpZ2l0cwogICAgICovCiAgICBpbnQzMl90IGdldE1pbmltdW1JbnRlZ2VyRGlnaXRzKHZvaWQpIGNvbnN0OwoKICAgIC8qKgogICAgICogU2V0cyB0aGUgbWluaW11bSBudW1iZXIgb2YgZGlnaXRzIGFsbG93ZWQgaW4gdGhlIGludGVnZXIgcG9ydGlvbiBvZiBhCiAgICAgKiBudW1iZXIuIG1pbmltdW1JbnRlZ2VyRGlnaXRzIG11c3QgYmUgJmx0Oz0gbWF4aW11bUludGVnZXJEaWdpdHMuICBJZiB0aGUKICAgICAqIG5ldyB2YWx1ZSBmb3IgbWluaW11bUludGVnZXJEaWdpdHMgZXhjZWVkcyB0aGUgY3VycmVudCB2YWx1ZQogICAgICogb2YgbWF4aW11bUludGVnZXJEaWdpdHMsIHRoZW4gbWF4aW11bUludGVnZXJEaWdpdHMgd2lsbCBhbHNvIGJlIHNldCB0bwogICAgICogdGhlIG5ldyB2YWx1ZS4KICAgICAqIEBzZWUgZ2V0TWluaW11bUludGVnZXJEaWdpdHMKICAgICAqLwogICAgdmlydHVhbCB2b2lkIHNldE1pbmltdW1JbnRlZ2VyRGlnaXRzKGludDMyX3QgbmV3VmFsdWUpOwoKICAgIC8qKgogICAgICogUmV0dXJucyB0aGUgbWF4aW11bSBudW1iZXIgb2YgZGlnaXRzIGFsbG93ZWQgaW4gdGhlIGZyYWN0aW9uIHBvcnRpb24gb2YgYQogICAgICogbnVtYmVyLgogICAgICogQHNlZSBzZXRNYXhpbXVtRnJhY3Rpb25EaWdpdHMKICAgICAqLwogICAgaW50MzJfdCBnZXRNYXhpbXVtRnJhY3Rpb25EaWdpdHModm9pZCkgY29uc3Q7CgogICAgLyoqCiAgICAgKiBTZXRzIHRoZSBtYXhpbXVtIG51bWJlciBvZiBkaWdpdHMgYWxsb3dlZCBpbiB0aGUgZnJhY3Rpb24gcG9ydGlvbiBvZiBhCiAgICAgKiBudW1iZXIuIG1heGltdW1GcmFjdGlvbkRpZ2l0cyBtdXN0IGJlID49IG1pbmltdW1GcmFjdGlvbkRpZ2l0cy4gIElmIHRoZQogICAgICogbmV3IHZhbHVlIGZvciBtYXhpbXVtRnJhY3Rpb25EaWdpdHMgaXMgbGVzcyB0aGFuIHRoZSBjdXJyZW50IHZhbHVlCiAgICAgKiBvZiBtaW5pbXVtRnJhY3Rpb25EaWdpdHMsIHRoZW4gbWluaW11bUZyYWN0aW9uRGlnaXRzIHdpbGwgYWxzbyBiZSBzZXQgdG8KICAgICAqIHRoZSBuZXcgdmFsdWUuCiAgICAgKiBAc2VlIGdldE1heGltdW1GcmFjdGlvbkRpZ2l0cwogICAgICovCiAgICB2aXJ0dWFsIHZvaWQgc2V0TWF4aW11bUZyYWN0aW9uRGlnaXRzKGludDMyX3QgbmV3VmFsdWUpOwoKICAgIC8qKgogICAgICogUmV0dXJucyB0aGUgbWluaW11bSBudW1iZXIgb2YgZGlnaXRzIGFsbG93ZWQgaW4gdGhlIGZyYWN0aW9uIHBvcnRpb24gb2YgYQogICAgICogbnVtYmVyLgogICAgICogQHNlZSBzZXRNaW5pbXVtRnJhY3Rpb25EaWdpdHMKICAgICAqLwogICAgaW50MzJfdCBnZXRNaW5pbXVtRnJhY3Rpb25EaWdpdHModm9pZCkgY29uc3Q7CgogICAgLyoqCiAgICAgKiBTZXRzIHRoZSBtaW5pbXVtIG51bWJlciBvZiBkaWdpdHMgYWxsb3dlZCBpbiB0aGUgZnJhY3Rpb24gcG9ydGlvbiBvZiBhCiAgICAgKiBudW1iZXIuIG1pbmltdW1GcmFjdGlvbkRpZ2l0cyBtdXN0IGJlICZsdDs9IG1heGltdW1GcmFjdGlvbkRpZ2l0cy4gICBJZiB0aGUKICAgICAqIG5ldyB2YWx1ZSBmb3IgbWluaW11bUZyYWN0aW9uRGlnaXRzIGV4Y2VlZHMgdGhlIGN1cnJlbnQgdmFsdWUKICAgICAqIG9mIG1heGltdW1GcmFjdGlvbkRpZ2l0cywgdGhlbiBtYXhpbXVtSW50ZWdlckRpZ2l0cyB3aWxsIGFsc28gYmUgc2V0IHRvCiAgICAgKiB0aGUgbmV3IHZhbHVlCiAgICAgKiBAc2VlIGdldE1pbmltdW1GcmFjdGlvbkRpZ2l0cwogICAgICovCiAgICB2aXJ0dWFsIHZvaWQgc2V0TWluaW11bUZyYWN0aW9uRGlnaXRzKGludDMyX3QgbmV3VmFsdWUpOwoKcHVibGljOgoKICAgIC8qKgogICAgICogUmV0dXJuIHRoZSBjbGFzcyBJRCBmb3IgdGhpcyBjbGFzcy4gIFRoaXMgaXMgdXNlZnVsIG9ubHkgZm9yCiAgICAgKiBjb21wYXJpbmcgdG8gYSByZXR1cm4gdmFsdWUgZnJvbSBnZXREeW5hbWljQ2xhc3NJRCgpLiAgRm9yIGV4YW1wbGU6CiAgICAgKiA8cHJlPgogICAgICogLiAgIEJhc2UqIHBvbHltb3JwaGljX3BvaW50ZXIgPSBjcmVhdGVQb2x5bW9ycGhpY09iamVjdCgpOwogICAgICogLiAgIGlmIChwb2x5bW9ycGhpY19wb2ludGVyLT5nZXREeW5hbWljQ2xhc3NJRCgpID09CiAgICAgKiAuICAgICAgIERlcml2ZWQ6OmdldFN0YXRpY0NsYXNzSUQoKSkgLi4uCiAgICAgKiA8L3ByZT4KICAgICAqIEByZXR1cm4gVGhlIGNsYXNzIElEIGZvciBhbGwgb2JqZWN0cyBvZiB0aGlzIGNsYXNzLgogICAgICovCiAgICBzdGF0aWMgVUNsYXNzSUQgZ2V0U3RhdGljQ2xhc3NJRCh2b2lkKSB7IHJldHVybiAoVUNsYXNzSUQpJmZnQ2xhc3NJRDsgfQoKICAgIC8qKgogICAgICogT3ZlcnJpZGUgQ2FsZW5kYXIKICAgICAqIFJldHVybnMgYSB1bmlxdWUgY2xhc3MgSUQgUE9MWU1PUlBISUNBTExZLiAgUHVyZSB2aXJ0dWFsIG92ZXJyaWRlLgogICAgICogVGhpcyBtZXRob2QgaXMgdG8gaW1wbGVtZW50IGEgc2ltcGxlIHZlcnNpb24gb2YgUlRUSSwgc2luY2Ugbm90IGFsbAogICAgICogQysrIGNvbXBpbGVycyBzdXBwb3J0IGdlbnVpbmUgUlRUSS4gIFBvbHltb3JwaGljIG9wZXJhdG9yPT0oKSBhbmQKICAgICAqIGNsb25lKCkgbWV0aG9kcyBjYWxsIHRoaXMgbWV0aG9kLgogICAgICogPFA+CiAgICAgKiBAcmV0dXJuIFRoZSBjbGFzcyBJRCBmb3IgdGhpcyBvYmplY3QuIEFsbCBvYmplY3RzIG9mIGEKICAgICAqIGdpdmVuIGNsYXNzIGhhdmUgdGhlIHNhbWUgY2xhc3MgSUQuICBPYmplY3RzIG9mCiAgICAgKiBvdGhlciBjbGFzc2VzIGhhdmUgZGlmZmVyZW50IGNsYXNzIElEcy4KICAgICAqLwogICAgdmlydHVhbCBVQ2xhc3NJRCBnZXREeW5hbWljQ2xhc3NJRCh2b2lkKSBjb25zdCB7IHJldHVybiBnZXRTdGF0aWNDbGFzc0lEKCk7IH0KCnByb3RlY3RlZDoKCiAgICAvKioKICAgICAqIERlZmF1bHQgY29uc3RydWN0b3IgZm9yIHN1YmNsYXNzIHVzZSBvbmx5LgogICAgICovCiAgICBOdW1iZXJGb3JtYXQoKTsKCiAgICAvKioKICAgICAqIENvcHkgY29uc3RydWN0b3IuCiAgICAgKi8KICAgIE51bWJlckZvcm1hdChjb25zdCBOdW1iZXJGb3JtYXQmKTsKCiAgICAvKioKICAgICAqIEFzc2lnbm1lbnQgb3BlcmF0b3IuCiAgICAgKi8KICAgIE51bWJlckZvcm1hdCYgb3BlcmF0b3I9KGNvbnN0IE51bWJlckZvcm1hdCYpOwoKcHJvdGVjdGVkOgogICAgc3RhdGljIGNvbnN0IGludDMyX3QgZmdNYXhJbnRlZ2VyRGlnaXRzOwogICAgc3RhdGljIGNvbnN0IGludDMyX3QgZmdNaW5JbnRlZ2VyRGlnaXRzOwoKcHJpdmF0ZToKICAgIHN0YXRpYyBjaGFyIGZnQ2xhc3NJRDsKCiAgICBlbnVtIEVTdHlsZXMgewogICAgICAgIGtOdW1iZXJTdHlsZSwKICAgICAgICBrQ3VycmVuY3lTdHlsZSwKICAgICAgICBrUGVyY2VudFN0eWxlLAogICAgICAgIGtTY2llbnRpZmljU3R5bGUsCiAgICAgICAga1N0eWxlQ291bnQgLy8gQUxXQVlTIExBU1QgRU5VTTogbnVtYmVyIG9mIHN0eWxlcwogICAgfTsKCiAgICBzdGF0aWMgTnVtYmVyRm9ybWF0KiBjcmVhdGVJbnN0YW5jZShjb25zdCBMb2NhbGUmIGRlc2lyZWRMb2NhbGUsIEVTdHlsZXMgY2hvaWNlLCBVRXJyb3JDb2RlJiBzdWNjZXNzKTsKCiAgICBzdGF0aWMgY29uc3QgaW50MzJfdCAgICAgICAgIGZnTnVtYmVyUGF0dGVybnNDb3VudDsKICAgIHN0YXRpYyBjb25zdCBVbmljb2RlU3RyaW5nICAgICBmZ0xhc3RSZXNvcnROdW1iZXJQYXR0ZXJuc1tdOwoKICAgIGJvb2xfdCAgICAgIGZHcm91cGluZ1VzZWQ7CiAgICBpbnQzMl90ICAgICBmTWF4SW50ZWdlckRpZ2l0czsKICAgIGludDMyX3QgICAgIGZNaW5JbnRlZ2VyRGlnaXRzOwogICAgaW50MzJfdCAgICAgZk1heEZyYWN0aW9uRGlnaXRzOwogICAgaW50MzJfdCAgICAgZk1pbkZyYWN0aW9uRGlnaXRzOwogICAgYm9vbF90ICAgICAgZlBhcnNlSW50ZWdlck9ubHk7Cn07CiAKLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogCmlubGluZSBib29sX3QKTnVtYmVyRm9ybWF0Ojppc1BhcnNlSW50ZWdlck9ubHkoKSBjb25zdAp7CiAgICByZXR1cm4gZlBhcnNlSW50ZWdlck9ubHk7Cn0KCmlubGluZSBVbmljb2RlU3RyaW5nJgpOdW1iZXJGb3JtYXQ6OmZvcm1hdChjb25zdCBGb3JtYXR0YWJsZSYgb2JqLAogICAgICAgICAgICAgICAgICAgICBVbmljb2RlU3RyaW5nJiByZXN1bHQsCiAgICAgICAgICAgICAgICAgICAgIFVFcnJvckNvZGUmIHN0YXR1cykgY29uc3QgewogICAgcmV0dXJuIEZvcm1hdDo6Zm9ybWF0KG9iaiwgcmVzdWx0LCBzdGF0dXMpOwp9CiAKI2VuZGlmIC8vIF9OVU1GTVQKLy9lb2YK