LyotCiAqIENvcHlyaWdodCAoYykgMTk5MCBUaGUgUmVnZW50cyBvZiB0aGUgVW5pdmVyc2l0eSBvZiBDYWxpZm9ybmlhLgogKiBBbGwgcmlnaHRzIHJlc2VydmVkLgogKgogKiBSZWRpc3RyaWJ1dGlvbiBhbmQgdXNlIGluIHNvdXJjZSBhbmQgYmluYXJ5IGZvcm1zLCB3aXRoIG9yIHdpdGhvdXQKICogbW9kaWZpY2F0aW9uLCBhcmUgcGVybWl0dGVkIHByb3ZpZGVkIHRoYXQgdGhlIGZvbGxvd2luZyBjb25kaXRpb25zCiAqIGFyZSBtZXQ6CiAqIDEuIFJlZGlzdHJpYnV0aW9ucyBvZiBzb3VyY2UgY29kZSBtdXN0IHJldGFpbiB0aGUgYWJvdmUgY29weXJpZ2h0CiAqICAgIG5vdGljZSwgdGhpcyBsaXN0IG9mIGNvbmRpdGlvbnMgYW5kIHRoZSBmb2xsb3dpbmcgZGlzY2xhaW1lci4KICogMi4gUmVkaXN0cmlidXRpb25zIGluIGJpbmFyeSBmb3JtIG11c3QgcmVwcm9kdWNlIHRoZSBhYm92ZSBjb3B5cmlnaHQKICogICAgbm90aWNlLCB0aGlzIGxpc3Qgb2YgY29uZGl0aW9ucyBhbmQgdGhlIGZvbGxvd2luZyBkaXNjbGFpbWVyIGluIHRoZQogKiAgICBkb2N1bWVudGF0aW9uIGFuZC9vciBvdGhlciBtYXRlcmlhbHMgcHJvdmlkZWQgd2l0aCB0aGUgZGlzdHJpYnV0aW9uLgogKiAzLiBBbGwgYWR2ZXJ0aXNpbmcgbWF0ZXJpYWxzIG1lbnRpb25pbmcgZmVhdHVyZXMgb3IgdXNlIG9mIHRoaXMgc29mdHdhcmUKICogICAgbXVzdCBkaXNwbGF5IHRoZSBmb2xsb3dpbmcgYWNrbm93bGVkZ2VtZW50OgogKglUaGlzIHByb2R1Y3QgaW5jbHVkZXMgc29mdHdhcmUgZGV2ZWxvcGVkIGJ5IHRoZSBVbml2ZXJzaXR5IG9mCiAqCUNhbGlmb3JuaWEsIEJlcmtlbGV5IGFuZCBpdHMgY29udHJpYnV0b3JzLgogKiA0LiBOZWl0aGVyIHRoZSBuYW1lIG9mIHRoZSBVbml2ZXJzaXR5IG5vciB0aGUgbmFtZXMgb2YgaXRzIGNvbnRyaWJ1dG9ycwogKiAgICBtYXkgYmUgdXNlZCB0byBlbmRvcnNlIG9yIHByb21vdGUgcHJvZHVjdHMgZGVyaXZlZCBmcm9tIHRoaXMgc29mdHdhcmUKICogICAgd2l0aG91dCBzcGVjaWZpYyBwcmlvciB3cml0dGVuIHBlcm1pc3Npb24uCiAqCiAqIFRISVMgU09GVFdBUkUgSVMgUFJPVklERUQgQlkgVEhFIFJFR0VOVFMgQU5EIENPTlRSSUJVVE9SUyBgYEFTIElTJycgQU5ECiAqIEFOWSBFWFBSRVNTIE9SIElNUExJRUQgV0FSUkFOVElFUywgSU5DTFVESU5HLCBCVVQgTk9UIExJTUlURUQgVE8sIFRIRQogKiBJTVBMSUVEIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZIEFORCBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRQogKiBBUkUgRElTQ0xBSU1FRC4gIElOIE5PIEVWRU5UIFNIQUxMIFRIRSBSRUdFTlRTIE9SIENPTlRSSUJVVE9SUyBCRSBMSUFCTEUKICogRk9SIEFOWSBESVJFQ1QsIElORElSRUNULCBJTkNJREVOVEFMLCBTUEVDSUFMLCBFWEVNUExBUlksIE9SIENPTlNFUVVFTlRJQUwKICogREFNQUdFUyAoSU5DTFVESU5HLCBCVVQgTk9UIExJTUlURUQgVE8sIFBST0NVUkVNRU5UIE9GIFNVQlNUSVRVVEUgR09PRFMKICogT1IgU0VSVklDRVM7IExPU1MgT0YgVVNFLCBEQVRBLCBPUiBQUk9GSVRTOyBPUiBCVVNJTkVTUyBJTlRFUlJVUFRJT04pCiAqIEhPV0VWRVIgQ0FVU0VEIEFORCBPTiBBTlkgVEhFT1JZIE9GIExJQUJJTElUWSwgV0hFVEhFUiBJTiBDT05UUkFDVCwgU1RSSUNUCiAqIExJQUJJTElUWSwgT1IgVE9SVCAoSU5DTFVESU5HIE5FR0xJR0VOQ0UgT1IgT1RIRVJXSVNFKSBBUklTSU5HIElOIEFOWSBXQVkKICogT1VUIE9GIFRIRSBVU0UgT0YgVEhJUyBTT0ZUV0FSRSwgRVZFTiBJRiBBRFZJU0VEIE9GIFRIRSBQT1NTSUJJTElUWSBPRgogKiBTVUNIIERBTUFHRS4KICovCgogLyogMTk5OS0wMi0yMiBBcmthZGl1c3ogTWm2a2lld2ljeiA8bWlzaWVrQHBsZC5PUkcuUEw+CiAgKiAtIGFkZGVkIE5hdGl2ZSBMYW5ndWFnZSBTdXBwb3J0CiAgKi8KCiNpbmNsdWRlIDxzeXMvdHlwZXMuaD4KI2luY2x1ZGUgPHN0ZGxpYi5oPgojaW5jbHVkZSA8c3RkaW8uaD4KI2luY2x1ZGUgPGN0eXBlLmg+CQkvKiBmb3IgaXNkaWdpdCgpICovCiNpbmNsdWRlIDx1bmlzdGQuaD4JCS8qIGZvciBnZXRvcHQoKSAqLwojaW5jbHVkZSAiaGV4ZHVtcC5oIgojaW5jbHVkZSAibmxzLmgiCgpzdGF0aWMgdm9pZCBvZG9mZnNldChpbnQsIGNoYXIgKioqKTsKc3RhdGljIHZvaWQgb2RwcmVjZWRlKHZvaWQpOwoKaW50IGRlcHJlY2F0ZWQ7Cgp2b2lkCm9sZHN5bnRheChpbnQgYXJnYywgY2hhciAqKiphcmd2cCkKewoJaW50IGNoOwoJY2hhciAqKmFyZ3Y7CgoJZGVwcmVjYXRlZCA9IDE7Cglhcmd2ID0gKmFyZ3ZwOwoJd2hpbGUgKChjaCA9IGdldG9wdChhcmdjLCBhcmd2LCAiYUJiY0RkZUZmSGhJaUxsT29QcHN3dlh4IikpICE9IC0xKQoJCXN3aXRjaCAoY2gpIHsKCQljYXNlICdhJzoKCQkJb2RwcmVjZWRlKCk7CgkJCWFkZCgiMTYvMSBcIiUzX3UgXCIgXCJcXG5cIiIpOwoJCQlicmVhazsKCQljYXNlICdCJzoKCQljYXNlICdvJzoKCQkJb2RwcmVjZWRlKCk7CgkJCWFkZCgiOC8yIFwiICUwNm8gXCIgXCJcXG5cIiIpOwoJCQlicmVhazsKCQljYXNlICdiJzoKCQkJb2RwcmVjZWRlKCk7CgkJCWFkZCgiMTYvMSBcIiUwM28gXCIgXCJcXG5cIiIpOwoJCQlicmVhazsKCQljYXNlICdjJzoKCQkJb2RwcmVjZWRlKCk7CgkJCWFkZCgiMTYvMSBcIiUzX2MgXCIgXCJcXG5cIiIpOwoJCQlicmVhazsKCQljYXNlICdkJzoKCQkJb2RwcmVjZWRlKCk7CgkJCWFkZCgiOC8yIFwiICAlMDV1IFwiIFwiXFxuXCIiKTsKCQkJYnJlYWs7CgkJY2FzZSAnRCc6CgkJCW9kcHJlY2VkZSgpOwoJCQlhZGQoIjQvNCBcIiAgICAgJTAxMHUgXCIgXCJcXG5cIiIpOwoJCQlicmVhazsKCQljYXNlICdlJzoJCS8qIHVuZG9jdW1lbnRlZCBpbiBvZCAqLwoJCWNhc2UgJ0YnOgoJCQlvZHByZWNlZGUoKTsKCQkJYWRkKCIyLzggXCIgICAgICAgICAgJTIxLjE0ZSBcIiBcIlxcblwiIik7CgkJCWJyZWFrOwoJCQkKCQljYXNlICdmJzoKCQkJb2RwcmVjZWRlKCk7CgkJCWFkZCgiNC80IFwiICUxNC43ZSBcIiBcIlxcblwiIik7CgkJCWJyZWFrOwoJCWNhc2UgJ0gnOgoJCWNhc2UgJ1gnOgoJCQlvZHByZWNlZGUoKTsKCQkJYWRkKCI0LzQgXCIgICAgICAgJTA4eCBcIiBcIlxcblwiIik7CgkJCWJyZWFrOwoJCWNhc2UgJ2gnOgoJCWNhc2UgJ3gnOgoJCQlvZHByZWNlZGUoKTsKCQkJYWRkKCI4LzIgXCIgICAlMDR4IFwiIFwiXFxuXCIiKTsKCQkJYnJlYWs7CgkJY2FzZSAnSSc6CgkJY2FzZSAnTCc6CgkJY2FzZSAnbCc6CgkJCW9kcHJlY2VkZSgpOwoJCQlhZGQoIjQvNCBcIiAgICAlMTFkIFwiIFwiXFxuXCIiKTsKCQkJYnJlYWs7CgkJY2FzZSAnaSc6CgkJCW9kcHJlY2VkZSgpOwoJCQlhZGQoIjgvMiBcIiAlNmQgXCIgXCJcXG5cIiIpOwoJCQlicmVhazsKCQljYXNlICdPJzoKCQkJb2RwcmVjZWRlKCk7CgkJCWFkZCgiNC80IFwiICAgICUwMTFvIFwiIFwiXFxuXCIiKTsKCQkJYnJlYWs7CgkJY2FzZSAndic6CgkJCXZmbGFnID0gQUxMOwoJCQlicmVhazsKCQljYXNlICdQJzoKCQljYXNlICdwJzoKCQljYXNlICdzJzoKCQljYXNlICd3JzoKCQljYXNlICc/JzoKCQlkZWZhdWx0OgoJCQlmcHJpbnRmKHN0ZGVyciwKCQkJICAgIF8oIm9kOiBvZCgxKSBoYXMgYmVlbiBkZXByZWNhdGVkIGZvciBoZXhkdW1wKDEpLlxuIikpOwoJCQlpZiAoY2ggIT0gJz8nKQoJCQkJZnByaW50ZihzdGRlcnIsCl8oIm9kOiBoZXhkdW1wKDEpIGNvbXBhdGliaWxpdHkgZG9lc24ndCBzdXBwb3J0IHRoZSAtJWMgb3B0aW9uJXNcbiIpLAoJCQkJICAgIGNoLCBjaCA9PSAncycgPyBfKCI7IHNlZSBzdHJpbmdzKDEpLiIpIDogIi4iKTsKCQkJdXNhZ2UoKTsKCQl9CgoJaWYgKCFmc2hlYWQpIHsKCQlhZGQoIlwiJTA3LjdfQW9cblwiIik7CgkJYWRkKCJcIiUwNy43X2FvICBcIiA4LzIgXCIlMDZvIFwiIFwiXFxuXCIiKTsKCX0KCglhcmdjIC09IG9wdGluZDsKCSphcmd2cCArPSBvcHRpbmQ7CgoJaWYgKGFyZ2MpCgkJb2RvZmZzZXQoYXJnYywgYXJndnApOwp9CgojZGVmaW5lCWlzaGV4ZGlnaXQoYykgXAoJKChjID49ICcwJyAmJiBjIDw9ICc5JykgfHwgKGMgPj0gJ2EnICYmIGMgPD0gJ2YnKSB8fCAoYyA+PSAnQScgJiYgYyA8PSAnRicpKQoKc3RhdGljIHZvaWQKb2RvZmZzZXQoaW50IGFyZ2MsIGNoYXIgKioqYXJndnApCnsKCWNoYXIgKm51bSwgKnA7CglpbnQgYmFzZTsKCWNoYXIgKmVuZDsKCgkvKgoJICogVGhlIG9mZnNldCBzeW50YXggb2Ygb2QoMSkgd2FzIGdlbnVpbmVseSBiaXphcnJlLiAgRmlyc3QsIGlmCgkgKiBpdCBzdGFydGVkIHdpdGggYSBwbHVzIGl0IGhhZCB0byBiZSBhbiBvZmZzZXQuICBPdGhlcndpc2UsIGlmCgkgKiB0aGVyZSB3ZXJlIGF0IGxlYXN0IHR3byBhcmd1bWVudHMsIGEgbnVtYmVyIG9yIGxvd2VyLWNhc2UgJ3gnCgkgKiBmb2xsb3dlZCBieSBhIG51bWJlciBtYWtlcyBpdCBhbiBvZmZzZXQuICBCeSBkZWZhdWx0IGl0IHdhcwoJICogb2N0YWw7IGlmIGl0IHN0YXJ0ZWQgd2l0aCAneCcgb3IgJzB4JyBpdCB3YXMgaGV4LiAgSWYgaXQgZW5kZWQKCSAqIGluIGEgJy4nLCBpdCB3YXMgZGVjaW1hbC4gIElmIGEgJ2InIG9yICdCJyB3YXMgYXBwZW5kZWQsIGl0CgkgKiBtdWx0aXBsaWVkIHRoZSBudW1iZXIgYnkgNTEyIG9yIDEwMjQgYnl0ZSB1bml0cy4gIFRoZXJlIHdhcwoJICogbm8gd2F5IHRvIGFzc2lnbiBhIGJsb2NrIGNvdW50IHRvIGEgaGV4IG9mZnNldC4KCSAqCgkgKiBXZSBhc3N1bWUgaXQncyBhIGZpbGUgaWYgdGhlIG9mZnNldCBpcyBiYWQuCgkgKi8KCXAgPSBhcmdjID09IDEgPyAoKmFyZ3ZwKVswXSA6ICgqYXJndnApWzFdOwoJaWYgKCFwKQoJCXJldHVybjsKCglpZiAoKnAgIT0gJysnICYmIChhcmdjIDwgMiB8fAoJICAgICghaXNkaWdpdCgodW5zaWduZWQgY2hhcilwWzBdKSAmJgoJICAgICAocFswXSAhPSAneCcgfHwgIWlzaGV4ZGlnaXQocFsxXSkpKSkpCgkJcmV0dXJuOwoKCWJhc2UgPSAwOwoJLyoKCSAqIHNraXAgb3ZlciBsZWFkaW5nICcrJywgJ3hbMC05YS1mQS1mXScgb3IgJzB4JywgYW5kCgkgKiBzZXQgYmFzZS4KCSAqLwoJaWYgKHBbMF0gPT0gJysnKQoJCSsrcDsKCWlmIChwWzBdID09ICd4JyAmJiBpc2hleGRpZ2l0KHBbMV0pKSB7CgkJKytwOwoJCWJhc2UgPSAxNjsKCX0gZWxzZSBpZiAocFswXSA9PSAnMCcgJiYgcFsxXSA9PSAneCcpIHsKCQlwICs9IDI7CgkJYmFzZSA9IDE2OwoJfQoKCS8qIHNraXAgb3ZlciB0aGUgbnVtYmVyICovCglpZiAoYmFzZSA9PSAxNikKCQlmb3IgKG51bSA9IHA7IGlzaGV4ZGlnaXQoKnApOyArK3ApOwoJZWxzZQoJCWZvciAobnVtID0gcDsgaXNkaWdpdCgodW5zaWduZWQgY2hhcikqcCk7ICsrcCk7CgoJLyogY2hlY2sgZm9yIG5vIG51bWJlciAqLwoJaWYgKG51bSA9PSBwKQoJCXJldHVybjsKCgkvKiBpZiB0ZXJtaW5hdGVzIHdpdGggYSAnLicsIGJhc2UgaXMgZGVjaW1hbCAqLwoJaWYgKCpwID09ICcuJykgewoJCWlmIChiYXNlKQoJCQlyZXR1cm47CgkJYmFzZSA9IDEwOwoJfQoKCXNraXAgPSBzdHJ0b2wobnVtLCAmZW5kLCBiYXNlID8gYmFzZSA6IDgpOwoKCS8qIGlmIGVuZCBpc24ndCB0aGUgc2FtZSBhcyBwLCB3ZSBnb3QgYSBub24tb2N0YWwgZGlnaXQgKi8KCWlmIChlbmQgIT0gcCkgewoJCXNraXAgPSAwOwoJCXJldHVybjsKCX0KCglpZiAoKnApIHsKCQlpZiAoKnAgPT0gJ0InKSB7CgkJCXNraXAgKj0gMTAyNDsKCQkJcCsrOwoJCX0gZWxzZSBpZiAoKnAgPT0gJ2InKSB7CgkJCXNraXAgKj0gNTEyOwoJCQlwKys7CgkJfQoJfQoKCWlmICgqcCkgewoJCXNraXAgPSAwOwoJCXJldHVybjsKCX0KCgkvKgoJICogSWYgdGhlIG9mZnNldCB1c2VzIGEgbm9uLW9jdGFsIGJhc2UsIHRoZSBiYXNlIG9mCgkgKiB0aGUgb2Zmc2V0IGlzIGNoYW5nZWQgYXMgd2VsbC4gIFRoaXMgaXNuJ3QgcHJldHR5LAoJICogYnV0IGl0J3MgZWFzeS4KCSAqLwojZGVmaW5lCVRZUEVfT0ZGU0VUCTcKCWlmIChiYXNlID09IDE2KSB7CgkJZnNoZWFkLT5uZXh0ZnUtPmZtdFtUWVBFX09GRlNFVF0gPSAneCc7CgkJZnNoZWFkLT5uZXh0ZnMtPm5leHRmdS0+Zm10W1RZUEVfT0ZGU0VUXSA9ICd4JzsKCX0gZWxzZSBpZiAoYmFzZSA9PSAxMCkgewoJCWZzaGVhZC0+bmV4dGZ1LT5mbXRbVFlQRV9PRkZTRVRdID0gJ2QnOwoJCWZzaGVhZC0+bmV4dGZzLT5uZXh0ZnUtPmZtdFtUWVBFX09GRlNFVF0gPSAnZCc7Cgl9CgoJLyogVGVybWluYXRlIGZpbGUgbGlzdC4gKi8KCSgqYXJndnApWzFdID0gTlVMTDsKfQoKc3RhdGljIHZvaWQKb2RwcmVjZWRlKHZvaWQpCnsKCXN0YXRpYyBpbnQgZmlyc3QgPSAxOwoKCWlmIChmaXJzdCkgewoJCWZpcnN0ID0gMDsKCQlhZGQoIlwiJTA3LjdfQW9cblwiIik7CgkJYWRkKCJcIiUwNy43X2FvICBcIiIpOwoJfSBlbHNlCgkJYWRkKCJcIiAgICAgICAgIFwiIik7Cn0K