LyoKICogTU1JTyBmdW5jdGlvbnMKICoKICogQ29weXJpZ2h0IDE5OTggQW5kcmV3IFRheWxvcgogKiBDb3B5cmlnaHQgMTk5OCBPdmUgS+V2ZW4KICogQ29weXJpZ2h0IDIwMDAsMjAwMiBFcmljIFBvdWVjaAogKgogKiBUaGlzIGxpYnJhcnkgaXMgZnJlZSBzb2Z0d2FyZTsgeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yCiAqIG1vZGlmeSBpdCB1bmRlciB0aGUgdGVybXMgb2YgdGhlIEdOVSBMZXNzZXIgR2VuZXJhbCBQdWJsaWMKICogTGljZW5zZSBhcyBwdWJsaXNoZWQgYnkgdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbjsgZWl0aGVyCiAqIHZlcnNpb24gMi4xIG9mIHRoZSBMaWNlbnNlLCBvciAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLgogKgogKiBUaGlzIGxpYnJhcnkgaXMgZGlzdHJpYnV0ZWQgaW4gdGhlIGhvcGUgdGhhdCBpdCB3aWxsIGJlIHVzZWZ1bCwKICogYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2YKICogTUVSQ0hBTlRBQklMSVRZIG9yIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFLiAgU2VlIHRoZSBHTlUKICogTGVzc2VyIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy4KICoKICogWW91IHNob3VsZCBoYXZlIHJlY2VpdmVkIGEgY29weSBvZiB0aGUgR05VIExlc3NlciBHZW5lcmFsIFB1YmxpYwogKiBMaWNlbnNlIGFsb25nIHdpdGggdGhpcyBsaWJyYXJ5OyBpZiBub3QsIHdyaXRlIHRvIHRoZSBGcmVlIFNvZnR3YXJlCiAqIEZvdW5kYXRpb24sIEluYy4sIDU5IFRlbXBsZSBQbGFjZSwgU3VpdGUgMzMwLCBCb3N0b24sIE1BICAwMjExMS0xMzA3ICBVU0EKICovCgovKiBTdGlsbCB0byBiZSBkb25lOgogKiAJKyBjb3JyZWN0IGhhbmRsaW5nIG9mIGdsb2JhbC9sb2NhbCBJT1Byb2NzIChhbmQgdGVtcG9yYXJ5IElPUHJvY3MpCiAqCSsgbW9kZSBvZiBtbWlvIG9iamVjdHMgaXMgbm90IHVzZWQgKHJlYWQgdnMgd3JpdGUgdnMgcmVhZHdyaXRlKQogKgkrIHRocmVhZCBzYWZlbmVzcwogKiAgICAgICsgMzIgQSA8PT4gVyBtZXNzYWdlIG1hcHBpbmcKICovCgoKI2luY2x1ZGUgPGN0eXBlLmg+CiNpbmNsdWRlIDxzdGRhcmcuaD4KI2luY2x1ZGUgPHN0ZGxpYi5oPgojaW5jbHVkZSA8c3RyaW5nLmg+CiNpbmNsdWRlIDxlcnJuby5oPgojaW5jbHVkZSA8YXNzZXJ0Lmg+CgojaW5jbHVkZSAid2luZGVmLmgiCiNpbmNsdWRlICJ3aW5iYXNlLmgiCiNpbmNsdWRlICJ3aW5ubHMuaCIKI2luY2x1ZGUgIm1tc3lzdGVtLmgiCiNpbmNsdWRlICJ3aW5lbW0uaCIKCiNpbmNsdWRlICJ3aW5lL2RlYnVnLmgiCgpXSU5FX0RFRkFVTFRfREVCVUdfQ0hBTk5FTChtbWlvKTsKCkxSRVNVTFQgICAgICAgICAoKnBGbk1taW9DYWxsYmFjazE2KShEV09SRCxMUE1NSU9JTkZPLFVJTlQsTFBBUkFNLExQQVJBTSkgLyogPSBOVUxMICovOwoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICAgICAgCW1taW9Eb3NJT1Byb2MgICAgICAgICAgIAkJW2ludGVybmFsXQogKi8Kc3RhdGljIExSRVNVTFQgQ0FMTEJBQ0sgbW1pb0Rvc0lPUHJvYyhMUE1NSU9JTkZPIGxwbW1pb2luZm8sIFVJTlQgdU1lc3NhZ2UsCgkJCQkgICAgICBMUEFSQU0gbFBhcmFtMSwgTFBBUkFNIGxQYXJhbTIpCnsKICAgIExSRVNVTFQJcmV0ID0gTU1TWVNFUlJfTk9FUlJPUjsKCiAgICBUUkFDRSgiKCVwLCAlWCwgMHglbHgsIDB4JWx4KTtcbiIsIGxwbW1pb2luZm8sIHVNZXNzYWdlLCBsUGFyYW0xLCBsUGFyYW0yKTsKCiAgICBzd2l0Y2ggKHVNZXNzYWdlKSB7CiAgICBjYXNlIE1NSU9NX09QRU46Cgl7CgkgICAgLyogUGFyYW1ldGVyczoKCSAgICAgKiBsUGFyYW0xID0gc3pGaWxlTmFtZSBwYXJhbWV0ZXIgZnJvbSBtbWlvT3BlbgoJICAgICAqIGxQYXJhbTIgPSByZXNlcnZlZAoJICAgICAqIFJldHVybnM6IHplcm8gb24gc3VjY2VzcywgZXJyb3IgY29kZSBvbiBlcnJvcgoJICAgICAqIE5PVEU6IGxEaXNrT2Zmc2V0IGF1dG9tYXRpY2FsbHkgc2V0IHRvIHplcm8KCSAgICAgKi8KCSAgICBMUENTVFIgICAgICBzekZpbGVOYW1lID0gKExQQ1NUUilsUGFyYW0xOwoKCSAgICBpZiAobHBtbWlvaW5mby0+ZHdGbGFncyAmIE1NSU9fR0VUVEVNUCkgewoJCUZJWE1FKCJNTUlPX0dFVFRFTVAgbm90IGltcGxlbWVudGVkXG4iKTsKCQlyZXR1cm4gTU1JT0VSUl9DQU5OT1RPUEVOOwoJICAgIH0KCgkgICAgLyogaWYgZmlsZW5hbWUgTlVMTCwgYXNzdW1lIG9wZW4gZmlsZSBoYW5kbGUgaW4gYWR3SW5mb1swXSAqLwoJICAgIGlmIChzekZpbGVOYW1lKSB7CiAgICAgICAgICAgICAgICBPRlNUUlVDVCAgICBvZnM7CiAgICAgICAgICAgICAgICBscG1taW9pbmZvLT5hZHdJbmZvWzBdID0gKERXT1JEKU9wZW5GaWxlKHN6RmlsZU5hbWUsICZvZnMsIGxwbW1pb2luZm8tPmR3RmxhZ3MgJiAweEZGRkYpOwogICAgICAgICAgICB9CgkgICAgaWYgKGxwbW1pb2luZm8tPmFkd0luZm9bMF0gPT0gKERXT1JEKUhGSUxFX0VSUk9SKQoJCXJldCA9IE1NSU9FUlJfQ0FOTk9UT1BFTjsKCX0KCWJyZWFrOwoKICAgIGNhc2UgTU1JT01fQ0xPU0U6CgkvKiBQYXJhbWV0ZXJzOgoJICogbFBhcmFtMSA9IHdGbGFncyBwYXJhbWV0ZXIgZnJvbSBtbWlvQ2xvc2UKCSAqIGxQYXJhbTIgPSB1bnVzZWQKCSAqIFJldHVybnM6IHplcm8gb24gc3VjY2VzcywgZXJyb3IgY29kZSBvbiBlcnJvcgoJICovCglpZiAoIShsUGFyYW0xICYgTU1JT19GSE9QRU4pKQoJICAgIF9sY2xvc2UoKEhGSUxFKWxwbW1pb2luZm8tPmFkd0luZm9bMF0pOwoJYnJlYWs7CgogICAgY2FzZSBNTUlPTV9SRUFEOgoJLyogUGFyYW1ldGVyczoKCSAqIGxQYXJhbTEgPSBodWdlIHBvaW50ZXIgdG8gcmVhZCBidWZmZXIKCSAqIGxQYXJhbTIgPSBudW1iZXIgb2YgYnl0ZXMgdG8gcmVhZAoJICogUmV0dXJuczogbnVtYmVyIG9mIGJ5dGVzIHJlYWQsIDAgZm9yIEVPRiwgLTEgZm9yIGVycm9yIChlcnJvciBjb2RlCgkgKgkgICBpbiB3RXJyb3JSZXQpCgkgKi8KCXJldCA9IF9scmVhZCgoSEZJTEUpbHBtbWlvaW5mby0+YWR3SW5mb1swXSwgKEhQU1RSKWxQYXJhbTEsIChMT05HKWxQYXJhbTIpOwoJaWYgKHJldCAhPSAtMSkKCSAgICBscG1taW9pbmZvLT5sRGlza09mZnNldCArPSByZXQ7CgoJYnJlYWs7CgogICAgY2FzZSBNTUlPTV9XUklURToKICAgIGNhc2UgTU1JT01fV1JJVEVGTFVTSDoKCS8qIG5vIGludGVybmFsIGJ1ZmZlcmluZywgc28gV1JJVEVGTFVTSCBoYW5kbGVkIHNhbWUgYXMgV1JJVEUgKi8KCgkvKiBQYXJhbWV0ZXJzOgoJICogbFBhcmFtMSA9IGh1Z2UgcG9pbnRlciB0byB3cml0ZSBidWZmZXIKCSAqIGxQYXJhbTIgPSBudW1iZXIgb2YgYnl0ZXMgdG8gd3JpdGUKCSAqIFJldHVybnM6IG51bWJlciBvZiBieXRlcyB3cml0dGVuLCAtMSBmb3IgZXJyb3IgKGVycm9yIGNvZGUgaW4KCSAqCQl3RXJyb3JSZXQpCgkgKi8KCXJldCA9IF9od3JpdGUoKEhGSUxFKWxwbW1pb2luZm8tPmFkd0luZm9bMF0sIChIUFNUUilsUGFyYW0xLCAoTE9ORylsUGFyYW0yKTsKCWlmIChyZXQgIT0gLTEpCgkgICAgbHBtbWlvaW5mby0+bERpc2tPZmZzZXQgKz0gcmV0OwoJYnJlYWs7CgogICAgY2FzZSBNTUlPTV9TRUVLOgoJLyogUGFyYW1ldGVyczoKCSAqIGxQYXJhbTEgPSBuZXcgcG9zaXRpb24KCSAqIGxQYXJhbTIgPSBmcm9tIHdoZW5jZSB0byBzZWVrIChTRUVLX1NFVCwgU0VFS19DVVIsIFNFRUtfRU5EKQoJICogUmV0dXJuczogbmV3IGZpbGUgcG9zdGlvbiwgLTEgb24gZXJyb3IKCSAqLwoJcmV0ID0gX2xsc2VlaygoSEZJTEUpbHBtbWlvaW5mby0+YWR3SW5mb1swXSwgKExPTkcpbFBhcmFtMSwgKExPTkcpbFBhcmFtMik7CglpZiAocmV0ICE9IC0xKQoJICAgIGxwbW1pb2luZm8tPmxEaXNrT2Zmc2V0ID0gcmV0OwoJcmV0dXJuIHJldDsKCiAgICBjYXNlIE1NSU9NX1JFTkFNRToKCS8qIFBhcmFtZXRlcnM6CgkgKiBsUGFyYW0xID0gb2xkIG5hbWUKCSAqIGxQYXJhbTIgPSBuZXcgbmFtZQoJICogUmV0dXJuczogemVybyBvbiBzdWNjZXNzLCBub24temVybyBvbiBmYWlsdXJlCgkgKi8KIAkgaWYgKCFNb3ZlRmlsZUEoKGNvbnN0IGNoYXIqKWxQYXJhbTEsIChjb25zdCBjaGFyKilsUGFyYW0yKSkKCSAgICAgcmV0ID0gTU1JT0VSUl9GSUxFTk9URk9VTkQ7CgkgYnJlYWs7CgogICAgZGVmYXVsdDoKCUZJWE1FKCJ1bmV4cGVjdGVkIG1lc3NhZ2UgJXVcbiIsIHVNZXNzYWdlKTsKCXJldHVybiAwOwogICAgfQoKICAgIHJldHVybiByZXQ7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAgICAgICAgIAltbWlvTWVtSU9Qcm9jICAgICAgICAgICAJCVtpbnRlcm5hbF0KICovCnN0YXRpYyBMUkVTVUxUIENBTExCQUNLIG1taW9NZW1JT1Byb2MoTFBNTUlPSU5GTyBscG1taW9pbmZvLCBVSU5UIHVNZXNzYWdlLAoJCQkJICAgICAgTFBBUkFNIGxQYXJhbTEsIExQQVJBTSBsUGFyYW0yKQp7CiAgICBUUkFDRSgiKCVwLDB4JTA0eCwweCUwOGx4LDB4JTA4bHgpXG4iLCBscG1taW9pbmZvLCB1TWVzc2FnZSwgbFBhcmFtMSwgbFBhcmFtMik7CgogICAgc3dpdGNoICh1TWVzc2FnZSkgewoKICAgIGNhc2UgTU1JT01fT1BFTjoKCS8qIFBhcmFtZXRlcnM6CgkgKiBsUGFyYW0xID0gZmlsZW5hbWUgKG11c3QgYmUgTlVMTCkKCSAqIGxQYXJhbTIgPSByZXNlcnZlZAoJICogUmV0dXJuczogemVybyBvbiBzdWNjZXNzLCBlcnJvciBjb2RlIG9uIGVycm9yCgkgKiBOT1RFOiBsRGlza09mZnNldCBhdXRvbWF0aWNhbGx5IHNldCB0byB6ZXJvCgkgKi8KCS8qIEZJWE1FOiBpbyBwcm9jIHNob3VsZG4ndCBjaGFuZ2UgaXQgKi8KCWlmICghKGxwbW1pb2luZm8tPmR3RmxhZ3MgJiBNTUlPX0NSRUFURSkpCgkgICAgbHBtbWlvaW5mby0+cGNoRW5kUmVhZCA9IGxwbW1pb2luZm8tPnBjaEVuZFdyaXRlOwogICAgICAgIGxwbW1pb2luZm8tPmFkd0luZm9bMF0gPSBIRklMRV9FUlJPUjsKCXJldHVybiAwOwoKICAgIGNhc2UgTU1JT01fQ0xPU0U6CgkvKiBQYXJhbWV0ZXJzOgoJICogbFBhcmFtMSA9IHdGbGFncyBwYXJhbWV0ZXIgZnJvbSBtbWlvQ2xvc2UKCSAqIGxQYXJhbTIgPSB1bnVzZWQKCSAqIFJldHVybnM6IHplcm8gb24gc3VjY2VzcywgZXJyb3IgY29kZSBvbiBlcnJvcgoJICovCglyZXR1cm4gMDsKCiAgICBjYXNlIE1NSU9NX1JFQUQ6CgkvKiBQYXJhbWV0ZXJzOgoJICogbFBhcmFtMSA9IGh1Z2UgcG9pbnRlciB0byByZWFkIGJ1ZmZlcgoJICogbFBhcmFtMiA9IG51bWJlciBvZiBieXRlcyB0byByZWFkCgkgKiBSZXR1cm5zOiBudW1iZXIgb2YgYnl0ZXMgcmVhZCwgMCBmb3IgRU9GLCAtMSBmb3IgZXJyb3IgKGVycm9yIGNvZGUKCSAqCSAgIGluIHdFcnJvclJldCkKCSAqIE5PVEU6IGxEaXNrT2Zmc2V0IHNob3VsZCBiZSB1cGRhdGVkCgkgKi8KCUZJWE1FKCJNTUlPTV9SRUFEIG9uIG1lbW9yeSBmaWxlcyBzaG91bGQgbm90IG9jY3VyLCBidWZmZXIgbWF5IGJlIGxvc3QhXG4iKTsKCXJldHVybiAwOwoKICAgIGNhc2UgTU1JT01fV1JJVEU6CiAgICBjYXNlIE1NSU9NX1dSSVRFRkxVU0g6CgkvKiBubyBpbnRlcm5hbCBidWZmZXJpbmcsIHNvIFdSSVRFRkxVU0ggaGFuZGxlZCBzYW1lIGFzIFdSSVRFICovCgoJLyogUGFyYW1ldGVyczoKCSAqIGxQYXJhbTEgPSBodWdlIHBvaW50ZXIgdG8gd3JpdGUgYnVmZmVyCgkgKiBsUGFyYW0yID0gbnVtYmVyIG9mIGJ5dGVzIHRvIHdyaXRlCgkgKiBSZXR1cm5zOiBudW1iZXIgb2YgYnl0ZXMgd3JpdHRlbiwgLTEgZm9yIGVycm9yIChlcnJvciBjb2RlIGluCgkgKgkJd0Vycm9yUmV0KQoJICogTk9URTogbERpc2tPZmZzZXQgc2hvdWxkIGJlIHVwZGF0ZWQKCSAqLwoJRklYTUUoIk1NSU9NX1dSSVRFIG9uIG1lbW9yeSBmaWxlcyBzaG91bGQgbm90IG9jY3VyLCBidWZmZXIgbWF5IGJlIGxvc3QhXG4iKTsKCXJldHVybiAwOwoKICAgIGNhc2UgTU1JT01fU0VFSzoKCS8qIFBhcmFtZXRlcnM6CgkgKiBsUGFyYW0xID0gbmV3IHBvc2l0aW9uCgkgKiBsUGFyYW0yID0gZnJvbSB3aGVuY2UgdG8gc2VlayAoU0VFS19TRVQsIFNFRUtfQ1VSLCBTRUVLX0VORCkKCSAqIFJldHVybnM6IG5ldyBmaWxlIHBvc3Rpb24sIC0xIG9uIGVycm9yCgkgKiBOT1RFOiBsRGlza09mZnNldCBzaG91bGQgYmUgdXBkYXRlZAoJICovCglGSVhNRSgiTU1JT01fU0VFSyBvbiBtZW1vcnkgZmlsZXMgc2hvdWxkIG5vdCBvY2N1ciwgYnVmZmVyIG1heSBiZSBsb3N0IVxuIik7CglyZXR1cm4gLTE7CgogICAgZGVmYXVsdDoKCUZJWE1FKCJ1bmV4cGVjdGVkIG1lc3NhZ2UgJXVcbiIsIHVNZXNzYWdlKTsKCXJldHVybiAwOwogICAgfQp9CgovKiBUaGlzIGFycmF5IHdpbGwgYmUgdGhlIGVudGlyZSBsaXN0IGZvciBtb3N0IGFwcHMgCiAqIE5vdGUgdGhhdCB0ZW1wb3JhcnkgaW9Qcm9jcyB3aWxsIGJlIHN0b3JlZCB3aXRoIGEgMCBmb3VyQ0MgY29kZQogKi8KCnN0YXRpYyBzdHJ1Y3QgSU9Qcm9jTGlzdCBkZWZhdWx0UHJvY3NbXSA9IHsKICAgIHsmZGVmYXVsdFByb2NzWzFdLCBGT1VSQ0NfRE9TLCAoTFBNTUlPUFJPQyltbWlvRG9zSU9Qcm9jLCBNTUlPX1BST0NfMzJBLCAwfSwKICAgIHtOVUxMLCAgICAgICAgICAgICBGT1VSQ0NfTUVNLCAoTFBNTUlPUFJPQyltbWlvTWVtSU9Qcm9jLCBNTUlPX1BST0NfMzJBLCAwfSwKfTsKCnN0YXRpYyBzdHJ1Y3QgSU9Qcm9jTGlzdCoJcElPUHJvY0xpc3RBbmNob3IgPSAmZGVmYXVsdFByb2NzWzBdOwoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgCU1NSU9fRmluZFByb2NOb2RlIAkJCVtJTlRFUk5BTF0KICoKICogRmluZHMgdGhlIFByb2NMaXN0IG5vZGUgYXNzb2NpYXRlZCB3aXRoIGEgZ2l2ZW4gRk9VUkNDIGNvZGUuCiAqLwpzdGF0aWMgc3RydWN0IElPUHJvY0xpc3QqCU1NSU9fRmluZFByb2NOb2RlKEZPVVJDQyBmY2NJT1Byb2MpCnsKICAgIHN0cnVjdCBJT1Byb2NMaXN0KglwTGlzdE5vZGU7CgogICAgZm9yIChwTGlzdE5vZGUgPSBwSU9Qcm9jTGlzdEFuY2hvcjsgcExpc3ROb2RlOyBwTGlzdE5vZGUgPSBwTGlzdE5vZGUtPnBOZXh0KSB7CglpZiAocExpc3ROb2RlLT5mb3VyQ0MgPT0gZmNjSU9Qcm9jKSB7CgkgICAgcmV0dXJuIHBMaXN0Tm9kZTsKCX0KICAgIH0KICAgIHJldHVybiBOVUxMOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAJTU1JT19JbnN0YWxsSU9Qcm9jIAkJCVtJTlRFUk5BTF0KICovCkxQTU1JT1BST0MgTU1JT19JbnN0YWxsSU9Qcm9jKEZPVVJDQyBmY2NJT1Byb2MsIExQTU1JT1BST0MgcElPUHJvYywKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgRFdPUkQgZHdGbGFncywgZW51bSBtbWlvUHJvY1R5cGUgdHlwZSkKewogICAgTFBNTUlPUFJPQwkgICAgICAgIGxwUHJvYyA9IE5VTEw7CiAgICBzdHJ1Y3QgSU9Qcm9jTGlzdCogIHBMaXN0Tm9kZTsKICAgIHN0cnVjdCBJT1Byb2NMaXN0KiogcHBMaXN0Tm9kZTsKCiAgICBUUkFDRSgiKCUwOGx4LCAlcCwgJTA4bFgsICVpKVxuIiwgZmNjSU9Qcm9jLCBwSU9Qcm9jLCBkd0ZsYWdzLCB0eXBlKTsKCiAgICBpZiAoZHdGbGFncyAmIE1NSU9fR0xPQkFMUFJPQykKCUZJWE1FKCJHbG9iYWwgcHJvY2VkdXJlcyBub3QgaW1wbGVtZW50ZWRcbiIpOwoKICAgIC8qIGp1c3QgaGFuZGxlIHRoZSBrbm93biBwcm9jZWR1cmVzIGZvciBub3cgKi8KICAgIHN3aXRjaCAoZHdGbGFncyAmIChNTUlPX0lOU1RBTExQUk9DfE1NSU9fUkVNT1ZFUFJPQ3xNTUlPX0ZJTkRQUk9DKSkgewogICAgY2FzZSBNTUlPX0lOU1RBTExQUk9DOgoJLyogQ3JlYXRlIG5ldyBlbnRyeSBmb3IgdGhlIElPUHJvYyBsaXN0ICovCglwTGlzdE5vZGUgPSBIZWFwQWxsb2MoR2V0UHJvY2Vzc0hlYXAoKSwgMCwgc2l6ZW9mKCpwTGlzdE5vZGUpKTsKCWlmIChwTGlzdE5vZGUpIHsKCSAgICAvKiBGaWxsIGluIHRoaXMgbm9kZSAqLwoJICAgIHBMaXN0Tm9kZS0+Zm91ckNDID0gZmNjSU9Qcm9jOwoJICAgIHBMaXN0Tm9kZS0+cElPUHJvYyA9IHBJT1Byb2M7CgkgICAgcExpc3ROb2RlLT50eXBlID0gdHlwZTsKCSAgICBwTGlzdE5vZGUtPmNvdW50ID0gMDsKCgkgICAgLyogU3RpY2sgaXQgb24gdGhlIGVuZCBvZiB0aGUgbGlzdCAqLwoJICAgIHBMaXN0Tm9kZS0+cE5leHQgPSBwSU9Qcm9jTGlzdEFuY2hvcjsKCSAgICBwSU9Qcm9jTGlzdEFuY2hvciA9IHBMaXN0Tm9kZTsKCgkgICAgLyogUmV0dXJuIHRoaXMgSU9Qcm9jIC0gdGhhdCdzIGhvdyB0aGUgY2FsbGVyIGtub3dzIHdlIHN1Y2NlZWRlZCAqLwoJICAgIGxwUHJvYyA9IHBJT1Byb2M7Cgl9CglicmVhazsKCiAgICBjYXNlIE1NSU9fUkVNT1ZFUFJPQzoKCS8qCgkgKiBTZWFyY2ggZm9yIHRoZSBub2RlIHRoYXQgd2UncmUgdHJ5aW5nIHRvIHJlbW92ZQogICAgICAgICAqIFdlIHNlYXJjaCBmb3IgYSBtYXRjaGluZyBmb3VyQ0MgY29kZSBpZiBpdCdzIG5vbiBudWxsLCBvciB0aGUgcHJvYwogICAgICAgICAqIGFkZHJlc3Mgb3RoZXJ3aXNlCiAgICAgICAgICogbm90ZSB0aGF0IHRoaXMgbWV0aG9kIHdvbid0IGZpbmQgdGhlIGZpcnN0IGl0ZW0gb24gdGhlIGxpc3QsIGJ1dAoJICogc2luY2UgdGhlIGZpcnN0IHR3byBpdGVtcyBvbiB0aGlzIGxpc3QgYXJlIG9uZXMgd2Ugd29uJ3QKCSAqIGxldCB0aGUgdXNlciBkZWxldGUgYW55d2F5LCB0aGF0J3Mgb2theQoJICovCglwcExpc3ROb2RlID0gJnBJT1Byb2NMaXN0QW5jaG9yOwoJd2hpbGUgKCgqcHBMaXN0Tm9kZSkgJiYgCiAgICAgICAgICAgICAgICgoZmNjSU9Qcm9jICE9IDApID8gCiAgICAgICAgICAgICAgICAoKnBwTGlzdE5vZGUpLT5mb3VyQ0MgIT0gZmNjSU9Qcm9jIDogCiAgICAgICAgICAgICAgICAoKnBwTGlzdE5vZGUpLT5wSU9Qcm9jICE9IHBJT1Byb2MpKQoJICAgIHBwTGlzdE5vZGUgPSAmKCgqcHBMaXN0Tm9kZSktPnBOZXh0KTsKCglpZiAoKnBwTGlzdE5vZGUpIHsgLyogZm91bmQgaXQgKi8KCSAgICAvKiBGSVhNRTogd2hhdCBzaG91bGQgYmUgZG9uZSBpZiBhbiBvcGVuIG1taW8gb2JqZWN0IHVzZXMgdGhpcyBwcm9jID8KCSAgICAgKiBzaGFsbCB3ZSByZXR1cm4gYW4gZXJyb3IsIG51a2UgdGhlIG1taW8gb2JqZWN0ID8KCSAgICAgKi8KCSAgICBpZiAoKCpwcExpc3ROb2RlKS0+Y291bnQpIHsKCQlFUlIoIkNhbm5vdCByZW1vdmUgYSBtbUlPUHJvYyB3aGlsZSBpbiB1c2VcbiIpOwoJCWJyZWFrOwoJICAgIH0KCSAgICAvKiByZW1vdmUgaXQsIGJ1dCBvbmx5IGlmIGl0IGlzbid0IGJ1aWx0aW4gKi8KCSAgICBpZiAoKCpwcExpc3ROb2RlKSA+PSBkZWZhdWx0UHJvY3MgJiYKCQkoKnBwTGlzdE5vZGUpIDwgZGVmYXVsdFByb2NzICsgc2l6ZW9mKGRlZmF1bHRQcm9jcykpIHsKCQlXQVJOKCJUcmllZCB0byByZW1vdmUgYnVpbHQtaW4gbW1pbyBwcm9jLiBTa2lwcGluZ1xuIik7CgkgICAgfSBlbHNlIHsKCQkvKiBPa2F5LCBudWtlIGl0ICovCgkJc3RydWN0IElPUHJvY0xpc3QqICBwdG1wTm9kZSA9ICpwcExpc3ROb2RlOwoJCWxwUHJvYyA9ICgqcHBMaXN0Tm9kZSktPnBJT1Byb2M7CgkJKnBwTGlzdE5vZGUgPSAoKnBwTGlzdE5vZGUpLT5wTmV4dDsKCQlIZWFwRnJlZShHZXRQcm9jZXNzSGVhcCgpLCAwLCBwdG1wTm9kZSk7CgkgICAgfQoJfQoJYnJlYWs7CgogICAgY2FzZSBNTUlPX0ZJTkRQUk9DOgoJaWYgKChwTGlzdE5vZGUgPSBNTUlPX0ZpbmRQcm9jTm9kZShmY2NJT1Byb2MpKSkgewoJICAgIGxwUHJvYyA9IHBMaXN0Tm9kZS0+cElPUHJvYzsKCX0KCWJyZWFrOwogICAgfQoKICAgIHJldHVybiBscFByb2M7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgIAlzZW5kX21lc3NhZ2UgICAgCQkJW0lOVEVSTkFMXQogKi8Kc3RhdGljIExSRVNVTFQJc2VuZF9tZXNzYWdlKHN0cnVjdCBJT1Byb2NMaXN0KiBpb1Byb2MsIExQTU1JT0lORk8gbW1pb2luZm8sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgRFdPUkQgd01zZywgTFBBUkFNIGxQYXJhbTEsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgTFBBUkFNIGxQYXJhbTIsIGVudW0gbW1pb1Byb2NUeXBlIHR5cGUpCnsKICAgIExSRVNVTFQgCQlyZXN1bHQgPSBNTVNZU0VSUl9FUlJPUjsKICAgIExQQVJBTQkJbHAxID0gbFBhcmFtMSwgbHAyID0gbFBhcmFtMjsKCiAgICBpZiAoIWlvUHJvYykgewoJRVJSKCJicnJyXG4iKTsKCXJlc3VsdCA9IE1NU1lTRVJSX0lOVkFMUEFSQU07CiAgICB9CgogICAgc3dpdGNoIChpb1Byb2MtPnR5cGUpIHsKICAgIGNhc2UgTU1JT19QUk9DXzE2OgogICAgICAgIGlmIChwRm5NbWlvQ2FsbGJhY2sxNikKICAgICAgICAgICAgcmVzdWx0ID0gcEZuTW1pb0NhbGxiYWNrMTYoKERXT1JEKWlvUHJvYy0+cElPUHJvYywKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbW1pb2luZm8sIHdNc2csIGxwMSwgbHAyKTsKICAgICAgICBicmVhazsKICAgIGNhc2UgTU1JT19QUk9DXzMyQToKICAgIGNhc2UgTU1JT19QUk9DXzMyVzoKCWlmIChpb1Byb2MtPnR5cGUgIT0gdHlwZSkgewoJICAgIC8qIG1hcCAobFBhcmFtMSwgbFBhcmFtMikgaW50byAobHAxLCBscDIpIDMyIEE8PT5XICovCgkgICAgRklYTUUoIk5JWSAzMiBBPD0+VyBtYXBwaW5nXG4iKTsKCX0KCXJlc3VsdCA9IChpb1Byb2MtPnBJT1Byb2MpKChMUFNUUiltbWlvaW5mbywgd01zZywgbHAxLCBscDIpOwoKI2lmIDAKCWlmIChpb1Byb2MtPnR5cGUgIT0gdHlwZSkgewoJICAgIC8qIHVubWFwIChsUGFyYW0xLCBsUGFyYW0yKSBpbnRvIChscDEsIGxwMikgMzIgQTw9PlcgKi8KCX0KI2VuZGlmCglicmVhazsKICAgIGRlZmF1bHQ6CglGSVhNRSgiSW50ZXJuYWwgZXJyb3JcbiIpOwogICAgfQoKICAgIHJldHVybiByZXN1bHQ7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgIAkJCU1NSU9fUGFyc2VFeHRBIAkJICAgICAgICBbaW50ZXJuYWxdCiAqCiAqIFBhcnNlcyBhIGZpbGVuYW1lIGZvciB0aGUgZXh0ZW5zaW9uLgogKgogKiBSRVRVUk5TCiAqICBUaGUgRk9VUkNDIGNvZGUgZm9yIHRoZSBleHRlbnNpb24gaWYgZm91bmQsIGVsc2UgMC4KICovCnN0YXRpYyBGT1VSQ0MgTU1JT19QYXJzZUV4dEEoTFBDU1RSIHN6RmlsZU5hbWUpCnsKICAgIC8qIEZpbGVuYW1lcyBhcmUgb2YgdGhlIGZvcm0gZmlsZS5leHR7K0FCQ30KICAgICAgIEZvciBub3csIHdlIHRha2UgdGhlIGxhc3QgJysnIGlmIHByZXNlbnQgKi8KCiAgICBGT1VSQ0MgcmV0ID0gMDsKCiAgICAvKiBOb3RlIHRoYXQgZXh0e1N0YXJ0LEVuZH0gcG9pbnQgdG8gdGhlIC4gYW5kICsgcmVzcGVjdGl2ZWx5ICovCiAgICBMUFNUUiBleHRFbmQ7CiAgICBMUFNUUiBleHRTdGFydDsKCiAgICBUUkFDRSgiKCVzKVxuIiwgZGVidWdzdHJfYShzekZpbGVOYW1lKSk7CgogICAgaWYgKCFzekZpbGVOYW1lKQoJcmV0dXJuIHJldDsKCiAgICAvKiBGaW5kIHRoZSBsYXN0ICcuJyAqLwogICAgZXh0U3RhcnQgPSBzdHJyY2hyKHN6RmlsZU5hbWUsJy4nKTsKCiAgICBpZiAoIWV4dFN0YXJ0KSB7CiAgICAgICAgIEVSUigiTm8gLiBpbiBzekZpbGVOYW1lOiAlc1xuIiwgZGVidWdzdHJfYShzekZpbGVOYW1lKSk7CiAgICB9IGVsc2UgewogICAgICAgIENIQVIgZXh0WzVdOwoKICAgICAgICAvKiBGaW5kIHRoZSAnKycgYWZ0ZXJ3YXJkcyAqLwogICAgICAgIGV4dEVuZCA9IHN0cmNocihleHRTdGFydCwnKycpOwogICAgICAgIGlmIChleHRFbmQpIHsKCiAgICAgICAgICAgIGlmIChleHRFbmQgLSBleHRTdGFydCAtIDEgPiA0KQogICAgICAgICAgICAgICAgV0FSTigiRXh0ZW5zaW9uIGxlbmd0aCA+IDRcbiIpOwogICAgICAgICAgICBsc3RyY3B5bkEoZXh0LCBleHRTdGFydCArIDEsIG1pbihleHRFbmQtZXh0U3RhcnQsNSkpOwoKICAgICAgICB9IGVsc2UgewogICAgICAgICAgICAvKiBObyArIHNvIGp1c3QgYW4gZXh0ZW5zaW9uICovCiAgICAgICAgICAgIGlmIChzdHJsZW4oZXh0U3RhcnQpID4gNCkgewogICAgICAgICAgICAgICAgV0FSTigiRXh0ZW5zaW9uIGxlbmd0aCA+IDRcbiIpOwogICAgICAgICAgICB9CiAgICAgICAgICAgIGxzdHJjcHluQShleHQsIGV4dFN0YXJ0ICsgMSwgNSk7CiAgICAgICAgfQogICAgICAgIFRSQUNFKCJHb3QgZXh0ZW5zaW9uOiAlc1xuIiwgZGVidWdzdHJfYShleHQpKTsKCiAgICAgICAgLyogRk9VUkNDIGNvZGVzIGlkZW50aWZ5aW5nIGZpbGUtZXh0ZW5zaW9ucyBtdXN0IGJlIHVwcGVyY2FzZSAqLwogICAgICAgIHJldCA9IG1taW9TdHJpbmdUb0ZPVVJDQ0EoZXh0LCBNTUlPX1RPVVBQRVIpOwogICAgfQogICAgcmV0dXJuIHJldDsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQkJCU1NSU9fR2V0CQkJW2ludGVybmFsXQogKgogKiBSZXRyaWV2ZXMgdGhlIG1taW8gb2JqZWN0IGZyb20gY3VycmVudCBwcm9jZXNzCiAqLwpMUFdJTkVfTU1JTwlNTUlPX0dldChITU1JTyBoKQp7CiAgICBMUFdJTkVfTU1JTwkJd20gPSBOVUxMOwoKICAgIEVudGVyQ3JpdGljYWxTZWN0aW9uKCZXSU5NTV9JRGF0YS5jcyk7CiAgICBmb3IgKHdtID0gV0lOTU1fSURhdGEubHBNTUlPOyB3bTsgd20gPSB3bS0+bHBOZXh0KSB7CglpZiAod20tPmluZm8uaG1taW8gPT0gaCkKCSAgICBicmVhazsKICAgIH0KICAgIExlYXZlQ3JpdGljYWxTZWN0aW9uKCZXSU5NTV9JRGF0YS5jcyk7CiAgICByZXR1cm4gd207Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJCQlNTUlPX0NyZWF0ZQkJCVtpbnRlcm5hbF0KICoKICogQ3JlYXRlcyBhbiBpbnRlcm5hbCByZXByZXNlbnRhdGlvbiBmb3IgYSBtbWlvIGluc3RhbmNlCiAqLwpzdGF0aWMJTFBXSU5FX01NSU8JCU1NSU9fQ3JlYXRlKHZvaWQpCnsKICAgIHN0YXRpYwlXT1JECU1NSU9fY291bnRlciA9IDA7CiAgICBMUFdJTkVfTU1JTwkJd207CgogICAgd20gPSBIZWFwQWxsb2MoR2V0UHJvY2Vzc0hlYXAoKSwgSEVBUF9aRVJPX01FTU9SWSwgc2l6ZW9mKFdJTkVfTU1JTykpOwogICAgaWYgKHdtKSB7CglFbnRlckNyaXRpY2FsU2VjdGlvbigmV0lOTU1fSURhdGEuY3MpOwogICAgICAgIC8qIGxvb2t1cCBuZXh0IHVuYWxsb2NhdGVkIFdPUkQgaGFuZGxlLCB3aXRoIGEgbm9uIE5VTEwgdmFsdWUgKi8KCXdoaWxlICgrK01NSU9fY291bnRlciA9PSAwIHx8IE1NSU9fR2V0KChITU1JTykoVUxPTkdfUFRSKU1NSU9fY291bnRlcikpOwoJd20tPmluZm8uaG1taW8gPSAoSE1NSU8pKFVMT05HX1BUUilNTUlPX2NvdW50ZXI7Cgl3bS0+bHBOZXh0ID0gV0lOTU1fSURhdGEubHBNTUlPOwoJV0lOTU1fSURhdGEubHBNTUlPID0gd207CglMZWF2ZUNyaXRpY2FsU2VjdGlvbigmV0lOTU1fSURhdGEuY3MpOwogICAgfQogICAgcmV0dXJuIHdtOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCQkJTU1JT19EZXN0cm95CQkJW2ludGVybmFsXQogKi0KICogRGVzdHJveXMgYW4gaW50ZXJuYWwgcmVwcmVzZW50YXRpb24gZm9yIGEgbW1pbyBpbnN0YW5jZQogKi8Kc3RhdGljCUJPT0wJCU1NSU9fRGVzdHJveShMUFdJTkVfTU1JTyB3bSkKewogICAgTFBXSU5FX01NSU8qCW07CgogICAgRW50ZXJDcml0aWNhbFNlY3Rpb24oJldJTk1NX0lEYXRhLmNzKTsKICAgIC8qIHNlYXJjaCBmb3IgdGhlIG1hdGNoaW5nIG9uZS4uLiAqLwogICAgbSA9ICYoV0lOTU1fSURhdGEubHBNTUlPKTsKICAgIHdoaWxlICgqbSAmJiAqbSAhPSB3bSkgbSA9ICYoKm0pLT5scE5leHQ7CiAgICAvKiAuLi5hbmQgZGVzdHJveSAqLwogICAgaWYgKCptKSB7CgkqbSA9ICgqbSktPmxwTmV4dDsKCUhlYXBGcmVlKEdldFByb2Nlc3NIZWFwKCksIDAsIHdtKTsKCXdtID0gTlVMTDsKICAgIH0KICAgIExlYXZlQ3JpdGljYWxTZWN0aW9uKCZXSU5NTV9JRGF0YS5jcyk7CiAgICByZXR1cm4gd20gPyBGQUxTRSA6IFRSVUU7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgIAkJTU1JT19GbHVzaCAJCQlbSU5URVJOQUxdCiAqLwpzdGF0aWMJTU1SRVNVTFQgTU1JT19GbHVzaChXSU5FX01NSU8qIHdtLCBVSU5UIHVGbGFncykKewogICAgaWYgKHdtLT5pbmZvLmNjaEJ1ZmZlciAmJiAod20tPmluZm8uZmNjSU9Qcm9jICE9IEZPVVJDQ19NRU0pKSB7CgkvKiBub3QgcXVpdGUgc3VyZSB3aGF0IHRvIGRvIGhlcmUsIGJ1dCBJJ2xsIGd1ZXNzICovCglpZiAod20tPmluZm8uZHdGbGFncyAmIE1NSU9fRElSVFkpIHsKICAgICAgICAgICAgLyogRklYTUU6IGVycm9yIGhhbmRsaW5nICovCgkgICAgc2VuZF9tZXNzYWdlKHdtLT5pb1Byb2MsICZ3bS0+aW5mbywgTU1JT01fU0VFSywgCiAgICAgICAgICAgICAgICAgICAgICAgICB3bS0+aW5mby5sQnVmT2Zmc2V0LCBTRUVLX1NFVCwgTU1JT19QUk9DXzMyQSk7CgkgICAgc2VuZF9tZXNzYWdlKHdtLT5pb1Byb2MsICZ3bS0+aW5mbywgTU1JT01fV1JJVEUsIAogICAgICAgICAgICAgICAgICAgICAgICAgKExQQVJBTSl3bS0+aW5mby5wY2hCdWZmZXIsCiAgICAgICAgICAgICAgICAgICAgICAgICB3bS0+aW5mby5wY2hOZXh0IC0gd20tPmluZm8ucGNoQnVmZmVyLCBNTUlPX1BST0NfMzJBKTsKCX0KCWlmICh1RmxhZ3MgJiBNTUlPX0VNUFRZQlVGKQoJICAgIHdtLT5pbmZvLnBjaE5leHQgPSB3bS0+aW5mby5wY2hFbmRSZWFkID0gd20tPmluZm8ucGNoQnVmZmVyOwogICAgfQogICAgd20tPmluZm8uZHdGbGFncyAmPSB+TU1JT19ESVJUWTsKCiAgICByZXR1cm4gTU1TWVNFUlJfTk9FUlJPUjsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAJCU1NSU9fR3JhYk5leHRCdWZmZXIJCQlbSU5URVJOQUxdCiAqLwpzdGF0aWMgTE9ORwlNTUlPX0dyYWJOZXh0QnVmZmVyKExQV0lORV9NTUlPIHdtLCBpbnQgZm9yX3JlYWQpCnsKICAgIExPTkcJc2l6ZSA9IHdtLT5pbmZvLmNjaEJ1ZmZlcjsKCiAgICBUUkFDRSgiYm89JWx4IGRvPSVseCBvZj0lbHhcbiIsCgkgIHdtLT5pbmZvLmxCdWZPZmZzZXQsIHdtLT5pbmZvLmxEaXNrT2Zmc2V0LAoJICBzZW5kX21lc3NhZ2Uod20tPmlvUHJvYywgJndtLT5pbmZvLCBNTUlPTV9TRUVLLCAwLCBTRUVLX0NVUiwgTU1JT19QUk9DXzMyQSkpOwoKICAgIHdtLT5pbmZvLmxCdWZPZmZzZXQgPSB3bS0+aW5mby5sRGlza09mZnNldDsKICAgIHdtLT5pbmZvLnBjaE5leHQgPSB3bS0+aW5mby5wY2hCdWZmZXI7CiAgICB3bS0+aW5mby5wY2hFbmRSZWFkID0gd20tPmluZm8ucGNoQnVmZmVyOwogICAgd20tPmluZm8ucGNoRW5kV3JpdGUgPSB3bS0+aW5mby5wY2hCdWZmZXIgKyB3bS0+aW5mby5jY2hCdWZmZXI7CgogICAgd20tPmJCdWZmZXJMb2FkZWQgPSBUUlVFOwogICAgaWYgKGZvcl9yZWFkKSB7CglzaXplID0gc2VuZF9tZXNzYWdlKHdtLT5pb1Byb2MsICZ3bS0+aW5mbywgTU1JT01fUkVBRCwgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAoTFBBUkFNKXdtLT5pbmZvLnBjaEJ1ZmZlciwgc2l6ZSwgTU1JT19QUk9DXzMyQSk7CglpZiAoc2l6ZSA+IDApCgkgICAgd20tPmluZm8ucGNoRW5kUmVhZCArPSBzaXplOwogICAgICAgIGVsc2UKICAgICAgICAgICAgd20tPmJCdWZmZXJMb2FkZWQgPSBGQUxTRTsKICAgIH0KCiAgICByZXR1cm4gc2l6ZTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAJCU1NSU9fU2V0QnVmZmVyIAkJCQlbSU5URVJOQUxdCiAqLwpzdGF0aWMgTU1SRVNVTFQgTU1JT19TZXRCdWZmZXIoV0lORV9NTUlPKiB3bSwgdm9pZCogcGNoQnVmZmVyLCBMT05HIGNjaEJ1ZmZlciwKCQkJICAgICAgIFVJTlQgdUZsYWdzKQp7CiAgICBUUkFDRSgiKCVwICVwICVsZCAldSlcbiIsIHdtLCBwY2hCdWZmZXIsIGNjaEJ1ZmZlciwgdUZsYWdzKTsKCiAgICBpZiAodUZsYWdzKQkJCXJldHVybiBNTVNZU0VSUl9JTlZBTFBBUkFNOwogICAgaWYgKGNjaEJ1ZmZlciA+IDB4RkZGRikKCVdBUk4oIlVudGVzdGVkIGhhbmRsaW5nIG9mIGh1Z2UgbW1pbyBidWZmZXJzICglbGQgPj0gNjRrKVxuIiwgY2NoQnVmZmVyKTsKCiAgICBpZiAoTU1JT19GbHVzaCh3bSwgMCkgIT0gTU1TWVNFUlJfTk9FUlJPUikKCXJldHVybiBNTUlPRVJSX0NBTk5PVFdSSVRFOwoKICAgIC8qIGZyZWUgcHJldmlvdXMgYnVmZmVyIGlmIGFsbG9jYXRlZCAqLwogICAgaWYgKHdtLT5pbmZvLmR3RmxhZ3MgJiBNTUlPX0FMTE9DQlVGKSB7CiAgICAgICAgSGVhcEZyZWUoR2V0UHJvY2Vzc0hlYXAoKSwgMCwgd20tPmluZm8ucGNoQnVmZmVyKTsKICAgICAgICB3bS0+aW5mby5wY2hCdWZmZXIgPSBOVUxMOwoJd20tPmluZm8uZHdGbGFncyAmPSB+TU1JT19BTExPQ0JVRjsKICAgIH0KCiAgICBpZiAocGNoQnVmZmVyKSB7CiAgICAgICAgd20tPmluZm8ucGNoQnVmZmVyID0gcGNoQnVmZmVyOwogICAgfSBlbHNlIGlmIChjY2hCdWZmZXIpIHsKCWlmICghKHdtLT5pbmZvLnBjaEJ1ZmZlciA9IEhlYXBBbGxvYyhHZXRQcm9jZXNzSGVhcCgpLCAwLCBjY2hCdWZmZXIpKSkKCSAgICByZXR1cm4gTU1JT0VSUl9PVVRPRk1FTU9SWTsKCXdtLT5pbmZvLmR3RmxhZ3MgfD0gTU1JT19BTExPQ0JVRjsKICAgIH0gZWxzZSB7Cgl3bS0+aW5mby5wY2hCdWZmZXIgPSBOVUxMOwogICAgfQoKICAgIHdtLT5pbmZvLmNjaEJ1ZmZlciA9IGNjaEJ1ZmZlcjsKICAgIHdtLT5pbmZvLnBjaE5leHQgPSB3bS0+aW5mby5wY2hCdWZmZXI7CiAgICB3bS0+aW5mby5wY2hFbmRSZWFkID0gd20tPmluZm8ucGNoQnVmZmVyOwogICAgd20tPmluZm8ucGNoRW5kV3JpdGUgPSB3bS0+aW5mby5wY2hCdWZmZXIgKyBjY2hCdWZmZXI7CiAgICB3bS0+aW5mby5sQnVmT2Zmc2V0ID0gMDsKICAgIHdtLT5iQnVmZmVyTG9hZGVkID0gRkFMU0U7CgogICAgcmV0dXJuIE1NU1lTRVJSX05PRVJST1I7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAJCQlNTUlPX09wZW4gICAgICAgCQkJW2ludGVybmFsXQogKi8KSE1NSU8gTU1JT19PcGVuKExQU1RSIHN6RmlsZU5hbWUsIE1NSU9JTkZPKiByZWZtbWluZm8sIERXT1JEIGR3T3BlbkZsYWdzLCAKICAgICAgICAgICAgICAgIGVudW0gbW1pb1Byb2NUeXBlIHR5cGUpCnsKICAgIExQV0lORV9NTUlPCQl3bTsKICAgIE1NSU9JTkZPICAgIAltbWlvaW5mbzsKCiAgICBUUkFDRSgiKCclcycsICVwLCAlMDhsWCwgJWQpO1xuIiwgc3pGaWxlTmFtZSwgcmVmbW1pbmZvLCBkd09wZW5GbGFncywgdHlwZSk7CgogICAgaWYgKCFyZWZtbWluZm8pIHsKICAgICAgICByZWZtbWluZm8gPSAmbW1pb2luZm87CgoJbW1pb2luZm8uZmNjSU9Qcm9jID0gMDsKCW1taW9pbmZvLnBJT1Byb2MgPSBOVUxMOwoJbW1pb2luZm8ucGNoQnVmZmVyID0gTlVMTDsKCW1taW9pbmZvLmNjaEJ1ZmZlciA9IDA7CiAgICAgICAgdHlwZSA9IE1NSU9fUFJPQ18zMkE7CiAgICB9CgogICAgaWYgKGR3T3BlbkZsYWdzICYgKE1NSU9fUEFSU0V8TU1JT19FWElTVCkpIHsKCWNoYXIJYnVmZmVyW01BWF9QQVRIXTsKCglpZiAoR2V0RnVsbFBhdGhOYW1lQShzekZpbGVOYW1lLCBzaXplb2YoYnVmZmVyKSwgYnVmZmVyLCBOVUxMKSA+PSBzaXplb2YoYnVmZmVyKSkKCSAgICByZXR1cm4gKEhNTUlPKUZBTFNFOwoJaWYgKChkd09wZW5GbGFncyAmIE1NSU9fRVhJU1QpICYmIChHZXRGaWxlQXR0cmlidXRlc0EoYnVmZmVyKSA9PSBJTlZBTElEX0ZJTEVfQVRUUklCVVRFUykpCgkgICAgcmV0dXJuIChITU1JTylGQUxTRTsKCXN0cmNweShzekZpbGVOYW1lLCBidWZmZXIpOwoJcmV0dXJuIChITU1JTylUUlVFOwogICAgfQoKICAgIGlmICgod20gPSBNTUlPX0NyZWF0ZSgpKSA9PSBOVUxMKQoJcmV0dXJuIDA7CgogICAgLyogSWYgYm90aCBwYXJhbXMgYXJlIE5VTEwsIHRoZW4gcGFyc2UgdGhlIGZpbGUgbmFtZSBpZiBhdmFpbGFibGUgKi8KICAgIGlmIChyZWZtbWluZm8tPmZjY0lPUHJvYyA9PSAwICYmIHJlZm1taW5mby0+cElPUHJvYyA9PSBOVUxMKSB7Cgl3bS0+aW5mby5mY2NJT1Byb2MgPSBNTUlPX1BhcnNlRXh0QShzekZpbGVOYW1lKTsKCS8qIEhhbmRsZSBhbnkgdW5oYW5kbGVkL2Vycm9yIGNhc2UuIEFzc3VtZSBET1MgZmlsZSAqLwoJaWYgKHdtLT5pbmZvLmZjY0lPUHJvYyA9PSAwKQoJICAgIHdtLT5pbmZvLmZjY0lPUHJvYyA9IEZPVVJDQ19ET1M7CglpZiAoISh3bS0+aW9Qcm9jID0gTU1JT19GaW5kUHJvY05vZGUod20tPmluZm8uZmNjSU9Qcm9jKSkpIHsKCSAgICAvKiBJZiBub3QgZm91bmQsIHJldHJ5IHdpdGggRk9VUkNDX0RPUyAqLwoJICAgIHdtLT5pbmZvLmZjY0lPUHJvYyA9IEZPVVJDQ19ET1M7CgkgICAgaWYgKCEod20tPmlvUHJvYyA9IE1NSU9fRmluZFByb2NOb2RlKHdtLT5pbmZvLmZjY0lPUHJvYykpKQoJCWdvdG8gZXJyb3IyOwoJfQoJd20tPmJUbXBJT1Byb2MgPSBGQUxTRTsKICAgIH0KICAgIC8qIGlmIGp1c3QgdGhlIGZvdXIgY2hhcmFjdGVyIGNvZGUgaXMgcHJlc2VudCwgbG9vayB1cCBJTyBwcm9jICovCiAgICBlbHNlIGlmIChyZWZtbWluZm8tPnBJT1Byb2MgPT0gTlVMTCkgewoJd20tPmluZm8uZmNjSU9Qcm9jID0gcmVmbW1pbmZvLT5mY2NJT1Byb2M7CglpZiAoISh3bS0+aW9Qcm9jID0gTU1JT19GaW5kUHJvY05vZGUod20tPmluZm8uZmNjSU9Qcm9jKSkpIGdvdG8gZXJyb3IyOwoJd20tPmJUbXBJT1Byb2MgPSBGQUxTRTsKICAgIH0KICAgIC8qIGlmIElPIHByb2Mgc3BlY2lmaWVkLCB1c2UgaXQgYW5kIHNwZWNpZmllZCBmb3VyIGNoYXJhY3RlciBjb2RlICovCiAgICBlbHNlIHsKCXdtLT5pbmZvLmZjY0lPUHJvYyA9IHJlZm1taW5mby0+ZmNjSU9Qcm9jOwoJTU1JT19JbnN0YWxsSU9Qcm9jKHdtLT5pbmZvLmZjY0lPUHJvYywgcmVmbW1pbmZvLT5wSU9Qcm9jLAogICAgICAgICAgICAgICAgICAgICAgICAgICBNTUlPX0lOU1RBTExQUk9DLCB0eXBlKTsKCWlmICghKHdtLT5pb1Byb2MgPSBNTUlPX0ZpbmRQcm9jTm9kZSh3bS0+aW5mby5mY2NJT1Byb2MpKSkgZ290byBlcnJvcjI7Cglhc3NlcnQod20tPmlvUHJvYy0+cElPUHJvYyA9PSByZWZtbWluZm8tPnBJT1Byb2MpOwoJd20tPmJUbXBJT1Byb2MgPSBUUlVFOwogICAgfQoKICAgIHdtLT5iQnVmZmVyTG9hZGVkID0gRkFMU0U7CiAgICB3bS0+aW9Qcm9jLT5jb3VudCsrOwoKICAgIGlmIChkd09wZW5GbGFncyAmIE1NSU9fQUxMT0NCVUYpIHsKCWlmICgocmVmbW1pbmZvLT53RXJyb3JSZXQgPSBNTUlPX1NldEJ1ZmZlcih3bSwgTlVMTCwgTU1JT19ERUZBVUxUQlVGRkVSLCAwKSkpCgkgICAgZ290byBlcnJvcjE7CiAgICB9IGVsc2UgaWYgKHdtLT5pbmZvLmZjY0lPUHJvYyA9PSBGT1VSQ0NfTUVNKSB7CiAgICAgICAgcmVmbW1pbmZvLT53RXJyb3JSZXQgPSBNTUlPX1NldEJ1ZmZlcih3bSwgcmVmbW1pbmZvLT5wY2hCdWZmZXIsIHJlZm1taW5mby0+Y2NoQnVmZmVyLCAwKTsKCWlmIChyZWZtbWluZm8tPndFcnJvclJldCAhPSBNTVNZU0VSUl9OT0VSUk9SKQoJICAgIGdvdG8gZXJyb3IxOwoJd20tPmJCdWZmZXJMb2FkZWQgPSBUUlVFOwogICAgfSAvKiBlbHNlID0+IHVuYnVmZmVyZWQsIHdtLT5pbmZvLnBjaEJ1ZmZlciA9PSBOVUxMICovCgogICAgLyogc2VlIG1taW9Eb3NJT1Byb2MgZm9yIHRoYXQgb25lICovCiAgICB3bS0+aW5mby5hZHdJbmZvWzBdID0gcmVmbW1pbmZvLT5hZHdJbmZvWzBdOwogICAgd20tPmluZm8uZHdGbGFncyA9IGR3T3BlbkZsYWdzOwoKICAgIC8qIGNhbGwgSU8gcHJvYyB0byBhY3R1YWxseSBvcGVuIGZpbGUgKi8KICAgIHJlZm1taW5mby0+d0Vycm9yUmV0ID0gc2VuZF9tZXNzYWdlKHdtLT5pb1Byb2MsICZ3bS0+aW5mbywgTU1JT01fT1BFTiwgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAoTFBBUkFNKXN6RmlsZU5hbWUsIDAsIE1NSU9fUFJPQ18zMkEpOwoKICAgIC8qIGdyYWIgZmlsZSBzaXplLCB3aGVuIHBvc3NpYmxlICovCiAgICB3bS0+ZHdGaWxlU2l6ZSA9IEdldEZpbGVTaXplKChIQU5ETEUpd20tPmluZm8uYWR3SW5mb1swXSwgTlVMTCk7CgogICAgaWYgKHJlZm1taW5mby0+d0Vycm9yUmV0ID09IDApCglyZXR1cm4gd20tPmluZm8uaG1taW87CiBlcnJvcjE6CiAgICBpZiAod20tPmlvUHJvYykgd20tPmlvUHJvYy0+Y291bnQtLTsKIGVycm9yMjoKICAgIE1NSU9fRGVzdHJveSh3bSk7CiAgICByZXR1cm4gMDsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqIAkJCQltbWlvT3BlblcgICAgICAgCQlbV0lOTU0uQF0KICovCkhNTUlPIFdJTkFQSSBtbWlvT3BlblcoTFBXU1RSIHN6RmlsZU5hbWUsIE1NSU9JTkZPKiBscG1taW9pbmZvLAoJCSAgICAgICBEV09SRCBkd09wZW5GbGFncykKewogICAgSE1NSU8gCXJldDsKICAgIExQU1RSCXN6Rm4gPSBOVUxMOwoKICAgIGlmIChzekZpbGVOYW1lKQogICAgewogICAgICAgIElOVCAgICAgbGVuID0gV2lkZUNoYXJUb011bHRpQnl0ZSggQ1BfQUNQLCAwLCBzekZpbGVOYW1lLCAtMSwgTlVMTCwgMCwgTlVMTCwgTlVMTCApOwogICAgICAgIHN6Rm4gPSBIZWFwQWxsb2MoIEdldFByb2Nlc3NIZWFwKCksIDAsIGxlbiApOwogICAgICAgIGlmICghc3pGbikgcmV0dXJuIE5VTEw7CiAgICAgICAgV2lkZUNoYXJUb011bHRpQnl0ZSggQ1BfQUNQLCAwLCBzekZpbGVOYW1lLCAtMSwgc3pGbiwgbGVuLCBOVUxMLCBOVUxMICk7CiAgICB9CgogICAgcmV0ID0gTU1JT19PcGVuKHN6Rm4sIGxwbW1pb2luZm8sIGR3T3BlbkZsYWdzLCBNTUlPX1BST0NfMzJXKTsKCiAgICBIZWFwRnJlZShHZXRQcm9jZXNzSGVhcCgpLCAwLCBzekZuKTsKICAgIHJldHVybiByZXQ7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAJCQkJbW1pb09wZW5BICAgICAgIAkJW1dJTk1NLkBdCiAqLwpITU1JTyBXSU5BUEkgbW1pb09wZW5BKExQU1RSIHN6RmlsZU5hbWUsIE1NSU9JTkZPKiBscG1taW9pbmZvLAoJCSAgICAgICBEV09SRCBkd09wZW5GbGFncykKewogICAgcmV0dXJuICBNTUlPX09wZW4oc3pGaWxlTmFtZSwgbHBtbWlvaW5mbywgZHdPcGVuRmxhZ3MsIE1NSU9fUFJPQ18zMkEpOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogCQkJCW1taW9DbG9zZSAgICAgIAkJW1dJTk1NLkBdCiAqLwpNTVJFU1VMVCBXSU5BUEkgbW1pb0Nsb3NlKEhNTUlPIGhtbWlvLCBVSU5UIHVGbGFncykKewogICAgTFBXSU5FX01NSU8Jd207CiAgICBNTVJFU1VMVCAJcmVzdWx0OwoKICAgIFRSQUNFKCIoJXAsICUwNFgpO1xuIiwgaG1taW8sIHVGbGFncyk7CgogICAgaWYgKCh3bSA9IE1NSU9fR2V0KGhtbWlvKSkgPT0gTlVMTCkKCXJldHVybiBNTVNZU0VSUl9JTlZBTEhBTkRMRTsKCiAgICBpZiAoKHJlc3VsdCA9IE1NSU9fRmx1c2god20sIDApKSAhPSBNTVNZU0VSUl9OT0VSUk9SKQoJcmV0dXJuIHJlc3VsdDsKCiAgICByZXN1bHQgPSBzZW5kX21lc3NhZ2Uod20tPmlvUHJvYywgJndtLT5pbmZvLCBNTUlPTV9DTE9TRSwgCiAgICAgICAgICAgICAgICAgICAgICAgICAgdUZsYWdzLCAwLCBNTUlPX1BST0NfMzJBKTsKCiAgICBNTUlPX1NldEJ1ZmZlcih3bSwgTlVMTCwgMCwgMCk7CgogICAgd20tPmlvUHJvYy0+Y291bnQtLTsKCiAgICBpZiAod20tPmJUbXBJT1Byb2MpCglNTUlPX0luc3RhbGxJT1Byb2Mod20tPmluZm8uZmNjSU9Qcm9jLCB3bS0+aW9Qcm9jLT5wSU9Qcm9jLAogICAgICAgICAgICAgICAgICAgICAgICAgICBNTUlPX1JFTU9WRVBST0MsIHdtLT5pb1Byb2MtPnR5cGUpOwoKICAgIE1NSU9fRGVzdHJveSh3bSk7CgogICAgcmV0dXJuIHJlc3VsdDsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqIAkJCQltbWlvUmVhZAkgICAgICAgCVtXSU5NTS5AXQogKi8KTE9ORyBXSU5BUEkgbW1pb1JlYWQoSE1NSU8gaG1taW8sIEhQU1RSIHBjaCwgTE9ORyBjY2gpCnsKICAgIExQV0lORV9NTUlPCXdtOwogICAgTE9ORyAJY291bnQ7CgogICAgVFJBQ0UoIiglcCwgJXAsICVsZCk7XG4iLCBobW1pbywgcGNoLCBjY2gpOwoKICAgIGlmICgod20gPSBNTUlPX0dldChobW1pbykpID09IE5VTEwpCglyZXR1cm4gLTE7CgogICAgLyogdW5idWZmZXJlZCBjYXNlIGZpcnN0ICovCiAgICBpZiAoIXdtLT5pbmZvLnBjaEJ1ZmZlcikKCXJldHVybiBzZW5kX21lc3NhZ2Uod20tPmlvUHJvYywgJndtLT5pbmZvLCBNTUlPTV9SRUFELCAKICAgICAgICAgICAgICAgICAgICAgICAgICAgIChMUEFSQU0pcGNoLCBjY2gsIE1NSU9fUFJPQ18zMkEpOwoKICAgIC8qIGZpcnN0IHRyeSBmcm9tIGN1cnJlbnQgYnVmZmVyICovCiAgICBpZiAod20tPmluZm8ucGNoTmV4dCAhPSB3bS0+aW5mby5wY2hFbmRSZWFkKSB7Cgljb3VudCA9IHdtLT5pbmZvLnBjaEVuZFJlYWQgLSB3bS0+aW5mby5wY2hOZXh0OwoJaWYgKGNvdW50ID4gY2NoIHx8IGNvdW50IDwgMCkgY291bnQgPSBjY2g7CgltZW1jcHkocGNoLCB3bS0+aW5mby5wY2hOZXh0LCBjb3VudCk7Cgl3bS0+aW5mby5wY2hOZXh0ICs9IGNvdW50OwoJcGNoICs9IGNvdW50OwoJY2NoIC09IGNvdW50OwogICAgfSBlbHNlCgljb3VudCA9IDA7CgogICAgaWYgKGNjaCAmJiAod20tPmluZm8uZmNjSU9Qcm9jICE9IEZPVVJDQ19NRU0pKSB7Cglhc3NlcnQod20tPmluZm8uY2NoQnVmZmVyKTsKCgl3aGlsZSAoY2NoKSB7CgkgICAgTE9ORyBzaXplOwoKCSAgICBzaXplID0gTU1JT19HcmFiTmV4dEJ1ZmZlcih3bSwgVFJVRSk7CgkgICAgaWYgKHNpemUgPD0gMCkgYnJlYWs7CgkgICAgaWYgKHNpemUgPiBjY2gpIHNpemUgPSBjY2g7CgkgICAgbWVtY3B5KHBjaCwgd20tPmluZm8ucGNoQnVmZmVyLCBzaXplKTsKCSAgICB3bS0+aW5mby5wY2hOZXh0ICs9IHNpemU7CgkgICAgcGNoICs9IHNpemU7CgkgICAgY2NoIC09IHNpemU7CgkgICAgY291bnQgKz0gc2l6ZTsKCX0KICAgIH0KCiAgICBUUkFDRSgiY291bnQ9JWxkXG4iLCBjb3VudCk7CiAgICByZXR1cm4gY291bnQ7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAJCQkJbW1pb1dyaXRlICAgICAgCQlbV0lOTU0uQF0KICovCkxPTkcgV0lOQVBJIG1taW9Xcml0ZShITU1JTyBobW1pbywgSFBDU1RSIHBjaCwgTE9ORyBjY2gpCnsKICAgIExQV0lORV9NTUlPCXdtOwogICAgTE9ORwljb3VudDsKCiAgICBUUkFDRSgiKCVwLCAlcCwgJWxkKTtcbiIsIGhtbWlvLCBwY2gsIGNjaCk7CgogICAgaWYgKCh3bSA9IE1NSU9fR2V0KGhtbWlvKSkgPT0gTlVMTCkKCXJldHVybiAtMTsKCiAgICBpZiAod20tPmluZm8uY2NoQnVmZmVyKSB7CglMT05HCWJ5dGVzVyA9IDA7CgogICAgICAgIGNvdW50ID0gMDsKICAgICAgICB3aGlsZSAoY2NoKSB7CiAgICAgICAgICAgIGlmICh3bS0+aW5mby5wY2hOZXh0ICE9IHdtLT5pbmZvLnBjaEVuZFdyaXRlKSB7CiAgICAgICAgICAgICAgICBjb3VudCA9IHdtLT5pbmZvLnBjaEVuZFdyaXRlIC0gd20tPmluZm8ucGNoTmV4dDsKICAgICAgICAgICAgICAgIGlmIChjb3VudCA+IGNjaCB8fCBjb3VudCA8IDApIGNvdW50ID0gY2NoOwogICAgICAgICAgICAgICAgbWVtY3B5KHdtLT5pbmZvLnBjaE5leHQsIHBjaCwgY291bnQpOwogICAgICAgICAgICAgICAgd20tPmluZm8ucGNoTmV4dCArPSBjb3VudDsKICAgICAgICAgICAgICAgIHBjaCArPSBjb3VudDsKICAgICAgICAgICAgICAgIGNjaCAtPSBjb3VudDsKICAgICAgICAgICAgICAgIGJ5dGVzVyArPSBjb3VudDsKICAgICAgICAgICAgICAgIHdtLT5pbmZvLmR3RmxhZ3MgfD0gTU1JT19ESVJUWTsKCSAgICB9IGVsc2UgewogICAgICAgICAgICAgICAgaWYgKHdtLT5pbmZvLmZjY0lPUHJvYyA9PSBGT1VSQ0NfTUVNKSB7CiAgICAgICAgICAgICAgICAgICAgaWYgKHdtLT5pbmZvLmFkd0luZm9bMF0pIHsKICAgICAgICAgICAgICAgICAgICAgICAgLyogZnJvbSB3aGVyZSB3b3VsZCB3ZSBnZXQgdGhlIG1lbW9yeSBoYW5kbGU/ICovCiAgICAgICAgICAgICAgICAgICAgICAgIEZJWE1FKCJtZW1vcnkgZmlsZSBleHBhbnNpb24gbm90IGltcGxlbWVudGVkIVxuIik7CiAgICAgICAgICAgICAgICAgICAgICAgIGJyZWFrOwoJCSAgICB9IGVsc2UgYnJlYWs7CiAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgIH0KCiAgICAgICAgICAgIGlmICh3bS0+aW5mby5wY2hOZXh0ID09IHdtLT5pbmZvLnBjaEVuZFdyaXRlKQogICAgICAgICAgICB7CiAgICAgICAgICAgICAgICBNTUlPX0ZsdXNoKHdtLCBNTUlPX0VNUFRZQlVGKTsKICAgICAgICAgICAgICAgIE1NSU9fR3JhYk5leHRCdWZmZXIod20sIEZBTFNFKTsKICAgICAgICAgICAgfQogICAgICAgICAgICBlbHNlIGJyZWFrOwogICAgICAgIH0KCWNvdW50ID0gYnl0ZXNXOwogICAgfSBlbHNlIHsKCWNvdW50ID0gc2VuZF9tZXNzYWdlKHdtLT5pb1Byb2MsICZ3bS0+aW5mbywgTU1JT01fV1JJVEUsIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgIChMUEFSQU0pcGNoLCBjY2gsIE1NSU9fUFJPQ18zMkEpOwoJd20tPmluZm8ubEJ1Zk9mZnNldCA9IHdtLT5pbmZvLmxEaXNrT2Zmc2V0OwogICAgfQoKICAgIFRSQUNFKCJieXRlcyB3cml0dGVuPSVsZFxuIiwgY291bnQpOwogICAgcmV0dXJuIGNvdW50Owp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogCQkJCW1taW9TZWVrCQlbV0lOTU0uQF0KICovCkxPTkcgV0lOQVBJIG1taW9TZWVrKEhNTUlPIGhtbWlvLCBMT05HIGxPZmZzZXQsIElOVCBpT3JpZ2luKQp7CiAgICBMUFdJTkVfTU1JTwl3bTsKICAgIExPTkcgCW9mZnNldDsKCiAgICBUUkFDRSgiKCVwLCAlMDhsWCwgJWQpO1xuIiwgaG1taW8sIGxPZmZzZXQsIGlPcmlnaW4pOwoKICAgIGlmICgod20gPSBNTUlPX0dldChobW1pbykpID09IE5VTEwpCglyZXR1cm4gTU1TWVNFUlJfSU5WQUxIQU5ETEU7CgogICAgLyogbm90IGJ1ZmZlcmVkLCBkaXJlY3Qgc2VlayBvbiBmaWxlICovCiAgICBpZiAoIXdtLT5pbmZvLnBjaEJ1ZmZlcikKCXJldHVybiBzZW5kX21lc3NhZ2Uod20tPmlvUHJvYywgJndtLT5pbmZvLCBNTUlPTV9TRUVLLCAKICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxPZmZzZXQsIGlPcmlnaW4sIE1NSU9fUFJPQ18zMkEpOwoKICAgIHN3aXRjaCAoaU9yaWdpbikgewogICAgY2FzZSBTRUVLX1NFVDoKCW9mZnNldCA9IGxPZmZzZXQ7CglicmVhazsKICAgIGNhc2UgU0VFS19DVVI6CglvZmZzZXQgPSB3bS0+aW5mby5sQnVmT2Zmc2V0ICsgKHdtLT5pbmZvLnBjaE5leHQgLSB3bS0+aW5mby5wY2hCdWZmZXIpICsgbE9mZnNldDsKCWJyZWFrOwogICAgY2FzZSBTRUVLX0VORDoKCW9mZnNldCA9ICgod20tPmluZm8uZmNjSU9Qcm9jID09IEZPVVJDQ19NRU0pPyB3bS0+aW5mby5jY2hCdWZmZXIgOiB3bS0+ZHdGaWxlU2l6ZSkgLSBsT2Zmc2V0OwoJYnJlYWs7CiAgICBkZWZhdWx0OgoJcmV0dXJuIC0xOwogICAgfQoKICAgIGlmIChvZmZzZXQgJiYgb2Zmc2V0ID49IHdtLT5kd0ZpbGVTaXplICYmIHdtLT5pbmZvLmZjY0lPUHJvYyAhPSBGT1VSQ0NfTUVNKSB7CiAgICAgICAgLyogc2hvdWxkIGNoZWNrIHRoYXQgd3JpdGUgbW9kZSBleGlzdHMgKi8KICAgICAgICBpZiAoTU1JT19GbHVzaCh3bSwgMCkgIT0gTU1TWVNFUlJfTk9FUlJPUikKICAgICAgICAgICAgcmV0dXJuIC0xOwogICAgICAgIHdtLT5pbmZvLmxCdWZPZmZzZXQgPSBvZmZzZXQ7CiAgICAgICAgd20tPmluZm8ucGNoRW5kUmVhZCA9IHdtLT5pbmZvLnBjaEJ1ZmZlcjsKICAgICAgICB3bS0+aW5mby5wY2hFbmRXcml0ZSA9IHdtLT5pbmZvLnBjaEJ1ZmZlciArIHdtLT5pbmZvLmNjaEJ1ZmZlcjsKICAgICAgICBpZiAoKHdtLT5pbmZvLmR3RmxhZ3MgJiBNTUlPX1JXTU9ERSkgPT0gTU1JT19SRUFEKSB7CiAgICAgICAgICAgIHdtLT5pbmZvLmxEaXNrT2Zmc2V0ID0gd20tPmR3RmlsZVNpemU7CiAgICAgICAgfQogICAgfSBlbHNlIGlmICgod20tPmluZm8uY2NoQnVmZmVyID4gMCkgJiYKCSgob2Zmc2V0IDwgd20tPmluZm8ubEJ1Zk9mZnNldCkgfHwKCSAob2Zmc2V0ID49IHdtLT5pbmZvLmxCdWZPZmZzZXQgKyB3bS0+aW5mby5jY2hCdWZmZXIpIHx8CgkgIXdtLT5iQnVmZmVyTG9hZGVkKSkgewogICAgICAgIC8qIHN0YXkgaW4gc2FtZSBidWZmZXIgPyAqLwogICAgICAgIC8qIHNvbWUgbWVtb3J5IG1hcHBlZCBidWZmZXJzIGFyZSBkZWZpbmVkIHdpdGggLTEgYXMgYSBzaXplICovCgoJLyogY29uZGl0aW9uIHRvIGNoYW5nZSBidWZmZXIgKi8KCWlmICgod20tPmluZm8uZmNjSU9Qcm9jID09IEZPVVJDQ19NRU0pIHx8CgkgICAgTU1JT19GbHVzaCh3bSwgMCkgIT0gTU1TWVNFUlJfTk9FUlJPUiB8fAoJICAgIC8qIHRoaXMgYWxzbyBzZXRzIHRoZSB3bS0+aW5mby5sRGlza09mZnNldCBmaWVsZCAqLwoJICAgIHNlbmRfbWVzc2FnZSh3bS0+aW9Qcm9jLCAmd20tPmluZm8sIE1NSU9NX1NFRUssCiAgICAgICAgICAgICAgICAgICAgICAgICAob2Zmc2V0IC8gd20tPmluZm8uY2NoQnVmZmVyKSAqIHdtLT5pbmZvLmNjaEJ1ZmZlciwKICAgICAgICAgICAgICAgICAgICAgICAgIFNFRUtfU0VULCBNTUlPX1BST0NfMzJBKSA9PSAtMSkKCSAgICByZXR1cm4gLTE7CglNTUlPX0dyYWJOZXh0QnVmZmVyKHdtLCBUUlVFKTsKICAgIH0KCiAgICB3bS0+aW5mby5wY2hOZXh0ID0gd20tPmluZm8ucGNoQnVmZmVyICsgKG9mZnNldCAtIHdtLT5pbmZvLmxCdWZPZmZzZXQpOwoKICAgIFRSQUNFKCI9PiAlbGRcbiIsIG9mZnNldCk7CiAgICByZXR1cm4gb2Zmc2V0Owp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogCQkJCW1taW9HZXRJbmZvCSAgICAgICAJW1dJTk1NLkBdCiAqLwpNTVJFU1VMVCBXSU5BUEkgbW1pb0dldEluZm8oSE1NSU8gaG1taW8sIE1NSU9JTkZPKiBscG1taW9pbmZvLCBVSU5UIHVGbGFncykKewogICAgTFBXSU5FX01NSU8JCXdtOwoKICAgIFRSQUNFKCIoJXAsJXAsMHglMDh4KVxuIixobW1pbyxscG1taW9pbmZvLHVGbGFncyk7CgogICAgaWYgKCh3bSA9IE1NSU9fR2V0KGhtbWlvKSkgPT0gTlVMTCkKCXJldHVybiBNTVNZU0VSUl9JTlZBTEhBTkRMRTsKCiAgICBtZW1jcHkobHBtbWlvaW5mbywgJndtLT5pbmZvLCBzaXplb2YoTU1JT0lORk8pKTsKICAgIC8qIGRvbid0IGV4cG9zZSAxNiBiaXQgaW9wcm9jOnMgKi8KICAgIGlmICh3bS0+aW9Qcm9jLT50eXBlICE9IE1NSU9fUFJPQ18xNikKICAgICAgICBscG1taW9pbmZvLT5wSU9Qcm9jID0gd20tPmlvUHJvYy0+cElPUHJvYzsKCiAgICByZXR1cm4gTU1TWVNFUlJfTk9FUlJPUjsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqIAkJCQltbWlvU2V0SW5mbyAgICAJCVtXSU5NTS5AXQogKi8KTU1SRVNVTFQgV0lOQVBJIG1taW9TZXRJbmZvKEhNTUlPIGhtbWlvLCBjb25zdCBNTUlPSU5GTyogbHBtbWlvaW5mbywgVUlOVCB1RmxhZ3MpCnsKICAgIExQV0lORV9NTUlPCQl3bTsKCiAgICBUUkFDRSgiKCVwLCVwLDB4JTA4eClcbiIsaG1taW8sbHBtbWlvaW5mbyx1RmxhZ3MpOwoKICAgIGlmICgod20gPSBNTUlPX0dldChobW1pbykpID09IE5VTEwpCglyZXR1cm4gTU1TWVNFUlJfSU5WQUxIQU5ETEU7CgogICAgLyogY2hlY2sgcG9pbnRlcnMgY29oZXJlbmNlICovCiAgICBpZiAobHBtbWlvaW5mby0+cGNoTmV4dCA8IHdtLT5pbmZvLnBjaEJ1ZmZlciB8fAoJbHBtbWlvaW5mby0+cGNoTmV4dCA+IHdtLT5pbmZvLnBjaEJ1ZmZlciArIHdtLT5pbmZvLmNjaEJ1ZmZlciB8fAoJbHBtbWlvaW5mby0+cGNoRW5kUmVhZCA8IHdtLT5pbmZvLnBjaEJ1ZmZlciB8fAoJbHBtbWlvaW5mby0+cGNoRW5kUmVhZCA+IHdtLT5pbmZvLnBjaEJ1ZmZlciArIHdtLT5pbmZvLmNjaEJ1ZmZlciB8fAoJbHBtbWlvaW5mby0+cGNoRW5kV3JpdGUgPCB3bS0+aW5mby5wY2hCdWZmZXIgfHwKCWxwbW1pb2luZm8tPnBjaEVuZFdyaXRlID4gd20tPmluZm8ucGNoQnVmZmVyICsgd20tPmluZm8uY2NoQnVmZmVyKQoJcmV0dXJuIE1NU1lTRVJSX0lOVkFMUEFSQU07CgogICAgd20tPmluZm8ucGNoTmV4dCA9IGxwbW1pb2luZm8tPnBjaE5leHQ7CiAgICB3bS0+aW5mby5wY2hFbmRSZWFkID0gbHBtbWlvaW5mby0+cGNoRW5kUmVhZDsKCiAgICByZXR1cm4gTU1TWVNFUlJfTk9FUlJPUjsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiogCQkJCW1taW9TZXRCdWZmZXIJCVtXSU5NTS5AXQoqLwpNTVJFU1VMVCBXSU5BUEkgbW1pb1NldEJ1ZmZlcihITU1JTyBobW1pbywgTFBTVFIgcGNoQnVmZmVyLCBMT05HIGNjaEJ1ZmZlciwgVUlOVCB1RmxhZ3MpCnsKICAgIExQV0lORV9NTUlPCQl3bTsKCiAgICBUUkFDRSgiKGhtbWlvPSVwLCBwY2hCdWY9JXAsIGNjaEJ1Zj0lbGQsIHVGbGFncz0lIzA4eClcbiIsCgkgIGhtbWlvLCBwY2hCdWZmZXIsIGNjaEJ1ZmZlciwgdUZsYWdzKTsKCiAgICBpZiAoKHdtID0gTU1JT19HZXQoaG1taW8pKSA9PSBOVUxMKQoJcmV0dXJuIE1NU1lTRVJSX0lOVkFMSEFORExFOwoKICAgIHJldHVybiBNTUlPX1NldEJ1ZmZlcih3bSwgcGNoQnVmZmVyLCBjY2hCdWZmZXIsIHVGbGFncyk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAJCQkJbW1pb0ZsdXNoICAgICAgCQlbV0lOTU0uQF0KICovCk1NUkVTVUxUIFdJTkFQSSBtbWlvRmx1c2goSE1NSU8gaG1taW8sIFVJTlQgdUZsYWdzKQp7CiAgICBMUFdJTkVfTU1JTwkJd207CgogICAgVFJBQ0UoIiglcCwgJTA0WClcbiIsIGhtbWlvLCB1RmxhZ3MpOwoKICAgIGlmICgod20gPSBNTUlPX0dldChobW1pbykpID09IE5VTEwpCglyZXR1cm4gTU1TWVNFUlJfSU5WQUxIQU5ETEU7CgogICAgcmV0dXJuIE1NSU9fRmx1c2god20sIHVGbGFncyk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAJCQkJbW1pb0FkdmFuY2UgICAgICAJW1dJTk1NLkBdCiAqLwpNTVJFU1VMVCBXSU5BUEkgbW1pb0FkdmFuY2UoSE1NSU8gaG1taW8sIE1NSU9JTkZPKiBscG1taW9pbmZvLCBVSU5UIHVGbGFncykKewogICAgTFBXSU5FX01NSU8JCXdtOwoKICAgIFRSQUNFKCJobW1pbz0lcCwgbHBtbWlvaW5mbz0lcCwgdUZsYWdzPSUwNFhcbiIsIGhtbWlvLCBscG1taW9pbmZvLCB1RmxhZ3MpOwoKICAgIC8qIE5PVEU6IG1taW9BZHZhbmNlMTYgaGVhdmlseSByZWxpZXMgb24gcGFyYW1ldGVycyBmcm9tIGxwbW1pb2luZm8gd2UncmUgdXNpbmcKICAgICAqIGhlcmUuIGJlIHN1cmUgaWYgeW91IGNoYW5nZSBzb21ldGhpbmcgaGVyZSB0byBjaGVjayBtbWlvQWR2YW5jZTE2IGFzIHdlbGwKICAgICAqLwogICAgaWYgKCh3bSA9IE1NSU9fR2V0KGhtbWlvKSkgPT0gTlVMTCkKCXJldHVybiBNTVNZU0VSUl9JTlZBTEhBTkRMRTsKCiAgICBpZiAoIXdtLT5pbmZvLmNjaEJ1ZmZlcikKCXJldHVybiBNTUlPRVJSX1VOQlVGRkVSRUQ7CgogICAgaWYgKHVGbGFncyAhPSBNTUlPX1JFQUQgJiYgdUZsYWdzICE9IE1NSU9fV1JJVEUpCglyZXR1cm4gTU1TWVNFUlJfSU5WQUxQQVJBTTsKCiAgICBpZiAodUZsYWdzID09IE1NSU9fV1JJVEUgJiYgKGxwbW1pb2luZm8tPmR3RmxhZ3MgJiBNTUlPX0RJUlRZKSkKICAgIHsKICAgICAgICBzZW5kX21lc3NhZ2Uod20tPmlvUHJvYywgJndtLT5pbmZvLCBNTUlPTV9TRUVLLCAKICAgICAgICAgICAgICAgICAgICAgbHBtbWlvaW5mby0+bEJ1Zk9mZnNldCwgU0VFS19TRVQsIE1NSU9fUFJPQ18zMkEpOwogICAgICAgIHNlbmRfbWVzc2FnZSh3bS0+aW9Qcm9jLCAmd20tPmluZm8sIE1NSU9NX1dSSVRFLCAKICAgICAgICAgICAgICAgICAgICAgKExQQVJBTSlscG1taW9pbmZvLT5wY2hCdWZmZXIsCiAgICAgICAgICAgICAgICAgICAgIGxwbW1pb2luZm8tPnBjaE5leHQgLSBscG1taW9pbmZvLT5wY2hCdWZmZXIsIE1NSU9fUFJPQ18zMkEpOwogICAgICAgIGxwbW1pb2luZm8tPmR3RmxhZ3MgJj0gfk1NSU9fRElSVFk7CiAgICB9CiAgICBpZiAoTU1JT19GbHVzaCh3bSwgMCkgIT0gTU1TWVNFUlJfTk9FUlJPUikKCXJldHVybiBNTUlPRVJSX0NBTk5PVFdSSVRFOwoKICAgIGlmIChscG1taW9pbmZvKSB7Cgl3bS0+ZHdGaWxlU2l6ZSA9IG1heCh3bS0+ZHdGaWxlU2l6ZSwgbHBtbWlvaW5mby0+bEJ1Zk9mZnNldCArIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgIChscG1taW9pbmZvLT5wY2hOZXh0IC0gbHBtbWlvaW5mby0+cGNoQnVmZmVyKSk7CiAgICB9CiAgICBNTUlPX0dyYWJOZXh0QnVmZmVyKHdtLCB1RmxhZ3MgPT0gTU1JT19SRUFEKTsKCiAgICBpZiAobHBtbWlvaW5mbykgewoJbHBtbWlvaW5mby0+cGNoTmV4dCA9IGxwbW1pb2luZm8tPnBjaEJ1ZmZlcjsKCWxwbW1pb2luZm8tPnBjaEVuZFJlYWQgID0gbHBtbWlvaW5mby0+cGNoQnVmZmVyICsKCSAgICAod20tPmluZm8ucGNoRW5kUmVhZCAtIHdtLT5pbmZvLnBjaEJ1ZmZlcik7CglscG1taW9pbmZvLT5wY2hFbmRXcml0ZSA9IGxwbW1pb2luZm8tPnBjaEJ1ZmZlciArCgkgICAgKHdtLT5pbmZvLnBjaEVuZFdyaXRlIC0gd20tPmluZm8ucGNoQnVmZmVyKTsKCWxwbW1pb2luZm8tPmxEaXNrT2Zmc2V0ID0gd20tPmluZm8ubERpc2tPZmZzZXQ7CglscG1taW9pbmZvLT5sQnVmT2Zmc2V0ID0gd20tPmluZm8ubEJ1Zk9mZnNldDsKICAgIH0KICAgIHJldHVybiBNTVNZU0VSUl9OT0VSUk9SOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogCQkJCW1taW9TdHJpbmdUb0ZPVVJDQ0EJW1dJTk1NLkBdCiAqLwpGT1VSQ0MgV0lOQVBJIG1taW9TdHJpbmdUb0ZPVVJDQ0EoTFBDU1RSIHN6LCBVSU5UIHVGbGFncykKewogICAgQ0hBUiBjY1s0XTsKICAgIGludCBpID0gMDsKCiAgICBmb3IgKGkgPSAwOyBpIDwgNCAmJiBzeltpXTsgaSsrKSB7CglpZiAodUZsYWdzICYgTU1JT19UT1VQUEVSKSB7CgkgICAgY2NbaV0gPSB0b3VwcGVyKHN6W2ldKTsKCX0gZWxzZSB7CgkgICAgY2NbaV0gPSBzeltpXTsKCX0KICAgIH0KCiAgICAvKiBQYWQgd2l0aCBzcGFjZXMgKi8KICAgIHdoaWxlIChpIDwgNCkgY2NbaSsrXSA9ICcgJzsKCiAgICBUUkFDRSgiR290ICclLjRzJ1xuIixjYyk7CiAgICByZXR1cm4gbW1pb0ZPVVJDQyhjY1swXSxjY1sxXSxjY1syXSxjY1szXSk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAJCQkJbW1pb1N0cmluZ1RvRk9VUkNDVwlbV0lOTU0uQF0KICovCkZPVVJDQyBXSU5BUEkgbW1pb1N0cmluZ1RvRk9VUkNDVyhMUENXU1RSIHN6LCBVSU5UIHVGbGFncykKewogICAgY2hhcglzekFbNF07CgogICAgV2lkZUNoYXJUb011bHRpQnl0ZSggQ1BfQUNQLCAwLCBzeiwgNCwgc3pBLCBzaXplb2Yoc3pBKSwgTlVMTCwgTlVMTCApOwogICAgcmV0dXJuIG1taW9TdHJpbmdUb0ZPVVJDQ0Eoc3pBLHVGbGFncyk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAJCQkJbW1pb0luc3RhbGxJT1Byb2NBCSAgIFtXSU5NTS5AXQogKi8KTFBNTUlPUFJPQyBXSU5BUEkgbW1pb0luc3RhbGxJT1Byb2NBKEZPVVJDQyBmY2NJT1Byb2MsCgkJCQkgICAgIExQTU1JT1BST0MgcElPUHJvYywgRFdPUkQgZHdGbGFncykKewogICAgcmV0dXJuIE1NSU9fSW5zdGFsbElPUHJvYyhmY2NJT1Byb2MsIHBJT1Byb2MsIGR3RmxhZ3MsIE1NSU9fUFJPQ18zMkEpOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogCQkJCW1taW9JbnN0YWxsSU9Qcm9jVwkgICBbV0lOTU0uQF0KICovCkxQTU1JT1BST0MgV0lOQVBJIG1taW9JbnN0YWxsSU9Qcm9jVyhGT1VSQ0MgZmNjSU9Qcm9jLAoJCQkJICAgICBMUE1NSU9QUk9DIHBJT1Byb2MsIERXT1JEIGR3RmxhZ3MpCnsKICAgIHJldHVybiBNTUlPX0luc3RhbGxJT1Byb2MoZmNjSU9Qcm9jLCBwSU9Qcm9jLCBkd0ZsYWdzLCBNTUlPX1BST0NfMzJXKTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJTU1JT19TZW5kTWVzc2FnZQogKgogKgogKi8KTFJFU1VMVCAgICAgICAgIE1NSU9fU2VuZE1lc3NhZ2UoSE1NSU8gaG1taW8sIFVJTlQgdU1lc3NhZ2UsIExQQVJBTSBsUGFyYW0xLCAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgTFBBUkFNIGxQYXJhbTIsIGVudW0gbW1pb1Byb2NUeXBlIHR5cGUpCnsKICAgIExQV0lORV9NTUlPCQl3bTsKCiAgICBUUkFDRSgiKCVwLCAldSwgJWxkLCAlbGQsICVkKVxuIiwgaG1taW8sIHVNZXNzYWdlLCBsUGFyYW0xLCBsUGFyYW0yLCB0eXBlKTsKCiAgICBpZiAodU1lc3NhZ2UgPCBNTUlPTV9VU0VSKQoJcmV0dXJuIE1NU1lTRVJSX0lOVkFMUEFSQU07CgogICAgaWYgKCh3bSA9IE1NSU9fR2V0KGhtbWlvKSkgPT0gTlVMTCkKCXJldHVybiBNTVNZU0VSUl9JTlZBTEhBTkRMRTsKCiAgICByZXR1cm4gc2VuZF9tZXNzYWdlKHdtLT5pb1Byb2MsICZ3bS0+aW5mbywgdU1lc3NhZ2UsIGxQYXJhbTEsIGxQYXJhbTIsIHR5cGUpOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogCQkJCW1taW9TZW5kTWVzc2FnZQkJW1dJTk1NLkBdCiAqLwpMUkVTVUxUIFdJTkFQSSBtbWlvU2VuZE1lc3NhZ2UoSE1NSU8gaG1taW8sIFVJTlQgdU1lc3NhZ2UsCgkJCSAgICAgICBMUEFSQU0gbFBhcmFtMSwgTFBBUkFNIGxQYXJhbTIpCnsKICAgIHJldHVybiBNTUlPX1NlbmRNZXNzYWdlKGhtbWlvLCB1TWVzc2FnZSwgbFBhcmFtMSwgbFBhcmFtMiwgTU1JT19QUk9DXzMyQSk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAJCQkJbW1pb0Rlc2NlbmQgICAgICAgICAJW1dJTk1NLkBdCiAqLwpNTVJFU1VMVCBXSU5BUEkgbW1pb0Rlc2NlbmQoSE1NSU8gaG1taW8sIExQTU1DS0lORk8gbHBjaywKICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNvbnN0IE1NQ0tJTkZPKiBscGNrUGFyZW50LCBVSU5UIHVGbGFncykKewogICAgRFdPUkQJCWR3T2xkUG9zOwogICAgRk9VUkNDCQlzcmNoQ2tJZDsKICAgIEZPVVJDQwkJc3JjaFR5cGU7CgogICAgVFJBQ0UoIiglcCwgJXAsICVwLCAlMDRYKTtcbiIsIGhtbWlvLCBscGNrLCBscGNrUGFyZW50LCB1RmxhZ3MpOwoKICAgIGlmIChscGNrID09IE5VTEwpCglyZXR1cm4gTU1TWVNFUlJfSU5WQUxQQVJBTTsKCiAgICBkd09sZFBvcyA9IG1taW9TZWVrKGhtbWlvLCAwLCBTRUVLX0NVUik7CiAgICBUUkFDRSgiZHdPbGRQb3M9JWxkXG4iLCBkd09sZFBvcyk7CgogICAgaWYgKGxwY2tQYXJlbnQgIT0gTlVMTCkgewoJVFJBQ0UoInNlZWsgaW5zaWRlIHBhcmVudCBhdCAlbGQgIVxuIiwgbHBja1BhcmVudC0+ZHdEYXRhT2Zmc2V0KTsKCS8qIEVQUDogd2FzIGR3T2xkUG9zID0gbW1pb1NlZWsoaG1taW8sbHBja1BhcmVudC0+ZHdEYXRhT2Zmc2V0LFNFRUtfU0VUKTsgKi8KCWlmIChkd09sZFBvcyA8IGxwY2tQYXJlbnQtPmR3RGF0YU9mZnNldCB8fAoJICAgIGR3T2xkUG9zID49IGxwY2tQYXJlbnQtPmR3RGF0YU9mZnNldCArIGxwY2tQYXJlbnQtPmNrc2l6ZSkgewoJICAgIFdBUk4oIm91dHNpZGUgcGFyZW50IGNodW5rXG4iKTsKCSAgICByZXR1cm4gTU1JT0VSUl9DSFVOS05PVEZPVU5EOwoJfQogICAgfQoKICAgIC8qIFRoZSBTREsgZG9jdSBzYXlzICdja2lkJyBpcyB1c2VkIGZvciBhbGwgY2FzZXMuIFJlYWwgV29ybGQKICAgICAqIGV4YW1wbGVzIGRpc2FncmVlIC1NYXJjdXMsOTkwMjE2LgogICAgICovCgogICAgc3JjaENrSWQgPSAwOwogICAgc3JjaFR5cGUgPSAwOwoKICAgIC8qIGZpbmRfY2h1bmsgbG9va3MgZm9yICdja2lkJyAqLwogICAgaWYgKHVGbGFncyAmIE1NSU9fRklORENIVU5LKQoJc3JjaENrSWQgPSBscGNrLT5ja2lkOwoKICAgIC8qIGZpbmRfcmlmZiBhbmQgZmluZF9saXN0IGxvb2sgZm9yICdmY2NUeXBlJyAqLwogICAgaWYgKHVGbGFncyAmIE1NSU9fRklORExJU1QpCiAgICB7CglzcmNoQ2tJZCA9IEZPVVJDQ19MSVNUOwogICAgICAgIHNyY2hUeXBlID0gbHBjay0+ZmNjVHlwZTsKICAgIH0KCiAgICBpZiAodUZsYWdzICYgTU1JT19GSU5EUklGRikKICAgIHsKCXNyY2hDa0lkID0gRk9VUkNDX1JJRkY7CiAgICAgICAgc3JjaFR5cGUgPSBscGNrLT5mY2NUeXBlOwogICAgfQoKICAgIFRSQUNFKCJzZWFyY2hpbmcgZm9yICU0LjRzLiU0LjRzXG4iLAogICAgICAgICAgKExQQ1NUUikmc3JjaENrSWQsIHNyY2hUeXBlID8gKExQQ1NUUikmc3JjaFR5cGUgOiAiYW55Iik7CgogICAgd2hpbGUgKFRSVUUpCiAgICB7CiAgICAgICAgTE9ORyBpeDsKCiAgICAgICAgaXggPSBtbWlvUmVhZChobW1pbywgKExQU1RSKWxwY2ssIDMgKiBzaXplb2YoRFdPUkQpKTsKICAgICAgICBpZiAoaXggPCAyKnNpemVvZihEV09SRCkpCiAgICAgICAgewogICAgICAgICAgICBtbWlvU2VlayhobW1pbywgZHdPbGRQb3MsIFNFRUtfU0VUKTsKICAgICAgICAgICAgV0FSTigicmV0dXJuIENodW5rTm90Rm91bmRcbiIpOwogICAgICAgICAgICByZXR1cm4gTU1JT0VSUl9DSFVOS05PVEZPVU5EOwogICAgICAgIH0KCiAgICAgICAgbHBjay0+ZHdEYXRhT2Zmc2V0ID0gZHdPbGRQb3MgKyAyICogc2l6ZW9mKERXT1JEKTsKICAgICAgICBUUkFDRSgiY2tpZD0lNC40cyBmY2M9JTQuNHMgY2tzaXplPSUwOGxYICFcbiIsCiAgICAgICAgICAgICAgKExQQ1NUUikmbHBjay0+Y2tpZCwKICAgICAgICAgICAgICBzcmNoVHlwZSA/IChMUENTVFIpJmxwY2stPmZjY1R5cGU6IjxuYT4iLAogICAgICAgICAgICAgIGxwY2stPmNrc2l6ZSk7CiAgICAgICAgaWYgKCAoIXNyY2hDa0lkIHx8IChzcmNoQ2tJZCA9PSBscGNrLT5ja2lkKSkgJiYKICAgICAgICAgICAgICghc3JjaFR5cGUgfHwgKHNyY2hUeXBlID09IGxwY2stPmZjY1R5cGUpKSApCiAgICAgICAgICAgIGJyZWFrOwoKICAgICAgICBkd09sZFBvcyA9IGxwY2stPmR3RGF0YU9mZnNldCArICgobHBjay0+Y2tzaXplICsgMSkgJiB+MSk7CiAgICAgICAgbW1pb1NlZWsoaG1taW8sIGR3T2xkUG9zLCBTRUVLX1NFVCk7CiAgICB9CgogICAgbHBjay0+ZHdGbGFncyA9IDA7CiAgICAvKiBJZiB3ZSB3ZXJlIGxvb2tpbmcgZm9yIFJJRkYvTElTVCBjaHVua3MsIHRoZSBmaW5hbCBmaWxlIHBvc2l0aW9uCiAgICAgKiBpcyBhZnRlciB0aGUgY2h1bmtpZC4gSWYgd2Ugd2VyZSBqdXN0IGxvb2tpbmcgZm9yIHRoZSBjaHVuawogICAgICogaXQgaXMgYWZ0ZXIgdGhlIGNrc2l6ZS4gU28gYWRkIDQgaW4gUklGRi9MSVNUIGNhc2UuCiAgICAgKi8KICAgIGlmIChscGNrLT5ja2lkID09IEZPVVJDQ19SSUZGIHx8IGxwY2stPmNraWQgPT0gRk9VUkNDX0xJU1QpCgltbWlvU2VlayhobW1pbywgbHBjay0+ZHdEYXRhT2Zmc2V0ICsgc2l6ZW9mKERXT1JEKSwgU0VFS19TRVQpOwogICAgZWxzZQoJbW1pb1NlZWsoaG1taW8sIGxwY2stPmR3RGF0YU9mZnNldCwgU0VFS19TRVQpOwogICAgVFJBQ0UoImxwY2s6IGNraWQ9JS40cywgY2tzaXplPSVsZCwgZHdEYXRhT2Zmc2V0PSVsZCBmY2NUeXBlPSUwOGxYICglLjRzKSFcbiIsCgkgIChMUFNUUikmbHBjay0+Y2tpZCwgbHBjay0+Y2tzaXplLCBscGNrLT5kd0RhdGFPZmZzZXQsCgkgIGxwY2stPmZjY1R5cGUsIHNyY2hUeXBlPyhMUFNUUikmbHBjay0+ZmNjVHlwZToiIik7CiAgICByZXR1cm4gTU1TWVNFUlJfTk9FUlJPUjsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqIAkJCQltbWlvQXNjZW5kICAgICAJCVtXSU5NTS5AXQogKi8KTU1SRVNVTFQgV0lOQVBJIG1taW9Bc2NlbmQoSE1NSU8gaG1taW8sIExQTU1DS0lORk8gbHBjaywgVUlOVCB1RmxhZ3MpCnsKICAgIFRSQUNFKCIoJXAsICVwLCAlMDRYKTtcbiIsIGhtbWlvLCBscGNrLCB1RmxhZ3MpOwoKICAgIGlmIChscGNrLT5kd0ZsYWdzICYgTU1JT19ESVJUWSkgewoJRFdPUkQJZHdPbGRQb3MsIGR3TmV3U2l6ZTsKCglUUkFDRSgiQ2h1bmsgaXMgZGlydHksIGNoZWNraW5nIGlmIGNodW5rJ3Mgc2l6ZSBpcyBjb3JyZWN0XG4iKTsKCWR3T2xkUG9zID0gbW1pb1NlZWsoaG1taW8sIDAsIFNFRUtfQ1VSKTsKCVRSQUNFKCJkd09sZFBvcz0lbGQgbHBjay0+ZHdEYXRhT2Zmc2V0ID0gJWxkXG4iLCBkd09sZFBvcywgbHBjay0+ZHdEYXRhT2Zmc2V0KTsKCWR3TmV3U2l6ZSA9IGR3T2xkUG9zIC0gbHBjay0+ZHdEYXRhT2Zmc2V0OwoJaWYgKGR3TmV3U2l6ZSAhPSBscGNrLT5ja3NpemUpIHsKCSAgICBUUkFDRSgiTm9wZTogbHBjay0+Y2tzaXplPSVsZCBkd05ld1NpemU9JWxkXG4iLCBscGNrLT5ja3NpemUsIGR3TmV3U2l6ZSk7CgkgICAgbHBjay0+Y2tzaXplID0gZHdOZXdTaXplOwoKCSAgICAvKiBwYWQgb2RkIHNpemUgd2l0aCAwICovCgkgICAgaWYgKGR3TmV3U2l6ZSAmIDEpIHsKCQljaGFyIGNoID0gMDsKCQltbWlvV3JpdGUoaG1taW8sICZjaCwgMSk7CgkgICAgfQoJICAgIG1taW9TZWVrKGhtbWlvLCBscGNrLT5kd0RhdGFPZmZzZXQgLSBzaXplb2YoRFdPUkQpLCBTRUVLX1NFVCk7CgkgICAgbW1pb1dyaXRlKGhtbWlvLCAoTFBTVFIpJmR3TmV3U2l6ZSwgc2l6ZW9mKERXT1JEKSk7Cgl9CglscGNrLT5kd0ZsYWdzID0gMDsKICAgIH0KCiAgICBtbWlvU2VlayhobW1pbywgbHBjay0+ZHdEYXRhT2Zmc2V0ICsgKChscGNrLT5ja3NpemUgKyAxKSAmIH4xKSwgU0VFS19TRVQpOwoKICAgIHJldHVybiBNTVNZU0VSUl9OT0VSUk9SOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogCQkJbW1pb0NyZWF0ZUNodW5rCQkJCVtXSU5NTS5AXQogKi8KTU1SRVNVTFQgV0lOQVBJIG1taW9DcmVhdGVDaHVuayhITU1JTyBobW1pbywgTU1DS0lORk8qIGxwY2ssIFVJTlQgdUZsYWdzKQp7CiAgICBEV09SRAlkd09sZFBvczsKICAgIExPTkcgCXNpemU7CiAgICBMT05HIAlpeDsKCiAgICBUUkFDRSgiKCVwLCAlcCwgJTA0WCk7XG4iLCBobW1pbywgbHBjaywgdUZsYWdzKTsKCiAgICBkd09sZFBvcyA9IG1taW9TZWVrKGhtbWlvLCAwLCBTRUVLX0NVUik7CiAgICBUUkFDRSgiZHdPbGRQb3M9JWxkXG4iLCBkd09sZFBvcyk7CgogICAgaWYgKHVGbGFncyA9PSBNTUlPX0NSRUFURUxJU1QpCglscGNrLT5ja2lkID0gRk9VUkNDX0xJU1Q7CiAgICBlbHNlIGlmICh1RmxhZ3MgPT0gTU1JT19DUkVBVEVSSUZGKQoJbHBjay0+Y2tpZCA9IEZPVVJDQ19SSUZGOwoKICAgIFRSQUNFKCJja2lkPSUuNHNcbiIsIChMUFNUUikmbHBjay0+Y2tpZCk7CgogICAgc2l6ZSA9IDIgKiBzaXplb2YoRFdPUkQpOwogICAgbHBjay0+ZHdEYXRhT2Zmc2V0ID0gZHdPbGRQb3MgKyBzaXplOwoKICAgIGlmIChscGNrLT5ja2lkID09IEZPVVJDQ19SSUZGIHx8IGxwY2stPmNraWQgPT0gRk9VUkNDX0xJU1QpCglzaXplICs9IHNpemVvZihEV09SRCk7CiAgICBscGNrLT5kd0ZsYWdzID0gTU1JT19ESVJUWTsKCiAgICBpeCA9IG1taW9Xcml0ZShobW1pbywgKExQU1RSKWxwY2ssIHNpemUpOwogICAgVFJBQ0UoImFmdGVyIG1taW9Xcml0ZSBpeCA9ICVsZCByZXEgPSAlbGQsIGVycm5vID0gJWRcbiIsaXgsIHNpemUsIGVycm5vKTsKICAgIGlmIChpeCA8IHNpemUpIHsKCW1taW9TZWVrKGhtbWlvLCBkd09sZFBvcywgU0VFS19TRVQpOwoJV0FSTigicmV0dXJuIENhbm5vdFdyaXRlXG4iKTsKCXJldHVybiBNTUlPRVJSX0NBTk5PVFdSSVRFOwogICAgfQoKICAgIHJldHVybiBNTVNZU0VSUl9OT0VSUk9SOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogCQkJCW1taW9SZW5hbWVBICAgIAkJCVtXSU5NTS5AXQogKi8KTU1SRVNVTFQgV0lOQVBJIG1taW9SZW5hbWVBKExQQ1NUUiBzekZpbGVOYW1lLCBMUENTVFIgc3pOZXdGaWxlTmFtZSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNvbnN0IE1NSU9JTkZPKiBscG1taW9pbmZvLCBEV09SRCBkd0ZsYWdzKQp7CiAgICBzdHJ1Y3QgSU9Qcm9jTGlzdCogIGlvUHJvYyA9IE5VTEw7CiAgICBzdHJ1Y3QgSU9Qcm9jTGlzdCAgIHRtcDsKICAgIEZPVVJDQyAgICAgICAgICAgICAgZmNjOwoKICAgIFRSQUNFKCIoJyVzJywgJyVzJywgJXAsICUwOGxYKTtcbiIsCgkgIGRlYnVnc3RyX2Eoc3pGaWxlTmFtZSksIGRlYnVnc3RyX2Eoc3pOZXdGaWxlTmFtZSksIGxwbW1pb2luZm8sIGR3RmxhZ3MpOwoKICAgIC8qIElmIGJvdGggcGFyYW1zIGFyZSBOVUxMLCB0aGVuIHBhcnNlIHRoZSBmaWxlIG5hbWUgKi8KICAgIGlmIChscG1taW9pbmZvICYmIGxwbW1pb2luZm8tPmZjY0lPUHJvYyA9PSAwICYmIGxwbW1pb2luZm8tPnBJT1Byb2MgPT0gTlVMTCkKICAgIHsKCWZjYyA9IE1NSU9fUGFyc2VFeHRBKHN6RmlsZU5hbWUpOwogICAgICAgIGlmIChmY2MpIGlvUHJvYyA9IE1NSU9fRmluZFByb2NOb2RlKGZjYyk7CiAgICB9CgogICAgLyogSGFuZGxlIGFueSB1bmhhbmRsZWQvZXJyb3IgY2FzZSBmcm9tIGFib3ZlLiBBc3N1bWUgRE9TIGZpbGUgKi8KICAgIGlmICghbHBtbWlvaW5mbyB8fCAobHBtbWlvaW5mby0+ZmNjSU9Qcm9jID09IDAgJiYgbHBtbWlvaW5mby0+cElPUHJvYyA9PSBOVUxMICYmIGlvUHJvYyA9PSBOVUxMKSkKCWlvUHJvYyA9IE1NSU9fRmluZFByb2NOb2RlKEZPVVJDQ19ET1MpOwogICAgLyogaWYganVzdCB0aGUgZm91ciBjaGFyYWN0ZXIgY29kZSBpcyBwcmVzZW50LCBsb29rIHVwIElPIHByb2MgKi8KICAgIGVsc2UgaWYgKGxwbW1pb2luZm8tPnBJT1Byb2MgPT0gTlVMTCkKICAgICAgICBpb1Byb2MgPSBNTUlPX0ZpbmRQcm9jTm9kZShscG1taW9pbmZvLT5mY2NJT1Byb2MpOwogICAgZWxzZSAvKiB1c2UgcmVsZXZhbnQgaW9Qcm9jICovCiAgICB7CiAgICAgICAgaW9Qcm9jID0gJnRtcDsKICAgICAgICB0bXAuZm91ckNDID0gbHBtbWlvaW5mby0+ZmNjSU9Qcm9jOwogICAgICAgIHRtcC5wSU9Qcm9jID0gbHBtbWlvaW5mby0+cElPUHJvYzsKICAgICAgICB0bXAudHlwZSA9IE1NSU9fUFJPQ18zMkE7CiAgICAgICAgdG1wLmNvdW50ID0gMTsKICAgIH0KCiAgICAvKiBGSVhNRTogc2hvdWxkIHdlIGFjdHVhbGx5IHBhc3MgbHBtbWlvaW5mbyBkb3duIHRoZSBkcmFpbiA/Pz8KICAgICAqIG9yIG1ha2UgYSBjb3B5IG9mIGl0IGJlY2F1c2UgaXQncyBjb25zdCA/Pz8KICAgICAqLwogICAgcmV0dXJuIHNlbmRfbWVzc2FnZShpb1Byb2MsIChNTUlPSU5GTyopbHBtbWlvaW5mbywgTU1JT01fUkVOQU1FLAogICAgICAgICAgICAgICAgICAgICAgICAoTFBBUkFNKXN6RmlsZU5hbWUsIChMUEFSQU0pc3pOZXdGaWxlTmFtZSwgTU1JT19QUk9DXzMyQSk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAJCQkJbW1pb1JlbmFtZVcgICAgCQkJW1dJTk1NLkBdCiAqLwpNTVJFU1VMVCBXSU5BUEkgbW1pb1JlbmFtZVcoTFBDV1NUUiBzekZpbGVOYW1lLCBMUENXU1RSIHN6TmV3RmlsZU5hbWUsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25zdCBNTUlPSU5GTyogbHBtbWlvaW5mbywgRFdPUkQgZHdGbGFncykKewogICAgTFBTVFIJc3pGbiA9IE5VTEw7CiAgICBMUFNUUglzem5GbiA9IE5VTEw7CiAgICBVSU5UCXJldCA9IE1NU1lTRVJSX05PTUVNOwogICAgSU5UICAgICAgICAgbGVuOwoKICAgIGlmIChzekZpbGVOYW1lKQogICAgewogICAgICAgIGxlbiA9IFdpZGVDaGFyVG9NdWx0aUJ5dGUoIENQX0FDUCwgMCwgc3pGaWxlTmFtZSwgLTEsIE5VTEwsIDAsIE5VTEwsIE5VTEwgKTsKICAgICAgICBzekZuID0gSGVhcEFsbG9jKCBHZXRQcm9jZXNzSGVhcCgpLCAwLCBsZW4gKTsKICAgICAgICBpZiAoIXN6Rm4pIGdvdG8gZG9uZTsKICAgICAgICBXaWRlQ2hhclRvTXVsdGlCeXRlKCBDUF9BQ1AsIDAsIHN6RmlsZU5hbWUsIC0xLCBzekZuLCBsZW4sIE5VTEwsIE5VTEwgKTsKICAgIH0KICAgIGlmIChzek5ld0ZpbGVOYW1lKQogICAgewogICAgICAgIGxlbiA9IFdpZGVDaGFyVG9NdWx0aUJ5dGUoIENQX0FDUCwgMCwgc3pOZXdGaWxlTmFtZSwgLTEsIE5VTEwsIDAsIE5VTEwsIE5VTEwgKTsKICAgICAgICBzem5GbiA9IEhlYXBBbGxvYyggR2V0UHJvY2Vzc0hlYXAoKSwgMCwgbGVuICk7CiAgICAgICAgaWYgKCFzem5GbikgZ290byBkb25lOwogICAgICAgIFdpZGVDaGFyVG9NdWx0aUJ5dGUoIENQX0FDUCwgMCwgc3pOZXdGaWxlTmFtZSwgLTEsIHN6bkZuLCBsZW4sIE5VTEwsIE5VTEwgKTsKICAgIH0KCiAgICByZXQgPSBtbWlvUmVuYW1lQShzekZuLCBzem5GbiwgbHBtbWlvaW5mbywgZHdGbGFncyk7Cgpkb25lOgogICAgSGVhcEZyZWUoR2V0UHJvY2Vzc0hlYXAoKSwwLHN6Rm4pOwogICAgSGVhcEZyZWUoR2V0UHJvY2Vzc0hlYXAoKSwwLHN6bkZuKTsKICAgIHJldHVybiByZXQ7Cn0K