LyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogQ29weXJpZ2h0IChjKSAyMDAzLCAyMDA1IElCTSBDb3Jwb3JhdGlvbiBhbmQgb3RoZXJzLgogKiBBbGwgcmlnaHRzIHJlc2VydmVkLiBUaGlzIHByb2dyYW0gYW5kIHRoZSBhY2NvbXBhbnlpbmcgbWF0ZXJpYWxzCiAqIGFyZSBtYWRlIGF2YWlsYWJsZSB1bmRlciB0aGUgdGVybXMgb2YgdGhlIEVjbGlwc2UgUHVibGljIExpY2Vuc2UgdjEuMAogKiB3aGljaCBhY2NvbXBhbmllcyB0aGlzIGRpc3RyaWJ1dGlvbiwgYW5kIGlzIGF2YWlsYWJsZSBhdAogKiBodHRwOi8vd3d3LmVjbGlwc2Uub3JnL2xlZ2FsL2VwbC12MTAuaHRtbAqgKiAKICogQ29udHJpYnV0b3JzOgogKiAgICAgSUJNIENvcnBvcmF0aW9uIC0gSW5pdGlhbCBBUEkgYW5kIGltcGxlbWVudGF0aW9uCiAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwpwYWNrYWdlIG9yZy5lY2xpcHNlLndzdC5zZXJ2ZXIuY29yZS51dGlsOwoKaW1wb3J0IGphdmEudXRpbC4qOwoKaW1wb3J0IG9yZy5lY2xpcHNlLmNvcmUucmVzb3VyY2VzLio7CmltcG9ydCBvcmcuZWNsaXBzZS5jb3JlLnJ1bnRpbWUuQ29yZUV4Y2VwdGlvbjsKaW1wb3J0IG9yZy5lY2xpcHNlLmNvcmUucnVudGltZS5JUGF0aDsKaW1wb3J0IG9yZy5lY2xpcHNlLndzdC5zZXJ2ZXIuY29yZS5JTW9kdWxlOwppbXBvcnQgb3JnLmVjbGlwc2Uud3N0LnNlcnZlci5jb3JlLmludGVybmFsLk1vZHVsZUZhY3Rvcnk7CmltcG9ydCBvcmcuZWNsaXBzZS53c3Quc2VydmVyLmNvcmUuaW50ZXJuYWwuU2VydmVyUGx1Z2luOwppbXBvcnQgb3JnLmVjbGlwc2Uud3N0LnNlcnZlci5jb3JlLmludGVybmFsLlRyYWNlOwppbXBvcnQgb3JnLmVjbGlwc2Uud3N0LnNlcnZlci5jb3JlLm1vZGVsLk1vZHVsZUZhY3RvcnlEZWxlZ2F0ZTsKLyoqCiAqIAogKiAKICogQHBsYW5uZWRmb3IgMS4wCiAqLwpwdWJsaWMgYWJzdHJhY3QgY2xhc3MgUHJvamVjdE1vZHVsZUZhY3RvcnlEZWxlZ2F0ZSBleHRlbmRzIE1vZHVsZUZhY3RvcnlEZWxlZ2F0ZSB7Cglwcm90ZWN0ZWQgc3RhdGljIElSZXNvdXJjZUNoYW5nZUxpc3RlbmVyIGxpc3RlbmVyOwoKCXByaXZhdGUgc3RhdGljIExpc3QgZmFjdG9yaWVzID0gbmV3IEFycmF5TGlzdCgpOwoKCS8vIGxpc3Qgb2YgSU1vZHVsZXMKCXByaXZhdGUgTGlzdCBwcm9qZWN0czsKCgkvKioKCSAqIENvbnN0cnVjdCBhIG5ldyBQcm9qZWN0TW9kdWxlRmFjdG9yeURlbGVnYXRlLgoJICovCglwdWJsaWMgUHJvamVjdE1vZHVsZUZhY3RvcnlEZWxlZ2F0ZSgpIHsKCQlzdXBlcigpOwoJCQoJCWZhY3Rvcmllcy5hZGQodGhpcyk7Cgl9CgoJLyoqCgkgKiBDYWNoZSBhbnkgcHJlZXhpc3RpbmcgbW9kdWxlcy4KCSAqLwoJcHJpdmF0ZSBmaW5hbCB2b2lkIGNhY2hlTW9kdWxlcygpIHsKCQlpZiAocHJvamVjdHMgIT0gbnVsbCkKCQkJcmV0dXJuOwoJCQoJCXRyeSB7CgkJCWNsZWFyQ2FjaGUoKTsKCQkJSVByb2plY3RbXSBwcm9qZWN0czIgPSBnZXRXb3Jrc3BhY2VSb290KCkuZ2V0UHJvamVjdHMoKTsKCQkJaW50IHNpemUgPSBwcm9qZWN0czIubGVuZ3RoOwoJCQlwcm9qZWN0cyA9IG5ldyBBcnJheUxpc3Qoc2l6ZSk7CgkJCWZvciAoaW50IGkgPSAwOyBpIDwgc2l6ZTsgaSsrKSB7CgkJCQkvL1RyYWNlLnRyYWNlKCJjYWNoaW5nOiAiICsgdGhpcyArICIgIiArIHByb2plY3RzW2ldICsgIiAiICsgaXNWYWxpZE1vZHVsZShwcm9qZWN0c1tpXSkpOwoJCQkJaWYgKHByb2plY3RzMltpXS5pc0FjY2Vzc2libGUoKSkgewoJCQkJCXRyeSB7CgkJCQkJCUlNb2R1bGUgbW9kdWxlID0gY3JlYXRlTW9kdWxlKHByb2plY3RzMltpXSk7CgkJCQkJCWlmIChtb2R1bGUgIT0gbnVsbCkKCQkJCQkJCXByb2plY3RzLmFkZChtb2R1bGUpOwoJCQkJCX0gY2F0Y2ggKFRocm93YWJsZSB0KSB7CgkJCQkJCVRyYWNlLnRyYWNlKFRyYWNlLlNFVkVSRSwgIkVycm9yIGNyZWF0aW5nIG1vZHVsZSIsIHQpOwoJCQkJCX0KCQkJCX0KCQkJfQoJCX0gY2F0Y2ggKEV4Y2VwdGlvbiBlKSB7CgkJCVRyYWNlLnRyYWNlKFRyYWNlLlNFVkVSRSwgIkVycm9yIGNhY2hpbmcgbW9kdWxlcyIsIGUpOwoJCX0KCX0KCgkvKioKCSAqIFJldHVybiB0aGUgd29ya3NwYWNlIHJvb3QuCgkgKiAKCSAqIEByZXR1cm4gdGhlIHdvcmtzcGFjZSByb290CgkgKi8KCXByaXZhdGUgc3RhdGljIElXb3Jrc3BhY2VSb290IGdldFdvcmtzcGFjZVJvb3QoKSB7CgkJcmV0dXJuIFJlc291cmNlc1BsdWdpbi5nZXRXb3Jrc3BhY2UoKS5nZXRSb290KCk7Cgl9CgoJcHVibGljIGZpbmFsIElNb2R1bGVbXSBnZXRNb2R1bGVzKCkgewoJCWNhY2hlTW9kdWxlcygpOwoJCQoJCUlNb2R1bGVbXSBtb2R1bGVzID0gbmV3IElNb2R1bGVbcHJvamVjdHMuc2l6ZSgpXTsKCQlwcm9qZWN0cy50b0FycmF5KG1vZHVsZXMpOwoJCXJldHVybiBtb2R1bGVzOwoJfQoKCS8qKgoJICogSGFuZGxlIGNoYW5nZXMgdG8gYSBwcm9qZWN0LgoJICogCgkgKiBAcGFyYW0gcHJvamVjdCBhIHByb2plY3QKCSAqIEBwYXJhbSBkZWx0YSBhIHJlc291cmNlIGRlbHRhCgkgKi8KCXB1YmxpYyBmaW5hbCBzdGF0aWMgdm9pZCBoYW5kbGVHbG9iYWxQcm9qZWN0Q2hhbmdlKGZpbmFsIElQcm9qZWN0IHByb2plY3QsIElSZXNvdXJjZURlbHRhIGRlbHRhKSB7CgkJTW9kdWxlRmFjdG9yeVtdIGZhY3RvcmllczIgPSBTZXJ2ZXJQbHVnaW4uZ2V0TW9kdWxlRmFjdG9yaWVzKCk7CgkJaW50IHNpemUgPSBmYWN0b3JpZXMyLmxlbmd0aDsKCQlmb3IgKGludCBpID0gMDsgaSA8IHNpemU7IGkrKykgewoJCQlpZiAoZmFjdG9yaWVzMltpXS5kZWxlZ2F0ZSAhPSBudWxsICYmIGZhY3RvcmllczJbaV0uZGVsZWdhdGUgaW5zdGFuY2VvZiBQcm9qZWN0TW9kdWxlRmFjdG9yeURlbGVnYXRlKSB7CgkJCQlQcm9qZWN0TW9kdWxlRmFjdG9yeURlbGVnYXRlIHBtZmQgPSAoUHJvamVjdE1vZHVsZUZhY3RvcnlEZWxlZ2F0ZSkgZmFjdG9yaWVzMltpXS5kZWxlZ2F0ZTsKCQkJCWlmIChwbWZkLmRlbHRhQWZmZWN0c01vZHVsZXMoZGVsdGEpKSB7CgkJCQkJcG1mZC5wcm9qZWN0cyA9IG51bGw7CgkJCQkJZmFjdG9yaWVzMltpXS5jbGVhck1vZHVsZUNhY2hlKCk7CgkJCQl9CgkJCX0KCQl9Cgl9CgoJLyoqCgkgKiBSZXR1cm5zIDxjb2RlPnRydWU8L2NvZGU+IGlmIHRoZSBkZWx0YSBtYXkgaGF2ZSBjaGFuZ2VkIG1vZHVsZXMsCgkgKiBhbmQgPGNvZGU+ZmFsc2U8L2NvZGU+IG90aGVyd2lzZS4KCSAqIAoJICogQHBhcmFtIGRlbHRhIGEgcmVzb3VyY2UgZGVsdGEKCSAqIEByZXR1cm4gPGNvZGU+dHJ1ZTwvY29kZT4gaWYgdGhlIGRlbHRhIG1heSBoYXZlIGNoYW5nZWQgbW9kdWxlcywKCSAqICAgIGFuZCA8Y29kZT5mYWxzZTwvY29kZT4gb3RoZXJ3aXNlCgkgKi8KCXByaXZhdGUgZmluYWwgYm9vbGVhbiBkZWx0YUFmZmVjdHNNb2R1bGVzKElSZXNvdXJjZURlbHRhIGRlbHRhKSB7CgkJY2xhc3MgVGVtcCB7CgkJCWJvb2xlYW4gYiA9IGZhbHNlOwoJCX0KCQlmaW5hbCBUZW1wIHQgPSBuZXcgVGVtcCgpOwoJCQoJCWZpbmFsIElQYXRoW10gbGlzdGVuZXJQYXRocyA9IGdldExpc3RlbmVyUGF0aHMoKTsKCQlpZiAobGlzdGVuZXJQYXRocyA9PSBudWxsIHx8IGxpc3RlbmVyUGF0aHMubGVuZ3RoID09IDApCgkJCXJldHVybiBmYWxzZTsKCQlmaW5hbCBpbnQgc2l6ZSA9IGxpc3RlbmVyUGF0aHMubGVuZ3RoOwoJCQoJCXRyeSB7CgkJCWRlbHRhLmFjY2VwdChuZXcgSVJlc291cmNlRGVsdGFWaXNpdG9yKCkgewoJCQkJcHVibGljIGJvb2xlYW4gdmlzaXQoSVJlc291cmNlRGVsdGEgZGVsdGEyKSB0aHJvd3MgQ29yZUV4Y2VwdGlvbiB7CgkJCQkJaWYgKHQuYikKCQkJCQkJcmV0dXJuIGZhbHNlOwoJCQkJCS8vVHJhY2UudHJhY2UoVHJhY2UuRklORVNULCBkZWx0YTIuZ2V0UmVzb3VyY2UoKSArICIgICIgKyBkZWx0YTIuZ2V0S2luZCgpICsgIiAiICsgZGVsdGEyLmdldEZsYWdzKCkpOwoJCQkJCWJvb2xlYW4gb2sgPSBmYWxzZTsKCQkJCQlJUGF0aCBwYXRoID0gZGVsdGEyLmdldFByb2plY3RSZWxhdGl2ZVBhdGgoKTsKCQkJCQlmb3IgKGludCBpID0gMDsgaSA8IHNpemU7IGkrKykgewoJCQkJCQlpZiAobGlzdGVuZXJQYXRoc1tpXS5lcXVhbHMocGF0aCkpIHsKCQkJCQkJCXQuYiA9IHRydWU7CgkJCQkJCQlyZXR1cm4gZmFsc2U7CgkJCQkJCX0gZWxzZSBpZiAocGF0aC5pc1ByZWZpeE9mKGxpc3RlbmVyUGF0aHNbaV0pKSB7CgkJCQkJCQlvayA9IHRydWU7CgkJCQkJCX0KCQkJCQl9CgkJCQkJcmV0dXJuIG9rOwoJCQkJfQoJCQl9KTsKCQl9IGNhdGNoIChFeGNlcHRpb24gZSkgewoJCQkvLyBpZ25vcmUKCQl9CgkJLy9UcmFjZS50cmFjZShUcmFjZS5GSU5FU1QsICJEZWx0YSBjb250YWlucyBjaGFuZ2U6ICIgKyB0LmIpOwoJCXJldHVybiB0LmI7Cgl9CgoJLyoqCgkgKiBDbGVhciBhbmQgY2FjaGVkIG1ldGFkYXRhLgoJICovCglwcm90ZWN0ZWQgdm9pZCBjbGVhckNhY2hlKCkgewoJCS8vIGlnbm9yZQoJfQoKCS8qKgoJICogQ3JlYXRlcyB0aGUgbW9kdWxlIGZvciBhIGdpdmVuIHByb2plY3QuCgkgKiAKCSAqIEBwYXJhbSBwcm9qZWN0IGEgcHJvamVjdCB0byBjcmVhdGUgbW9kdWxlcyBmb3IKCSAqIEByZXR1cm4gYSBtb2R1bGUsIG9yIDxjb2RlPm51bGw8L2NvZGU+IGlmIHRoZXJlIHdhcyBubyBtb2R1bGUgaW4gdGhlIHByb2plY3QKCSAqLwoJcHJvdGVjdGVkIGFic3RyYWN0IElNb2R1bGUgY3JlYXRlTW9kdWxlKElQcm9qZWN0IHByb2plY3QpOwoKCS8qKgoJICogUmV0dXJucyB0aGUgbGlzdCBvZiByZXNvdXJjZXMgdGhhdCB0aGUgbW9kdWxlIHNob3VsZCBsaXN0ZW4gdG8KCSAqIGZvciBzdGF0ZSBjaGFuZ2VzLiBUaGUgcGF0aHMgc2hvdWxkIGJlIHByb2plY3QgcmVsYXRpdmUgcGF0aHMuCgkgKiBTdWJjbGFzc2VzIGNhbiBvdmVycmlkZSB0aGlzIG1ldGhvZCB0byBwcm92aWRlIHRoZSBwYXRocy4KCSAqCgkgKiBAcmV0dXJuIGEgcG9zc2libHkgZW1wdHkgYXJyYXkgb2YgcGF0aHMKCSAqLwoJcHJvdGVjdGVkIElQYXRoW10gZ2V0TGlzdGVuZXJQYXRocygpIHsKCQlyZXR1cm4gbnVsbDsKCX0KfQ==