Advertisement
therealinsight

BSC demopack2

Jul 15th, 2016
106
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 95.25 KB | None | 0 0
  1. local bundle = [[{
  2. [ "cobalt-ui/init.lua" ] = "Y3VpID0geyB9Cm9zLmxvYWRBUEkoICJjb2JhbHQtdWkvc3VyZmFjZSIgKQoKY3VpLnJvb3RzID0geyB9CmN1aS5zdHlsZXMgPSB7IH0KY3VpLmVsZW1lbnRzID0geyB9CmZvciBpLCB2IGluIHBhaXJzKCBmcy5saXN0KCAiY29iYWx0LXVpL2VsZW1lbnRzIiApICkgZG8KCWN1aS5lbGVtZW50c1t2OnN1YigxLCAjdi00KV0gPSBkb2ZpbGUoImNvYmFsdC11aS9lbGVtZW50cy8iIC4uIHYpCmVuZAoKZnVuY3Rpb24gY3VpLmxvYWRTdHlsZXMoIHBhdGggKQoJaWYgZnMuZXhpc3RzKCBwYXRoICkgdGhlbgoJCWxvY2FsIHQgPSBkb2ZpbGUocGF0aCkKCQl0YWJsZS5pbnNlcnQoIGN1aS5zdHlsZXMsIHQgKQoJCXJldHVybiB0CgllbHNlCgkJZXJyb3IoImZpbGUgIiAuLiBwYXRoIC4uICIgZG9lcyBub3QgZXhpc3QiKQoJZW5kCmVuZAoKZnVuY3Rpb24gY3VpLnVwZGF0ZSggZHQgKQoJZm9yIGksIHYgaW4gaXBhaXJzKCBjdWkucm9vdHMgKSBkbwoJCWlmIHYudXBkYXRlIHRoZW4KCQkJdjp1cGRhdGUoIGR0ICkKCQllbmQKCWVuZAplbmQKCmZ1bmN0aW9uIGN1aS5kcmF3KCkKCWZvciBpID0gI2N1aS5yb290cywgMSwgLTEgZG8KCQlpZiBjdWkucm9vdHNbaV0uZHJhdyB0aGVuIGN1aS5yb290c1tpXTpkcmF3KCkgZW5kCgllbmQKZW5kCgpmdW5jdGlvbiBjdWkubmV3KCBkYXRhICkKCXJldHVybiBjdWkuZWxlbWVudHNbInBhbmVsIl0ubmV3KCBkYXRhLCBuaWwsIHRydWUgKQplbmQKCmZ1bmN0aW9uIGN1aS5tb3VzZXByZXNzZWQoIHgsIHksIGJ1dHRvbiApCglmb3IgaSA9ICNjdWkucm9vdHMsIDEsIC0xIGRvCgkJaWYgY3VpLnJvb3RzW2ldLm1vdXNlcHJlc3NlZCB0aGVuCgkJCWlmIGN1aS5yb290c1tpXTptb3VzZXByZXNzZWQoIHgsIHksIGJ1dHRvbiApIHRoZW4gcmV0dXJuIGVuZAoJCWVuZAoJZW5kCmVuZAoKZnVuY3Rpb24gY3VpLm1vdXNlcmVsZWFzZWQoIHgsIHksIGJ1dHRvbiApCglmb3IgaSA9ICNjdWkucm9vdHMsIDEsIC0xIGRvCgkJaWYgY3VpLnJvb3RzW2ldLm1vdXNlcmVsZWFzZWQgdGhlbgoJCQlpZiBjdWkucm9vdHNbaV06bW91c2VyZWxlYXNlZCggeCwgeSwgYnV0dG9uICkgdGhlbiByZXR1cm4gZW5kCgkJZW5kCgllbmQKZW5kCgoKZnVuY3Rpb24gY3VpLmtleXByZXNzZWQoIGtleWNvZGUsIGtleSApCglmb3IgaSwgdiBpbiBpcGFpcnMoIGN1aS5yb290cyApIGRvCgkJaWYgdi5rZXlwcmVzc2VkIHRoZW4KCQkJdjprZXlwcmVzc2VkKCBrZXljb2RlLCBrZXkgKQoJCWVuZAoJZW5kCmVuZAoKZnVuY3Rpb24gY3VpLmtleXJlbGVhc2VkKCBrZXljb2RlLCBrZXkgKQoJZm9yIGksIHYgaW4gaXBhaXJzKCBjdWkucm9vdHMgKSBkbwoJCWlmIHYua2V5cmVsZWFzZWQgdGhlbgoJCQl2OmtleXJlbGVhc2VkKCBrZXljb2RlLCBrZXkgKQoJCWVuZAoJZW5kCmVuZAoKZnVuY3Rpb24gY3VpLnRleHRpbnB1dCggdCApCglmb3IgaSwgdiBpbiBpcGFpcnMoIGN1aS5yb290cyApIGRvCgkJaWYgdi50ZXh0aW5wdXQgdGhlbgoJCQlpZiB2OnRleHRpbnB1dCggdCApIHRoZW4gcmV0dXJuIGVuZAoJCWVuZAoJZW5kCmVuZAoKZnVuY3Rpb24gY3VpLm1vdXNlZHJhZyggeCwgeSApCglmb3IgaSwgdiBpbiBpcGFpcnMoIGN1aS5yb290cyApIGRvCgkJaWYgdi5tb3VzZWRyYWcgdGhlbgoJCQl2Om1vdXNlZHJhZyggeCwgeSApCgkJZW5kCgllbmQKZW5kCgoKCnJldHVybiBjdWk=",
  3. [ "cobalt-ui/elements/radio.lua" ] = "bG9jYWwgcmFkaW8gPSB7CgoJeCA9IDEsCgl5ID0gMSwKCWJhY2tDb2xvdXIgPSBjb2xvdXJzLmxpZ2h0R3JleSwKCWZvcmVDb2xvdXIgPSBjb2xvdXJzLmJsYWNrLAoJY2hhciA9ICJvIiwKCXNlbGVjdGVkID0gZmFsc2UsCglncm91cCA9ICJfTUFJTiIsCgl2aXNpYmxlID0gdHJ1ZSwKCXR5cGUgPSAicmFkaW8iLAoJbGFiZWwgPSAiQSBSYWRpbyIsCglhdXRveCA9ICIiLAoJYXV0b3kgPSAiIiwKCWF1dG9tbCA9ICIiLAoJYXV0b210ID0gIiIsCgl3cmFwID0gImxlZnQiLAoJbWFyZ2lubGVmdCA9IDAsCgltYXJnaW50b3AgPSAwLAoKfQpyYWRpby5fX2luZGV4ID0gcmFkaW8KCmZ1bmN0aW9uIHJhZGlvOmdldFBlcmNlbnRhZ2VzKCkKCWlmIHR5cGUoc2VsZi5tYXJnaW5sZWZ0KSA9PSAic3RyaW5nIiB0aGVuCgkJc2VsZi5tYXJnaW5sZWZ0ID0gY29iYWx0LmdldFBlcmNlbnRhZ2UoIHNlbGYubWFyZ2lubGVmdCApCgkJc2VsZi5hdXRvbWwgPSAicGVyYzoiIC4uIHNlbGYubWFyZ2lubGVmdAoJZW5kCglpZiB0eXBlKHNlbGYubWFyZ2ludG9wKSA9PSAic3RyaW5nIiB0aGVuCgkJc2VsZi5tYXJnaW50b3AgPSBjb2JhbHQuZ2V0UGVyY2VudGFnZSggc2VsZi5tYXJnaW50b3AgKQoJCXNlbGYuYXV0b210ID0gInBlcmM6IiAuLiBzZWxmLm1hcmdpbnRvcAoJZW5kCglpZiB0eXBlKHNlbGYueCkgPT0gInN0cmluZyIgdGhlbgoJCXNlbGYueCA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLnggKQoJCXNlbGYuYXV0b3ggPSAicGVyYzoiIC4uIHNlbGYueAoJZW5kCglpZiB0eXBlKHNlbGYueSkgPT0gInN0cmluZyIgdGhlbgoJCXNlbGYueSA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLnkgKQoJCXNlbGYuYXV0b3kgPSAicGVyYzoiIC4uIHNlbGYueQoJZW5kCmVuZAoKZnVuY3Rpb24gcmFkaW8ubmV3KCBkYXRhLCBwYXJlbnQgKQoJZGF0YSA9IGRhdGEgb3IgeyB9CglpZiBkYXRhLnN0eWxlIHRoZW4KCQlsb2NhbCB0ID0gZGF0YS5zdHlsZQoJCWZvciBrLCB2IGluIHBhaXJzKCB0ICkgZG8KCQkJaWYgbm90IGRhdGFba10gdGhlbgoJCQkJZGF0YVtrXSA9IHYKCQkJZW5kCgkJZW5kCgkJZGF0YS5zdHlsZSA9IG5pbAoJZW5kCglsb2NhbCBzZWxmID0gc2V0bWV0YXRhYmxlKGRhdGEscmFkaW8pCglpZiBub3Qgc2VsZi52YWwgdGhlbiBzZWxmLnZhbCA9IHNlbGYubGFiZWwgZW5kCglzZWxmLnBhcmVudCA9IHBhcmVudAoJc2VsZjpnZXRQZXJjZW50YWdlcygpCglzZWxmOnJlc2l6ZSgpCglzZWxmLnN0YXRlID0gZGF0YS5zdGF0ZSBvciBwYXJlbnQuc3RhdGUKCXRhYmxlLmluc2VydCggcGFyZW50LmNoaWxkcmVuLCBzZWxmICkKCXJldHVybiBzZWxmCmVuZAoKZnVuY3Rpb24gcmFkaW86Z2V0QWJzWCgpCglyZXR1cm4gc2VsZi54ICsgc2VsZi5wYXJlbnQ6Z2V0QWJzWCgpLTEgKyBzZWxmLm1hcmdpbmxlZnQKZW5kCgpmdW5jdGlvbiByYWRpbzpnZXRBYnNZKCkKCXJldHVybiBzZWxmLnkgKyBzZWxmLnBhcmVudDpnZXRBYnNZKCktMSArIHNlbGYubWFyZ2ludG9wCmVuZAoKZnVuY3Rpb24gcmFkaW86ZHJhdygpCglzZWxmLncgPSAjc2VsZi5sYWJlbCArIDIKCWlmIHNlbGYud3JhcCA9PSAiY2VudGVyIiB0aGVuCgkJc2VsZi54ID0gbWF0aC5jZWlsKCBzZWxmLnBhcmVudC53LzIgLSBzZWxmLncvMiApICsgc2VsZi5tYXJnaW5sZWZ0CgllbmQKCWlmIHNlbGYuc3RhdGUgPT0gY29iYWx0LnN0YXRlIG9yIHNlbGYuc3RhdGUgPT0gIl9BTEwiIGFuZCBzZWxmLnZpc2libGUgdGhlbgoJCWxvY2FsIGNoYXIgPSAiICIKCQlpZiBzZWxmLnNlbGVjdGVkIHRoZW4KCQkJY2hhciA9IHNlbGYuY2hhcgoJCWVuZAoJCXNlbGYucGFyZW50LnN1cmY6ZHJhd1BpeGVsKCBtYXRoLmNlaWwoc2VsZi54ICsgc2VsZi5tYXJnaW5sZWZ0KSwgbWF0aC5jZWlsKHNlbGYueSArIHNlbGYubWFyZ2ludG9wKSwgY2hhciwgc2VsZi5iYWNrQ29sb3VyLCBzZWxmLmZvcmVDb2xvdXIgKQoJCXNlbGYucGFyZW50LnN1cmY6ZHJhd1RleHQoIG1hdGguY2VpbChzZWxmLngrMiArIHNlbGYubWFyZ2lubGVmdCksIG1hdGguY2VpbChzZWxmLnkgKyBzZWxmLm1hcmdpbnRvcCksIHNlbGYubGFiZWwsIG5pbCwgc2VsZi5mb3JlQ29sb3VyICkKCWVuZAplbmQKCmZ1bmN0aW9uIHJhZGlvOnNldE1hcmdpbnMoIHQsIHIsIGIsIGwgKQoJaWYgdCB0aGVuCgkJc2VsZi5tYXJnaW50b3AgPSB0IG9yIHNlbGYubWFyZ2ludG9wCgkJaWYgdHlwZSh0KSA9PSAic3RyaW5nIiB0aGVuCgkJCXNlbGY6Z2V0UGVyY2VudGFnZXMoKQoJCWVsc2UKCQkJc2VsZi5hdXRvbXQgPSAibm9uZSIKCQllbmQKCWVuZAoJaWYgciB0aGVuCgkJc2VsZi5tYXJnaW5yaWdodCA9IHIgb3Igc2VsZi5tYXJnaW5yaWdodAoJCWlmIHR5cGUocikgPT0gInN0cmluZyIgdGhlbgoJCQlzZWxmOmdldFBlcmNlbnRhZ2VzKCkKCQllbHNlCgkJCXNlbGYuYXV0b21yID0gIm5vbmUiCgkJZW5kCgllbmQKCWlmIGIgdGhlbgoJCXNlbGYubWFyZ2ludG9wID0gYiBvciBzZWxmLm1hcmdpbnRvcAoJCWlmIHR5cGUoYikgPT0gInN0cmluZyIgdGhlbgoJCQlzZWxmOmdldFBlcmNlbnRhZ2VzKCkKCQllbHNlCgkJCXNlbGYuYXV0b21iID0gIm5vbmUiCgkJZW5kCgllbmQKCWlmIGwgdGhlbgoJCXNlbGYubWFyZ2lubGVmdCA9IGwgb3Igc2VsZi5tYXJnaW5sZWZ0CgkJaWYgdHlwZShsKSA9PSAic3RyaW5nIiB0aGVuCgkJCXNlbGY6Z2V0UGVyY2VudGFnZXMoKQoJCWVsc2UKCQkJc2VsZi5hdXRvbWwgPSAibm9uZSIKCQllbmQKCWVuZAoJc2VsZjpyZXNpemUoKQplbmQKCmZ1bmN0aW9uIHJhZGlvOnJlc2l6ZSgpCglpZiBzZWxmLmF1dG9tbDpzdWIoIDEsIDQgKSA9PSAicGVyYyIgdGhlbgoJCWxvY2FsIHBlcmMgPSBzZWxmLmF1dG9tbDptYXRjaCgicGVyYzooJWQrKSIpCgkJc2VsZi5tYXJnaW5sZWZ0ID0gbWF0aC5mbG9vciggc2VsZi5wYXJlbnQudyAqIGNvYmFsdC5zZXRQZXJjZW50YWdlKCBwZXJjICkgKQoJZW5kCglpZiBzZWxmLmF1dG9tdDpzdWIoIDEsIDQgKSA9PSAicGVyYyIgdGhlbgoJCWxvY2FsIHBlcmMgPSBzZWxmLmF1dG9tdDptYXRjaCgicGVyYzooJWQrKSIpCgkJc2VsZi5tYXJnaW50b3AgPSBtYXRoLmZsb29yKCBzZWxmLnBhcmVudC5oICogY29iYWx0LnNldFBlcmNlbnRhZ2UoIHBlcmMgKSApCgllbmQKCWlmIHNlbGYuYXV0b3ggYW5kIHNlbGYuYXV0b3g6c3ViKCAxLCA0ICkgPT0gInBlcmMiIHRoZW4KCQlsb2NhbCBwZXJjID0gc2VsZi5hdXRveDptYXRjaCgicGVyYzooJWQrKSIpCgkJc2VsZi54ID0gbWF0aC5mbG9vciggc2VsZi5wYXJlbnQudyAqIGNvYmFsdC5zZXRQZXJjZW50YWdlKCBwZXJjICkgKQoJZW5kCglpZiBzZWxmLmF1dG95IGFuZCBzZWxmLmF1dG95OnN1YiggMSwgNCApID09ICJwZXJjIiB0aGVuCgkJbG9jYWwgcGVyYyA9IHNlbGYuYXV0b3k6bWF0Y2goInBlcmM6KCVkKykiKQoJCXNlbGYueSA9IG1hdGguZmxvb3IoIHNlbGYucGFyZW50LmggKiBjb2JhbHQuc2V0UGVyY2VudGFnZSggcGVyYyApICkKCWVuZAplbmQKCmZ1bmN0aW9uIHJhZGlvOm1vdXNlcHJlc3NlZCggeCwgeSwgYnV0dG9uICkKCWlmIHNlbGYuc3RhdGUgPT0gY29iYWx0LnN0YXRlIG9yIHNlbGYuc3RhdGUgPT0gIl9BTEwiIGFuZCBzZWxmLnZpc2libGUgdGhlbgoJCWlmIGJ1dHRvbiA9PSAxIGFuZCB4ID09IHNlbGY6Z2V0QWJzWCgpIGFuZCB5ID09IHNlbGY6Z2V0QWJzWSgpIHRoZW4KCgkJZW5kCgllbHNlCgkJc2VsZi5zZWxlY3RlZCA9IGZhbHNlCgllbmQKZW5kCgpmdW5jdGlvbiByYWRpbzptb3VzZXJlbGVhc2VkKCB4LCB5LCBidXR0b24gKQoJaWYgc2VsZi5zdGF0ZSA9PSBjb2JhbHQuc3RhdGUgb3Igc2VsZi5zdGF0ZSA9PSAiX0FMTCIgYW5kIHNlbGYudmlzaWJsZSB0aGVuCgkJaWYgYnV0dG9uID09IDEgYW5kIHggPT0gc2VsZjpnZXRBYnNYKCkgYW5kIHkgPT0gc2VsZjpnZXRBYnNZKCkgdGhlbgoJCQlzZWxmLnNlbGVjdGVkID0gdHJ1ZQoJCQlmb3IgaywgdiBpbiBwYWlycyggc2VsZi5wYXJlbnQuY2hpbGRyZW4gKSBkbwoJCQkJaWYgdi50eXBlIGFuZCB2LnR5cGUgPT0gInJhZGlvIiBhbmQgdiB+PSBzZWxmIHRoZW4KCQkJCQlpZiB2Lmdyb3VwID09IHNlbGYuZ3JvdXAgdGhlbgoJCQkJCQl2LnNlbGVjdGVkID0gZmFsc2UKCQkJCQllbmQKCQkJCWVuZAoJCQllbmQKCQllbmQKCWVsc2UKCQlzZWxmLnNlbGVjdGVkID0gZmFsc2UKCWVuZAplbmQKCnJldHVybiByYWRpbw==",
  4. [ "cobalt-ui/elements/checkbox.lua" ] = "bG9jYWwgY2hlY2tib3ggPSB7CgoJeCA9IDEsCgl5ID0gMSwKCWJhY2tDb2xvdXIgPSBjb2xvdXJzLmxpZ2h0R3JleSwKCWZvcmVDb2xvdXIgPSBjb2xvdXJzLmJsYWNrLAoJY2hhciA9ICJ4IiwKCXNlbGVjdGVkID0gZmFsc2UsCglncm91cCA9ICJfTUFJTiIsCgl2aXNpYmxlID0gdHJ1ZSwKCWxhYmVsID0gIkEgQ2hlY2tib3giLAoJdHlwZSA9ICJjaGVja2JveCIsCglhdXRvbWwgPSAiIiwKCWF1dG9tdCA9ICIiLAoJYXV0b3ggPSAiIiwKCWF1dG95ID0gIiIsCgl3cmFwID0gImxlZnQiLAoJbWFyZ2lubGVmdCA9IDAsCgltYXJnaW50b3AgPSAwLAoKfQpjaGVja2JveC5fX2luZGV4ID0gY2hlY2tib3gKCmZ1bmN0aW9uIGNoZWNrYm94OmdldFBlcmNlbnRhZ2VzKCkKCWlmIHR5cGUoc2VsZi5tYXJnaW5sZWZ0KSA9PSAic3RyaW5nIiB0aGVuCgkJc2VsZi5tYXJnaW5sZWZ0ID0gY29iYWx0LmdldFBlcmNlbnRhZ2UoIHNlbGYubWFyZ2lubGVmdCApCgkJc2VsZi5hdXRvbWwgPSAicGVyYzoiIC4uIHNlbGYubWFyZ2lubGVmdAoJZW5kCglpZiB0eXBlKHNlbGYubWFyZ2ludG9wKSA9PSAic3RyaW5nIiB0aGVuCgkJc2VsZi5tYXJnaW50b3AgPSBjb2JhbHQuZ2V0UGVyY2VudGFnZSggc2VsZi5tYXJnaW50b3AgKQoJCXNlbGYuYXV0b210ID0gInBlcmM6IiAuLiBzZWxmLm1hcmdpbnRvcAoJZW5kCglpZiB0eXBlKHNlbGYueCkgPT0gInN0cmluZyIgdGhlbgoJCXNlbGYueCA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLnggKQoJCXNlbGYuYXV0b3ggPSAicGVyYzoiIC4uIHNlbGYueAoJZW5kCglpZiB0eXBlKHNlbGYueSkgPT0gInN0cmluZyIgdGhlbgoJCXNlbGYueSA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLnkgKQoJCXNlbGYuYXV0b3kgPSAicGVyYzoiIC4uIHNlbGYueQoJZW5kCmVuZAoKZnVuY3Rpb24gY2hlY2tib3gubmV3KCBkYXRhLCBwYXJlbnQgKQoJZGF0YSA9IGRhdGEgb3IgeyB9CglpZiBkYXRhLnN0eWxlIHRoZW4KCQlsb2NhbCB0ID0gZGF0YS5zdHlsZQoJCWZvciBrLCB2IGluIHBhaXJzKCB0ICkgZG8KCQkJaWYgbm90IGRhdGFba10gdGhlbgoJCQkJZGF0YVtrXSA9IHYKCQkJZW5kCgkJZW5kCgkJZGF0YS5zdHlsZSA9IG5pbAoJZW5kCglsb2NhbCBzZWxmID0gc2V0bWV0YXRhYmxlKGRhdGEsY2hlY2tib3gpCglpZiBub3Qgc2VsZi52YWwgdGhlbiBzZWxmLnZhbCA9IHNlbGYubGFiZWwgZW5kCglzZWxmLncgPSAjc2VsZi5sYWJlbCArIDIKCXNlbGYucGFyZW50ID0gcGFyZW50CglzZWxmOmdldFBlcmNlbnRhZ2VzKCkKCXNlbGY6cmVzaXplKCkKCXNlbGYuc3RhdGUgPSBkYXRhLnN0YXRlIG9yIHBhcmVudC5zdGF0ZQoJdGFibGUuaW5zZXJ0KCBwYXJlbnQuY2hpbGRyZW4sIHNlbGYgKQoJcmV0dXJuIHNlbGYKZW5kCgpmdW5jdGlvbiBjaGVja2JveDpzZXRNYXJnaW5zKCB0LCByLCBiLCBsICkKCWlmIHQgdGhlbgoJCXNlbGYubWFyZ2ludG9wID0gdCBvciBzZWxmLm1hcmdpbnRvcAoJCWlmIHR5cGUodCkgPT0gInN0cmluZyIgdGhlbgoJCQlzZWxmOmdldFBlcmNlbnRhZ2VzKCkKCQllbHNlCgkJCXNlbGYuYXV0b210ID0gIm5vbmUiCgkJZW5kCgllbmQKCWlmIHIgdGhlbgoJCXNlbGYubWFyZ2lucmlnaHQgPSByIG9yIHNlbGYubWFyZ2lucmlnaHQKCQlpZiB0eXBlKHIpID09ICJzdHJpbmciIHRoZW4KCQkJc2VsZjpnZXRQZXJjZW50YWdlcygpCgkJZWxzZQoJCQlzZWxmLmF1dG9tciA9ICJub25lIgoJCWVuZAoJZW5kCglpZiBiIHRoZW4KCQlzZWxmLm1hcmdpbnRvcCA9IGIgb3Igc2VsZi5tYXJnaW50b3AKCQlpZiB0eXBlKGIpID09ICJzdHJpbmciIHRoZW4KCQkJc2VsZjpnZXRQZXJjZW50YWdlcygpCgkJZWxzZQoJCQlzZWxmLmF1dG9tYiA9ICJub25lIgoJCWVuZAoJZW5kCglpZiBsIHRoZW4KCQlzZWxmLm1hcmdpbmxlZnQgPSBsIG9yIHNlbGYubWFyZ2lubGVmdAoJCWlmIHR5cGUobCkgPT0gInN0cmluZyIgdGhlbgoJCQlzZWxmOmdldFBlcmNlbnRhZ2VzKCkKCQllbHNlCgkJCXNlbGYuYXV0b21sID0gIm5vbmUiCgkJZW5kCgllbmQKCXNlbGY6cmVzaXplKCkKZW5kCgpmdW5jdGlvbiBjaGVja2JveDpyZXNpemUoKQoJaWYgc2VsZi5hdXRvbWw6c3ViKCAxLCA0ICkgPT0gInBlcmMiIHRoZW4KCQlsb2NhbCBwZXJjID0gc2VsZi5hdXRvbWw6bWF0Y2goInBlcmM6KCVkKykiKQoJCXNlbGYubWFyZ2lubGVmdCA9IG1hdGguZmxvb3IoIHNlbGYucGFyZW50LncgKiBjb2JhbHQuc2V0UGVyY2VudGFnZSggcGVyYyApICkKCWVuZAoJaWYgc2VsZi5hdXRvbXQ6c3ViKCAxLCA0ICkgPT0gInBlcmMiIHRoZW4KCQlsb2NhbCBwZXJjID0gc2VsZi5hdXRvbXQ6bWF0Y2goInBlcmM6KCVkKykiKQoJCXNlbGYubWFyZ2ludG9wID0gbWF0aC5mbG9vciggc2VsZi5wYXJlbnQuaCAqIGNvYmFsdC5zZXRQZXJjZW50YWdlKCBwZXJjICkgKQoJZW5kCglpZiBzZWxmLmF1dG94IGFuZCBzZWxmLmF1dG94OnN1YiggMSwgNCApID09ICJwZXJjIiB0aGVuCgkJbG9jYWwgcGVyYyA9IHNlbGYuYXV0b3g6bWF0Y2goInBlcmM6KCVkKykiKQoJCXNlbGYueCA9IG1hdGguZmxvb3IoIHNlbGYucGFyZW50LncgKiBjb2JhbHQuc2V0UGVyY2VudGFnZSggcGVyYyApICkKCWVuZAoJaWYgc2VsZi5hdXRveSBhbmQgc2VsZi5hdXRveTpzdWIoIDEsIDQgKSA9PSAicGVyYyIgdGhlbgoJCWxvY2FsIHBlcmMgPSBzZWxmLmF1dG95Om1hdGNoKCJwZXJjOiglZCspIikKCQlzZWxmLnkgPSBtYXRoLmZsb29yKCBzZWxmLnBhcmVudC5oICogY29iYWx0LnNldFBlcmNlbnRhZ2UoIHBlcmMgKSApCgllbmQKZW5kCgpmdW5jdGlvbiBjaGVja2JveDpnZXRBYnNYKCkKCXJldHVybiBzZWxmLnggKyBzZWxmLnBhcmVudDpnZXRBYnNYKCkgLSAxICsgc2VsZi5tYXJnaW5sZWZ0CmVuZAoKZnVuY3Rpb24gY2hlY2tib3g6Z2V0QWJzWSgpCglyZXR1cm4gc2VsZi55ICsgc2VsZi5wYXJlbnQ6Z2V0QWJzWSgpIC0gMSArIHNlbGYubWFyZ2ludG9wCmVuZAoKZnVuY3Rpb24gY2hlY2tib3g6ZHJhdygpCglzZWxmLncgPSAjc2VsZi5sYWJlbCArIDIKCWlmIHNlbGYud3JhcCA9PSAiY2VudGVyIiB0aGVuCgkJc2VsZi54ID0gbWF0aC5jZWlsKCBzZWxmLnBhcmVudC53LzIgLSBzZWxmLncvMiApICsgc2VsZi5tYXJnaW5sZWZ0CgllbmQKCWlmIHNlbGYuc3RhdGUgPT0gY29iYWx0LnN0YXRlIG9yIHNlbGYuc3RhdGUgPT0gIl9BTEwiIGFuZCBzZWxmLnZpc2libGUgdGhlbgoJCWxvY2FsIGNoYXIgPSAiICIKCQlpZiBzZWxmLnNlbGVjdGVkIHRoZW4KCQkJY2hhciA9IHNlbGYuY2hhcgoJCWVuZAoJCXNlbGYucGFyZW50LnN1cmY6ZHJhd1BpeGVsKCBtYXRoLmNlaWwoc2VsZi54ICsgc2VsZi5tYXJnaW5sZWZ0KSwgbWF0aC5jZWlsKHNlbGYueSArIHNlbGYubWFyZ2ludG9wKSwgY2hhciwgc2VsZi5iYWNrQ29sb3VyLCBzZWxmLmZvcmVDb2xvdXIgKQoJCXNlbGYucGFyZW50LnN1cmY6ZHJhd1RleHQoIG1hdGguY2VpbChzZWxmLngrMiArIHNlbGYubWFyZ2lubGVmdCksIG1hdGguY2VpbChzZWxmLnkrIHNlbGYubWFyZ2ludG9wKSwgc2VsZi5sYWJlbCwgbmlsLCBzZWxmLmZvcmVDb2xvdXIgKQoJZW5kCmVuZAoKZnVuY3Rpb24gY2hlY2tib3g6bW91c2VwcmVzc2VkKCB4LCB5LCBidXR0b24gKQoJaWYgc2VsZi5zdGF0ZSA9PSBjb2JhbHQuc3RhdGUgb3Igc2VsZi5zdGF0ZSA9PSAiX0FMTCIgYW5kIHNlbGYudmlzaWJsZSB0aGVuCgkJaWYgYnV0dG9uID09IDEgYW5kIHggPj0gc2VsZjpnZXRBYnNYKCkgYW5kIHggPD0gc2VsZjpnZXRBYnNYKCkgKyBzZWxmLncgYW5kIHkgPT0gc2VsZjpnZXRBYnNZKCkgdGhlbgoKCQllbmQKCWVsc2UKCQlzZWxmLnNlbGVjdGVkID0gZmFsc2UKCWVuZAplbmQKCmZ1bmN0aW9uIGNoZWNrYm94Om1vdXNlcmVsZWFzZWQoIHgsIHksIGJ1dHRvbiApCglpZiBzZWxmLnN0YXRlID09IGNvYmFsdC5zdGF0ZSBvciBzZWxmLnN0YXRlID09ICJfQUxMIiBhbmQgc2VsZi52aXNpYmxlIHRoZW4KCQlpZiBidXR0b24gPT0gMSBhbmQgeCA9PSBzZWxmOmdldEFic1goKSBhbmQgeSA9PSBzZWxmOmdldEFic1koKSB0aGVuCgkJCXNlbGYuc2VsZWN0ZWQgPSBub3Qgc2VsZi5zZWxlY3RlZAoJCWVuZAoJZWxzZQoJCXNlbGYuc2VsZWN0ZWQgPSBmYWxzZQoJZW5kCmVuZAoKcmV0dXJuIGNoZWNrYm94",
  5. [ "cobalt-ui/elements/text.lua" ] = "bG9jYWwgdGV4dCA9IHsKCXggPSAwLAoJeSA9IDEsCgl0ZXh0ID0gIlNvbWUgVGV4dCIsCgl1bmZvcm1hdHRlZCA9ICJTb21lIFRleHQiLAoJZm9yZUNvbG91ciA9IGNvbG91cnMuYmxhY2ssCgl0eXBlID0gInRleHQiLAoJYXV0b2ZpdCA9IHRydWUsCgltYXJnaW5sZWZ0ID0gMCwKCW1hcmdpbnJpZ2h0ID0gMCwKCW1hcmdpbnRvcCA9IDAsCgltYXJnaW5ib3R0b20gPSAwLAoJYXV0b21sID0gIiIsCglhdXRvbXIgPSAiIiwKCWF1dG9tdCA9ICIiLAoJYXV0b21iID0gIiIsCgl3cmFwID0gImxlZnQiLAoJYXV0b3cgPSAicGFyZW50IiwKCWF1dG9oID0gdHJ1ZSwKfQp0ZXh0Ll9faW5kZXggPSB0ZXh0Cgpsb2NhbCBmdW5jdGlvbiBzcGxpdEJ5U3BhY2UoIHRleHQgKQoJbG9jYWwgdCA9IHsgfQoJZm9yIGkgaW4gc3RyaW5nLmdtYXRjaCggdGV4dCwgIiVTKyIgKSBkbwoJCXRbI3QrMV0gPSBpCgllbmQKCXJldHVybiB0CmVuZAoKbG9jYWwgZnVuY3Rpb24gZm9ybWF0VGV4dCggdGV4dCwgdyApCglsb2NhbCB0ID0gc3BsaXRCeVNwYWNlKCB0ZXh0ICkKCWxvY2FsIGxpbmVzID0ge1sxXSA9ICIifQoJbG9jYWwgbGluZSA9IDEKCWZvciBpPTEsICN0IGRvCgkJaWYgI3Rvc3RyaW5nKGxpbmVzW2xpbmVdLi4iICIuLnRbaV0pID4gdyB0aGVuCgkJCWxpbmVzW2xpbmVdID0gbGluZXNbbGluZV0gLi4gIlxuIgoJCQlsaW5lID0gbGluZSArIDEKCQkJbGluZXNbbGluZV0gPSAiICIgLi4gdFtpXQoJCWVsc2UKCQkJbGluZXNbbGluZV0gPSBsaW5lc1tsaW5lXSAuLiAiICIgLi4gdFtpXQoJCWVuZAoJZW5kCglyZXR1cm4gbGluZXMKZW5kCgpmdW5jdGlvbiB0ZXh0OmdldFBlcmNlbnRhZ2VzKCkKCWlmIHR5cGUoc2VsZi53KSA9PSAic3RyaW5nIiB0aGVuCgkJc2VsZi53ID0gY29iYWx0LmdldFBlcmNlbnRhZ2UoIHNlbGYudyApCgkJc2VsZi5hdXRvdyA9ICJwZXJjOiIgLi4gc2VsZi53CgllbHNlCgkJc2VsZi5hdXRvdyA9ICJub25lIgoJZW5kCglpZiB0eXBlKHNlbGYuaCkgPT0gInN0cmluZyIgdGhlbgoJCXNlbGYuaCA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLmggKQoJCXNlbGYuYXV0b2ggPSAicGVyYzoiIC4uIHNlbGYuaAoJZWxzZQoJCXNlbGYuYXV0b2ggPSAibm9uZSIKCWVuZAoKCWlmIHR5cGUoc2VsZi5tYXJnaW5sZWZ0KSA9PSAic3RyaW5nIiB0aGVuCgkJc2VsZi5tYXJnaW5sZWZ0ID0gY29iYWx0LmdldFBlcmNlbnRhZ2UoIHNlbGYubWFyZ2lubGVmdCApCgkJc2VsZi5hdXRvbWwgPSAicGVyYzoiIC4uIHNlbGYubWFyZ2lubGVmdAoJZW5kCglpZiB0eXBlKHNlbGYubWFyZ2lucmlnaHQpID09ICJzdHJpbmciIHRoZW4KCQlzZWxmLm1hcmdpbnJpZ2h0ID0gY29iYWx0LmdldFBlcmNlbnRhZ2UoIHNlbGYubWFyZ2lucmlnaHQgKQoJCXNlbGYuYXV0b21yID0gInBlcmM6IiAuLiBzZWxmLm1hcmdpbnJpZ2h0CgllbmQKCWlmIHR5cGUoc2VsZi5tYXJnaW50b3ApID09ICJzdHJpbmciIHRoZW4KCQlzZWxmLm1hcmdpbnRvcCA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLm1hcmdpbnRvcCApCgkJc2VsZi5hdXRvbXQgPSAicGVyYzoiIC4uIHNlbGYubWFyZ2ludG9wCgllbmQKCWlmIHR5cGUoc2VsZi5tYXJnaW5ib3R0b20pID09ICJzdHJpbmciIHRoZW4KCQlzZWxmLm1hcmdpbmJvdHRvbSA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLm1hcmdpbmJvdHRvbSApCgkJc2VsZi5hdXRvbWwgPSAicGVyYzoiIC4uIHNlbGYubWFyZ2luYm90dG9tCgllbmQKCWlmIHR5cGUoc2VsZi54KSA9PSAic3RyaW5nIiB0aGVuCgkJc2VsZi54ID0gY29iYWx0LmdldFBlcmNlbnRhZ2UoIHNlbGYueCApCgkJc2VsZi5hdXRveCA9ICJwZXJjOiIgLi4gc2VsZi54CgllbmQKCWlmIHR5cGUoc2VsZi55KSA9PSAic3RyaW5nIiB0aGVuCgkJc2VsZi55ID0gY29iYWx0LmdldFBlcmNlbnRhZ2UoIHNlbGYueSApCgkJc2VsZi5hdXRveSA9ICJwZXJjOiIgLi4gc2VsZi55CgllbmQKZW5kCgpmdW5jdGlvbiB0ZXh0Lm5ldyggZGF0YSwgcGFyZW50ICkKCWRhdGEgPSBkYXRhIG9yIHsgfQoJaWYgZGF0YS5zdHlsZSB0aGVuCgkJbG9jYWwgdCA9IGRhdGEuc3R5bGUKCQlmb3IgaywgdiBpbiBwYWlycyggdCApIGRvCgkJCWlmIG5vdCBkYXRhW2tdIHRoZW4KCQkJCWRhdGFba10gPSB2CgkJCWVuZAoJCWVuZAoJCWRhdGEuc3R5bGUgPSBuaWwKCWVuZAoJbG9jYWwgc2VsZiA9IHNldG1ldGF0YWJsZShkYXRhLHRleHQpCgoJc2VsZi5wYXJlbnQgPSBwYXJlbnQKCXNlbGY6Z2V0UGVyY2VudGFnZXMoKQoJaWYgc2VsZi50ZXh0IHRoZW4gc2VsZi51bmZvcm1hdHRlZCA9IHNlbGYudGV4dDsgc2VsZi50ZXh0ID0gZm9ybWF0VGV4dCggc2VsZi51bmZvcm1hdHRlZCwgc2VsZi53IG9yIHNlbGYucGFyZW50LncgKSBlbmQKCXNlbGY6cmVzaXplKCkKCXNlbGYuYmFja0NvbG91ciA9IGRhdGEuYmFja0NvbG91ciBvciBwYXJlbnQuYmFja0NvbG91cgoJc2VsZi5zdGF0ZSA9IGRhdGEuc3RhdGUgb3IgcGFyZW50LnN0YXRlCgl0YWJsZS5pbnNlcnQoIHBhcmVudC5jaGlsZHJlbiwgc2VsZiApCglyZXR1cm4gc2VsZgplbmQKCmZ1bmN0aW9uIHRleHQ6c2V0TWFyZ2lucyggdCwgciwgYiwgbCApCglpZiB0IHRoZW4KCQlzZWxmLm1hcmdpbnRvcCA9IHQgb3Igc2VsZi5tYXJnaW50b3AKCQlpZiB0eXBlKHQpID09ICJzdHJpbmciIHRoZW4KCQkJc2VsZjpnZXRQZXJjZW50YWdlcygpCgkJZWxzZQoJCQlzZWxmLmF1dG9tdCA9ICJub25lIgoJCWVuZAoJZW5kCglpZiByIHRoZW4KCQlzZWxmLm1hcmdpbnJpZ2h0ID0gciBvciBzZWxmLm1hcmdpbnJpZ2h0CgkJaWYgdHlwZShyKSA9PSAic3RyaW5nIiB0aGVuCgkJCXNlbGY6Z2V0UGVyY2VudGFnZXMoKQoJCWVsc2UKCQkJc2VsZi5hdXRvbXIgPSAibm9uZSIKCQllbmQKCWVuZAoJaWYgYiB0aGVuCgkJc2VsZi5tYXJnaW50b3AgPSBiIG9yIHNlbGYubWFyZ2ludG9wCgkJaWYgdHlwZShiKSA9PSAic3RyaW5nIiB0aGVuCgkJCXNlbGY6Z2V0UGVyY2VudGFnZXMoKQoJCWVsc2UKCQkJc2VsZi5hdXRvbWIgPSAibm9uZSIKCQllbmQKCWVuZAoJaWYgbCB0aGVuCgkJc2VsZi5tYXJnaW5sZWZ0ID0gbCBvciBzZWxmLm1hcmdpbmxlZnQKCQlpZiB0eXBlKGwpID09ICJzdHJpbmciIHRoZW4KCQkJc2VsZjpnZXRQZXJjZW50YWdlcygpCgkJZWxzZQoJCQlzZWxmLmF1dG9tbCA9ICJub25lIgoJCWVuZAoJZW5kCglzZWxmOnJlc2l6ZSgpCmVuZAoKZnVuY3Rpb24gdGV4dDpyZXNpemUoKQoJaWYgc2VsZi5hdXRvdz09InBhcmVudCIgdGhlbgoJCXNlbGYudyA9IHNlbGYucGFyZW50LncKCWVsc2VpZiBzZWxmLmF1dG93OnN1YiggMSwgNCApID09ICJwZXJjIiB0aGVuCgkJbG9jYWwgcGVyYyA9IHNlbGYuYXV0b3c6bWF0Y2goInBlcmM6KCVkKykiKQoJCXNlbGYudyA9IG1hdGguY2VpbCggc2VsZi5wYXJlbnQudyAqIGNvYmFsdC5zZXRQZXJjZW50YWdlKCBwZXJjICkgKQoJZW5kCglpZiBzZWxmLmF1dG9tbDpzdWIoIDEsIDQgKSA9PSAicGVyYyIgdGhlbgoJCWxvY2FsIHBlcmMgPSBzZWxmLmF1dG9tbDptYXRjaCgicGVyYzooJWQrKSIpCgkJc2VsZi5tYXJnaW5sZWZ0ID0gbWF0aC5mbG9vciggc2VsZi5wYXJlbnQudyAqIGNvYmFsdC5zZXRQZXJjZW50YWdlKCBwZXJjICkgKQoJZW5kCglpZiBzZWxmLmF1dG9tcjpzdWIoIDEsIDQgKSA9PSAicGVyYyIgdGhlbgoJCWxvY2FsIHBlcmMgPSBzZWxmLmF1dG9tcjptYXRjaCgicGVyYzooJWQrKSIpCgkJc2VsZi5tYXJnaW5yaWdodCA9IG1hdGguY2VpbCggc2VsZi5wYXJlbnQudyAqIGNvYmFsdC5zZXRQZXJjZW50YWdlKCBwZXJjICkgKQoJZW5kCglpZiBzZWxmLmF1dG9tdDpzdWIoIDEsIDQgKSA9PSAicGVyYyIgdGhlbgoJCWxvY2FsIHBlcmMgPSBzZWxmLmF1dG9tdDptYXRjaCgicGVyYzooJWQrKSIpCgkJc2VsZi5tYXJnaW50b3AgPSBtYXRoLmZsb29yKCBzZWxmLnBhcmVudC5oICogY29iYWx0LnNldFBlcmNlbnRhZ2UoIHBlcmMgKSApCgllbmQKCWlmIHNlbGYuYXV0b21iOnN1YiggMSwgNCApID09ICJwZXJjIiB0aGVuCgkJbG9jYWwgcGVyYyA9IHNlbGYuYXV0b21iOm1hdGNoKCJwZXJjOiglZCspIikKCQlzZWxmLm1hcmdpbmJvdHRvbSA9IG1hdGguY2VpbCggc2VsZi5wYXJlbnQuaCAqIGNvYmFsdC5zZXRQZXJjZW50YWdlKCBwZXJjICkgKQoJZW5kCglpZiBzZWxmLmF1dG94IGFuZCBzZWxmLmF1dG94OnN1YiggMSwgNCApID09ICJwZXJjIiB0aGVuCgkJbG9jYWwgcGVyYyA9IHNlbGYuYXV0b3g6bWF0Y2goInBlcmM6KCVkKykiKQoJCXNlbGYueCA9IG1hdGguY2VpbCggc2VsZi5wYXJlbnQudyAqIGNvYmFsdC5zZXRQZXJjZW50YWdlKCBwZXJjICkgKQoJZW5kCglpZiBzZWxmLmF1dG95IGFuZCBzZWxmLmF1dG95OnN1YiggMSwgNCApID09ICJwZXJjIiB0aGVuCgkJbG9jYWwgcGVyYyA9IHNlbGYuYXV0b3k6bWF0Y2goInBlcmM6KCVkKykiKQoJCXNlbGYueSA9IG1hdGguY2VpbCggc2VsZi5wYXJlbnQuaCAqIGNvYmFsdC5zZXRQZXJjZW50YWdlKCBwZXJjICkgKQoJZW5kCglzZWxmLnRleHQgPSBmb3JtYXRUZXh0KCBzZWxmLnVuZm9ybWF0dGVkLCBzZWxmLncgb3Igc2VsZi5wYXJlbnQudyApCmVuZAoKZnVuY3Rpb24gdGV4dDpnZXRBYnNYKCkKCXJldHVybiBzZWxmLnggKyBzZWxmLnBhcmVudDpnZXRBYnNYKCktMQplbmQKCmZ1bmN0aW9uIHRleHQ6Z2V0QWJzWSgpCglyZXR1cm4gc2VsZi55ICsgc2VsZi5wYXJlbnQ6Z2V0QWJzWSgpLTEKZW5kCgpmdW5jdGlvbiB0ZXh0OmRyYXcoKQoJaWYgdHlwZShzZWxmLnRleHQpID09ICJzdHJpbmciIHRoZW4KCQlzZWxmLnVuZm9ybWF0dGVkID0gc2VsZi50ZXh0CgkJc2VsZi50ZXh0ID0gZm9ybWF0VGV4dCggc2VsZi51bmZvcm1hdHRlZCwgc2VsZi53IG9yIHNlbGYucGFyZW50LncgKQoJZW5kCglpZiBzZWxmLnN0YXRlID09IGNvYmFsdC5zdGF0ZSBvciBzZWxmLnN0YXRlID09ICJfQUxMIiB0aGVuCgkJaWYgc2VsZi53cmFwID09ICJyaWdodCIgdGhlbgoJCQlmb3IgaSA9IDEsICNzZWxmLnRleHQgZG8KCQkJCXNlbGYucGFyZW50LnN1cmY6ZHJhd1RleHQoKCNzZWxmLnRleHRbaV0tc2VsZi54KzEpIC0gbWF0aC5mbG9vciggI3NlbGYudGV4dFtpXSApK21hdGguY2VpbCggc2VsZi5tYXJnaW5yaWdodCApLCBzZWxmLnkgKyAoaS0xKStzZWxmLm1hcmdpbnRvcCwgc2VsZi50ZXh0W2ldLCBzZWxmLmJhY2tDb2xvdXIsIHNlbGYuZm9yZUNvbG91ciApCgkJCWVuZAoJCWVsc2VpZiBzZWxmLndyYXAgPT0gImNlbnRlciIgdGhlbgoJCQlmb3IgaSA9IDEsICNzZWxmLnRleHQgZG8KCQkJCXNlbGYucGFyZW50LnN1cmY6ZHJhd1RleHQoIG1hdGguY2VpbCggc2VsZi5wYXJlbnQudy8yLSAjc2VsZi50ZXh0W2ldLzIgKSttYXRoLmNlaWwoIHNlbGYubWFyZ2lubGVmdCksIHNlbGYueSArIChpLTEpICsgc2VsZi5tYXJnaW50b3AsIHNlbGYudGV4dFtpXSwgc2VsZi5iYWNrQ29sb3VyLCBzZWxmLmZvcmVDb2xvdXIgKQoJCQllbmQKCQllbHNlCgkJCWZvciBpID0gMSwgI3NlbGYudGV4dCBkbwoJCQkJc2VsZi5wYXJlbnQuc3VyZjpkcmF3VGV4dCggc2VsZi54ICsgbWF0aC5jZWlsKHNlbGYubWFyZ2lubGVmdCksIHNlbGYueSArIChpLTEpICsgc2VsZi5tYXJnaW50b3AsIHNlbGYudGV4dFtpXSwgc2VsZi5iYWNrQ29sb3VyLCBzZWxmLmZvcmVDb2xvdXIgKQoJCQllbmQKCQllbmQKCWVuZAplbmQKCnJldHVybiB0ZXh0",
  6. [ "cobalt-ui/surface" ] = "-- Surface API version 1.6.2 by CrazedProgrammer
-- You can find info and documentation on these pages:
-- http://cp.msdev.nl/computercraft/surface-api/ or http://www.computercraft.info/forums2/index.php?/topic/22397-surface-api/
-- You may use this in your ComputerCraft programs and modify it without asking.
-- However, you may not publish this API under your name without asking me.
-- If you have any suggestions, bug reports or questions then please send an email to:
-- crazedprogrammer@gmail.com
version = "1.6.2"

local math_floor, math_cos, math_sin, table_concat, _colors = math.floor, math.cos, math.sin, table.concat, {[1] = "0", [2] = "1", [4] = "2", [8] = "3", [16] = "4", [32] = "5", [64] = "6", [128] = "7", [256] = "8", [512] = "9", [1024] = "a", [2048] = "b", [4096] = "c", [8192] = "d", [16384] = "e", [32768] = "f"}

local function _bufferLine(buffer, width, x1, y1, x2, y2)
	local delta_x = x2 - x1
	local ix = delta_x > 0 and 1 or -1
	delta_x = 2 * math.abs(delta_x)
	local delta_y = y2 - y1
	local iy = delta_y > 0 and 1 or -1
	delta_y = 2 * math.abs(delta_y)
	buffer[(y1 - 1) * width + x1] = true
	if delta_x >= delta_y then
		local error = delta_y - delta_x / 2
		while x1 ~= x2 do
			if (error >= 0) and ((error ~= 0) or (ix > 0)) then
				error = error - delta_x
				y1 = y1 + iy
			end
			error = error + delta_y
			x1 = x1 + ix
			buffer[(y1 - 1) * width + x1] = true
		end
	else
		local error = delta_x - delta_y / 2
		while y1 ~= y2 do
			if (error >= 0) and ((error ~= 0) or (iy > 0)) then
				error = error - delta_y
				x1 = x1 + ix
			end
			error = error + delta_x
			y1 = y1 + iy
			buffer[(y1 - 1) * width + x1] = true
		end
	end
end

local _functions = {
setBounds = function(surf, x1, y1, x2, y2)
	if x1 > x2 then
		local temp = x1
		x1, x2 = x2, temp
	end
	if y1 > y2 then
		local temp = y1
		y1, y2 = y2, temp
	end
	if x2 < 1 or x1 > surf.width or y2 < 1 or y1 > surf.height then return end
	if x1 < 1 then x1 = 1 end
	if x2 > surf.width then x2 = surf.width end
	if y1 < 1 then y1 = 1 end
	if y2 > surf.height then y2 = surf.height end
	surf.x1, surf.y1, surf.x2, surf.y2 = x1, y1, x2, y2
end,

getBounds = function(surf)
	return surf.x1, surf.y1, surf.x2, surf.y2
end,

copy = function(surf)
	local surf2 = create(surf.width, surf.height)
	surf2.x1, surf2.y1, surf2.x2, surf2.y2, surf2.blink, surf2.curX, surf2.curY, surf2.overwrite = surf.x1, surf.y1, surf.x2, surf.y2, surf.blink, surf.curX, surf.curY, surf.overwrite
	for i=1,surf.width * surf.height * 3 do
		surf2.buffer[i] = surf.buffer[i]
	end
	return surf2
end,

save = function(surf, path, type)
	type = type or "srf"
	local f = fs.open(path, "w")
	if type == "nfp" then
		local color = nil
		for j=1,surf.height do
			if j > 1 then f.write("\n") end
			for i=1,surf.width do
				color = surf.buffer[((j - 1) * surf.width + i) * 3 - 1]
				if color then
					f.write(_colors[color])
				else
					f.write(" ")
				end
			end
		end
	elseif type == "nft" then
		local backcolor, textcolor, char = nil
		for j=1,surf.height do
			if j > 1 then f.write("\n") end
			backcolor, textcolor = nil
			for i=1,surf.width do
				if backcolor ~= surf.buffer[((j - 1) * surf.width + i) * 3 - 1] then
					f.write(string.char(30))
					backcolor = surf.buffer[((j - 1) * surf.width + i) * 3 - 1]
					if backcolor then
						f.write(_colors[backcolor])
					else
						f.write(" ")
					end
				end
				if textcolor ~= surf.buffer[((j - 1) * surf.width + i) * 3] then
					f.write(string.char(31))
					textcolor = surf.buffer[((j - 1) * surf.width + i) * 3]
					if textcolor then
						f.write(_colors[textcolor])
					else
						f.write(" ")
					end
				end
				char = surf.buffer[((j - 1) * surf.width + i) * 3 - 2]
				if char then
					f.write(char)
				else
					f.write(" ")
				end
			end
		end
	elseif type == "srf" then
		f.write(surf:saveString())
	end
	f.close()
end,

saveString = function(surf)
	local str = {"_"..string.format("%04x", surf.width)..string.format("%04x", surf.height)}
	for j=1,surf.height do
		for i=1,surf.width do
			if surf.buffer[((j - 1) * surf.width + i) * 3 - 2] then
				str[#str + 1] = string.format("%02x", surf.buffer[((j - 1) * surf.width + i) * 3 - 2]:byte(1))
			else
				str[#str + 1] = "__"
			end
			if surf.buffer[((j - 1) * surf.width + i) * 3 - 1] then
				str[#str + 1] = _colors[surf.buffer[((j - 1) * surf.width + i) * 3 - 1]]
			else
				str[#str + 1] = "_"
			end
			if surf.buffer[((j - 1) * surf.width + i) * 3] then
				str[#str + 1] = _colors[surf.buffer[((j - 1) * surf.width + i) * 3]]
			else
				str[#str + 1] = "_"
			end
		end
	end
	return table_concat(str)
end,

getTerm = function(surf)
	local term, backcolor, textcolor = { }, colors.black, colors.white
	function term.write(str)
		surf:drawText(surf.curX, surf.curY, tostring(str), backcolor, textcolor)
		surf.curX = surf.curX + #tostring(str)
	end
	function term.blit(str, text, back)
		for i=1,#str do
			if surf.curX >= surf.x1 and surf.curY >= surf.y1 and surf.curX <= surf.x2 and surf.curY <= surf.y2 then
				surf.buffer[((surf.curY - 1) * surf.width + surf.curX) * 3 - 2] = str:sub(i, i)
				surf.buffer[((surf.curY - 1) * surf.width + surf.curX) * 3 - 1] = 2 ^ tonumber(back:sub(i, i), 16)
				surf.buffer[((surf.curY - 1) * surf.width + surf.curX) * 3] = 2 ^ tonumber(text:sub(i, i), 16)
			end
			surf.curX = surf.curX + 1
		end
	end
	function term.clear()
		surf:clear(" ", backcolor, textcolor)
	end
	function term.clearLine(n)
		surf:drawHLine(surf.x1, surf.x2, surf.curY, " ", backcolor, textcolor)
	end
	function term.getCursorPos()
		return surf.curX, surf.curY
	end
	function term.setCursorPos(x, y)
		surf.curX, surf.curY = math_floor(x), math_floor(y)
	end
	function term.setCursorBlink(blink)
		surf.blink = blink
	end
	function term.isColor()
		return true
	end
	term.isColour = term.isColor
	function term.setTextColor(color)
		textcolor = color
	end
	term.setTextColour = term.setTextColor
	function term.setBackgroundColor(color)
		backcolor = color
	end
	term.setBackgroundColour = term.setBackgroundColor
	function term.getSize()
		return surf.width, surf.height
	end
	function term.scroll(n)
		surf:shift(0, -n)
	end
	function term.getTextColor()
		return textcolor
	end
	term.getTextColour = term.getTextColor
	function term.getBackgroundColor()
		return backcolor
	end
	term.getBackgroundColour = term.getBackgroundColor
	return term
end,

render = function(surf, display, x, y, sx1, sy1, sx2, sy2)
	display, x, y, sx1, sy1, sx2, sy2 = display or term, x or 1, y or 1, sx1 or 1, sy1 or 1, sx2 or surf.width, sy2 or surf.height
	if sx1 > sx2 then
		local temp = sx1
		sx1, sx2 = sx2, temp
	end
	if sy1 > sy2 then
		local temp = sy1
		sy1, sy2 = sy2, temp
	end
	if sx2 < 1 or sx1 > surf.width or sy2 < 1 or sy1 > surf.height then return end
	if sx1 < 1 then sx1 = 1 end
	if sx2 > surf.width then sx2 = surf.width end
	if sy1 < 1 then sy1 = 1 end
	if sy2 > surf.height then sy2 = surf.height end
	local cmd = { }
	if display.blit then
		local str, back, text = { }, { }, { }
		for j=sy1,sy2 do
			for i=sx1,sx2 do
				str[i - sx1 + 1] = surf.buffer[((j - 1) * surf.width + i) * 3 - 2] or " "
				back[i - sx1 + 1] = _colors[surf.buffer[((j - 1) * surf.width + i) * 3 - 1] or 32768]
				text[i - sx1 + 1] = _colors[surf.buffer[((j - 1) * surf.width + i) * 3] or 1]
			end
			cmd[#cmd + 1] = y + j - sy1
			cmd[#cmd + 1] = table_concat(str)
			cmd[#cmd + 1] = table_concat(text)
			cmd[#cmd + 1] = table_concat(back)
		end
		for i=1,#cmd,4 do
			display.setCursorPos(x, cmd[i])
			display.blit(cmd[i + 1], cmd[i + 2], cmd[i + 3])
		end
	else
		local str, backcolor, textcolor, backc, textc = "", 0, 0
		for j=sy1,sy2 do
			cmd[#cmd + 1] = 1
			cmd[#cmd + 1] = y + j - sy1
			for i=sx1,sx2 do
				backc, textc = (surf.buffer[((j - 1) * surf.width + i) * 3 - 1] or 32768), (surf.buffer[((j - 1) * surf.width + i) * 3] or 1)
				if backc ~= backcolor then
					backcolor = backc
					if str ~= "" then
						cmd[#cmd + 1] = 4
						cmd[#cmd + 1] = str
						str = ""
					end
					cmd[#cmd + 1] = 2
					cmd[#cmd + 1] = backcolor
				end
				if textc ~= textcolor then
					textcolor = textc
					if str ~= "" then
						cmd[#cmd + 1] = 4
						cmd[#cmd + 1] = str
						str = ""
					end
					cmd[#cmd + 1] = 3
					cmd[#cmd + 1] = textcolor
				end
				str = str..(surf.buffer[((j - 1) * surf.width + i) * 3 - 2] or " ")
			end
			cmd[#cmd + 1] = 4
			cmd[#cmd + 1] = str
			str = ""
		end
		local c, a = nil
		for i=1,#cmd,2 do
			c, a = cmd[i], cmd[i + 1]
			if c == 1 then
				display.setCursorPos(x, a)
			elseif c == 2 then
				display.setBackgroundColor(a)
			elseif c == 3 then
				display.setTextColor(a)
			else
				display.write(a)
			end
		end
	end
	if surf.blink and surf.curX >= 1 and surf.curY >= 1 and surf.curX <= surf.width and surf.curY <= surf.height then
		display.setCursorPos(x + surf.curX - sx1, y + surf.curY - sy1)
		display.setCursorBlink(true)
	elseif surf.blink == false then
		display.setCursorBlink(false)
		surf.blink = nil
	end
	return #cmd / 2
end,

clear = function(surf, char, backcolor, textcolor)
	local overwrite = surf.overwrite
	surf.overwrite = true
	surf:fillRect(surf.x1, surf.y1, surf.x2, surf.y2, char, backcolor, textcolor)
	surf.overwrite = overwrite
end,

drawPixel = function(surf, x, y, char, backcolor, textcolor)
	if x < surf.x1 or y < surf.y1 or x > surf.x2 or y > surf.y2 then return end
	if char or surf.overwrite then
		surf.buffer[((y - 1) * surf.width + x) * 3 - 2] = char
	end
	if backcolor or surf.overwrite then
		surf.buffer[((y - 1) * surf.width + x) * 3 - 1] = backcolor
	end
	if textcolor or surf.overwrite then
		surf.buffer[((y - 1) * surf.width + x) * 3] = textcolor
	end
end,

getPixel = function(surf, x, y)
	if x < 1 or y < 1 or x > surf.width or y > surf.height then return end
	return surf.buffer[((y - 1) * surf.width + x) * 3 - 2], surf.buffer[((y - 1) * surf.width + x) * 3 - 1], surf.buffer[((y - 1) * surf.width + x) * 3]
end,

drawText = function(surf, x, y, text, backcolor, textcolor)
	local px = x
	for i=1,#text do
		if text:sub(i, i) ~= "\n" then
			if x >= surf.x1 and y >= surf.y1 and x <= surf.x2 and y <= surf.y2 then
				surf.buffer[((y - 1) * surf.width + x) * 3 - 2] = text:sub(i, i)
				if backcolor or surf.overwrite then
					surf.buffer[((y - 1) * surf.width + x) * 3 - 1] = backcolor
				end
				if textcolor or surf.overwrite then
					surf.buffer[((y - 1) * surf.width + x) * 3] = textcolor
				end
			end
		else
			x = px - 1
			y = y + 1
		end
		x = x + 1
	end
end,

drawLine = function(surf, x1, y1, x2, y2, char, backcolor, textcolor)
	local delta_x = x2 - x1
	local ix = delta_x > 0 and 1 or -1
	delta_x = 2 * math.abs(delta_x)
	local delta_y = y2 - y1
	local iy = delta_y > 0 and 1 or -1
	delta_y = 2 * math.abs(delta_y)
	surf:drawPixel(x1, y1, char, backcolor, textcolor)
	if delta_x >= delta_y then
		local error = delta_y - delta_x / 2
		while x1 ~= x2 do
			if (error >= 0) and ((error ~= 0) or (ix > 0)) then
				error = error - delta_x
				y1 = y1 + iy
			end
			error = error + delta_y
			x1 = x1 + ix
			surf:drawPixel(x1, y1, char, backcolor, textcolor)
		end
	else
		local error = delta_x - delta_y / 2
		while y1 ~= y2 do
			if (error >= 0) and ((error ~= 0) or (iy > 0)) then
				error = error - delta_y
				x1 = x1 + ix
			end
			error = error + delta_x
			y1 = y1 + iy
			surf:drawPixel(x1, y1, char, backcolor, textcolor)
		end
	end
end,

drawLines = function(surf, points, mode, char, backcolor, textcolor)
	mode = mode or 1
	if mode == 1 then
		for i=1,#points,4 do
			surf:drawLine(points[i], points[i+1], points[i+2], points[i+3], char, backcolor, textcolor)
		end
	elseif mode == 2 then
		local lastx, lasty = points[1], points[2]
		for i=3,#points,2 do
			local curx, cury = points[i], points[i+1]
			surf:drawLine(lastx, lasty, curx, cury, char, backcolor, textcolor)
			lastx = curx
			lasty = cury
		end
	elseif mode == 3 then
		local midx, midy = points[1], points[2]
		for i=3,#points,2 do
			surf:drawLine(midx, midy, points[i], points[i+1], char, backcolor, textcolor)
		end
	end
end,

drawHLine = function(surf, x1, x2, y, char, backcolor, textcolor)
	if x1 > x2 then
		local temp = x1
		x1, x2 = x2, temp
	end
	if y < surf.y1 or y > surf.y2 or x2 < surf.x1 or x1 > surf.x2 then return end
	if x1 < surf.x1 then x1 = surf.x1 end
	if x2 > surf.x2 then x2 = surf.x2 end
	if char or surf.overwrite then
		for x=x1,x2 do
			surf.buffer[((y - 1) * surf.width + x) * 3 - 2] = char
		end
	end
	if backcolor or surf.overwrite then
		for x=x1,x2 do
			surf.buffer[((y - 1) * surf.width + x) * 3 - 1] = backcolor
		end
	end
	if textcolor or surf.overwrite then
		for x=x1,x2 do
			surf.buffer[((y - 1) * surf.width + x) * 3] = textcolor
		end
	end
end,

drawVLine = function(surf, y1, y2, x, char, backcolor, textcolor)
	if y1 > y2 then
		local temp = y1
		y1, y2 = y2, temp
	end
	if x < surf.x1 or x > surf.x2 or y2 < surf.y1 or y1 > surf.y2 then return end
	if y1 < surf.y1 then y1 = surf.y1 end
	if y2 > surf.y2 then y2 = surf.y2 end
	if char or surf.overwrite then
		for y=y1,y2 do
			surf.buffer[((y - 1) * surf.width + x) * 3 - 2] = char
		end
	end
	if backcolor or surf.overwrite then
		for y=y1,y2 do
			surf.buffer[((y - 1) * surf.width + x) * 3 - 1] = backcolor
		end
	end
	if textcolor or surf.overwrite then
		for y=y1,y2 do
			surf.buffer[((y - 1) * surf.width + x) * 3] = textcolor
		end
	end
end,

drawRect = function(surf, x1, y1, x2, y2, char, backcolor, textcolor)
	surf:drawHLine(x1, x2, y1, char, backcolor, textcolor)
	surf:drawHLine(x1, x2, y2, char, backcolor, textcolor)
	surf:drawVLine(y1, y2, x1, char, backcolor, textcolor)
	surf:drawVLine(y1, y2, x2, char, backcolor, textcolor)
end,

drawRoundRect = function(surf, x1, y1, x2, y2, char, backcolor, textcolor)
	surf:drawHLine(x1 + 1, x2 - 1, y1, char, backcolor, textcolor)
	surf:drawHLine(x1 + 1, x2 - 1, y2, char, backcolor, textcolor)
	surf:drawVLine(y1 + 1, y2 - 1, x1, char, backcolor, textcolor)
	surf:drawVLine(y1 + 1, y2 - 1, x2, char, backcolor, textcolor)
end,

drawRoundedRect = function(surf, x1, y1, x2, y2, radius, char, backcolor, textcolor)
	surf:drawHLine(x1 + radius, x2 - radius, y1, char, backcolor, textcolor)
	surf:drawHLine(x1 + radius, x2 - radius, y2, char, backcolor, textcolor)
	surf:drawVLine(y1 + radius, y2 - radius, x1, char, backcolor, textcolor)
	surf:drawVLine(y1 + radius, y2 - radius, x2, char, backcolor, textcolor)
	surf:drawArc(x1, y1, x1 + radius * 2 + 2, y1 + radius * 2 + 2, -math.pi, -math.pi / 2, char, backcolor, textcolor)
	surf:drawArc(x2, y1, x2 - radius * 2 - 2, y1 + radius * 2 + 2, 0, -math.pi / 2, char, backcolor, textcolor)
	surf:drawArc(x1, y2, x1 + radius * 2 + 2, y2 - radius * 2 - 2, math.pi, math.pi / 2, char, backcolor, textcolor)
	surf:drawArc(x2, y2, x2 - radius * 2 - 2, y2 - radius * 2 - 2, 0, math.pi / 2, char, backcolor, textcolor)
end,

fillRect = function(surf, x1, y1, x2, y2, char, backcolor, textcolor)
	if x1 > x2 then
		local temp = x1
		x1, x2 = x2, temp
	end
	if y1 > y2 then
		local temp = y1
		y1, y2 = y2, temp
	end
	if x2 < surf.x1 or x1 > surf.x2 or y2 < surf.y1 or y1 > surf.y2 then return end
	if x1 < surf.x1 then x1 = surf.x1 end
	if x2 > surf.x2 then x2 = surf.x2 end
	if y1 < surf.y1 then y1 = surf.y1 end
	if y2 > surf.y2 then y2 = surf.y2 end
	if char or surf.overwrite then
		for y=y1,y2 do
			for x=x1,x2 do
				surf.buffer[((y - 1) * surf.width + x) * 3 - 2] = char
			end
		end
	end
	if backcolor or surf.overwrite then
		for y=y1,y2 do
			for x=x1,x2 do
				surf.buffer[((y - 1) * surf.width + x) * 3 - 1] = backcolor
			end
		end
	end
	if textcolor or surf.overwrite then
		for y=y1,y2 do
			for x=x1,x2 do
				surf.buffer[((y - 1) * surf.width + x) * 3] = textcolor
			end
		end
	end
end,

fillRoundRect = function(surf, x1, y1, x2, y2, char, backcolor, textcolor)
	surf:drawHLine(x1 + 1, x2 - 1, y1, char, backcolor, textcolor)
	surf:drawHLine(x1 + 1, x2 - 1, y2, char, backcolor, textcolor)
	surf:drawVLine(y1 + 1, y2 - 1, x1, char, backcolor, textcolor)
	surf:drawVLine(y1 + 1, y2 - 1, x2, char, backcolor, textcolor)
	surf:fillRect(x1 + 1, y1 + 1, x2 - 1, y2 - 1, char, backcolor, textcolor)
end,

fillRoundedRect = function(surf, x1, y1, x2, y2, radius, char, backcolor, textcolor)
	surf:fillRect(x1 + radius, y1, x2 - radius, y2, char, backcolor, textcolor)
	surf:fillRect(x1, y1 + radius, x1 + radius, y2 - radius, char, backcolor, textcolor)
	surf:fillRect(x2 - radius, y1 + radius, x2, y2 - radius, char, backcolor, textcolor)
	surf:fillPie(x1, y1, x1 + radius * 2 + 2, y1 + radius * 2 + 2, -math.pi, -math.pi / 2, char, backcolor, textcolor)
	surf:fillPie(x2, y1, x2 - radius * 2 - 2, y1 + radius * 2 + 2, 0, -math.pi / 2, char, backcolor, textcolor)
	surf:fillPie(x1, y2, x1 + radius * 2 + 2, y2 - radius * 2 - 2, math.pi, math.pi / 2, char, backcolor, textcolor)
	surf:fillPie(x2, y2, x2 - radius * 2 - 2, y2 - radius * 2 - 2, 0, math.pi / 2, char, backcolor, textcolor)
end,

drawTriangle = function(surf, x1, y1, x2, y2, x3, y3, char, backcolor, textcolor)
	surf:drawLine(x1, y1, x2, y2, char, backcolor, textcolor)
	surf:drawLine(x2, y2, x3, y3, char, backcolor, textcolor)
	surf:drawLine(x3, y3, x1, y1, char, backcolor, textcolor)
end,

fillTriangle = function(surf, x1, y1, x2, y2, x3, y3, char, backcolor, textcolor)
	local minX, minY, maxX, maxY = x1, y1, x1, y1
	if x2 < minX then minX = x2 end
	if x3 < minX then minX = x3 end
	if y2 < minY then minY = y2 end
	if y3 < minY then minY = y3 end
	if x2 > maxX then maxX = x2 end
	if x3 > maxX then maxX = x3 end
	if y2 > maxY then maxY = y2 end
	if y3 > maxY then maxY = y3 end
	local width, height, buffer, min, max = maxX - minX + 1, maxY - minY + 1, { }, 0, 0
	_bufferLine(buffer, width, x1 - minX + 1, y1 - minY + 1, x2 - minX + 1, y2 - minY + 1)
	_bufferLine(buffer, width, x2 - minX + 1, y2 - minY + 1, x3 - minX + 1, y3 - minY + 1)
	_bufferLine(buffer, width, x3 - minX + 1, y3 - minY + 1, x1 - minX + 1, y1 - minY + 1)
	for j=1,height do
		min, max = nil
		for i=1,width do
			if buffer[(j - 1) * width + i] then
				if not min then min = i end
				max = i
			end
		end
		surf:drawHLine(min + minX - 1, max + minX - 1, j + minY - 1, char, backcolor, textcolor)
	end
end,

drawTriangles = function(surf, points, mode, char, backcolor, textcolor)
	mode = mode or 1
	if mode == 1 then
		for i=1,#points,6 do
			surf:drawTriangle(points[i], points[i+1], points[i+2], points[i+3], points[i+4], points[i+5], char, backcolor, textcolor)
		end
	elseif mode == 2 then
		local lastx, lasty, prevx, prevy, curx, cury = points[1], points[2], points[3], points[4]
		for i=5,#points,2 do
			curx, cury = points[i], points[i+1]
			surf:drawTriangle(lastx, lasty, prevx, prevy, curx, cury, char, backcolor, textcolor)
			lastx, lasty, prevx, prevy = prevx, prevy, curx, cury
		end
	elseif mode == 3 then
		local midx, midy, lastx, lasty, curx, cury = points[1], points[2], points[3], points[4]
		for i=5,#points,2 do
			curx, cury = points[i], points[i+1]
			surf:drawTriangle(midx, midy, lastx, lasty, curx, cury, char, backcolor, textcolor)
			lastx, lasty = curx, cury
		end
	end
end,

fillTriangles = function(surf, points, mode, char, backcolor, textcolor)
	mode = mode or 1
	if mode == 1 then
		for i=1,#points,6 do
			surf:fillTriangle(points[i], points[i+1], points[i+2], points[i+3], points[i+4], points[i+5], char, backcolor, textcolor)
		end
	elseif mode == 2 then
		local lastx, lasty, prevx, prevy, curx, cury = points[1], points[2], points[3], points[4]
		for i=5,#points,2 do
			curx, cury = points[i], points[i+1]
			surf:fillTriangle(lastx, lasty, prevx, prevy, curx, cury, char, backcolor, textcolor)
			lastx, lasty, prevx, prevy = prevx, prevy, curx, cury
		end
	elseif mode == 3 then
		local midx, midy, lastx, lasty, curx, cury = points[1], points[2], points[3], points[4]
		for i=5,#points,2 do
			curx, cury = points[i], points[i+1]
			surf:fillTriangle(midx, midy, lastx, lasty, curx, cury, char, backcolor, textcolor)
			lastx, lasty = curx, cury
		end
	end
end,

drawEllipse = function(surf, x1, y1, x2, y2, char, backcolor, textcolor)
	if x1 > x2 then
		local temp = x1
		x1, x2 = x2, temp
	end
	if y1 > y2 then
		local temp = y1
		y1, y2 = y2, temp
	end
	local step, midX, midY, width, height, lastX, lastY = (math.pi * 2) / 16, (x1 + x2) / 2, (y1 + y2) / 2, (x2 - x1) / 2, (y2 - y1) / 2, 1, 1
	for i=1,17 do
		local x, y = math_floor((midX + math_cos(step * i) * width) + 0.5), math_floor((midY + math_sin(step * i) * height) + 0.5)
		if i > 1 then
			surf:drawLine(lastX, lastY, x, y, char, backcolor, textcolor)
		end
		lastX, lastY = x, y
	end
end,

fillEllipse = function(surf, x1, y1, x2, y2, char, backcolor, textcolor)
	if x1 > x2 then
		local temp = x1
		x1, x2 = x2, temp
	end
	if y1 > y2 then
		local temp = y1
		y1, y2 = y2, temp
	end
	local resolution, step, midX, midY, width, height, lastX, lastY, bwidth, bheight, buffer = 16, (math.pi * 2) / 16, (x1 + x2) / 2, (y1 + y2) / 2, (x2 - x1) / 2, (y2 - y1) / 2, 1, 1, x2 - x1 + 1, y2 - y1 + 1, { }
	for i=1,resolution+1 do
		local x, y = math_floor((midX + math_cos(step * i) * width) + 0.5), math_floor((midY + math_sin(step * i) * height) + 0.5)
		if i > 1 then
			_bufferLine(buffer, bwidth, lastX - x1 + 1, lastY - y1 + 1, x - x1 + 1, y - y1 + 1)
		end
		lastX, lastY = x, y
	end
	for j=1,bheight do
		min, max = nil
		for i=1,bwidth do
			if buffer[(j - 1) * bwidth + i] then
				if not min then min = i end
				max = i
			end
		end
		surf:drawHLine(min + x1 - 1, max + x1 - 1, j + y1 - 1, char, backcolor, textcolor)
	end
end,

drawArc = function(surf, x1, y1, x2, y2, a1, a2, char, backcolor, textcolor)
	if x1 > x2 then
		local temp = x1
		x1, x2 = x2, temp
	end
	if y1 > y2 then
		local temp = y1
		y1, y2 = y2, temp
	end
	if a1 > a2 then
		local temp = a1
		a1, a2 = a2, temp
	end
	local step, midX, midY, width, height, lastX, lastY = (a2 - a1) / 16, (x1 + x2) / 2, (y1 + y2) / 2, (x2 - x1) / 2, (y2 - y1) / 2, 1, 1
	for i=1,17 do
		local x, y = math_floor((midX + math_cos(step * (i - 1) + a1) * width) + 0.5), math_floor((midY - math_sin(step * (i - 1) + a1) * height) + 0.5)
		if i > 1 then
			surf:drawLine(lastX, lastY, x, y, char, backcolor, textcolor)
		end
		lastX, lastY = x, y
	end
end,

drawPie = function(surf, x1, y1, x2, y2, a1, a2, char, backcolor, textcolor)
	if x1 > x2 then
		local temp = x1
		x1, x2 = x2, temp
	end
	if y1 > y2 then
		local temp = y1
		y1, y2 = y2, temp
	end
	if a1 > a2 then
		local temp = a1
		a1, a2 = a2, temp
	end
	local step, midX, midY, width, height, lastX, lastY = (a2 - a1) / 16, (x1 + x2) / 2, (y1 + y2) / 2, (x2 - x1) / 2, (y2 - y1) / 2, 1, 1
	for i=1,17 do
		local x, y = math_floor((midX + math_cos(step * (i - 1) + a1) * width) + 0.5), math_floor((midY - math_sin(step * (i - 1) + a1) * height) + 0.5)
		if i > 1 then
			surf:drawLine(lastX, lastY, x, y, char, backcolor, textcolor)
		end
		lastX, lastY = x, y
	end
	surf:drawLine(math_floor(midX + 0.5), math_floor(midY + 0.5), math_floor((midX + math_cos(a1) * width) + 0.5), math_floor((midY - math_sin(a1) * height) + 0.5), char, backcolor, textcolor)
	surf:drawLine(math_floor(midX + 0.5), math_floor(midY + 0.5), math_floor((midX + math_cos(a2) * width) + 0.5), math_floor((midY - math_sin(a2) * height) + 0.5), char, backcolor, textcolor)
end,

fillPie = function(surf, x1, y1, x2, y2, a1, a2, char, backcolor, textcolor)
	if x1 > x2 then
		local temp = x1
		x1, x2 = x2, temp
	end
	if y1 > y2 then
		local temp = y1
		y1, y2 = y2, temp
	end
	if a1 > a2 then
		local temp = a1
		a1, a2 = a2, temp
	end
	local step, midX, midY, width, height, lastX, lastY, bwidth, bheight, buffer = (a2 - a1) / 16, (x1 + x2) / 2, (y1 + y2) / 2, (x2 - x1) / 2, (y2 - y1) / 2, 1, 1, x2 - x1 + 1, y2 - y1 + 1, { }
	for i=1,17 do
		local x, y = math_floor((midX + math_cos(step * (i - 1) + a1) * width) + 0.5), math_floor((midY - math_sin(step * (i - 1) + a1) * height) + 0.5)
		if i > 1 then
			_bufferLine(buffer, bwidth, lastX - x1 + 1, lastY - y1 + 1, x - x1 + 1, y - y1 + 1)
		end
		lastX, lastY = x, y
	end
	_bufferLine(buffer, bwidth, math_floor(midX + 0.5) - x1 + 1, math_floor(midY + 0.5) - y1 + 1, math_floor((midX + math_cos(a1) * width) + 0.5) - x1 + 1, math_floor((midY - math_sin(a1) * height) + 0.5) - y1 + 1)
	_bufferLine(buffer, bwidth, math_floor(midX + 0.5) - x1 + 1, math_floor(midY + 0.5) - y1 + 1, math_floor((midX + math_cos(a2) * width) + 0.5) - x1 + 1, math_floor((midY - math_sin(a2) * height) + 0.5) - y1 + 1)
	for j=1,bheight do
		min, max = nil
		for i=1,bwidth do
			if buffer[(j - 1) * bwidth + i] then
				if not min then min = i end
				max = i
			end
		end
		if min then
			surf:drawHLine(min + x1 - 1, max + x1 - 1, j + y1 - 1, char, backcolor, textcolor)
		end
	end
end,

floodFill = function(surf, x, y, char, backcolor, textcolor)
	if x < surf.x1 or y < surf.y1 or x > surf.x2 or y > surf.y2 then return end
	local stack, tchar, tbackcolor, ttextcolor = { x, y }, surf.buffer[((y - 1) * surf.width + x) * 3 - 2], surf.buffer[((y - 1) * surf.width + x) * 3 - 1], surf.buffer[((y - 1) * surf.width + x) * 3]
	if (tchar == char) and (tbackcolor == backcolor) and (ttextcolor == textcolor) then return end
	while #stack > 0 do
		local cx, cy = stack[#stack - 1], stack[#stack]
		stack[#stack] = nil
		stack[#stack] = nil
		if cx >= surf.x1 and cy >= surf.y1 and cx <= surf.x2 and cy <= surf.y2 then
			local cchar, cbackcolor, ctextcolor = surf.buffer[((cy - 1) * surf.width + cx) * 3 - 2], surf.buffer[((cy - 1) * surf.width + cx) * 3 - 1], surf.buffer[((cy - 1) * surf.width + cx) * 3]
			if (tchar == cchar) and (tbackcolor == cbackcolor) and (ttextcolor == ctextcolor) then
				if char or surf.overwrite then
					surf.buffer[((cy - 1) * surf.width + cx) * 3 - 2] = char
				end
				if backcolor or surf.overwrite then
					surf.buffer[((cy - 1) * surf.width + cx) * 3 - 1] = backcolor
				end
				if textcolor or surf.overwrite then
					surf.buffer[((cy - 1) * surf.width + cx) * 3] = textcolor
				end
				stack[#stack + 1] = cx - 1
				stack[#stack + 1] = cy
				stack[#stack + 1] = cx + 1
				stack[#stack + 1] = cy
				stack[#stack + 1] = cx
				stack[#stack + 1] = cy - 1
				stack[#stack + 1] = cx
				stack[#stack + 1] = cy + 1
			end
		end
	end
end,

drawSurface = function(surf, x, y, surf2)
	for j=1,surf2.height do
		for i=1,surf2.width do
			surf:drawPixel(i + x - 1, j + y - 1, surf2.buffer[((j - 1) * surf2.width + i) * 3 - 2], surf2.buffer[((j - 1) * surf2.width + i) * 3 - 1], surf2.buffer[((j - 1) * surf2.width + i) * 3])
		end
	end
end,

drawSurfacePart = function(surf, x, y, sx1, sy1, sx2, sy2, surf2)
	if sx1 > sx2 then
		local temp = sx1
		sx1, sx2 = sx2, temp
	end
	if sy1 > sy2 then
		local temp = sy1
		sy1, sy2 = sy2, temp
	end
	if sx2 < 1 or sx1 > surf2.width or sy2 < 1 or sy1 > surf2.height then return end
	if sx1 < 1 then sx1 = 1 end
	if sx2 > surf2.width then sx2 = surf2.width end
	if sy1 < 1 then sy1 = 1 end
	if sy2 > surf2.height then sy2 = surf2.height end
	for j=sy1,sy2 do
		for i=sx1,sx2 do
			surf:drawPixel(x + i - sx1, y + j - sy1, surf2.buffer[((j - 1) * surf2.width + i) * 3 - 2], surf2.buffer[((j - 1) * surf2.width + i) * 3 - 1], surf2.buffer[((j - 1) * surf2.width + i) * 3])
		end
	end
end,

drawSurfaceScaled = function(surf, x1, y1, x2, y2, surf2)
	local x, width, xinv, y, height, yinv = 0, 0, false, 0, 0, false
	if x1 <= x2 then
		x = x1
		width = x2 - x1 + 1
	else
		x = x2
		width = x1 - x2 + 1
		xinv = true
	end
	if y1 <= y2 then
		y = y1
		height = y2 - y1 + 1
	else
		y = y2
		height = y1 - y2 + 1
		yinv = true
	end
	local xscale, yscale, px, py = width / surf2.width, height / surf2.height
	for j=1,height do
		for i=1,width do
			if xinv then
				px = math_floor((width - i + 0.5) / xscale) + 1
			else
				px = math_floor((i - 0.5) / xscale) + 1
			end
			if yinv then
				py = math_floor((height - j + 0.5) / yscale) + 1
			else
				py = math_floor((j - 0.5) / yscale) + 1
			end
			surf:drawPixel(x + i - 1, y + j - 1, surf2.buffer[((py - 1) * surf2.width + px) * 3 - 2], surf2.buffer[((py - 1) * surf2.width + px) * 3 - 1], surf2.buffer[((py - 1) * surf2.width + px) * 3])
		end
	end
end,

drawSurfaceRotated = function(surf, x, y, ox, oy, angle, surf2)
	local cos, sin, range = math_cos(angle), math_sin(angle), math_floor(math.sqrt(surf2.width * surf2.width + surf2.height * surf2.height))
	x, y = x - math_floor(cos * (ox - 1) + sin * (oy - 1) + 0.5), y - math_floor(cos * (oy - 1) - sin * (ox - 1) + 0.5)
	for j=-range,range do
		for i=-range,range do
			local sx, sy = math_floor(i * cos - j * sin), math_floor(i * sin + j * cos)
			if sx >= 0 and sx < surf2.width and sy >= 0 and sy < surf2.height then
				surf:drawPixel(x + i, y + j, surf2.buffer[(sy * surf2.width + sx) * 3 + 1], surf2.buffer[(sy * surf2.width + sx) * 3 + 2], surf2.buffer[(sy * surf2.width + sx) * 3 + 3])
			end
		end
	end
end,

shader = function(surf, f, x1, y1, x2, y2)
	x1, y1, x2, y2 = x1 or surf.x1, y1 or surf.y1, x2 or surf.x2, y2 or surf.y2
	if x1 > x2 then
		local temp = x1
		x1, x2 = x2, temp
	end
	if y1 > y2 then
		local temp = y1
		y1, y2 = y2, temp
	end
	if x2 < surf.x1 or x1 > surf.x2 or y2 < surf.y1 or y1 > surf.y2 then return end
	if x1 < surf.x1 then x1 = surf.x1 end
	if x2 > surf.x2 then x2 = surf.x2 end
	if y1 < surf.y1 then y1 = surf.y1 end
	if y2 > surf.y2 then y2 = surf.y2 end
	local width, buffer = x2 - x1 + 1, { }
	for j=y1,y2 do
		for i=x1,x2 do
			buffer[((j - y1) * width + i - x1) * 3 + 1], buffer[((j - y1) * width + i - x1) * 3 + 2], buffer[((j - y1) * width + i - x1) * 3 + 3] = f(surf.buffer[((j - 1) * surf.width + i) * 3 - 2], surf.buffer[((j - 1) * surf.width + i) * 3 - 1], surf.buffer[((j - 1) * surf.width + i) * 3], i, j)
		end
	end
	for j=y1,y2 do
		for i=x1,x2 do
			surf.buffer[((j - 1) * surf.width + i) * 3 - 2], surf.buffer[((j - 1) * surf.width + i) * 3 - 1], surf.buffer[((j - 1) * surf.width + i) * 3] = buffer[((j - y1) * width + i - x1) * 3 + 1], buffer[((j - y1) * width + i - x1) * 3 + 2], buffer[((j - y1) * width + i - x1) * 3 + 3]
		end
	end
end,

shift = function(surf, x, y, x1, y1, x2, y2)
	x1, y1, x2, y2 = x1 or surf.x1, y1 or surf.y1, x2 or surf.x2, y2 or surf.y2
	if x1 > x2 then
		local temp = x1
		x1, x2 = x2, temp
	end
	if y1 > y2 then
		local temp = y1
		y1, y2 = y2, temp
	end
	if x2 < surf.x1 or x1 > surf.x2 or y2 < surf.y1 or y1 > surf.y2 then return end
	if x1 < surf.x1 then x1 = surf.x1 end
	if x2 > surf.x2 then x2 = surf.x2 end
	if y1 < surf.y1 then y1 = surf.y1 end
	if y2 > surf.y2 then y2 = surf.y2 end
	local width, buffer = x2 - x1 + 1, { }
	for j=y1,y2 do
		for i=x1,x2 do
			if i - x >= 1 and j - y >= 1 and i - x <= surf.width and j - y <= surf.height then
				buffer[((j - y1) * width + i - x1) * 3 + 1], buffer[((j - y1) * width + i - x1) * 3 + 2], buffer[((j - y1) * width + i - x1) * 3 + 3] = surf.buffer[((j - y - 1) * surf.width + i - x) * 3 - 2], surf.buffer[((j - y - 1) * surf.width + i - x) * 3 - 1], surf.buffer[((j - y - 1) * surf.width + i - x) * 3]
			end
		end
	end
	for j=y1,y2 do
		for i=x1,x2 do
			surf.buffer[((j - 1) * surf.width + i) * 3 - 2], surf.buffer[((j - 1) * surf.width + i) * 3 - 1], surf.buffer[((j - 1) * surf.width + i) * 3] = buffer[((j - y1) * width + i - x1) * 3 + 1], buffer[((j - y1) * width + i - x1) * 3 + 2], buffer[((j - y1) * width + i - x1) * 3 + 3]
		end
	end
end
}

function create(width, height, char, backcolor, textcolor)
	local surf = { }
	for k,v in pairs(_functions) do
		surf[k] = v
	end
	surf.width, surf.height, surf.x1, surf.y1, surf.x2, surf.y2, surf.curX, surf.curY, surf.overwrite, surf.buffer = width, height, 1, 1, width, height, 1, 1, false, { }
	if char then
		for i=1,width * height do
			surf.buffer[i * 3 - 2] = char
		end
	end
	if backcolor then
		for i=1,width * height do
			surf.buffer[i * 3 - 1] = backcolor
		end
	end
	if textcolor then
		for i=1,width * height do
			surf.buffer[i * 3] = textcolor
		end
	end
	return surf
end

function load(path)
	local lines, f = { }, fs.open(path, "r")
	for line in f.readLine do
		lines[#lines + 1] = line
	end
	f.close()
	local height = #lines
	if lines[1]:byte(1) == 30 then
		local width, i = 0, 1
		while i <= #lines[1] do
			local char = lines[1]:byte(i)
			if char == 30 or char == 31 then
				i = i + 1
			else
				width = width + 1
			end
			i = i + 1
		end
		local surf, backcolor, textcolor, i, px, char, color = create(width, height)
		for j=1,height do
			i = 1
			px = 1
			while i <= #lines[j] do
				char = lines[j]:byte(i)
				if char == 30 then
					i = i + 1
					char = lines[j]:byte(i)
					color = tonumber(lines[j]:sub(i, i), 16)
					if color then
						backcolor = 2^color
					else
						backcolor = nil
					end
				elseif char == 31 then
					i = i + 1
					char = lines[j]:byte(i)
					color = tonumber(lines[j]:sub(i, i), 16)
					if color then
						textcolor = 2^color
					else
						textcolor = nil
					end
				else
					surf.buffer[((j - 1) * surf.width + px) * 3 - 2] = lines[j]:sub(i, i)
					surf.buffer[((j - 1) * surf.width + px) * 3 - 1] = backcolor
					surf.buffer[((j - 1) * surf.width + px) * 3] = textcolor
					px = px + 1
				end
				i = i + 1
			end
		end
		return surf
	elseif lines[1]:byte(1) == 95 then
		return loadString(lines[1])
	else
		local width = 0
		for i=1,#lines do
			if #lines[i] > width then
				width = #lines[i]
			end
		end
		local surf, color = create(width, height)
		for j=1,height do
			for i=1,width do
				color = tonumber(lines[j]:sub(i, i), 16)
				if color then
					surf.buffer[((j - 1) * surf.width + i) * 3 - 1] = 2 ^ color
				end
			end
		end
		return surf
	end
end

function loadString(str)
	local width, height, n = tonumber(str:sub(2, 5), 16), tonumber(str:sub(6, 9), 16), 10
	local surf = create(width, height)
	for j=1,height do
		for i=1,width do
			if str:byte(n) ~= 95 then
				surf.buffer[((j - 1) * surf.width + i) * 3 - 2] = string.char(tonumber(str:sub(n, n + 1), 16))
			end
			if str:byte(n + 2) ~= 95 then
				surf.buffer[((j - 1) * surf.width + i) * 3 - 1] = 2 ^ tonumber(str:sub(n + 2, n + 2), 16)
			end
			if str:byte(n + 3) ~= 95 then
				surf.buffer[((j - 1) * surf.width + i) * 3] = 2 ^ tonumber(str:sub(n + 3, n + 3), 16)
			end
			n = n + 4
		end
	end
	return surf
end",
  7. [ "cobalt-ui/elements/button.lua" ] = "bG9jYWwgYnV0dG9uID0gewoJeCA9IDEsCgl5ID0gMSwKCXcgPSAxMSwKCWggPSAyLAoJdGV4dCA9ICJBIGJ1dHRvbiIsCgliYWNrQ29sb3VyID0gY29sb3Vycy5jeWFuLAoJZm9yZUNvbG91ciA9IGNvbG91cnMud2hpdGUsCglzZWxlY3RlZCA9IGZhbHNlLAoJdmlzaWJsZSA9IHRydWUsCgl0eXBlID0gImJ1dHRvbiIsCgltYXJnaW5sZWZ0ID0gMCwKCW1hcmdpbnJpZ2h0ID0gMCwKCW1hcmdpbnRvcCA9IDAsCgltYXJnaW5ib3R0b20gPSAwLAoJYXV0b21sID0gIiIsCglhdXRvbXIgPSAiIiwKCWF1dG9tdCA9ICIiLAoJYXV0b21iID0gIiIsCglhdXRvdyA9ICJwZXJjOjUwIiwKCXdyYXAgPSAibGVmdCIsCglhdXRvaCA9IHRydWUsCn0KYnV0dG9uLl9faW5kZXggPSBidXR0b24KCmZ1bmN0aW9uIGJ1dHRvbjpnZXRQZXJjZW50YWdlcygpCglpZiB0eXBlKHNlbGYudykgPT0gInN0cmluZyIgdGhlbgoJCXNlbGYudyA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLncgKQoJCXNlbGYuYXV0b3cgPSAicGVyYzoiIC4uIHNlbGYudwoJZWxzZQoJCXNlbGYuYXV0b3cgPSAibm9uZSIKCWVuZAoJaWYgdHlwZShzZWxmLmgpID09ICJzdHJpbmciIHRoZW4KCQlzZWxmLmggPSBjb2JhbHQuZ2V0UGVyY2VudGFnZSggc2VsZi5oICkKCQlzZWxmLmF1dG9oID0gInBlcmM6IiAuLiBzZWxmLmgKCWVsc2UKCQlzZWxmLmF1dG9oID0gIm5vbmUiCgllbmQKCglpZiB0eXBlKHNlbGYubWFyZ2lubGVmdCkgPT0gInN0cmluZyIgdGhlbgoJCXNlbGYubWFyZ2lubGVmdCA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLm1hcmdpbmxlZnQgKQoJCXNlbGYuYXV0b21sID0gInBlcmM6IiAuLiBzZWxmLm1hcmdpbmxlZnQKCWVuZAoJaWYgdHlwZShzZWxmLm1hcmdpbnJpZ2h0KSA9PSAic3RyaW5nIiB0aGVuCgkJc2VsZi5tYXJnaW5yaWdodCA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLm1hcmdpbnJpZ2h0ICkKCQlzZWxmLmF1dG9tciA9ICJwZXJjOiIgLi4gc2VsZi5tYXJnaW5yaWdodAoJZW5kCglpZiB0eXBlKHNlbGYubWFyZ2ludG9wKSA9PSAic3RyaW5nIiB0aGVuCgkJc2VsZi5tYXJnaW50b3AgPSBjb2JhbHQuZ2V0UGVyY2VudGFnZSggc2VsZi5tYXJnaW50b3AgKQoJCXNlbGYuYXV0b210ID0gInBlcmM6IiAuLiBzZWxmLm1hcmdpbnRvcAoJZW5kCglpZiB0eXBlKHNlbGYubWFyZ2luYm90dG9tKSA9PSAic3RyaW5nIiB0aGVuCgkJc2VsZi5tYXJnaW5ib3R0b20gPSBjb2JhbHQuZ2V0UGVyY2VudGFnZSggc2VsZi5tYXJnaW5ib3R0b20gKQoJCXNlbGYuYXV0b21sID0gInBlcmM6IiAuLiBzZWxmLm1hcmdpbmJvdHRvbQoJZW5kCglpZiB0eXBlKHNlbGYueCkgPT0gInN0cmluZyIgdGhlbgoJCXNlbGYueCA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLnggKQoJCXNlbGYuYXV0b3ggPSAicGVyYzoiIC4uIHNlbGYueAoJZW5kCglpZiB0eXBlKHNlbGYueSkgPT0gInN0cmluZyIgdGhlbgoJCXNlbGYueSA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLnkgKQoJCXNlbGYuYXV0b3kgPSAicGVyYzoiIC4uIHNlbGYueQoJZW5kCmVuZAoKZnVuY3Rpb24gYnV0dG9uLm5ldyggZGF0YSwgcGFyZW50ICkKCWRhdGEgPSBkYXRhIG9yIHsgfQoJaWYgZGF0YS5zdHlsZSB0aGVuCgkJbG9jYWwgdCA9IGRhdGEuc3R5bGUKCQlmb3IgaywgdiBpbiBwYWlycyggdCApIGRvCgkJCWlmIG5vdCBkYXRhW2tdIHRoZW4KCQkJCWRhdGFba10gPSB2CgkJCWVuZAoJCWVuZAoJCWRhdGEuc3R5bGUgPSBuaWwKCWVuZAoJbG9jYWwgc2VsZiA9IHNldG1ldGF0YWJsZShkYXRhLGJ1dHRvbikKCXNlbGYucGFyZW50ID0gcGFyZW50CglzZWxmOmdldFBlcmNlbnRhZ2VzKCkKCXNlbGY6cmVzaXplKCkKCXNlbGYuc3RhdGUgPSBkYXRhLnN0YXRlIG9yIHBhcmVudC5zdGF0ZQoJdGFibGUuaW5zZXJ0KCBwYXJlbnQuY2hpbGRyZW4sIHNlbGYgKQoJcmV0dXJuIHNlbGYKZW5kCgpmdW5jdGlvbiBidXR0b246c2V0TWFyZ2lucyggdCwgciwgYiwgbCApCglpZiB0IHRoZW4KCQlzZWxmLm1hcmdpbnRvcCA9IHQgb3Igc2VsZi5tYXJnaW50b3AKCQlpZiB0eXBlKHQpID09ICJzdHJpbmciIHRoZW4KCQkJc2VsZjpnZXRQZXJjZW50YWdlcygpCgkJZWxzZQoJCQlzZWxmLmF1dG9tdCA9ICJub25lIgoJCWVuZAoJZW5kCglpZiByIHRoZW4KCQlzZWxmLm1hcmdpbnJpZ2h0ID0gciBvciBzZWxmLm1hcmdpbnJpZ2h0CgkJaWYgdHlwZShyKSA9PSAic3RyaW5nIiB0aGVuCgkJCXNlbGY6Z2V0UGVyY2VudGFnZXMoKQoJCWVsc2UKCQkJc2VsZi5hdXRvbXIgPSAibm9uZSIKCQllbmQKCWVuZAoJaWYgYiB0aGVuCgkJc2VsZi5tYXJnaW50b3AgPSBiIG9yIHNlbGYubWFyZ2ludG9wCgkJaWYgdHlwZShiKSA9PSAic3RyaW5nIiB0aGVuCgkJCXNlbGY6Z2V0UGVyY2VudGFnZXMoKQoJCWVsc2UKCQkJc2VsZi5hdXRvbWIgPSAibm9uZSIKCQllbmQKCWVuZAoJaWYgbCB0aGVuCgkJc2VsZi5tYXJnaW5sZWZ0ID0gbCBvciBzZWxmLm1hcmdpbmxlZnQKCQlpZiB0eXBlKGwpID09ICJzdHJpbmciIHRoZW4KCQkJc2VsZjpnZXRQZXJjZW50YWdlcygpCgkJZWxzZQoJCQlzZWxmLmF1dG9tbCA9ICJub25lIgoJCWVuZAoJZW5kCglzZWxmOnJlc2l6ZSgpCmVuZAoKZnVuY3Rpb24gYnV0dG9uOnJlc2l6ZSggdywgaCApCglpZiB3IHRoZW4KCQlzZWxmLncgPSB3IG9yIHNlbGYudwoJCWlmIHR5cGUoIHNlbGYudyApID09ICJzdHJpbmciIHRoZW4KCQkJc2VsZjpnZXRQZXJjZW50YWdlcygpCgkJZWxzZQoJCQlzZWxmLmF1dG93ID0gIm5vbmUiCgkJZW5kCgllbmQKCWlmIGggdGhlbgoJCXNlbGYuaCA9IGggb3Igc2VsZi5oCgkJaWYgdHlwZSggc2VsZi5oICkgPT0gInN0cmluZyIgdGhlbgoJCQlzZWxmOmdldFBlcmNlbnRhZ2VzKCkKCQllbHNlCgkJCXNlbGYuYXV0b2ggPSAibm9uZSIKCQllbmQKCWVuZAoJaWYgc2VsZi5hdXRvdzpzdWIoIDEsIDQgKSA9PSAicGVyYyIgdGhlbgoJCWxvY2FsIHBlcmMgPSBzZWxmLmF1dG93Om1hdGNoKCJwZXJjOiglZCspIikKCQljb2JhbHQuc2V0UGVyY2VudGFnZSggcGVyYyApCgkJc2VsZi53ID0gbWF0aC5jZWlsKCBzZWxmLnBhcmVudC53ICogY29iYWx0LnNldFBlcmNlbnRhZ2UoIHBlcmMgKSApCgllbmQKCWlmIHNlbGYuYXV0b21sOnN1YiggMSwgNCApID09ICJwZXJjIiB0aGVuCgkJbG9jYWwgcGVyYyA9IHNlbGYuYXV0b21sOm1hdGNoKCJwZXJjOiglZCspIikKCQlzZWxmLm1hcmdpbmxlZnQgPSBtYXRoLmZsb29yKCBzZWxmLnBhcmVudC53ICogY29iYWx0LnNldFBlcmNlbnRhZ2UoIHBlcmMgKSApCgllbmQKCWlmIHNlbGYuYXV0b21yOnN1YiggMSwgNCApID09ICJwZXJjIiB0aGVuCgkJbG9jYWwgcGVyYyA9IHNlbGYuYXV0b21yOm1hdGNoKCJwZXJjOiglZCspIikKCQlzZWxmLm1hcmdpbnJpZ2h0ID0gbWF0aC5mbG9vciggc2VsZi5wYXJlbnQudyAqIGNvYmFsdC5zZXRQZXJjZW50YWdlKCBwZXJjICkgKQoJZW5kCglpZiBzZWxmLmF1dG9tdDpzdWIoIDEsIDQgKSA9PSAicGVyYyIgdGhlbgoJCWxvY2FsIHBlcmMgPSBzZWxmLmF1dG9tdDptYXRjaCgicGVyYzooJWQrKSIpCgkJc2VsZi5tYXJnaW50b3AgPSBtYXRoLmZsb29yKCBzZWxmLnBhcmVudC5oICogY29iYWx0LnNldFBlcmNlbnRhZ2UoIHBlcmMgKSApCgllbmQKCWlmIHNlbGYuYXV0b21iOnN1YiggMSwgNCApID09ICJwZXJjIiB0aGVuCgkJbG9jYWwgcGVyYyA9IHNlbGYuYXV0b21iOm1hdGNoKCJwZXJjOiglZCspIikKCQlzZWxmLm1hcmdpbmJvdHRvbSA9IG1hdGguZmxvb3IoIHNlbGYucGFyZW50LmggKiBjb2JhbHQuc2V0UGVyY2VudGFnZSggcGVyYyApICkKCWVuZAoJaWYgc2VsZi5hdXRveCBhbmQgc2VsZi5hdXRveDpzdWIoIDEsIDQgKSA9PSAicGVyYyIgdGhlbgoJCWxvY2FsIHBlcmMgPSBzZWxmLmF1dG94Om1hdGNoKCJwZXJjOiglZCspIikKCQlzZWxmLnggPSBtYXRoLmZsb29yKCBzZWxmLnBhcmVudC53ICogY29iYWx0LnNldFBlcmNlbnRhZ2UoIHBlcmMgKSApCgllbmQKCWlmIHNlbGYuYXV0b3kgYW5kIHNlbGYuYXV0b3k6c3ViKCAxLCA0ICkgPT0gInBlcmMiIHRoZW4KCQlsb2NhbCBwZXJjID0gc2VsZi5hdXRveTptYXRjaCgicGVyYzooJWQrKSIpCgkJc2VsZi55ID0gbWF0aC5mbG9vciggc2VsZi5wYXJlbnQuaCAqIGNvYmFsdC5zZXRQZXJjZW50YWdlKCBwZXJjICkgKQoJZW5kCmVuZAoKZnVuY3Rpb24gYnV0dG9uOmdldEFic1goKQoJcmV0dXJuIG1hdGguZmxvb3Ioc2VsZi54ICsgc2VsZi5wYXJlbnQ6Z2V0QWJzWCgpICsgc2VsZi5tYXJnaW5sZWZ0KS0xCmVuZAoKZnVuY3Rpb24gYnV0dG9uOmdldEFic1koKQoJcmV0dXJuIG1hdGguZmxvb3Ioc2VsZi55ICsgc2VsZi5wYXJlbnQ6Z2V0QWJzWSgpICsgc2VsZi5tYXJnaW50b3ApLTEKZW5kCgpmdW5jdGlvbiBidXR0b246ZHJhdygpCglpZiBzZWxmLnN0YXRlID09IGNvYmFsdC5zdGF0ZSBvciBzZWxmLnN0YXRlID09ICJfQUxMIiBhbmQgc2VsZi52aXNpYmxlIHRoZW4KCQlsb2NhbCBjb2xvdXIgPSBzZWxmLmJhY2tDb2xvdXIKCQlpZiBzZWxmLndyYXAgPT0gImNlbnRlciIgdGhlbgoJCQlzZWxmLnggPSBtYXRoLmNlaWwoIChzZWxmLnBhcmVudC53LzIpLXNlbGYudy8yICsgc2VsZi5tYXJnaW5sZWZ0ICkKCQllbmQKCQlpZiBzZWxmLnNlbGVjdGVkIHRoZW4KCQkJY29sb3VyID0gY29iYWx0LmcubGlnaHRlbiggc2VsZi5iYWNrQ29sb3VyICkKCQllbmQKCQlpZiBzZWxmLmggPT0gMSB0aGVuCgkJCXNlbGYucGFyZW50LnN1cmY6ZHJhd0xpbmUoIHNlbGYueCArIHNlbGYubWFyZ2lubGVmdCwgc2VsZi55KzEgKyBzZWxmLm1hcmdpbnRvcCwgc2VsZi54ICsgc2VsZi53K3NlbGYubWFyZ2lubGVmdCwgc2VsZi55KzEsICIgIiwgY29sb3VyLCBzZWxmLmZvcmVDb2xvdXIgKQoJCWVsc2UKCQkJc2VsZi5wYXJlbnQuc3VyZjpmaWxsUmVjdCggc2VsZi54ICsgc2VsZi5tYXJnaW5sZWZ0LCBzZWxmLnkgKyBzZWxmLm1hcmdpbnRvcCwgc2VsZi54ICsgc2VsZi53K3NlbGYubWFyZ2lubGVmdCwgc2VsZi55ICsgc2VsZi5oLCAiICIsIGNvbG91ciwgc2VsZi5mb3JlQ29sb3VyICkKCQllbmQKCQlzZWxmLnBhcmVudC5zdXJmOmRyYXdUZXh0KCBzZWxmLngrbWF0aC5jZWlsKChzZWxmLncvMiktI3NlbGYudGV4dC8yICsgIHNlbGYubWFyZ2lubGVmdCksIG1hdGguY2VpbChzZWxmLnkrc2VsZi5oLzIpKyBzZWxmLm1hcmdpbnRvcCwgc2VsZi50ZXh0LCBjb2xvdXIsIHNlbGYuZm9yZUNvbG91ciApCgllbmQKZW5kCgpmdW5jdGlvbiBidXR0b246bW91c2VwcmVzc2VkKCB4LCB5LCBidXR0b24gKQoJaWYgc2VsZi5zdGF0ZSA9PSBjb2JhbHQuc3RhdGUgb3Igc2VsZi5zdGF0ZSA9PSAiX0FMTCIgYW5kIHNlbGYudmlzaWJsZSB0aGVuCgkJaWYgYnV0dG9uID09IDEgdGhlbgoJCQlpZiB4ID49IHNlbGY6Z2V0QWJzWCgpIGFuZCB4IDw9IHNlbGY6Z2V0QWJzWCgpICsgc2VsZi53IGFuZCB5ID49IHNlbGY6Z2V0QWJzWSgpIGFuZCB5IDw9IHNlbGY6Z2V0QWJzWSgpICsgc2VsZi5oIHRoZW4KCQkJCXNlbGYuc2VsZWN0ZWQgPSB0cnVlCgkJCWVuZAoJCWVuZAoJZW5kCmVuZAoKZnVuY3Rpb24gYnV0dG9uOm1vdXNlcmVsZWFzZWQoIHgsIHksIGJ1dHRvbiApCglpZiBzZWxmLnN0YXRlID09IGNvYmFsdC5zdGF0ZSBvciBzZWxmLnN0YXRlID09ICJfQUxMIiBhbmQgc2VsZi52aXNpYmxlIHRoZW4KCQlpZiBidXR0b24gPT0gMSBhbmQgeCA+PSBzZWxmOmdldEFic1goKSBhbmQgeCA8PSBzZWxmOmdldEFic1goKSArIHNlbGYudyBhbmQgeSA+PSBzZWxmOmdldEFic1koKSBhbmQgeSA8PSBzZWxmOmdldEFic1koKSArIHNlbGYuaCB0aGVuCgkJCWlmIHNlbGYuc2VsZWN0ZWQgdGhlbgoJCQkJaWYgc2VsZi5vbmNsaWNrIHRoZW4KCQkJCQlzZWxmLm9uY2xpY2soKQoJCQkJZW5kCgkJCQlzZWxmLnNlbGVjdGVkID0gZmFsc2UKCQkJZW5kCgkJZWxzZQoJCQlzZWxmLnNlbGVjdGVkID0gZmFsc2UKCQllbmQKCWVuZAplbmQKCnJldHVybiBidXR0b24=",
  8. [ "cobalt-ui/elements/input.lua" ] = "bG9jYWwgaW5wdXQgPSB7Cgl4ID0gMSwKCXkgPSAxLAoJdyA9IDI1LAoJYmFja1Bhc3NpdmVDb2xvdXIgPSBjb2xvdXJzLndoaXRlLAoJYmFja0FjdGl2ZUNvbG91ciA9IGNvbG91cnMud2hpdGUsCglmb3JlUGFzc2l2ZUNvbG91ciA9IGNvbG91cnMubGlnaHRHcmV5LAoJZm9yZUFjdGl2ZUNvbG91ciA9IGNvbG91cnMuYmxhY2ssCglwbGFjZWhvbGRlckNvbG91ciA9IGNvbG91cnMubGlnaHRHcmV5LAoJcGxhY2Vob2xkZXIgPSAiIiwKCXRleHQgPSAiIiwKCW1hc2sgPSAiIiwKCWFjdGl2ZSA9IGZhbHNlLAoJdGltZXIgPSAwLAoJZmxhc2ggPSBmYWxzZSwKCXR5cGUgPSAiaW5wdXQiLAoJYXV0b3ggPSAiIiwKCWF1dG95ID0gIiIsCglhdXRvbWwgPSAiIiwKCWF1dG9tdCA9ICIiLAoJYXV0b3cgPSAiIiwKCW1hcmdpbmxlZnQgPSAwLAoJbWFyZ2ludG9wID0gMCwKCW1heGxlbmd0aCA9IC0xLAoJcG9zID0gMSwKCXNjcm9sbCA9IDAsCglkcmF3eCA9IDAsCn0KaW5wdXQuX19pbmRleCA9IGlucHV0CgpmdW5jdGlvbiBpbnB1dDpnZXRQZXJjZW50YWdlcygpCglpZiB0eXBlKHNlbGYudykgPT0gInN0cmluZyIgdGhlbgoJCXNlbGYudyA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLncgKQoJCXNlbGYuYXV0b3cgPSAicGVyYzoiIC4uIHNlbGYudwoJZW5kCglpZiB0eXBlKHNlbGYubWFyZ2lubGVmdCkgPT0gInN0cmluZyIgdGhlbgoJCXNlbGYubWFyZ2lubGVmdCA9IGNvYmFsdC5nZXRQZXJjZW50YWdlKCBzZWxmLm1hcmdpbmxlZnQgKQoJCXNlbGYuYXV0b21sID0gInBlcmM6IiAuLiBzZWxmLm1hcmdpbmxlZnQKCWVuZAoJaWYgdHlwZShzZWxmLm1hcmdpbnRvcCkgPT0gInN0cmluZyIgdGhlbgoJCXNlbGYubWFyZ2ludG9wID0gY29iYWx0LmdldFBlcmNlbnRhZ2UoIHNlbGYubWFyZ2ludG9wICkKCQlzZWxmLmF1dG9tdCA9ICJwZXJjOiIgLi4gc2VsZi5tYXJnaW50b3AKCWVuZAoJaWYgdHlwZShzZWxmLngpID09ICJzdHJpbmciIHRoZW4KCQlzZWxmLnggPSBjb2JhbHQuZ2V0UGVyY2VudGFnZSggc2VsZi54ICkKCQlzZWxmLmF1dG94ID0gInBlcmM6IiAuLiBzZWxmLngKCWVuZAoJaWYgdHlwZShzZWxmLnkpID09ICJzdHJpbmciIHRoZW4KCQlzZWxmLnkgPSBjb2JhbHQuZ2V0UGVyY2VudGFnZSggc2VsZi55ICkKCQlzZWxmLmF1dG95ID0gInBlcmM6IiAuLiBzZWxmLnkKCWVuZAplbmQKCmZ1bmN0aW9uIGlucHV0Lm5ldyggZGF0YSwgcGFyZW50ICkKCWRhdGEgPSBkYXRhIG9yIHsgfQoJaWYgZGF0YS5zdHlsZSB0aGVuCgkJbG9jYWwgdCA9IGRhdGEuc3R5bGUKCQlmb3IgaywgdiBpbiBwYWlycyggdCApIGRvCgkJCWlmIG5vdCBkYXRhW2tdIHRoZW4KCQkJCWRhdGFba10gPSB2CgkJCWVuZAoJCWVuZAoJCWRhdGEuc3R5bGUgPSBuaWwKCWVuZAoJbG9jYWwgc2VsZiA9IHNldG1ldGF0YWJsZShkYXRhLGlucHV0KQoJc2VsZi5wYXJlbnQgPSBwYXJlbnQKCXNlbGY6Z2V0UGVyY2VudGFnZXMoKQoJc2VsZjpyZXNpemUoKQoJc2VsZi5zdGF0ZSA9IGRhdGEuc3RhdGUgb3IgcGFyZW50LnN0YXRlCgl0YWJsZS5pbnNlcnQoIHBhcmVudC5jaGlsZHJlbiwgc2VsZiApCglyZXR1cm4gc2VsZgplbmQKCmZ1bmN0aW9uIGlucHV0OnJlc2l6ZSgpCglpZiBzZWxmLmF1dG93OnN1YiggMSwgNCApID09ICJwZXJjIiB0aGVuCgkJbG9jYWwgcGVyYyA9IHNlbGYuYXV0b3c6bWF0Y2goInBlcmM6KCVkKykiKQoJCWNvYmFsdC5zZXRQZXJjZW50YWdlKCBwZXJjICkKCQlzZWxmLncgPSBtYXRoLmNlaWwoIHNlbGYucGFyZW50LncgKiBjb2JhbHQuc2V0UGVyY2VudGFnZSggcGVyYyApICkKCWVuZAoJaWYgc2VsZi5hdXRvbWw6c3ViKCAxLCA0ICkgPT0gInBlcmMiIHRoZW4KCQlsb2NhbCBwZXJjID0gc2VsZi5hdXRvbWw6bWF0Y2goInBlcmM6KCVkKykiKQoJCXNlbGYubWFyZ2lubGVmdCA9IG1hdGguZmxvb3IoIHNlbGYucGFyZW50LncgKiBjb2JhbHQuc2V0UGVyY2VudGFnZSggcGVyYyApICkKCWVuZAoJaWYgc2VsZi5hdXRvbXQ6c3ViKCAxLCA0ICkgPT0gInBlcmMiIHRoZW4KCQlsb2NhbCBwZXJjID0gc2VsZi5hdXRvbXQ6bWF0Y2goInBlcmM6KCVkKykiKQoJCXNlbGYubWFyZ2ludG9wID0gbWF0aC5jZWlsKCBzZWxmLnBhcmVudC5oICogY29iYWx0LnNldFBlcmNlbnRhZ2UoIHBlcmMgKSApLTEKCWVuZAoJaWYgc2VsZi5hdXRveCBhbmQgc2VsZi5hdXRveDpzdWIoIDEsIDQgKSA9PSAicGVyYyIgdGhlbgoJCWxvY2FsIHBlcmMgPSBzZWxmLmF1dG94Om1hdGNoKCJwZXJjOiglZCspIikKCQlzZWxmLnggPSBtYXRoLmZsb29yKCBzZWxmLnBhcmVudC53ICogY29iYWx0LnNldFBlcmNlbnRhZ2UoIHBlcmMgKSApCgllbmQKCWlmIHNlbGYuYXV0b3kgYW5kIHNlbGYuYXV0b3k6c3ViKCAxLCA0ICkgPT0gInBlcmMiIHRoZW4KCQlsb2NhbCBwZXJjID0gc2VsZi5hdXRveTptYXRjaCgicGVyYzooJWQrKSIpCgkJc2VsZi55ID0gbWF0aC5mbG9vciggc2VsZi5wYXJlbnQuaCAqIGNvYmFsdC5zZXRQZXJjZW50YWdlKCBwZXJjICkgKQoJZW5kCmVuZAoKZnVuY3Rpb24gaW5wdXQ6c2V0TWFyZ2lucyggdCwgciwgYiwgbCApCglpZiB0IHRoZW4KCQlzZWxmLm1hcmdpbnRvcCA9IHQgb3Igc2VsZi5tYXJnaW50b3AKCQlpZiB0eXBlKHQpID09ICJzdHJpbmciIHRoZW4KCQkJc2VsZjpnZXRQZXJjZW50YWdlcygpCgkJZWxzZQoJCQlzZWxmLmF1dG9tdCA9ICJub25lIgoJCWVuZAoJZW5kCglpZiByIHRoZW4KCQlzZWxmLm1hcmdpbnJpZ2h0ID0gciBvciBzZWxmLm1hcmdpbnJpZ2h0CgkJaWYgdHlwZShyKSA9PSAic3RyaW5nIiB0aGVuCgkJCXNlbGY6Z2V0UGVyY2VudGFnZXMoKQoJCWVsc2UKCQkJc2VsZi5hdXRvbXIgPSAibm9uZSIKCQllbmQKCWVuZAoJaWYgYiB0aGVuCgkJc2VsZi5tYXJnaW50b3AgPSBiIG9yIHNlbGYubWFyZ2ludG9wCgkJaWYgdHlwZShiKSA9PSAic3RyaW5nIiB0aGVuCgkJCXNlbGY6Z2V0UGVyY2VudGFnZXMoKQoJCWVsc2UKCQkJc2VsZi5hdXRvbWIgPSAibm9uZSIKCQllbmQKCWVuZAoJaWYgbCB0aGVuCgkJc2VsZi5tYXJnaW5sZWZ0ID0gbCBvciBzZWxmLm1hcmdpbmxlZnQKCQlpZiB0eXBlKGwpID09ICJzdHJpbmciIHRoZW4KCQkJc2VsZjpnZXRQZXJjZW50YWdlcygpCgkJZWxzZQoJCQlzZWxmLmF1dG9tbCA9ICJub25lIgoJCWVuZAoJZW5kCglzZWxmOnJlc2l6ZSgpCmVuZAoKZnVuY3Rpb24gaW5wdXQ6Z2V0QWJzWCgpCglyZXR1cm4gc2VsZi54ICsgc2VsZi5wYXJlbnQ6Z2V0QWJzWCgpLTEgKyBzZWxmLm1hcmdpbmxlZnQKZW5kCgpmdW5jdGlvbiBpbnB1dDpnZXRBYnNZKCkKCXJldHVybiBzZWxmLnkgKyBtYXRoLmZsb29yKHNlbGYucGFyZW50OmdldEFic1koKSktMSArIHNlbGYubWFyZ2ludG9wCmVuZAoKZnVuY3Rpb24gaW5wdXQ6dXBkYXRlKCBkdCApCglpZiBzZWxmLmFjdGl2ZSB0aGVuCgkJc2VsZi50aW1lciA9IHNlbGYudGltZXIgKyAwLjEKCQlpZiBzZWxmLnRpbWVyID4gMC41IHRoZW4KCQkJc2VsZi50aW1lciA9IDAKCQkJc2VsZi5mbGFzaCA9IG5vdCBzZWxmLmZsYXNoCgkJZW5kCgllbHNlCgkJc2VsZi5mbGFzaCA9IGZhbHNlCgllbmQKZW5kCgpmdW5jdGlvbiBpbnB1dDpkcmF3KCkKCgoJaWYgc2VsZi5zdGF0ZSA9PSBjb2JhbHQuc3RhdGUgb3Igc2VsZi5zdGF0ZSA9PSAiX0FMTCIgdGhlbgoJCWxvY2FsIGJjID0gc2VsZi5iYWNrUGFzc2l2ZUNvbG91cgoJCWxvY2FsIGZjID0gc2VsZi5mb3JlUGFzc2l2ZUNvbG91cgoJCWlmIHNlbGYuYWN0aXZlIHRoZW4KCQkJYmMgPSBzZWxmLmJhY2tBY3RpdmVDb2xvdXIKCQkJZmMgPSBzZWxmLmZvcmVBY3RpdmVDb2xvdXIKCQllbmQKCQlzZWxmLnBhcmVudC5zdXJmOmRyYXdMaW5lKCBtYXRoLmZsb29yKHNlbGYueCArIHNlbGYubWFyZ2lubGVmdCksIG1hdGguZmxvb3Ioc2VsZi55ICsgc2VsZi5tYXJnaW50b3ApLCBtYXRoLmZsb29yKHNlbGYueCArIHNlbGYubWFyZ2lubGVmdCkgKyBzZWxmLncsIG1hdGguZmxvb3Ioc2VsZi55ICsgc2VsZi5tYXJnaW50b3ApLCAiICIsIGJjLCBmYyApCgkJbG9jYWwgdCA9IHNlbGYudGV4dAoJCWlmICNzZWxmLnRleHQgPiBzZWxmLnctMSB0aGVuCgkJCXQgPSBzZWxmLnRleHQ6c3ViKCAjc2VsZi50ZXh0LXNlbGYudysxLCAjc2VsZi50ZXh0ICkKCQllbmQKCQlpZiAjc2VsZi50ZXh0ID4gMCB0aGVuCgkJCWlmIHNlbGYubWFzayB+PSAiIiAgdGhlbgoJCQkJbG9jYWwgbXNrc3RyID0gIiIKCQkJCWZvciBpID0gMSwgI3NlbGYudGV4dCBkbwoJCQkJCW1za3N0ciA9IG1za3N0ciAuLiBzZWxmLm1hc2sKCQkJCWVuZAoJCQkJc2VsZi5wYXJlbnQuc3VyZjpkcmF3VGV4dCggbWF0aC5mbG9vcihzZWxmLngrIHNlbGYubWFyZ2lubGVmdCksIG1hdGguZmxvb3Ioc2VsZi55KyBzZWxmLm1hcmdpbnRvcCksIG1za3N0ciwgYmMsIGZjICkKCQkJZWxzZQoJCQkJc2VsZi5wYXJlbnQuc3VyZjpkcmF3VGV4dCggbWF0aC5mbG9vcihzZWxmLngrIHNlbGYubWFyZ2lubGVmdCksIG1hdGguZmxvb3Ioc2VsZi55KyBzZWxmLm1hcmdpbnRvcCksIHQsIGJjLCBmYyApCgkJCWVuZAoJCWVsc2UKCQkJaWYgbm90IHNlbGYuYWN0aXZlIHRoZW4KCQkJCXNlbGYucGFyZW50LnN1cmY6ZHJhd1RleHQoIG1hdGguZmxvb3Ioc2VsZi54KyBzZWxmLm1hcmdpbmxlZnQpLCBtYXRoLmZsb29yKHNlbGYueSsgc2VsZi5tYXJnaW50b3ApLCBzZWxmLnBsYWNlaG9sZGVyLCBiYywgc2VsZi5wbGFjaG9sZGVyQ29sb3VyICkKCQkJZW5kCgkJZW5kCgkJaWYgc2VsZi5mbGFzaCBhbmQgc2VsZi5hY3RpdmUgdGhlbgoJCQlzZWxmLnBhcmVudC5zdXJmOmRyYXdUZXh0KCBtYXRoLmZsb29yKHNlbGYueCsjdCtzZWxmLm1hcmdpbmxlZnQpLCBtYXRoLmZsb29yKHNlbGYueStzZWxmLm1hcmdpbnRvcCksICJfIiwgYmMsIGZjICkKCQllbmQKCWVuZAplbmQKCmZ1bmN0aW9uIGlucHV0Om1vdXNlcHJlc3NlZCggeCwgeSwgYnV0dG9uICkKCWlmIGJ1dHRvbiA9PSAxIGFuZCB4ID49IHNlbGY6Z2V0QWJzWCgpIGFuZCB4IDw9IHNlbGY6Z2V0QWJzWCgpICsgc2VsZi53IGFuZCB5ID09IHNlbGY6Z2V0QWJzWSgpIHRoZW4KCQlzZWxmLmFjdGl2ZSA9IHRydWUKCWVuZAplbmQKCgpmdW5jdGlvbiBpbnB1dDptb3VzZXJlbGVhc2VkKCB4LCB5LCBidXR0b24gKQoJaWYgYnV0dG9uID09IDEgYW5kIHggPj0gc2VsZjpnZXRBYnNYKCkgYW5kIHggPD0gc2VsZjpnZXRBYnNYKCkgKyBzZWxmLncgYW5kIHkgPT0gc2VsZjpnZXRBYnNZKCkgdGhlbgoJCS0tCgllbHNlCgkJc2VsZi5hY3RpdmUgPSBmYWxzZQoJZW5kCmVuZAoKZnVuY3Rpb24gaW5wdXQ6a2V5cHJlc3NlZCgga2V5Y29kZSwga2V5ICkKCWlmIHNlbGYuYWN0aXZlIHRoZW4KCQlpZiBzZWxmLnN0YXRlID09IGNvYmFsdC5zdGF0ZSBvciBzZWxmLnN0YXRlID09ICJfQUxMIiB0aGVuCgkJCXNlbGYudGltZXIgPSAwCgkJCXNlbGYuZmxhc2ggPSB0cnVlCgkJCWlmIGtleWNvZGUgPT0gMTQgdGhlbgoJCQkJc2VsZi50ZXh0ID0gc2VsZi50ZXh0OnN1YigxLCAjc2VsZi50ZXh0LTEgKQoJCQllbHNlaWYga2V5Y29kZSA9PSAyMTEgdGhlbgoKCQkJZWxzZWlmIGtleWNvZGUgPT0gMjggdGhlbgoJCQkJc2VsZi5hY3RpdmUgPSBmYWxzZQoJCQkJaWYgc2VsZi5vbmNvbXBsZXRlIHRoZW4gc2VsZjpvbmNvbXBsZXRlKCkgZW5kCgkJCWVuZAoJCWVuZAoJZW5kCmVuZAoKZnVuY3Rpb24gaW5wdXQ6dGV4dGlucHV0KCB0ICkKCWlmIHNlbGYuc3RhdGUgPT0gY29iYWx0LnN0YXRlIG9yIHNlbGYuc3RhdGUgPT0gIl9BTEwiIHRoZW4KCQlpZiBzZWxmLmFjdGl2ZSBhbmQgKCNzZWxmLnRleHQgPCBzZWxmLm1heGxlbmd0aCBvciBzZWxmLm1heGxlbmd0aCA8IDApIHRoZW4KCQkJc2VsZi50ZXh0ID0gc2VsZi50ZXh0IC4uIHQKCQllbmQKCWVuZAplbmQKCnJldHVybiBpbnB1dA==",
  9. [ "cobalt-ui/elements/panel.lua" ] = "local panel = {
	x = 1,
	y = 1,
	w = 10,
	h = 5,
	backColour = colours.white,
	foreColour = colours.black,

	state = "_ALL",
	isroot = false,
	sortChildren = true,
	type = "panel",
	alwaysfocus = false,
	scrollx = 0,
	scrolly = 0,
	autosize = true,
	marginleft = 0,
	marginright = 0,
	margintop = 0,
	marginbottom = 0,
	autow = "none",
	autoh = "none",
	automl = false,
	automr = false,
	automt = false,
	automb = false,
	wrap = "left",
}
panel.__index = panel

function panel:getPercentages()
	if type(self.w) == "string" then
		self.w = cobalt.getPercentage( self.w )
		self.autow = "perc:" .. self.w
	else
		self.autow = "none"
	end
	if type(self.h) == "string" then
		self.h = cobalt.getPercentage( self.h )
		self.autoh = "perc:" .. self.h
	else
		self.autoh = "none"
	end

	if type(self.marginleft) == "string" then
		self.marginleft = cobalt.getPercentage( self.marginleft )
		self.automl = "perc:" .. self.marginleft
	end
	if type(self.marginright) == "string" then
		self.marginright = cobalt.getPercentage( self.marginright )
		self.automr = "perc:" .. self.marginright
	end
	if type(self.margintop) == "string" then
		self.margintop = cobalt.getPercentage( self.margintop )
		self.automt = "perc:" .. self.margintop
	end
	if type(self.marginbottom) == "string" then
		self.marginbottom = cobalt.getPercentage( self.marginbottom )
		self.automl = "perc:" .. self.marginbottom
	end
	if type(self.x) == "string" then
		self.x = cobalt.getPercentage( self.x )
		self.autox = "perc:" .. self.x
	end
	if type(self.y) == "string" then
		self.y = cobalt.getPercentage( self.y )
		self.autoy = "perc:" .. self.y
	end
end


function panel.new( data, parent, isroot )
	local self
	if data.style then
		local t = data.style
		for k, v in pairs( t ) do
			if not data[k] then
				data[k] = v
			end
		end
		data.style = nil
	end
	self = setmetatable(data,panel)
	if not self.isroot then self.parent = parent end
	self.children = { }

	self:getPercentages()

	self.bw = self.w
	self.bh = self.h



	if isroot then
		table.insert( cui.roots, self )
		self.isroot = true
	else
		if not parent then
			error( "Expected parent object")
		end
		table.insert( parent.children, self )
	end

	self:resize()
	return self
end

function panel:resize( w, h )
	if w then
		self.w = w or self.w
		if type( self.w ) == "string" then
			self:getPercentages()
		else
			self.autow = "none"
		end
	end
	if h then
		self.h = h or self.h
		if type( self.h ) == "string" then
			self:getPercentages()
		else
			self.autoh = "none"
		end
	end
	if self.autow:sub( 1, 4 ) == "perc" then
		local perc = self.autow:match("perc:(%d+)")
		if self.parent then
			self.w = math.ceil( self.parent.w * cobalt.setPercentage( perc ) )
		else
			self.w = math.floor((cobalt.window.getWidth()) * cobalt.setPercentage( perc ) )
		end
	end
	if self.autoh:sub( 1, 4 ) == "perc" then
		local perc = self.autoh:match("perc:(%d+)")
		if self.parent then
			self.h = math.floor( self.parent.h * cobalt.setPercentage( perc ) )
		else
			self.h = math.floor((cobalt.window.getHeight()-1) * cobalt.setPercentage( perc ) )
		end
	end
	if self.automl and self.automl:sub( 1, 4 ) == "perc" then
		local perc = self.automl:match("perc:(%d+)")
		if self.parent then
			self.marginleft = math.floor( self.parent.w * cobalt.setPercentage( perc ) )
		else
			self.marginleft = math.floor( cobalt.window.getWidth() * cobalt.setPercentage( perc ) )
		end
	end
	if self.automr and self.automr:sub( 1, 4 ) == "perc" then
		local perc = self.automr:match("perc:(%d+)")
		if self.parent then
			self.marginright = math.floor( self.parent.w * cobalt.setPercentage( perc ) )
		else
			self.marginright = math.floor( cobalt.window.getWidth() * cobalt.setPercentage( perc ) )
		end
	end
	if self.automt and self.automt:sub( 1, 4 ) == "perc" then
		local perc = self.automt:match("perc:(%d+)")
		if self.parent then
			self.margintop = math.floor( self.parent.h * cobalt.setPercentage( perc ) )
		else
			self.margintop = math.floor( cobalt.window.getHeight() * cobalt.setPercentage( perc ) )
		end
	end
	if self.automb and self.automb:sub( 1, 4 ) == "perc" then
		local perc = self.automb:match("perc:(%d+)")
		if self.parent then
			self.marginbottom = math.floor( self.parent.h * cobalt.setPercentage( perc ) )
		else
			self.marginbottom = math.floor( cobalt.window.getHeight() * cobalt.setPercentage( perc ) )
		end
	end
	if self.autox and self.autox and self.autox:sub( 1, 4 ) == "perc" then
		local perc = self.autox:match("perc:(%d+)")
		if self.parent then
			self.x = math.floor( self.parent.w * cobalt.setPercentage( perc ) )
		else
			self.x = math.floor( cobalt.window.getWidth() * cobalt.setPercentage( perc ) )
		end
	end
	if self.autoy and self.autoy and self.autoy:sub( 1, 4 ) == "perc" then
		local perc = self.autoy:match("perc:(%d+)")
		if self.parent then
			self.y = math.floor( self.parent.h * cobalt.setPercentage( perc ) )
		else
			self.y = math.floor( cobalt.window.getHeight() * cobalt.setPercentage( perc ) )
		end
	end
	if self.children then
		for i, v in pairs( self.children ) do
			v:resize()
		end
	end
	self.surf = nil
	self.surf = surface.create( self.w, self.h, " ", self.backColour, self.foreColour )
end

function panel:setMargins( t, r, b, l )
	if t then
		self.margintop = t or self.margintop
		if type(t) == "string" then
			self:getPercentages()
		else
			self.automt = "none"
		end
	end
	if r then
		self.marginright = r or self.marginright
		if type(r) == "string" then
			self:getPercentages()
		else
			self.automr = "none"
		end
	end
	if b then
		self.margintop = b or self.margintop
		if type(b) == "string" then
			self:getPercentages()
		else
			self.automb = "none"
		end
	end
	if l then
		self.marginleft = l or self.marginleft
		if type(l) == "string" then
			self:getPercentages()
		else
			self.automl = "none"
		end
	end
	self:resize()
end

function panel:getAbsX()
	if not self.isroot then
		return self.x + self.parent:getAbsX()-1 + self.marginleft
	end
	return self.x + self.marginleft
end

function panel:getAbsY()
	if not self.isroot then
		return self.y + math.floor(self.parent:getAbsY())-1 + self.margintop
	end
	return self.y + self.margintop
end

function panel:getAbsW()
	return self:getAbsX() + self.w
end

function panel:getAbsH()
	return self:getAbsY() + self.h
end

function panel:setBackgroundColour( colour )
	self.backColour = colour or self.backColour
end

function panel:add( type, data )
	return cui.elements[type].new( data, self, false )
end

function panel:getCheckResults( group )
	local results = { }
	group = group or "_ALL"
	for k, v in pairs( self.children ) do
		if v.type and v.type == "checkbox" then
			if v.group == group or group == "_ALL" then
				if v.selected then
					results[#results+1] = v.val
				end
			end
		end
	end
	return results
end

function panel:getRadioResults( group )
	local results = { }
	group = group or "_ALL"
	for k, v in pairs( self.children ) do
		if v.type and v.type == "radio" then
			if v.group == group or group == "_ALL" then
				if v.selected then
					results[#results+1] = v.val
				end
			end
		end
	end
	return results
end



function panel:bringToFront()

	if self.parent and self.parent.sortChildren then
		for k, v in pairs( self.parent.children ) do
			if v == self then
				table.remove( self.parent.children, k )
				table.insert( self.parent.children, 1, v )
			end
		end
	else
		for k, v in pairs( cui.roots ) do
			if v == self then
				table.remove( cui.roots, k )
				table.insert( cui.roots, 1, v )
			end
		end
	end

end
function panel:sendToBack()

	if self.parent and self.parent.sortChildren then
		for k, v in pairs( self.parent.children ) do
			if v == self then
				table.remove( self.parent.children, k )
				table.insert( self.parent.children, #self.parent.children, v )
			end
		end
	else
		for k, v in pairs( cui.roots ) do
			if v == self then
				table.remove( cui.roots, k )
				table.insert( cui.roots, #cui.roots, v )
			end
		end
	end

end

function panel:update( dt )
	if self.w ~= self.bw then
		self.bw = self.w
		self:resize()
	end
	if self.h ~= self.bh then
		self.bh = self.h
		self:resize()
	end
	for i, v in pairs( self.children ) do
		if v.update then v:update() end
	end

end

function panel:draw( )
	if self.wrap == "center" then
		self.x = ( self.parent.w/2 - self.w/2 ) + self.marginleft
	end
	if self.state == cobalt.state or self.state == "_ALL" then
		self.surf:clear(" ", self.backColour, self.foreColour)
		for i, v in pairs( self.children ) do
			if v.draw then v:draw() end
		end
		if self.isroot then
			self.surf:render(term, self.x+self.marginleft, self.y+self.margintop, self.scrollx, self.scrolly, self.scrollx + self.w, self.scrolly+self.h)
		else
			self.parent.surf:drawSurface(self.x+self.marginleft, self.y+self.margintop, self.surf)
		end
	end
end

function panel:mousepressed( x, y, button )
	if self.alwaysfocus then
		self:bringToFront()
	end

	if self.state == cobalt.state or self.state == "_ALL" then
		if x >= self:getAbsX() and x <= self:getAbsX() + self.w and y >= self:getAbsY() and y <= self:getAbsY() + self.h then
			self:bringToFront()
			for i, v in pairs( self.children ) do
				if v.mousepressed then v:mousepressed( x, y, button ) end
			end

			return true
		end
	end
end



function panel:mousereleased( x, y, button )

	if x >= self:getAbsX() and x <= self:getAbsX() + self.w and y >= self:getAbsY() and y <= self:getAbsY() + self.h then
		if self.state == cobalt.state or self.state == "_ALL" then
			for i, v in pairs( self.children ) do
				if v.mousereleased then v:mousereleased( x, y, button ) end
			end
			return true
		end
	end
end

function panel:textinput( t )

	if self.state == cobalt.state or self.state == "_ALL" then
		--

		for k, v in pairs( self.children ) do
			if v.textinput then v:textinput( t ) end
		end
	end

end

function panel:keypressed( keycode, key )
	if self.state == cobalt.state or self.state == "_ALL" then
		for k, v in pairs( self.children ) do
			if v.keypressed then v:keypressed( keycode, key ) end
		end

	end
end

function panel:mousedrag( x, y )
	for k, v in pairs( self.children ) do
		if v.mousedrag then v:mousedrag( x, y ) end
	end
end

function panel:keyreleased( keycode, key )
	if self.state == cobalt.state or self.state == "_ALL" then

		for k, v in pairs( self.children ) do
			if v.keyreleased then v:keyreleased( keycode, key ) end
		end

	end
end

return panel",
  10. }
  11. ]] --End of bundle
  12.  
  13.  
  14. --Bundel Extraction Script version 1.0
  15.  
  16. -- BASE64 Encoding
  17.  
  18. -- Lua 5.1+ base64 v3.0 (c) 2009 by Alex Kloss <alexthkloss@web.de>
  19. -- licensed under the terms of the LGPL2
  20.  
  21. -- character table string
  22. local b='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'
  23.  
  24. -- decoding
  25. function dec(data)
  26. data = string.gsub(data, '[^'..b..'=]', '')
  27. return (data:gsub('.', function(x)
  28. if (x == '=') then return '' end
  29. local r,f='',(b:find(x)-1)
  30. for i=6,1,-1 do r=r..(f%2^i-f%2^(i-1)>0 and '1' or '0') end
  31. return r;
  32. end):gsub('%d%d%d?%d?%d?%d?%d?%d?', function(x)
  33. if (#x ~= 8) then return '' end
  34. local c=0
  35. for i=1,8 do c=c+(x:sub(i,i)=='1' and 2^(8-i) or 0) end
  36. return string.char(c)
  37. end))
  38. end
  39.  
  40. -- ACTUAL PROGRAM STARTS NOW
  41.  
  42. print("Bundel by Admicos.")
  43. print("\nExtracting bundle here.")
  44.  
  45. for name, file in pairs(textutils.unserialize(bundle)) do
  46. print("[#] Extracting " .. name)
  47.  
  48. local handle = fs.open(shell.dir() .. "/" .. name, "w")
  49. handle.write(dec(file))
  50. handle.close()
  51. end
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement