diff --git a/.drone.yml b/.drone.yml new file mode 100644 index 00000000..6fcfaf78 --- /dev/null +++ b/.drone.yml @@ -0,0 +1,69 @@ +--- +kind: pipeline +type: docker +name: default + +steps: +- name: install, build doc run scripts + image: python:3.8 + commands: + - git fetch --tags + - python setup.py install + +- name: develop + image: python:3.8 + commands: + - python setup.py develop + +- name: sdist + image: python:3.8 + commands: + - python setup.py sdist + +- name: upload to pypi + image: plugins/pypi + when: + event: tag + settings: + skip_build: True + username: dessia_tech + password: + from_secret: pypi_password + +- name: npm build + image: node + commands: + - npm install + - npm run-script build + +- name: npm build and update tag + image: node + when: + event: tag + commands: + - npm-version from-git + - npm run-script build + + +- name: upload npm + image: plugins/npm + when: + event: tag + settings: + username: dessia + password: + from_secret: npm_password + email: root@dessia.tech + +- name: notify by email + when: + status: + - failure + image: drillster/drone-email + settings: + host: mail.dessia.tech + username: technical@dessia.tech + password: + from_secret: email_password + from: technical@dessia.tech + recipients: [ root@dessia.tech ] diff --git a/.gitignore b/.gitignore new file mode 100644 index 00000000..4fc56c0d --- /dev/null +++ b/.gitignore @@ -0,0 +1,132 @@ +node_modules +/lib +# HTML files +*.html + +# CAD files +*.fcstd +*.fcstd1 +*.stl + + +# Python gitignore +# Byte-compiled / optimized / DLL files +__pycache__/ +*.py[cod] +*$py.class + +# C extensions +*.so + +# Distribution / packaging +.Python +build/ +develop-eggs/ +dist/ +downloads/ +eggs/ +.eggs/ +lib/ +lib64/ +parts/ +sdist/ +var/ +wheels/ +share/python-wheels/ +*.egg-info/ +.installed.cfg +*.egg +MANIFEST + +# PyInstaller +# Usually these files are written by a python script from a template +# before PyInstaller builds the exe, so as to inject date/other infos into it. +*.manifest +*.spec + +# Installer logs +pip-log.txt +pip-delete-this-directory.txt + +# Unit test / coverage reports +htmlcov/ +.tox/ +.nox/ +.coverage +.coverage.* +.cache +nosetests.xml +coverage.xml +*.cover +.hypothesis/ +.pytest_cache/ + +# Translations +*.mo +*.pot + +# Django stuff: +*.log +local_settings.py +db.sqlite3 + +# Flask stuff: +instance/ +.webassets-cache + +# Scrapy stuff: +.scrapy + +# Sphinx documentation +docs/_build/ + +# PyBuilder +target/ + +# Jupyter Notebook +.ipynb_checkpoints + +# IPython +profile_default/ +ipython_config.py + +# pyenv +.python-version + +# celery beat schedule file +celerybeat-schedule + +# SageMath parsed files +*.sage.py + +# Environments +.env +.venv +env/ +venv/ +ENV/ +env.bak/ +venv.bak/ + +# Spyder project settings +.spyderproject +.spyproject + +# Rope project settings +.ropeproject + +# mkdocs documentation +/site + +# mypy +.mypy_cache/ +.dmypy.json +dmypy.json + +# Pyre type checker +.pyre/ + +volmdlr/templates/core.ts + +volmdlr/core_compiled.c + diff --git a/.npmignore b/.npmignore new file mode 100644 index 00000000..ac989be1 --- /dev/null +++ b/.npmignore @@ -0,0 +1 @@ +“files”: [“lib/**/*”] diff --git a/.prettierrc b/.prettierrc new file mode 100644 index 00000000..4ddba9ab --- /dev/null +++ b/.prettierrc @@ -0,0 +1,5 @@ +{ + "printWidth": 120, + "trailingComma": "all", + "singleQuote": true +} \ No newline at end of file diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 00000000..52e80a16 --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,7 @@ +# Changelog + +All notable changes to this project will be documented in this file. + +The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), +and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). + diff --git a/ISSUE_TEMPLATE.md b/ISSUE_TEMPLATE.md new file mode 100644 index 00000000..228433d3 --- /dev/null +++ b/ISSUE_TEMPLATE.md @@ -0,0 +1,31 @@ +* **I'm submitting a ...** + - [ ] bug report + - [ ] feature request + - [ ] support request => Please do not submit support request here, see note at the top of this template. + + +* **What is the current behavior?** + + + +* **If the current behavior is a bug, please provide the steps to reproduce and if possible a minimal demo of the problem** Avoid reference to other packages + + + +* **What is the expected behavior?** + + +* **What is the motivation / use case for changing the behavior?** + + +* **Possible fixes** + + +* **Please tell us about your environment:** + + - branch: + - commit: + - python version: + + + diff --git a/README.md b/README.md index bdcf6de9..5483c987 100644 --- a/README.md +++ b/README.md @@ -1 +1,35 @@ -# plot_data \ No newline at end of file +# @dessia/plot-data + + + +![GitHub last commit](https://img.shields.io/github/last-commit/Dessia-tech/plot_data) + +## Install + +``` +npm i @dessia/plot-data +``` + +## Usage + +``` +<<<<<<< HEAD +import * as plotdata from '@natsudzn/plot-data'; +``` + +## Develop + +``` +npm i +npm run-script build +``` +======= +import * as plotdata from '@dessia/plot-data'; +``` + +## Changelog + +Check the changelog [here](CHANGELOG.md) +>>>>>>> f831483d8d375c8e8a9526e6858d582f01044851 diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 00000000..f1d3ce13 --- /dev/null +++ b/package-lock.json @@ -0,0 +1,371 @@ +{ + "name": "@dessia/plot-data", + "version": "0.1.1", + "lockfileVersion": 1, + "requires": true, + "dependencies": { + "@babel/code-frame": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.10.4.tgz", + "integrity": "sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg==", + "dev": true, + "requires": { + "@babel/highlight": "^7.10.4" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.4.tgz", + "integrity": "sha512-3U9y+43hz7ZM+rzG24Qe2mufW5KhvFg/NhnNph+i9mgCtdTCtMJuI1TMkrIUiK7Ix4PYlRF9I5dhqaLYA/ADXw==", + "dev": true + }, + "@babel/highlight": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", + "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.10.4", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + } + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dev": true, + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "balanced-match": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", + "dev": true + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "builtin-modules": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", + "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", + "dev": true + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "requires": { + "color-name": "1.1.3" + } + }, + "color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", + "dev": true + }, + "commander": { + "version": "2.20.3", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", + "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", + "dev": true + }, + "diff": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", + "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", + "dev": true + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", + "dev": true + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "dev": true + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", + "dev": true + }, + "glob": { + "version": "7.1.6", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", + "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", + "dev": true + }, + "ignore-errors": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ignore-errors/-/ignore-errors-2.0.0.tgz", + "integrity": "sha512-qTHCs4+E40EKSO3l9k3bFCRrf3SsPYt8fydN39VbJOPNo+f9dGhcvBzRw48UpnYKOMJKM3G2bGNnfHOTMSuhbg==", + "requires": { + "mem": "^6.1.0", + "mimic-fn": "^3.1.0", + "shallow-contains": "^1.0.1", + "shallowequal": "^1.1.0" + } + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "dev": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true + }, + "js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, + "js-yaml": { + "version": "3.14.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.0.tgz", + "integrity": "sha512-/4IbIeHcD9VMHFqDR/gQ7EdZdLimOvW2DdcxFjdyyZ9NsbS+ccrXqVWDtab/lRl5AlUqmpBx8EhPaWR+OtY17A==", + "dev": true, + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + } + }, + "map-age-cleaner": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/map-age-cleaner/-/map-age-cleaner-0.1.3.tgz", + "integrity": "sha512-bJzx6nMoP6PDLPBFmg7+xRKeFZvFboMrGlxmNj9ClvX53KrmvM5bXFXEWjbz4cz1AFn+jWJ9z/DJSz7hrs0w3w==", + "requires": { + "p-defer": "^1.0.0" + } + }, + "mem": { + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/mem/-/mem-6.1.1.tgz", + "integrity": "sha512-Ci6bIfq/UgcxPTYa8dQQ5FY3BzKkT894bwXWXxC/zqs0XgMO2cT20CGkOqda7gZNkmK5VP4x89IGZ6K7hfbn3Q==", + "requires": { + "map-age-cleaner": "^0.1.3", + "mimic-fn": "^3.0.0" + } + }, + "mimic-fn": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-3.1.0.tgz", + "integrity": "sha512-Ysbi9uYW9hFyfrThdDEQuykN4Ey6BuwPD2kpI5ES/nFTDn/98yxYNLZJcgUAKPT/mcrLLKaGzJR9YVxJrIdASQ==" + }, + "minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", + "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", + "dev": true + }, + "mkdirp": { + "version": "0.5.5", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", + "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", + "dev": true, + "requires": { + "minimist": "^1.2.5" + } + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "dev": true, + "requires": { + "wrappy": "1" + } + }, + "p-defer": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-defer/-/p-defer-1.0.0.tgz", + "integrity": "sha1-n26xgvbJqozXQwBKfU+WsZaw+ww=" + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", + "dev": true + }, + "path-parse": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", + "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", + "dev": true + }, + "prettier": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.1.2.tgz", + "integrity": "sha512-16c7K+x4qVlJg9rEbXl7HEGmQyZlG4R9AgP+oHKRMsMsuk8s+ATStlf1NpDqyBI1HpVyfjLOeMhH2LvuNvV5Vg==", + "dev": true + }, + "resolve": { + "version": "1.17.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.17.0.tgz", + "integrity": "sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w==", + "dev": true, + "requires": { + "path-parse": "^1.0.6" + } + }, + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", + "dev": true + }, + "shallow-contains": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/shallow-contains/-/shallow-contains-1.0.1.tgz", + "integrity": "sha512-dU/p+1aoRp8teAPIVO5IvnTKBotYwVKPAH860yEixoMkw1ZO60piLzTz+hiaZWbJWVYvh7UwkbuiQqAWMNnHig==" + }, + "shallowequal": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/shallowequal/-/shallowequal-1.1.0.tgz", + "integrity": "sha512-y0m1JoUZSlPAjXVtPPW70aZWfIL/dSP7AFkRnniLCrK/8MDKog3TySTBmckD+RObVxH0v4Tox67+F14PdED2oQ==" + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", + "dev": true + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "tslib": { + "version": "1.14.0", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.0.tgz", + "integrity": "sha512-+Zw5lu0D9tvBMjGP8LpvMb0u2WW2QV3y+D8mO6J+cNzCYIN4sVy43Bf9vl92nqFahutN0I8zHa7cc4vihIshnw==", + "dev": true + }, + "tslint": { + "version": "6.1.3", + "resolved": "https://registry.npmjs.org/tslint/-/tslint-6.1.3.tgz", + "integrity": "sha512-IbR4nkT96EQOvKE2PW/djGz8iGNeJ4rF2mBfiYaR/nvUWYKJhLwimoJKgjIFEIDibBtOevj7BqCRL4oHeWWUCg==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.0.0", + "builtin-modules": "^1.1.1", + "chalk": "^2.3.0", + "commander": "^2.12.1", + "diff": "^4.0.1", + "glob": "^7.1.1", + "js-yaml": "^3.13.1", + "minimatch": "^3.0.4", + "mkdirp": "^0.5.3", + "resolve": "^1.3.2", + "semver": "^5.3.0", + "tslib": "^1.13.0", + "tsutils": "^2.29.0" + } + }, + "tslint-config-prettier": { + "version": "1.18.0", + "resolved": "https://registry.npmjs.org/tslint-config-prettier/-/tslint-config-prettier-1.18.0.tgz", + "integrity": "sha512-xPw9PgNPLG3iKRxmK7DWr+Ea/SzrvfHtjFt5LBl61gk2UBG/DB9kCXRjv+xyIU1rUtnayLeMUVJBcMX8Z17nDg==", + "dev": true + }, + "tsutils": { + "version": "2.29.0", + "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-2.29.0.tgz", + "integrity": "sha512-g5JVHCIJwzfISaXpXE1qvNalca5Jwob6FjI4AoPlqMusJ6ftFE7IkkFoMhVLRgK+4Kx3gkzb8UZK5t5yTTvEmA==", + "dev": true, + "requires": { + "tslib": "^1.8.1" + } + }, + "typescript": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.0.3.tgz", + "integrity": "sha512-tEu6DGxGgRJPb/mVPIZ48e69xCn2yRmCgYmDugAVwmJ6o+0u1RI18eO7E7WBTLYLaEVVOhwQmcdhQHweux/WPg==", + "dev": true + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", + "dev": true + } + } +} diff --git a/package.json b/package.json new file mode 100644 index 00000000..eea1978b --- /dev/null +++ b/package.json @@ -0,0 +1,37 @@ +{ + "name": "@dessia/plot-data", + "version": "0.1.1", + "description": "", + "main": "lib/core.js", + "prepublish": "tsc", + "types": "lib/core.d.ts", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1", + "build": "tsc", + "format": "prettier --write \"src/**/*.ts\"", + "lint": "tslint -p tsconfig.json" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/Dessia-tech/plot_data.git" + }, + "keywords": [ + "dessia", + "plot-data" + ], + "author": "", + "license": "ISC", + "bugs": { + "url": "https://github.com/Dessia-tech/plot_data/issues" + }, + "homepage": "http://dessia.tech/", + "devDependencies": { + "prettier": "^2.1.2", + "tslint": "^6.1.3", + "tslint-config-prettier": "^1.18.0", + "typescript": "^4.0.3" + }, + "dependencies": { + "ignore-errors": "^2.0.0" + } +} diff --git a/plot_data/__init__.py b/plot_data/__init__.py new file mode 100644 index 00000000..e69de29b diff --git a/plot_data/plot_data.py b/plot_data/plot_data.py new file mode 100644 index 00000000..5479894d --- /dev/null +++ b/plot_data/plot_data.py @@ -0,0 +1,348 @@ +#!/usr/bin/env python3 +# -*- coding: utf-8 -*- +""" +Created on Tue Feb 28 14:07:37 2017 + +@author: steven +""" + +import math +import os +import numpy as npy + +npy.seterr(divide='raise') +import volmdlr as vm +# from itertools import permutations +import jsonschema +import json + +import matplotlib.pyplot as plt +from matplotlib.patches import Arc, FancyArrow +from mpl_toolkits.mplot3d import Axes3D +import pkg_resources +import tempfile +import webbrowser +from dessia_common import DessiaObject +from typing import TypeVar, List + +from jinja2 import Environment, PackageLoader, select_autoescape,\ + FileSystemLoader + + +class ColorMapSet(DessiaObject): + def __init__(self, value: float = None, tooltip: bool = False, + color_range: str = None, selector: bool = True, + name: str = ''): + self.selector = selector + self.color_range = color_range + self.tooltip = tooltip + self.value = value + DessiaObject.__init__(self, name=name) + + +class HatchingSet(DessiaObject): + def __init__(self, stroke_width: float = 1, hatch_spacing: float = 10, + name: str = ''): + self.stroke_width = stroke_width + self.hatch_spacing = hatch_spacing + DessiaObject.__init__(self, name=name) + + +class ColorSurfaceSet(DessiaObject): + def __init__(self, color: str = 'white', name: str = ''): + self.color = color + DessiaObject.__init__(self, name=name) + + +class PointShapeSet(DessiaObject): + def __init__(self, shape: str = 'circle', name: str = ''): + self.shape = shape + DessiaObject.__init__(self, name=name) + + +class PointSizeSet(DessiaObject): + def __init__(self, size: int, name: str = ''): + self.size = size + DessiaObject.__init__(self, name=name) + + +class PointColorSet(DessiaObject): + def __init__(self, color_fill: str, color_stroke: str, name: str = ''): + self.color_fill = color_fill + self.color_stroke = color_stroke + DessiaObject.__init__(self, name=name) + + +class WindowSizeSet(DessiaObject): + def __init__(self, width: float, height: float, name: str = ''): + self.width = width + self.height = height + DessiaObject.__init__(self, name=name) + + +class PlotDataState(DessiaObject): + def __init__(self, name: str = '', color_map: ColorMapSet = None, + hatching: HatchingSet = None, + color_surface: ColorSurfaceSet = None, + shape_set: PointShapeSet = None, + point_size: PointSizeSet = None, + point_color: PointColorSet = None, + window_size: WindowSizeSet = None, + stroke_width: float = 1, color_line: str = 'black', + marker: str = None, + dash: str = None, opacity: float = 1): + self.color_surface = color_surface + self.color_map = color_map + self.hatching = hatching + self.opacity = opacity + self.dash = dash + self.marker = marker + self.color_line = color_line + self.stroke_width = stroke_width + self.shape_set = shape_set + if self.shape_set is None: + self.shape_set = PointShapeSet(shape='circle') + self.point_size = point_size + if self.point_size is None: + self.point_size = PointSizeSet(size=2) + self.point_color = point_color + if self.point_color is None: + self.point_color = PointColorSet(color_fill='black', + color_stroke='black') + self.window_size = window_size + DessiaObject.__init__(self, name=name) + + +class PlotDataLine2D(DessiaObject): + def __init__(self, data: List[float], + plot_data_states: List[PlotDataState], + type: str = 'line', name: str = '', ): + self.data = data + self.type = type + self.plot_data_states = plot_data_states + if plot_data_states is None: + self.plot_data_states = [PlotDataState()] + DessiaObject.__init__(self, name=name) + + +class PlotDataCircle2D(DessiaObject): + def __init__(self, cx: float, cy: float, r: float, + plot_data_states: List[PlotDataState], + type: str = 'circle', name: str = '', ): + self.type = type + self.plot_data_states = plot_data_states + self.r = r + self.cy = cy + self.cx = cx + DessiaObject.__init__(self, name=name) + + +class PlotDataPoint2D(DessiaObject): + def __init__(self, cx: float, cy: float, + plot_data_states: List[PlotDataState], type: str = 'point', + name: str = '', ): + self.type = type + self.plot_data_states = plot_data_states + self.cx = cx + self.cy = cy + DessiaObject.__init__(self, name=name) + + +class PlotDataAxis(DessiaObject): + def __init__(self, nb_points_x: int, nb_points_y: int, font_size: int, + graduation_color: str, axis_color: str, + plot_data_states: List[PlotDataState], + arrow_on: bool, axis_width: float, grid_on: bool, + name: str = '', + type: str = 'axis'): + self.nb_points_x = nb_points_x + self.nb_points_y = nb_points_y + self.font_size = font_size + self.graduation_color = graduation_color + self.axis_color = axis_color + self.plot_data_states = plot_data_states + if plot_data_states is None: + self.plot_data_states = [PlotDataState()] + self.arrow_on = arrow_on + self.axis_width = axis_width + self.grid_on = grid_on + self.type = type + DessiaObject.__init__(self, name=name) + + +class PlotDataTooltip(DessiaObject): + def __init__(self, colorfill: str, text_color:str, font: str, + tp_radius: float, to_plot_list: list, + plot_data_states: List[PlotDataState], type: str = 'tooltip', + name: str = ''): + self.colorfill = colorfill + self.text_color = text_color + self.font = font + self.tp_radius = tp_radius + self.to_plot_list = to_plot_list + self.plot_data_states = plot_data_states + if plot_data_states is None: + self.plot_data_states = [PlotDataState()] + self.type = type + DessiaObject.__init__(self, name=name) + + +class PlotDataGraph2D(DessiaObject): + def __init__(self, point_list, dashline: List[float], + graph_colorstroke: str, graph_linewidth: float, display_step: float, + plot_data_states: List[PlotDataState], type: str = 'graph2D', + name: str = ''): + self.serialized_point_list = [p.to_dict() for p in point_list] + self.dashline = dashline + self.graph_colorstroke = graph_colorstroke + self.graph_linewidth = graph_linewidth + self.serialized_segments = [] + for k in range(len(point_list) -1): + data = [point_list[k].cx, point_list[k].cy, point_list[k+1].cx, point_list[k+1].cy] + segment = PlotDataLine2D(data, [PlotDataState()]) + self.serialized_segments.append(segment.to_dict()) + self.display_step = display_step + if display_step is None: + self.display_step = 1 + self.plot_data_states = plot_data_states + if plot_data_states is None: + self.plot_data_states = [PlotDataState()] + self.type = type + DessiaObject.__init__(self, name) + + +class PlotDataScatter(DessiaObject): + def __init__(self, point_list, + plot_data_states: List[PlotDataState], + type: str = 'ScatterPlot', name: str = ''): + self.serialized_point_list = [p.to_dict() for p in point_list] + self.plot_data_states = plot_data_states + if plot_data_states is None: + self.plot_data_states = [PlotDataState()] + self.type = type + DessiaObject.__init__(self, name) + + +class PlotDataArc2D(DessiaObject): + def __init__(self, cx: float, cy: float, r: float, + data: List[float], angle1: float, angle2: float, + plot_data_states: List[PlotDataState], + type: str = 'arc', name: str = '', ): + self.angle2 = angle2 + self.angle1 = angle1 + self.data = data + self.type = type + self.plot_data_states = plot_data_states + self.r = r + self.cy = cy + self.cx = cx + DessiaObject.__init__(self, name=name) + + +class PlotDataContour2D(DessiaObject): + def __init__(self, plot_data_primitives: List[float], + plot_data_states: List[PlotDataState], + type: str = 'contour', name: str = '', ): + self.plot_data_primitives = plot_data_primitives + self.type = type + self.plot_data_states = plot_data_states + DessiaObject.__init__(self, name=name) + + +color = {'black': 'k', 'blue': 'b', 'red': 'r', 'green': 'g'} + + +def plot_d3(plot_datas): + template_path = pkg_resources.resource_filename( + pkg_resources.Requirement('plot_data'), + 'plot_data/templates') + module_sequence = template_path.split('/')[:-3] + module_path = '/'.join(module_sequence) + loader = FileSystemLoader(module_path) + env = Environment(loader=loader, + autoescape=select_autoescape(['html', 'xml'])) + # env = Environment(loader=PackageLoader('plot_data', 'templates'), + # autoescape=select_autoescape(['html', 'xml'])) + template = env.get_template('python/plot_data/templates/plot_data.html') + + core_path = '/'+os.path.join(*template_path.split('/')[:-3]+['typescript', 'src', 'core.ts']) + + print(core_path) + print(template_path) + + data = [] + for d in plot_datas: + data.append(json.dumps(d)) + s = template.render(D3Data=data, core_path=core_path, template_path=template_path) + temp_file = tempfile.mkstemp(suffix='.html')[1] + + with open(temp_file, 'wb') as file: + file.write(s.encode('utf-8')) + + webbrowser.open('file://' + temp_file) + print('file://' + temp_file) + + +# def plot(plot_datas, ax=None): +# if ax is None: +# fig, ax = plt.subplots() +# ax.set_aspect('equal') +# else: +# fig = None +# +# for plot_data in plot_datas: +# if plot_data['type'] == 'line': +# style = '' +# if plot_data['dash']: +# style += '--' +# else: +# style += '-' +# style += color[plot_data['color']] +# p1, p2 = plot_data['data'][0: 2], plot_data['data'][2:] +# if plot_data['arrow']: +# ax.plot([p1[0], p2[0]], [p1[1], p2[1]], style) +# length = ((p1[0] - p2[0]) ** 2 + (p1[1] - p2[1]) ** 2) ** 0.5 +# if width is None: +# width = length / 1000. +# head_length = length / 20. +# head_width = head_length / 2. +# else: +# head_width = 2 * width +# head_length = head_width +# ax.arrow(p1[0], p1[1], +# (p2[0] - p1[0]) / length * (length - head_length), +# (p2[1] - p1[1]) / length * (length - head_length), +# head_width=head_width, fc='b', linewidth=0, +# head_length=head_length, width=width, alpha=0.3) +# else: +# ax.plot([p1[0], p2[0]], [p1[1], p2[1]], style, +# linewidth=plot_data['size']) +# +# elif plot_data['type'] == 'point': +# p1 = plot_data['data'] +# style = '' +# style += color[plot_data['color']] +# style += plot_data['marker'] +# ax.plot(p1[0], p1[1], style, linewidth=plot_data['size']) +# +# elif plot_data['type'] == 'contour': +# plot(plot_data['plot_data'], ax) +# +# elif plot_data['type'] == 'arc': +# pc = vm.Point2D((plot_data['cx'], plot_data['cy'])) +# ax.add_patch( +# Arc(pc, 2 * plot_data['r'], 2 * plot_data['r'], angle=0, +# theta1=plot_data['angle1'] * 0.5 / math.pi * 360, +# theta2=plot_data['angle2'] * 0.5 / math.pi * 360, +# color=color[plot_data['color']], +# linewidth=plot_data['size'])) +# +# elif plot_data['type'] == 'circle': +# pc = vm.Point2D((plot_data['cx'], plot_data['cy'])) +# ax.add_patch( +# Arc(pc, 2 * plot_data['r'], 2 * plot_data['r'], angle=0, +# theta1=0, +# theta2=360, +# color=color[plot_data['color']], +# linewidth=plot_data['size'])) +# return fig, ax diff --git a/plot_data/templates/js/typescript.compile.min.js b/plot_data/templates/js/typescript.compile.min.js new file mode 100644 index 00000000..c2d6e245 --- /dev/null +++ b/plot_data/templates/js/typescript.compile.min.js @@ -0,0 +1,16 @@ +/* ***************************************************************************** +Copyright (c) niu tech. All rights reserved. +Licensed under the Apache License, Version 2.0 (the "License"); you may not use +this file except in compliance with the License. You may obtain a copy of the +License at http://www.apache.org/licenses/LICENSE-2.0 + +THIS CODE IS PROVIDED *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED +WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, +MERCHANTABLITY OR NON-INFRINGEMENT. + +See the Apache Version 2.0 License for specific language governing permissions +and limitations under the License. +***************************************************************************** */ + +(function(){if(!window.console){window.console={log:function(){}}}hashCode=function(c){var d=0,b,a;if(c.length==0){return d}for(a=0;a35?String.fromCharCode(c+29):c.toString(36))};if(!''.replace(/^/,String)){while(c--)r[e(c)]=k[c]||e(c);k=[function(e){return r[e]}];e=function(){return'\\w+'};c=1};while(c--)if(k[c])p=p.replace(new RegExp('\\b'+e(c)+'\\b','g'),k[c]);return p}('1c 2c;(1b(e){1b t(e,t){1d(e&t)!=0}1b h(e){1d e}1b g(e,t){1c n="";1w(1c r=1;r<1<<31;r<<=1)if((t&r)!=0)1w(1c i in e)if(e[i]==r){n.1n>0&&(n+="|"),n+=i;1B}1d n}e.1s=t,1b(e){e.1r=[],e.1q=0,e.2Y=1,e.2R=2,e.2S=4,e.3U=8,e.6R=16,e.3H=32,e.3T=64,e.4H=8Z,e.5j=dJ,e.gz=bY,e.gB=dN,e.4N=eH,e.cZ=kJ,e.hB=lc,e.3y=lh,e.7B=lI,e.Bc=m3,e.aB=1<<17,e.mn=1<<18,e.mE=1<<19,e.6l=1<<20,e.fW=1<<21,e.7L=1<<22,e.aL=1<<23,e.3j=1<<24,e.gH=1<<25,e.aP=1<<26,e.dg=1<<27,e.dk=1<<28,e.5I=1<<29,e.8d=1<<30,e.a1=e.2R|e.gB|e.4N|e.cZ|e.hB|e.3y|e.7B|e.3j|e.gH|e.dg|e.dk|e.aP,e.8H=e.a1|e.2R|e.fW|e.7L|e.aL|e.8d,e.uK=e.4H|e.3y|e.7B}(e.1v||(e.1v={}));1c n=e.1v;(1b(e){e.1r=[],e.1q=0,e.fb=1,e.dA=2,e.d4=4,e.i0=8,e.l6=16,e.kM=32,e.kL=64,e.tu=dJ,e.tj=bY,e.kK=dN,e.kG=eH,e.5M=e.fb|e.dA|e.kM|e.kL,e.kA=e.fb|e.dA|e.d4|e.i0|e.l6|e.kK,e.p8=e.fb|e.dA,e.so=e.kM|e.dA|e.d4|e.i0|e.l6|e.kL|e.fb|e.kK,e.sk=e.kM|e.dA|e.fb|e.kL|e.kG,e.A7=e.tu|e.tj,e.sg=e.kA|e.kG})(e.4O||(e.4O={}));1c r=e.4O;(1b(e){e.1r=[],e.1q=0,e.3h=1,e.4u=2,e.7x=4,e.2s=8,e.2x=16,e.6d=32,e.7v=64,e.3x=8Z})(e.1V||(e.1V={}));1c i=e.1V;(1b(e){e.1r=[],e.1q=0,e.rw=1,e.ku=2,e.ew=4,e.2k=8,e.zg=16,e.eB=32,e.kn=64,e.wf=8Z,e.ke=dJ,e.pG=bY,e.c9=dN})(e.2M||(e.2M={}));1c s=e.2M;(1b(e){e.1r=[],e.1q=0,e.2x=1,e.3h=2,e.4u=4,e.2s=8,e.3x=16,e.bn=32,e.6C=64,e.8D=8Z})(e.8c||(e.8c={}));1c o=e.8c;(1b(e){e.1r=[],e.1q=0,e.2x=1,e.3h=2,e.4u=4,e.2s=8,e.3x=16,e.bn=32,e.6C=64,e.8D=8Z,e.6F=dJ,e.eQ=bY,e.k6=dN,e.9q=eH})(e.3r||(e.3r={}));1c u=e.3r;(1b(e){e.1r=[],e.1q=0,e.2x=1,e.3h=2,e.4u=4,e.2s=8,e.3x=16,e.bn=32,e.6C=64,e.8D=8Z,e.3k=dJ,e.7x=bY,e.9r=dN,e.C7=eH,e.EB=kJ,e.q9=lc,e.qg=lh,e.ed=lI,e.9w=m3,e.fh=1<<17,e.qA=1<<18})(e.2j||(e.2j={}));1c a=e.2j;(1b(e){e.1r=[],e.1q=0,e.2x=1,e.3h=2,e.4u=4,e.2s=8,e.3x=16,e.bn=32,e.6C=64,e.8D=8Z,e.ju=dJ,e.3k=bY,e.7x=dN,e.4K=eH,e.Ad=kJ,e.xP=lc,e.qG=lh,e.df=lI,e.ed=m3})(e.1U||(e.1U={}));1c f=e.1U;(1b(e){e.1r=[],e.1q=0,e.2x=1,e.3h=2,e.4u=4,e.2s=8,e.3x=16,e.bn=32,e.6C=64,e.8D=8Z,e.aJ=dJ,e.7F=bY,e.fS=dN,e.ja=eH,e.qW=kJ,e.j4=lc,e.iZ=lh,e.8v=lI,e.j5=m3,e.aH=1<<17,e.6U=1<<18,e.fV=1<<19})(e.1O||(e.1O={}));1c l=e.1O;(1b(e){e.1r=[],e.1q=0,e.qX=1,e.j9=2,e.jc=4})(e.8C||(e.8C={}));1c c=e.8C;e.6A=h,1b(e){e.1r=[],e.1q=0,e.qO=1,e.iZ=2,e.E0=4,e.6F=8,e.il=16,e.jg=32,e.jh=64,e.i4=8Z}(e.4w||(e.4w={}));1c p=e.4w;(1b(e){e.1r=[],e.xI=0,e.Eo=1,e.t5=2,e.jv=4,e.uT=3,e.xK=16,e.y4=32,e.rP=64})(e.8V||(e.8V={}));1c d=e.8V;(1b(e){e.1r=[],e.qo=0,e.5S=1})(e.8a||(e.8a={}));1c v=e.8a;(1b(e){e.1r=[],e.q7=0,e.f7=1,e.q0=2})(e.9m||(e.9m={}));1c m=e.9m;e.7K=v.qo,e.9l=m.q7,e.kC=!0,e.AY=g})(2c||(2c={}));1c 2c;(1b(e){(1b(e){e.1r=[],e.1r[0]="1q",e.1q=0,e.1r[1]="7s",e.7s=1,e.1r[2]="e4",e.e4=2,e.1r[3]="ef",e.ef=3,e.1r[4]="fd",e.fd=4,e.1r[5]="e7",e.e7=5,e.1r[6]="9k",e.9k=6,e.1r[7]="6a",e.6a=7,e.1r[8]="av",e.av=8,e.1r[9]="9Q",e.9Q=9,e.1r[10]="8X",e.8X=10,e.1r[11]="7c",e.7c=11,e.1r[12]="9V",e.9V=12,e.1r[13]="2Y",e.2Y=13,e.1r[14]="co",e.co=14,e.1r[15]="ci",e.ci=15,e.1r[16]="eE",e.eE=16,e.1r[17]="oj",e.oj=17,e.1r[18]="aB",e.aB=18,e.1r[19]="4H",e.4H=19,e.1r[20]="li",e.li=20,e.1r[21]="hn",e.hn=21,e.1r[22]="hf",e.hf=22,e.1r[23]="eU",e.eU=23,e.1r[24]="7w",e.7w=24,e.1r[25]="3L",e.3L=25,e.1r[26]="aj",e.aj=26,e.1r[27]="7y",e.7y=27,e.1r[28]="5U",e.5U=28,e.1r[29]="bj",e.bj=29,e.1r[30]="2S",e.2S=30,e.1r[31]="ap",e.ap=31,e.1r[32]="bf",e.bf=32,e.1r[33]="bc",e.bc=33,e.1r[34]="ba",e.ba=34,e.1r[35]="b7",e.b7=35,e.1r[36]="9N",e.9N=36,e.1r[37]="b3",e.b3=37,e.1r[38]="ab",e.ab=38,e.1r[39]="b1",e.b1=39,e.1r[40]="b0",e.b0=40,e.1r[41]="9S",e.9S=41,e.1r[42]="6x",e.6x=42,e.1r[43]="aX",e.aX=43,e.1r[44]="aU",e.aU=44,e.1r[45]="a3",e.a3=45,e.1r[46]="8T",e.8T=46,e.1r[47]="a9",e.a9=47,e.1r[48]="Eq",e.Eq=48,e.1r[49]="h8",e.h8=49,e.1r[50]="aQ",e.aQ=50,e.1r[51]="aN",e.aN=51,e.1r[52]="gr",e.gr=52,e.1r[53]="gm",e.gm=53,e.1r[54]="ge",e.ge=54,e.1r[55]="iy",e.iy=55,e.1r[56]="7z",e.7z=56,e.1r[57]="ao",e.ao=57,e.1r[58]="aq",e.aq=58,e.1r[59]="aC",e.aC=59,e.1r[60]="hO",e.hO=60,e.1r[61]="az",e.az=61,e.1r[62]="b4",e.b4=62,e.1r[63]="aG",e.aG=63,e.1r[64]="da",e.da=64,e.1r[65]="fK",e.fK=65,e.1r[66]="fu",e.fu=66,e.1r[67]="fq",e.fq=67,e.1r[68]="fo",e.fo=68,e.1r[69]="fn",e.fn=69,e.1r[70]="ff",e.ff=70,e.1r[71]="2t",e.2t=71,e.1r[72]="9i",e.9i=72,e.1r[73]="3m",e.3m=73,e.1r[74]="9e",e.9e=74,e.1r[75]="eS",e.eS=75,e.1r[76]="cX",e.cX=76,e.1r[77]="ey",e.ey=77,e.1r[78]="cs",e.cs=78,e.1r[79]="gq",e.gq=79,e.1r[80]="iO",e.iO=80,e.1r[81]="cB",e.cB=81,e.1r[82]="aL",e.aL=82,e.1r[83]="im",e.im=83,e.1r[84]="5M",e.5M=84,e.1r[85]="hX",e.hX=85,e.1r[86]="bB",e.bB=86,e.1r[87]="e3",e.e3=87,e.1r[88]="en",e.en=88,e.1r[89]="ct",e.ct=89,e.1r[90]="ak",e.ak=90,e.1r[91]="6l",e.6l=91,e.1r[92]="4o",e.4o=92,e.1r[93]="6Y",e.6Y=93,e.1r[94]="4K",e.4K=94,e.1r[95]="5h",e.5h=95,e.1r[96]="4h",e.4h=96,e.1r[97]="ec",e.ec=97,e.1r[98]="9K",e.9K=98,e.1r[99]="eY",e.eY=99,e.1r[gl]="f6",e.f6=gl,e.1r[jT]="q8",e.q8=jT,e.1r[ih]="qe",e.qe=ih,e.1r[jB]="8S",e.8S=jB,e.1r[jy]="2k",e.2k=jy,e.1r[jr]="7W",e.7W=jr,e.1r[jl]="iL",e.iL=jl,e.xq=e.2t,e.qN=e.9S})(e.1f||(e.1f={}));1c t=e.1f})(2c||(2c={}));1c 2c;(1b(e){1b i(e){1c t=Dz;1d e=e^61^e>>>16,e+=e<<3,e^=e>>>4,e*=t,e^=e>>>15,e}1b s(e,t){1d t^(e>>5)+e}1c t=1b(){1b e(){1a.1e=2i,1a.5v=2i,1a.DG=2i,1a.DJ=2i,1a.qP=2i,1a.DQ=2i,1a.DU=2i,1a.6J=2i}1d e}();e.Ee=t;1c n=1b(){1b e(){1a.bM=0,1a.5b=1h t}1d e.1e.8e=1b(){1c e=[];1w(1c t in 1a.5b)1a.5b[t]!=2i&&(e[e.1n]=t);1d e},e.1e.4L=1b(e,t){1d 1a.5b[e]!=2i?!1:(1a.5b[e]=t,1a.bM++,!0)},e.1e.j1=1b(e,t){1d 1a.5b[e]!=2i?(1a.5b[e]=t,!1):(1a.5b[e]=t,1a.bM++,!0)},e.1e.5p=1b(e,t){1w(1c n in 1a.5b){1c r=1a.5b[n];r!=2i&&e(n,1a.5b[n],t)}},e.1e.iY=1b(e,t){1w(1c n in 1a.5b){1c r=1a.5b[n];if(r!=2i&&!e(n,1a.5b[n],t))1d!1}1d!0},e.1e.kZ=1b(e,t){1w(1c n in 1a.5b){1c r=1a.5b[n];if(r!=2i&&e(n,1a.5b[n],t))1d!0}1d!1},e.1e.3f=1b(){1d 1a.bM},e.1e.4r=1b(e){1c t=1a.5b[e];1d t!=2i?t:1g},e}();e.2h=n;1c r=1b(){1b e(e,t){1a.9J=e,1a.7m=t,1a.di=!0}1d e.1e.8e=1b(){1d 1a.9J.8e().4E(1a.7m.8e())},e.1e.4L=1b(e,t){1d 1a.di?1a.9J.4L(e,t):1a.7m.4L(e,t)},e.1e.j1=1b(e,t){1d 1a.di?1a.9J.j1(e,t):1a.7m.j1(e,t)},e.1e.5p=1b(e,t){1a.9J.5p(e,t),1a.7m.5p(e,t)},e.1e.iY=1b(e,t){1d 1a.9J.iY(e,t)&&1a.7m.iY(e,t)},e.1e.kZ=1b(e,t){1d 1a.9J.kZ(e,t)||1a.7m.kZ(e,t)},e.1e.3f=1b(){1d 1a.9J.3f()+1a.7m.3f()},e.1e.4r=1b(e){1c t=1a.9J.4r(e);1d t!=2i?t:1a.7m.4r(e)},e}();e.3M=r,e.EK=i,e.EJ=s;1c o=1b(){1b e(e,t){1a.j2=e,1a.r0=t}1d e}();e.EF=o;1c u=1b(){1b e(e,t,n){1a.fR=e,1a.j6=t,1a.jb=n,1a.bM=0,1a.5b=1h 2T;1w(1c r=0;r<1a.fR;r++)1a.5b[r]=1g}1d e.1e.4L=1b(e,t){1c n,r=1h o(e,t),i=1a.j6(e);i%=1a.fR;1w(n=1a.5b[i];n!=1g;n=n.d0)if(1a.jb(e,n.j2))1d!1;1d r.d0=1a.5b[i],1a.5b[i]=r,1a.bM++,!0},e.1e.Ej=1b(e){1c t,n=1a.j6(e);n%=1a.fR;1c r=1g,i=1g;1w(t=1a.5b[n];t!=1g;t=t.d0){if(1a.jb(e,t.j2)){r=t.r0,1a.bM--,i?i.d0=t.d0:1a.5b[n]=t.d0;1B}i=t}1d r},e.1e.3f=1b(){1d 1a.bM},e.1e.4r=1b(e){1c t,n=1a.j6(e);n%=1a.fR;1w(t=1a.5b[n];t!=1g;t=t.d0)if(1a.jb(e,t.j2))1d t.r0;1d 1g},e}();e.Eg=u})(2c||(2c={}));1c 2B=1a.2B||1b(e,t){1b n(){1a.6J=e}n.1e=t.1e,e.1e=1h n},2c;(1b(e){1c t=1b(){1b t(t){1a.1o=t,1a.1i=1g,1a.1M=e.2M.ew,1a.1u=-1,1a.1x=-1,1a.DI=e.6w.hd,1a.5s=1g,1a.5q=1g,1a.7o=!1}1d t.1e.5P=1b(){1d!1},t.1e.cC=1b(){1d!1},t.1e.xj=1b(){1d 1a.5P()&&!1a.cC()},t.1e.1P=1b(t){3S(1a.1o){1t e.1f.2k:1t e.1f.e4:1a.1i=t.1Q;1B;1t e.1f.e7:1d t.wQ(1a);1t e.1f.9Q:1a.1i=t.7t;1B;1t e.1f.fd:1t e.1f.ef:1a.1i=t.5B;1B;1t e.1f.9k:1d t.wr(1a);1t e.1f.8S:1t e.1f.7s:1t e.1f.9V:1a.1i=t.3O;1B;4G:3K 1h 2k("6S 6b in 6Q 3g")}1d 1a},t.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a);3S(1a.1o){1t e.1f.e7:t.2U&&e.1s(t.2U.1S,e.1O.8v)?t.1H("k5"):t.1H("1a");1B;1t e.1f.9Q:t.1H("1g");1B;1t e.1f.fd:t.1H("k7");1B;1t e.1f.ef:t.1H("d3");1B;1t e.1f.9k:t.vD();1t e.1f.8S:1B;1t e.1f.2k:1t e.1f.e4:1B;1t e.1f.7s:t.1H("; ");1B;1t e.1f.9V:t.1H("a7 ");1B;4G:3K 1h 2k("6S 6b in 6Q 3g")}t.2C(1a),t.2w(1a,!1)},t.1e.6E=1b(t){t.cd();1c n={2K:-1,3c:-1},r={2K:-1,3c:-1};t.4t!==1g&&(t.4t.ex(n,1a.1u),t.4t.ex(r,1a.1x),t.vx("("+n.2K+","+n.3c+")--"+"("+r.2K+","+r.3c+"): "));1c i=1a.6t();e.1s(1a.1M,e.2M.2k)&&(i+=" (2k)"),t.vq(i)},t.1e.6t=1b(){1d e.br[1a.1o]!==2i?e.br[1a.1o]:e.1f.1r[1a.1o]},t.1e.5C=1b(e){e.6O.2o.4s=!1,e.8M(1a)},t.1e.zQ=1b(e,t){},t.1e.a4=1b(){1d e.1f.1r[1a.1o]},t}();e.5y=t;1c n=1b(t){1b n(n,r){t.1K(1a,e.1f.2k),1a.1u=n,1a.1x=r}1d 2B(n,t),n}(t);e.vc=n;1c r=1b(t){1b n(){t.1K(1a,e.1f.4o),1a.kj=1g,1a.1p=1h 2T}1d 2B(n,t),n.1e.5C=1b(e){1c t=1a.1p.1n;1w(1c n=0;n0||1a.fZ.1n>0)},n}(t);e.2t=b;1c w=1b(){1b e(e,t,n){1a.ae=e,1a.5x=t,1a.3d=n}1d e}();e.wB=w,e.n1=1h w("n2",1g,-1);1c E=1b(t){1b n(n,r){t.1K(1a,1h i("aR"),1g,!1,1g,n,r,1g,e.1f.6Y),1a.2v=1g,1a.vQ=!1,1a.n8=!1,1a.9A=!1,1a.n9=!1,1a.mp=!1,1a.ng=1g,1a.4U=0,1a.4R=0,1a.bG=n,1a.c5=r}1d 2B(n,t),n.1e.1P=1b(e){1d e.vz(1a)},n.1e.a4=1b(){1d"6Y"},n.1e.nh=1b(){if(!1a.n9&&!1a.9A&&1a.3C)1w(1c t=0,n=1a.3C.1p.1n;t0&&(t.2E.3Z(n),t.2E=n)},n.1e.1P=1b(e){1d e.1j.5r.m1||(1a.6g===1g||1a.6g.1p.1n==0)&&e.1j.1L.6D(1a,"A6 bF"),e.1P(1a.6g),1a},n}(k);e.5M=A;1c O=1b(t){1b n(e){t.1K(1a,e),1a.3A=1g,1a.lS=1g,1a.5A=e}1d 2B(n,t),n.1e.nX=1b(){1d 1a.3A},n.1e.lR=1b(t,n){1d n.aZ()?(1a.lS=n,!0):1a.5A===e.1f.ey?(t.1T("3P 4m yC 4e to Ff"),!1):n.1o==e.1f.bB||1a.nX()?(1a.lS=n,!0):(t.1T("1B 4m 5F no o8 8u f3 4e to a lE or 3S 4m"),!1)},n.1e.5C=1b(n){t.1e.5C.1K(1a,n),n.sK(1a.lS,1a.5A==e.1f.ey)},n.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a),1a.5A==e.1f.cX?t.1H("1B"):t.1H("3P"),1a.nX()&&t.1H(" "+1a.3A),t.1H(";"),t.2C(1a),t.2w(1a,!1)},n}(k);e.sC=O;1c M=1b(t){1b n(n){t.1K(1a,e.1f.aL),1a.3V=n,1a.1W=1g}1d 2B(n,t),n.1e.5P=1b(){1d!0},n.1e.aZ=1b(){1d!0},n.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a);1c s=t.5J(!1);t.1H("3q("),t.2D(1a.3V,e.1k.f2,!1),t.1H(")"),t.bd(1a.1W,!1,!1),t.5J(s),t.2C(1a),t.2w(1a,!1)},n.1e.1P=1b(e){1d e.sn(1a)},n.1e.5C=1b(t){1c n=t.2E,r=1h e.4Q,i=1h e.4Q;n.3Z(r),t.2E=r,t.8M(1a.3V);1c s=t.2E,o=1g;1a.1W&&(t.2E=1h e.4Q,s.3Z(t.2E),t.9P(1a,r,i),t.2d(1a.1W,1a),o=t.9O());if(!t.5d){1c u=t.2E;u.3Z(r)}t.2E=i,s.3Z(i),t.5d=!1,t.6O.2o.4s=!1},n}(k);e.sj=M;1c 6B=1b(t){1b n(){t.1K(1a,e.1f.im),1a.1W=1g,1a.dR=1g,1a.3V=1g}1d 2B(n,t),n.1e.5P=1b(){1d!0},n.1e.aZ=1b(){1d!0},n.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a);1c s=t.5J(!1);t.1H("do"),t.bd(1a.1W,!0,!1),t.2A(1a.dR),t.1H("3q"),t.2C(1a.dR),t.1H("("),t.2D(1a.3V,e.1k.3T,!1),t.1H(")"),t.5J(s),t.2C(1a),t.2w(1a,!1)},n.1e.1P=1b(e){1d e.si(1a)},n.1e.5C=1b(t){1c n=t.2E,r=1h e.4Q,i=1h e.4Q;n.3Z(r),t.2E=r;1c s=1g;1a.1W&&(t.9P(1a,r,i),t.2d(1a.1W,1a),s=t.9O());if(!t.5d){1c o=t.2E;o.3Z(r),t.8M(1a.3V),t.2E=i,o.3Z(i)}1y t.kk(1a.3V);t.6O.2o.4s=!1},n}(k);e.sf=6B;1c D=1b(t){1b n(n){t.1K(1a,e.1f.cB),1a.3V=n,1a.7Q=1g}1d 2B(n,t),n.1e.5P=1b(){1d!0},n.1e.cC=1b(){1d!0},n.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a);1c s=t.5J(!1);t.1H("if("),t.2D(1a.3V,e.1k.gI,!1),t.1H(")"),t.bd(1a.9f,!0,!1),1a.7Q&&(t.1H(" 1y"),t.bd(1a.7Q,!0,!0)),t.5J(s),t.2C(1a),t.2w(1a,!1)},n.1e.1P=1b(e){1d e.s5(1a)},n.1e.5C=1b(t){1a.3V.5C(t);1c n=1h e.4Q,r=t.2E;t.9P(1a,r,n);1c i=!1;t.2E=1h e.4Q,r.3Z(t.2E),t.2d(1a.9f,1a),t.5d||(i=!0,t.2E.3Z(n)),1a.7Q?(t.2E=1h e.4Q,t.5d=!1,r.3Z(t.2E),t.2d(1a.7Q,1a),t.5d?i&&(t.5d=!1):(i=!0,t.2E.3Z(n))):(r.3Z(n),t.5d=!1,i=!0);1c s=t.9O();n.b5.1n>0&&(t.5d=!1,i=!0),i&&(t.2E=n),t.6O.2o.4s=!1},n}(k);e.s4=D;1c P=1b(t){1b n(){t.1K(1a,e.1f.eS),1a.6i=1g}1d 2B(n,t),n.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a);1c s=t.5J(!1);1a.6i?(t.1H("1d "),t.2D(1a.6i,e.1k.2R,!1)):t.1H("1d;"),t.5J(s),t.2C(1a),t.2w(1a,!1)},n.1e.5C=1b(e){t.1e.5C.1K(1a,e),e.p0()},n.1e.1P=1b(e){1d e.s3(1a)},n}(k);e.oa=P;1c H=1b(t){1b n(){t.1K(1a,e.1f.8S)}1d 2B(n,t),n}(t);e.8S=H;1c B=1b(t){1b n(n,r){t.1K(1a,e.1f.iO),1a.7u=n,1a.ad=r,1a.7u&&1a.7u.1o==e.1f.3m&&(1a.7u.1Y|=e.1U.ju)}1d 2B(n,t),n.1e.5P=1b(){1d!0},n.1e.aZ=1b(){1d!0},n.1e.rV=1b(){if(1a.1W){1c t=1g;if(1a.1W.1o==e.1f.4o){1c n=1a.1W;n.1p.1n==1&&(t=n.1p[0])}1y t=1a.1W;if(t!==1g){if(t.1o==e.1f.5M){1c r=t;r.6g!==1g&&r.6g.1p.1n==1&&(t=r.6g.1p[0])}if(t.1o==e.1f.cB){1c i=t.3V;if(i.1o==e.1f.5U){1c s=i.3A;if(s.1o==e.1f.4H){1c o=s;if(o.2l.1o==e.1f.3L&&1a.ad.1o==e.1f.3L&&o.2l.1G==1a.ad.1G){1c u=o.2f;if(u.1G=="qP"){1c a=i.2p;if(a!==1g&&a.1p.1n==1){1c f=a.1p[0];if(f.1o==e.1f.3L&&1a.7u.1o==e.1f.3L&&1a.7u.1G==f.1G)1d!0}}}}}}}}1d!1},n.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a);1c s=t.5J(!1);t.1H("1w("),t.2D(1a.7u,e.1k.9d,!1),t.1H(" in "),t.2D(1a.ad,e.1k.9d,!1),t.1H(")"),t.bd(1a.1W,!0,!1),t.5J(s),t.2C(1a),t.2w(1a,!1)},n.1e.1P=1b(e){1d e.1j.5r.lq&&(1a.rV()||e.1j.1L.6D(1a,"no qP cW")),e.rT(1a)},n.1e.5C=1b(t){1a.7u&&t.8M(1a.7u),1a.ad&&t.8M(1a.ad);1c n=t.2E,r=1h e.4Q,i=1h e.4Q;n.3Z(r),t.2E=r,1a.1W&&(t.9P(1a,r,i),t.2d(1a.1W,1a),t.9O());if(!t.5d){1c s=t.2E;s.3Z(r)}t.2E=i,t.5d=!1,n.3Z(i),t.6O.2o.4s=!1},n}(k);e.rN=B;1c j=1b(t){1b n(n){t.1K(1a,e.1f.gq),1a.2m=n}1d 2B(n,t),n.1e.5P=1b(){1d!0},n.1e.aZ=1b(){1d!0},n.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a);1c s=t.5J(!1);t.1H("1w("),1a.2m&&(1a.2m.1o!=e.1f.4o?t.2D(1a.2m,e.1k.9d,!1):t.rL(1a.2m)),t.1H("; "),t.2D(1a.3V,e.1k.9d,!1),t.1H("; "),t.2D(1a.9a,e.1k.9d,!1),t.1H(")"),t.bd(1a.1W,!0,!1),t.5J(s),t.2C(1a),t.2w(1a,!1)},n.1e.1P=1b(e){1d e.rJ(1a)},n.1e.5C=1b(t){1a.2m&&t.8M(1a.2m);1c n=t.2E,r=1h e.4Q,i=1h e.4Q;n.3Z(r),t.2E=r;1c s=1g,o=r,u=1g;1a.9a&&(u=1h e.4Q,o=u),1a.3V&&(s=t.2E,t.8M(1a.3V),t.2E=1h e.4Q,s.3Z(t.2E));1c a=1g;1a.1W&&(t.9P(1a,o,i),t.2d(1a.1W,1a),a=t.9O()),1a.9a&&(t.5d?u.b5.1n==0&&t.kk(1a.9a):(t.2E.3Z(u),t.2E=u,t.8M(1a.9a)));1c f=t.2E;t.5d||f.3Z(r),s&&(s.3Z(i),t.5d=!1),i.b5.1n>0&&(t.5d=!1,t.2E=i),t.6O.2o.4s=!1},n}(k);e.rH=j;1c F=1b(t){1b n(n){t.1K(1a,e.1f.9K),1a.6h=n,1a.rF=1g}1d 2B(n,t),n.1e.5P=1b(){1d!0},n.1e.cC=1b(){1d!0},n.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a),t.1H("5F ("),1a.6h&&t.2D(1a.6h,e.1k.hi,!1),t.1H(")"),t.bd(1a.1W,!0,!1),t.2C(1a),t.2w(1a,!1)},n.1e.1P=1b(e){1d e.rB(1a)},n}(k);e.rx=F;1c I=1b(t){1b n(n){t.1K(1a,e.1f.bB),1a.c6=n,1a.c7=1g}1d 2B(n,t),n.1e.5P=1b(){1d!0},n.1e.cC=1b(){1d!0},n.1e.3o=1b(t,n,r){t.2w(1a,!0),t.2A(1a);1c i=t.5J(!1);t.1H("3S("),t.2D(1a.c6,e.1k.3j,!1),t.2y(") {"),t.5Q();1c s=1a.6I.1p.1n;1w(1c o=0;o0?(t.5d=!1,t.2E=i):t.5d=!0,t.6O.2o.4s=!1},n}(k);e.rp=I;1c q=1b(t){1b n(){t.1K(1a,e.1f.hX),1a.6h=1g}1d 2B(n,t),n.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a),1a.6h?(t.1H("1t "),t.2D(1a.6h,e.1k.3j,!1)):t.1H("4G"),t.1H(":"),t.bd(1a.1W,!1,!1),t.2C(1a),t.2w(1a,!1)},n.1e.1P=1b(e){1d 1a.6h=e.1P(1a.6h),e.1P(1a.1W),1a.1i=e.3O,1a},n.1e.5C=1b(t){1c n=1h e.4Q,r=t.hu[t.hu.1n-1];if(1a.6h){1c i=1h e.4Q;t.2E=i,r.3Z(i),t.8M(1a.6h),i.3Z(n)}1y r.3Z(n);t.2E=n,1a.1W&&t.2d(1a.1W,1a),t.5d=!1,t.6O.2o.4s=!1},n}(k);e.rm=q;1c R=1b(t){1b n(n,r){t.1K(1a,e.1f.aj),1a.ca=n,1a.hy=r}1d 2B(n,t),n.1e.3o=1b(e,t,n,r){3K 1h 2k("lU 2g 3o a 1i At")},n.1e.1P=1b(t){1c n=t.hA;t.hA=!0;1c r=e.cb(1a,t.1j,!0);1d t.1j.7D(t.2a,r,!1),t.op(r.1i,1a),1a.1i=r.1i,1a.ca&&(1a.ca.1i=1a.1i),t.hA=n,1a},n}(t);e.eD=R;1c U=1b(t){1b n(n,r){t.1K(1a,e.1f.ct),1a.7e=n,1a.cj=r}1d 2B(n,t),n.1e.5P=1b(){1d!0},n.1e.cC=1b(){1d!0},n.1e.3o=1b(t,n,r){t.2A(1a),t.2D(1a.7e,e.1k.dl,!1),t.2D(1a.cj,e.1k.eC,!1),t.2C(1a)},n.1e.1P=1b(e){1d 1a.7e=e.1P(1a.7e),1a.cj=e.1P(1a.cj),1a.1i=e.3O,1a},n.1e.5C=1b(t){1c n=1h e.4Q;t.2d(1a.7e,1a);1c r=1h e.4Q;t.2E&&t.2E.3Z(r),t.2E=r,t.9P(1a,1g,n),t.2d(1a.cj,1a),!t.5d&&t.2E&&t.2E.3Z(n),n.b5.1n>0?t.2E=n:t.5d=!0,t.9O(),t.6O.2o.4s=!1},n}(k);e.ct=U;1c z=1b(t){1b n(n,r){t.1K(1a,e.1f.en),1a.7e=n,1a.cz=r}1d 2B(n,t),n.1e.5P=1b(){1d!0},n.1e.cC=1b(){1d!0},n.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a),t.2D(1a.7e,e.1k.dl,!1),t.2D(1a.cz,e.1k.eA,!1),t.2C(1a),t.2w(1a,!1)},n.1e.5C=1b(t){1c n=t.2E,r=1h e.4Q;n.3Z(r),t.2E=r;1c i=1h e.4Q;t.9P(1a,1g,i),t.2d(1a.7e,1a),t.5d||t.2E&&t.2E.3Z(i),t.2E=1h e.4Q,n.3Z(t.2E),t.2d(1a.cz,1a),t.9O(),t.5d||t.2E&&t.2E.3Z(i),t.2E=i,t.6O.2o.4s=!1},n.1e.1P=1b(e){1d 1a.7e=e.1P(1a.7e),1a.cz=e.1P(1a.cz),1a.1i=e.3O,1a},n}(k);e.en=z;1c W=1b(t){1b n(n){t.1K(1a,e.1f.e3),1a.1W=n}1d 2B(n,t),n.1e.5P=1b(){1d!0},n.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a),t.1H("9Y "),t.2D(1a.1W,e.1k.dl,!1),t.2C(1a),t.2w(1a,!1)},n.1e.1P=1b(e){1d 1a.1W=e.1P(1a.1W),1a},n.1e.5C=1b(e){1a.1W&&e.2d(1a.1W,1a),e.6O.2o.4s=!1,e.5d=!1},n}(k);e.e3=W;1c X=1b(t){1b n(n,r){t.1K(1a,e.1f.6l),1a.6M=n,1a.1W=r,1a.3v=1g,1a.6M&&(1a.6M.1Y|=e.1U.ju)}1d 2B(n,t),n.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a),t.1H(" 7X ("),t.2D(1a.6M,e.1k.3y,!1),t.1H(")"),t.2D(1a.1W,e.1k.eA,!1),t.2C(1a),t.2w(1a,!1)},n.1e.5C=1b(t){if(1a.6M){t.8M(1a.6M);1c n=1h e.4Q;t.2E.3Z(n),t.2E=n}1a.1W&&t.2d(1a.1W,1a),t.5d=!1,t.6O.2o.4s=!1},n.1e.1P=1b(t){1c n=t.2a;t.2a=1a.3v,1a.6M=t.1P(1a.6M);1c r=1h e.7T,i=1h e.hW(1a.6M.id.1G,1a.6M.1u,t.1j.2v.3d,r);r.1A=i,r.2H=1h e.7p,r.2H.1i=t.1Q;1c s=t.2U;s&&s.1i?r.1A.1R=s.1i.1A:r.1A.1R=1g,1a.6M.2z=r.1A,t.2a.6W(r.1A.1R,1a.6M,r.1A,t.1j.1L,!1,!1,!1),1a.1W=t.1P(1a.1W);if(t.1j.9s()){1c o=t.2a.lf();o.7m.5b[r.1A.1C]=2i}1d 1a.1i=t.3O,t.2a=n,1a},n}(k);e.6l=X;1c V=1b(t){1b n(n){t.1K(1a,e.1f.ak),1a.1W=n}1d 2B(n,t),n.1e.3o=1b(t,n,r,i){t.2w(1a,!0),t.2A(1a),t.1H("i3"),t.2D(1a.1W,e.1k.eC,!1),t.2C(1a),t.2w(1a,!1)},n.1e.5C=1b(e){1a.1W&&e.2d(1a.1W,1a),e.6O.2o.4s=!1,e.5d=!1},n.1e.1P=1b(e){1d 1a.1W=e.1P(1a.1W),1a},n}(k);e.ak=V;1c $=1b(t){1b n(n,r,i){t.1K(1a,e.1f.7W),1a.6c=n,1a.ld=r,1a.dC=i,1a.1G=1g}1d 2B(n,t),n.1e.3b=1b(){if(1a.1G==1g)if(1a.ld){1a.1G=1a.6c.cw("\\n");1w(1c e=0;e<1a.1G.1n;e++)1a.1G[e]=1a.1G[e].8W(/^\\s+|\\s+$/g,"")}1y 1a.1G=[1a.6c.8W(/^\\s+|\\s+$/g,"")];1d 1a.1G},n}(t);e.7W=$;1c J=1b(t){1b n(){t.1K(1a,e.1f.iL)}1d 2B(n,t),n.1e.3o=1b(e,t,n,r){e.2w(1a,!0),e.2A(1a),e.2y("oy;"),e.2C(1a),e.2w(1a,!1)},n}(k);e.xi=J})(2c||(2c={}));1c 2c;(1b(e){1b s(){1d i||(i=1h r),i}1c t=1b(){1b e(){1a.4s=!0,1a.3J=!0,1a.es=!1}1d e.1e.l9=1b(e){5i e=="2i"&&(e=!0),1a.4s=!e,1a.3J=!e},e}();e.oB=t;1c n=1b(){1b e(e,t,n,r,i){1a.1Z=e,1a.wO=t,1a.oG=n,1a.2o=r,1a.5o=i}1d e.1e.2d=1b(e,t){1c n=1a.wO(e,t,1a);n===2i&&(n=e);if(1a.2o.4s){1c r=1a.2o.3J;1a.2o.3J=!0,1a.1Z[e.1o](e,t,1a),1a.2o.3J=r}1y 1a.2o.4s=!0;if(1a.oG){1c i=1a.oG(n,t,1a);1d i===2i&&(i=n),i}1d n},e}(),r=1b(){1b r(){1a.1Z=[],1a.wE()}1d r.1e.2d=1b(e,t,n,r,i){1d 1a.mW(t,n,r,i).2d(e,1g)},r.1e.mW=1b(e,t,n,r){1d 1a.wD(e,t,n,r)},r.1e.wD=1b(e,r,i,s){1d i||(i=1h t),1h n(1a.1Z,e,r,i,s)},r.1e.wE=1b(){1a.1Z[e.1f.1q]=o.5N,1a.1Z[e.1f.7s]=o.5N,1a.1Z[e.1f.e4]=o.5N,1a.1Z[e.1f.ef]=o.5N,1a.1Z[e.1f.fd]=o.5N,1a.1Z[e.1f.e7]=o.5N,1a.1Z[e.1f.9k]=o.5N,1a.1Z[e.1f.6a]=o.5N,1a.1Z[e.1f.av]=o.5N,1a.1Z[e.1f.9Q]=o.5N,1a.1Z[e.1f.8X]=o.7b,1a.1Z[e.1f.7c]=o.7b,1a.1Z[e.1f.9V]=o.5N,1a.1Z[e.1f.2Y]=o.3B,1a.1Z[e.1f.co]=o.7b,1a.1Z[e.1f.ci]=o.7b,1a.1Z[e.1f.eE]=o.7b,1a.1Z[e.1f.oj]=o.7b,1a.1Z[e.1f.aB]=o.3B,1a.1Z[e.1f.4H]=o.3B,1a.1Z[e.1f.li]=o.3B,1a.1Z[e.1f.hn]=o.3B,1a.1Z[e.1f.hf]=o.3B,1a.1Z[e.1f.eU]=o.7b,1a.1Z[e.1f.7w]=o.5N,1a.1Z[e.1f.3L]=o.5N,1a.1Z[e.1f.aj]=o.wC,1a.1Z[e.1f.7y]=o.3B,1a.1Z[e.1f.5U]=o.oI,1a.1Z[e.1f.bj]=o.oI,1a.1Z[e.1f.2S]=o.3B,1a.1Z[e.1f.ap]=o.3B,1a.1Z[e.1f.bf]=o.3B,1a.1Z[e.1f.bc]=o.3B,1a.1Z[e.1f.ba]=o.3B,1a.1Z[e.1f.b7]=o.3B,1a.1Z[e.1f.9N]=o.3B,1a.1Z[e.1f.b3]=o.3B,1a.1Z[e.1f.ab]=o.3B,1a.1Z[e.1f.b1]=o.3B,1a.1Z[e.1f.b0]=o.3B,1a.1Z[e.1f.9S]=o.3B,1a.1Z[e.1f.6x]=o.wn,1a.1Z[e.1f.aX]=o.3B,1a.1Z[e.1f.aU]=o.3B,1a.1Z[e.1f.a3]=o.3B,1a.1Z[e.1f.8T]=o.3B,1a.1Z[e.1f.a9]=o.3B,1a.1Z[e.1f.Eq]=o.3B,1a.1Z[e.1f.h8]=o.3B,1a.1Z[e.1f.aQ]=o.3B,1a.1Z[e.1f.aN]=o.3B,1a.1Z[e.1f.gr]=o.3B,1a.1Z[e.1f.gm]=o.3B,1a.1Z[e.1f.ge]=o.3B,1a.1Z[e.1f.iy]=o.3B,1a.1Z[e.1f.7z]=o.3B,1a.1Z[e.1f.ao]=o.3B,1a.1Z[e.1f.aq]=o.3B,1a.1Z[e.1f.aC]=o.3B,1a.1Z[e.1f.hO]=o.3B,1a.1Z[e.1f.az]=o.3B,1a.1Z[e.1f.b4]=o.3B,1a.1Z[e.1f.aG]=o.3B,1a.1Z[e.1f.da]=o.7b,1a.1Z[e.1f.fK]=o.7b,1a.1Z[e.1f.fu]=o.7b,1a.1Z[e.1f.fq]=o.7b,1a.1Z[e.1f.fo]=o.7b,1a.1Z[e.1f.fn]=o.7b,1a.1Z[e.1f.ff]=o.7b,1a.1Z[e.1f.2t]=o.wl,1a.1Z[e.1f.9i]=o.3B,1a.1Z[e.1f.3m]=o.oK,1a.1Z[e.1f.9e]=o.oK,1a.1Z[e.1f.eS]=o.wa,1a.1Z[e.1f.cX]=o.5N,1a.1Z[e.1f.ey]=o.5N,1a.1Z[e.1f.cs]=o.7b,1a.1Z[e.1f.gq]=o.w4,1a.1Z[e.1f.iO]=o.vU,1a.1Z[e.1f.cB]=o.vH,1a.1Z[e.1f.aL]=o.vA,1a.1Z[e.1f.im]=o.vr,1a.1Z[e.1f.5M]=o.vn,1a.1Z[e.1f.hX]=o.vh,1a.1Z[e.1f.bB]=o.ve,1a.1Z[e.1f.e3]=o.vd,1a.1Z[e.1f.en]=o.v8,1a.1Z[e.1f.ct]=o.v3,1a.1Z[e.1f.ak]=o.uX,1a.1Z[e.1f.6l]=o.uW,1a.1Z[e.1f.4o]=o.uP,1a.1Z[e.1f.6Y]=o.uF,1a.1Z[e.1f.4K]=o.uD,1a.1Z[e.1f.5h]=o.uB,1a.1Z[e.1f.4h]=o.uy,1a.1Z[e.1f.ec]=o.uw,1a.1Z[e.1f.9K]=o.uv,1a.1Z[e.1f.eY]=o.uu,1a.1Z[e.1f.f6]=o.ur,1a.1Z[e.1f.q8]=o.5N,1a.1Z[e.1f.qe]=o.5N,1a.1Z[e.1f.8S]=o.5N,1a.1Z[e.1f.2k]=o.5N,1a.1Z[e.1f.7W]=o.5N,1a.1Z[e.1f.iL]=o.5N;1w(1c t in e.1f.1r)if(1a.1Z[t]===2i)3K 1h 2k("D1 1b is 2g up to CX 5F kQ 6c!")},r}();e.CB=r;1c i;e.6f=s;1c o;(1b(e){1b t(e,t,n){}1b n(e,t,n){1c r=e.1p.1n;if(n.2o.es)1w(1c i=r-1;i>=0;i--)n.2o.3J&&(e.1p[i]=n.2d(e.1p[i],e));1y 1w(1c i=0;i0&&n.2o.3J&&(e.2p=n.2d(e.2p,e)),e.5m&&n.2o.3J&&(e.5m=n.2d(e.5m,e)),e.3C&&e.3C.1p.1n>0&&n.2o.3J&&(e.3C=n.2d(e.3C,e))}1b f(e,t,n){e.id&&(e.id=n.2d(e.id,e)),e.2m&&(e.2m=n.2d(e.2m,e)),e.4C&&n.2o.3J&&(e.4C=n.2d(e.4C,e))}1b l(e,t,n){e.6i&&(e.6i=n.2d(e.6i,e))}1b c(e,t,n){e.2m&&(e.2m=n.2d(e.2m,e)),e.3V&&n.2o.3J&&(e.3V=n.2d(e.3V,e)),e.9a&&n.2o.3J&&(e.9a=n.2d(e.9a,e)),e.1W&&n.2o.3J&&(e.1W=n.2d(e.1W,e))}1b h(e,t,n){e.7u=n.2d(e.7u,e),n.2o.3J&&(e.ad=n.2d(e.ad,e)),e.1W&&n.2o.3J&&(e.1W=n.2d(e.1W,e))}1b p(e,t,n){e.3V=n.2d(e.3V,e),e.9f&&n.2o.3J&&(e.9f=n.2d(e.9f,e)),e.7Q&&n.2o.3J&&(e.7Q=n.2d(e.7Q,e))}1b d(e,t,n){e.3V=n.2d(e.3V,e),e.1W&&n.2o.3J&&(e.1W=n.2d(e.1W,e))}1b v(e,t,n){e.3V=n.2d(e.3V,e),e.1W&&n.2o.3J&&(e.1W=n.2d(e.1W,e))}1b m(e,t,n){e.6g&&(e.6g=n.2d(e.6g,e))}1b g(e,t,n){e.6h&&(e.6h=n.2d(e.6h,e)),e.1W&&n.2o.3J&&(e.1W=n.2d(e.1W,e))}1b y(e,t,n){e.c6&&(e.c6=n.2d(e.c6,e)),e.6I&&n.2o.3J&&(e.6I=n.2d(e.6I,e))}1b b(e,t,n){e.1W&&(e.1W=n.2d(e.1W,e))}1b w(e,t,n){e.7e&&(e.7e=n.2d(e.7e,e)),e.cz&&n.2o.3J&&(e.cz=n.2d(e.cz,e))}1b E(e,t,n){e.7e&&(e.7e=n.2d(e.7e,e)),e.cj&&n.2o.3J&&(e.cj=n.2d(e.cj,e))}1b S(e,t,n){e.1W&&(e.1W=n.2d(e.1W,e))}1b x(e,t,n){e.6M&&(e.6M=n.2d(e.6M,e)),e.1W&&n.2o.3J&&(e.1W=n.2d(e.1W,e))}1b T(e,t,n){e.1C=n.2d(e.1C,e),n.2o.3J&&e.1p&&(e.1p=n.2d(e.1p,e))}1b N(e,t,n){T(e,t,n)}1b C(e,t,n){N(e,t,n),n.2o.3J&&e.7U&&(e.7U=n.2d(e.7U,e)),n.2o.3J&&e.6y&&(e.6y=n.2d(e.6y,e))}1b k(e,t,n){e.3C&&(e.3C=n.2d(e.3C,e))}1b L(e,t,n){N(e,t,n),n.2o.3J&&e.2V&&(e.2V=n.2d(e.2V,e)),n.2o.3J&&e.6y&&(e.6y=n.2d(e.6y,e))}1b A(e,t,n){T(e,t,n),n.2o.3J&&e.5k&&(e.5k=n.2d(e.5k,e))}1b O(e,t,n){e.id&&(e.id=n.2d(e.id,e)),e.5k&&(e.5k=n.2d(e.5k,e))}1b M(e,t,n){e.6h&&(e.6h=n.2d(e.6h,e)),e.1W&&n.2o.3J&&(e.1W=n.2d(e.1W,e))}1b 6B(e,t,n){}1b D(e,t,n){e.8I=n.2d(e.8I,e),n.2o.3J&&(e.7q=n.2d(e.7q,e))}e.5N=t,e.uP=n,e.7b=r,e.3B=i,e.wC=s,e.oI=o,e.wn=u,e.wl=a,e.oK=f,e.wa=l,e.w4=c,e.vU=h,e.vH=p,e.vA=d,e.vr=v,e.vn=m,e.vh=g,e.ve=y,e.vd=b,e.v8=w,e.v3=E,e.uX=S,e.uW=x,e.Cq=T,e.C4=N,e.uD=C,e.uF=k,e.uB=L,e.uy=A,e.uw=O,e.uv=M,e.uu=6B,e.ur=D})(o||(o={}))})(2c||(2c={}));1c 2c;(1b(e){1b t(e){1d e===1g||e.1n===0?1g:e[e.1n-1]}1b n(e,t){1d e>=t?e:t}1b r(e,t){1d e<=t?e:t}1b s(e){1d e===1g?!1:e.1u===-1||e.1x===-1?!1:!0}1b a(t,n,r){5i r=="2i"&&(r=u.tx);1c i=1b(e){if(e&&e.1n>0)1w(1c t=0;t=r&&n=h&&n=d.1u&&o.1x<=d.1x)&&f.5e.4b(o)}n=h&&i(o.5q),e.1s(r,u.tm)||(l.2o.4s=h<=n&&n<=p)}1d o},f=1h o;1d e.6f().2d(t,a,1g,1g,f),f.5e}1b f(t,r){1c i=0,s=1b(t,s,o){if(e.gw(t)){t.1u<=r&&(i=n(i,t.1u));if(t.1u>r||t.1x1a.3f())1a.1J.7a();1d e},n.1e.4b=1b(e){3q(1a.1J.1n>1a.3f())1a.1J.7a();1a.1I=1a.1J.1n,1a.1J.4b(e)},n.1e.up=1b(){if(1a.1I<=-1)3K 1h 2k("kz 1K to \'up\'");1a.1I--},n.1e.s6=1b(){if(1a.1I==1a.3I.1n-1)3K 1h 2k("kz 1K to \'s6\'");1a.1I++},n.1e.1o=1b(){1d 1a.3I()==1g?e.1f.1q:1a.3I().1o},n.1e.3I=1b(){1d n.p5(1a.1J,1a.1J.1n-(1a.1I+1))},n.1e.4c=1b(){1d n.p5(1a.1J,1a.1J.1n-1a.1I)},n.1e.3f=1b(){1d 1a.1I+1},n.1e.ac=1b(e){1d 1a.1J[e]},n.1e.zP=1b(){1d 1a.3I()===1g||1a.4c()===1g?!1:1a.3I().1o===e.1f.3L&&1a.4c().1o===e.1f.4K&&1a.4c().1C===1a.3I()},n.1e.zJ=1b(){1d 1a.3I()===1g||1a.4c()===1g?!1:1a.3I().1o===e.1f.3L&&1a.4c().1o===e.1f.5h&&1a.4c().1C===1a.3I()},n.1e.zG=1b(){1d 1a.3I()===1g||1a.4c()===1g?!1:1a.3I().1o===e.1f.3L&&1a.4c().1o===e.1f.9e&&1a.4c().id===1a.3I()},n.1e.zs=1b(){1d 1a.3I()===1g||1a.4c()===1g?!1:1a.3I().1o===e.1f.3L&&1a.4c().1o===e.1f.3m&&1a.4c().id===1a.3I()},n.1e.zp=1b(){1d 1a.3I()===1g||1a.4c()===1g?!1:1a.3I().1o===e.1f.3L&&1a.4c().1o===e.1f.4h&&1a.4c().1C===1a.3I()},n.1e.zm=1b(){1d 1a.3I()===1g||1a.4c()===1g?!1:1a.3I().1o===e.1f.3L&&1a.4c().1o===e.1f.2t&&1a.4c().1C===1a.3I()},n.1e.zl=1b(){1c n=t(1a.1J);1d 1a.3f()>=3&&1a.1J[1a.1I]===n&&1a.1J[1a.1I-1].1o===e.1f.4o&&1a.1J[1a.1I-2].1o===e.1f.6Y},n.1e.zi=1b(){1c n=t(1a.1J);1d 1a.3f()>=3&&1a.1J[1a.1I]===n&&1a.1J[1a.1I-1].1o===e.1f.4o&&1a.1J[1a.1I-2].1o===e.1f.4h},n.1e.zh=1b(){1c n=t(1a.1J);1d 1a.3f()>=3&&1a.1J[1a.1I]===n&&1a.1J[1a.1I-1].1o===e.1f.4o&&1a.1J[1a.1I-2].1o===e.1f.4K},n.1e.ze=1b(){1c n=t(1a.1J);1d 1a.3f()>=5&&1a.1J[1a.1I]===n&&1a.1J[1a.1I-1].1o===e.1f.4o&&1a.1J[1a.1I-2].1o===e.1f.2t&&1a.1J[1a.1I-3].1o===e.1f.4o&&1a.1J[1a.1I-4].1o===e.1f.4K&&1a.1J[1a.1I-2].3p&&1a.1J[1a.1I-2].2p===1a.1J[1a.1I-1]&&1a.1J[1a.1I-4].7V===1a.1J[1a.1I-2]},n.1e.yX=1b(){1c n=t(1a.1J);1d 1a.3f()>=3&&1a.1J[1a.1I]===n&&1a.1J[1a.1I-1].1o===e.1f.4o&&1a.1J[1a.1I-2].1o===e.1f.5h},n.1e.yv=1b(){1d 1a.3f()>=1&&1a.1J[1a.1I].1o===e.1f.4h&&e.1s(1a.1J[1a.1I].3l,e.3r.k6)},n.1e.ys=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-0].1o===e.1f.4o&&1a.1J[1a.1I-1].1o===e.1f.4h&&1a.1J[1a.1I-1].1p==1a.1J[1a.1I-0]&&e.1s(1a.1J[1a.1I-1].3l,e.3r.k6)},n.1e.Fj=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.6Y&&1a.1J[1a.1I-1].3C==1a.1J[1a.1I-0]},n.1e.Fh=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.bB&&1a.1J[1a.1I-1].6I==1a.1J[1a.1I-0]},n.1e.ES=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.4h&&1a.1J[1a.1I-1].1p==1a.1J[1a.1I-0]},n.1e.ER=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.4K&&1a.1J[1a.1I-1].1p==1a.1J[1a.1I-0]},n.1e.EP=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.2t&&1a.1J[1a.1I-1].3C==1a.1J[1a.1I-0]},n.1e.DV=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.5h&&1a.1J[1a.1I-1].1p==1a.1J[1a.1I-0]},n.1e.D0=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.5M&&1a.1J[1a.1I-1].6g==1a.1J[1a.1I-0]},n.1e.CU=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.gq&&1a.1J[1a.1I-1].1W==1a.1J[1a.1I-0]},n.1e.vW=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.hX&&1a.1J[1a.1I-1].1W==1a.1J[1a.1I-0]},n.1e.Cj=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.e3&&1a.1J[1a.1I-1].1W==1a.1J[1a.1I-0]},n.1e.C0=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.6l&&1a.1J[1a.1I-1].1W==1a.1J[1a.1I-0]},n.1e.BL=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.im&&1a.1J[1a.1I-1].1W==1a.1J[1a.1I-0]},n.1e.Bw=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.aL&&1a.1J[1a.1I-1].1W==1a.1J[1a.1I-0]},n.1e.Bu=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.iO&&1a.1J[1a.1I-1].1W==1a.1J[1a.1I-0]},n.1e.Bg=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.9K&&1a.1J[1a.1I-1].1W==1a.1J[1a.1I-0]},n.1e.Bf=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.ak&&1a.1J[1a.1I-1].1W==1a.1J[1a.1I-0]},n.1e.B1=1b(){1d 1a.3f()>=3&&1a.1J[1a.1I-2].1o===e.1f.bB&&1a.1J[1a.1I-1].1o===e.1f.4o&&1a.1J[1a.1I-2].6I==1a.1J[1a.1I-1]},n.1e.As=1b(){1d 1a.3f()>=3&&1a.1J[1a.1I-2].1o===e.1f.bB&&1a.1J[1a.1I-1].1o===e.1f.4o&&1a.1J[1a.1I-2].6I==1a.1J[1a.1I-1]&&1a.1J[1a.1I-2].c7==1a.1J[1a.1I-0]},n.1e.uj=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.7c&&1a.1J[1a.1I-0].1o===e.1f.4o&&1a.1J[1a.1I-1].2P==1a.1J[1a.1I-0]},n.1e.A9=1b(){1d 1a.uj()},n.1e.zW=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.7c&&1a.1J[1a.1I-0].1o===e.1f.4o&&1a.1J[1a.1I-1].2P==1a.1J[1a.1I-0]&&1a.1J[1a.1I-0].1p.1n==0},n.1e.zV=1b(){1d 1a.3f()>=3&&1a.1J[1a.1I-2].1o===e.1f.7c&&1a.1J[1a.1I-1].1o===e.1f.4o&&1a.1J[1a.1I-0].1o===e.1f.9i&&1a.1J[1a.1I-2].2P==1a.1J[1a.1I-1]},n.1e.zK=1b(){1d 1a.3f()>=4&&1a.1J[1a.1I-3].1o===e.1f.7c&&1a.1J[1a.1I-2].1o===e.1f.4o&&1a.1J[1a.1I-1].1o===e.1f.9i&&1a.1J[1a.1I-0].1o===e.1f.3L&&1a.1J[1a.1I-3].2P==1a.1J[1a.1I-2]},n.1e.zE=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.8X&&1a.1J[1a.1I-0].1o===e.1f.4o&&1a.1J[1a.1I-1].2P==1a.1J[1a.1I-0]},n.1e.zn=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.9i&&1a.1J[1a.1I-1].2l===1a.1J[1a.1I-0]},n.1e.yS=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.9i&&1a.1J[1a.1I-1].2f===1a.1J[1a.1I-0]},n.1e.yQ=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.4o},n.1e.yA=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.cB&&1a.1J[1a.1I-1].9f==1a.1J[1a.1I-0]},n.1e.yw=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-1].1o===e.1f.cB&&1a.1J[1a.1I-1].7Q==1a.1J[1a.1I-0]},n.1e.Fp=1b(){1d 1a.vW()},n.1e.Fe=1b(){1d 1a.3f()>=1&&1a.1J[1a.1I].1o===e.1f.4o&&1a.1J[1a.1I].1p.1n===1},n.1e.EA=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-0].1o===e.1f.4o&&1a.1J[1a.1I-1].1o===e.1f.2t&&1a.1J[1a.1I-1].2p===1a.1J[1a.1I-0]},n.1e.Ey=1b(){1d 1a.3f()>=3&&1a.1J[1a.1I-1].1o===e.1f.4o&&1a.1J[1a.1I-2].1o===e.1f.2t&&1a.1J[1a.1I-2].2p===1a.1J[1a.1I-1]},n.1e.Ev=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-0].1o===e.1f.4o&&1a.1J[1a.1I-1].1o===e.1f.5U&&1a.1J[1a.1I-1].2p===1a.1J[1a.1I-0]},n.1e.DK=1b(){1d 1a.3f()>=2&&1a.1J[1a.1I-0].1o===e.1f.4o&&1a.1J[1a.1I-1].1o===e.1f.bj&&1a.1J[1a.1I-1].2p===1a.1J[1a.1I-0]},n.1e.Dt=1b(){1d 1a.3f()>=1&&1a.1J[1a.1I-0].1o===e.1f.5M&&1a.1J[1a.1I-0].8s===!1},n}();e.s1=i,e.gw=s;1c o=1b(){1b t(){1a.5e=1h e.s1}1d t}();e.C5=o,1b(e){e.1r=[],e.tx=0,e.tr=1,e.tm=2}(e.pX||(e.pX={}));1c u=e.pX;e.zU=a,e.zL=f,e.zB=l})(2c||(2c={}));1c 2c;(1b(e){1c t=1b(){1b t(e){1a.3n=e}1d t.1e.yz=1b(t){1c n=1a;1a.hs(t.2v.5x);1c r=[],i=1b(e,i){r.4b(e);1c s=(r.1n-1)*2;1d n.q1(t,e.5s,s),n.q2(t,e,s),n.q1(t,e.5q,s),e},s=1b(e,t){1d r.7a(),e};e.6f().2d(t,i,s)},t.1e.q2=1b(e,t,n){1c r=1a.b6("",n,"| ",!0);r=r.4E("+ "+t.a4()),r=1a.b6(r,70," ",!1),r+=1a.q3(e,t.1u),r=1a.b6(r,80," ",!1),r+="=> ",r+=1a.q3(e,t.1x),r=1a.b6(r,ih," ",!1),r=r.4E("["+1a.b6(t.1u.5v(),1," ",!0)+", "+1a.b6(t.1x.5v(),1," ",!0)+"]"),r=1a.b6(r,DY," ",!1),r=r.4E("2z="+t.2z),r=1a.b6(r,D6," ",!1),r=r.4E("1i="+(t.1i===1g?"1g":t.1i.3Q())),1a.3n.4S(r)},t.1e.q1=1b(e,t,n){if(t==1g)1d;1w(1c r=0;r0&&(t+=","),t+=e[n];t+="]",1a.3n.4S("CK: "+t)},t.1e.b6=1b(e,t,n,r){1c i=r?"":e;1w(1c s=e.1n;s=0&&n.3d<1a.1j.6e.1n&&(1a.1j.2v=1a.1j.6e[n.3d]);3S(n.4i()){1t e.4g.3z:if(n.1M&e.2j.qA)1B;1c i=n;i.1M|=e.2j.qA;if(i.9C&&!i.1i&&i.9C.5k.1o==e.1f.3L){1c s=i.9C.5k.1G,o=1a.1j.ix(s,1a.1j.2v.ae,1b(e){1d t.3u(e,!1,!0)});o&&(i.1i=o.2N())}if(i.1i&&i.1i!=1a.1j.wP){1a.i9(t,i.1i,i.3i);if(i.1i.e1())1w(1c u=0;u>=5,n>0&&(i|=32),r+=t.d2(i)}3q(n>0);1d r},e.Ax=1b(n){1c r=0,i=!1,s=0;1w(1c o=0;o>1&15):r|=(u&31)<1||e.dC){1a.2y("");1w(1c r=1;r0&&(1a.1H(", "),1a.7G(a,", ",e.1k.2Y,!1,!1,!1)),1a.1H(")")}1y s.1i&&s.1i.8R()&&(1a.2X(),1a.1H(n.1C.1G+".fv.6J"),1a.1H(".1K(1a)"))}1a.2C(n)},r.1e.c0=1b(n,r,i,s,o,u,a,f){5i a=="2i"&&(a=!1),5i f=="2i"&&(f=1a.4z.1R);1c l=n.3p&&e.1s(n.1S,e.1O.6U),c=l&&e.1s(1a.3s.1i.3i.4V,e.4w.jg)&&!e.1s(1a.3s.1i.3i.4V,e.4w.jh),h=c&&e.1s(1a.3s.1Y,e.1U.df);1a.2w(n,!0),1a.2A(n),(!n.4y()||!n.7k.qw)&&1a.1H("1b ");if(r){1c p=n.aI();p&&!n.4y()&&1a.1H(p)}1a.1H("("),a&&(a=1a.qv(n,!1,f));1c d=0,v=0,m,g=[];if(n.2p){1c y=1a.7r(t.iC);d=n.2p.1p.1n;1c b=d;n.8N&&b--;1w(v=0;v1)1d!1}1y if(t.1i.1K.2e.1n>1)1d!1;if(!1a.cr(e.6A(t.1S),r))1d!1;if(t.3p)1a.8j(),1a.2I.2Z("6J ");1y{1c i=t.aI();n?(1a.8j(),t.fM()?1a.2I.2Z("1h"):!t.mY()&&!t.d1()&&(1a.2I.2Z(i),e.1s(t.1C.1M,e.2M.c9)&&1a.2I.2Z("? "))):(1a.aa(e.6A(t.1S),"1b"),1a.2I.2Z(i))}1d t.d1()?1a.2I.2Z("["):1a.2I.2Z("("),!0},r.1e.qt=1b(e){if(e.8N){1c t=e.2p.1p[e.2p.1p.1n-1];e.2p.1p.1n>1?1a.2I.2Z(", ..."):1a.2I.2Z("..."),1a.mu(t)}e.d1()?1a.2I.2Z("]"):1a.2I.2Z(")"),!e.3p&&(e.5m||e.3F.2J.1i!=1a.1j.1Q)&&1a.jC(e.3F.2J.1i)&&1a.2I.2Z(": "+1a.dZ(e.3F.2J.1i)),e.iS()?1a.2I.3D(" {"):1a.2I.3D(";")},r.1e.dY=1b(e,t){5i t=="2i"&&(t=!1);1c n=1a.qv(e,t);if(n){if(e.2p){1c r=e.2p.1p.1n;e.8N&&r--;1w(1c i=0;i0){1a.2I.2Z(" "+t+" ");1c n=e.1p.1n;1w(1c r=0;r0&&1a.2I.2Z(", "),1a.2I.2Z(u)}}},r.1e.qm=1b(t){if(!1a.cr(e.6A(t.1Y)))1d!1;1c n=t.1C.1G;1d 1a.aa(e.6A(t.1Y),"3g"),1a.2I.2Z(n),1a.jJ(t.7U,"qk"),1a.jJ(t.6y,"tN"),1a.2I.3D(" {"),!0},r.1e.uh=1b(t){1c n=t.8E.1p.1n;1w(1c r=0;r0);if(n||i){1c s=t.1o==e.1f.5M||t.1o==e.1f.4o&&t.1p.1n==1&&t.1p[0].1o==e.1f.5M;1a.2A(t),s||(1a.2y(" {"),1a.5Q()),1a.7G(t,1g,e.1k.2R,!0,!1,!1),s||(1a.2y(""),1a.5L(),1a.2X(),1a.1H("}")),1a.2C(t)}}1y 1a.2D(t,e.1k.2R,!0);1y n&&1a.1H("{ }")},r.1e.xb=1b(t,n){if(t.1o!=e.1f.5M)if(t.1o==e.1f.4o){1c r=t;r.1p.1n==2&&r.1p[0].1o==e.1f.5M&&r.1p[1].1o==e.1f.8S?(1a.2D(r.1p[0],e.1k.2R,!0),1a.2y("")):1a.7G(t,1g,e.1k.2R,!0,!1,n)}1y 1a.2D(t,e.1k.2R,!0);1y 1a.2D(t,e.1k.2R,!0)},r.1e.2A=1b(t){if(1a.7A&&t){1c n={2K:-1,3c:-1},r=1h e.wN(t);r.iM=1a.4z.dj,r.iN=1a.4z.2K,e.dn(n,t.1u,1a.1j.2v.5x),r.r9=n.3c,r.ra=n.2K,e.dn(n,t.1x,1a.1j.2v.5x),r.AA=n.3c,r.AF=n.2K,r.4c=1a.7A.gb,1a.7A.gb=1a.7A.dG.1n,1a.7A.dG.4b(r);if(r.4c>=0){1c i=1a.7A.dG[r.4c];i.iQ==-1&&(i.iQ=1a.7A.gb)}}},r.1e.2C=1b(e){if(1a.7A&&e){1c t=1a.7A.gb,n=1a.7A.dG[t];n.AH=1a.4z.dj,n.AJ=1a.4z.2K,1a.7A.gb=n.4c}},r.1e.pW=1b(){e.ea.re(1a.qT)},r.1e.7G=1b(t,n,r,i,s,o,u){if(t==1g)1d;if(t.1o!=e.1f.4o)1a.2D(t,r,i,u);1y{1c a=t;if(a.1p.1n==0)1d;1a.2w(t,!0);1c f=a.1p.1n;1w(1c l=0;l0&&n.1o!=e.1f.4o&&n.1o!=e.1f.5M&&n.1o!=e.1f.5h&&(n.1o!=e.1f.3m||(n.1Y&e.1U.2s)!=e.1U.2s||n.2m!=1g)&&n.1o!=e.1f.8S&&(n.1o!=e.1f.2t||1a.4z.1R!=t.cl)&&1a.2X(),o&&1a.1H("("),n.3o(1a,r,i,s),o&&1a.1H(")"),r==e.1k.2R&&n.1o1)1w(1c s=1;s0&&(1a.1H(", "),1a.7G(t.2p,", ",e.1k.2Y,!1,!1,!1)),1a.1H(")"),!0}1d!1},r}();e.k2=r})(2c||(2c={}));1c 2c;(1b(e){1c t=1b(){1b t(e){1a.4F=e,1a.4t=1g,1a.1j=1g,1a.bg={2K:0,3c:0},1a.pT=!0,1a.pS=!1,1a.bi=!1,1a.hl=[]}1d t.1e.sp=1b(){1d 1a.hl},t.1e.sr=1b(){1a.hl=[]},t.1e.pR=1b(e){1a.hl[1a.hl.1n]=e},t.1e.sA=1b(e){1a.4F=e,1a.pT=!1},t.1e.pQ=1b(){1a.pT&&1a.4F.2Z("// "),1a.4F.2Z(1a.1j.2v.ae+"("+1a.bg.2K+","+1a.bg.3c+"): ")},t.1e.sN=1b(e){e?1a.sS(e):(1a.bg.2K=-1,1a.bg.3c=-1),1a.pQ()},t.1e.t3=1b(t){t&&1a.1j.2v.5x?e.dn(1a.bg,t.c1,1a.1j.2v.5x):(1a.bg.2K=-1,1a.bg.3c=-1),1a.pQ()},t.1e.sS=1b(t){t&&(t.1M|=e.2M.2k,1a.1j.2v.5x&&e.dn(1a.bg,t.1u,1a.1j.2v.5x))},t.1e.7O=1b(e,t){if(1a.bi){1a.pR(t);1d}1a.pS=!0;1c n=e.1x-e.1u;1a.4t.4A&&1a.4t.7M?1a.4t.7M(e.1u,n,t,1a.1j.2v.3d):(1a.sN(e),1a.4F.3D(t))},t.1e.pO=1b(e,t){if(1a.bi){1a.pR(t);1d}1a.pS=!0,1a.4t.4A&&1a.4t.7M?1a.4t.7M(e.c1,1,t,1a.1j.2v.3d):(1a.t3(e),1a.4F.3D(t))},t.1e.xC=1b(e,t){3K 1a.7O(e,t),2k("EU")},t.1e.cV=1b(e,t){1a.7O(e,"hh 7H \'"+t+"\'")},t.1e.yx=1b(e,t,n){1c r={2K:-1,3c:-1};1a.4t.ex(r,n.c1),1a.7O(e,"1A "+t+" pM at ("+r.2K+","+r.3c+")")},t.1e.k9=1b(e,t){1a.7O(e,"9R 1C \'"+t+"\' 6k 2g td in 5K 2E 2a")},t.1e.th=1b(e,t){1a.7O(e,"9R 1C \'"+t+"\' 6k 2g zt to a 4k")},t.1e.6D=1b(e,t){1c n=1a.bi;1a.bi=!1,1a.7O(e,"tw: "+t),1a.bi=n},t.1e.2q=1b(e,t){1a.7O(e,t)},t.1e.7g=1b(e,t){1a.pO(e,t)},t.1e.tB=1b(e){1a.2q(e,"hc \'d7\' 8u 4e be ka zO a 3g u2 eK")},t.1e.eJ=1b(e){1a.2q(e,"9R h9-Aa Ab of an pL 8B 8F be a 5O, 5u or Au")},t.1e.pK=1b(t,n,r){1c i=t.3A.1i,s=i.8b(r);if(i.2n&&n==e.1f.5U)1a.7O(t,"pJ of 1i \'"+s+"\' is 2g uo. pH ut uC to uR \'1h\'?");1y{1c o=n==e.1f.5U?"uo":"AU";1a.7O(t,"pJ of 1i \'"+s+"\' is 2g "+o)}},t.1e.AV=1b(e,t){1c n=e.2l.1i.8b(t),r=e.2f.1i.8b(t);1a.2q(e,"pJ of 1i \'"+n+"\' is 2g AZ by 1i \'"+r+"\'")},t.1e.dc=1b(e,t,n,r,i,s){t||(t=1a.1j.1Q),n||(n=1a.1j.1Q);1c o=s?s.7E:"";r?1a.7O(e,"h5 \'"+r+"\' h4 be eF to 9p \'"+t.8b(i)+"\' 8o \'"+n.8b(i)+"\'"+(o?": "+o:"")):1a.7O(e,"cg C1 \'"+t.8b(i)+"\' to \'"+n.8b(i)+"\'"+(o?": "+o:""))},t.1e.vg=1b(e){1a.2q(e,"2u 1c, 3g, 7f, or 6s")},t.1e.C9=1b(e,t,n){1a.7O(e,"h5 \'"+t+"\' h4 be eF to 1i \'"+n.3Q()+"\'")},t}();e.vy=t})(2c||(2c={}));1c 2c;(1b(e){1b s(t,n,r,s,o,u){1c a=r.3b(s,o);t.4S("Ci dm pF ("+s+","+o+\'): "\'+e.vK(a,gl)+\'"\');1c f=1h i;f.kg(1g,-1,-1),f.7M=u;1c l=1h e.m5(e.1f.4K,1g,1g,1g,1g,1g);f.h0=l;1c c=f.gZ(1h e.gY(a),"",0);1d c}(1b(e){e.1r=[],e.4l=0,e.kh=1,e.7d=2,e.pE=4,e.wG=e.7d|e.pE,e.Dw=e.7d|e.pE|e.kh})(e.pA||(e.pA={}));1c t=e.pA;(1b(e){e.1r=[],e.1r[0]="1q",e.1q=0,e.1r[1]="py",e.py=1,e.1r[2]="gX",e.gX=2,e.1r[3]="px",e.px=3,e.1r[4]="pu",e.pu=4,e.1r[5]="pt",e.pt=5,e.1r[6]="ps",e.ps=6,e.1r[7]="pr",e.pr=7,e.1r[8]="pq",e.pq=8,e.1r[9]="pl",e.pl=9,e.1r[10]="pk",e.pk=10,e.1r[11]="pj",e.pj=11,e.1r[12]="pi",e.pi=12})(e.ph||(e.ph={}));1c n=e.ph,r=1b(){1b e(e,t){1a.6Y=e,1a.y0=t}1d e}();e.EE=r;1c i=1b(){1b i(){1a.gW=[],1a.gV=[],1a.gU=[],1a.1l=1h e.pg,1a.1m=1g,1a.Fi=!1,1a.gS=!1,1a.yi=!1,1a.bp=!1,1a.h0=1g,1a.cn=!1,1a.yj=1h e.3R("ko"),1a.kp=!1,1a.pf=!0,1a.yK=!1,1a.4A=!1,1a.4F=2i,1a.7M=1g,1a.5o=n.gX,1a.pe=-1,1a.pc=-1,1a.rn=n.1q,1a.yU="",1a.6u=!1,1a.gP=!1,1a.ds=!0,1a.pb=-1,1a.7j=1g,1a.am=1h 2T,1a.gM=!1,1a.5a=!1,1a.4X=0,1a.ev=1g,1a.4n=1g,1a.9o=!1,1a.5w=!1,1a.bT=[],1a.9n=!1,1a.kv="",1a.rS=!1}1d i.1e.rU=1b(){1a.am=1h 2T},i.1e.rW=1b(){1w(1c e=1a.am.1n-1;e>=0;e--)if(1a.am[e].7q.aZ())1d!0;1d!1},i.1e.bs=1b(e,t){1c n={7q:e,8I:t};1a.am.4b(n)},i.1e.bt=1b(){1d 1a.am.7a()},i.1e.rZ=1b(t){1c n=1a.am.1n;1w(1c r=n-1;r>=0;r--){1c i=1a.am[r];if(t.3A){if(i.8I&&i.8I.1p.1n>0)1w(1c s=0,o=i.8I.1p.1n;s0)1a.1m.1z==e.1k.4N?i++:1a.1m.1z==e.1k.3H&&i--,1a.1m=1a.1l.1N(),n=e.1v.1q,r=e.eo(1a.1m.1z),r!=2i&&(n=r.p7)},i.1e.3t=1b(e,t,n){1a.1m.1z!=e?(1a.1T(t),1a.4A&&1a.6N(n)):1a.1m=1a.1l.1N()},i.1e.gC=1b(){1a.gU.4b(1h e.3X),1a.gW.4b(1h e.3X),1a.gV.4b(1h e.3X)},i.1e.em=1b(){1a.gU.7a(),1a.gW.7a(),1a.gV.7a()},i.1e.cF=1b(){1d 1a.gW[1a.gW.1n-1]},i.1e.cN=1b(){1d 1a.gV[1a.gV.1n-1]},i.1e.p3=1b(){1d 1a.gU[1a.gU.1n-1]},i.1e.t2=1b(t){if(t){1c n=1h e.7W(t.4k,t.kF,t.dC);n.1u=t.1X,n.1x=t.1X+t.4k.1n;if(!t.kF&&t.4k.1n>3&&t.4k.3e(0,3)=="///"){1c r=e.t4(t.4k);r&&1a.bT.4b(r)}1d n}1d 1g},i.1e.p1=1b(e){if(e){1c t=1h 2T;1w(1c n=0;n0){1c g=a.1n,y=a[g-1],b=1h e.dS(y,p,1a.cF(),1a.cN());if(1a.5w||e.1s(n,e.1V.2s))b.3l|=e.3r.2s;b.3l|=e.3r.2x,b.1u=l,b.1x=v,1a.em();1c w;1w(1c E=g-2;E>=0;E--){w=1h e.3X,w.4Y(b),y=a[E],b=1h e.dS(y,w,1h e.3X,1h e.3X),w.1u=b.1u=l,w.1x=b.1x=v;if(1a.5w||e.1s(n,e.1V.2s))b.3l|=e.3r.2s;b.3l|=e.3r.2x}w=1h e.3X,w.4Y(b),w.1u=l,w.1x=v,m=1h e.dS(u,w,1h e.3X,1h e.3X)}1y m=1h e.dS(u,p,1a.cF(),1a.cN()),1a.em();if(1a.5w||e.1s(n,e.1V.2s))m.3l|=e.3r.2s;1d e.1s(n,e.1V.2x)&&(m.3l|=e.3r.2x),c&&(m.3l|=e.3r.9q),m.5s=f,m.5q=1a.4Z(),1a.6u=s,1a.ds=o,m.4U=1a.1l.4U-r,m.4R=1a.1l.4R-i,m},i.1e.go=1b(t,n,r){1c i=1h e.eD(r,0);i.1u=n;3q(1a.1m.1z==e.1k.7B)1a.1m=1a.1l.1N(),i.hy++,1a.3t(e.1k.6R,"2u \']\'",t|e.1v.7B);1d i.1x=1a.1l.3a(),i},i.1e.gn=1b(t,n,r,i){1a.1m=1a.1l.1N();if(1a.1m.1z==e.1k.4H){1c s=1a.1l.1F;1a.1m=1a.1l.1N();if(1a.1m.1z==e.1k.3j||e.5z(1a.1m,1a.5a)){1c o=1h e.3R(1a.1m.3b());o.1u=1a.1l.1X,o.1x=1a.1l.1F;1c u=1h e.9D(e.1f.4H,r,o);1d u.1u=r.1u,u.1x=o.1x,1a.gn(t,n,u,i)}1a.1T("tU 7H kO \'.\'");if(1a.4A)1d r.1M|=e.2M.eB,r.1x=1a.1l.3a(),r;1c a=1h e.6p;a.1u=1a.1l.1F,a.1x=1a.1l.1F;1c f=1h e.9D(e.1f.4H,r,a);1d f.1M|=e.2M.2k,f.1u=r.1u,f.1x=a.1x,1a.gn(t,n,f,i)}1d i?1a.go(t,n,r):r},i.1e.cQ=1b(t,n){1c r=1a.1l.1X,i=!1;3S(1a.1m.1z){1t e.1k.kT:n||1a.1T("a7 2g a kU 1i in 1a 9W");1t e.1k.gk:1t e.1k.gj:1t e.1k.gi:1t e.1k.gh:1c s=e.a8[1a.1m.1z].1G,o=1h e.3R(s);1d o.1u=r,o.1x=1a.1l.1F,1a.1m=1a.1l.1N(),1a.go(t,r,o);1t e.1k.3j:1c u=1a.gF(1a.1m.3b(),r);1d u.1x=1a.1l.1F,1a.gn(t,r,u,!0);1t e.1k.4N:1a.1m=1a.1l.1N();1c a=1h e.3X;a.1u=r;1c f=1a.bp;1a.bp=!0,1a.oT(t|e.1v.3H,a),1a.bp=f,1a.3t(e.1k.3H,"2u \'}\'",t);1c l=1h e.m5(e.1f.5h,1a.yj,a,1g,1g,1g);1d l.1u=r,l.1x=a.1x,1a.go(t,r,l);1t e.1k.eh:1a.1m=1a.1l.1N(),1a.1m.1z!=e.1k.3y?1a.1T("2u \'(\'"):i=!0;1t e.1k.3y:1c c=1h e.3X,h=1a.gf(t|e.1v.3T,c,!1,!0,!1,!1,!1,1g);1a.3t(e.1k.a5,"2u \'=>\'",t);1c p=1a.cQ(t,!0),d=1h e.2t(1g,1g,!1,c,1g,1g,1g,e.1f.2t);1d d.5m=p,d.8N=h,d.1S|=e.1O.7F,i&&(d.1S|=e.1O.j4,d.6L="uQ",d.9F=1g),d.1u=r,1a.go(t,r,d);4G:1a.1T("2u 1i 1C");1c v=1h e.eD(1g,0);1d v.1M|=e.2M.2k,v.1u=1a.1l.1F,v.1x=1a.1l.1F,v}},i.1e.kW=1b(r,i,s,o,u,a,f,l,c){1a.gC();1c h=1a.am;1a.rU();1c p=1g,d=!1,v=!1;if(!l){p=1h e.3X;1c m=1a.1l.1X;1a.1m.1z==e.1k.a5&&(o&&1a.1T("\'=>\' 3G 2g be ka 1w 3g El"),d=!0,1a.1m=1a.1l.1N());if(d&&1a.1m.1z!=e.1k.4N){1c g=1a.4v(r|e.1v.2R,e.4q.2S,!0,t.4l),y=1h e.oa;y.6i=g,p.1u=m,p.4Y(y)}1y{1a.5o=n.gX,1a.3t(e.1k.4N,"2u \'{\'",r|e.1v.8H);1c b=1a.gS;v=d,1a.gS=!0,1a.eg(r|e.1v.3H|e.1v.8H,p,!0,!1,a,c),p.1u=m,p.1x=1a.1l.1F,1a.gS=b;1c w=1h e.8S;w.1u=p.1x,w.1x=w.1u,p.4Y(w)}}1c E=1h e.2t(i,p,s,u,1a.cF(),1a.cN(),1a.p3(),e.1f.2t);1a.em();1c S=1a.cN();S.4Y(E);1c x=!1,T=1a.1l.1F;1d l?1a.3t(e.1k.2R,"2u \';\'",r):!d||v?(1a.3t(e.1k.3H,"2u \'}\'",r),v&&(E.1S|=e.1O.8v)):(E.1S|=e.1O.8v,1a.1m.1z==e.1k.2R&&(1a.1m=1a.1l.1N())),E.1u=f,E.1x=T,l||(E.1S|=e.1O.aJ),1a.am=h,E},i.1e.oS=1b(t,n){1c r=1a,i=1b(n){if(n.1o==e.1f.2Y)r.oS(t,n);1y if(n.1o==e.1f.3L||n.1o==e.1f.2S){1c i=n.1o==e.1f.2S?n.2l:n,s=1h e.9e(i);s.5s=i.5s,s.5q=i.5q,s.1u=i.1u,s.1x=i.1x,e.1s(i.1M,e.2M.ke)&&(s.ar=!0),n.1o==e.1f.2S&&(s.2m=n.2f),t.4Y(s)}1y r.1T("kz Ep e2")};if(n)if(n.1o==e.1f.2Y){1c s=n;i(s.2l),i(s.2f)}1y i(n)},i.1e.gf=1b(n,r,i,s,o,u,a,f){r.1u=1a.1l.1X,o?1a.1m=1a.1l.1N():f||1a.3t(e.1k.3y,"2u \'(\'",n|e.1v.3T);1c l=!1,c=!0,h=!1,p=!1,d=!1;f&&(1a.oS(r,f),p=!0);1w(;;){1c v=!1,m=e.1U.1q,g=1a.1l.1X;1a.9n&&1a.1m.1z==e.1k.bD&&(i||1a.1T("v1 5u e0 v5 \'1a\' 3G 4e be ka in 3g oQ"),1a.1m=1a.1l.1N(),m|=e.1U.4u|e.1U.3k,1a.4n&&(1a.4n.1Y|=e.1U.df)),1a.1m.1z==e.1k.ei?(m|=e.1U.4u|e.1U.3k,1a.4n&&(1a.4n.1Y|=e.1U.df)):1a.1m.1z==e.1k.ej&&(m|=e.1U.3h|e.1U.3k,1a.4n&&(1a.4n.1Y|=e.1U.df)),m!=e.1U.1q?(i||1a.1T("4e 6J 2r 8u be iI"),1a.1m=1a.1l.1N(),1a.9n&&1a.1m.1z==e.1k.bD&&(i||1a.1T("v1 5u e0 v5 \'1a\' 3G 4e be ka in 3g oQ"),1a.1m=1a.1l.1N(),1a.1m=1a.1l.1N())):1a.1m.1z==e.1k.gL&&(l=!0,1a.1m=1a.1l.1N());1c y=1g;if(!p&&1a.1m.1z==e.1k.3j||e.5z(1a.1m,1a.5a))y=1h e.3R(1a.1m.3b()),y.1u=1a.1l.1X,y.1x=1a.1l.1F;if(p||y){v=!0;1c b=1g,w=1g;p&&r.1p.1n?(w=r.1p[r.1p.1n-1],w.ar&&(h=!0,d=!0)):(w=1h e.9e(y),u&&1a.1T("3k EY 3G 2g 8O 8r c4"),a&&!c&&1a.1T("3k oP 3G 4e 8O bA e2"),w.1u=g,w.5s=1a.4Z(),1a.1m=1a.1l.1N()),1a.1m.1z==e.1k.6x&&(w.ar=!0,h=!0,1a.1m=1a.1l.1N()),1a.1m.1z==e.1k.5j&&(1a.1m=1a.1l.1N(),b=1a.cQ(n,!1),f&&(d=!0)),1a.1m.1z==e.1k.2S&&(s&&1a.1T("Fl in 2e 3G 2g 8h 4G Fm"),h=!0,1a.1m=1a.1l.1N(),w.2m=1a.4v(e.1v.2Y|n,e.4q.8L,!1,t.4l)),h&&!w.hL()&&!l&&1a.1T("9w 2r 3G 4e be Fn by cY vs 2r"),l&&w.hL()&&1a.1T("yr 3G 2g be vs or 8h 4G 2r"),w.5q=1a.4Z(),w.4C=b,w.1x=1a.1l.3a(),w.1Y|=m,p?p=!1:r.4Y(w)}c=!1;if(1a.1m.1z!=e.1k.2Y)1B;if(v&&!l){1a.1m=1a.1l.1N();3P}1a.1T("oM \',\' in e2 yt");if(1a.4A){1a.1m=1a.1l.1N();3P}}1d o?1a.3t(e.1k.6R,"2u \']\'",n|e.1v.4N|e.1v.2R):(!f||d)&&1a.3t(e.1k.3T,"2u \')\'",n|e.1v.4N|e.1v.2R),r.1x=1a.1l.3a(),l},i.1e.dU=1b(t,r,i,s,o,u,a,f,l,c){1c h=1a.1l.4U,p=1a.1l.4R,d=1a.9o;1a.9o=!1;1c v=1g,m=1a.1l.1X,g=1a.1l.1F,y=1a.4X;1a.4X=0,!1a.pf&&1a.rW()&&1a.ky("1b 5V in lE");if(!s&&!a&&!u&&!c){1a.1m=1a.1l.1N(),1a.5o=n.pu;if(1a.1m.1z!=e.1k.3j&&!e.5z(1a.1m,1a.5a)){if(r)1d 1a.1T("aE 5V 8F uR 7H"),1a.4X=y,1h e.vc(m,1a.1l.1F)}1y v=1h e.3R(1a.1m.3b()),v.1u=1a.1l.1X,v.1x=1a.1l.1F,1a.1m=1a.1l.1N()}1y o&&(v=o);1a.5o=n.pt;1c b=1h e.3X,w=!1,E=!1,S=e.1s(l,e.1V.6d),x=e.1s(l,e.1V.7v);if(1a.1m.1z==e.1k.3y||u&&1a.1m.1z==e.1k.7B||c&&c.l1)w=1a.gf(t,b,!1,i,u,S,x,c?c.l1:1g);1a.5o=n.ps;1c T=1g;1a.1m.1z==e.1k.5j&&(1a.1m=1a.1l.1N(),e.1s(l,e.1V.7v)&&1a.1T("3k oP 3G 2g iE a 1d 1i"),T=1a.cQ(t,!0)),u&&b.1p.1n==0&&1a.1T("7y 2e jV a 3W 1i to be yy"),1a.5o=n.pr,r&&!1a.5w&&!f&&(!s||!(1a.6u||1a.gP||1a.bp))&&1a.1m.1z==e.1k.2R&&(E=!0,r=!1,i=!0);1c N=1a.cn;1a.cn=!0;1c C=1a.kW(t|e.1v.3H,v,!1,s,b,e.4O.p8,g,i,e.1V.1q);1d 1a.cn=N,C.8N=w,C.6Z=E,i||(C.1S|=e.1O.aJ),a&&(C.1S|=e.1O.3x),i&&(C.1S|=e.1O.7F),u&&(C.1S|=e.1O.j5),C.5m=T,s&&(C.1S|=e.1O.fS,C.1S|=e.1O.fV),C.4U=1a.1l.4U-h,C.4R=1a.1l.4R-p,1a.4X=y,1a.9o=d,C},i.1e.l2=1b(t){1c n;3S(t.1o){1t e.1f.aj:1d t;1t e.1f.3L:1d n=1h e.eD(t,0),n.1u=t.1u,n.1x=t.1x,n;1t e.1f.7y:1c r=t;n=1a.l2(r.2l);if(n)1d n.hy++,n.1u=r.1u,n.1x=r.1x,n;1c i=1h e.5y(e.1f.2k);1d i}1d 1g},i.1e.l3=1b(n){1c r=1h e.3X;r.1u=1a.1l.1X,1a.1m=1a.1l.1N();if(1a.1m.1z!==e.1k.3T)1w(;;){if(r.1p.1n>yH){1a.1T("cI cJ of 2p yM");1B}1c i=1a.4v(e.1v.2Y|n,e.4q.8L,!1,t.4l);r.4Y(i);if(1a.1m.1z!=e.1k.2Y)1B;1a.1m=1a.1l.1N()}1d r.1x=1a.1l.1F,r},i.1e.oL=1b(t,n,r,i,s){1c o=!0,u=t;1w(;;){o&&(1a.1m.1z==e.1k.ek&&(i&&1a.1T("xw 8u 2g 6b cY 9p"),u=n),1a.1m=1a.1l.1N(),o=!1);1c a=1g;if(1a.1m.1z==e.1k.3j||e.5z(1a.1m,1a.5a)){1c f=1a.1l.1X;a=1h e.3R(1a.1m.3b()),a.1u=f,a.1x=1a.1l.1F,a=1a.gn(r|e.1v.4N,f,a,!1)}1y 1a.1T("2u bz 1C"),1a.4A&&(a=1h e.6p,a.1u=1a.1l.1F,a.1x=1a.1l.1F,a.1M|=e.2M.2k);if(1a.1m.1z==e.1k.3y){s&&1a.1T("iz aV 3G 4e be wk z5 a \'d7\' 1K bx 5K 6J 1W");1c l=1a.l3(r|e.1v.3T),c=1h e.lb(e.1f.5U,a,l);1a.1m=1a.1l.1N(),c.1x=1a.1l.1F,u.4Y(c)}1y u.4Y(a);!i&&u==t&&t.1p.1n>1&&1a.1T("A 3g 3G 4e qp bA cY 3g");if(1a.1m.1z==e.1k.2Y){1a.1m=1a.1l.1N();3P}if(1a.1m.1z==e.1k.el||1a.1m.1z==e.1k.ek){u=t,o=!0;3P}1B}},i.1e.wo=1b(t,n,r){1c i=1a.1l.4U,s=1a.1l.4R;(r&e.1V.7x)!=e.1V.1q&&1a.1T("oJ wt is zk 1w 3g");if(1a.5w||1a.6u)r|=e.1V.2s,r|=e.1V.2x;1c o=1a.5w||(r&e.1V.2s)!=e.1V.1q,u=1a.gP;1a.gP=o,1a.1m=1a.1l.1N();1c a=1g;1a.1m.1z==e.1k.3j||e.5z(1a.1m,1a.5a)?(a=1h e.3R(1a.1m.3b()),a.1u=1a.1l.1X,a.1x=1a.1l.1F,1a.1m=1a.1l.1N()):(1a.1T("3g kS 1C"),1a.4A&&(a=1h e.6p,a.1u=1a.1l.1F,a.1x=1a.1l.1F,a.1M|=e.2M.2k));1c f=1g,l=1g,c=!1;if(1a.1m.1z==e.1k.el||1a.1m.1z==e.1k.ek)f=1h e.3X,l=1h e.3X,1a.oL(f,l,t,!1,!0);1c h=1h e.uL(a,1h e.3X,f,l);1a.4n=h,1a.wu(h,t,r);if(1a.6u||1a.5w||e.1s(r,e.1V.2x))h.1Y|=e.1U.2x;if(1a.6u||e.1s(r,e.1V.2s))h.1Y|=e.1U.2s;1d h.1Y|=e.1U.4K,1a.gP=u,h.4U=1a.1l.4U-i,h.4R=1a.1l.4R-s,h},i.1e.wu=1b(t,n,r){1c i=r,s=!1,o=1a.1l.1X;1a.3t(e.1k.4N,"2u \'{\'",n),1a.4X++;1c u=1a.1l.1X,a=!1;3q(1a.1m.1z!=e.1k.3H&&1a.1m.1z!=e.1k.5I){1c f=!0,l=e.1V.4u|e.1V.3h;if(1a.1m.1z==e.1k.cE)i&e.1V.6d&&1a.1T("hh \'ac\' 5V in 3g 1W"),i&e.1V.7v&&1a.1T("6d iv iq as a 7R"),i|=e.1V.6d;1y if(1a.1m.1z==e.1k.bv)i&e.1V.7v&&1a.1T("hh \'6q\' 5V in 3g 1W"),i&e.1V.6d&&1a.1T("7v iv iq as a 9t"),i|=e.1V.7v;1y if(1a.1m.1z==e.1k.ej)i&l&&1a.1T("oE 6X 3G 2g be eF to 3g 1p"),i|=e.1V.3h;1y if(1a.1m.1z==e.1k.ei)i&l&&1a.1T("oE 6X 3G 2g be eF to 3g 1p"),i|=e.1V.4u;1y if(1a.1m.1z==e.1k.io)i&e.1V.3x&&1a.1T("oE 6X 3G 2g be eF to 3g 1p"),i|=e.1V.3x;1y if(1a.1m.1z==e.1k.l7)i!=r&&1a.1T("oC 3G 2g 8h 6X"),1a.wZ(u,n,i),f=!1,s=!0;1y if(a||1a.1m.1z==e.1k.3j||e.cO(1a.1m)){1c c=a?i&e.1V.6d?"ac":"6q":1a.1m.3b(),h=1h e.3R(c);h.1u=1a.1l.1X,h.1x=1a.1l.1F,a?(i^=i&e.1V.6d?e.1V.6d:e.1V.7v,a=!1):1a.1m=1a.1l.1N();if(1a.1m.1z==e.1k.3y)1a.x0(h,u,n,i),f=!1;1y{(i&e.1V.6d||i&e.1V.7v)&&1a.1T("3k 8w 8F be x9");1c p=1a.ij(h,u,!1,n,i);p.2m&&p.2m.1o==e.1f.2t?1a.1m.1z==e.1k.3H&&(f=!1):p.2m&&p.2m.1o==e.1f.7c&&1a.1m.1z!=e.1k.2R?(f=!1,p.2m.1M|=e.2M.ku):1a.1m.1z!=e.1k.2R&&(1a.1T("2u \';\'"),f=!1)}s=!0}1y 1a.1m.1z==e.1k.ig?1a.1T("iz 3g xr 8F be 5K xt 4m in a 3g dF"):!a&&(i&e.1V.6d||i&e.1V.7v)&&1a.1m.1z==e.1k.3y||1a.1m.1z==e.1k.2S?(a=!0,f=!1):1a.1m.1z!=e.1k.2R&&(1a.1T("oM \'"+1a.1m.3b()+"\' in 3g dF"),s=!0);f&&(1a.1m=1a.1l.1N()),s&&(i=r,u=1a.1l.1X,s=!1)}1c d=1a.1l.1F;1a.1m.1z==e.1k.3H&&(1a.4n.8E.1p.1n||(1a.4n.5s=1a.4Z()),1a.1m=1a.1l.1N()),1a.4X--,1a.4n.1p.1u=o,1a.4n.1p.1x=d,1a.4n.1x=d,1a.4n=1g},i.1e.wZ=1b(t,n,r){1a.9o=!0;1c i=1a.5w||e.1s(r,e.1V.2s),s=1h e.3X,o=!1,u=1a.4Z();1a.1m=1a.1l.1N();if(1a.1m.1z==e.1k.3y){o=1a.gf(n,s,!0,i,!1,!1,!1,1g);if(s.1p.1n>0)1c a=s.1p[s.1p.1n-1]}1c f=i||1a.1m.1z==e.1k.2R;if(f)1w(1c l=0;l\'",n);if(o==1g)3S(1a.1m.1z){1t e.1k.3y:f=1a.1l.1F;1c d=1a.1l.od().1z;1a.1m=1a.1l.1N();1c v=d==e.1k.3y||d==e.1k.2Y||d==e.1k.EQ||d==e.1k.5j;v&&1a.1m.1z==e.1k.3T?(c=!0,1a.1m=1a.1l.1N()):(o=1a.4v(n|e.1v.3T,e.4q.1D,!0,t.4l),l=1a.1l.3a(),c=v&&(o.1o==e.1f.3L||o.1o==e.1f.2Y)&&(1a.1m.1z==e.1k.5j||1a.1m.1z==e.1k.6x)),o&&!c&&(1a.3t(e.1k.3T,"2u \')\'",n),o.7o=!0);1B;1t e.1k.7w:1c m=1a.1m;1a.1m=1a.1l.1N(),o=1h e.mh(m.4k),o.1u=f,l=1a.1l.3a();1B;1t e.1k.6a:o=1h e.gN(1a.1m.3b()),1a.1m=1a.1l.1N(),o.1u=f,l=1a.1l.3a();1B;1t e.1k.av:1c g=1a.1m;o=1h e.rK(g.gc),1a.1m=1a.1l.1N(),o.1u=f,l=1a.1l.3a();1B;1t e.1k.7B:f=1a.1l.1X,1a.1m=1a.1l.1N(),o=1a.ri(e.1v.6R|n),o.1u=f,l=1a.1l.1F,1a.3t(e.1k.6R,"2u \']\'",n);1B;1t e.1k.4N:f=1a.1l.1X,1a.1m=1a.1l.1N();1c y=1a.rf(e.1v.3H|n);1a.3t(e.1k.3H,"2u \'}\'",n),o=1h e.bS(e.1f.7c,y),o.1u=f,l=1a.1l.3a(),y.1u=f,y.1x=l;1B;1t e.1k.hj:f=1a.1l.1X,1a.1m=1a.1l.1N();1c b=1a.cQ(e.1v.3U,!1);1a.3t(e.1k.eI,"2u \'>\'",n),o=1h e.bS(e.1f.ff,1a.4v(n,e.4q.8y,!1,t.4l)),o.9X=b;1B;4G:if(1a.ev&&e.1s(1a.ev.1M,e.2M.ke))c=!0,o=1a.ev;1y{1a.1T("BX BZ of 8B ca");if(1a.4A){1c w=1h e.6p;w.1u=f,w.1M|=e.2M.2k,1a.6N(n|e.1v.uK),1a.1m.1z==e.1k.3j||e.5z(1a.1m,1a.5a)?(w.1G=1a.1m.3b(),1a.1m=1a.1l.1N(),l=1a.1l.3a()):l=1a.1l.3a(),o=w}}}c&&(1a.1m.1z==e.1k.a5||1a.1m.1z==e.1k.5j||1a.1m.1z==e.1k.2Y||1a.1m.1z==e.1k.3T?(o=1a.dU(n,!1,!1,!1,1g,!1,!1,!1,e.1V.1q,{l1:o}),o.1S|=e.1O.aH,o.1S|=e.1O.8v,o.1u=f,l=1a.1l.3a(),o.1x=l):o&&(o.7o=!0)),u&&i!=t.4l&&(i|=t.kh);1c E=1a.rE(n,o,r,a,i,f,l);if(E){if(u&&E.1o==e.1f.7y){1c S=E;S.2f==1g&&(E=1a.l2(E))}1d E.1u=f,E.1x=e.cI(E.1x,1a.1l.3a()),E}1d 1h e.5y(e.1f.2k)},i.1e.4v=1b(n,r,i,s){1c o=1g,u=e.eo(1a.1m.1z),a=!0,f=1g,l=1a.1l.1X,c=1a.4Z(),h=!1;if(u!=2i&&u.eO!=e.1f.1q){a=!1,1a.1m=1a.1l.1N();1c p=1a.4v(e.1v.3U|n,u.rG,i,t.4l);if(u.eO==e.1f.co&&p.1o==e.1f.7w)o=p;1y if(u.eO==e.1f.ci&&p.1o==e.1f.7w){1c d=p;d.4k=-d.4k,d.4k==0&&(d.nQ=!0),o=p}1y o=1h e.bS(u.eO,p),o.1x=p.1x;o.1u=l}1y{o=1a.oe(e.1v.3U|e.1v.gB|n,!0,s,!1);1c v,m;if(o.1o==e.1f.3L)v=o,f=v.1G;1y if(o.1o==e.1f.4H){1c g=!1;if(1a.9n&&(1a.1m.1z==e.1k.5j||1a.1m.1z==e.1k.2S)&&1a.9o&&1a.4X==1a.4n.nt&&o.2l.1o==e.1f.e7&&o.2f.1o==e.1f.3L){1c y=o.2f;1a.4n.mf[y.1G]||(o=1a.ij(y,o.1u,!0,n,e.1V.4u),g=!0)}if(!g){m=o;3q(m.1o==e.1f.4H){1c b=m;m=b.2f}m.1o==e.1f.3L&&(v=m,f=v.1G)}}if(!1a.1l.bl()&&(1a.1m.1z==e.1k.bh||1a.1m.1z==e.1k.bV)){a=!1;1c w=o;o=1h e.bS(1a.1m.1z==e.1k.bh?e.1f.fo:e.1f.fn,w),o.1x=1a.1l.1F,o.1u=w.1u,1a.1m=1a.1l.1N()}}1w(;;){u=e.eo(1a.1m.1z);if(u==2i||u.eP==e.1f.1q)1B;if(!i&&u.eP==e.1f.aB)1B;if(u.hb==e.4q.2S){if(u.hb0&&e.6w.lG(1a.b8);1c t=1a.fT[1a.9G];if(t===2i){t="";1w(1c n=0;n<1a.9G;n++)t+=1a.sY;1a.fT[1a.9G]=t}1a.b8+=t},t.1e.vx=1b(e){1a.b8+=e},t.1e.vq=1b(e){1a.b8+=e,1a.4F.3D(1a.b8),1a.b8=""},t}();e.o7=t,e.o5=n,e.o4=r})(2c||(2c={}));1c 2c;(1b(e){1b r(){e.t6(),t[e.lJ]=e.2G[e.1k.3y],t[e.lK]=e.2G[e.1k.3T],t[e.tc]=e.2G[e.1k.2Y],t[e.jo]=e.2G[e.1k.2R],t[e.i2]=e.2G[e.1k.7B],t[e.lL]=e.2G[e.1k.6R],t[e.te]=e.2G[e.1k.6v],t[e.tf]=e.2G[e.1k.6x],t[e.lM]=e.2G[e.1k.4N],t[e.lN]=e.2G[e.1k.3H],t[e.ti]=e.2G[e.1k.5j],e.gg=1h e.2h;1w(1c r in e.1k.1r)r<=e.1k.lO&&e.gg.4L(e.1k.1r[r].yI(),r);1w(1c i=0;i<8Z;i++)s(i)?n[i]=!0:n[i]=!1}1b i(t,n){1d t==e.i2||t==e.lM||t==e.lJ?n+1:t==e.lL||t==e.lN||t==e.lK?n-1:n}1b s(t){1d t>=97&&t<=yJ||t>=65&&t<=90||t==e.tk||t==e.tl}1b o(e){1d e>=48&&e<=57}1b u(e){1d n[e]||o(e)}1b a(t){1d t==e.lL?e.i2:t==e.lN?e.lM:t==e.lK?e.lJ:0}1b b(e){1d E(e,!0,!1)}1b w(e,t){1d E(e,!1,t)}1b E(t,n,r){if(!(t.1z<=e.1k.lO))1d!1;1c i=e.eo(t.1z);if(i==2i)1d!1;1c s=e.f4.o2|e.f4.nY;r&&(s|=e.f4.dw);if(n||!e.1s(i.tv,s))1d!0}1b S(e,t){if(t===-1)1d 0;1c n=0,r=e.1n-1;3q(n>1;t0&&(e.2K=r,e.3c=t-n[r])}1b T(e,t){1c n={2K:-1,3c:-1};1d x(n,t,e.2v.5x),n.3c>=0&&n.3c++,n}1b N(e,t,n){1d e.2v.5x[t]+(n-1)}e.f5=-1,e.f8=10,e.lT=13,e.tC=9,e.tD=11,e.tE="e".2L(0),e.tH="E".2L(0),e.tL="x".2L(0),e.tM="X".2L(0),e.nW="a".2L(0),e.tQ="A".2L(0),e.nU="f".2L(0),e.tY="F".2L(0),e.tZ="g".2L(0),e.u0="m".2L(0),e.u1="i".2L(0),e.iH="0".2L(0),e.lW="9".2L(0),e.u4="8".2L(0),e.u6="7".2L(0),e.nP="\\\\".2L(0),e.zM="#".2L(0),e.u8="!".2L(0),e.ub=\'"\'.2L(0),e.ud="\'".2L(0),e.uf="%".2L(0),e.nJ="&".2L(0),e.lJ="(".2L(0),e.lK=")".2L(0),e.lY="+".2L(0),e.lZ="-".2L(0),e.m0="*".2L(0),e.iF="/".2L(0),e.um="^".2L(0),e.tc=",".2L(0),e.f9=".".2L(0),e.nI="<".2L(0),e.6o="=".2L(0),e.ip=">".2L(0),e.tf="?".2L(0),e.i2="[".2L(0),e.lL="]".2L(0),e.Ac="6B".2L(0),e.lM="{".2L(0),e.lN="}".2L(0),e.nA="|".2L(0),e.te="~".2L(0),e.ti=":".2L(0),e.jo=";".2L(0),e.tl="6B".2L(0),e.tk="$".2L(0),e.i7=32,e.gg=2i;1c t=1h 2T(8Z),n=1h 2T(8Z);e.Af=r,e.Ah=i,e.Ai=s,e.Ak=o,e.Al=u,e.Am=a,1b(e){e.1r=[],e.1r[0]="8K",e.8K=0,e.1r[1]="fj",e.fj=1,e.1r[2]="ib",e.ib=2}(e.nz||(e.nz={}));1c f=e.nz;(1b(e){e.1r=[],e.1r[0]="8K",e.8K=0,e.1r[1]="ia",e.ia=1})(e.m6||(e.m6={}));1c l=e.m6;(1b(e){e.1r=[],e.1r[0]="9T",e.9T=0,e.1r[1]="b9",e.b9=1})(e.gt||(e.gt={}));1c c=e.gt;(1b(e){e.1r=[],e.1r[0]="9T",e.9T=0,e.1r[1]="5M",e.5M=1})(e.nx||(e.nx={}));1c h=e.nx,p=1b(){1b e(e){1a.1G=e}1d e.1e.3b=1b(e,t){1d 1a.1G.3e(e,t)},e.1e.aY=1b(){1d 1a.1G.1n},e}();e.gY=p;1c d=1b(){1b e(e,t,n){1a.7J=e,1a.fm=t,1a.cp=n}1d e.1e.2L=1b(e){1d 1a.cp.2L(e-1a.7J)},e.1e.3e=1b(e,t){1d 1a.cp.3e(e-1a.7J,t-1a.7J)},e}();e.AG=d;1c v=1b(){1b e(e,t){1a.6z=e,1a.eb=t}1d e.1e.2L=1b(e){1d 1a.6z.7J<=e&&e<1a.6z.fm?1a.6z.cp.2L(e-1a.6z.7J):1a.eb.cp.2L(e-1a.eb.7J)},e.1e.3e=1b(e,t){1d 1a.6z.7J<=e&&t<=1a.6z.fm?1a.6z.cp.3e(e-1a.6z.7J,t-1a.6z.7J):1a.eb.cp.3e(e-1a.eb.7J)+1a.6z.cp.3e(0,t-1a.6z.7J)},e}();e.AK=v;1c m=1b(){1b t(e){1a.nw=e,1a.8A=1h v(t.nu,t.nu),1a.9u=1a.nw.aY()}1d t.nu=1h d(0,0,""),t.1e.cI=1b(e,t){1d e>=t?e:t},t.1e.p4=1b(e,t){1d e<=t?e:t},t.1e.nr=1b(t,n){if(1a.8A.6z.7J<=t&&n<=1a.8A.6z.fm)1d 1a.8A.6z;if(1a.8A.eb.7J<=t&&n<=1a.8A.6z.fm)1d 1a.8A;1c r=1a.8A.6z,i=r.fm,s=e.cI(i+bY,n);s=e.p4(s,1a.9u);1c o=1a.nw.3b(i,s),u=1h d(i,s,o);1d 1a.8A.eb=r,1a.8A.6z=u,1a.8A},t.1e.2L=1b(e){1d 1a.nr(e,e+1).2L(e)},t.1e.3e=1b(e,t){1d 1a.nr(e,t).3e(e,t)},t}();e.AW=m;1c g=1b(){1b t(){1a.me=1g,1a.aT=1g,1a.mg=1g,1a.me=1g,1a.nq=0,1a.v7=1h 2T,1a.cU=1,1a.2K=1,1a.3c=0,1a.bO=l.8K,1a.6j=1h 2T}1d t.1e.od=1b(){1d 1a.me},t.1e.Bb=1b(){1a.nq=0},t.1e.va=1b(t,n){1a.v7[1a.nq++]=1h e.vb(t,n.1X,n.1F)},t.1e.1N=1b(){1a.cd=1a.2K,1a.1X=1a.3c;if(1a.a2==1a.9v.1n){if(!(1a.2K<1a.5x.1n))1d e.2G[e.1k.5I];1a.2K++,1a.3c=0,1a.a2=0,1a.9v=1a.nm[1a.2K]}if(1a.a2<1a.9v.1n){1a.me=1a.aT.1m,1a.mg=1a.aT,1a.aT=1a.9v[1a.a2++];1c t=1a.aT.1m;1d 1a.1F=1a.aT.1x,1a.3c+=1a.aT.1x-1a.aT.1u,1a.1X=1a.aT.1u,1a.cU=1a.2K,t}1d e.2G[e.1k.5I]},t.1e.Bz=1b(e){1a.2K=S(1a.5x,e),1a.a2=0;1c t=e-1a.5x[1a.2K];3q(1a.BJ[1a.2K]==l.ia&&1a.2K>0)1a.2K--,t=0;1c n=1a.5x.1n-1;1a.9v=1a.nm[1a.2K];3q(1a.9v.1n==0&&1a.2K1a.9v[1a.a2].1x)1a.a2++;if(1a.a2<1a.9v.1n)1d 1a.3c=1a.9v[1a.a2].1u,1a.3c+1a.5x[1a.2K]}1d-1},t.1e.3a=1b(){1d 1a.mg!==1g?1a.mg.1x:0},t.1e.bl=1b(){1d 1a.cU!=1a.cd},t.1e.mi=1b(e){1a.6j.4b(e)},t.1e.kH=1b(){1c e=1a.6j;1d 1a.6j=[],e},t.1e.oX=1b(e){1c t=1g;3q(1a.6j.1n>0&&1a.6j[0].2K==e)t==1g?t=[1a.6j.mj()]:t=t.4E([1a.6j.mj()]);1d t},t.1e.lD=1b(){1a.6j=[]},t.1e.gu=1b(e,t){},t}();e.BY=g;1c y=1b(){1b i(){1a.cU=1,1a.2K=1,1a.3c=0,1a.1F=0,1a.1X=0,1a.9u=0,1a.5x=[],1a.ch=e.f5,1a.bO=l.8K,1a.8x=c.b9,1a.fw=!0,1a.8g=!1,1a.bR=0,1a.4U=0,1a.4R=0,1a.6j=1h 2T,1a.ml=1g,1a.fE=e.2G[e.1k.5I],1a.ni=1a.3c,1a.cd=1a.2K,1a.5x[1]=0,e.gg||r()}1d i.1e.od=1b(){1d 1a.fE},i.1e.gu=1b(e,t){1a.8x=t,1a.fw=1a.8x===c.9T,1a.1F=0,1a.bR=0,1a.1X=0,1a.2K=1,1a.3c=0,1a.ni=1a.3c,1a.cd=1a.2K,1a.9u=0,1a.5H=e.3b(0,e.aY()),1a.9u=1a.5H.1n,1a.5x=[],1a.5x[1]=0,1a.6j=[],1a.4U=0,1a.4R=0},i.1e.Ca=1b(e){1a.ml=e},i.1e.vw=1b(e,t){1a.gu(1h p(e),t)},i.1e.Cc=1b(e){1a.fw=e},i.1e.Cd=1b(){1d 1a.bO},i.1e.Ce=1b(t,n){1a.bO=n;1c r=1h 2T;1a.vw(t,c.9T);1c i=1a.1N();3q(i.1z!=e.1k.5I)r[r.1n]=i,i=1a.1N();1d r},i.1e.dy=1b(){1a.1X=1a.1F,1a.cd=1a.2K,1a.ni=1a.3c,1a.8g=!1},i.1e.aS=1b(){1d 1a.1F<1a.9u?1a.5H.2L(1a.1F):e.f5},i.1e.4J=1b(t){1d t<1a.9u?1a.5H.2L(t):e.f5},i.1e.vB=1b(t){1d t>=e.iH&&t<=e.lW||t>=e.tQ&&t<=e.tY||t>=e.nW&&t<=e.nU},i.1e.vC=1b(t){1d t>=e.iH&&t<=e.u6||t>=e.nW&&t<=e.nU},i.1e.vE=1b(){1c t=!1;1w(;;){if(!1a.vB(1a.ch))1d t?1h e.bI(vG(1a.5H.3e(1a.1X,1a.1F))):1g;1a.3Y(),t=!0}},i.1e.vJ=1b(){1c t=!1;1w(;;){if(!1a.vC(1a.ch))1d t?1h e.bI(vG(1a.5H.3e(1a.1X,1a.1F))):1g;1a.3Y(),t=!0}},i.1e.mr=1b(t){1c n=!1,r=1a.1F,i=1a.3c;1w(;;)if(o(1a.ch))n=!0,1a.3Y();1y if(1a.ch==e.f9){if(t!=f.8K)1d n?1h e.bI(he(1a.5H.3e(1a.1X,1a.1F))):(1a.1F=r,1a.3c=i,1g);1a.3Y(),t=f.fj}1y if(1a.ch==e.tE||1a.ch==e.tH)if(t==f.8K){if(!n)1d 1a.1F=r,1a.3c=i,1g;n=!1,1a.3Y(),t=f.ib}1y{if(t!=f.fj)1d n?1h e.bI(he(1a.5H.3e(1a.1X,1a.1F))):(1a.1F=r,1a.3c=i,1g);1a.3Y(),t=f.ib,n=!1}1y{if(1a.ch!=e.lY&&1a.ch!=e.lZ)1d n?1h e.bI(he(1a.5H.3e(1a.1X,1a.1F))):(1a.1F=r,1a.3c=i,1g);if(t!=f.ib)1d t==f.fj?1h e.bI(he(1a.5H.3e(1a.1X,1a.1F))):n?1h e.bI(he(1a.5H.3e(1a.1X,1a.1F))):(1a.1F=r,1a.3c=i,1g);if(!!n)1d 1a.1F=r,1a.3c=i,1g;1a.3Y()}},i.1e.vP=1b(){if(1a.aS()!=e.iH)1d 1a.mr(f.8K);3S(1a.4J(1a.1F+1)){1t e.tL:1t e.tM:1d 1a.5g(2),1a.vE();1t e.u4:1t e.lW:1t e.f9:1d 1a.mr(f.8K);4G:1d 1a.vJ()}},i.1e.vT=1b(){1d 1a.mr(f.fj)},i.1e.n6=1b(){1a.3c=0,1a.8x==c.b9&&(1a.2K++,1a.5x[1a.2K]=1a.1F+1)},i.1e.n4=1b(){1c t;1a.bO=l.ia;3q(1a.1F<1a.9u){if(1a.ch==e.m0){t=1a.4J(1a.1F+1);if(t==e.iF)1d 1a.5g(2),1a.8x==c.b9&&1a.dy(),1a.bO=l.8K,!0}1y if(1a.ch==e.f8){1a.n6();if(1a.8x==c.9T)1d 1a.3Y(),!1}1a.3Y()}1d!1},i.1e.mi=1b(e){1a.6j.4b(e)},i.1e.kH=1b(){1c e=1a.6j;1d 1a.6j=[],e},i.1e.oX=1b(e){1c t=1g;3q(1a.6j.1n>0&&1a.6j[0].2K==e)t==1g?t=[1a.6j.mj()]:t=t.4E([1a.6j.mj()]);1d t},i.1e.lD=1b(){1a.6j=[]},i.1e.dC=1b(t){1d t==e.f8||t==e.lT||t==vX||t==vY},i.1e.vZ=1b(){3q(1a.1F<1a.9u){if(1a.dC(1a.ch))1B;1a.3Y()}1a.8x==c.b9&&1a.dy()},i.1e.CQ=1b(){1d 1a.5H.3e(1a.1X,1a.1F)},i.1e.w0=1b(){1c t=1a.1F,n=1a.5H.2L(t),r=0,i=!1;3q(!1a.dC(n)&&t<1a.9u){if(n==e.iF&&!i)1d t;r=n,t++,i?i=!1:i=r==e.nP,n=1a.5H.2L(t)}1d-1},i.1e.w2=1b(){if(e.7Z[1a.fE.1z]!=2i)1d 1g;1c t=1a.1F,n=1a.3c,r=1a.w0();if(r>0){1c i=1a.5H.3e(t,r),s="";1a.1F=r+1,1a.ch=1a.aS();1c o=1a.1F;3q(1a.ch==e.u1||1a.ch==e.tZ||1a.ch==e.u0)1a.3Y();if(1a.1F-o>3)1d 1g;s=1a.5H.3e(o,1a.1F);1c u=2i;9Y{u=1h hB(i,s)}7X(a){}if(u)1d 1a.3c=n+(1a.1F-1a.1X),1h e.w7(u)}1d 1a.1F=t,1a.3c=n,1g},i.1e.bl=1b(){1d 1a.cU!=1a.cd},i.1e.3a=1b(){1d 1a.8g?1a.bR:1a.1X},i.1e.5g=1b(e){1a.1F+=e,1a.3c+=e,1a.ch=1a.aS()},i.1e.3Y=1b(){1a.1F++,1a.3c++,1a.ch=1a.aS()},i.1e.1N=1b(){if(1a.bO==l.ia&&1a.fw){1a.ch=1a.aS();1c t=1a.2K;1a.n4();if(1a.1X<1a.1F){1c n=1a.5H.3e(1a.1X,1a.1F);1d 1a.dy(),1h e.mv(e.1k.7W,n,!0,1a.1X,t,!0)}1d e.2G[e.1k.5I]}1d 1a.cU=1a.2K,1a.fE=1a.wd(),1a.ml&&1a.ml.va(1a.fE,1a),1a.fE},i.1e.wd=1b(){1c r;1a.dy(),1a.ch=1a.aS();3q(1a.1F<1a.9u){if(n[1a.ch]){do 1a.3Y();3q(n[1a.ch]||o(1a.ch));1c i=1a.5H.3e(1a.1X,1a.1F),s;1d(s=e.gg.4r(i))!=1g?e.2G[s]:1h e.n3(e.1k.3j,i)}if(1a.ch==e.i7){1a.8g||(1a.bR=1a.1F);do 1a.3Y();3q(1a.ch==e.i7);if(1a.8x==c.9T){1c u=1a.5H.3e(1a.1X,1a.1F);1d 1h e.rb(e.1k.dh,u)}1a.dy(),1a.8g=!0}1y if(1a.ch==e.iF){1a.3Y();1c a;if(1a.ch==e.iF){1a.8g||(1a.bR=1a.1F-1);1c f=1a.1F-1,l=1a.2K;1a.vZ();1c a=1a.5H.3e(f,1a.1F),h=1h e.mv(e.1k.7W,a,!1,f,l,!1);if(1a.fw)1d 1a.1X=f,h;1a.mi(h),1a.8g=!0}1y{if(1a.ch!=e.m0){1c d=1a.w2();1d d?d:1a.4J(1a.1F)==e.6o?(1a.3Y(),e.2G[e.1k.bc]):e.2G[e.1k.aC]}1a.8g||(1a.bR=1a.1F-1);1c f=1a.1F-1,l=1a.2K;1a.3Y(),1a.n4();1c a=1a.5H.3e(f,1a.1F),p=1a.aS()==e.f8||1a.aS()==e.lT,h=1h e.mv(e.1k.7W,a,!0,f,l,p);if(1a.fw)1d 1a.1X=f,h;1a.mi(h),1a.8g=!0}}1y{if(1a.ch==e.jo)1d 1a.3Y(),e.2G[e.1k.2R];if(1a.ch==e.ud||1a.ch==e.ub){1c v=1a.ch,m=0,g=!1;do m=1a.ch,g?g=!1:g=m==e.nP,1a.3Y();3q(1a.ch!=e.f5&&(g||1a.ch!=v));1d 1a.ch!=e.f5&&1a.3Y(),1h e.n3(e.1k.6a,1a.5H.3e(1a.1X,1a.1F))}if(t[1a.ch]){1c y=t[1a.ch];1d y.1z==e.1k.4N?1a.4U++:y.1z==e.1k.3H&&1a.4R++,1a.3Y(),y}if(1a.ch>=e.iH&&1a.ch<=e.lW)1d r=1a.vP(),r?r:(1a.3Y(),e.2G[e.1k.2k]);3S(1a.ch){1t e.tC:1t e.tD:1a.8g||(1a.bR=1a.1F);if(1a.8x==c.9T){do 1a.3Y();3q(1a.ch==e.i7||1a.ch==9);1c b=1a.5H.3e(1a.1X,1a.1F);1d 1h e.rb(e.1k.dh,b)}1a.8g=!0;1t De:1t Df:1t Dh:1t Dj:1t Dk:1t vX:1t vY:1t e.f8:1t e.lT:if(1a.ch==e.f8){1a.n6();if(1a.8x==c.9T)1d e.2G[e.1k.5I]}1a.8g||(1a.bR=1a.1F),1a.3Y(),1a.dy(),1a.8g=!0;1B;1t e.f9:1d 1a.4J(1a.1F+1)==e.f9?1a.4J(1a.1F+2)==e.f9?(1a.5g(3),e.2G[e.1k.gL]):(1a.3Y(),e.2G[e.1k.4H]):(1a.3Y(),r=1a.vT(),r?r:e.2G[e.1k.4H]);1t e.6o:1d 1a.4J(1a.1F+1)==e.6o?1a.4J(1a.1F+2)==e.6o?(1a.5g(3),e.2G[e.1k.aQ]):(1a.5g(2),e.2G[e.1k.EQ]):1a.4J(1a.1F+1)==e.ip?(1a.5g(2),e.2G[e.1k.a5]):(1a.3Y(),e.2G[e.1k.2S]);1t e.u8:1d 1a.4J(1a.1F+1)==e.6o?1a.4J(1a.1F+2)==e.6o?(1a.5g(3),e.2G[e.1k.aN]):(1a.5g(2),e.2G[e.1k.my]):(1a.3Y(),e.2G[e.1k.ik]);1t e.lY:1d 1a.4J(1a.1F+1)==e.6o?(1a.5g(2),e.2G[e.1k.ap]):1a.4J(1a.1F+1)==e.lY?(1a.5g(2),e.2G[e.1k.bh]):(1a.3Y(),e.2G[e.1k.7z]);1t e.lZ:1d 1a.4J(1a.1F+1)==e.6o?(1a.5g(2),e.2G[e.1k.bf]):1a.4J(1a.1F+1)==e.lZ?(1a.5g(2),e.2G[e.1k.bV]):(1a.3Y(),e.2G[e.1k.ao]);1t e.m0:1d 1a.4J(1a.1F+1)==e.6o?(1a.5g(2),e.2G[e.1k.ba]):(1a.3Y(),e.2G[e.1k.mz]);1t e.uf:1d 1a.4J(1a.1F+1)==e.6o?(1a.5g(2),e.2G[e.1k.b7]):(1a.3Y(),e.2G[e.1k.mA]);1t e.nI:1d 1a.4J(1a.1F+1)==e.nI?1a.4J(1a.1F+2)==e.6o?(1a.5g(3),e.2G[e.1k.b1]):(1a.5g(2),e.2G[e.1k.az]):1a.4J(1a.1F+1)==e.6o?(1a.5g(2),e.2G[e.1k.mB]):(1a.3Y(),e.2G[e.1k.hj]);1t e.ip:1d 1a.4J(1a.1F+1)==e.ip?1a.4J(1a.1F+2)==e.6o?(1a.5g(3),e.2G[e.1k.b0]):1a.4J(1a.1F+2)==e.ip?1a.4J(1a.1F+3)==e.6o?(1a.5g(4),e.2G[e.1k.9S]):(1a.5g(3),e.2G[e.1k.aG]):(1a.5g(2),e.2G[e.1k.b4]):1a.4J(1a.1F+1)==e.6o?(1a.5g(2),e.2G[e.1k.mC]):(1a.3Y(),e.2G[e.1k.eI]);1t e.um:1d 1a.4J(1a.1F+1)==e.6o?(1a.5g(2),e.2G[e.1k.b3]):(1a.3Y(),e.2G[e.1k.8T]);1t e.nA:1d 1a.4J(1a.1F+1)==e.6o?(1a.5g(2),e.2G[e.1k.ab]):1a.4J(1a.1F+1)==e.nA?(1a.5g(2),e.2G[e.1k.aX]):(1a.3Y(),e.2G[e.1k.a3]);1t e.nJ:1d 1a.4J(1a.1F+1)==e.6o?(1a.5g(2),e.2G[e.1k.9N]):1a.4J(1a.1F+1)==e.nJ?(1a.5g(2),e.2G[e.1k.aU]):(1a.3Y(),e.2G[e.1k.a9]);4G:1d e.2G[e.1k.5I]}}}1d e.2G[e.1k.5I]},i}();e.pg=y,e.cO=b,e.5z=w,e.DD=S,e.dn=x,e.DE=T,e.DH=N})(2c||(2c={}));1c 2c;(1b(e){1b n(t,n,r,i,s){1c o=1h e.mD(1g,n.2b,t);o.3N=r,o.9B=i,o.af=s,n.2b=o}1b r(e){e.2b=e.2b.8Y}1b i(e,t){1d e==1g||!e.dT()?t:e}1b s(e){1d e.dT()}1b u(t,r){1c i=t,s=1g,o=1g;i.1C&&i.5c&&(i.1C.2z=i.5c.1A);1c u=i.5c;if(!u)1d;s=1h e.fI(u.1p,u.5E,u.4M,u.4f,u.1A),u.2W=s,r.fL.4b(i),r.2F.1j.4B=i,o=1h e.bH(u.1A),o.8f(s),o.8f(r.2b.2a),n(o,r,1g,1g,1g),u.3v=o,u.1A&&r.2F.gE(u.3v,u.1A,i.bG,u.1p.cK,!0)}1b a(t,r){1c i=t,s=1g,o=1g;i.1C&&i.1i&&(i.1C.2z=i.1i.1A);1c u=t.1i;if(u){1c a=u.1A;s=r.2F.1j.gv(u),o=1h e.bH(u.1A),o.8f(s),o.8f(r.2b.2a),u.3v=o,u.2W=s;1c f=u.3i;s=r.2F.1j.gv(f),f.2W=s,o=1h e.bH(f.1A),o.8f(r.2b.2a),n(o,r,f,u,1g),f.3v=o}1y t.1i=r.2F.1Q}1b f(t,r){1c i=t,s=1g,o=1g;i.1C&&i.1i&&(i.1C.2z=i.1i.1A);1c u=t.1i;s=r.2F.1j.gv(u),u.2W=s,o=1h e.bH(u.1A),o.8f(s),o.8f(r.2b.2a),n(o,r,1g,1g,1g),u.3v=o}1b l(t,r){1c i=t,s=i.1i,o=1h e.4a(1h e.3M(1h e.2h,1h e.2h)),u=1h e.4a(1h e.3M(1h e.2h,1h e.2h)),s=1h e.3z,a=1h e.vF(i.1u,r.2F.1j.2v.3d,s);s.1p=o,s.5E=u,s.1A=a,s.ah(),i.1i=s;1c f=1h e.ai(s.1p,s.5E,1g,1g,r.2b.2a,s.1A);n(f,r,1g,1g,1g),s.3v=f}1b c(t,r){1c i=t,s=1g,o=1g;i.1i&&(o=t.1i.1A);1c u=e.1s(i.1S,e.1O.3x),a=u&&r.2b.af!=1g,f=a?r.2b.af.1i.2W:r.2b.2a;if(r.2b.3N&&(!i.3p||e.1s(i.1S,e.1O.6U))){1c l=r.2b.3N;!(l.4V&e.4w.i4)&&!e.1s(i.1S,e.1O.6U)?!i.4T()||u?f=l.aM:f=l.3v:r.2b.8Y.2a.1R&&r.2b.8Y.2a.1R.1E&&r.2b.8Y.2a.1R.1E.1o==e.1f.2t&&r.2b.8Y.2a.1R.1E.3p?f=l.aM:u&&r.2b.9B?f=r.2b.9B.3v:f=l.3v,s=l.1A}1y i.3p&&r.2b.3N&&(s=r.2b.3N.1A);if(i.1i==1g||e.1s(i.1i.1A.1M,e.2j.qg)){r.2b.af&&r.2b.af.1i&&(s=r.2b.af.1i.1A);1c c=1g,h=r.2b.af,p=i.1C?i.1C.1G:1g,d=1g;u?(h.1i.1p==1g&&s.2N().2W&&(h.1i.1p=s.1i.2W.4p),c=r.2b.af.1i.2W,h.fZ[h.fZ.1n]=i):!i.3p&&s&&s.1E&&s.1E.1o==e.1f.2t&&s.1E.3p&&!i.4T()?c=r.2b.3N.aM:c=r.2b.2a,p&&p!="p6"&&!i.4y()&&(u?d=c.6n(p,!1,!1):d=c.6n(p,!1,!1)),r.2F.1j.cu(i,s,c,d,d==1g);if(!i.7k&&i.1S&e.1O.6U&&s&&(!d||d.1E.1o!=e.1f.2t)&&i.4y()||d&&d.4y())i.7k=r.2F.1j.mH(i,d,s.2N(),i.4T()&&u,!0,c,s);i.1i.1A.1M|=e.2j.qg}i.1C&&i.1i&&(i.1C.2z=i.1i.1A),i.iD=i.1i;if(i.6Z)1d;1c v=1h e.2h,m=1h e.4a(1h e.3M(v,1h e.2h)),g=1h e.2h,y=1h e.4a(1h e.3M(g,1h e.2h)),b=1h e.2h,w=1h e.4a(1h e.3M(b,1h e.2h)),E=1h e.2h,S=1h e.4a(1h e.3M(E,1h e.2h));i.3d=r.2F.1j.2v.3d;1c x=1h e.ai(m,y,1g,1g,f,o),T=1h e.ai(w,S,1g,1g,f,1g);i.3p&&r.2b.3N&&(r.2b.3N.aM=x),i.fP=v;if(!i.aO()){1c N=i.1i,C=i.3F;i.3p||(N.3v=x,x.1R=N.1A,N.2W=T,T.1R=N.1A),i.g2=r.2b.af,N.9E=u?r.2b.9B:r.2b.3N;1c d=t.1i.1A;(i.1S&e.1O.7F)==e.1O.1q&&i.bG&&(r.2F.gE(x,d,i.bG,v,!1),r.2F.gE(T,d,i.c8,b,!1));if(C.2r){1c k=C.2r.1n;1w(1c L=0;L=1&&(s.2F.1j.4B=s.fL[s.fL.1n-1])}1y if(t.1o==e.1f.4K)r(s);1y if(t.1o==e.1f.5h)r(s);1y if(t.1o==e.1f.9K)r(s);1y if(t.1o==e.1f.2t){1c a=t;(!a.3p||e.1s(a.1S,e.1O.6U))&&!a.6Z&&r(s)}1y if(t.1o==e.1f.6l){1c f=t;f.6M&&r(s)}1y o=!1;1d i.2o.4s=o,t}1c t=1b(){1b e(e,t,n){1a.2b=e,1a.2F=t,1a.fL=n}1d e}();e.x3=t,e.EG=n,e.EH=r,e.EI=i,e.EL=s;1c o=1b(){1b e(e,t){1a.x4=e,1a.x5=t,1a.aK=1g}1d e.1e.mV=1b(){1a.aK=1g},e.1e.fQ=1b(e){1d 1a.aK=1a.x4(1a.aK,e),1a.aK?1a.x5(1a.aK):!1},e}();e.EX=o,e.mS=1h o(i,s),e.EZ=u,e.F0=a,e.F2=f,e.F6=l,e.F9=c,e.Fb=h,e.xd=p,e.xe=d})(2c||(2c={}));1c 2c;(1b(e){1b i(t,n,r){1c i=r.5o;1d e.1s(t.1M,i.xf)&&(i.1F<0||i.1F==t.1x)&&(i.3I=t,t.1i==1g&&i.1F>=0&&i.xg.xh(t,i.2a),i.1i=t.1i,i.2o.l9()),t}1b s(t,n,r,i,s,o,u,a,f){1c l=1h e.ai(n,r,i,s,1g,t),c=1h e.mD(t,o.2b,l);c.3N=u,c.9B=a,c.5G=f,o.2b=c}1b o(e){e.2b=e.2b.8Y}1b u(t,n,r){1c i=r.5o,s=t.1u,o=t.1x;t.1o==e.1f.6Y&&i.1F>o&&(o=i.1F);if(s<=i.1F&&o>=i.1F){3S(t.1o){1t e.1f.6Y:1c u=t;i.bL=1b(){1d u.3C===1g?1g:u.3C.kj},i.5Y=u;1B;1t e.1f.4K:i.bL=1b(){1d t.1i===1g||t.1i.3i.3v===1g?1g:t.1i.3i.3v},i.5Y=t,i.fX=t;1B;1t e.1f.7c:1c a=t;a.gT&&(i.bL=1b(){1d a.gT.3v},i.mQ=1b(){1d a.gT.2W},i.mO=a);1B;1t e.1f.4h:i.p2=t,i.bL=1b(){1d t.1i===1g?1g:t.1i.3v},i.5Y=t;1B;1t e.1f.5h:i.bL=1b(){1d t.1i===1g?1g:t.1i.3v},i.5Y=t;1B;1t e.1f.2t:1c f=t;i.mP?i.mP=!1:(i.bL=1b(){1d f.3p&&e.1s(f.1S,e.1O.6U)&&t.1i&&t.1i.9E?t.1i.9E.aM:f.iD?f.iD.3v:f.1i?f.1i.3v:1g},i.5Y=t)}r.2o.4s=!0}1y r.2o.4s=!1;1d t}1b a(t,n,i,s,o){1c a=1h r(t,n,i,s,o);1d e.6f().2d(n,u,1g,1g,a),a.5Y===1g?1g:a}1c t=1b(){1b e(e,t){1a.2b=e,1a.1j=t,1a.aR=1g}1d e}();e.xL=t;1c n=1b(){1b t(t,n,r){1a.xg=t,1a.1F=n,1a.xf=r,1a.1i=1g,1a.3I=1g,1a.2o=1h e.oB}1d t}();e.xO=n;1c r=1b(){1b t(e,t,n,r,i){1a.3n=e,1a.aR=t,1a.1G=n,1a.1F=r,1a.fY=i,1a.bL=1g,1a.mQ=1g,1a.5Y=1g,1a.mP=!1,1a.p2=1g,1a.fX=1g,1a.mO=1g,1a.mL=!0,1a.xT=!1}1d t.1e.g0=1b(){1d 1a.bL()},t.1e.xV=1b(){1d 1a.mQ()},t.1e.yE=1b(){1d 1a.5Y},t.1e.yG=1b(){1d 1a.5Y.1u},t.1e.mT=1b(){1d 1a.5Y},t.1e.y1=1b(){1d 1a.mT().1u},t.1e.y2=1b(){if(1a.mU==1g){1c t=1a.mT(),n=t.1u,r=1a.fY?1a.1F:1a.1F+1;1a.mU=e.gZ(1a.3n,t,1a.1G,n,r,1g).6Y}1d 1a.mU},t}();e.yL=r,e.y5=i,e.mJ=s,e.mG=o,e.yR=u,e.mX=a})(2c||(2c={}));1c 2c;(1b(e){1c t=1b(){1b t(){1a.5Z=!1,1a.2r=1g,1a.1E=1g,1a.4d=e.5t.aD,1a.6r=0}1d t.1e.6m=1b(n,r,i){1c s=1h t;1a.5Z&&(s.5Z=!0),s.2J=1h e.7p,1a.2J.1i?s.2J.1i=1a.2J.1i.6m(n,r,i,!1):s.2J.1i=i.1Q;if(1a.2r){s.2r=[];1w(1c o=0,u=1a.2r.1n;o1&&(n=!1);1w(1c o=0;o1&&1a.2e[o]==1a.dz)3P;1a.1M&e.8C.qX?i[o]=1a.2e[o].mw(n,!0,r):i[o]=t+1a.2e[o].mw(n,!1,r)}1d i},t.1e.6m=1b(e,n,r){1c i=1h t;if(1a.2e)1w(1c s=0,o=1a.2e.1n;s0)1w(1c r=0;r0){1w(1c s=0;s=n.1E.1x:!1}1b r(e,t){3q(e.1R){if(e==t||n(e.1R,t))1d!0;e=e.1R}1d!1}(1b(e){e.1r=[],e.1r[0]="aD",e.aD=0,e.1r[1]="aA",e.aA=1,e.1r[2]="8n",e.8n=2})(e.5t||(e.5t={}));1c t=e.5t;e.zv=n,e.zw=r;1c i=1b(){1b t(t,n,r){1a.1C=t,1a.c1=n,1a.3d=r,1a.qV=!1,1a.1M=e.2j.1q,1a.qw=!1,1a.1E=1g,1a.5D=1g,1a.zx=e.6w.hd}1d t.1e.nb=1b(){1d 1g},t.1e.dP=1b(){1d!1},t.1e.f1=1b(){1d!1},t.1e.dX=1b(){1d!1},t.1e.rq=1b(){1d!1},t.1e.hC=1b(){1d!1},t.1e.8l=1b(){1d!1},t.1e.2N=1b(){1d 1g},t.1e.4y=1b(){1d!1},t.1e.dT=1b(){1d e.1s(1a.1M,e.2j.3k)&&!e.1s(1a.1M,e.2j.9r)},t.1e.3Q=1b(e){1d 1a.5v()},t.1e.g5=1b(){1d e.1s(1a.1M,e.2j.9w)?"?":""},t.1e.nd=1b(){1c t=1h 2T,n=1a;3q(n&&n.1C!=e.f0)t[t.1n]=n,n=n.1R;1d t},t.1e.ne=1b(e){if(1a.1R==1g)1d 1h 2T;1c t=1a.1R.nd(),n;e?n=e.nd():n=1h 2T;1c r=-1;1w(1c i=0,s=t.1n;i=0)1B}1d r>=0?t.ru(0,r):t},t.1e.nf=1b(e){if(e==1g)1d 1a.1C;1c t=1a.ne(e.1R),n="";1w(1c r=0,i=t.1n;r>=",e.1v.3U),s(t.9S,r.1q,n.2S,e.1f.9S,n.1D,e.1f.1q,">>>=",e.1v.3U),s(t.6x,r.1q,n.nK,e.1f.6x,n.1D,e.1f.1q,"?",e.1v.3U),s(t.5j,r.1q,n.1D,e.1f.1q,n.1D,e.1f.1q,":",e.1v.5j),s(t.aX,r.1q,n.nL,e.1f.aX,n.1D,e.1f.1q,"||",e.1v.3U),s(t.aU,r.1q,n.nM,e.1f.aU,n.1D,e.1f.1q,"&&",e.1v.3U),s(t.a3,r.1q,n.nN,e.1f.a3,n.1D,e.1f.1q,"|",e.1v.3U),s(t.8T,r.1q,n.8T,e.1f.8T,n.1D,e.1f.1q,"^",e.1v.3U),s(t.a9,r.1q,n.nO,e.1f.a9,n.1D,e.1f.1q,"&",e.1v.3U),s(t.EQ,r.1q,n.g3,e.1f.Eq,n.1D,e.1f.1q,"==",e.1v.3U),s(t.my,r.1q,n.g3,e.1f.h8,n.1D,e.1f.1q,"!=",e.1v.3U),s(t.aQ,r.1q,n.g3,e.1f.aQ,n.1D,e.1f.1q,"===",e.1v.3U),s(t.aN,r.1q,n.g3,e.1f.aN,n.1D,e.1f.1q,"!==",e.1v.3U),s(t.hj,r.1q,n.cA,e.1f.gr,n.1D,e.1f.1q,"<",e.1v.3U),s(t.mB,r.1q,n.cA,e.1f.gm,n.1D,e.1f.1q,"<=",e.1v.3U),s(t.eI,r.1q,n.cA,e.1f.ge,n.1D,e.1f.1q,">",e.1v.3U),s(t.mC,r.1q,n.cA,e.1f.iy,n.1D,e.1f.1q,">=",e.1v.3U),s(t.az,r.1q,n.gp,e.1f.az,n.1D,e.1f.1q,"<<",e.1v.3U),s(t.b4,r.1q,n.gp,e.1f.b4,n.1D,e.1f.1q,">>",e.1v.3U),s(t.aG,r.1q,n.gp,e.1f.aG,n.1D,e.1f.1q,">>>",e.1v.3U),s(t.7z,r.1q,n.7z,e.1f.7z,n.8y,e.1f.co,"+",e.1v.gB),s(t.ao,r.1q,n.7z,e.1f.ao,n.8y,e.1f.ci,"-",e.1v.gB),s(t.mz,r.1q,n.aq,e.1f.aq,n.1D,e.1f.1q,"*",e.1v.3U),s(t.aC,r.1q,n.aq,e.1f.aC,n.1D,e.1f.1q,"/",e.1v.3U),s(t.mA,r.1q,n.aq,e.1f.hO,n.1D,e.1f.1q,"%",e.1v.3U),s(t.6v,r.1q,n.1D,e.1f.1q,n.8y,e.1f.da,"~",e.1v.cZ),s(t.ik,r.1q,n.1D,e.1f.1q,n.8y,e.1f.fK,"!",e.1v.cZ),s(t.bh,r.1q,n.1D,e.1f.1q,n.8y,e.1f.fu,"++",e.1v.cZ),s(t.bV,r.1q,n.1D,e.1f.1q,n.8y,e.1f.fq,"--",e.1v.cZ),s(t.3y,r.1q,n.1D,e.1f.1q,n.1D,e.1f.1q,"(",e.1v.3y),s(t.7B,r.1q,n.1D,e.1f.1q,n.1D,e.1f.1q,"[",e.1v.7B),s(t.4H,r.1q,n.8y,e.1f.1q,n.1D,e.1f.1q,".",e.1v.4H),s(t.5I,r.1q,n.1D,e.1f.1q,n.1D,e.1f.1q,"<5I>",e.1v.5I),s(t.a5,r.1q,n.1D,e.1f.1q,n.1D,e.1f.1q,"=>",e.1v.1q),e.eo=o,1b(e){e.1r=[],e.1r[0]="nS",e.nS=0,e.1r[1]="hc",e.hc=1,e.1r[2]="h5",e.h5=2,e.1r[3]="7W",e.7W=3,e.1r[4]="dh",e.dh=4,e.1r[5]="3R",e.3R=5,e.1r[6]="aP",e.aP=6}(e.nT||(e.nT={}));1c u=e.nT,a=1b(){1b e(e,t,n){1a.1m=e,1a.1u=t,1a.1x=n}1d e}();e.vb=a;1c f=1b(){1b n(e){1a.1z=e}1d n.1e.5v=1b(){1d"Bx: "+1a.1z+" "+1a.3b()+" ("+t.1r[1a.1z]+")"},n.1e.6E=1b(e,t){t.3D(1a.5v()+",on 2K"+e)},n.1e.3b=1b(){1d e.a8[1a.1z].1G},n.1e.fN=1b(){if(1a.1z<=t.lO)1d u.hc;1c n=o(1a.1z);if(n!=2i)if(n.eO!=e.1f.1q||n.eP!=e.1f.1q)1d u.h5;1d u.nS},n}();e.BB=f;1c l=1b(e){1b n(n){e.1K(1a,t.7w),1a.4k=n}1d 2B(n,e),n.1e.3b=1b(){1d 1a.4k.5v()},n.1e.fN=1b(){1d u.aP},n}(f);e.bI=l;1c c=1b(e){1b n(t,n){e.1K(1a,t),1a.4k=n,1a.1z=t}1d 2B(n,e),n.1e.3b=1b(){1d 1a.4k},n.1e.fN=1b(){1d 1a.1z==t.3j?u.3R:u.aP},n}(f);e.n3=c;1c h=1b(e){1b t(t,n){e.1K(1a,t),1a.4k=n,1a.1z=t}1d 2B(t,e),t.1e.3b=1b(){1d 1a.4k},t.1e.fN=1b(){1d u.dh},t}(f);e.rb=h;1c p=1b(e){1b t(t,n,r,i,s,o){e.1K(1a,t),1a.4k=n,1a.kF=r,1a.1X=i,1a.2K=s,1a.dC=o,1a.BF=t}1d 2B(t,e),t.1e.3b=1b(){1d 1a.4k},t.1e.fN=1b(){1d u.7W},t}(f);e.mv=p;1c d=1b(e){1b n(n){e.1K(1a,t.av),1a.gc=n}1d 2B(n,e),n.1e.3b=1b(){1d 1a.gc.5v()},n.1e.fN=1b(){1d u.aP},n}(f);e.w7=d,e.2G=1h 2T,e.t6=v})(2c||(2c={}));1c 2c;(1b(e){1c t=1b(){1b e(){1a.lV=1g}1d e.1e.ss=1b(e,t){1d 1a.lV==1g&&(1a.lV=e.6m(t.e6.1i,1a.iA.3w,t,!0)),1a.lV},e}();e.BV=t;1c n=1b(){1b t(){1a.nV=!1,1a.1M=e.8V.xI,1a.7E=""}1d t.1e.d9=1b(e){1a.nV?1a.dd(e):1a.7E=1a.7E?e+":\\n "+1a.7E:e},t.1e.dd=1b(e){1a.7E=e},t}();e.ii=n,1b(e){e.1r=[],e.1r[0]="fJ",e.fJ=0,e.1r[1]="ic",e.ic=1}(e.bN||(e.bN={}));1c r=e.bN,i=1b(){1b t(t){1a.1L=t,1a.nZ=1h e.4a(1h e.3M(1h e.2h,1h e.2h)),1a.o0=1h e.4a(1h e.3M(1h e.2h,1h e.2h)),1a.fB=1g,1a.hT=1g,1a.hS=1g,1a.hM=1g,1a.sF=1h e.2h,1a.sG=1h e.2h,1a.sH=1h e.2h,1a.sI=1h e.2h,1a.sJ=!0,1a.5c=1g,1a.4W=1g,1a.e6=1g,1a.lP=1h e.ai(1g,1a.nZ,1g,1a.o0,1g,1g),1a.hK=1h e.3M(1a.sF,1h e.2h),1a.hJ=1h e.3M(1a.sG,1h e.2h),1a.hI=1h e.3M(1a.sH,1h e.2h),1a.hH=1h e.3M(1a.sI,1h e.2h);1c n=1h e.4a(1h e.3M(1a.hK,1h e.2h)),i=1h e.4a(1h e.3M(1a.hI,1h e.2h)),s=1h e.4a(1h e.3M(1a.hJ,1h e.2h)),o=1h e.4a(1h e.3M(1a.hH,1h e.2h));1a.5X=1h e.ai(n,i,s,o,1a.lP,1g),1a.3O=1a.c2(e.7d.9V,"a7"),1a.5B=1a.c2(e.7d.lH,"nR"),1a.6G=1a.c2(e.7d.o6,"cJ"),1a.lP.4f.bJ("cJ",1a.6G.1A),1a.5l=1a.c2(e.7d.hD,"e9"),1a.1Q=1a.c2(e.7d.ft,"8r"),1a.7t=1a.c2(e.7d.9Q,"1g"),1a.6H=1a.c2(e.7d.sV,"2i"),1a.fs(r.fJ),1a.e6=1h e.9I("sX",0,-1,1h e.3z),1a.o0.bJ(1a.e6.1C,1a.e6),1a.5c=1h e.lF(s,o),1a.5c.1p=n,1a.5c.5E=i,1a.5c.3v=1a.5X,1a.4W=1h e.9I(e.f0,0,-1,1a.5c),1a.5c.1p.bJ(1a.4W.1C,1a.4W),1a.sZ("2i",1a.6H)}1d t.1e.c2=1b(t,n){1c r=1h e.3z;r.8Q=t;1c i=1h e.9I(n,0,-1,r);1d i.4d=e.5t.8n,r.1A=i,1a.lP.6W(1g,1g,i,1a.1L,!0,!0,!0),r},t.1e.fs=1b(e){1a.sJ=1a.hK.di=1a.hJ.di=1a.hI.di=1a.hH.di=e==r.fJ},t.1e.t0=1b(){1a.fB=1h e.2h,1a.hT=1h e.2h,1a.hS=1h e.2h,1a.hM=1h e.2h,1a.hK.7m=1a.fB,1a.hJ.7m=1a.hT,1a.hI.7m=1a.hS,1a.hH.7m=1a.hM},t.1e.sZ=1b(t,n){1c r=1h e.7T;r.2H=1h e.7p;1c i=1h e.hW(t,0,-1,r);i.7i(n),i.4d=e.5t.8n,i.1R=1a.4W,1a.nZ.bJ(t,i)},t}();e.t1=i;1c s=1b(){1b e(e,t,n){1a.fr=e,1a.o9=t,1a.lt=n,1a.9Z=1g,1a.CT=1g,1a.oc=1g}1d e}();e.CV=s;1c o=1b(){1b t(e){1a.1j=e,1a.8z=[],1a.8m=!1}1d t.lt=e.5t.8n+1,t.1e.t8=1b(e,n){1a.8z.4b(1h s(e,n,t.lt++)),1a.1j.1L.bi=n},t.1e.t9=1b(){1c e=1a.8z.7a();1d 1a.1j.1L.bi=1a.lm(),1a.8m=1a.8m||e.o9&&1a.1j.1L.sp().1n,1a.1j.1L.sr(),e},t.1e.gR=1b(){1d 1a.8z.1n?1a.8z[1a.8z.1n-1]:1g},t.1e.oi=1b(){1d 1a.8z.1n?1a.8z[1a.8z.1n-1].lt:e.5t.8n},t.1e.lm=1b(){1d 1a.8z.1n?1a.8z[1a.8z.1n-1].o9:!1},t}();e.Dd=o;1c u=1b(){1b n(e){1a.7l=e,1a.1L=1g,1a.ok=!1,1a.ol=!1,1a.om=!1,1a.5r=1g,1a.6e=1g,1a.oo="ko",1a.2v=1g,1a.2F=1g,1a.Dq=1g,1a.Dr=1g,1a.4B=1g,1a.jf=!1,1a.lg=!1,1a.oq=!0,1a.aW=1g,1a.jH=!1,1a.gG=!1,1a.le={},1a.fl={},1a.7Y={},1a.fi=[],1a.3O=1a.7l.3O,1a.5B=1a.7l.5B,1a.5f=1a.7l.6G,1a.5l=1a.7l.5l,1a.1Q=1a.7l.1Q,1a.7t=1a.7l.7t,1a.6H=1a.7l.6H,1a.fB=1a.7l.hK,1a.hT=1a.7l.hJ,1a.hS=1a.7l.hI,1a.hM=1a.7l.hH,1a.wP=1a.7l.5c,1a.4W=1a.7l.4W,1a.e6=1a.7l.e6,1a.5X=1a.7l.5X,1a.8p=1h o(1a)}1d n.1e.tt=1b(e){1a.5r=e},n.1e.ow=1b(e,t){1a.8p.t8(e,t),1a.aW=1a.8p.gR()},n.1e.ox=1b(){1c e=1a.8p.t9();1d 1a.aW=1a.8p.gR(),e},n.1e.8m=1b(){1d 1a.8p.8m},n.1e.la=1b(){1a.8p.gR()||(1a.8p.8m=!1)},n.1e.7P=1b(e,t,n,r){n&&1a.ow(e,1a.8p.lm()||t),1a.2F.1P(r),n&&1a.ox()},n.1e.E3=1b(){1a.aW=1a.8p.gR()},n.1e.oz=1b(){1a.aW=1g,1a.1L.bi=!1},n.1e.fc=1b(){1d 1a.aW&&1a.aW.fr},n.1e.cL=1b(){1d 1a.aW},n.1e.9s=1b(){1d 1a.8p.lm()},n.1e.fa=1b(){1d 1a.9s()?1a.8p.oi():e.5t.8n},n.1e.aw=1b(t){1d t==e.5t.8n||1a.9s()&&t==1a.8p.oi()},n.1e.l8=1b(e){1a.9s()&&(1a.fi[1a.fi.1n]=e)},n.1e.dx=1b(){1w(1c t=0;t<1a.fi.1n;t++)1a.fi[t].4d=e.5t.aD;1a.fi=[]},n.1e.oD=1b(t){if(t.1o==e.1f.6Y){1c n=t;1a.2v=n.2v}1c r=1h e.mD(1a.4W,1g,1a.5X),i=1h e.xL(r,1a);e.6f().2d(t,e.tF,e.tG,1g,i)},n.1e.9x=1b(n){1d n.dE==1g&&(n.dE=1h t,n.dE.iA=1h e.3z,n.dE.iA.3w=n,n.dE.iA.1A=n.1A),n.dE.iA},n.1e.tI=1b(t,n){1c r=1g,i=1g,s=t.1p.1n,o=0,u=[];if(s>0){r=1h e.4a(1h e.3M(1h e.2h,1h e.2h)),i=1h e.ai(r,1g,1g,1g,1g,n);1w(1c a=0;a0;S--)n.1i=1a.9x(n.1i);r&&n.1i==1g&&(n.1i=1a.1Q),n.3I&&(n.3I.1i=n.1i)}},n.1e.oR=1b(e,t){if(e.1n==1)1d{kX:e[0].3F,kV:!1};1c n=e[0],r=1g,i=1g,s=1g,o=1g,u=!1;1w(1c a=1;a=t[f].2r.1n)3P;s=t[f].2r[l].2N(),t[f].1E.8N&&l>=t[f].6r-1&&s.8i()&&(s=s.3w);if(s==1a.1Q)3P;if(n.1p[l].1o==e.1f.2t){if(1a.2F.7n&&s==1a.2F.7n)3P;if(!1a.kI(s,n.1p[l],!0)){if(!1a.kI(s,n.1p[l],!1))1B;1a.2F.1P(n.1p[l]);if(!1a.7C(n.1p[l].1i,s,r))1B}1y{1a.7P(s,!0,!0,n.1p[l]),1a.dx(),a=1a.8m(),1a.7C(n.1p[l].1i,s,r)||(r&&r.dd("eN 2g f3 1i \'"+s.3Q()+"\' to e2 "+(l+1)+", oZ is of 1i \'"+n.1p[l].1i.3Q()+"\'"),o=!0),a&&(u=1a.aW,1a.7P(1g,!0,!0,n.1p[l]),1a.7C(n.1p[l].1i,s)||(o=!0),1a.dx()),1a.la();if(o)1B}}1y if(n.1p[l].1o==e.1f.7c){if(1a.2F.6V&&s==1a.2F.6V)3P;1a.7P(s,!0,!0,n.1p[l]),1a.dx(),a=1a.8m(),1a.7C(n.1p[l].1i,s,r)||(r&&r.dd("eN 2g f3 1i \'"+s.3Q()+"\' to e2 "+(l+1)+", oZ is of 1i \'"+n.1p[l].1i.3Q()+"\'"),o=!0),a&&(1a.7P(1g,!0,!0,n.1p[l]),1a.7C(n.1p[l].1i,s)||(o=!0),1a.dx()),1a.la();if(o)1B}1y if(n.1p[l].1o==e.1f.8X){if(1a.2F.cc&&s==1a.2F.cc)3P;1a.7P(s,!0,!0,n.1p[l]),1a.dx(),a=1a.8m();if(!1a.7C(n.1p[l].1i,s,r)){r&&r.dd("eN 2g f3 1i \'"+s.3Q()+"\' to e2 "+(l+1)+", oZ is of 1i \'"+n.1p[l].1i.3Q()+"\'");1B}a&&(1a.7P(1g,!0,!0,n.1p[l]),1a.7C(n.1p[l].1i,s)||(o=!0),1a.dx()),1a.la();if(o)1B}}l==n.1p.1n&&(i[i.1n]={3F:t[f],8m:a}),a=!1}1d i},n.1e.kI=1b(e,t,n){if(t.7o||t.4T()||n&&t.5m||t.mR)1d!1;n=n||1a.2F.7n==e;if(!n)1d!0;t.3F||(1a.cu(t,1a.2F.2a.1R,1a.2F.2a,1g,1g),1a.2F.1P(t));1c r=t.3F,i=r.2r.1n;1w(1c s=0;s1?!1:!0},n.1e.yu=1b(t,n){if(t==1a.2F.6V)1d!0;1c r=n.2P;if(!r||!t.2W)1d!1;1c i=1g,s=1g,o="",u={};1w(1c a=0;ao&&!n.5Z)1d s&&(s.1M|=e.8V.uT,s.d9("5U 3F yP "+o+" or pd 2r")),!1;1c a=t.2J.1i,f=n.2J.1i;if(f!=1a.3O&&!1a.cq(a,f,r,i,s))1d s&&(s.1M|=e.8V.xK),!1;1c l=u=e.1f.2S&&t.1o<=e.1f.qN){1c a=t;if(a.2l&&a.2l.1o==e.1f.3L){1c l=a.2l;r(l.2z,o)}}1y t.1o==e.1f.2t&&(s.2o.4s=!1);1d t}1c n=1a,r=1b(e,t){if(t.po(e)){1c r=t.pp(e);n.8U[r]=1h 2T,n.km[r]=!0}},i=1b(e,t,r){if(t.po(e)){1c i=t.pp(e);n.8U[i]==2i&&(n.8U[i]=1h 2T);1c s=n.8U[i],o=t.uY(r);t.uZ(i,o),s.4b(o)}},o=1h e.oB;o.es=!0,e.6f().2d(1a.bb.6c,s,1g,o,t)},t.1e.v0=1b(e){1c t=1a.8U.1n,n=e.er.1n;1a.i1=1h i(n);1w(1c r=0;r0)1w(1c o=0,u=s.1n;oe.bC){1a.5n=1h 2T;1c n=m4.ns(1a.dK/e.bC);1w(1c r=0;re},t.1e.v9=1b(){1a.pv++},t.1e.3Z=1b(e){1a.dL[1a.dL.1n]=e,e.b5[e.b5.1n]=1a},t}();e.4Q=s;1c o=1b(){1b t(e,t){1a.2E=e,1a.pw=t,1a.ki=1g,1a.8q=1g,1a.5d=!1,1a.hk=1h 2T,1a.hu=1h 2T,1a.pz=0,1a.e5=1h 2T,1a.ki=1a.2E}1d t.1e.2d=1b(e,t){1d 1a.6O.2d(e,t)},t.1e.rv=1b(e){1a.hu.4b(e)},t.1e.rs=1b(){1d 1a.hu.7a()},t.1e.vf=1b(t){if(1a.8q&&1a.8q.1n>0){1c n=1a.8q.1n;1w(1c r=0;r0){1c o=s.7a();if(!o.iq(i)){o.v9(),e&&e(o);1c u=o.dL.1n;if(u>0){n&&n();1w(1c a=u-1;a>=0;a--){1c f=o.dL[a];f.iq(1a.pz)||(t&&t(o,f),s[s.1n]=f)}r&&r()}}}},t.1e.9j=1b(e,t){1c i=1a,s=1h r;s.mZ=t;1c o=1b(e){e.9j=1h n(e),e.9j.uV(s),i.e5[i.e5.1n]=e};1a.pC(o,1g,1g,1g);1c u,a;1w(u=0,a=1a.e5.1n;u=0&&n.3d<1a.1j.6e.1n?1a.1j.2v=1a.1j.6e[n.3d]:1a.1j.2v=e.n1;3q(f){if(f.4i()==e.4g.3z){1c l=f,c=l.1i;c.1K&&(1a.8G=l.4T);if(c.6P()){1a.3N=c.3i;1B}}f=f.1R}1a.nc(t),1a.2a=a}}1a.2U=r,1a.3N=i,1a.1j.2v=o,1a.8G=s},n.1e.k3=1b(e){if(e.4C)(e.4C.1i==1g||e.4C.1i&&e.4C.1i==1a.1Q&&1a.2a||e.4C.1i.1A==1g||!1a.1j.aw(e.4C.1i.1A.4d))&&1a.1P(e.4C),e.1i=e.4C.1i,e.2z&&e.2z.7i(e.1i);1y if(e.2m==1g){1a.1j.5r.c3&&1a.1j.1L.6D(e,"1i h6 6q to \'8r\'"),e.1i=1a.1Q;if(e.2z){if(e.2z.8l()){1c t=e.2z;if(t.4T){1a.1j.1L.2q(e,"cg 9z eK Ay to 5O. (pH ut uC to 9c \'iE 1b\' vM of \'iE 1c\'?)");1d}1a.1j.1L.2q(e,"cg 9z 1i to 5O");1d}e.2z.7i(e.1i)}}},n.1e.nc=1b(t){1c n=t.2z;if(n==1g)t.2m?(t.2m=1a.1P(t.2m),t.1i=1a.1j.ez(t.2m.1i)):(1a.1j.5r.c3&&1a.1j.1L.6D(t,"1i h6 6q to \'8r\'"),t.1i=1a.1Q);1y if(n.4d==e.5t.aA)1a.1j.5r.c3&&1a.1j.1L.6D(t,"1i h6 6q to \'8r\'"),t.1i=1a.1Q,n.7i(1a.1Q);1y if(n.4d==e.5t.aD){n.4d=e.5t.aA,1a.1j.l8(n);1c r=!1;t.1i==1g&&t.4C&&(1a.k3(t),r=!0,t.1i=t.4C.1i,n.4d=1a.1j.fa());if(t.2m){e.1s(t.1Y,e.1U.2s)&&1a.1j.1L.2q(t,"2s 5O 8u 2g 8h an i6");1c i=e.1s(t.1Y,e.1U.bn),s=1a.2a,o=!t.2m.7o;i&&(1a.2a=t.2z.1R.2N().2W),t.1Y&e.1U.3k&&(1a.hN=!0),1a.1j.7P(t.1i,1a.1j.9s(),o,t.2m),1a.hN&&(1a.hN=!1),1a.2a=s;if(t.1i){1c u=!1,a=1g;t.2m.1i&&(a=t.2m.1i.3v,u=!0,t.2m.1i==1a.3O&&1a.1j.1L.2q(t,"cg vN 1i \'a7\' to 5O \'"+t.id.1G+"\'")),t.2m=1a.hY(t.2m,t.1i,o,!1),u&&t.2m.1i.3v==1g&&(t.2m.1i.3v=a)}1y t.1i=1a.1j.ez(t.2m.1i),t.1i==1a.3O&&(1a.1j.1L.2q(t,"cg vN 1i \'a7\' to 5O \'"+t.id.1G+"\'"),t.1i=1a.1Q);n.7i(t.1i)}1y r||1a.k3(t);n.4d=1a.1j.fa()}1y 1a.1j.aw(n.4d)&&n.1E!=t&&t.2m&&(t.2m=1a.1P(t.2m),t.1i=n.2N(),t.2m=1a.bm(t.2m,t.1i));1d t.id&&t.2z&&(t.id.2z=t.2z),t},n.1e.wr=1b(e){1d 1a.3N&&1a.8G&&!1a.2U.na()&&1a.3N.7U()?e.1i=1a.3N.7U():(e.1i=1a.1Q,1a.1j.1L.tB(e)),e},n.1e.wQ=1b(t){1c n=!1;1a.2U==1g?1a.3N?1a.3s&&1a.3s.5A==e.1f.4K?(n=!0,t.1i=1a.1Q):t.1i=1a.3N:(1a.1j.4B&&1a.1j.1L.2q(t,"\'1a\' 3G 2g be iG bx 6s ls"),t.1i=1a.1Q):((1a.hN||1a.hp)&&1a.3s&&1a.3s.5A==e.1f.4K&&(n=!0),1a.2U.4T()||1a.2U.3p||1a.2U.mM?1a.3N&&!(1a.2U.1S&e.1O.3x)?t.1i=1a.3N:t.1i=1a.1Q:t.1i=1a.1Q);if(!1a.8G&&1a.2U&&e.1s(1a.2U.1S,e.1O.8v))if(1a.2U.mK){1c r=1a.2U.mK.2z.1R;r.1E.1o==e.1f.2t&&r.1E.mI()}1y{1c i=1a.2U.g2,s=i,o=!1;3q(i){if(i.4T()||i.3p||i.ce()){i.mI(),o=!0;1B}i=i.g2}!o&&s&&s.mI(),o&&1a.3N&&(t.1i=1a.3N)}1d n&&1a.1j.1L.2q(t,"hc \'1a\' h4 be iG in xr in a 3g 1W, or in d7 6J AB"),t},n.1e.vO=1b(t,n){if(n.dP()){if(n.dX()){1c r=n;r.1E&&!1a.1j.aw(r.4d)&&1a.k4(r.1E),1a.1j.5r.k0||r.1E&&r.1E.1o==e.1f.3m&&1a.4X=0&&t.3d<1a.1j.6e.1n?1a.1j.2v=1a.1j.6e[t.3d]:1a.1j.2v=e.n1,n.9E?1a.3N=n.9E:1a.3N=l;1c C=i.2r.1n;if(!t.3p&&t.3C&&!t.5T()){1c k=1a.2a,w=1a.2a;if(!t.4T()&&t.5m==1g){if(s&&t.1C&&!t.1C.bu()){1c L=s.e8(t.1C.1G,!1,!1);L&&L.1E&&L.1E.1i&&(1a.1j.ow(L.1E.1i,!1),p=!0)}if(1a.1j.fc()){1c A=1a.1j.cL(),O=A.fr;if(1a.1j.kI(O,t,!0)){1c M=O.2n?O.2n:O.1K;A.9Z=M.2e[0];1c 6B=A.9Z.2r;d=6B,v=A.9Z.2J.1i,A.9Z.1E&&(A.9Z.1E.3p?t.mM=!0:A.9Z.1E.4T()&&(t.mM=!0)),r.1i=A.fr}1y O&&t.4y()?(y=O,A.oc=y):1a.1j.oz()}}1c D=w.4p;1a.2a=1h e.ai(D,1g,1g,1g,s,f);1w(1c P=0;P=d.1n-1?d[d.1n-1].2N().3w:d[P].2N(),j.2z.7i(j.1i),j.2z.4d=1a.1j.fa()}1y 1a.1P(j);g&&y&&(j=1a.bm(j,y)),B.1R=f,D.3E.4L(B.1C,B)}1a.2a=k}1y{1a.1P(t.2p);1w(1c P=0;P1?1a.1j.1L.2q(t,"7y 2e 3G 8O 4e bA 3W"):t.2p.1p[0].1i==1a.1j.5f?n.2O.1M|=e.8C.jc:t.2p.1p[0].1i==1a.1j.5l?n.2O.1M|=e.8C.j9:1a.1j.1L.2q(t,"7y 2e 3G 4e 8O \'e9\' or \'cJ\' as Bm 3W"))}if(t.3C&&!t.5T()){if(!t.3p)1a.w3(f,i,h);1y{1a.q4(t.1i.1A,t.2p,h,e.1s(t.1S,e.1O.6U));if(1a.3s&&1a.3s.2V){1c I=1a.2a,q=1h e.4a(h);1a.2a=1h e.rX(q,s,t.1i.1A,1b(t){1d t.4i()==e.4g.iB}),1a.we(1a.3s.2V),1a.2a=I}}1c R=1a.1j.4B;t.1i&&t.1i.1A&&!t.4T()&&t.1i.1A.5D&&(1a.1j.4B=t.1i.1A.5D),1a.1P(t.3C),1a.1j.4B=R;if(1a.1j.ok){1c U=t.wX();1a.1j.ol&&U.6E(1a.1j.1L.4F),U.vf(1a.1j.1L),1a.1j.om&&U.9j(1a.1j.1L,t.1i.1A)}if(t.3p){1c z=t.c5,W=z.1p.1n,X,V,$=0;1w(;$0){1c K={aY:1b(){1d t.al.1n},kP:1b(e,n){t.al[e].1i=n},hw:1b(e){1d t.al[e].1i}},Q=t.al[0].1i;Q=1a.1j.kN(Q,1g,K);if(Q)i.2J.1i=1a.1j.ez(Q);1y{1w(1c G=0;G0&&t.3C.1p[0].1o==e.1f.cs;Y||1a.1j.1L.2q(t,"aE eu a wi-a7 1d 1i, ks wj no 1d 8B")}p&&1a.1j.ox();if(t.7k){1c y=t.7k.2N();y?(e.1s(t.1S,e.1O.6C)&&y!=i.2J.1i||t.2p.1p.1n>0&&y!=t.2p.1p[0].1i)&&1a.1j.1L.2q(t,"6d 8o 7R 9p do 2g oF"):e.1s(t.1S,e.1O.6C)?t.7k.7i(i.2J.1i):t.2p.1p.1n!=1?1a.1j.1L.2q(t,"Bv 3G 8h bA 8o 4e bA e2"):t.7k.7i(t.2p.1p[0].1i)}1d 1a.jS(n,t),t},n.1e.qb=1b(t){1c n=!1,r=t.2V;if(r){1c i=r.1n;1a.eM=!0,i>0&&(t.4V|=e.4w.jg);1w(1c s=0;s0){1c o=1h e.2h;if(i.8R())1w(1c u=0;u0);i.1p&&i.1p.3E.5p(1b(t,o,u){1c a=o;1w(1c f=0;f=e.1f.2S&&t.1o<=e.1f.qN&&1a.1j.1L.2q(t,"1I-s2 pL 4m in BW 8B")},n.1e.cD=1b(t,n){1a.1j.5r.jQ&&t&&t.1o!=e.1f.5M&&1a.1j.1L.6D(t,n+" bw a bF")},n.1e.s5=1b(e){1d e.3V=1a.1P(e.3V),1a.hZ(e.3V),e.9f=1a.1P(e.9f),e.7Q=1a.1P(e.7Q),1a.cD(e.9f,"if 4m"),1a.cD(e.7Q,"if 4m"),e.1i=1a.3O,e},n.1e.wv=1b(t){1d t.4y()?e.1s(t.1S,e.1O.6C)?t.1i.1K.2e[0].2J.1i:t.1i.1K.2e[0].2r[0].2N():1g},n.1e.u9=1b(t){1c n=1h e.3z;n.1A=1h e.9I(1a.1j.oo,t.1u,1a.1j.2v.3d,n),n.1p=1h e.4a(1h e.3M(1h e.2h,1h e.2h)),n.2W=1h e.fI(n.1p,1g,1g,1g,1g);1c r=1h e.bH(n.1A);r.8f(n.2W),r.8f(1a.2a),n.3v=r;1c i=t.2P,s=1a.3N,o=!1,u=1g;1a.1j.fc()&&(u=1a.1j.cL().fr,u&&u.1A&&!1a.1j.aw(u.1A.4d)&&u.1A.1E&&1a.1P(u.1A.1E),o=!0);if(i)1w(1c a=0,f=i.1p.1n;a0)1w(1c n=0;n=s&&(e.5Z||t.1n<=o)&&(u=e.5Z?e.2r.1n:t.1n,a=!0);1c f=1g;if(a||e.5Z){e.5Z&&(u-=1,f=e.2r[u].3W.2H.1i,f=f.3w,a=t.1n>=u);1c l=t.1n,c=a,h=a;1w(1c p=0;p1,f=1h e.ii,l=1g,c=1g;if(t.1o==e.1f.5U||t.1o==e.1f.bj){1c h=t;l=h.2p,c=h.3A;if(h.2p){1c p=h.2p.1p.1n;1w(1c d=0;d0){1c w=1a.1j.oR(b,l);w.kV&&1a.1j.1L.2q(c,"wx 1K 8B - kw 2g wy wz"),u=w.kX}1y{1c E="C2 2r do 2g C3 8r 3F of 1K 3A";f.7E?1a.1j.1L.2q(c,E+":\\n "+f.7E):1a.1j.1L.2q(c,E)}}1y if(s.1n>1){1c S=[];1w(1c d=0;d=i.6r){n=!0;1c s=1g,o=t.2p.1p.1n=i.6r-1&&(s=s.3w);3S(t.2p.1p[r].1o){1t e.1f.2t:1t e.1f.7c:1t e.1f.8X:1a.1j.7P(s,1a.1j.9s(),!i.2r[r].1E.7o,t.2p.1p[r]);1B;4G:3P}}}}if(!n&&t.2p){1a.1j.oz();1w(r=0;r0?1a.2V[0]:1g},r.1e.pZ=1b(e,t){1d 1a.dE.ss(e,t)},r.1e.6P=1b(){1d 1a.3i!=1g},r.1e.8i=1b(){1d 1a.3w!=1g},r.1e.8R=1b(){1d 1a.1A&&!1a.3w&&1a.1A.1i.6P()},r.1e.kY=1b(){1d 1a.6P()?1a.3i:1a},r.1e.8P=1b(){1d e.1s(1a.4V,e.4w.qO)},r.1e.ah=1b(){1a.4V|=e.4w.qO},r.1e.wR=1b(){1d e.1s(1a.8Q,t.o6)},r.1e.jD=1b(){1d e.1s(1a.8Q,t.hD)},r.1e.wS=1b(){1d e.1s(1a.8Q,t.lH)},r.1e.Cs=1b(){1d e.1s(1a.8Q,t.9Q)},r.1e.3Q=1b(){1d 1a.dI("",!0,!1,1g)},r.1e.8b=1b(e){1d 1a.dI("",!0,!1,e)},r.1e.Ct=1b(e){1d 1a.jz("",!0,!1,e)},r.1e.qu=1b(){1c e=0;1d 1a.1K&&(e+=1a.1K.2e.1n),1a.2n&&(e+=1a.2n.2e.1n),1a.2O&&(e+=1a.2O.2e.1n),e},r.1e.dI=1b(e,t,n,r){1c i=1a.jz(e,t,n,r);1d i.5v()},r.1e.jz=1b(t,r,s,o){if(1a.3w)1d n.9M(1a.3w.jz(t,!1,!0,o),"","[]");if(1a.1A&&1a.1A.1C&&1a.1A.1C!="ko"&&(1a.1K==1g&&1a.2n==1g&&1a.2O==1g||e.1s(1a.4V,e.4w.il)||1a.1p&&!1a.6P())){1c u=1a.1A.nf(o);1d n.9M(u=="1g"?"8r":u)}if(1a.1p||1a.1K||1a.2n){if(e.1s(1a.4V,e.4w.il))1d n.9M("1a");1a.4V|=e.4w.il;1c a="",f=1h i,l=s,c=0,h=0,p="; ";1a.1p&&1a.1p.2Q.5p(1b(t,r,i){1c s=r;if(!e.1s(s.1M,e.2j.q9)){1c u=s.3Q(o);u.1n>=p.1n&&u.3e(u.1n-p.1n)==p&&(u=u.3e(0,u.1n-p.1n)),f.4L(n.9M(u)),h++;if(s.4i()==e.4g.3z){1c a=s.1i;a.qu()>1&&(l=!0)}1y l=!0}},1g);1c d,v,m=0,g=h==0&&1a.qu()==1&&r;g||(f.qs=p);if(1a.1K){d=1a.1K.mt(t,g,o);1w(v=0,m=d.1n;v1&&r)f.jI="{ ",f.jG="}";1d 1a.4V&=~e.4w.il,c==0&&h==0?n.9M("{}"):f}1d n.9M("{}")},r.1e.Cw=1b(e){(1a.8R()||1a.6P())&&1a.1A.1E&&e.2F.k4(1a.1A.1E)},r.1e.jK=1b(e){if(1a==e.1Q)1d 1g;if(1a.wR())1d e.cv?e.cv.2W:1g;if(1a.wS())1d e.cy?e.cy.2W:1g;if(1a==e.5l)1d e.cx?e.cx.2W:1g;if(1a.3w){if(e.cc){1c t=1a.3w.pZ(e.cc,e.1j);1d t.2W}1d 1g}1d 1a.2W},r.1e.jY=1b(){1d 1a.1p||1a.2V||1a.2n||1a.1K||1a.2O||1a.3w},r.1e.6m=1b(t,n,i,s){if(t==1a)1d n;1c o=1a;1d s?1a.jY()&&(o=1h r,1a.1p&&(o.1p=1h e.4a(1h e.3M(1h e.2h,1h e.2h)),1a.1p.3E.5p(1b(e,r,s){1c u=r,a=u.6m(t,n,i);o.1p.bJ(a.1C,a)},1g),1a.1p.cK.5p(1b(e,r,s){1c u=r,a=u.6m(t,n,i);o.1p.nn(a.1C,a)},1g)),1a.5E&&(o.5E=1h e.4a(1h e.3M(1h e.2h,1h e.2h)),1a.5E.3E.5p(1b(e,r,s){1c u=r,a=u.6m(t,n,i);o.5E.bJ(a.1C,a)},1g),1a.5E.cK.5p(1b(e,r,s){1c u=r,a=u.6m(t,n,i);o.5E.nn(a.1C,a)},1g)),o.3v=i.gv(o),o.2W=o.3v):1a.3w?1a.3w==t?o=i.9x(n):1a.3w.3w==t&&(o=i.9x(i.9x(n))):1a.1K&&(o=1h r,o.1K=1a.1K.6m(t,n,i)),o},r.1e.pa=1b(e){if(e==1a)1d!0;if(1a.2V)1w(1c t=0,n=1a.2V.1n;t6&&e.3e(e.1n-6,e.1n)==".d.bU"?e.3e(0,e.1n-6):e.1n>4&&e.3e(e.1n-4,e.1n)==".bU"?e.3e(0,e.1n-4):e.1n>5&&e.3e(e.1n-5,e.1n)==".d.ts"?e.3e(0,e.1n-5):e.1n>3&&e.3e(e.1n-3,e.1n)==".ts"?e.3e(0,e.1n-3):e.1n>3&&e.3e(e.1n-3,e.1n)==".js"?e.3e(0,e.1n-3):e}1b u(e){1d e.1n>4&&e.3e(e.1n-4,e.1n)==".bU"}1b a(e){1d e.1n>3&&e.3e(e.1n-3,e.1n)==".ts"}1b f(e){1d e.1n>6&&e.3e(e.1n-6,e.1n)==".d.bU"}1b l(e){1d e.1n>5&&e.3e(e.1n-5,e.1n)==".d.ts"}1b c(e,n,i){5i n=="2i"&&(n=!0),5i i=="2i"&&(i=!1);1c u=i?s(e):o(t(e)),a=u.cw("/");1d a.1n?n?r(a[a.1n-1]):a[a.1n-1]:e}1b h(e){1c n=o(t(e)),i=b(n);if(i=="")1d e;1c s=n.cw(i),u=s.1n>1?1:0;1d r(s[u])}1b p(e){1d o(t(e))+".bU"}1b d(e){1d o(t(e))+".d.bU"}1b v(e){1d o(t(e))+".ts"}1b m(e){1d o(t(e))+".d.ts"}1b g(e){1d e.dW(0)=="."}1b y(e){1d e.dW(0)=="\\\\"||e.dW(0)=="/"||e.9H(":\\\\")!=-1||e.9H(":/")!=-1}1b b(e){if(e=="")1d e;1c t=e.9H("/")!=-1;1d t?w(e):""}1b w(e){e=s(e);1c t=e.cw("/"),n=t.ru(0,t.1n-1);1d n.j0("/")+"/"}1b E(e){1c t=/^(Cz?:\\/\\/[\\-\\w\\.]+(:\\d+)?\\/)(.*)$/i,n=t.db(e);if(n){1c r=n[1],i=n[3];1d r+S(i)}1d S(e)}1b S(e){e=s(e);1c t=e.dW(0)==="/",n=e.cw("/");1w(1c r=0;r0&&n[r]===".."&&n[r-1]!==".."&&(n.jx(r-1,2),r-=2)}1d(t?"/":"")+n.j0("/")}1b x(e){1d S(e)}e.8k=t,e.gs=n,e.rd=r,e.tT=i,e.dD=s,e.x8=o,e.du=u,e.dr=a,e.sP=f,e.sR=l,e.iV=c,e.yk=h,e.l4=p,e.eR=d,e.qx=v,e.bZ=m,e.ho=g,e.qy=y,e.tW=b,e.CE=w,e.CF=E,e.CG=/\\//g,e.iw=S,e.CH=x})(2c||(2c={}));1c 2c;(1b(e){1c t=1b(){1b e(e,t){1a.5e=e,1a.6c=t}1d e.1e.3b=1b(e,t){1d 1a.6c.3e(e,t)},e.1e.aY=1b(){1d 1a.6c.1n},e}();e.CI=t;1c n=1b(){1b e(e,t){1a.qz=e,1a.x2=t,1a.CL=[],1a.cT=[]}1d e}();e.CM=n;1c r=1b(){1b n(e){1a.jw=e,1a.jt={}}1d n.1e.qC=1b(n,r,i,s){1c o={6c:"",5e:n},u=1a.jw.x2,a=e.ho(n),f=a?!1:e.qy(n),l=a?u.x6(r+"/"+n):f||!r||i?n:r+"/"+n;!e.du(l)&&!e.dr(l)&&(l+=".ts"),l=e.dD(e.8k(l));1c c=1a.jw.qz.x7?l:l.CS();if(!1a.jt[c]){if(a||f||!i)9Y{e.6w.ag(" jq cT a6 "+l);9Y{o.6c=u.jp(l)}7X(h){9Y{e.du(l)?l=e.qx(l):e.dr(l)&&(l=e.l4(l)),e.6w.ag(" jq cT a6 "+l),o.6c=u.jp(l)}7X(h){l=e.eR(l),e.6w.ag(" jq cT a6 "+l);9Y{o.6c=u.jp(l)}7X(h){l=e.bZ(l),e.6w.ag(" jq cT a6 "+l),o.6c=u.jp(l)}}}e.6w.ag(" CW cT at "+l),o.5e=l,1a.jt[c]=!0}7X(h){e.6w.ag(" pH 2g 3u cT 1w "+n)}1y o=u.jm(r,l),o||(e.du(l)?l=e.qx(l):e.dr(l)&&(l=e.l4(l)),o=u.jm(r,l)),o||(l=e.bZ(l),o=u.jm(r,l),o||(l=e.eR(l),o=u.jm(r,l))),o?(o.5e=e.dD(e.8k(o.5e)),e.6w.ag(n+" CY to: "+o.5e),o.6c=o.6c,1a.jt[c]=!0):e.6w.ag("eN 2g 3u "+n);if(o&&o.6c){1c p=u.CZ(o.5e),d=1h t(o.5e,o.6c),v=e.xc(d,1a.jw.qz);1w(1c m=0;m/gD,r=n.db(t);if(r){1c i=e.iw(r[3]),s=e.iw(i),o=r.1n>=7&&r[6]=="d3";1d o&&e.6w.ag(i+" is D7"),{1u:0,1x:0,5e:e.dD(s),9A:o}}1d 1g}1b i(e){1c t=/^(\\/\\/\\/\\s*/gD,n=t.db(e);if(n){1c r=n[3];1d r}1d 1g}1b s(e,t){1c n=/^(\\/\\/\\/\\s*/gD,r=n.db(e);if(r){1c i=/^([a-zA-Z]+=[\'"]on[\'|"])/gD;r=i.db(r[2]);if(r)1w(1c s=0;s/gD,b=y.db(f.3b());b&&(d=b[3]=="d3")}}1d{4j:c,qH:h,qI:p,Di:d}}1c t=1b(){1b e(){1a.pY=!1,1a.jQ=!1,1a.lk=!1,1a.lq=!1,1a.m1=!0,1a.jO=!1,1a.jk=!1,1a.jR=!1,1a.lo=!1,1a.jL=!0,1a.k0=!0,1a.jj=!0,1a.qM=!0,1a.jX=!0,1a.c3=!1}1d e.1e.xk=1b(e,t){1c n=1a[e];1d n!==2i?(1a[e]=t,!0):!1},e.1e.xl=1b(e){1c t=e.cw(";");1w(1c n=0,r=t.1n;n=0){1c u=i.3e(o+1);i=i.3e(0,o),u=="Dm"&&(s=!1)}if(!1a.xk(i,s))1d!1}1d!0},e}();e.Dn=t;1c n=1b(){1b n(){1a.5r=1h t,1a.fx=!1,1a.bP=!1,1a.Do=!1,1a.dv=!0,1a.4A=!1,1a.fy=!1,1a.Dp=!1,1a.db=!1,1a.wq=!0,1a.xm=!1,1a.xn=!1,1a.xo=!1,1a.xp=!0,1a.Du=!0,1a.gG=!1,1a.9n=!1,1a.Dv=!0,1a.7K=e.8a.qo,1a.9l=e.9m.q7,1a.d8="",1a.Dx="",1a.dV=!1,1a.fz=!1,1a.x7=!1}1d n.1e.tt=1b(e){1a.5r.xl(e)},n.1e.DA=1b(e){1a.d8=e,1a.dv=!1},n}();e.xs=n,e.t4=i,e.DC=s,e.xc=o})(2c||(2c={}));1c 2c;(1b(e){1c t=1b(){1b t(t){1a.3n=t,1a.je=1h e.wM(1a.3n)}1d t.1e.xu=1b(t,n,r,i){1a.3n.4S(\'DF("\'+n+\'")\');if(i===1g)3K 1h 2k("fA lU be kU");if(i.xv())1d 1a.3n.4S(" 7I 7S 7N xx pF is n2"),1g;1c s=e.mX(1a.3n,t,r,i.1u,!1),o=e.mX(1a.3n,t,r,i.1x,!1);if(s==1g||o==1g)1d 1a.3n.4S(" 7I 7S 7N su c5 h4 be DM"),1g;if(s.5Y!==o.5Y)1d 1a.3n.4S(" 7I 7S 7N xx DN 2 DP c5"),1g;1c u=s.5Y.1x-s.5Y.1u+i.9L;1d u<=0?(1a.3n.4S(" 7I 7S 7N 2a wj DR DS DT a6 1h bX 1G"),1g):s},t.1e.xy=1b(t,n,r,i){1a.3n.4S(\'xy("\'+n+\'")\');if(i===1g)3K 1h 2k("fA lU be kU");1c s=1a.xu(t,n,r,i);if(s===1g)1d 1g;1c o=s.5Y.1x-s.5Y.1u+i.9L;if(o>=r.aY()/2)1d 1a.3n.4S(" 7I 7S 7N pF of 2a to DW ("+o+" DX) is a0 xz DZ 5K fR of 5K bX 1G"),1g;1c u=[],a=1b(t,n,r,i){u.4b(1h e.xA(i,t,t+n,r))},f=e.gZ(1a.3n,s.5Y,r,s.5Y.1u,s.5Y.1u+o,a);if(f.y0!=e.m6.8K)1d 1a.3n.4S(" 7I 7S 7N 2a iJ E1 E2"),1g;1c l=f.6Y;if(l.bG.1p.1n!==0)1d 1a.3n.4S(" 7I 7S 7N 1h bX 1G xB w8"),1g;if(l.3C.1p.1n!==1)1d 1a.3n.4S(" 7I 7S 7N 1h bX 1G xB jZ xz bA 2a (or E4)"),1g;1c c=s.5Y,h=l.3C.1p[0];1d c.1o!=h.1o?(1a.3n.4S(" 7I 7S 7N 1h bX 1G 6k 2g xS 5K wb 2a 1i as 5K wc 2a"),1g):!c.4U||!c.4R?(1a.3n.4S(" 7I 7S 7N E5 E6\'t 8h h9/jU qQ 3f"),1g):c.4U!==h.4U?(1a.3n.4S(" 7I 7S 7N 1h bX 1G iJ jZ (or pd) h9 qQ xD"),1g):c.4R!==h.4R?(1a.3n.4S(" 7I 7S 7N 1h bX 1G iJ jZ (or pd) jU qQ xD"),1g):h.1u!==0?(1a.3n.4S(" 7I 7S 7N 1h 1b 5V 6k 2g ob at xE 0"),1g):h.1x!==o?(1a.3n.4S(" 7I 7S 7N 1h 1b 5V 6k 2g xF at 5K 1h xF xE"),1g):e.xG.xH(t,l,c,h,i,u)},t.1e.qR=1b(t){1c n=1a;e.9y(1a.3n,"qR()",1b(){1c r=1h e.xJ(t.hQ.1u,t.hQ.1x,t.fA.9L);n.qS(t.jd,r.1x,r.9L),n.qS(t.hE,0,r.1u),n.xM(t.jd,t.hE,r),n.xN(t.jd,t.hQ,t.qU)})},t.1e.xN=1b(t,n,r){1c i=1a,s=1b(t,s,o){1d t===n?(r.5s=t.5s,r.5q=t.5q,i.3n.4S("Em En 5y kr 5F 1h bA in aR 5y"),o.2o.l9(),r):(e.gw(t)&&(t.1xn.1x)&&(o.2o.4s=!1),t)};e.6f().2d(t,s)},t.1e.xM=1b(e,t,n){1c r=e.2v.5x,i=t.2v.5x;1a.3n.fO()&&(1a.3n.4S("xQ (bQ):"),1a.je.hs(r),1a.3n.4S("Er (Es dm):"),1a.je.hs(i),1a.3n.4S("Et="+n));1c s=2,o=2,u=r.1n,a=i.1n;3q(s=n.1x?(r[s]+=n.9L,s++):o=n&&(e.1u+=r),e.1x!==-1&&e.1x>=n&&(e.1x+=r)},s=1b(e){if(e&&e.1n>0)1w(1c t=0;tt;if(i){1c s=t>>1;1w(1c o=0;o + + + + + + + + + + + diff --git a/script/Canvas_tests/Graph.py b/script/Canvas_tests/Graph.py new file mode 100644 index 00000000..f728b88f --- /dev/null +++ b/script/Canvas_tests/Graph.py @@ -0,0 +1,91 @@ +import plot_data +from plot_data import plot_data +import numpy as np + +# PlotDataState +plot_datas = [] +surface_color = 'black' +stroke_width = 0.5 # Points' stroke width + +# Scatter plot +nb_points_x = 10 +nb_points_y = 10 +font_size = 12 +graduation_color = 'grey' +axis_color = 'grey' +axis_width = 0.5 +arrow_on = False +grid_on = True + +# Tooltip +colorfill = 'black' +text_color = 'white' +font = '12px sans-serif' # Font family : Arial, Helvetica, serif, sans-serif, Verdana, Times New Roman, Courier New +tp_radius = 5 +to_plot_list = ['cx', 'cy'] + +# Graph2D +point_list = [] +k = 0 + +dashline=[] +graph_colorstroke = 'black' +graph_linewidth = 0.5 +point_colorfill = 'violet' +point_colorstroke = 'grey' +point_strokewidth = 0.5 +graph_point_size = 2; +point_shape = 'circle' +display_step = 3 +shape_set = plot_data.PointShapeSet(shape=point_shape) +point_size = plot_data.PointSizeSet(size=graph_point_size) +point_color = plot_data.PointColorSet(color_fill=point_colorfill, color_stroke=point_colorstroke) +plot_data_states = [plot_data.PlotDataState(shape_set=shape_set, point_size=point_size, point_color=point_color, stroke_width=point_strokewidth)] +while k < 20 * np.pi: + point = plot_data.PlotDataPoint2D(k, np.sin(k), plot_data_states) + point_list.append(point) + k = k + np.pi/20 + +graph = plot_data.PlotDataGraph2D(point_list, dashline,graph_colorstroke,graph_linewidth,display_step,plot_data_states) +plot_datas += [graph] + +point_list1 = [] +k = 0 +plot_data_states1 = [plot_data.PlotDataState(shape_set=plot_data.PointShapeSet(shape='square'), + point_size=plot_data.PointSizeSet(size=graph_point_size), + point_color=plot_data.PointColorSet(color_fill='green', color_stroke='black'), + stroke_width=0.5)] +while k < 20 * np.pi: + point = plot_data.PlotDataPoint2D(k, np.sin(k + np.pi/3), plot_data_states1) + point_list1.append(point) + k = k + np.pi/20 +graph1 = plot_data.PlotDataGraph2D(point_list=point_list1, dashline=[10,10], graph_colorstroke='red', graph_linewidth=0.5, display_step=display_step, plot_data_states=[plot_data.PlotDataState()]) +plot_datas += [graph1] + + +point_list2 = [] +k = 0 +plot_data_states2 = [plot_data.PlotDataState(shape_set=plot_data.PointShapeSet(shape='crux'), + point_size=plot_data.PointSizeSet(size=graph_point_size), + point_color=plot_data.PointColorSet(color_fill='brown', color_stroke='black'), + stroke_width=0.5)] +while k < 20 * np.pi: + point = plot_data.PlotDataPoint2D(k, np.sin(k + 2*np.pi/3), plot_data_states2) + point_list2.append(point) + k = k + np.pi/20 +graph2 = plot_data.PlotDataGraph2D(point_list=point_list2, dashline=[5,3,1,3], graph_colorstroke='blue', graph_linewidth=0.5, display_step=display_step, plot_data_states=[plot_data.PlotDataState()]) +plot_datas += [graph2] + +axis = plot_data.PlotDataAxis(nb_points_x=nb_points_x, nb_points_y=nb_points_y, + font_size=font_size, + graduation_color=graduation_color, + axis_color=axis_color, arrow_on=arrow_on, + axis_width=axis_width, grid_on=grid_on, plot_data_states=[plot_data.PlotDataState()]) +plot_datas += [axis] + +tooltip = plot_data.PlotDataTooltip(colorfill=colorfill,text_color=text_color, font=font, + tp_radius=tp_radius, to_plot_list=to_plot_list, plot_data_states=[plot_data.PlotDataState()]) +plot_datas += [tooltip] + +sol = [c.to_dict() for c in plot_datas] +plot_data.plot_d3(sol) \ No newline at end of file diff --git a/script/Canvas_tests/Points.py b/script/Canvas_tests/Points.py new file mode 100644 index 00000000..da13e324 --- /dev/null +++ b/script/Canvas_tests/Points.py @@ -0,0 +1,73 @@ +import plot_data +from plot_data import plot_data +import random + +# Point test #### + +# PARAMETERS # +# Window size +width = 2 +height = 1 + +# Shape set (circle, square, crux) +shape = 'circle' + +# Point size (1 to 4) +size = 2 + +# Points' color +color_fill = 'violet' +color_stroke = 'grey' + +# PlotDataState +surface_color = 'black' +stroke_width = 0.5 # Points' stroke width + +# Axis +nb_points_x = 10 +nb_points_y = 10 +font_size = 12 +graduation_color = 'grey' +axis_color = 'grey' +axis_width = 0.5 +arrow_on = False +grid_on = True + +# Tooltip +colorfill = 'black' +text_color = 'white' +font = '12px sans-serif' # Font family : Arial, Helvetica, serif, sans-serif, Verdana, Times New Roman, Courier New +tp_radius = 5 +to_plot_list = ['cx', 'cy'] + +# link_object +lo_colorstroke = 'black' +lo_linewidth = 1 + +plot_datas = [] +window_size = plot_data.WindowSizeSet(width=width, height=height) +shape_set = plot_data.PointShapeSet(shape=shape) +point_size = plot_data.PointSizeSet(size=size) +point_color = plot_data.PointColorSet(color_fill=color_fill, + color_stroke=color_stroke) +plot_data_states = [plot_data.PlotDataState( + color_surface=plot_data.ColorSurfaceSet(color=surface_color), + window_size=window_size, stroke_width=stroke_width, + shape_set=shape_set, point_size=point_size, point_color=point_color)] +for i in range(50): + cx = random.uniform(0,window_size.width) + cy = random.uniform(0,window_size.height) + point = plot_data.PlotDataPoint2D(cx=cx, cy=cy, plot_data_states=plot_data_states) + plot_datas += [point] + +axis = plot_data.PlotDataAxis(nb_points_x=nb_points_x, nb_points_y=nb_points_y, + font_size=font_size, graduation_color=graduation_color, + axis_color=axis_color,plot_data_states=plot_data_states, + arrow_on=arrow_on, axis_width=axis_width, grid_on=grid_on) +plot_datas += [axis] + +tooltip = plot_data.PlotDataTooltip(colorfill,text_color=text_color,font=font,tp_radius=tp_radius,to_plot_list=to_plot_list, plot_data_states=plot_data_states) +plot_datas += [tooltip] + +sol = [c.to_dict() for c in plot_datas] +plot_data.plot_d3(sol) diff --git a/script/Canvas_tests/ScatterPlot.py b/script/Canvas_tests/ScatterPlot.py new file mode 100644 index 00000000..8c0146bc --- /dev/null +++ b/script/Canvas_tests/ScatterPlot.py @@ -0,0 +1,75 @@ +import plot_data as vm +from plot_data import plot_data +import random +import numpy as np + +# Point test #### + +# PARAMETERS # +# Window size +width = 2 +height = 1 + +# Shape set (circle, square, crux) +shape = 'circle' + +# Point size (1 to 4) +size = 2 + +# Points' color +colorfill = 'lightblue' +colorstroke = 'grey' + +# PlotDataState +surface_color = 'black' +strokewidth = 0.5 # Points' stroke width + +# Scatter plot +nb_points_x = 10 +nb_points_y = 10 +font_size = 12 +graduation_color = 'grey' +axis_color = 'grey' +axis_width = 0.5 +arrow_on = False +grid_on = True + +# Tooltip +tp_colorfill = 'black' +text_color = 'white' +font = '12px sans-serif' # Font family : Arial, Helvetica, serif, sans-serif, Verdana, Times New Roman, Courier New +tp_radius = 5 +to_plot_list = ['cx', 'cy'] + +plot_datas = [] +point_list = [] +window_size = plot_data.WindowSizeSet(width=width, height=height) +shape_set = plot_data.PointShapeSet(shape=shape) +point_size = plot_data.PointSizeSet(size=size) +point_color = plot_data.PointColorSet(color_fill=colorfill, + color_stroke=colorstroke) +plot_data_states = [plot_data.PlotDataState( + color_surface=plot_data.ColorSurfaceSet(color=surface_color), stroke_width=strokewidth, + shape_set=shape_set, point_size=point_size, point_color=point_color)] +for i in range(2000): + cx = random.uniform(0, 2) + cy = random.uniform(0, 1) + point = plot_data.PlotDataPoint2D(cx=cx, cy=cy, plot_data_states=plot_data_states) + point_list += [point] + +ScatterPlot = plot_data.PlotDataScatter(point_list, plot_data_states=None) +plot_datas += [ScatterPlot] + +axis = plot_data.PlotDataAxis(nb_points_x=nb_points_x, nb_points_y=nb_points_y, + font_size=font_size, + graduation_color=graduation_color, + axis_color=axis_color, arrow_on=arrow_on, + axis_width=axis_width, grid_on=grid_on, plot_data_states=[plot_data.PlotDataState()]) +plot_datas += [axis] + +tooltip = plot_data.PlotDataTooltip(colorfill=tp_colorfill, text_color=text_color, font=font, + tp_radius=tp_radius, to_plot_list=to_plot_list, plot_data_states=[plot_data.PlotDataState()]) +plot_datas += [tooltip] + +sol = [c.to_dict() for c in plot_datas] +plot_data.plot_d3(sol) \ No newline at end of file diff --git a/setup.py b/setup.py new file mode 100644 index 00000000..271281b3 --- /dev/null +++ b/setup.py @@ -0,0 +1,115 @@ +# -*- coding: utf-8 -*- +""" +Setup install script for volmdlr + +""" + +from setuptools import setup + +from os.path import dirname, isdir, join +import re +from subprocess import CalledProcessError, check_output + +tag_re = re.compile(r'\btag: %s([0-9][^,]*)\b') +version_re = re.compile('^Version: (.+)$', re.M) + +def readme(): + with open('README.md') as f: + return f.read() + +def version_from_git_describe(version): + if version[0]=='v': + version = version[1:] + + # PEP 440 compatibility + number_commits_ahead = 0 + if '-' in version: + version, number_commits_ahead, commit_hash = version.split('-') + number_commits_ahead = int(number_commits_ahead) + + # print('number_commits_ahead', number_commits_ahead) + + split_versions = version.split('.') + if 'post' in split_versions[-1]: + suffix = split_versions[-1] + split_versions = split_versions[:-1] + else: + suffix = None + + for pre_release_segment in ['a', 'b', 'rc']: + if pre_release_segment in split_versions[-1]: + if number_commits_ahead > 0: + split_versions[-1] = str(split_versions[-1].split(pre_release_segment)[0]) + if len(split_versions) == 2: + split_versions.append('0') + if len(split_versions) == 1: + split_versions.extend(['0', '0']) + + split_versions[-1] = str(int(split_versions[-1])+1) + future_version = '.'.join(split_versions) + return '{}.dev{}'.format(future_version, number_commits_ahead) + else: + return '.'.join(split_versions) + + if number_commits_ahead > 0: + if len(split_versions) == 2: + split_versions.append('0') + if len(split_versions) == 1: + split_versions.extend(['0', '0']) + split_versions[-1] = str(int(split_versions[-1])+1) + split_versions = '.'.join(split_versions) + return '{}.dev{}'.format(split_versions, number_commits_ahead) + else: + if suffix is not None: + split_versions.append(suffix) + + return '.'.join(split_versions) + +# Just testing if get_version works well +assert version_from_git_describe('v0.1.7.post2') == '0.1.7.post2' +assert version_from_git_describe('v0.0.1-25-gaf0bf53') == '0.0.2.dev25' +assert version_from_git_describe('v0.1-15-zsdgaz') == '0.1.1.dev15' +assert version_from_git_describe('v1') == '1' +assert version_from_git_describe('v1-3-aqsfjbo') == '1.0.1.dev3' + +def get_version(): + # Return the version if it has been injected into the file by git-archive + version = tag_re.search('$Format:%D$') + if version: + return version.group(1) + + d = dirname(__file__) + + if isdir(join(d, '.git')): + cmd = 'git describe --tags' + try: + version = check_output(cmd.split()).decode().strip()[:] + + except CalledProcessError: + raise RuntimeError('Unable to get version number from git tags') + + return version_from_git_describe(version) + else: + # Extract the version from the PKG-INFO file. + with open(join(d, 'PKG-INFO')) as f: + version = version_re.search(f.read()).group(1) + + # print('version', version) + return version + + + +setup(name='plot_data', + version = get_version(), + description=' A volume modeler computation-oriented. Include rendering bindings.', + long_description=readme(), + keywords='volume, modeler, CAD', + url='https://github.com/Dessia-tech/volmdlr', + author='DessiA Technologies', + author_email='root@dessia.tech', + license='Creative Commons Attribution-Share Alike license', + packages=['plot_data'], + package_dir={}, + include_package_data = True, + install_requires=['matplotlib', 'dessia_common', 'jinja2'], + classifiers=['Topic :: Scientific/Engineering :: Visualization','Development Status :: 3 - Alpha']) diff --git a/src/core.ts b/src/core.ts new file mode 100644 index 00000000..d4558ec3 --- /dev/null +++ b/src/core.ts @@ -0,0 +1,1985 @@ +export class PlotData { + context_show:any; + context_hidden:any; + minX:number; + maxX:number; + minY:number; + maxY:number; + init_scale:number; + init_scaleX:number; + init_scaleY:number; + scale:number; + scaleX:number; + scaleY:number; + scroll_x:number=0; + scroll_y:number=0; + last_mouse1X:number; + last_mouse1Y:number; + colour_to_plot_data:any={}; + select_on_mouse:any; + select_on_click:any[]=[]; + color_surface_on_mouse:string='lightskyblue'; + color_surface_on_click:string='blue'; + context:any; + tooltip_ON:boolean = false; + axis_ON:boolean = false; + link_object_ON:boolean = false; + index_first_in:number; + index_last_in:number; + nb_points_in:number; + graph_ON:boolean=false; + + plot_datas:any; + tooltip_list:any[]=[]; + zoom_rect_x:number; + zoom_rect_y:number; + zoom_rect_w:number; + zoom_rect_h:number; + zw_bool:boolean; + zw_x:number; + zw_y:number; + zw_w:number; + zw_h:number; + reset_rect_x:number; + reset_rect_y:number; + reset_rect_w:number; + reset_rect_h:number; + select_bool:boolean; + select_x:number; + select_y:number; + select_w:number; + select_h:number; + sort_list_points:any[]=[]; + graph_to_display:boolean[]=[]; + graph1_button_x:number; + graph1_button_y:number; + graph1_button_w:number; + graph1_button_h:number; + nb_graph:number = 0; + graph_colorlist:string[]=[]; + graph_text_spacing:number; + decalage_axis_x = 50; + decalage_axis_y = 20; + last_point_list:any[]=[]; + scatter_point_list:PlotDataPoint2D[]=[]; + refresh_point_list_bool:boolean=true; + + constructor(public data:any, + public width: number, + public height: number, + public coeff_pixel: number) {} + + + draw(hidden, show_state, mvx, mvy, scaleX, scaleY) {} + + define_canvas() { + var canvas : any = document.getElementById('canvas'); + canvas.width = this.width; + canvas.height = this.height; + this.context_show = canvas.getContext("2d"); + + var hiddenCanvas = document.createElement("canvas"); + hiddenCanvas.width = this.width; + hiddenCanvas.height = this.height; + this.context_hidden = hiddenCanvas.getContext("2d"); + } + + draw_initial() { + this.init_scale = Math.min(this.width/(this.coeff_pixel*this.maxX - this.coeff_pixel*this.minX), this.height/(this.coeff_pixel*this.maxY - this.coeff_pixel*this.minY)); + this.scale = this.init_scale; + if ((this.axis_ON) && !(this.graph_ON)) { + this.init_scaleX = (this.width-this.decalage_axis_x)/(this.coeff_pixel*this.maxX - this.coeff_pixel*this.minX); + this.init_scaleY = (this.height - this.decalage_axis_y)/(this.coeff_pixel*this.maxY - this.coeff_pixel*this.minY); + this.scaleX = this.init_scaleX; + this.scaleY = this.init_scaleY; + this.last_mouse1X = (this.width/2 - (this.coeff_pixel*this.maxX - this.coeff_pixel*this.minX)*this.scaleX/2)/this.scaleX - this.coeff_pixel*this.minX + this.decalage_axis_x/(2*this.scaleX); + this.last_mouse1Y = (this.height/2 - (this.coeff_pixel*this.maxY - this.coeff_pixel*this.minY)*this.scaleY/2)/this.scaleY - this.coeff_pixel*this.minY - this.decalage_axis_y/(2*this.scaleY); + } else if ((this.axis_ON) && (this.graph_ON)) { + this.init_scaleX = (this.width-this.decalage_axis_x)/(this.coeff_pixel*this.maxX - this.coeff_pixel*this.minX); + this.init_scaleY = (this.height - this.decalage_axis_y - (this.graph1_button_y + this.graph1_button_h + 5))/(this.coeff_pixel*this.maxY - this.coeff_pixel*this.minY); + this.scaleX = this.init_scaleX; + this.scaleY = this.init_scaleY; + this.last_mouse1X = (this.width/2 - (this.coeff_pixel*this.maxX - this.coeff_pixel*this.minX)*this.scaleX/2)/this.scaleX - this.coeff_pixel*this.minX + this.decalage_axis_x/(2*this.scaleX); + this.last_mouse1Y = (this.height/2 - (this.coeff_pixel*this.maxY - this.coeff_pixel*this.minY)*this.scaleY/2)/this.scaleY - this.coeff_pixel*this.minY - (this.decalage_axis_y - (this.graph1_button_y + this.graph1_button_h + 5))/(2*this.scaleY); + } else { + this.scaleX = this.init_scale; + this.scaleY = this.init_scale; + this.last_mouse1X = (this.width/2 - (this.coeff_pixel*this.maxX - this.coeff_pixel*this.minX)*this.scaleX/2)/this.scaleX - this.coeff_pixel*this.minX; + this.last_mouse1Y = (this.height/2 - (this.coeff_pixel*this.maxY - this.coeff_pixel*this.minY)*this.scaleY/2)/this.scaleY - this.coeff_pixel*this.minY; + } + this.draw(true, 0, this.last_mouse1X, this.last_mouse1Y, this.scaleX, this.scaleY); + this.draw(false, 0, this.last_mouse1X, this.last_mouse1Y, this.scaleX, this.scaleY); + + } + + draw_empty_canvas(hidden) { + if (hidden) { + this.context = this.context_hidden; + } else { + this.context = this.context_show; + } + this.context.clearRect(0, 0, this.width, this.height); + } + + draw_contour(hidden, show_state, mvx, mvy, scaleX, scaleY, d) { + if (d['type'] == 'contour') { + this.context.beginPath(); + if (hidden) { + this.context.fillStyle = d.mouse_selection_color; + } else { + this.context.strokeStyle = d.plot_data_states[show_state].color_line; + this.context.lineWidth = d.plot_data_states[show_state].stroke_width; + this.context.fillStyle = 'white'; + if (d.plot_data_states[show_state].hatching != null) { + this.context.fillStyle = this.context.createPattern(d.plot_data_states[show_state].hatching.canvas_hatching,'repeat'); + } + if (d.plot_data_states[show_state].color_surface != null) { + this.context.fillStyle = d.plot_data_states[show_state].color_surface.color; + } + if (this.select_on_mouse == d) { + this.context.fillStyle = this.color_surface_on_mouse; + } + for (var j = 0; j < this.select_on_click.length; j++) { + var z = this.select_on_click[j]; + if (z == d) { + this.context.fillStyle = this.color_surface_on_click; + } + } + } + for (var j = 0; j < d.plot_data_primitives.length; j++) { + var elem = d.plot_data_primitives[j]; + if (j == 0) {var first_elem = true} else {var first_elem = false} + elem.draw(this.context, first_elem, mvx, mvy, scaleX, scaleY); + } + this.context.fill(); + this.context.stroke(); + this.context.closePath(); + + } + } + + draw_point(hidden, show_state, mvx, mvy, scaleX, scaleY, d) { + if (d['type'] == 'point') { + if (hidden) { + this.context.fillStyle = d.mouse_selection_color; + } else { + this.context.fillStyle = d.plot_data_states[show_state].point_color.color_fill; + this.context.lineWidth = d.plot_data_states[show_state].stroke_width; + this.context.strokeStyle = d.plot_data_states[show_state].point_color.color_stroke; + var shape = d.plot_data_states[show_state].shape_set.shape; + + if (shape == 'crux') { + this.context.strokeStyle = d.plot_data_states[show_state].point_color.color_fill; + } + if (this.select_on_mouse == d) { + this.context.fillStyle = this.color_surface_on_mouse; + } + for (var j = 0; j < this.select_on_click.length; j++) { + var z = this.select_on_click[j]; + if (z == d) { + if (shape == 'crux') { + this.context.strokeStyle = this.color_surface_on_click; + } else { + this.context.fillStyle = this.color_surface_on_click; + } + } + } + } + var x = scaleX*(1000*d.cx+ mvx); + var y = scaleY*(1000*d.cy + mvy); + var length = 1000*d.size; + + var is_inside_canvas = ((x + length>=0) && (x - length <= this.width) && (y + length >= 0) && (y - length <= this.height)); + + if (is_inside_canvas === true) { + this.context.beginPath(); + d.draw(this.context, this.context_hidden, mvx, mvy, scaleX, scaleY); + this.context.fill(); + this.context.stroke(); + this.context.closePath(); + } + } + } + + draw_axis(mvx, mvy, scaleX, scaleY, d) { + if (d['type'] == 'axis'){ + this.context.beginPath(); + d.draw(this.context, mvx, mvy, scaleX, scaleY, this.width, this.height, this.init_scaleX, this.init_scaleY, this.minX, this.maxX, this.minY, this.maxY, this.scroll_x, this.scroll_y, this.decalage_axis_x, this.decalage_axis_y); + this.context.closePath(); + this.context.fill(); + } + } + draw_tooltip(d, mvx, mvy) { + if (d['type'] == 'tooltip') { + this.tooltip_ON = true; + d.manage_tooltip(this.context, mvx, mvy, this.scaleX, this.scaleY, this.init_scale, this.width, this.height, this.tooltip_list) + } + } + + find_min_dist(d, mvx, mvy, step) { + var x0 = this.scaleX*(1000*d.point_list[0].cx + mvx); + var y0 = this.scaleY*(1000*d.point_list[0].cy + mvy); + var x1 = this.scaleX*(1000*d.point_list[step].cx + mvx); + var y1 = this.scaleY*(1000*d.point_list[step].cy + mvy); + var min_dist = this.distance([x0,y0],[x1,y1]); + for (var i=1; ithis.width) || (y<0) || (y+2*h>this.height)) { + throw new Error("Invalid x or y, the zoom button is out of the canvas"); + } + this.context.strokeStyle = 'black'; + this.context.beginPath(); + this.context.lineWidth = "2"; + this.context.fillStyle = 'white'; + this.context.rect(x, y, w, h); + this.context.rect(x, y+h, w, h); + this.context.moveTo(x, y+h); + this.context.lineTo(x+w, y+h); + Shape.crux(this.context, x+w/2, y+h/2, h/3); + this.context.moveTo(x + w/2 - h/3, y + 3*h/2); + this.context.lineTo(x + w/2 + h/3, y + 3*h/2); + this.context.fill(); + this.context.stroke(); + this.context.closePath(); + } + + zoom_window_button(x, y, w, h) { + if ((x<0) || (x+h>this.width) || (y<0) || (y+h>this.height)) { + throw new Error("Invalid x or y, the zoom window button is out of the canvas"); + } + this.context.strokeStyle = 'black'; + if (this.zw_bool) { + Shape.createButton(x, y, w, h, this.context, "Z ON", "12px Arial"); + } else { + Shape.createButton(x, y, w, h, this.context, "Z OFF", "12px Arial"); + } + + } + + reset_button(x, y, w, h) { + if ((x<0) || (x+h>this.width) || (y<0) || (y+h>this.height)) { + throw new Error("Invalid x or y, the reset button is out of the canvas"); + } + this.context.strokeStyle = 'black'; + Shape.createButton(x, y, w, h, this.context, "Reset", "12px Arial"); + } + + selection_button(x, y, w, h) { + if ((x<0) || (x+h>this.width) || (y<0) || (y+h>this.height)) { + throw new Error("Invalid x or y, the selection button is out of the canvas"); + } + this.context.strokeStyle = 'black'; + if (this.select_bool) { + Shape.createButton(x, y, w, h, this.context, "S ON", "12px Arial") + } else { + Shape.createButton(x, y, w, h, this.context, "S OFF", "12px Arial") + } + } + + graph_buttons(x, y, w, h, police, text_spacing) { + for (var i=0; i40) && (Math.abs(mouse2Y - mouse1Y)>30); + var click_on_select = Shape.Is_in_rect(mouse1X, mouse1Y, this.select_x, this.select_y, this.select_w, this.select_h); + var click_on_graph = false; + for (var i=0; i scale_floor) && (this.scaleY/1.2 > scale_floor)) { + this.zoom_out_button_action(); + + } else if (click_on_zoom_window === true) { + this.click_on_zoom_window_action(); + + } else if (click_on_reset === true) { + this.click_on_reset_action(); + + } else if (click_on_select === true) { + this.click_on_selection_button_action(); + + } else if (click_on_graph) { + this.graph_button_action(mouse1X, mouse1Y); + } + + this.draw(false, 0, this.last_mouse1X, this.last_mouse1Y, this.scaleX, this.scaleY); + } + var isDrawing = false; + mouse_moving = false; + return [isDrawing, mouse_moving, mouse1X, mouse1Y, mouse2X, mouse2Y]; + } + + wheel_interaction(mouse3X, mouse3Y, e) { + var scale_ceil = 400*this.init_scale; + var scale_floor = this.init_scale/100; + var zoom_coeff = 1.1; + var event = -e.deltaY; + mouse3X = e.offsetX; + mouse3Y = e.offsetY; + if ((mouse3Y>=this.height - this.decalage_axis_y) && (mouse3X>this.decalage_axis_x) && this.axis_ON) { + var old_scaleX = this.scaleX; + if ((event>0) && (this.scaleX*zoom_coeffscale_floor) { + this.scaleX = this.scaleX/zoom_coeff; + this.scroll_x = this.scroll_x - e.deltaY/Math.abs(e.deltaY); + this.last_mouse1X = this.last_mouse1X - ((this.width/2)/old_scaleX - (this.width/2)/this.scaleX); + } + + } else if ((mouse3X<=this.decalage_axis_x) && (mouse3Y0) && (this.scaleY*zoom_coeffscale_floor) { + this.scaleY = this.scaleY/zoom_coeff; + this.scroll_y = this.scroll_y - e.deltaY/Math.abs(e.deltaY); + this.last_mouse1Y = this.last_mouse1Y - ((this.height/2)/old_scaleY - (this.height/2)/this.scaleY); + } + + } else { + var old_scaleY = this.scaleY; + var old_scaleX = this.scaleX; + if ((event>0) && (this.scaleX*zoom_coeffscale_floor) && (this.scaleY/zoom_coeff>scale_floor)) { + this.scaleX = this.scaleX/zoom_coeff; + this.scaleY = this.scaleY/zoom_coeff; + this.scroll_x = this.scroll_x - e.deltaY/Math.abs(e.deltaY); + this.scroll_y = this.scroll_y - e.deltaY/Math.abs(e.deltaY); + this.last_mouse1X = this.last_mouse1X - (mouse3X/old_scaleX - mouse3X/this.scaleX); + this.last_mouse1Y = this.last_mouse1Y - (mouse3Y/old_scaleY - mouse3Y/this.scaleY); + } + } + this.draw(false, 0, this.last_mouse1X, this.last_mouse1Y, this.scaleX, this.scaleY); + this.draw(true, 0, this.last_mouse1X, this.last_mouse1Y, this.scaleX, this.scaleY); + return [mouse3X, mouse3Y]; + } + + mouse_interaction() { + var isDrawing = false; + var mouse_moving = false; + var mouse1X = 0; + var mouse1Y = 0; + var mouse2X = 0; + var mouse2Y = 0; + var mouse3X = 0; + var mouse3Y = 0; + + var canvas = document.getElementById('canvas'); + + canvas.addEventListener('mousedown', e => { + [mouse1X, mouse1Y, mouse2X, mouse2Y, isDrawing] = this.mouse_down_interaction(mouse1X, mouse1Y, mouse2X, mouse2Y, isDrawing, e); + }) + + canvas.addEventListener('mousemove', e => { + [isDrawing, mouse_moving, mouse1X, mouse1Y, mouse2X, mouse2Y] = this.mouse_move_interaction(isDrawing, mouse_moving, mouse1X, mouse1Y, mouse2X, mouse2Y, e); + }) + + canvas.addEventListener('mouseup', e => { + [isDrawing, mouse_moving, mouse1X, mouse1Y, mouse2X, mouse2Y] = this.mouse_up_interaction(mouse_moving, mouse1X, mouse1Y, mouse2X, mouse2Y); + }) + + canvas.addEventListener('wheel', e => { + [mouse3X, mouse3Y] = this.wheel_interaction(mouse3X, mouse3Y, e); + }) + } + + contains_undefined(list) { + for (var i=0; i=0) && (x<=this.width) && (y>=0) && (y<=this.height); + if (is_inside_canvas === true) { + index_first_in = k; + bool = false; + } else { + k++; + } + } + if (index_first_in == -1) { + return [index_first_in, nb_points_in, index_last_in]; + } + + while (k=0) && (x<=this.width) && (y>=0) && (y<=this.height); + if (is_inside_canvas === true) { + index_last_in = k; + nb_points_in++; + } + k++; + } + return [index_first_in, nb_points_in, index_last_in]; + } + + is_inside_canvas(point, mvx, mvy) { + var x = this.scaleX*(1000*point.cx + mvx); + var y = this.scaleY*(1000*point.cy + mvy); + length = 100*point.size; + return (x+length>=0) && (x<=this.width-length) && (y+length>=0) && (y-length<=this.height); + } + + get_points_inside_canvas(list_points, mvx, mvy) { + var new_list_points = []; + for (var i=0; i=size_j) { + var max_size_index = i + var min_size_index = j; + } else { + var max_size_index = j; + var min_size_index = i; + } + var xj = this.scaleX*(1000*point_dict_j[1].cx + mvx); + var yj = this.scaleY*(1000*point_dict_j[1].cy + mvy); + var is_touching_ij = this.distance([xi,yi], [xj,yj])<1000*(size_i + size_j); + if ((Math.abs(i_0-j_0)<=1) && (Math.abs(i_1-j_1)<=1) && is_touching_ij) { + var copy_point_max_index = dict_point_list[max_size_index][1].copy(); + var copy_point_min_index = dict_point_list[min_size_index][1].copy(); + var new_cx = (copy_point_max_index.cx + copy_point_min_index.cx)/2; + var new_cy = (copy_point_max_index.cy + copy_point_min_index.cy)/2; + var copy_plot_data_states = [copy_point_max_index.plot_data_states[0]]; + var point = new PlotDataPoint2D([],new_cx, new_cy, copy_plot_data_states, 'point', ''); + var size_coeff = 1.15; + point.size = dict_point_list[max_size_index][1].size*size_coeff; + var point_i = dict_point_list[i][1]; + var point_j = dict_point_list[j][1]; + this.delete_clicked_points([point_i, point_j]); + this.delete_tooltip([point_i, point_j]); + dict_point_list = this.remove_selection(dict_point_list[i], dict_point_list); + dict_point_list = this.remove_selection(dict_point_list[j-1], dict_point_list); + dict_point_list.push(this.hashing_point(point, nb_x, nb_y, mvx, mvy)); + this.colour_to_plot_data[point.mouse_selection_color] = point; + bool = true; + break; + } else { + j++; + } + } + if (bool) {length--} else {i++} + } + return this.dehashing_list(dict_point_list); + } + + refresh_point_list(point_list, mvx, mvy) { //methode recherche naive + var new_point_list = this.copy_list(point_list); + var i = 0; + var length = new_point_list.length; + while (i=size_j) {var max_size_index = i} else {var max_size_index = j} + var xj = this.scaleX*(1000*new_point_list[j].cx + mvx); + var yj = this.scaleY*(1000*new_point_list[j].cy + mvy); + if (this.distance([xi,yi], [xj,yj])<1000*(new_point_list[i].size + new_point_list[j].size)) { + var new_cx = (new_point_list[i].cx + new_point_list[j].cx)/2; + var new_cy = (new_point_list[i].cy + new_point_list[j].cy)/2; + var copy_plot_data_states = [new_point_list[max_size_index].plot_data_states[0].copy()]; + var point = new PlotDataPoint2D([],new_cx, new_cy, copy_plot_data_states, 'point', ''); + var size_coeff = 1.15; + point.size = new_point_list[max_size_index].size*size_coeff; + var point_i = new_point_list[i]; + var point_j = new_point_list[j]; + this.delete_clicked_points([point_i, point_j]); + this.delete_tooltip([point_i, point_j]); + new_point_list = this.remove_selection(new_point_list[i], new_point_list); + new_point_list = this.remove_selection(new_point_list[j-1], new_point_list); + new_point_list.push(point); + this.colour_to_plot_data[point.mouse_selection_color] = point; + bool = true; + break; + } else { + j++ + } + } + if (bool) { + length--; + } else { + i++; + } + } + return new_point_list; + } + + delete_clicked_points(point_list) { + var i = 0; + while (i=rect_x) && (x<= rect_x + rect_w) && (y>=rect_y) && (y<=rect_y + rect_h)) + } + + public static createButton(x, y, w, h, context, text, police) { + context.beginPath(); + context.fillStyle = 'white'; + context.lineWidth = "3"; + context.rect(x,y,w,h); + context.stroke(); + context.fill(); + context.closePath(); + context.beginPath(); + context.fillStyle = "black" + context.textAlign = "center"; + context.font = police; + context.fillText(text, x+w/2, y+h/1.8); + context.fill(); + context.closePath(); + } + + public static createGraphButton(x, y, w, h, context, text, police, colorfill, strikeout) { + context.beginPath(); + context.fillStyle = colorfill; + context.rect(x,y,w,h); + context.fill(); + context.closePath(); + context.beginPath(); + context.fillStyle = 'grey'; + context.textAlign = 'start'; + context.textBaseline = 'middle'; + context.font = police; + context.fillText(text, x+w + 5, y+h/1.8); + context.fill(); + if (strikeout === true) { + var text_w = context.measureText(text).width; + context.lineWidth = 1.5; + context.strokeStyle = 'grey'; + Shape.drawLine(context, [x+w + 5, y+h/1.8], [x+w+5+text_w, y+h/2]); + context.stroke(); + } + context.closePath(); + } +} + +export class PlotDataContour2D { + minX:number=0; + maxX:number=0; + minY:number=0; + maxY:number=0; + mouse_selection_color:any; + + constructor(public plot_data_primitives:any, + public plot_data_states:any, + public type:string, + public name:string) { + for (var i = 0; i < this.plot_data_primitives.length; i++) { + var d = plot_data_primitives[i] + this.minX = Math.min(this.minX, d.minX); + this.maxX = Math.max(this.maxX, d.maxX); + this.minY = Math.min(this.minY, d.minY); + this.maxY = Math.max(this.maxY, d.maxY); + } + this.mouse_selection_color = genColor(); + + } + + public static deserialize(serialized) { + var temp = serialized['plot_data_states']; + var plot_data_states = []; + for (var i = 0; i < temp.length; i++) { + var d = temp[i]; + plot_data_states.push(PlotDataState.deserialize(d)); + } + var temp = serialized['plot_data_primitives']; + var plot_data_primitives = []; + for (var i = 0; i < temp.length; i++) { + var d = temp[i]; + if (d['type'] == 'line') { + plot_data_primitives.push(PlotDataLine2D.deserialize(d)); + } + if (d['type'] == 'circle') { + plot_data_primitives.push(PlotDataCircle2D.deserialize(d)); + } + if (d['type'] == 'arc') { + plot_data_primitives.push(PlotDataArc2D.deserialize(d)); + } + + } + return new PlotDataContour2D(plot_data_primitives, + plot_data_states, + serialized['type'], + serialized['name']); + } +} + +export class PlotDataLine2D { + minX:number=0; + maxX:number=0; + minY:number=0; + maxY:number=0; + + constructor(public data:any, + public plot_data_states:any, + public type:string, + public name:string) { + this.minX = Math.min(this.data[0], this.data[2]); + this.maxX = Math.max(this.data[0], this.data[2]); + this.minY = Math.min(this.data[1], this.data[3]); + this.maxY = Math.max(this.data[1], this.data[3]); + } + + public static deserialize(serialized) { + var temp = serialized['plot_data_states']; + var plot_data_states = []; + for (var i = 0; i < temp.length; i++) { + var d = temp[i]; + plot_data_states.push(PlotDataState.deserialize(d)); + } + return new PlotDataLine2D(serialized['data'], + plot_data_states, + serialized['type'], + serialized['name']); + } + + draw(context, first_elem, mvx, mvy, scaleX, scaleY) { + if (first_elem) { + context.moveTo(scaleX*(1000*this.data[0]+ mvx), scaleY*(1000*this.data[1]+ mvy)); + } + context.lineTo(scaleX*(1000*this.data[2]+ mvx), scaleY*(1000*this.data[3]+ mvy)); + } +} + +export class PlotDataCircle2D { + minX:number=0; + maxX:number=0; + minY:number=0; + maxY:number=0; + + constructor(public data:any, + public cx:number, + public cy:number, + public r:number, + public plot_data_states:PlotDataState[], + public type:string, + public name:string) { + this.minX = this.cx - this.r; + this.maxX = this.cx + this.r; + this.minY = this.cy - this.r; + this.maxY = this.cy + this.r; + } + + public static deserialize(serialized) { + var temp = serialized['plot_data_states'] + var plot_data_states = [] + for (var i = 0; i < temp.length; i++) { + var d = temp[i] + plot_data_states.push(PlotDataState.deserialize(d)) + } + return new PlotDataCircle2D(serialized['data'], + serialized['cx'], + serialized['cy'], + serialized['r'], + plot_data_states, + serialized['type'], + serialized['name']); + } + + draw(context, first_elem, mvx, mvy, scaleX, scaleY) { + context.arc(scaleX*(1000*this.cx+ mvx), scaleY*(1000*this.cy+ mvy), scaleX*1000*this.r, 0, 2*Math.PI); + } + +} + +export class PlotDataPoint2D { + minX:number=0; + maxX:number=0; + minY:number=0; + maxY:number=0; + mouse_selection_color:any; + size:number; + k:number=1; + + constructor(public data:any, + public cx:number, + public cy:number, + public plot_data_states:PlotDataState[], + public type:string, + public name:string) { + + var plot = plot_data_states[0]; + var point_size = plot.point_size.size; + if (point_size<1) { + throw new Error('Invalid point_size'); + } + this.size = this.k*point_size/400; + this.minX = this.cx - 2.5*this.size; + this.maxX = this.cx + 2.5*this.size; + this.minY = this.cy - 5*this.size; + this.maxY = this.cy + 5*this.size; + + this.mouse_selection_color = genColor(); + } + + public static deserialize(serialized) { + var temp = serialized['plot_data_states']; + var plot_data_states = []; + for (var i = 0; i < temp.length; i++) { + var d = temp[i]; + plot_data_states.push(PlotDataState.deserialize(d)); + } + return new PlotDataPoint2D(serialized['data'], + serialized['cx'], + serialized['cy'], + plot_data_states, + serialized['type'], + serialized['name']); + } + + draw(context, context_hidden, mvx, mvy, scaleX, scaleY) { + var show_states = 0; + var shape = this.plot_data_states[show_states].shape_set.shape; + if (shape == 'circle') { + context.arc(scaleX*(1000*this.cx+ mvx), scaleY*(1000*this.cy+ mvy), 1000*this.size, 0, 2*Math.PI); + context.stroke(); + } else if (shape == 'square') { + context.rect(scaleX*(1000*this.cx + mvx) - 1000*this.size,scaleY*(1000*this.cy + mvy) - 1000*this.size,1000*this.size*2, 1000*this.size*2); + context.stroke(); + } else if (shape == 'crux') { + context.rect(scaleX*(1000*this.cx + mvx), scaleY*(1000*this.cy + mvy),1000*this.size, 100*this.size); + context.rect(scaleX*(1000*this.cx + mvx), scaleY*(1000*this.cy + mvy),-1000*this.size, 100*this.size); + context.rect(scaleX*(1000*this.cx + mvx), scaleY*(1000*this.cy + mvy),100*this.size, 1000*this.size); + context.rect(scaleX*(1000*this.cx + mvx), scaleY*(1000*this.cy + mvy),100*this.size, -1000*this.size); + context.fillStyle = context.strokeStyle; + context.stroke(); + + context_hidden.beginPath() + context_hidden.arc(scaleX*(1000*this.cx+ mvx), scaleY*(1000*this.cy+ mvy), 1000*this.size, 0, 2*Math.PI); + context_hidden.stroke(); + context_hidden.closePath(); + } else { + throw new Error('Invalid shape for point'); + } + + } + + copy() { + return new PlotDataPoint2D(this.data, this.cx, this.cy, this.plot_data_states, this.type, this.name); + } +} + +export class PlotDataAxis { + colorStroke:any; + x_step:number; + y_step:number; + constructor(public nb_points_x:number, + public nb_points_y:number, + public font_size:number, + public graduation_color:string, + public axis_color:string, + public name:string, + public arrow_on:boolean, + public axis_width:string, + public grid_on:boolean, + public type:string, + public plot_data_states:PlotDataState[]) { + + for (var i=0; iaxis_x_start) && (scaleX*(1000*(grad_beg_x + i*x_step) + mvx) axis_y_start) && (scaleY*(-1000*(grad_beg_y + i*y_step) + mvy) < axis_y_end)) { + if (this.grid_on === true) { + context.strokeStyle = 'lightgrey'; + Shape.drawLine(context,[axis_x_start - 3, scaleY*(-1000*(grad_beg_y + i*y_step) + mvy)], [axis_x_end, scaleY*(-1000*(grad_beg_y + i*y_step) + mvy)]); + } else { + Shape.drawLine(context, [axis_x_start - 3, scaleY*(-1000*(grad_beg_y + i*y_step) + mvy)], [axis_x_start + 3, scaleY*(-1000*(grad_beg_y + i*y_step) + mvy)]); + } + context.fillText(MyMath.round(grad_beg_y + i*y_step, y_nb_digits), axis_x_start - 5, scaleY*(-1000*(grad_beg_y + i*y_step) + mvy)); + } + i++; + } + + context.stroke(); + } + + draw(context, mvx, mvy, scaleX, scaleY, width, height, init_scaleX, init_scaleY, minX, maxX, minY, maxY, scroll_x, scroll_y, decalage_axis_x, decalage_axis_y) { + // Dessin du repère + context.beginPath(); + context.strokeStyle = this.axis_color; + context.lineWidth = this.axis_width; + var axis_x_start = decalage_axis_x; + var axis_x_end = width; + var axis_y_start = 0; + var axis_y_end = height - decalage_axis_y; + //Flèches + if (this.arrow_on === true) { + Shape.drawLine(context, [axis_x_start - 10, axis_y_start + 20], [axis_x_start, axis_y_start]); + Shape.drawLine(context, [axis_x_start, axis_y_start], [axis_x_start + 10, axis_y_start + 20]); + + Shape.drawLine(context, [axis_x_end - 20, axis_y_end - 10], [axis_x_end, axis_y_end]); + Shape.drawLine(context, [axis_x_end, axis_y_end], [axis_x_end - 20, axis_y_end + 10]); + } + + //Axes + Shape.drawLine(context, [axis_x_start, axis_y_start], [axis_x_start, axis_y_end]); + Shape.drawLine(context, [axis_x_start, axis_y_end], [axis_x_end, axis_y_end]); + + context.stroke(); + + //Graduations + if (scroll_x % 5 == 0) { + var kx = 1.1*scaleX/init_scaleX; + this.x_step = (maxX - minX)/(kx*(this.nb_points_x-1)); + } + if (scroll_y % 5 == 0) { + var ky = 1.1*scaleY/init_scaleY; + this.y_step = (maxY - minY)/(ky*(this.nb_points_y-1)); + } + + context.font = this.font_size.toString() + 'px Arial'; + context.fillStyle = this.graduation_color; + context.strokeStyle = this.axis_color; + + this.draw_graduations(context, mvx, mvy, scaleX, scaleY, axis_x_start, axis_x_end, axis_y_start, axis_y_end, minX, maxX, minY, maxY, this.x_step, this.y_step, this.font_size); + context.closePath(); + + } +} + +export class PlotDataTooltip { + constructor(public colorfill:string, public text_color: string, public font:string, public tp_radius:any, public to_plot_list:any, public plot_data_states:PlotDataState[],public type:string, public name:string) {} + + public static deserialize(serialized) { + var temp = serialized['plot_data_states'] + var plot_data_states = []; + for (var i = 0; i < temp.length; i++) { + var d = temp[i]; + plot_data_states.push(PlotDataState.deserialize(d)); + } + return new PlotDataTooltip(serialized['colorfill'], + serialized['text_color'], + serialized['font'], + serialized['tp_radius'], + serialized['to_plot_list'], + plot_data_states, + serialized['type'], + serialized['name']); + } + + draw(context, object, mvx, mvy, scaleX, scaleY, canvas_width, canvas_height) { + context.beginPath(); + var textfills = []; + var text_max_length = 0; + for (var i=0; itext_max_length) { + text_max_length = text_w; + } + } + + var font_size = Number(this.font.split('px')[0]); + var tp_height = (textfills.length + 0.25)*font_size ; + var cx = object.cx; + var cy = object.cy; + var point_size = object.plot_data_states[0].point_size.size; + var decalage = 2.5*point_size + 5 + var tp_x = scaleX*(1000*cx + mvx) + decalage; + var tp_y = scaleY*(1000*cy + mvy) - 1/2*tp_height; + var tp_width = text_max_length + 25; + + if (tp_x + tp_width > canvas_width) { + tp_x = scaleX*(1000*cx + mvx) - decalage - tp_width; + } + if (tp_y < 0) { + tp_y = scaleY*(1000*cy + mvy); + } + if (tp_y + tp_height > canvas_height) { + tp_y = scaleY*(1000*cy + mvy) - tp_height; + } + + Shape.roundRect(tp_x, tp_y, tp_width, tp_height, this.tp_radius, context); + context.strokeStyle = 'black'; + context.globalAlpha = 0.75; + context.fillStyle = this.colorfill; + context.stroke(); + context.fill(); + context.fillStyle = this.text_color; + context.textAlign = 'start'; + context.textBaseline = 'Alphabetic'; + + var x_start = tp_x + 1/10*tp_width; + context.font = this.font; + + var current_y = tp_y + 0.75*font_size; + for (var i=0; i this.maxX){ + this.maxX = this.cx + this.r; + } + if((this.cy - this.r) < this.minY){ + this.minY = this.cy - this.r; + } + if((this.cy + this.r) > this.maxY){ + this.maxY = this.cy + this.r; + } + } + + public static deserialize(serialized) { + var temp = serialized['plot_data_states'] + var plot_data_states = []; + for (var i = 0; i < temp.length; i++) { + var d = temp[i]; + plot_data_states.push(PlotDataState.deserialize(d)); + } + return new PlotDataArc2D(serialized['cx'], + serialized['cy'], + serialized['r'], + serialized['data'], + serialized['angle1'], + serialized['angle2'], + plot_data_states, + serialized['type'], + serialized['name']); + } + + draw(context, first_elem, mvx, mvy, scaleX, scaleY) { + var ptsa = []; + for (var l = 0; l < this.data.length; l++) { + ptsa.push(scaleX*(1000*this.data[l]['x']+ mvx)); + ptsa.push(scaleY*(1000*this.data[l]['y']+ mvy)); + } + var tension = 0.4; + var isClosed = false; + var numOfSegments = 16; + drawLines(context, getCurvePoints(ptsa, tension, isClosed, numOfSegments)); + } +} + +export class PlotDataState { + + constructor(public color_surface:ColorSurfaceSet, + public color_map:any, + public hatching:HatchingSet, + public opacity:number, + public dash:any, + public marker:any, + public color_line:any, + public shape_set:PointShapeSet, + public point_size:PointSizeSet, + public point_color:PointColorSet, + public window_size:WindowSizeSet, + public stroke_width:any, + public name:any,) {} + + public static deserialize(serialized) { + var color_surface = null + if (serialized['color_surface'] != null) { + color_surface = ColorSurfaceSet.deserialize(serialized['color_surface']); + } + var hatching = null; + if (serialized['hatching'] != null) { + hatching = HatchingSet.deserialize(serialized['hatching']); + } + var shape_set = null; + if (serialized['shape_set'] != null) { + shape_set = PointShapeSet.deserialize(serialized['shape_set']); + } + var window_size = null; + if(serialized['window_size'] != null) { + window_size = WindowSizeSet.deserialize(serialized['window_size']); + } + var point_size = null; + if (serialized['point_size'] != null) { + point_size = PointSizeSet.deserialize(serialized['point_size']); + } + var point_color = null; + if (serialized['point_color'] != null) { + point_color = PointColorSet.deserialize(serialized['point_color']); + } + return new PlotDataState(color_surface, + serialized['color_map'], + hatching, + serialized['opacity'], + serialized['dash'], + serialized['marker'], + serialized['color_line'], + shape_set, + point_size, + point_color, + window_size, + serialized['stroke_width'], + serialized['name']); + } + copy() { + return new PlotDataState(this.color_surface, this.color_map, this.hatching, this.opacity, this.dash, this.marker, this.color_line, this.shape_set, this.point_size, this.point_color, this.window_size, this.stroke_width, this.name); + } +} + +export class ColorSurfaceSet { + + constructor(public name:string, + public color:any) {} + + public static deserialize(serialized) { + return new ColorSurfaceSet(serialized['name'], + serialized['color']); + } +} + +export class PointShapeSet { + constructor(public name:string, public shape:any){} + + public static deserialize(serialized) { + return new PointShapeSet(serialized['name'], + serialized['shape']); + } +} + +export class PointSizeSet { + constructor(public name:string, public size:number) {} + + public static deserialize(serialized) { + return new PointSizeSet(serialized['name'], + serialized['size']) + } +} + +export class PointColorSet { + constructor(public name:string, public color_fill:string, public color_stroke:string) {} + + public static deserialize(serialized) { + return new PointColorSet(serialized['name'], + serialized['color_fill'], + serialized['color_stroke']) + } +} + +export class WindowSizeSet { + constructor(public name:string, public height:number,public width:number){ + } + + public static deserialize(serialized) { + return new WindowSizeSet(serialized['name'], + serialized['height'], + serialized['width']); + } +} + +export class HatchingSet { + canvas_hatching:any; + + constructor(public name:string, + public stroke_width:number, + public hatch_spacing:number) { + this.canvas_hatching = this.generate_canvas() + } + + public static deserialize(serialized) { + return new HatchingSet(serialized['name'], + serialized['stroke_width'], + serialized['hatch_spacing']); + } + + generate_canvas() { + var nb_hatch = 20; + var max_size = nb_hatch*this.hatch_spacing; + + var p_hatch = document.createElement("canvas"); + p_hatch.width = max_size; + p_hatch.height = max_size; + var pctx = p_hatch.getContext("2d"); + pctx.lineCap = 'square'; + pctx.strokeStyle = 'black'; + pctx.lineWidth = this.stroke_width; + pctx.beginPath(); + var pos_x = - Math.pow(Math.pow(max_size,2)/2, 0.5); + var pos_y = Math.pow(Math.pow(max_size,2)/2, 0.5); + for (var i = 0; i <= 2*nb_hatch; i++) { + pos_x = pos_x + this.hatch_spacing; + pos_y = pos_y - this.hatch_spacing; + pctx.moveTo(pos_x, pos_y); + pctx.lineTo(pos_x + max_size, pos_y + max_size); + } + pctx.stroke(); + return p_hatch; + } +} + + +function drawLines(ctx, pts) { + // ctx.moveTo(pts[0], pts[1]); + for(var i=2; i> 8); // G + ret.push((nextCol & 0xff0000) >> 16); // B + + nextCol += 50; + } + var col = "rgb(" + ret.join(',') + ")"; + return col; +} + +function log10(x) { + return Math.log(x)/Math.log(10) +} \ No newline at end of file diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 00000000..347b6733 --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,14 @@ +{ + "compilerOptions": { + "target": "es5", + "module": "commonjs", + "declaration": true, + "outDir": "./lib", + "strict": true, + "noImplicitAny": false, + "strictPropertyInitialization": false, + "strictNullChecks": false + }, + "include": ["src"], + "exclude": ["node_modules", "**/__tests__/*"] +} diff --git a/tslint.json b/tslint.json new file mode 100644 index 00000000..70fdbab2 --- /dev/null +++ b/tslint.json @@ -0,0 +1,3 @@ +{ + "extends": ["tslint:recommended", "tslint-config-prettier"] +} \ No newline at end of file