diff --git a/.gitattributes b/.gitattributes deleted file mode 100644 index da8c15f..0000000 --- a/.gitattributes +++ /dev/null @@ -1 +0,0 @@ -flake.lock binary diff --git a/.sops.yaml b/.sops.yaml deleted file mode 100644 index 7aa3d88..0000000 --- a/.sops.yaml +++ /dev/null @@ -1,28 +0,0 @@ -keys: - - &lelgenio-gpg 0FECE8316E74BA6F44EFC21A2F8F21CE8721456B - - &lelgenio-ssh age1zrgu7w8059xydagm60phnffghvfe9h2ca58cx8qwagqpyfuvs9fqw79c8h - - &monolith-ssh age1ecyynwv93lfu7crjjp8l47defv07quzfzaktwurpep7jc9eha5pscg7lrw - - &phantom-ssh age1m4mqcd2kmuhfr8a22rvh02c68jkakhdfmuqgtusuv0czk4jvna7sz79p3y - -creation_rules: - - path_regex: secrets/[^/]+\.(yaml|json|env|ini)$ - key_groups: - - pgp: - - *lelgenio-gpg - age: - - *lelgenio-ssh - - *monolith-ssh - - path_regex: secrets/monolith/[^/]+\.(yaml|json|env|ini)$ - key_groups: - - pgp: - - *lelgenio-gpg - age: - - *lelgenio-ssh - - *monolith-ssh - - path_regex: secrets/phantom/[^/]+\.(yaml|json|env|ini)$ - key_groups: - - pgp: - - *lelgenio-gpg - age: - - *lelgenio-ssh - - *phantom-ssh diff --git a/flake.lock b/flake.lock index 6e77084..0c0e72a 100644 --- a/flake.lock +++ b/flake.lock @@ -16,23 +16,37 @@ "type": "github" } }, + "advisory-db_2": { + "flake": false, + "locked": { + "lastModified": 1683272394, + "narHash": "sha256-4XQZbSZ8XYAeASpr0Er8mNPnjbYLJwvaB+VyH+bt6DE=", + "owner": "rustsec", + "repo": "advisory-db", + "rev": "50bed3ba4066e6255dab434dc845e7f655812ce1", + "type": "github" + }, + "original": { + "owner": "rustsec", + "repo": "advisory-db", + "type": "github" + } + }, "agenix": { "inputs": { "darwin": "darwin", - "home-manager": [ - "home-manager" - ], + "home-manager": "home-manager", "nixpkgs": [ "nixpkgs" ], "systems": "systems" }, "locked": { - "lastModified": 1747575206, - "narHash": "sha256-NwmAFuDUO/PFcgaGGr4j3ozG9Pe5hZ/ogitWhY+D81k=", + "lastModified": 1703433843, + "narHash": "sha256-nmtA4KqFboWxxoOAA6Y1okHbZh+HsXaMPFkYHsoDRDw=", "owner": "ryantm", "repo": "agenix", - "rev": "4835b1dc898959d8547a871ef484930675cb47f1", + "rev": "417caa847f9383e111d1397039c9d4337d024bf0", "type": "github" }, "original": { @@ -41,54 +55,6 @@ "type": "github" } }, - "blobs": { - "flake": false, - "locked": { - "lastModified": 1604995301, - "narHash": "sha256-wcLzgLec6SGJA8fx1OEN1yV/Py5b+U5iyYpksUY/yLw=", - "owner": "simple-nixos-mailserver", - "repo": "blobs", - "rev": "2cccdf1ca48316f2cfd1c9a0017e8de5a7156265", - "type": "gitlab" - }, - "original": { - "owner": "simple-nixos-mailserver", - "repo": "blobs", - "type": "gitlab" - } - }, - "catboy-spinner": { - "flake": false, - "locked": { - "lastModified": 1728098748, - "narHash": "sha256-FHM/a+wqctmg1LXf/XB6TcXowL0Wzbq1kSCGVnxGgL8=", - "ref": "refs/heads/main", - "rev": "c6fc11b0900826508f6a766c65cf92e0c7c4eab9", - "revCount": 4, - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/catboy-spinner" - }, - "original": { - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/catboy-spinner" - } - }, - "contador-da-viagem": { - "flake": false, - "locked": { - "lastModified": 1742610036, - "narHash": "sha256-sY1iheemazmIVJAnoFtut6cN7HX/C5OMDY54UrmCoqE=", - "ref": "refs/heads/main", - "rev": "efe5ac4a16de7f78824ac89dc987ef635afa5267", - "revCount": 4, - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/contador-da-viagem" - }, - "original": { - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/contador-da-viagem" - } - }, "crane": { "inputs": { "flake-compat": "flake-compat", @@ -115,38 +81,20 @@ }, "crane_2": { "inputs": { + "flake-compat": "flake-compat_2", + "flake-utils": "flake-utils_4", "nixpkgs": [ - "made-you-look", + "maildir-notify-daemon", "nixpkgs" - ] + ], + "rust-overlay": "rust-overlay_2" }, "locked": { - "lastModified": 1718730147, - "narHash": "sha256-QmD6B6FYpuoCqu6ZuPJH896ItNquDkn0ulQlOn4ykN8=", + "lastModified": 1683505101, + "narHash": "sha256-VBU64Jfu2V4sUR5+tuQS9erBRAe/QEYUxdVMcJGMZZs=", "owner": "ipetkov", "repo": "crane", - "rev": "32c21c29b034d0a93fdb2379d6fabc40fc3d0e6c", - "type": "github" - }, - "original": { - "owner": "ipetkov", - "repo": "crane", - "type": "github" - } - }, - "crane_3": { - "inputs": { - "nixpkgs": [ - "warthunder-leak-counter", - "nixpkgs" - ] - }, - "locked": { - "lastModified": 1718730147, - "narHash": "sha256-QmD6B6FYpuoCqu6ZuPJH896ItNquDkn0ulQlOn4ykN8=", - "owner": "ipetkov", - "repo": "crane", - "rev": "32c21c29b034d0a93fdb2379d6fabc40fc3d0e6c", + "rev": "7b5bd9e5acb2bb0cfba2d65f34d8568a894cdb6c", "type": "github" }, "original": { @@ -163,11 +111,11 @@ ] }, "locked": { - "lastModified": 1744478979, - "narHash": "sha256-dyN+teG9G82G+m+PX/aSAagkC+vUv0SgUw3XkPhQodQ=", + "lastModified": 1700795494, + "narHash": "sha256-gzGLZSiOhf155FW7262kdHo2YDeugp3VuIFb4/GGng0=", "owner": "lnl7", "repo": "nix-darwin", - "rev": "43975d782b418ebf4969e9ccba82466728c2851b", + "rev": "4b9b83d5a92e8c1fbfd8eb27eda375908c11ec4d", "type": "github" }, "original": { @@ -182,7 +130,9 @@ "advisory-db": "advisory-db", "crane": "crane", "flake-utils": "flake-utils_2", - "nixpkgs": "nixpkgs" + "nixpkgs": [ + "nixpkgs" + ] }, "locked": { "lastModified": 1693509848, @@ -202,7 +152,9 @@ "inputs": { "fenix": "fenix", "flake-utils": "flake-utils_3", - "nixpkgs": "nixpkgs_2" + "nixpkgs": [ + "nixpkgs" + ] }, "locked": { "lastModified": 1659395338, @@ -218,36 +170,33 @@ "type": "github" } }, - "disko": { - "inputs": { - "nixpkgs": [ - "nixpkgs" - ] - }, + "dzgui": { + "flake": false, "locked": { - "lastModified": 1749436314, - "narHash": "sha256-CqmqU5FRg5AadtIkxwu8ulDSOSoIisUMZRLlcED3Q5w=", - "owner": "nix-community", - "repo": "disko", - "rev": "dfa4d1b9c39c0342ef133795127a3af14598017a", + "lastModified": 1702780245, + "narHash": "sha256-cdW5LN2Q7eYW8xIqKPQfeYPd7e6VdJGaoA9NMHesCrE=", + "owner": "aclist", + "repo": "dztui", + "rev": "28323f3edb8fa747dc559d1939ccdd7729e4e3a1", "type": "github" }, "original": { - "owner": "nix-community", - "repo": "disko", + "owner": "aclist", + "repo": "dztui", "type": "github" } }, "dzgui-nix": { "inputs": { - "nixpkgs": "nixpkgs_3" + "dzgui": "dzgui", + "nixpkgs": "nixpkgs" }, "locked": { - "lastModified": 1749410315, - "narHash": "sha256-5H8MuMMSq1WnQcvb1FiDNkKP+uyeZ8HX5GRTMfEOyLI=", + "lastModified": 1702850463, + "narHash": "sha256-qR/c/GjsLUzrCyHN/Q9nnClduf6OqTg26S1AFYKPzxA=", "owner": "lelgenio", "repo": "dzgui-nix", - "rev": "49adbb1edfb3c25b0cd8256d35673394386065e7", + "rev": "2ed6515b27d8186b9fedfe1dcaf861f07e796a0d", "type": "github" }, "original": { @@ -297,11 +246,41 @@ "flake-compat_2": { "flake": false, "locked": { - "lastModified": 1747046372, - "narHash": "sha256-CIVLLkVgvHYbgI2UpXvIIBJ12HWgX+fjA8Xf8PUmqCY=", + "lastModified": 1673956053, + "narHash": "sha256-4gtG9iQuiKITOjNQQeQIpoIB6b16fm+504Ch3sNKLd8=", "owner": "edolstra", "repo": "flake-compat", - "rev": "9100a0f413b0c601e0533d1d94ffd501ce2e7885", + "rev": "35bb57c0c8d8b62bbfd284272c928ceb64ddbde9", + "type": "github" + }, + "original": { + "owner": "edolstra", + "repo": "flake-compat", + "type": "github" + } + }, + "flake-compat_3": { + "locked": { + "lastModified": 1696426674, + "narHash": "sha256-kvjfFW7WAETZlt09AgDn1MrtKzP7t90Vf7vypd3OL1U=", + "rev": "0f9255e01c2351cc7d116c072cb317785dd33b33", + "revCount": 57, + "type": "tarball", + "url": "https://api.flakehub.com/f/pinned/edolstra/flake-compat/1.0.1/018afb31-abd1-7bff-a5e4-cff7e18efb7a/source.tar.gz" + }, + "original": { + "type": "tarball", + "url": "https://flakehub.com/f/edolstra/flake-compat/1.tar.gz" + } + }, + "flake-compat_4": { + "flake": false, + "locked": { + "lastModified": 1650374568, + "narHash": "sha256-Z+s0J8/r907g149rllvwhb4pKi8Wam5ij0st8PwAh+E=", + "owner": "edolstra", + "repo": "flake-compat", + "rev": "b4a34015c698c7793d592d66adbab377907a2be8", "type": "github" }, "original": { @@ -328,6 +307,24 @@ "type": "github" } }, + "flake-utils-plus": { + "inputs": { + "flake-utils": "flake-utils_6" + }, + "locked": { + "lastModified": 1696331477, + "narHash": "sha256-YkbRa/1wQWdWkVJ01JvV+75KIdM37UErqKgTf0L54Fk=", + "owner": "gytis-ivaskevicius", + "repo": "flake-utils-plus", + "rev": "bfc53579db89de750b25b0c5e7af299e0c06d7d3", + "type": "github" + }, + "original": { + "owner": "gytis-ivaskevicius", + "repo": "flake-utils-plus", + "type": "github" + } + }, "flake-utils_2": { "inputs": { "systems": "systems_3" @@ -363,7 +360,7 @@ }, "flake-utils_4": { "inputs": { - "systems": "systems_4" + "systems": "systems_5" }, "locked": { "lastModified": 1681202837, @@ -381,7 +378,7 @@ }, "flake-utils_5": { "inputs": { - "systems": "systems_5" + "systems": "systems_6" }, "locked": { "lastModified": 1681202837, @@ -399,7 +396,25 @@ }, "flake-utils_6": { "inputs": { - "systems": "systems_6" + "systems": "systems_8" + }, + "locked": { + "lastModified": 1694529238, + "narHash": "sha256-zsNZZGTGnMOf9YpHKJqMSsa0dXbfmxeoJ7xHlrt+xmY=", + "owner": "numtide", + "repo": "flake-utils", + "rev": "ff7b65b44d01cf9ba6a71320833626af21126384", + "type": "github" + }, + "original": { + "owner": "numtide", + "repo": "flake-utils", + "type": "github" + } + }, + "flake-utils_7": { + "inputs": { + "systems": "systems_9" }, "locked": { "lastModified": 1681202837, @@ -415,16 +430,16 @@ "type": "github" } }, - "flake-utils_7": { + "flake-utils_8": { "inputs": { - "systems": "systems_7" + "systems": "systems_10" }, "locked": { - "lastModified": 1710146030, - "narHash": "sha256-SZ5L6eA7HJ/nmkzGG7/ISclqe6oZdOZTNoesiInkXPQ=", + "lastModified": 1681202837, + "narHash": "sha256-H+Rh19JDwRtpVPAWp64F+rlEtxUWBAQW28eAi3SRSzg=", "owner": "numtide", "repo": "flake-utils", - "rev": "b1d9ab70662946ef0850d488da1c9019f3a9752a", + "rev": "cfacdce06f30d2b68473a46042957675eebb3401", "type": "github" }, "original": { @@ -433,109 +448,172 @@ "type": "github" } }, - "git-hooks": { - "inputs": { - "flake-compat": [ - "nixos-mailserver", - "flake-compat" - ], - "gitignore": "gitignore", - "nixpkgs": [ - "nixos-mailserver", - "nixpkgs" - ] - }, - "locked": { - "lastModified": 1742649964, - "narHash": "sha256-DwOTp7nvfi8mRfuL1escHDXabVXFGT1VlPD1JHrtrco=", - "owner": "cachix", - "repo": "git-hooks.nix", - "rev": "dcf5072734cb576d2b0c59b2ac44f5050b5eac82", - "type": "github" - }, - "original": { - "owner": "cachix", - "repo": "git-hooks.nix", - "type": "github" - } - }, - "gitignore": { - "inputs": { - "nixpkgs": [ - "nixos-mailserver", - "git-hooks", - "nixpkgs" - ] - }, - "locked": { - "lastModified": 1709087332, - "narHash": "sha256-HG2cCnktfHsKV0s4XW83gU3F57gaTljL9KNSuG6bnQs=", - "owner": "hercules-ci", - "repo": "gitignore.nix", - "rev": "637db329424fd7e46cf4185293b9cc8c88c95394", - "type": "github" - }, - "original": { - "owner": "hercules-ci", - "repo": "gitignore.nix", - "type": "github" - } - }, - "hello-fonts": { - "flake": false, - "locked": { - "lastModified": 1728232065, - "narHash": "sha256-1DUW1YqZALPFxBM7HYcNZiCZQvMqUiJ1m04NU4IIe3I=", - "ref": "refs/heads/main", - "rev": "10f7485fea930bb45e97fbda0cd68f199a7e8f59", - "revCount": 1, - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/hello-fonts" - }, - "original": { - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/hello-fonts" - } - }, "home-manager": { "inputs": { "nixpkgs": [ + "agenix", "nixpkgs" ] }, "locked": { - "lastModified": 1749154018, - "narHash": "sha256-gjN3j7joRvT3a8Zgcylnd4NFsnXeDBumqiu4HmY1RIg=", + "lastModified": 1703113217, + "narHash": "sha256-7ulcXOk63TIT2lVDSExj7XzFx09LpdSAPtvgtM7yQPE=", "owner": "nix-community", "repo": "home-manager", - "rev": "7aae0ee71a17b19708b93b3ed448a1a0952bf111", + "rev": "3bfaacf46133c037bb356193bd2f1765d9dc82c1", "type": "github" }, "original": { "owner": "nix-community", - "ref": "release-25.05", "repo": "home-manager", "type": "github" } }, - "made-you-look": { + "home-manager_2": { "inputs": { - "crane": "crane_2", - "flake-utils": "flake-utils_4", - "nixpkgs": "nixpkgs_4" + "nixpkgs": [ + "nixpkgs" + ] }, "locked": { - "lastModified": 1728159958, - "narHash": "sha256-r/h/ch70KfOQ8moftDhHagu3WajglaqU+hrEzUtTM1Y=", - "ref": "refs/heads/main", - "rev": "96e978aa2f414d4b92b78e7ae975d7ff7db95a91", - "revCount": 3, - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/made-you-look" + "lastModified": 1705476964, + "narHash": "sha256-W5OK1fnj4qdn1HWOlxV2S3YiUvfaVjQM5ldWVpGV1fs=", + "owner": "nix-community", + "repo": "home-manager", + "rev": "85c3b600f660abd86e94cbcd1c46733943197a07", + "type": "github" }, "original": { - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/made-you-look" + "owner": "nix-community", + "ref": "release-23.11", + "repo": "home-manager", + "type": "github" + } + }, + "hyprland": { + "inputs": { + "hyprland-protocols": "hyprland-protocols", + "nixpkgs": [ + "nixpkgs" + ], + "systems": "systems_4", + "wlroots": "wlroots", + "xdph": "xdph" + }, + "locked": { + "lastModified": 1705503680, + "narHash": "sha256-e+ou1KvZeZp104yeCgvgTTp5G+DB380CUZuUkijZxAc=", + "owner": "hyprwm", + "repo": "Hyprland", + "rev": "c4365f20ed8ff0dd480b7ed7cf1bfff1a0b6911a", + "type": "github" + }, + "original": { + "owner": "hyprwm", + "repo": "Hyprland", + "type": "github" + } + }, + "hyprland-protocols": { + "inputs": { + "nixpkgs": [ + "hyprland", + "nixpkgs" + ], + "systems": [ + "hyprland", + "systems" + ] + }, + "locked": { + "lastModified": 1691753796, + "narHash": "sha256-zOEwiWoXk3j3+EoF3ySUJmberFewWlagvewDRuWYAso=", + "owner": "hyprwm", + "repo": "hyprland-protocols", + "rev": "0c2ce70625cb30aef199cb388f99e19a61a6ce03", + "type": "github" + }, + "original": { + "owner": "hyprwm", + "repo": "hyprland-protocols", + "type": "github" + } + }, + "hyprlang": { + "inputs": { + "nixpkgs": [ + "hyprland", + "xdph", + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1704287638, + "narHash": "sha256-TuRXJGwtK440AXQNl5eiqmQqY4LZ/9+z/R7xC0ie3iA=", + "owner": "hyprwm", + "repo": "hyprlang", + "rev": "6624f2bb66d4d27975766e81f77174adbe58ec97", + "type": "github" + }, + "original": { + "owner": "hyprwm", + "repo": "hyprlang", + "type": "github" + } + }, + "lipsum": { + "flake": false, + "locked": { + "lastModified": 1630421397, + "narHash": "sha256-a6uv0tJulN9cAGWxvQr8B0PUJEY8Rx4e759xzS66Xlo=", + "owner": "hannenz", + "repo": "lipsum", + "rev": "0fb31e6ede10fbd78d7652f5fb21670cddd8e3ed", + "type": "github" + }, + "original": { + "owner": "hannenz", + "repo": "lipsum", + "type": "github" + } + }, + "maildir-notify-daemon": { + "inputs": { + "advisory-db": "advisory-db_2", + "crane": "crane_2", + "flake-utils": "flake-utils_5", + "nixpkgs": [ + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1683946606, + "narHash": "sha256-nzI8XDjf7Q0NZdVuxEvkkU4x0w229DmJZAN2yB92oMc=", + "owner": "lelgenio", + "repo": "maildir-notify-daemon", + "rev": "f609cbd6dd6accce8f24594bc2e13822023e3d79", + "type": "github" + }, + "original": { + "owner": "lelgenio", + "repo": "maildir-notify-daemon", + "type": "github" + } + }, + "material-wifi-icons": { + "flake": false, + "locked": { + "lastModified": 1703850449, + "narHash": "sha256-KykU5J7SdpBDG+6rkD//XeHd+6pK3qabe+88RduhwKc=", + "owner": "dcousens", + "repo": "material-wifi-icons", + "rev": "2daf6b3d96d65beb2a3e37a9a53556aab3826d97", + "type": "github" + }, + "original": { + "owner": "dcousens", + "repo": "material-wifi-icons", + "type": "github" } }, "nix-index-database": { @@ -545,11 +623,11 @@ ] }, "locked": { - "lastModified": 1749355504, - "narHash": "sha256-L17CdJMD+/FCBOHjREQLXbe2VUnc3rjffenBbu2Kwpc=", + "lastModified": 1705282324, + "narHash": "sha256-LnURMA7yCM5t7et9O2+2YfGQh0FKAfE5GyahNDDzJVM=", "owner": "Mic92", "repo": "nix-index-database", - "rev": "40a6e15e44b11fbf8f2b1df9d64dbfc117625e94", + "rev": "49aaeecf41ae0a0944e2c627cb515bcde428a1d1", "type": "github" }, "original": { @@ -558,187 +636,123 @@ "type": "github" } }, - "nixos-mailserver": { + "nix-software-center": { "inputs": { - "blobs": "blobs", - "flake-compat": "flake-compat_2", - "git-hooks": "git-hooks", - "nixpkgs": [ - "nixpkgs" - ], - "nixpkgs-25_05": "nixpkgs-25_05" + "nixpkgs": "nixpkgs_2", + "utils": "utils" }, "locked": { - "lastModified": 1747965231, - "narHash": "sha256-BW3ktviEhfCN/z3+kEyzpDKAI8qFTwO7+S0NVA0C90o=", - "owner": "simple-nixos-mailserver", - "repo": "nixos-mailserver", - "rev": "53007af63fade28853408370c4c600a63dd97f41", - "type": "gitlab" + "lastModified": 1703105285, + "narHash": "sha256-BHoW1RQMc2Auz8paBvTBriKv0F6FI99+3nnz/ELLawg=", + "owner": "vlinkz", + "repo": "nix-software-center", + "rev": "68e87fb6e24fb3e6fe65449918d0cbda96622b65", + "type": "github" }, "original": { - "owner": "simple-nixos-mailserver", - "ref": "nixos-25.05", - "repo": "nixos-mailserver", - "type": "gitlab" + "owner": "vlinkz", + "repo": "nix-software-center", + "type": "github" + } + }, + "nixos-conf-editor": { + "inputs": { + "flake-compat": "flake-compat_3", + "nixpkgs": "nixpkgs_3", + "snowfall-lib": "snowfall-lib" + }, + "locked": { + "lastModified": 1703104726, + "narHash": "sha256-9wD01mLe7tQCzTtLIRzUaAvOKzfPuWPfpCfYkeCsQD0=", + "owner": "vlinkz", + "repo": "nixos-conf-editor", + "rev": "18dc1d25b2025dc437490c71653429a05f9e0bf2", + "type": "github" + }, + "original": { + "owner": "vlinkz", + "repo": "nixos-conf-editor", + "type": "github" } }, "nixpkgs": { "locked": { - "lastModified": 1684425776, - "narHash": "sha256-eXzSIXkzXa9EecoDF9xCsoim0vd++8dvYU7QOuQMO8A=", + "lastModified": 1702539185, + "narHash": "sha256-KnIRG5NMdLIpEkZTnN5zovNYc0hhXjAgv6pfd5Z4c7U=", "owner": "NixOS", "repo": "nixpkgs", - "rev": "8dc174d8b768893172eb3e52008f10f48dfbd5cf", - "type": "github" - }, - "original": { - "owner": "NixOS", - "ref": "release-22.11", - "repo": "nixpkgs", - "type": "github" - } - }, - "nixpkgs-25_05": { - "locked": { - "lastModified": 1747610100, - "narHash": "sha256-rpR5ZPMkWzcnCcYYo3lScqfuzEw5Uyfh+R0EKZfroAc=", - "owner": "NixOS", - "repo": "nixpkgs", - "rev": "ca49c4304acf0973078db0a9d200fd2bae75676d", - "type": "github" - }, - "original": { - "owner": "NixOS", - "ref": "nixos-25.05", - "repo": "nixpkgs", - "type": "github" - } - }, - "nixpkgs-unstable": { - "locked": { - "lastModified": 1749285348, - "narHash": "sha256-frdhQvPbmDYaScPFiCnfdh3B/Vh81Uuoo0w5TkWmmjU=", - "owner": "NixOS", - "repo": "nixpkgs", - "rev": "3e3afe5174c561dee0df6f2c2b2236990146329f", + "rev": "aa9d4729cbc99dabacb50e3994dcefb3ea0f7447", "type": "github" }, "original": { "id": "nixpkgs", - "ref": "nixos-unstable", + "ref": "nixpkgs-unstable", "type": "indirect" } }, + "nixpkgs-fixed-steam": { + "locked": { + "lastModified": 1701016343, + "narHash": "sha256-UhFqv2bl/ZB4RwGxq1Qp6+91uZDwTEA80rxALTiJ3fg=", + "owner": "lelgenio", + "repo": "nixpkgs", + "rev": "ac4d51306af54a088e29e2e5efcfac5dfe87d95c", + "type": "github" + }, + "original": { + "owner": "lelgenio", + "ref": "test-steam-fix", + "repo": "nixpkgs", + "type": "github" + } + }, "nixpkgs_2": { "locked": { - "lastModified": 1659219666, - "narHash": "sha256-pzYr5fokQPHv7CmUXioOhhzDy/XyWOIXP4LZvv/T7Mk=", + "lastModified": 1692638711, + "narHash": "sha256-J0LgSFgJVGCC1+j5R2QndadWI1oumusg6hCtYAzLID4=", "owner": "NixOS", "repo": "nixpkgs", - "rev": "7b9be38c7250b22d829ab6effdee90d5e40c6e5c", + "rev": "91a22f76cd1716f9d0149e8a5c68424bb691de15", "type": "github" }, "original": { - "id": "nixpkgs", + "owner": "NixOS", "ref": "nixos-unstable", - "type": "indirect" + "repo": "nixpkgs", + "type": "github" } }, "nixpkgs_3": { "locked": { - "lastModified": 1732812356, - "narHash": "sha256-LNcgjOLArRlx2W6XSi0yc0xwLjrK3KF9LxAMqUgFDgw=", - "owner": "NixOS", + "lastModified": 1698318101, + "narHash": "sha256-gUihHt3yPD7bVqg+k/UVHgngyaJ3DMEBchbymBMvK1E=", + "owner": "nixos", "repo": "nixpkgs", - "rev": "581d7e4d23b91daf2afa0005a5d3d01d6a8884fe", + "rev": "63678e9f3d3afecfeafa0acead6239cdb447574c", "type": "github" }, "original": { - "id": "nixpkgs", - "ref": "nixpkgs-unstable", - "type": "indirect" + "owner": "nixos", + "ref": "nixos-unstable", + "repo": "nixpkgs", + "type": "github" } }, "nixpkgs_4": { "locked": { - "lastModified": 1719010183, - "narHash": "sha256-8HMWaqpyjbVeEsmy/A2H6VFtW/Wr71vkPLnpTiAXu+8=", + "lastModified": 1705458851, + "narHash": "sha256-uQvEhiv33Zj/Pv364dTvnpPwFSptRZgVedDzoM+HqVg=", "owner": "NixOS", "repo": "nixpkgs", - "rev": "0f620ca71fa69abb411a6c78739a9b171a0a95a6", - "type": "github" - }, - "original": { - "owner": "NixOS", - "ref": "release-24.05", - "repo": "nixpkgs", - "type": "github" - } - }, - "nixpkgs_5": { - "locked": { - "lastModified": 1749727998, - "narHash": "sha256-mHv/yeUbmL91/TvV95p+mBVahm9mdQMJoqaTVTALaFw=", - "owner": "NixOS", - "repo": "nixpkgs", - "rev": "fd487183437963a59ba763c0cc4f27e3447dd6dd", + "rev": "8bf65f17d8070a0a490daf5f1c784b87ee73982c", "type": "github" }, "original": { "id": "nixpkgs", - "ref": "nixos-25.05", + "ref": "nixos-23.11", "type": "indirect" } }, - "nixpkgs_6": { - "locked": { - "lastModified": 1747958103, - "narHash": "sha256-qmmFCrfBwSHoWw7cVK4Aj+fns+c54EBP8cGqp/yK410=", - "owner": "nixos", - "repo": "nixpkgs", - "rev": "fe51d34885f7b5e3e7b59572796e1bcb427eccb1", - "type": "github" - }, - "original": { - "owner": "nixos", - "ref": "nixpkgs-unstable", - "repo": "nixpkgs", - "type": "github" - } - }, - "nixpkgs_7": { - "locked": { - "lastModified": 1719010183, - "narHash": "sha256-8HMWaqpyjbVeEsmy/A2H6VFtW/Wr71vkPLnpTiAXu+8=", - "owner": "NixOS", - "repo": "nixpkgs", - "rev": "0f620ca71fa69abb411a6c78739a9b171a0a95a6", - "type": "github" - }, - "original": { - "owner": "NixOS", - "ref": "release-24.05", - "repo": "nixpkgs", - "type": "github" - } - }, - "nixpkgs_8": { - "locked": { - "lastModified": 1714091391, - "narHash": "sha256-68n3GBvlm1MIeJXadPzQ3v8Y9sIW3zmv8gI5w5sliC8=", - "owner": "NixOS", - "repo": "nixpkgs", - "rev": "4c86138ce486d601d956a165e2f7a0fc029a03c1", - "type": "github" - }, - "original": { - "owner": "NixOS", - "ref": "nixpkgs-unstable", - "repo": "nixpkgs", - "type": "github" - } - }, "plymouth-themes": { "flake": false, "locked": { @@ -758,11 +772,11 @@ "ranger-icons": { "flake": false, "locked": { - "lastModified": 1749128401, - "narHash": "sha256-qvWqKVS4C5OO6bgETBlVDwcv4eamGlCUltjsBU3gAbA=", + "lastModified": 1691165140, + "narHash": "sha256-6JEhyU08QEkGdRW2L00ynRaoaaR5PaiVUccEUbtTQuU=", "owner": "alexanderjeurissen", "repo": "ranger_devicons", - "rev": "1bcaff0366a9d345313dc5af14002cfdcddabb82", + "rev": "de64ab26fb581c00a803381d522c6b3e48b79415", "type": "github" }, "original": { @@ -774,29 +788,23 @@ "root": { "inputs": { "agenix": "agenix", - "catboy-spinner": "catboy-spinner", - "contador-da-viagem": "contador-da-viagem", "demoji": "demoji", "dhist": "dhist", - "disko": "disko", "dzgui-nix": "dzgui-nix", - "hello-fonts": "hello-fonts", - "home-manager": "home-manager", - "made-you-look": "made-you-look", + "home-manager": "home-manager_2", + "hyprland": "hyprland", + "lipsum": "lipsum", + "maildir-notify-daemon": "maildir-notify-daemon", + "material-wifi-icons": "material-wifi-icons", "nix-index-database": "nix-index-database", - "nixos-mailserver": "nixos-mailserver", - "nixpkgs": "nixpkgs_5", - "nixpkgs-unstable": "nixpkgs-unstable", + "nix-software-center": "nix-software-center", + "nixos-conf-editor": "nixos-conf-editor", + "nixpkgs": "nixpkgs_4", + "nixpkgs-fixed-steam": "nixpkgs-fixed-steam", "plymouth-themes": "plymouth-themes", "ranger-icons": "ranger-icons", - "sops-nix": "sops-nix", "tlauncher": "tlauncher", - "tomater": "tomater", - "treefmt-nix": "treefmt-nix", - "vpsadminos": "vpsadminos", - "warthunder-leak-counter": "warthunder-leak-counter", - "wl-crosshair": "wl-crosshair", - "youre-wrong": "youre-wrong" + "wl-crosshair": "wl-crosshair" } }, "rust-analyzer-src": { @@ -843,23 +851,53 @@ "type": "github" } }, - "sops-nix": { + "rust-overlay_2": { "inputs": { + "flake-utils": [ + "maildir-notify-daemon", + "crane", + "flake-utils" + ], "nixpkgs": [ + "maildir-notify-daemon", + "crane", "nixpkgs" ] }, "locked": { - "lastModified": 1749592509, - "narHash": "sha256-VunQzfZFA+Y6x3wYi2UE4DEQ8qKoAZZCnZPUlSoqC+A=", - "owner": "Mic92", - "repo": "sops-nix", - "rev": "50754dfaa0e24e313c626900d44ef431f3210138", + "lastModified": 1683080331, + "narHash": "sha256-nGDvJ1DAxZIwdn6ww8IFwzoHb2rqBP4wv/65Wt5vflk=", + "owner": "oxalica", + "repo": "rust-overlay", + "rev": "d59c3fa0cba8336e115b376c2d9e91053aa59e56", "type": "github" }, "original": { - "owner": "Mic92", - "repo": "sops-nix", + "owner": "oxalica", + "repo": "rust-overlay", + "type": "github" + } + }, + "snowfall-lib": { + "inputs": { + "flake-compat": "flake-compat_4", + "flake-utils-plus": "flake-utils-plus", + "nixpkgs": [ + "nixos-conf-editor", + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1696432959, + "narHash": "sha256-oJQZv2MYyJaVyVJY5IeevzqpGvMGKu5pZcCCJvb+xjc=", + "owner": "snowfallorg", + "repo": "lib", + "rev": "92803a029b5314d4436a8d9311d8707b71d9f0b6", + "type": "github" + }, + "original": { + "owner": "snowfallorg", + "repo": "lib", "type": "github" } }, @@ -878,6 +916,21 @@ "type": "github" } }, + "systems_10": { + "locked": { + "lastModified": 1681028828, + "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", + "owner": "nix-systems", + "repo": "default", + "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", + "type": "github" + }, + "original": { + "owner": "nix-systems", + "repo": "default", + "type": "github" + } + }, "systems_2": { "locked": { "lastModified": 1681028828, @@ -910,16 +963,16 @@ }, "systems_4": { "locked": { - "lastModified": 1681028828, - "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", + "lastModified": 1689347949, + "narHash": "sha256-12tWmuL2zgBgZkdoB6qXZsgJEH9LR3oUgpaQq2RbI80=", "owner": "nix-systems", - "repo": "default", - "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", + "repo": "default-linux", + "rev": "31732fcf5e8fea42e59c2488ad31a0e651500f68", "type": "github" }, "original": { "owner": "nix-systems", - "repo": "default", + "repo": "default-linux", "type": "github" } }, @@ -968,107 +1021,88 @@ "type": "github" } }, + "systems_8": { + "locked": { + "lastModified": 1681028828, + "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", + "owner": "nix-systems", + "repo": "default", + "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", + "type": "github" + }, + "original": { + "owner": "nix-systems", + "repo": "default", + "type": "github" + } + }, + "systems_9": { + "locked": { + "lastModified": 1681028828, + "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", + "owner": "nix-systems", + "repo": "default", + "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", + "type": "github" + }, + "original": { + "owner": "nix-systems", + "repo": "default", + "type": "github" + } + }, "tlauncher": { "inputs": { - "flake-utils": "flake-utils_5", + "flake-utils": "flake-utils_7", "nixpkgs": [ "nixpkgs" ] }, "locked": { - "lastModified": 1734044605, - "narHash": "sha256-CeCYv3JFJIySSf2eX9ceEOF1FqNGeJnzEuO5f+OvioQ=", - "ref": "refs/heads/main", - "rev": "6a68f2cda0aa2fbb399a4c43b445e8c1a2df0634", - "revCount": 4, - "type": "git", - "url": "https://git.lelgenio.xyz/lelgenio/tlauncher-nix" + "lastModified": 1684504342, + "narHash": "sha256-rJ0eH7BuPizvXPc+LjVtovse4gWEuxP2WiyNdXjPNL4=", + "owner": "lelgenio", + "repo": "tlauncher-nix", + "rev": "add4df7220bd0b85177a1938c02b60c966c5eb71", + "type": "github" }, "original": { - "type": "git", - "url": "https://git.lelgenio.xyz/lelgenio/tlauncher-nix" + "owner": "lelgenio", + "repo": "tlauncher-nix", + "type": "github" } }, - "tomater": { - "flake": false, - "locked": { - "lastModified": 1728089744, - "narHash": "sha256-WOz/qUKyao7lM2qcwqqcJDw4jI8mUJL6kNUNm0sxPKk=", - "ref": "refs/heads/main", - "rev": "efff561c745514a7874e3f5de95307a74efc7df9", - "revCount": 1, - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/tomater" - }, - "original": { - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/tomater" - } - }, - "treefmt-nix": { + "utils": { "inputs": { - "nixpkgs": "nixpkgs_6" + "systems": "systems_7" }, "locked": { - "lastModified": 1749194973, - "narHash": "sha256-eEy8cuS0mZ2j/r/FE0/LYBSBcIs/MKOIVakwHVuqTfk=", + "lastModified": 1689068808, + "narHash": "sha256-6ixXo3wt24N/melDWjq70UuHQLxGV8jZvooRanIHXw0=", "owner": "numtide", - "repo": "treefmt-nix", - "rev": "a05be418a1af1198ca0f63facb13c985db4cb3c5", + "repo": "flake-utils", + "rev": "919d646de7be200f3bf08cb76ae1f09402b6f9b4", "type": "github" }, "original": { "owner": "numtide", - "repo": "treefmt-nix", + "repo": "flake-utils", "type": "github" } }, - "vpsadminos": { - "locked": { - "lastModified": 1749716966, - "narHash": "sha256-aF+YOXv07qI7Q267gqapUcAsoQkI3+EcmZczatq6wkg=", - "owner": "vpsfreecz", - "repo": "vpsadminos", - "rev": "2d991bb5109350801a381bff097809b76ee962f5", - "type": "github" - }, - "original": { - "owner": "vpsfreecz", - "repo": "vpsadminos", - "type": "github" - } - }, - "warthunder-leak-counter": { - "inputs": { - "crane": "crane_3", - "flake-utils": "flake-utils_6", - "nixpkgs": "nixpkgs_7" - }, - "locked": { - "lastModified": 1719076817, - "narHash": "sha256-B6NTomYXL50j6fabZrAGvTPp3zv5oFxNUhwvLhDNoMw=", - "ref": "refs/heads/main", - "rev": "406d6646970191c016a375f25a35aa00dfa0d4aa", - "revCount": 4, - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/warthunder-leak-counter" - }, - "original": { - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/warthunder-leak-counter" - } - }, "wl-crosshair": { "inputs": { - "flake-utils": "flake-utils_7", - "nixpkgs": "nixpkgs_8" + "flake-utils": "flake-utils_8", + "nixpkgs": [ + "nixpkgs" + ] }, "locked": { - "lastModified": 1715216838, - "narHash": "sha256-q5key9BWJjJQqECrhflso9ZTzULBeScvromo0S4fjqE=", + "lastModified": 1685576039, + "narHash": "sha256-WMkWurJsZZG7YkWzW/k2SNquYLsAZjzFs7CFswSjDew=", "owner": "lelgenio", "repo": "wl-crosshair", - "rev": "39b716cf410a1b45006f50f32f8d63de5c43aedb", + "rev": "57d0908e10d9f58fc37fe866404cc8b66be1f0d9", "type": "github" }, "original": { @@ -1077,20 +1111,53 @@ "type": "github" } }, - "youre-wrong": { + "wlroots": { "flake": false, "locked": { - "lastModified": 1728228087, - "narHash": "sha256-W40rQbQAo3lGrKlfenSA8JaGwZMSx/X4lP71enQtK7Y=", - "ref": "refs/heads/main", - "rev": "64e7876233e99ad7223cae29688374a1c1ff569a", - "revCount": 2, - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/youre-wrong" + "host": "gitlab.freedesktop.org", + "lastModified": 1703963193, + "narHash": "sha256-ke8drv6PTrdQDruWbajrRJffP9A9PU6FRyjJGNZRTs4=", + "owner": "wlroots", + "repo": "wlroots", + "rev": "f81c3d93cd6f61b20ae784297679283438def8df", + "type": "gitlab" }, "original": { - "type": "git", - "url": "https://git.lelgenio.com/lelgenio/youre-wrong" + "host": "gitlab.freedesktop.org", + "owner": "wlroots", + "repo": "wlroots", + "rev": "f81c3d93cd6f61b20ae784297679283438def8df", + "type": "gitlab" + } + }, + "xdph": { + "inputs": { + "hyprland-protocols": [ + "hyprland", + "hyprland-protocols" + ], + "hyprlang": "hyprlang", + "nixpkgs": [ + "hyprland", + "nixpkgs" + ], + "systems": [ + "hyprland", + "systems" + ] + }, + "locked": { + "lastModified": 1704659450, + "narHash": "sha256-3lyoUVtUWz1LuxbltAtkJSK2IlVXmKhxCRU2/0PYCms=", + "owner": "hyprwm", + "repo": "xdg-desktop-portal-hyprland", + "rev": "6a5de92769d5b7038134044053f90e7458f6a197", + "type": "github" + }, + "original": { + "owner": "hyprwm", + "repo": "xdg-desktop-portal-hyprland", + "type": "github" } } }, diff --git a/flake.nix b/flake.nix index 0818b6a..2716537 100644 --- a/flake.nix +++ b/flake.nix @@ -1,183 +1,161 @@ { description = "My system config"; inputs = { - nixpkgs.url = "nixpkgs/nixos-25.05"; - nixpkgs-unstable.url = "nixpkgs/nixos-unstable"; - - home-manager.url = "github:nix-community/home-manager/release-25.05"; + nixpkgs.url = "nixpkgs/nixos-23.11"; + home-manager.url = "github:nix-community/home-manager/release-23.11"; home-manager.inputs.nixpkgs.follows = "nixpkgs"; - vpsadminos.url = "github:vpsfreecz/vpsadminos"; - nix-index-database = { url = "github:Mic92/nix-index-database"; inputs.nixpkgs.follows = "nixpkgs"; }; + hyprland = { + url = "github:hyprwm/Hyprland"; + inputs.nixpkgs.follows = "nixpkgs"; + }; + ranger-icons.url = "github:alexanderjeurissen/ranger_devicons"; ranger-icons.flake = false; + material-wifi-icons.url = "github:dcousens/material-wifi-icons"; + material-wifi-icons.flake = false; + plymouth-themes.url = "github:adi1090x/plymouth-themes"; plymouth-themes.flake = false; + lipsum.url = "github:hannenz/lipsum"; + lipsum.flake = false; + agenix = { url = "github:ryantm/agenix"; inputs.nixpkgs.follows = "nixpkgs"; - inputs.home-manager.follows = "home-manager"; }; - sops-nix = { - url = "github:Mic92/sops-nix"; - inputs.nixpkgs.follows = "nixpkgs"; + dzgui-nix = { + url = "github:lelgenio/dzgui-nix"; }; - nixos-mailserver = { - url = "gitlab:simple-nixos-mailserver/nixos-mailserver/nixos-25.05"; - inputs.nixpkgs.follows = "nixpkgs"; - }; - - dzgui-nix.url = "github:lelgenio/dzgui-nix"; - tlauncher = { - url = "git+https://git.lelgenio.xyz/lelgenio/tlauncher-nix"; + url = "github:lelgenio/tlauncher-nix"; inputs.nixpkgs.follows = "nixpkgs"; }; - disko = { - url = "github:nix-community/disko"; - inputs.nixpkgs.follows = "nixpkgs"; - }; - - treefmt-nix.url = "github:numtide/treefmt-nix"; - # my stuff - dhist.url = "github:lelgenio/dhist"; - demoji.url = "github:lelgenio/demoji"; - wl-crosshair.url = "github:lelgenio/wl-crosshair"; - warthunder-leak-counter.url = "git+https://git.lelgenio.com/lelgenio/warthunder-leak-counter"; - made-you-look.url = "git+https://git.lelgenio.com/lelgenio/made-you-look"; - contador-da-viagem = { - url = "git+https://git.lelgenio.com/lelgenio/contador-da-viagem"; - flake = false; + dhist = { + url = "github:lelgenio/dhist"; + inputs.nixpkgs.follows = "nixpkgs"; }; - catboy-spinner = { - url = "git+https://git.lelgenio.com/lelgenio/catboy-spinner"; - flake = false; + demoji = { + url = "github:lelgenio/demoji"; + inputs.nixpkgs.follows = "nixpkgs"; }; - tomater = { - url = "git+https://git.lelgenio.com/lelgenio/tomater"; - flake = false; + maildir-notify-daemon = { + url = "github:lelgenio/maildir-notify-daemon"; + inputs.nixpkgs.follows = "nixpkgs"; }; - youre-wrong = { - url = "git+https://git.lelgenio.com/lelgenio/youre-wrong"; - flake = false; - }; - hello-fonts = { - url = "git+https://git.lelgenio.com/lelgenio/hello-fonts"; - flake = false; + wl-crosshair = { + url = "github:lelgenio/wl-crosshair"; + inputs.nixpkgs.follows = "nixpkgs"; }; + nixpkgs-fixed-steam.url = "github:lelgenio/nixpkgs/test-steam-fix"; + + # gnome stuff + nixos-conf-editor.url = "github:vlinkz/nixos-conf-editor"; + nix-software-center.url = "github:vlinkz/nix-software-center"; }; - outputs = - inputs: + outputs = inputs: let nixpkgsConfig = { inherit system; - config = { - allowUnfree = true; - }; + config = { allowUnfree = true; }; overlays = old_overlays.all; }; + bootstrapPkgs = import inputs.nixpkgs nixpkgsConfig; + nixpkgs = bootstrapPkgs.applyPatches { + name = "patched-nixpkgs"; + src = inputs.nixpkgs; + patches = lib.mapAttrsToList (k: v: ./patches/nixpkgs/${k}) + (builtins.readDir ./patches/nixpkgs); + }; + inherit (import ./user/variables.nix) desktop; system = "x86_64-linux"; - pkgs = import inputs.nixpkgs nixpkgsConfig; + pkgs = import nixpkgs nixpkgsConfig; lib = inputs.nixpkgs.lib; packages = import ./pkgs { inherit pkgs inputs; }; old_overlays = (import ./overlays { inherit packages inputs; }); - specialArgs = { - inherit inputs; - }; - common_modules = - [ - { nixpkgs.pkgs = pkgs; } - ./system/configuration.nix - ./system/secrets.nix - ./system/sops.nix - ./system/greetd.nix - { login-manager.greetd.enable = desktop == "sway"; } + specialArgs = { inherit inputs; }; + common_modules = [ + { nixpkgs.pkgs = pkgs; } + ./system/configuration.nix + ./system/secrets.nix + ./system/specialisation.nix + ./system/greetd.nix + { login-manager.greetd.enable = desktop == "sway" || desktop == "hyprland"; } - inputs.agenix.nixosModules.default - inputs.sops-nix.nixosModules.default - inputs.home-manager.nixosModules.home-manager - inputs.disko.nixosModules.disko - ( - { config, ... }: - { - home-manager.useGlobalPkgs = true; - home-manager.useUserPackages = true; - home-manager.users.lelgenio = { - my = config.my; - imports = [ - ./user/home.nix - ]; - }; - home-manager.backupFileExtension = "bkp"; - # Optionally, use home-manager.extraSpecialArgs to pass - # arguments to home.nix - home-manager.extraSpecialArgs = { - inherit inputs; - }; - } - ) - ] - ++ lib.optional (desktop == "gnome") ./system/gnome.nix - ++ lib.optional (desktop == "kde") ./system/kde.nix; + inputs.agenix.nixosModules.default + # inputs.hyprland.nixosModules.default + inputs.dzgui-nix.nixosModules.default + { programs.hyprland.enable = (desktop == "hyprland"); } + inputs.home-manager.nixosModules.home-manager + { + home-manager.useGlobalPkgs = true; + home-manager.useUserPackages = true; + home-manager.users.lelgenio = import ./user/home.nix; + home-manager.backupFileExtension = "bkp"; + # Optionally, use home-manager.extraSpecialArgs to pass + # arguments to home.nix + home-manager.extraSpecialArgs = { inherit inputs; }; + } + ] + ++ lib.optional (desktop == "gnome") ./system/gnome.nix + ++ lib.optional (desktop == "kde") ./system/kde.nix; in { - checks."${system}" = { - disko-format-i15 = pkgs.callPackage ./hosts/i15/partitions-test.nix { }; - }; nixosConfigurations = { i15 = lib.nixosSystem { inherit system specialArgs; - modules = [ ./hosts/i15 ] ++ common_modules; + modules = [ ./hosts/i15.nix ] ++ common_modules; }; monolith = lib.nixosSystem { inherit system specialArgs; modules = [ - ./hosts/monolith + ./hosts/monolith.nix ./system/monolith-gitlab-runner.nix - ./system/monolith-forgejo-runner.nix ./system/nix-serve.nix + ./system/steam.nix + ] ++ common_modules; + }; + rainbow = lib.nixosSystem { + inherit system specialArgs; + modules = [ + ./hosts/rainbow.nix + ./system/rainbow-gitlab-runner.nix ] ++ common_modules; }; double-rainbow = lib.nixosSystem { inherit system specialArgs; modules = [ ./hosts/double-rainbow.nix + ./system/rainbow-gitlab-runner.nix ] ++ common_modules; }; pixie = lib.nixosSystem { inherit system specialArgs; - modules = - [ ./hosts/pixie.nix ] - ++ common_modules - ++ [ - { - packages.media-packages.enable = lib.mkOverride 0 false; - services.flatpak.enable = lib.mkOverride 0 false; - } - ]; + modules = [ ./hosts/pixie.nix ] ++ common_modules ++ [{ + packages.media-packages.enable = lib.mkOverride 0 false; + programs.steam.enable = lib.mkOverride 0 false; + services.flatpak.enable = lib.mkOverride 0 false; + }]; }; - phantom = lib.nixosSystem { + ghost = lib.nixosSystem { inherit system specialArgs; - modules = [ - { nixpkgs.pkgs = pkgs; } - ./hosts/phantom - ]; + modules = [ ./hosts/ghost ]; }; }; @@ -194,7 +172,6 @@ packages.${system} = pkgs // packages; - # formatter.${system} = pkgs.nixfmt-rfc-style; - formatter.${system} = (inputs.treefmt-nix.lib.evalModule pkgs ./treefmt.nix).config.build.wrapper; + formatter.${system} = pkgs.nixpkgs-fmt; }; } diff --git a/hosts/double-rainbow.nix b/hosts/double-rainbow.nix index 2270198..7725898 100644 --- a/hosts/double-rainbow.nix +++ b/hosts/double-rainbow.nix @@ -1,34 +1,13 @@ -{ - config, - lib, - pkgs, - modulesPath, - ... -}: +{ config, lib, pkgs, modulesPath, ... }: let - btrfs_options = [ - "compress=zstd:3" - "noatime" - "x-systemd.device-timeout=0" - ]; - btrfs_ssd = [ - "ssd" - "discard=async" - ]; + btrfs_options = [ "compress=zstd:3" "noatime" "x-systemd.device-timeout=0" ]; + btrfs_ssd = [ "ssd" "discard=async" ]; in { imports = [ (modulesPath + "/installer/scan/not-detected.nix") ]; - my.nix-ld.enable = true; - - boot.initrd.availableKernelModules = [ - "xhci_pci" - "ahci" - "nvme" - "usb_storage" - "usbhid" - "sd_mod" - ]; + boot.initrd.availableKernelModules = + [ "xhci_pci" "ahci" "nvme" "usb_storage" "usbhid" "sd_mod" ]; boot.initrd.kernelModules = [ "i915" ]; boot.kernelModules = [ "kvm-intel" ]; boot.extraModulePackages = [ ]; @@ -47,13 +26,7 @@ in fsType = "vfat"; }; - swapDevices = [ { device = "/swapfile"; } ]; - - services.udev.extraRules = '' - # Force all disks to use mq-deadline scheduler - # For some reason "noop" is used by default which is kinda bad when io is saturated - ACTION=="add|change", KERNEL=="sd[a-z]*[0-9]*|mmcblk[0-9]*p[0-9]*|nvme[0-9]*n[0-9]*p[0-9]*", ATTR{../queue/scheduler}="mq-deadline" - ''; + swapDevices = [ ]; # Enables DHCP on each ethernet and wireless interface. In case of scripted networking # (the default) this is the recommended approach. When using systemd-networkd it's @@ -64,7 +37,8 @@ in nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux"; powerManagement.cpuFreqGovernor = lib.mkDefault "ondemand"; - hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; + hardware.cpu.intel.updateMicrocode = + lib.mkDefault config.hardware.enableRedistributableFirmware; networking.hostName = "double-rainbow"; # Define your hostname. } diff --git a/hosts/ghost/default.nix b/hosts/ghost/default.nix new file mode 100644 index 0000000..3d1afc8 --- /dev/null +++ b/hosts/ghost/default.nix @@ -0,0 +1,33 @@ +{ config, pkgs, inputs, ... }: { + imports = [ + "${inputs.nixpkgs}/nixos/modules/virtualisation/digital-ocean-image.nix" + inputs.agenix.nixosModules.default + ../../system/nix.nix + ./hardware-config.nix + ./mastodon.nix + ./nextcloud.nix + ./nginx.nix + ./syncthing.nix + ./users.nix + ./writefreely.nix + ./renawiki.nix + ]; + + # Use more aggressive compression then the default. + virtualisation.digitalOceanImage.compressionMethod = "bzip2"; + # Enable networking + networking.networkmanager.enable = true; + # Set your time zone. + time.timeZone = "America/Sao_Paulo"; + # Select internationalisation properties. + i18n.defaultLocale = "pt_BR.utf8"; + + boot.kernel.sysctl."fs.inotify.max_user_watches" = 1048576; + + age = { + identityPaths = [ "/root/.ssh/id_rsa" ]; + }; + + system.stateVersion = "23.05"; # Never change this +} + diff --git a/hosts/ghost/hardware-config.nix b/hosts/ghost/hardware-config.nix new file mode 100644 index 0000000..62a744f --- /dev/null +++ b/hosts/ghost/hardware-config.nix @@ -0,0 +1,13 @@ +{ config, pkgs, inputs, ... }: { + swapDevices = [{ + device = "/swap/swapfile"; + size = (1024 * 2); # 2 GB + }]; + + fileSystems."/var" = { + device = "/dev/disk/by-uuid/b19e7272-8fd1-4999-93eb-abc6d5c0a1cc"; + fsType = "btrfs"; + options = [ "subvol=@var" ]; + }; +} + diff --git a/hosts/ghost/mastodon.nix b/hosts/ghost/mastodon.nix new file mode 100644 index 0000000..a4262f0 --- /dev/null +++ b/hosts/ghost/mastodon.nix @@ -0,0 +1,16 @@ +{ config, pkgs, inputs, ... }: { + services.mastodon = { + enable = true; + localDomain = "social.lelgenio.xyz"; + configureNginx = true; + smtp.fromAddress = "lelgenio@disroot.org"; + extraConfig.SINGLE_USER_MODE = "true"; + streamingProcesses = 2; + }; + + services.nginx.virtualHosts.${config.services.nextcloud.hostName} = { + forceSSL = true; + enableACME = true; + }; +} + diff --git a/hosts/ghost/nextcloud.nix b/hosts/ghost/nextcloud.nix new file mode 100644 index 0000000..db6b04c --- /dev/null +++ b/hosts/ghost/nextcloud.nix @@ -0,0 +1,22 @@ +{ config, pkgs, inputs, ... }: { + services.nextcloud = { + enable = true; + package = pkgs.nextcloud27; + hostName = "cloud.lelgenio.xyz"; + https = true; + config = { + adminpassFile = config.age.secrets.ghost-nextcloud.path; + }; + }; + + age = { + secrets.ghost-nextcloud = { + file = ../../secrets/ghost-nextcloud.age; + mode = "400"; + owner = "nextcloud"; + group = "nextcloud"; + }; + }; + +} + diff --git a/hosts/ghost/nginx.nix b/hosts/ghost/nginx.nix new file mode 100644 index 0000000..7a795d7 --- /dev/null +++ b/hosts/ghost/nginx.nix @@ -0,0 +1,15 @@ +{ config, pkgs, inputs, ... }: { + services.nginx = { + enable = true; + recommendedProxySettings = true; + recommendedTlsSettings = true; + }; + + security.acme = { + acceptTerms = true; + defaults.email = "lelgenio@disroot.org"; + }; + + networking.firewall.allowedTCPPorts = [ 80 443 ]; +} + diff --git a/hosts/ghost/renawiki.nix b/hosts/ghost/renawiki.nix new file mode 100644 index 0000000..009e06e --- /dev/null +++ b/hosts/ghost/renawiki.nix @@ -0,0 +1,23 @@ +{ config, pkgs, inputs, ... }: { + services.mediawiki = { + enable = true; + name = "Rena Wiki"; + + webserver = "nginx"; + nginx.hostName = "renawiki.lelgenio.xyz"; + passwordFile = config.age.secrets.ghost-renawiki.path; + + extensions.VisualEditor = null; + }; + services.nginx.virtualHosts."renawiki.lelgenio.xyz" = { + enableACME = true; + forceSSL = true; + }; + + age.secrets.ghost-renawiki = { + file = ../../secrets/ghost-renawiki.age; + mode = "400"; + owner = "mediawiki"; + }; +} + diff --git a/hosts/phantom/syncthing.nix b/hosts/ghost/syncthing.nix similarity index 58% rename from hosts/phantom/syncthing.nix rename to hosts/ghost/syncthing.nix index abbda7d..a971b86 100644 --- a/hosts/phantom/syncthing.nix +++ b/hosts/ghost/syncthing.nix @@ -1,10 +1,4 @@ -{ - config, - pkgs, - inputs, - ... -}: -{ +{ config, pkgs, inputs, ... }: { services.syncthing = { enable = true; @@ -13,17 +7,18 @@ openDefaultPorts = true; }; - services.nginx.virtualHosts."syncthing.lelgenio.com" = { + services.nginx.virtualHosts."syncthing.lelgenio.xyz" = { enableACME = true; forceSSL = true; locations."/" = { proxyPass = "http://127.0.0.1:8384"; extraConfig = # required when the target is also TLS server with multiple hosts - "proxy_ssl_server_name on;" - + - # required when the server wants to use HTTP Authentication - "proxy_pass_header Authorization;"; + "proxy_ssl_server_name on;" + + # required when the server wants to use HTTP Authentication + "proxy_pass_header Authorization;" + ; }; }; } + diff --git a/hosts/phantom/users.nix b/hosts/ghost/users.nix similarity index 88% rename from hosts/phantom/users.nix rename to hosts/ghost/users.nix index a881f50..5cc853a 100644 --- a/hosts/phantom/users.nix +++ b/hosts/ghost/users.nix @@ -1,12 +1,8 @@ -{ pkgs, ... }: -{ +{ pkgs, ... }: { security.rtkit.enable = true; services.openssh = { enable = true; - ports = [ - 9022 - 22 - ]; + ports = [ 9022 ]; settings = { PasswordAuthentication = false; KbdInteractiveAuthentication = false; @@ -19,15 +15,7 @@ isNormalUser = true; description = "Leonardo Eugênio"; hashedPassword = "$y$j9T$0e/rczjOVCy7PuwC3pG0V/$gTHZhfO4wQSlFvbDyfghbCnGI2uDI0a52zSrQ/yOA5A"; - extraGroups = [ - "networkmanager" - "wheel" - "docker" - "adbusers" - "bluetooth" - "corectrl" - "vboxusers" - ]; + extraGroups = [ "networkmanager" "wheel" "docker" "adbusers" "bluetooth" "corectrl" "vboxusers" ]; shell = pkgs.fish; openssh.authorizedKeys.keys = [ "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQCxR/w+38b2lX90yNBqhq3mUmkn1WGu6GAPhN1tVp2ZjYRJNV/+5gWCnTtOWYtDx35HmK/spQ2Qy8X9ttkzORa24fysNx1Iqn/TiXhD7eIJjbGPnrOpIKTkW5/uB3SD/P5NBSa06//BaqJU4sBlG79hoXRpod052hQtdpTVDiMCIV+iboWPKqopmJJfWdBtVnHXs9rep0htPRExxGslImFk7Z6xjcaHyCpIQZPlOGf+sGsmUU7jRqzvZFV8ucIdbnAlMHrU4pepNFhuraESyZVTa/bi9sw0iozXp5Q5+5thMebEslmT1Z771kI4sieDy+O4r8c0Sx2/VY1UAzcpq1faggc3YB01MTh+tiEC6xdMvZLrQGL1NBWjHleMyL53GU5ERluC0vXJF3Hv3BGGBDfXWbrEm5n06DHr2apRVJGC0LwiQ7Woud1X4V4X1pKSusxCVMjT2lmcOwV6YhKhB2sowJc1OdMx4+tL0UWE+YKSZgBHfolwk6ml0F4EO9nnUHc= lelgenio@i15" @@ -40,10 +28,11 @@ ]; initialHashedPassword = "$y$j9T$E3aBBSSq0Gma8hZD9L7ov0$iCGDW4fqrXWfHO0qodBYYgMFA9CpIraoklHcPbJJrM3"; }; - security.sudo.wheelNeedsPassword = false; programs.fish.enable = true; - environment.systemPackages = with pkgs; [ git ]; + environment.systemPackages = with pkgs; [ + git + ]; } diff --git a/hosts/phantom/writefreely.nix b/hosts/ghost/writefreely.nix similarity index 59% rename from hosts/phantom/writefreely.nix rename to hosts/ghost/writefreely.nix index 5608c0f..b5cee3b 100644 --- a/hosts/phantom/writefreely.nix +++ b/hosts/ghost/writefreely.nix @@ -1,18 +1,12 @@ -{ - config, - pkgs, - inputs, - ... -}: -{ +{ config, pkgs, inputs, ... }: { services.writefreely = { enable = true; acme.enable = true; nginx.enable = true; nginx.forceSSL = true; - host = "blog.lelgenio.com"; + host = "blog.lelgenio.xyz"; admin.name = "lelgenio"; - admin.initialPasswordFile = config.age.secrets.phantom-writefreely.path; + admin.initialPasswordFile = config.age.secrets.ghost-writefreely.path; settings.app = { site_name = "Leo's blog"; single_user = true; @@ -20,11 +14,12 @@ }; age = { - secrets.phantom-writefreely = { - file = ../../secrets/phantom-writefreely.age; + secrets.ghost-writefreely = { + file = ../../secrets/ghost-writefreely.age; mode = "400"; owner = "writefreely"; group = "writefreely"; }; }; } + diff --git a/hosts/i15.nix b/hosts/i15.nix index c318665..e6f0e75 100644 --- a/hosts/i15.nix +++ b/hosts/i15.nix @@ -1,30 +1,15 @@ # Do not modify this file! It was generated by ‘nixos-generate-config’ # and may be overwritten by future invocations. Please make changes # to /etc/nixos/configuration.nix instead. -{ - config, - lib, - pkgs, - modulesPath, - ... -}: +{ config, lib, pkgs, modulesPath, ... }: let - btrfs_options = [ - "compress=zstd:3" - "noatime" - "x-systemd.device-timeout=0" - ]; + btrfs_options = [ "compress=zstd:3" "noatime" "x-systemd.device-timeout=0" ]; in { imports = [ (modulesPath + "/installer/scan/not-detected.nix") ]; - boot.initrd.availableKernelModules = [ - "xhci_pci" - "ahci" - "usb_storage" - "sd_mod" - "rtsx_usb_sdmmc" - ]; + boot.initrd.availableKernelModules = + [ "xhci_pci" "ahci" "usb_storage" "sd_mod" "rtsx_usb_sdmmc" ]; boot.initrd.kernelModules = [ ]; boot.kernelModules = [ "kvm-intel" ]; boot.extraModulePackages = [ ]; @@ -60,12 +45,10 @@ in options = [ "subvol=@swap" ] ++ btrfs_options; }; - swapDevices = [ - { - device = "/swap/swapfile"; - size = (1024 * 8) + (1024 * 2); # RAM size + 2 GB - } - ]; + swapDevices = [{ + device = "/swap/swapfile"; + size = (1024 * 8) + (1024 * 2); # RAM size + 2 GB + }]; # Enables DHCP on each ethernet and wireless interface. In case of scripted networking # (the default) this is the recommended approach. When using systemd-networkd it's @@ -76,6 +59,7 @@ in # networking.interfaces.wlp1s0.useDHCP = lib.mkDefault true; powerManagement.cpuFreqGovernor = lib.mkDefault "ondemand"; - hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; + hardware.cpu.intel.updateMicrocode = + lib.mkDefault config.hardware.enableRedistributableFirmware; networking.hostName = "i15"; # Define your hostname. } diff --git a/hosts/i15/default.nix b/hosts/i15/default.nix deleted file mode 100644 index ca7c217..0000000 --- a/hosts/i15/default.nix +++ /dev/null @@ -1,38 +0,0 @@ -{ - config, - lib, - pkgs, - modulesPath, - ... -}: -{ - networking.hostName = "i15"; # Define your hostname. - - imports = [ (modulesPath + "/installer/scan/not-detected.nix") ]; - - boot.initrd.availableKernelModules = [ - "xhci_pci" - "ahci" - "usb_storage" - "sd_mod" - "rtsx_usb_sdmmc" - ]; - boot.initrd.kernelModules = [ ]; - boot.kernelModules = [ "kvm-intel" ]; - boot.extraModulePackages = [ ]; - - disko.devices = (import ./partitions.nix { disks = [ "/dev/sda" ]; }); - boot.loader.efi.efiSysMountPoint = "/boot/efi"; - - swapDevices = [ - { - device = "/swap/swapfile"; - size = (1024 * 8) + (1024 * 2); # RAM size + 2 GB - } - ]; - - networking.useDHCP = lib.mkDefault true; - - powerManagement.cpuFreqGovernor = lib.mkDefault "ondemand"; - hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; -} diff --git a/hosts/i15/partitions-test.nix b/hosts/i15/partitions-test.nix deleted file mode 100644 index bb2c273..0000000 --- a/hosts/i15/partitions-test.nix +++ /dev/null @@ -1,19 +0,0 @@ -{ - config, - lib, - pkgs, - ... -}: -pkgs.makeDiskoTest { - name = "test-disko-i15"; - disko-config = ./partitions.nix; - enableOCR = true; - bootCommands = '' - machine.wait_for_text("[Pp]assphrase for") - machine.send_chars("secretsecret\n") - ''; - extraTestScript = '' - machine.succeed("cryptsetup isLuks /dev/vda2"); - machine.succeed("mountpoint /home"); - ''; -} diff --git a/hosts/i15/partitions.nix b/hosts/i15/partitions.nix deleted file mode 100644 index 7b69e0f..0000000 --- a/hosts/i15/partitions.nix +++ /dev/null @@ -1,73 +0,0 @@ -{ - disks ? [ "/dev/sda" ], - ... -}: -let - btrfs_options = [ - "compress=zstd:3" - "noatime" - ]; -in -{ - disk.sda = { - type = "disk"; - device = builtins.elemAt disks 0; - content = { - type = "table"; - format = "gpt"; - partitions = [ - { - type = "partition"; - name = "NIX_BOOT"; - start = "1MiB"; - end = "300MiB"; - bootable = true; - content = { - type = "filesystem"; - extraArgs = [ - "-n" - "BOOT_I15" - ]; - format = "vfat"; - mountpoint = "/boot"; - # options = [ "defaults" ]; - }; - } - { - type = "partition"; - name = "CRYPT_I15"; - start = "300MiB"; - end = "100%"; - content = { - type = "luks"; - name = "main"; - keyFile = "/tmp/secret.key"; - content = { - type = "btrfs"; - extraArgs = [ - "--label" - "ROOT_I15" - ]; - subvolumes = - let - mountOptions = btrfs_options; - in - { - "/home" = { - inherit mountOptions; - }; - "/nixos" = { - inherit mountOptions; - mountpoint = "/"; - }; - "/swap" = { - inherit mountOptions; - }; - }; - }; - }; - } - ]; - }; - }; -} diff --git a/hosts/monolith.nix b/hosts/monolith.nix new file mode 100644 index 0000000..c78f64f --- /dev/null +++ b/hosts/monolith.nix @@ -0,0 +1,131 @@ +# Do not modify this file! It was generated by ‘nixos-generate-config’ +# and may be overwritten by future invocations. Please make changes +# to /etc/nixos/configuration.nix instead. +{ config, lib, pkgs, modulesPath, ... }: +let + btrfs_options = [ "compress=zstd:3" "noatime" "x-systemd.device-timeout=0" ]; + btrfs_ssd = [ "ssd" "discard=async" ]; +in +{ + imports = [ (modulesPath + "/installer/scan/not-detected.nix") ]; + boot.initrd.availableKernelModules = + [ "nvme" "xhci_pci" "ahci" "usb_storage" "usbhid" "sd_mod" ]; + + boot.extraModulePackages = with config.boot.kernelPackages; [ + zenpower + ]; + boot.initrd.kernelModules = [ "amdgpu" ]; + boot.kernelModules = [ + "kvm-amd" + "amdgpu" + "zenpower" + ]; + boot.kernelParams = [ + "video=DP-1:1920x1080@144" + # hibernation + "resume=LABEL=BTRFS_ROOT" # findmnt -o LABEL --noheadings /swap/ + "resume_offset=36709632" # btrfs inspect-internal map-swapfile -r /swap/swapfile + ]; + systemd.sleep.extraConfig = '' + HibernateDelaySec=30s + SuspendState=mem + ''; + + hardware.opengl.driSupport = true; + # # For 32 bit applications + hardware.opengl.driSupport32Bit = true; + + hardware.opengl.extraPackages = with pkgs; [ + libva + libvdpau + vaapiVdpau + ]; + + programs.corectrl.enable = true; + virtualisation.virtualbox.host.enable = true; + + fileSystems."/" = { + device = "/dev/disk/by-label/BTRFS_ROOT"; + fsType = "btrfs"; + options = [ "subvol=nixos" ] ++ btrfs_options ++ btrfs_ssd; + }; + # boot.initrd.luks.reusePassphrases = true; + boot.initrd.luks.devices = { + "main" = { + bypassWorkqueues = true; + device = "/dev/disk/by-label/CRYPT_ROOT"; + }; + "data" = { + bypassWorkqueues = true; + device = "/dev/disk/by-label/CRYPT_DATA"; + }; + "bigboy" = { + bypassWorkqueues = true; + device = "/dev/disk/by-label/CRYPT_BIGBOY"; + }; + }; + boot.loader.efi.efiSysMountPoint = "/boot/efi"; + fileSystems."/boot/efi" = { + device = "/dev/disk/by-label/NIXBOOT"; + fsType = "vfat"; + }; + fileSystems."/home" = { + device = "/dev/disk/by-label/BTRFS_ROOT"; + fsType = "btrfs"; + options = [ "subvol=home" ] ++ btrfs_options ++ btrfs_ssd; + }; + fileSystems."/home/lelgenio/Games" = { + device = "/dev/disk/by-label/BTRFS_DATA"; + fsType = "btrfs"; + options = [ "subvol=@games" "nofail" ] ++ btrfs_options; + }; + fileSystems."/home/lelgenio/Downloads/Torrents" = { + device = "/dev/disk/by-label/BTRFS_DATA"; + fsType = "btrfs"; + options = [ "subvol=@torrents" "nofail" ] ++ btrfs_options; + }; + fileSystems."/home/lelgenio/Música" = { + device = "/dev/disk/by-label/BTRFS_DATA"; + fsType = "btrfs"; + options = [ "subvol=@music" "nofail" ] ++ btrfs_options; + }; + fileSystems."/home/lelgenio/.local/mount/data" = { + device = "/dev/disk/by-label/BTRFS_DATA"; + fsType = "btrfs"; + options = [ "subvol=@data" "nofail" ] ++ btrfs_options; + }; + fileSystems."/home/lelgenio/.local/mount/bigboy" = { + device = "/dev/disk/by-label/BTRFS_BIGBOY"; + fsType = "btrfs"; + options = [ "nofail" ] ++ btrfs_options ++ btrfs_ssd; + }; + # Enables DHCP on each ethernet and wireless interface. In case of scripted networking + # (the default) this is the recommended approach. When using systemd-networkd it's + # still possible to use this option, but it's recommended to use it in conjunction + # with explicit per-interface declarations with `networking.interfaces..useDHCP`. + networking.useDHCP = lib.mkDefault true; + # networking.interfaces.enp4s0.useDHCP = lib.mkDefault true; + powerManagement.cpuFreqGovernor = "ondemand"; + hardware.cpu.amd.updateMicrocode = + lib.mkDefault config.hardware.enableRedistributableFirmware; + networking.hostName = "monolith"; # Define your hostname. + + # Fix broken suspend with Logitech USB dongle + # `lsusb | grep Logitech` will return "vendor:product" + services.udev.extraRules = '' + ACTION=="add" SUBSYSTEM=="usb" ATTR{idVendor}=="046d" ATTR{idProduct}=="c547" ATTR{power/wakeup}="disabled" + ''; + + # swap + fileSystems."/swap" = { + device = "/dev/disk/by-label/BTRFS_ROOT"; + fsType = "btrfs"; + # Note these options effect the entire BTRFS filesystem and not just this volume, + # with the exception of `"subvol=swap"`, the other options are repeated in my other `fileSystem` mounts + options = [ "subvol=swap" ] ++ btrfs_options ++ btrfs_ssd; + }; + swapDevices = [{ + device = "/swap/swapfile"; + size = (1024 * 16) + (1024 * 2); # RAM size + 2 GB + }]; +} diff --git a/hosts/monolith/amdgpu.nix b/hosts/monolith/amdgpu.nix deleted file mode 100644 index 2554500..0000000 --- a/hosts/monolith/amdgpu.nix +++ /dev/null @@ -1,39 +0,0 @@ -{ pkgs, lib, ... }: -let - undervoltGpu = pkgs.writeShellScript "undervolt-gpu" '' - set -xe - cd $1 - echo "manual" > power_dpm_force_performance_level - echo "1" > pp_power_profile_mode - test -e pp_od_clk_voltage - echo "vo -120" > pp_od_clk_voltage - echo "c" > pp_od_clk_voltage - ''; -in -{ - boot.initrd.kernelModules = [ "amdgpu" ]; - boot.kernelParams = [ - "video=DP-1:1920x1080@144" - ]; - - systemd.services.amd-fan-control = { - script = '' - ${lib.getExe pkgs.amd-fan-control} /sys/class/drm/card1/device 60 90 0 80 - ''; - serviceConfig = { - Restart = "always"; - RestartSec = 10; - }; - wantedBy = [ "multi-user.target" ]; - }; - - hardware.graphics.enable32Bit = true; - - hardware.graphics.extraPackages = with pkgs; [ - libva - ]; - - services.udev.extraRules = '' - ACTION=="add", SUBSYSTEM=="hwmon", ATTR{name}=="amdgpu", ATTR{power1_cap}="186000000", RUN+="${undervoltGpu} %S%p/device" - ''; -} diff --git a/hosts/monolith/default.nix b/hosts/monolith/default.nix deleted file mode 100644 index 753047a..0000000 --- a/hosts/monolith/default.nix +++ /dev/null @@ -1,169 +0,0 @@ -# Do not modify this file! It was generated by ‘nixos-generate-config’ -# and may be overwritten by future invocations. Please make changes -# to /etc/nixos/configuration.nix instead. -{ - config, - lib, - pkgs, - modulesPath, - ... -}: -let - btrfs_options = [ - "compress=zstd:3" - "noatime" - "x-systemd.device-timeout=0" - ]; - btrfs_ssd = [ - "ssd" - "discard=async" - ]; -in -{ - imports = [ - (modulesPath + "/installer/scan/not-detected.nix") - ./partition.nix - ./amdgpu.nix - ./factorio-server.nix - ]; - boot.initrd.availableKernelModules = [ - "nvme" - "xhci_pci" - "ahci" - "usb_storage" - "usbhid" - "sd_mod" - ]; - - hardware.opentabletdriver = { - enable = true; - # TODO: remove this once otd gets updated - package = pkgs.unstable.opentabletdriver; - }; - - my.gaming.enable = true; - my.nix-ld.enable = true; - - boot.extraModulePackages = with config.boot.kernelPackages; [ zenpower ]; - - boot.initrd.kernelModules = [ "amdgpu" ]; - boot.kernelModules = [ - "kvm-amd" - "amdgpu" - "zenpower" - ]; - - systemd.sleep.extraConfig = '' - HibernateDelaySec=30s - SuspendState=mem - ''; - - fileSystems."/mnt/old" = { - device = "/dev/disk/by-label/BTRFS_ROOT"; - fsType = "btrfs"; - options = [ "nofail" ] ++ btrfs_options ++ btrfs_ssd; - }; - # boot.initrd.luks.reusePassphrases = true; - boot.initrd.luks.devices = { - "old" = { - bypassWorkqueues = true; - device = "/dev/disk/by-label/CRYPT_ROOT"; - }; - "data" = { - bypassWorkqueues = true; - device = "/dev/disk/by-label/CRYPT_DATA"; - }; - # "bigboy" = { - # bypassWorkqueues = true; - # device = "/dev/disk/by-label/CRYPT_BIGBOY"; - # }; - }; - # boot.loader.efi.efiSysMountPoint = "/boot/efi"; - # fileSystems."/boot/efi" = { - # device = "/dev/disk/by-label/NIXBOOT"; - # fsType = "vfat"; - # }; - # fileSystems."/home" = { - # device = "/dev/disk/by-label/BTRFS_ROOT"; - # fsType = "btrfs"; - # options = [ "subvol=home" ] ++ btrfs_options ++ btrfs_ssd; - # }; - fileSystems."/home/lelgenio/Games" = { - device = "/dev/disk/by-label/BTRFS_DATA"; - fsType = "btrfs"; - options = [ - "subvol=@games" - "nofail" - ] ++ btrfs_options; - }; - fileSystems."/home/lelgenio/Downloads/Torrents" = { - device = "/dev/disk/by-label/BTRFS_DATA"; - fsType = "btrfs"; - options = [ - "subvol=@torrents" - "nofail" - ] ++ btrfs_options; - }; - fileSystems."/home/lelgenio/Música" = { - device = "/dev/disk/by-label/BTRFS_DATA"; - fsType = "btrfs"; - options = [ - "subvol=@music" - "nofail" - ] ++ btrfs_options; - }; - fileSystems."/home/lelgenio/.local/mount/data" = { - device = "/dev/disk/by-label/BTRFS_DATA"; - fsType = "btrfs"; - options = [ - "subvol=@data" - "nofail" - ] ++ btrfs_options; - }; - fileSystems."/home/lelgenio/.local/mount/old" = { - device = "/dev/disk/by-label/BTRFS_ROOT"; - fsType = "btrfs"; - options = [ "nofail" ] ++ btrfs_options ++ btrfs_ssd; - }; - - # Enables DHCP on each ethernet and wireless interface. In case of scripted networking - # (the default) this is the recommended approach. When using systemd-networkd it's - # still possible to use this option, but it's recommended to use it in conjunction - # with explicit per-interface declarations with `networking.interfaces..useDHCP`. - networking.useDHCP = lib.mkDefault true; - # networking.interfaces.enp4s0.useDHCP = lib.mkDefault true; - powerManagement.cpuFreqGovernor = "ondemand"; - hardware.cpu.amd.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; - networking.hostName = "monolith"; # Define your hostname. - - virtualisation.virtualbox.host.enable = true; - - services.udev.extraRules = '' - # Fix broken suspend with Logitech USB dongle - # `lsusb | grep Logitech` will return "vendor:product" - ACTION=="add" SUBSYSTEM=="usb" ATTR{idVendor}=="046d" ATTR{idProduct}=="c547" ATTR{power/wakeup}="disabled" - # Force all disks to use mq-deadline scheduler - # For some reason "noop" is used by default which is kinda bad when io is saturated - ACTION=="add|change", KERNEL=="sd[a-z]*[0-9]*|mmcblk[0-9]*p[0-9]*|nvme[0-9]*n[0-9]*p[0-9]*", ATTR{../queue/scheduler}="kyber" - ''; - - boot.tmp = { - cleanOnBoot = true; - useTmpfs = true; - }; - - # swap - # fileSystems."/swap" = { - # device = "/dev/disk/by-label/BTRFS_ROOT"; - # fsType = "btrfs"; - # # Note these options effect the entire BTRFS filesystem and not just this volume, - # # with the exception of `"subvol=swap"`, the other options are repeated in my other `fileSystem` mounts - # options = [ "subvol=swap" ] ++ btrfs_options ++ btrfs_ssd; - # }; - # swapDevices = [ - # { - # device = "/swap/swapfile"; - # size = (1024 * 16) + (1024 * 2); # RAM size + 2 GB - # } - # ]; -} diff --git a/hosts/monolith/factorio-server.nix b/hosts/monolith/factorio-server.nix deleted file mode 100644 index 9648de3..0000000 --- a/hosts/monolith/factorio-server.nix +++ /dev/null @@ -1,50 +0,0 @@ -{ - config, - pkgs, - lib, - ... -}: -{ - services.factorio = { - enable = true; - package = pkgs.factorio-headless; # I override this in ./pkgs - public = true; - lan = true; - openFirewall = true; - admins = [ "lelgenio" ]; - extraSettingsFile = config.age.secrets.factorio-settings.path; - }; - - systemd.services.factorio = { - after = [ "network-online.target" ]; - wants = [ "network-online.target" ]; - }; - - systemd.services.factorio-backup-save = { - description = "Backup factorio saves"; - script = '' - FILENAME="space-age-$(date --iso=seconds | tr ':' '_').zip" - ${lib.getExe pkgs.rsync} \ - -av \ - --chown=lelgenio \ - /var/lib/factorio/saves/default.zip \ - ~lelgenio/Documentos/GameSaves/factorio_saves/$FILENAME - ''; - serviceConfig.Type = "oneshot"; - wantedBy = [ "multi-user.target" ]; - }; - - systemd.timers.factorio-backup-save = { - timerConfig = { - OnCalendar = "*-*-* 18:00:00"; - Persistent = true; - Unit = "factorio-backup-save.service"; - }; - wantedBy = [ "timers.target" ]; - }; - - age.secrets.factorio-settings = { - file = ../../secrets/factorio-settings.age; - mode = "777"; - }; -} diff --git a/hosts/monolith/partition.nix b/hosts/monolith/partition.nix deleted file mode 100644 index d75d814..0000000 --- a/hosts/monolith/partition.nix +++ /dev/null @@ -1,68 +0,0 @@ -let - btrfs_options = [ - "compress=zstd:3" - "noatime" - "x-systemd.device-timeout=0" - ]; - btrfs_ssd = btrfs_options ++ [ - "ssd" - "discard=async" - ]; -in -{ - disko.devices = { - disk = { - bigboy_disk = { - type = "disk"; - device = "/dev/nvme0n1"; - content = { - type = "gpt"; - partitions = { - ESP = { - size = "2G"; - type = "EF00"; - content = { - type = "filesystem"; - format = "vfat"; - mountpoint = "/boot"; - mountOptions = [ "defaults" ]; - }; - }; - luks = { - size = "100%"; - content = { - type = "luks"; - name = "bigboy"; - # disable settings.keyFile if you want to use interactive password entry - passwordFile = "/tmp/secret.key"; # Interactive - # settings = { - # allowDiscards = true; - # keyFile = "/tmp/secret.key"; - # }; - # additionalKeyFiles = [ "/tmp/additionalSecret.key" ]; - content = { - type = "btrfs"; - extraArgs = [ "-f" ]; - subvolumes = { - "/@nixos" = { - mountpoint = "/"; - mountOptions = btrfs_ssd; - }; - "/@home" = { - mountpoint = "/home"; - mountOptions = btrfs_ssd; - }; - "/@swap" = { - mountpoint = "/.swapvol"; - swap.swapfile.size = "32G"; - }; - }; - }; - }; - }; - }; - }; - }; - }; - }; -} diff --git a/hosts/phantom/davi.nix b/hosts/phantom/davi.nix deleted file mode 100644 index 876aee7..0000000 --- a/hosts/phantom/davi.nix +++ /dev/null @@ -1,26 +0,0 @@ -{ pkgs, ... }: -{ - users.users.davikiwi = { - isNormalUser = true; - description = "Davi"; - hashedPassword = "$y$j9T$0e/rczjOVCy7PuwC3pG0V/$gTHZhfO4wQSlFvbDyfghbCnGI2uDI0a52zSrQ/yOA5A"; - openssh.authorizedKeys.keys = [ - "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIGgZDBnj+gVMHqoNvjpx2T/HqnxUDbLPshu+t7301gXd Davi@DESKTOP-EVHFGJ9" - ]; - extraGroups = [ "docker" ]; - packages = with pkgs; [ - (pkgs.python3.withPackages (python-pkgs: [ - python-pkgs.pip - python-pkgs.wheel - ])) - ]; - }; - - services.nginx.virtualHosts."davikiwi.lelgenio.com" = { - enableACME = true; - forceSSL = true; - locations."/" = { - proxyPass = "http://127.0.0.1:24618"; - }; - }; -} diff --git a/hosts/phantom/default.nix b/hosts/phantom/default.nix deleted file mode 100644 index 1b0d3cb..0000000 --- a/hosts/phantom/default.nix +++ /dev/null @@ -1,106 +0,0 @@ -{ - config, - pkgs, - inputs, - lib, - ... -}: -{ - imports = [ - inputs.vpsadminos.nixosConfigurations.container - inputs.agenix.nixosModules.default - inputs.sops-nix.nixosModules.default - - ../../system/sops.nix - ../../system/nix.nix - ./hardware-config.nix - ./mastodon.nix - ./lemmy.nix - ./nextcloud.nix - ./nginx.nix - ./syncthing.nix - ./users.nix - ./writefreely.nix - ./email.nix - ./forgejo.nix - ./invidious.nix - ./davi.nix - ./goofs.nix - ]; - - networking.hostName = "phantom"; - - services.nginx.virtualHosts."lelgenio.com" = { - enableACME = true; - forceSSL = true; - root = pkgs.runCommand "www-dir" { } '' - mkdir -p $out - cat > $out/index.html < - - -

- Nothing to see here! -

- - - EOF - ''; - }; - - # # Enable networking - # networking.networkmanager.enable = true; - # Set your time zone. - time.timeZone = "America/Sao_Paulo"; - # Select internationalisation properties. - i18n.defaultLocale = "pt_BR.UTF-8"; - - boot.kernel.sysctl."fs.inotify.max_user_watches" = 1048576; - - age = { - identityPaths = [ "/root/.ssh/id_rsa" ]; - }; - - sops = { - secrets.hello = { }; - defaultSopsFile = lib.mkForce ../../secrets/phantom/default.yaml; - }; - - environment.etc."teste-sops" = { - text = config.sops.secrets.hello.path; - }; - - virtualisation.docker = { - enable = true; - daemon.settings = { - # needed by bitbucket runner ??? - log-driver = "json-file"; - log-opts = { - max-size = "10m"; - max-file = "3"; - }; - }; - }; - - nix.settings = { - cores = 1; - max-jobs = 1; - }; - - system.autoUpgrade = { - enable = true; - dates = "04:40"; - operation = "switch"; - flags = [ - "--update-input" - "nixpkgs" - "--no-write-lock-file" - "--print-build-logs" - ]; - flake = "git+https://git.lelgenio.com/lelgenio/nixos-config#phantom"; - }; - - networking.firewall.allowedTCPPorts = [ 8745 ]; - - system.stateVersion = "23.05"; # Never change this -} diff --git a/hosts/phantom/email.nix b/hosts/phantom/email.nix deleted file mode 100644 index 105113b..0000000 --- a/hosts/phantom/email.nix +++ /dev/null @@ -1,60 +0,0 @@ -{ - pkgs, - inputs, - config, - ... -}: -{ - imports = [ inputs.nixos-mailserver.nixosModules.mailserver ]; - - mailserver = { - enable = true; - fqdn = "lelgenio.com"; - domains = [ - "lelgenio.xyz" - "git.lelgenio.xyz" - "lelgenio.com" - "git.lelgenio.com" - "social.lelgenio.com" - ]; - certificateScheme = "acme-nginx"; - # Create passwords with - # nix-shell -p mkpasswd --run 'mkpasswd -sm bcrypt' - loginAccounts = { - "lelgenio@lelgenio.com" = { - hashedPassword = "$2y$05$z5s7QCXcs5uTFsfyYpwNJeWzb3RmzgWxNgcPCr0zjSytkLFF/qZmS"; - aliases = [ - "postmaster@lelgenio.com" - "lelgenio@lelgenio.xyz" - "lelgenio@lelgenio.xyz" - ]; - }; - "noreply@git.lelgenio.com" = { - hashedPassword = "$2b$05$TmR1R7ZwXfec7yrOfeBL7u3ZtyXf0up5dEO6uMWSvb/O7LPEm.j0."; - }; - "noreply@social.lelgenio.com" = { - hashedPassword = "$2b$05$DcA9xMdvHqqQMZw2.zybI.vfKsQAJtaQ/JB.t9AHu6psstWq97m2C"; - }; - }; - - enableManageSieve = true; - }; - - # Prefer ipv4 and use main ipv6 to avoid reverse DNS issues - services.postfix.extraConfig = '' - smtp_address_preference = ipv4 - ''; - - # Webmail - services.roundcube = { - enable = true; - package = pkgs.roundcube.withPlugins (p: [ p.carddav ]); - hostName = "mail.lelgenio.com"; - extraConfig = '' - $config['smtp_host'] = "tls://${config.mailserver.fqdn}:587"; - $config['smtp_user'] = "%u"; - $config['smtp_pass'] = "%p"; - $config['plugins'] = [ "carddav", "archive", "managesieve" ]; - ''; - }; -} diff --git a/hosts/phantom/forgejo.nix b/hosts/phantom/forgejo.nix deleted file mode 100644 index dbb63d3..0000000 --- a/hosts/phantom/forgejo.nix +++ /dev/null @@ -1,53 +0,0 @@ -{ - lib, - pkgs, - config, - ... -}: -let - cfg = config.services.forgejo; - srv = cfg.settings.server; -in -{ - services.nginx = { - virtualHosts.${cfg.settings.server.DOMAIN} = { - forceSSL = true; - enableACME = true; - locations."/".proxyPass = "http://localhost:${toString srv.HTTP_PORT}"; - }; - }; - - services.forgejo = { - enable = true; - database.type = "postgres"; - lfs.enable = true; - settings = { - service.DISABLE_REGISTRATION = true; - actions = { - ENABLED = true; - DEFAULT_ACTIONS_URL = "github"; - }; - repository = { - ENABLE_PUSH_CREATE_USER = true; - }; - server = { - DOMAIN = "git.lelgenio.com"; - HTTP_PORT = 3000; - ROOT_URL = "https://${srv.DOMAIN}/"; - }; - mailer = { - ENABLED = true; - SMTP_ADDR = "lelgenio.com"; - FROM = "noreply@git.lelgenio.com"; - USER = "noreply@git.lelgenio.com"; - }; - }; - mailerPasswordFile = config.age.secrets.phantom-forgejo-mailer-password.path; - }; - - age.secrets.phantom-forgejo-mailer-password = { - file = ../../secrets/phantom-forgejo-mailer-password.age; - mode = "400"; - owner = "forgejo"; - }; -} diff --git a/hosts/phantom/goofs.nix b/hosts/phantom/goofs.nix deleted file mode 100644 index dfb5736..0000000 --- a/hosts/phantom/goofs.nix +++ /dev/null @@ -1,51 +0,0 @@ -{ inputs, config, ... }: -{ - imports = [ - inputs.warthunder-leak-counter.nixosModules.default - inputs.made-you-look.nixosModules.default - ]; - - services.warthunder-leak-counter.enable = true; - services.nginx.virtualHosts."warthunder-leak-counter.lelgenio.com" = { - enableACME = true; - forceSSL = true; - locations."/" = { - proxyPass = "http://127.0.0.1:${toString config.services.warthunder-leak-counter.port}"; - }; - }; - - services.made-you-look.enable = true; - services.nginx.virtualHosts."coolest-thing-ever.lelgenio.com" = { - enableACME = true; - forceSSL = true; - locations."/" = { - proxyPass = "http://127.0.0.1:${toString config.services.made-you-look.port}"; - }; - }; - - services.nginx.virtualHosts."catboy-spinner.lelgenio.com" = { - enableACME = true; - forceSSL = true; - root = inputs.catboy-spinner; - }; - services.nginx.virtualHosts."tomater.lelgenio.com" = { - enableACME = true; - forceSSL = true; - root = inputs.tomater; - }; - services.nginx.virtualHosts."youre-wrong.lelgenio.com" = { - enableACME = true; - forceSSL = true; - root = inputs.youre-wrong; - }; - services.nginx.virtualHosts."hello-fonts.lelgenio.com" = { - enableACME = true; - forceSSL = true; - root = inputs.hello-fonts; - }; - services.nginx.virtualHosts."contador-da-viagem.lelgenio.com" = { - enableACME = true; - forceSSL = true; - root = inputs.contador-da-viagem; - }; -} diff --git a/hosts/phantom/hardware-config.nix b/hosts/phantom/hardware-config.nix deleted file mode 100644 index 7eebde8..0000000 --- a/hosts/phantom/hardware-config.nix +++ /dev/null @@ -1,19 +0,0 @@ -{ - fileSystems."/var/lib/syncthing-data" = { - device = "172.16.130.7:/nas/5749/syncthinng_data"; - fsType = "nfs"; - options = [ "nofail" ]; - }; - fileSystems."/var/lib/mastodon" = { - device = "172.16.131.19:/nas/5749/mastodon"; - fsType = "nfs"; - options = [ "nofail" ]; - }; - - swapDevices = [ - { - device = "/swap/swapfile"; - size = (1024 * 2); # 2 GB - } - ]; -} diff --git a/hosts/phantom/invidious.nix b/hosts/phantom/invidious.nix deleted file mode 100644 index 60c1dca..0000000 --- a/hosts/phantom/invidious.nix +++ /dev/null @@ -1,40 +0,0 @@ -{ - inputs, - pkgs, - config, - ... -}: -{ - # Replace with unstable, since 24.05 does not have sig-helper - disabledModules = [ "services/web-apps/invidious.nix" ]; - imports = [ (inputs.nixpkgs-unstable + "/nixos/modules/services/web-apps/invidious.nix") ]; - - services.invidious = { - enable = true; - domain = "invidious.lelgenio.com"; - nginx.enable = true; - port = 10601; - http3-ytproxy.enable = true; - sig-helper = { - enable = true; - package = pkgs.unstable.inv-sig-helper; - }; - # { - # "visitor_data": "...", - # "po_token": "..." - # } - extraSettingsFile = config.age.secrets.phantom-invidious-settings.path; - settings = { - force_resolve = "ipv6"; - db = { - user = "invidious"; - dbname = "invidious"; - }; - }; - }; - - age.secrets.phantom-invidious-settings = { - file = ../../secrets/phantom-invidious-settings.age; - mode = "666"; - }; -} diff --git a/hosts/phantom/lemmy.nix b/hosts/phantom/lemmy.nix deleted file mode 100644 index 0e6ee1a..0000000 --- a/hosts/phantom/lemmy.nix +++ /dev/null @@ -1,18 +0,0 @@ -{ pkgs, ... }: -{ - services.lemmy = { - enable = true; - settings = { - hostname = "lemmy.lelgenio.com"; - }; - database.createLocally = true; - nginx.enable = true; - }; - - services.pict-rs.package = pkgs.pict-rs; - - services.nginx.virtualHosts."lemmy.lelgenio.com" = { - enableACME = true; - forceSSL = true; - }; -} diff --git a/hosts/phantom/mastodon.nix b/hosts/phantom/mastodon.nix deleted file mode 100644 index d0dd5d3..0000000 --- a/hosts/phantom/mastodon.nix +++ /dev/null @@ -1,29 +0,0 @@ -{ - config, - pkgs, - inputs, - ... -}: -{ - services.mastodon = { - enable = true; - configureNginx = true; - localDomain = "social.lelgenio.com"; - smtp = { - authenticate = true; - host = "lelgenio.com"; - fromAddress = "noreply@social.lelgenio.com"; - user = "noreply@social.lelgenio.com"; - passwordFile = config.age.secrets.phantom-mastodon-mailer-password.path; - }; - streamingProcesses = 2; - extraConfig.SINGLE_USER_MODE = "true"; - mediaAutoRemove.olderThanDays = 5; - }; - - age.secrets.phantom-mastodon-mailer-password = { - file = ../../secrets/phantom-mastodon-mailer-password.age; - mode = "400"; - owner = "mastodon"; - }; -} diff --git a/hosts/phantom/nextcloud.nix b/hosts/phantom/nextcloud.nix deleted file mode 100644 index 28d76a1..0000000 --- a/hosts/phantom/nextcloud.nix +++ /dev/null @@ -1,31 +0,0 @@ -{ - config, - pkgs, - ... -}: -{ - services.nextcloud = { - enable = true; - package = pkgs.nextcloud30; - hostName = "cloud.lelgenio.com"; - https = true; - config = { - dbtype = "sqlite"; # TODO: move to single postgres db - adminpassFile = config.age.secrets.phantom-nextcloud.path; - }; - }; - - services.nginx.virtualHosts.${config.services.nextcloud.hostName} = { - forceSSL = true; - enableACME = true; - }; - - age = { - secrets.phantom-nextcloud = { - file = ../../secrets/phantom-nextcloud.age; - mode = "400"; - owner = "nextcloud"; - group = "nextcloud"; - }; - }; -} diff --git a/hosts/phantom/nginx.nix b/hosts/phantom/nginx.nix deleted file mode 100644 index bfff32c..0000000 --- a/hosts/phantom/nginx.nix +++ /dev/null @@ -1,47 +0,0 @@ -{ - config, - pkgs, - lib, - ... -}: -{ - services.nginx = { - enable = true; - recommendedProxySettings = true; - recommendedTlsSettings = true; - recommendedOptimisation = true; - recommendedGzipSettings = true; - clientMaxBodySize = "512M"; - }; - - # Redirect *lelgenio.xyz -> *lelgenio.com - services.nginx.virtualHosts = - lib.mapAttrs' (key: value: lib.nameValuePair "${key}lelgenio.xyz" value) - ( - lib.genAttrs - [ - "" - "social." - "blog." - "cloud." - "mail." - "git." - "syncthing." - ] - (name: { - enableACME = true; - forceSSL = true; - locations."/".return = "301 $scheme://${name}lelgenio.com$request_uri"; - }) - ); - - security.acme = { - acceptTerms = true; - defaults.email = "lelgenio@disroot.org"; - }; - - networking.firewall.allowedTCPPorts = [ - 80 - 443 - ]; -} diff --git a/hosts/pixie/default.nix b/hosts/pixie.nix similarity index 80% rename from hosts/pixie/default.nix rename to hosts/pixie.nix index 9aa5a1e..5f8ce66 100644 --- a/hosts/pixie/default.nix +++ b/hosts/pixie.nix @@ -1,25 +1,13 @@ # Do not modify this file! It was generated by ‘nixos-generate-config’ # and may be overwritten by future invocations. Please make changes # to /etc/nixos/configuration.nix instead. -{ - config, - lib, - pkgs, - modulesPath, - ... -}: +{ config, lib, pkgs, modulesPath, ... }: { imports = [ (modulesPath + "/installer/scan/not-detected.nix") ]; - boot.initrd.availableKernelModules = [ - "nvme" - "xhci_pci" - "ahci" - "usb_storage" - "usbhid" - "sd_mod" - ]; + boot.initrd.availableKernelModules = + [ "nvme" "xhci_pci" "ahci" "usb_storage" "usbhid" "sd_mod" ]; boot.initrd.kernelModules = [ ]; boot.kernelModules = [ "kvm-amd" ]; boot.extraModulePackages = [ ]; @@ -30,7 +18,8 @@ options = [ "subvol=nixos" ]; }; - boot.initrd.luks.devices."pixie".device = "/dev/disk/by-uuid/f4ae5858-d2d6-4cd1-a054-bf5147a9a928"; + boot.initrd.luks.devices."pixie".device = + "/dev/disk/by-uuid/f4ae5858-d2d6-4cd1-a054-bf5147a9a928"; fileSystems."/home" = { device = "/dev/mapper/pixie"; @@ -57,7 +46,8 @@ # networking.interfaces.enp4s0.useDHCP = lib.mkDefault true; # networking.interfaces.veth74f3ffc.useDHCP = lib.mkDefault true; - hardware.cpu.amd.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; + hardware.cpu.amd.updateMicrocode = + lib.mkDefault config.hardware.enableRedistributableFirmware; networking.hostName = "pixie"; # Define your hostname. } diff --git a/hosts/rainbow.nix b/hosts/rainbow.nix new file mode 100644 index 0000000..776ebec --- /dev/null +++ b/hosts/rainbow.nix @@ -0,0 +1,66 @@ +# Do not modify this file! It was generated by ‘nixos-generate-config’ +# and may be overwritten by future invocations. Please make changes +# to /etc/nixos/configuration.nix instead. +{ config, lib, pkgs, modulesPath, ... }: +let + btrfs_options = [ "compress=zstd:3" "noatime" "x-systemd.device-timeout=0" ]; + btrfs_ssd = [ "ssd" "discard=async" ]; +in +{ + imports = [ (modulesPath + "/installer/scan/not-detected.nix") ]; + + boot.initrd.availableKernelModules = + [ "xhci_pci" "ahci" "usb_storage" "usbhid" "sd_mod" ]; + boot.initrd.kernelModules = [ "i915" ]; + boot.kernelModules = [ "kvm-intel" ]; + boot.extraModulePackages = [ ]; + + fileSystems."/" = { + device = "/dev/disk/by-label/BTRFS_ROOT"; + fsType = "btrfs"; + options = [ "subvol=@nixos" ] ++ btrfs_options ++ btrfs_ssd; + }; + + boot.initrd.luks.devices = { + "main" = { + bypassWorkqueues = true; + device = "/dev/disk/by-label/CRYPT_ROOT"; + }; + }; + + fileSystems."/home" = { + device = "/dev/disk/by-label/BTRFS_ROOT"; + fsType = "btrfs"; + options = [ "subvol=@home" ] ++ btrfs_options ++ btrfs_ssd; + }; + + boot.loader.efi.efiSysMountPoint = "/boot/efi"; + fileSystems."/boot/efi" = { + device = "/dev/disk/by-uuid/DC3B-5753"; + fsType = "vfat"; + }; + + fileSystems."/swap" = { + device = "/dev/disk/by-label/BTRFS_ROOT"; + fsType = "btrfs"; + options = [ "subvol=@swap" ] ++ btrfs_ssd; + }; + + swapDevices = [{ + device = "/swap/swapfile"; + size = (1024 * 8); + }]; + + # Enables DHCP on each ethernet and wireless interface. In case of scripted networking + # (the default) this is the recommended approach. When using systemd-networkd it's + # still possible to use this option, but it's recommended to use it in conjunction + # with explicit per-interface declarations with `networking.interfaces..useDHCP`. + networking.useDHCP = lib.mkDefault true; + # networking.interfaces.enp1s0.useDHCP = lib.mkDefault true; + + powerManagement.cpuFreqGovernor = lib.mkDefault "ondemand"; + hardware.cpu.intel.updateMicrocode = + lib.mkDefault config.hardware.enableRedistributableFirmware; + + networking.hostName = "rainbow"; # Define your hostname. +} diff --git a/install/i15.sh b/install/i15.sh new file mode 100644 index 0000000..72a5ac6 --- /dev/null +++ b/install/i15.sh @@ -0,0 +1,63 @@ +#!/bin/sh + +set -xe + +settle() { + udevadm trigger --subsystem-match=block + udevadm settle +} + +lsblk +echo 'Enter the name of the device to WIPE and install (something like "sda"):' +read DRIVE_ID + +echo 'Enter a passphrase to encrypt the disk:' +read -s DRIVE_PASSPHRASE + +echo "Creating partition table..." +parted -s "/dev/${DRIVE_ID}" -- mklabel gpt + +echo "Creating EFI system partition..." +parted -s "/dev/${DRIVE_ID}" -- mkpart ESP 1MiB 1GiB +parted -s "/dev/${DRIVE_ID}" -- set 1 boot on +mkfs.fat -F32 "/dev/${DRIVE_ID}1" -n NIX_BOOT + +echo "Creating encrypted root partition..." +parted -s "/dev/${DRIVE_ID}" -- mkpart luks 1GiB 100% +echo "$DRIVE_PASSPHRASE" | cryptsetup --batch-mode luksFormat --label CRYPT_ROOT "/dev/${DRIVE_ID}2" +settle +echo "$DRIVE_PASSPHRASE" | cryptsetup luksOpen /dev/disk/by-label/CRYPT_ROOT "crypt_root" + +echo "Creating btrfs partition..." +mkfs.btrfs --quiet --label NIX_ROOT /dev/mapper/"crypt_root" +MNTPOINT=$(mktemp -d) +mount /dev/mapper/"crypt_root" "$MNTPOINT" + +echo "Creating subvolumes..." +btrfs subvolume create "$MNTPOINT"/@nixos +btrfs subvolume create "$MNTPOINT"/@home +btrfs subvolume create "$MNTPOINT"/@swap + +echo "Closing btrfs partition..." +umount -Rl "$MNTPOINT" +rm -rf "$MNTPOINT" + +echo "Mounting root btrfs submodule to '$MNTPOINT' ..." +MNTPOINT=$(mktemp -d) +mount /dev/disk/by-label/NIX_ROOT "$MNTPOINT" -o subvol=@nixos,noatime,compress=zstd + +echo "Creating and mounting EFI system partition mountpoint..." +mkdir -p "$MNTPOINT/boot" +mount /dev/disk/by-label/NIX_BOOT "$MNTPOINT/boot" + +echo "Creating home partition mountpoint..." +mkdir -p "$MNTPOINT/home" +mount /dev/disk/by-label/NIX_ROOT "$MNTPOINT/home" -o subvol=@home,noatime,compress=zstd + +echo "Swapfile" +mkdir -p "$MNTPOINT/swap" +mount /dev/disk/by-label/NIX_ROOT "$MNTPOINT/swap" -o subvol=@swap,noatime + +# echo "Installing system..." +nixos-generate-config --root "$MNTPOINT" +# nixos-install --root "$MNTPOINT" diff --git a/overlays/default.nix b/overlays/default.nix index a032271..6782ca4 100644 --- a/overlays/default.nix +++ b/overlays/default.nix @@ -1,81 +1,74 @@ -{ inputs, packages, ... }: -rec { +{ inputs, packages, ... }: rec { all = [ scripts - unstable + sway themes new-packages patches + variables lib_extended - disko ]; scripts = (import ../scripts); - unstable = final: prev: { - unstable = import inputs.nixpkgs-unstable { inherit (final) system config; }; - }; + sway = (import ./sway.nix); - themes = ( - final: prev: { - papirus_red = (final.papirus-icon-theme.override { color = "red"; }); - orchis_theme_compact = ( - final.orchis-theme.override { - border-radius = 0; - tweaks = [ - "compact" - "solid" - ]; - } - ); - } - ); + themes = (final: prev: { + material-wifi-icons = final.stdenv.mkDerivation rec { + name = "material-wifi-icons"; + src = inputs.material-wifi-icons; + installPhase = '' + install -D material-wifi.ttf $out/share/fonts/${name} + ''; + }; + papirus_red = (final.papirus-icon-theme.override { color = "red"; }); + orchis_theme_compact = (final.orchis-theme.override { + border-radius = 0; + tweaks = [ "compact" "solid" ]; + }); + nerdfonts_fira_hack = (final.nerdfonts.override { fonts = [ "FiraCode" "Hack" ]; }); + }); - new-packages = ( - final: prev: - packages - // { - dhist = inputs.dhist.packages.${prev.system}.dhist; - demoji = inputs.demoji.packages.${prev.system}.default; - tlauncher = inputs.tlauncher.packages.${prev.system}.tlauncher; - wl-crosshair = inputs.wl-crosshair.packages.${prev.system}.default; - } - ); + new-packages = (final: prev: packages // { + dhist = inputs.dhist.packages.${prev.system}.dhist; + demoji = inputs.demoji.packages.${prev.system}.default; + tlauncher = inputs.tlauncher.packages.${prev.system}.tlauncher; + maildir-notify-daemon = inputs.maildir-notify-daemon.packages.${prev.system}.default; + wl-crosshair = inputs.wl-crosshair.packages.${prev.system}.default; - patches = ( - final: prev: { - mySway = prev.sway.override { - withBaseWrapper = true; - withGtkWrapper = true; - sway-unwrapped = prev.sway-unwrapped.overrideAttrs (old: { - patches = old.patches ++ [ ../patches/sway/fix-hide_cursor-clearing-focus.patch ]; - }); - }; - } - ); + webcord = (prev.webcord.overrideAttrs (old: { + patches = (old.patches or [ ]) ++ [ ../patches/webcord/fix-reading-config.patch ]; + })); + }); - lib_extended = ( - final: prev: { - lib = prev.lib // rec { - # Utility function - # Input: [{v1=1;} {v2=2;}] - # Output: {v1=1;v2=2;} - mergeAttrsSet = prev.lib.foldAttrs (n: _: n) { }; + patches = (final: prev: { + bemenu = prev.bemenu.overrideAttrs (o: { + postPatch = '' + substituteInPlace lib/renderers/wayland/window.c \ + --replace ZWLR_LAYER_SHELL_V1_LAYER_TOP ZWLR_LAYER_SHELL_V1_LAYER_OVERLAY + ''; + }); + sway-unwrapped = prev.sway-unwrapped.overrideAttrs (old: { + patches = old.patches + ++ [ ../patches/sway/fix-hide_cursor-clearing-focus.patch ]; + }); + }); - # Easily translate imperative templating code - # Input: [ 1 2 ] (num: { "v${num}" = num; }) - # Output: {v1=1;v2=2;} - forEachMerge = list: func: mergeAttrsSet (prev.lib.forEach list func); - }; - } - ); + variables = (final: prev: { + uservars = import ../user/variables.nix; + }); - disko = final: prev: { - makeDiskoTest = - let - makeTest = import (prev.path + "/nixos/tests/make-test-python.nix"); - eval-config = import (prev.path + "/nixos/lib/eval-config.nix"); - in - (prev.callPackage "${inputs.disko}/tests/lib.nix" { inherit makeTest eval-config; }).makeDiskoTest; - }; + lib_extended = (final: prev: { + lib = prev.lib // rec { + # Utility function + # Input: [{v1=1;} {v2=2;}] + # Output: {v1=1;v2=2;} + mergeAttrsSet = prev.lib.foldAttrs (n: _: n) { }; + + # Easily translate imperative templating code + # Input: [ 1 2 ] (num: { "v${num}" = num; }) + # Output: {v1=1;v2=2;} + forEachMerge = list: func: mergeAttrsSet (prev.lib.forEach list func); + }; + }); } diff --git a/overlays/sway.nix b/overlays/sway.nix new file mode 100644 index 0000000..4de4395 --- /dev/null +++ b/overlays/sway.nix @@ -0,0 +1,19 @@ +(pkgs: _: { + # bash script to let dbus know about important env variables and + # propogate them to relevent services run at the end of sway config + # see + # https://github.com/emersion/xdg-desktop-portal-wlr/wiki/"It-doesn't-work"-Troubleshooting-Checklist + # note: this is pretty much the same as /etc/sway/config.d/nixos.conf but also restarts + # some user services to make sure they have the correct environment variables + dbus-sway-environment = pkgs.writeTextFile { + name = "dbus-sway-environment"; + destination = "/bin/dbus-sway-environment"; + executable = true; + text = '' + systemctl --user import-environment + dbus-update-activation-environment --systemd WAYLAND_DISPLAY XDG_CURRENT_DESKTOP=sway + # systemctl --user stop pipewire wireplumber xdg-desktop-portal xdg-desktop-portal-wlr + # systemctl --user start pipewire wireplumber xdg-desktop-portal xdg-desktop-portal-wlr + ''; + }; +}) diff --git a/patches/nixpkgs/fix-steam-generation-after-generation-switch.patch b/patches/nixpkgs/fix-steam-generation-after-generation-switch.patch new file mode 100644 index 0000000..7c2b37f --- /dev/null +++ b/patches/nixpkgs/fix-steam-generation-after-generation-switch.patch @@ -0,0 +1,27 @@ +From ac4d51306af54a088e29e2e5efcfac5dfe87d95c Mon Sep 17 00:00:00 2001 +From: lelgenio +Date: Fri, 4 Aug 2023 01:25:04 -0300 +Subject: [PATCH] HACK: fix steam after generation switch + +--- + pkgs/build-support/build-fhsenv-bubblewrap/default.nix | 4 ++++ + 1 file changed, 4 insertions(+) + +diff --git a/pkgs/build-support/build-fhsenv-bubblewrap/default.nix b/pkgs/build-support/build-fhsenv-bubblewrap/default.nix +index 3500e5e9216f..4d7ac0aa7618 100644 +--- a/pkgs/build-support/build-fhsenv-bubblewrap/default.nix ++++ b/pkgs/build-support/build-fhsenv-bubblewrap/default.nix +@@ -152,6 +152,10 @@ let + fi + if [[ -L $i ]]; then + symlinks+=(--symlink "$(${coreutils}/bin/readlink "$i")" "$i") ++ elif [[ -f $i && -r $i ]]; then ++ SNAPSHOT=$(mktemp --dry-run) ++ cp "$i" "$SNAPSHOT" ++ ro_mounts+=(--ro-bind-try "$SNAPSHOT" "$i") + else + ro_mounts+=(--ro-bind-try "$i" "$i") + fi +-- +2.42.0 + diff --git a/patches/qutebrowser/tree-style-tabs.patch b/patches/qutebrowser/tree-style-tabs.patch new file mode 100644 index 0000000..f8dc6a0 --- /dev/null +++ b/patches/qutebrowser/tree-style-tabs.patch @@ -0,0 +1,10282 @@ +diff --git a/.coveragerc b/.coveragerc +index cb0619b80..7c4f7b218 100644 +--- a/.coveragerc ++++ b/.coveragerc +@@ -23,3 +23,6 @@ exclude_lines = + + [xml] + output=coverage.xml ++ ++[html] ++show_contexts = True +diff --git a/.flake8 b/.flake8 +index 9110dc54c..34a829a4b 100644 +--- a/.flake8 ++++ b/.flake8 +@@ -40,7 +40,7 @@ exclude = .*,__pycache__,resources.py + # A003: Builtin name for class attribute (needed for overridden methods) + # W503: like break before binary operator + # W504: line break after binary operator +-# FI15: __future__ import "generator_stop" missing ++# FI18: __future__ import "annotations" missing + # PT004: fixture '{name}' does not return anything, add leading underscore + # PT011: pytest.raises(ValueError) is too broad, set the match parameter or use a more specific exception + # PT012: pytest.raises() block should contain a single simple statement +@@ -53,11 +53,11 @@ ignore = + D102,D103,D106,D107,D104,D105,D209,D211,D401,D402,D403,D412,D413, + A003, + W503, W504, +- FI15, ++ FI18, + PT004, + PT011, + PT012 +-min-version = 3.6.1 ++min-version = 3.7.0 + max-complexity = 12 + per-file-ignores = + qutebrowser/api/hook.py : N801 +diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml +index 23d37f991..1fc5c0d5b 100644 +--- a/.github/workflows/ci.yml ++++ b/.github/workflows/ci.yml +@@ -105,10 +105,10 @@ jobs: + fail-fast: false + matrix: + include: +- ### PyQt 5.12 (Python 3.6) +- - testenv: py36-pyqt512 ++ ### PyQt 5.12 (Python 3.7) ++ - testenv: py37-pyqt512 + os: ubuntu-18.04 +- python: 3.6 ++ python: 3.7 + ### PyQt 5.13 (Python 3.7) + - testenv: py37-pyqt513 + os: ubuntu-20.04 +diff --git a/.mypy.ini b/.mypy.ini +index 501ab747e..b347323f5 100644 +--- a/.mypy.ini ++++ b/.mypy.ini +@@ -1,5 +1,5 @@ + [mypy] +-python_version = 3.6 ++python_version = 3.7 + + ### --strict + warn_unused_configs = True +diff --git a/.pylintrc b/.pylintrc +index 4ff4f2080..c5a1289fb 100644 +--- a/.pylintrc ++++ b/.pylintrc +@@ -18,7 +18,7 @@ load-plugins=qute_pylint.config, + pylint.extensions.private_import, + + persistent=n +-py-version=3.6 ++py-version=3.7 + + [MESSAGES CONTROL] + enable=all +diff --git a/MANIFEST.in b/MANIFEST.in +index ed4b5e5b1..81bf824b7 100644 +--- a/MANIFEST.in ++++ b/MANIFEST.in +@@ -4,7 +4,7 @@ recursive-include qutebrowser/javascript *.js + graft tests + graft qutebrowser/html + graft qutebrowser/3rdparty +-graft icons ++graft qutebrowser/icons + graft doc/img + graft misc/apparmor + graft misc/userscripts +diff --git a/README.asciidoc b/README.asciidoc +index bb1f2562c..fe0c23f2d 100644 +--- a/README.asciidoc ++++ b/README.asciidoc +@@ -7,7 +7,7 @@ qutebrowser + =========== + + // QUTE_WEB_HIDE +-image:icons/qutebrowser-64x64.png[qutebrowser logo] *A keyboard-driven, vim-like browser based on PyQt5 and Qt.* ++image:qutebrowser/icons/qutebrowser-64x64.png[qutebrowser logo] *A keyboard-driven, vim-like browser based on Python and Qt.* + + image:https://github.com/qutebrowser/qutebrowser/workflows/CI/badge.svg["Build Status", link="https://github.com/qutebrowser/qutebrowser/actions?query=workflow%3ACI"] + image:https://codecov.io/github/qutebrowser/qutebrowser/coverage.svg?branch=master["coverage badge",link="https://codecov.io/github/qutebrowser/qutebrowser?branch=master"] +@@ -16,7 +16,7 @@ link:https://www.qutebrowser.org[website] | link:https://blog.qutebrowser.org[bl + // QUTE_WEB_HIDE_END + + qutebrowser is a keyboard-focused browser with a minimal GUI. It's based +-on Python and PyQt5 and free software, licensed under the GPL. ++on Python and Qt and free software, licensed under the GPL. + + It was inspired by other browsers/addons like dwb and Vimperator/Pentadactyl. + +@@ -74,7 +74,7 @@ Requirements + + The following software and libraries are required to run qutebrowser: + +-* https://www.python.org/[Python] 3.6.1 or newer ++* https://www.python.org/[Python] 3.7 or newer + * https://www.qt.io/[Qt] 5.12.0 or newer (5.12 LTS or 5.15 recommended, Qt 6 is + not supported yet) with the following modules: + - QtCore / qtbase +@@ -96,10 +96,9 @@ websites and using it for transmission of sensitive data._ + * https://palletsprojects.com/p/jinja/[jinja2] + * https://github.com/yaml/pyyaml[PyYAML] + +-On older Python versions (3.6/3.7/3.8), the following backports are also required: ++On older Python versions (3.7/3.8), the following backports are also required: + +-* https://importlib-resources.readthedocs.io/[importlib_resources] (Python 3.8 or older) +-* https://github.com/ericvsmith/dataclasses[dataclasses] (Python 3.6 only) ++* https://importlib-resources.readthedocs.io/[importlib_resources] + + The following libraries are optional: + +@@ -109,8 +108,8 @@ The following libraries are optional: + QtWebEngine backend. + * On Windows, https://pypi.python.org/pypi/colorama/[colorama] for colored log + output. +-* https://importlib-metadata.readthedocs.io/[importlib_resources] on Python 3.7 +- or older, to improve QtWebEngine version detection when PyQtWebEngine is ++* https://importlib-metadata.readthedocs.io/[importlib_metadata] on Python 3.7, ++ to improve QtWebEngine version detection when PyQtWebEngine is + installed via pip (thus, this dependency usually isn't relevant for + packagers). + * https://asciidoc.org/[asciidoc] to generate the documentation for the `:help` +diff --git a/doc/changelog.asciidoc b/doc/changelog.asciidoc +index 4e7afd159..236039f67 100644 +--- a/doc/changelog.asciidoc ++++ b/doc/changelog.asciidoc +@@ -15,38 +15,37 @@ breaking changes (such as renamed commands) can happen in minor releases. + // `Fixed` for any bug fixes. + // `Security` to invite users to upgrade in case of vulnerabilities. + +-[[v2.5.2]] +-v2.5.2 (2022-06-22) ++[[v3.0.0]] ++v3.0.0 (unreleased) + ------------------- + +-Fixed +-~~~~~ ++Removed ++~~~~~~~ ++ ++- Support for Python 3.6 is dropped, as it's been ++ https://discuss.python.org/t/python-3-6-rides-into-the-sunset/12964[end-of-life upstream] ++ since December 2021. Python 3.7.0 or newer is now required. ++- It's planned to drop support for various legacy platforms and libraries which ++ are unsupported upstream, such as: ++ * Qt before 5.15 LTS (plus adding support for Qt 6.2+) ++ * The QtWebKit backend ++ * macOS 10.14 (via Homebrew) ++ * 32-bit Windows (via Qt) ++ * Windows 8 (via Qt) ++ * Windows 10 before 1809 (via Qt) ++ * Possibly other more minor dependency changes + +-- Packaging-related fixes: +- * The `install` and `stacktrace` help pages are now included in the docs +- shipped with qutebrowser when using the recommended packaging workflow. +- * The Windows installer now more consistently uses the configured Windows +- colors. +- * The Windows installer now bases the desktop/start menu icon choices on +- the existing install, if upgrading. +- * The macOS release hopefully doesn't cause macOS to (falsely) claim that it +- "is damaged and can't be opened" anymore. +-- The notification fixes in v2.5.1 caused new notification crashes (probably +- more common than the ones being fixed...). Those are now fixed, along with a +- (rather involved) test case to prevent similar issues in the future. +-- When a text was not found on a page, the associated message would be shown as +- rich text (e.g. after `/

`). With this release, this is fixed for search +- messages, while the 3.0.0 release will change the default for all messages to be +- plain-text. Note this is NOT a security issue, as only a small subset of HTML +- is interpreted as rich text by Qt, independently from the website. +-- When a Greasemonkey script couldn't be loaded (e.g. due to an unreadable file), +- qutebrowser would crash. It now shows an error instead. +-- Ever since the v1.2.0 release in 2018, the `content.default_encoding` setting +- was not applied on start properly (only when it was changed afterwards). This +- is now fixed. ++Changed ++~~~~~~~ ++ ++- The qutebrowser icons got moved from `icons/` to `qutebrowser/icons` in the ++ repository, so that it's possible for qutebrowser to load them using Python's ++ resource system (rather than compiling them into a Qt resource file). ++ Packagers are advised to use `misc/Makefile` if possible, which has been ++ updated with the new paths. + + [[v2.5.1]] +-v2.5.1 (2022-05-26) ++v2.5.1 (unreleased) + ------------------- + + Fixed +@@ -54,25 +53,6 @@ Fixed + + - The `qute-pass` userscript is marked as executable again. + - PDF.js now works properly again with the macOS and Windows releases. +-- The MathML workaround for darkmode (e.g. black on black Wikipedia formula) +- now also works for display (rather than inline) math. +-- The `content.proxy` setting can now correctly be set to arbitrary values via +- the `qute://settings` page again. +-- Fixed issues with Chromium version detection on Archlinux with +- qt5-webengine 5.15.9-3. +-- Fixed a rare possible crash with invalid `Content-Disposition` headers. +-- Fixes for various notification-related crashes: +- * With the `tiramisu` notification server (due to invalid behavior of the server, now a non-fatal error) +- * With the `budgie` notification server when closing a notification (due to invalid behavior of the server, now worked around) +- * When a server exits with an unsuccessful exit status (now a non-fatal error) +- * When a server couldn't be started successfully (now a non-fatal error) +- * With the `herbe` notification presenter, when the website tries to close +- the notification after the user accepting (right-clicking) it. +-- Fixes in userscripts: +- * The `qute-bitwarden` userscript now correctly searches for entries for +- sites on a subdomain of an unrecognized TLD. subdomain names. Previously +- `my.site.local` would have searched in bitwarden for `my.sitelocal`, +- losing the rightmost dot. + + [[v2.5.0]] + v2.5.0 (2022-04-01) +diff --git a/doc/contributing.asciidoc b/doc/contributing.asciidoc +index 75c19045e..70447d8c5 100644 +--- a/doc/contributing.asciidoc ++++ b/doc/contributing.asciidoc +@@ -111,9 +111,9 @@ unittests and several linters/checkers. + Currently, the following tox environments are available: + + * Tests using https://www.pytest.org[pytest]: +- - `py36`, `py37`, ...: Run pytest for python 3.6/3.7/... with the system-wide PyQt. +- - `py36-pyqt512`, ..., `py36-pyqt515`: Run pytest with the given PyQt version (`py35-*` also works). +- - `py36-pyqt515-cov`: Run with coverage support (other Python/PyQt versions work too). ++ - `py37`, `py38`, ...: Run pytest for python 3.7/3.8/... with the system-wide PyQt. ++ - `py37-pyqt512`, ..., `py37-pyqt515`: Run pytest with the given PyQt version (`py37-*` also works). ++ - `py37-pyqt515-cov`: Run with coverage support (other Python/PyQt versions work too). + * `flake8`: Run various linting checks via https://pypi.python.org/pypi/flake8[flake8]. + * `vulture`: Run https://pypi.python.org/pypi/vulture[vulture] to find + unused code portions. +@@ -168,16 +168,16 @@ Examples: + + ---- + # run only pytest tests which failed in last run: +-tox -e py35 -- --lf ++tox -e py37 -- --lf + + # run only the end2end feature tests: +-tox -e py35 -- tests/end2end/features ++tox -e py37 -- tests/end2end/features + + # run everything with undo in the generated name, based on the scenario text +-tox -e py35 -- tests/end2end/features/test_tabs_bdd.py -k undo ++tox -e py37 -- tests/end2end/features/test_tabs_bdd.py -k undo + + # run coverage test for specific file (updates htmlcov/index.html) +-tox -e py35-cov -- tests/unit/browser/test_webelem.py ++tox -e py37-cov -- tests/unit/browser/test_webelem.py + ---- + + Profiling +@@ -544,11 +544,8 @@ ____ + Setting up a Windows Development Environment + ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +-* Install https://www.python.org/downloads/release/python-362/[Python 3.6]. ++* Install https://www.python.org/downloads/release/python-3911/[Python 3.9]. + * Install PyQt via `pip install PyQt5`. +-* Create a file at `C:\Windows\system32\python3.bat` with the following content (adjust the path as necessary): +- `@C:\Python36\python %*`. +- This will make the Python 3.6 interpreter available as `python3`, which is used by various development scripts. + * Install git from the https://git-scm.com/download/win[git-scm downloads page]. + Try not to enable `core.autocrlf`, since that will cause `flake8` to complain a lot. Use an editor that can deal with plain line feeds instead. + * Clone your favourite qutebrowser repository. +diff --git a/doc/help/commands.asciidoc b/doc/help/commands.asciidoc +index 445d46d4b..ad9de2a71 100644 +--- a/doc/help/commands.asciidoc ++++ b/doc/help/commands.asciidoc +@@ -130,6 +130,12 @@ possible to run or bind multiple commands by separating them with `;;`. + |<>|Switch to the previous tab, or switch [count] tabs back. + |<>|Select tab by index or url/title best match. + |<>|Take a tab from another window. ++|<>|Wrapper around :open qute://treegroup/name. Correctly escapes names. ++|<>|Hides levels of descendents: children, grandchildren, and so on. ++|<>|Demote a tab making it children of its previous adjacent sibling. ++|<>|Promote a tab so it becomes next sibling of its parent. ++|<>|Suspends all descendent of a tab to reduce memory usage. ++|<>|If the current tab's children are shown hide them, and vice-versa. + |<>|Unbind a keychain. + |<>|Re-open the last closed tab(s) or window. + |<>|Show version information. +@@ -904,7 +910,7 @@ Do nothing. + + [[open]] + === open +-Syntax: +:open [*--related*] [*--bg*] [*--tab*] [*--window*] [*--secure*] [*--private*] ['url']+ ++Syntax: +:open [*--related*] [*--sibling*] [*--bg*] [*--tab*] [*--window*] [*--secure*] [*--private*] ['url']+ + + Open a URL in the current/[count]th tab. + +@@ -916,6 +922,8 @@ If the URL contains newlines, each line gets opened in its own tab. + ==== optional arguments + * +*-r*+, +*--related*+: If opening a new tab, position the tab as related to the current one (like clicking on a link). + ++* +*-S*+, +*--sibling*+: If opening a new tab, position the as a sibling of the current one. ++ + * +*-b*+, +*--bg*+: Open in a new background tab. + * +*-t*+, +*--tab*+: Open in a new tab. + * +*-w*+, +*--window*+: Open in a new window. +@@ -1367,7 +1375,7 @@ Duplicate the current tab. + + [[tab-close]] + === tab-close +-Syntax: +:tab-close [*--prev*] [*--next*] [*--opposite*] [*--force*]+ ++Syntax: +:tab-close [*--prev*] [*--next*] [*--opposite*] [*--force*] [*--recursive*]+ + + Close the current/[count]th tab. + +@@ -1377,6 +1385,7 @@ Close the current/[count]th tab. + * +*-o*+, +*--opposite*+: Force selecting the tab in the opposite direction of what's configured in 'tabs.select_on_remove'. + + * +*-f*+, +*--force*+: Avoid confirmation for pinned tabs. ++* +*-r*+, +*--recursive*+: Close all descendents (tree-tabs) as well as current tab + + ==== count + The tab index to close +@@ -1390,10 +1399,14 @@ Select the tab given as argument/[count]. + If neither count nor index are given, it behaves like tab-next. If both are given, use count. + + ==== positional arguments +-* +'index'+: The tab index to focus, starting with 1. The special value `last` focuses the last focused tab (regardless of count), +- and `stack-prev`/`stack-next` traverse a stack of visited +- tabs. Negative indices count from the end, such that -1 is +- the last tab. ++* +'index'+: The tab index to focus, starting with 1. Negative indices count from the end, such that -1 is the last tab. Special ++ values are: ++ - `last` focuses the last focused tab (regardless of ++ count). ++ - `parent` focuses the parent tab in the tree hierarchy, ++ if `tabs.tree_tabs` is enabled. ++ - `stack-prev`/`stack-next` traverse a stack of visited ++ tabs. + + + ==== optional arguments +@@ -1404,7 +1417,7 @@ The tab index to focus, starting with 1. + + [[tab-give]] + === tab-give +-Syntax: +:tab-give [*--keep*] [*--private*] ['win-id']+ ++Syntax: +:tab-give [*--keep*] [*--private*] [*--recursive*] ['win-id']+ + + Give the current tab to a new or existing window if win_id given. + +@@ -1416,6 +1429,7 @@ If no win_id is given, the tab will get detached into a new window. + ==== optional arguments + * +*-k*+, +*--keep*+: If given, keep the old tab around. + * +*-p*+, +*--private*+: If the tab should be detached into a private instance. ++* +*-r*+, +*--recursive*+: Whether to move the entire subtree starting at the tab. + + ==== count + Overrides win_id (index starts at 1 for win_id=0). +@@ -1448,8 +1462,13 @@ The tab index to mute or unmute + + [[tab-next]] + === tab-next ++Syntax: +:tab-next [*--sibling*]+ ++ + Switch to the next tab, or switch [count] tabs forward. + ++==== optional arguments ++* +*-s*+, +*--sibling*+: Whether to focus the next tree sibling. ++ + ==== count + How many tabs to switch forward. + +@@ -1477,8 +1496,13 @@ The tab index to pin or unpin + + [[tab-prev]] + === tab-prev ++Syntax: +:tab-prev [*--sibling*]+ ++ + Switch to the previous tab, or switch [count] tabs back. + ++==== optional arguments ++* +*-s*+, +*--sibling*+: Whether to focus the previous tree sibling. ++ + ==== count + How many tabs to switch back. + +@@ -1516,6 +1540,59 @@ Take a tab from another window. + ==== note + * This command does not split arguments after the last argument and handles quotes literally. + ++[[tree-tab-create-group]] ++=== tree-tab-create-group ++Syntax: +:tree-tab-create-group [*--related*] [*--background*] 'name' ['name' ...]+ ++ ++Wrapper around :open qute://treegroup/name. Correctly escapes names. ++ ++Example: `:tree-tab-create-group Foo Bar` calls `:open qute://treegroup/Foo%20Bar` ++ ++==== positional arguments ++* +'name'+: Name of the group to create ++ ++==== optional arguments ++* +*-r*+, +*--related*+: whether to open as a child of current tab or under root ++* +*-b*+, +*--background*+: whether to open in a background tab ++ ++[[tree-tab-cycle-hide]] ++=== tree-tab-cycle-hide ++Hides levels of descendents: children, grandchildren, and so on. ++ ++==== count ++How many levels to hide. ++ ++[[tree-tab-demote]] ++=== tree-tab-demote ++Demote a tab making it children of its previous adjacent sibling. ++ ++Observes tabs.new_position.tree.demote in positioning the tab among new siblings. ++ ++[[tree-tab-promote]] ++=== tree-tab-promote ++Promote a tab so it becomes next sibling of its parent. ++ ++Observes tabs.new_position.tree.promote in positioning the tab among new siblings. ++ ++==== count ++How many levels the tabs should be promoted to ++ ++[[tree-tab-suspend-children]] ++=== tree-tab-suspend-children ++Suspends all descendent of a tab to reduce memory usage. ++ ++==== count ++Target tab. ++ ++[[tree-tab-toggle-hide]] ++=== tree-tab-toggle-hide ++If the current tab's children are shown hide them, and vice-versa. ++ ++This toggles the current tab's node's `collapsed` attribute. ++ ++==== count ++Which tab to collapse ++ + [[unbind]] + === unbind + Syntax: +:unbind [*--mode* 'mode'] 'key'+ +diff --git a/doc/help/configuring.asciidoc b/doc/help/configuring.asciidoc +index b469118ed..3ecef8ecf 100644 +--- a/doc/help/configuring.asciidoc ++++ b/doc/help/configuring.asciidoc +@@ -391,8 +391,8 @@ import subprocess + + def read_xresources(prefix): + props = {} +- x = subprocess.run(['xrdb', '-query'], stdout=subprocess.PIPE) +- lines = x.stdout.decode().split('\n') ++ x = subprocess.run(['xrdb', '-query'], capture_output=True, check=True, text=True) ++ lines = x.stdout.split('\n') + for line in filter(lambda l : l.startswith(prefix), lines): + prop, _, value = line.partition(':\t') + props[prop] = value +@@ -447,7 +447,7 @@ Various emacs/conkeror-like keybinding configs exist: + + - https://gitlab.com/jgkamat/qutemacs/blob/master/qutemacs.py[jgkamat] + - https://gitlab.com/Kaligule/qutebrowser-emacs-config/blob/master/config.py[Kaligule] +-- https://me0w.net/pit/1540882719[nm0i] ++- https://web.archive.org/web/20210512185023/https://me0w.net/pit/1540882719[nm0i] + - https://www.reddit.com/r/qutebrowser/comments/eh10i7/config_share_qute_with_emacs_keybindings/[jasonsun0310] + + It's also mostly possible to get rid of modal keybindings by setting +diff --git a/doc/help/settings.asciidoc b/doc/help/settings.asciidoc +index 2f60525f4..20012b121 100644 +--- a/doc/help/settings.asciidoc ++++ b/doc/help/settings.asciidoc +@@ -325,6 +325,11 @@ + |<>|Switch between tabs using the mouse wheel. + |<>|Position of new tabs opened from another tab. + |<>|Stack related tabs on top of each other when opened consecutively. ++|<>|Position at which a tab is placed among its new siblings after being demoted with `:tree-tab-demote` ++|<>|Position of new children among siblings, e.g. after calling `:open --relative ...` or following a link. ++|<>|Position of siblings, e.g. after calling `:open --sibling ...`. ++|<>|Position of new top-level tabs related to the topmost ancestor of current tab, e.g. when calling `:open ...` without `--relative` or `--sibling`. ++|<>|Position at which a tab is placed among its new siblings after being promoted with `:tree-tab-promote` + |<>|Position of new tabs which are not opened from another tab. + |<>|Padding (in pixels) around text for tabs. + |<>|Force pinned tabs to stay at fixed URL. +@@ -364,7 +369,7 @@ The keys of the given dictionary are the aliases, while the values are the comma + + Type: <> + +-Default: ++Default: + + - +pass:[q]+: +pass:[close]+ + - +pass:[qa]+: +pass:[quit]+ +@@ -471,7 +476,7 @@ This setting can only be set in config.py. + + Type: <> + +-Default: ++Default: + + - +pass:[caret]+: + +@@ -740,6 +745,17 @@ Default: + * +pass:[yp]+: +pass:[yank pretty-url]+ + * +pass:[yt]+: +pass:[yank title]+ + * +pass:[yy]+: +pass:[yank]+ ++* +pass:[zG]+: +pass:[set-cmd-text -s :tree-tab-create-group]+ ++* +pass:[zH]+: +pass:[tree-tab-promote]+ ++* +pass:[zJ]+: +pass:[tab-next -s]+ ++* +pass:[zK]+: +pass:[tab-prev -s]+ ++* +pass:[zL]+: +pass:[tree-tab-demote]+ ++* +pass:[zO]+: +pass:[set-cmd-text --space :open -tS]+ ++* +pass:[za]+: +pass:[tree-tab-toggle-hide]+ ++* +pass:[zd]+: +pass:[tab-close -r]+ ++* +pass:[zg]+: +pass:[set-cmd-text -s :tree-tab-create-group -r]+ ++* +pass:[zo]+: +pass:[set-cmd-text --space :open -tr]+ ++* +pass:[zp]+: +pass:[tab-focus parent]+ + * +pass:[{{]+: +pass:[navigate prev -t]+ + * +pass:[}}]+: +pass:[navigate next -t]+ + - +pass:[passthrough]+: +@@ -796,7 +812,7 @@ Note that when a key is bound (via `bindings.default` or `bindings.commands`), t + + Type: <> + +-Default: ++Default: + + - +pass:[<Ctrl-6>]+: +pass:[<Ctrl-^>]+ + - +pass:[<Ctrl-Enter>]+: +pass:[<Ctrl-Return>]+ +@@ -870,7 +886,7 @@ May be a single color to use for all columns or a list of three colors, one for + + Type: <> + +-Default: ++Default: + + - +pass:[white]+ + - +pass:[white]+ +@@ -1850,7 +1866,7 @@ Valid values: + * +history+ + * +filesystem+ + +-Default: ++Default: + + - +pass:[searchengines]+ + - +pass:[quickmarks]+ +@@ -1955,7 +1971,7 @@ Valid values: + * +downloads+: Show a confirmation if downloads are running + * +never+: Never show a confirmation. + +-Default: ++Default: + + - +pass:[never]+ + +@@ -1986,7 +2002,7 @@ need to find the link to the raw `.txt` file (e.g. by extracting it from the + + Type: <> + +-Default: ++Default: + + - +pass:[https://easylist.to/easylist/easylist.txt]+ + - +pass:[https://easylist.to/easylist/easyprivacy.txt]+ +@@ -2031,7 +2047,7 @@ The file `~/.config/qutebrowser/blocked-hosts` is always read if it exists. + + Type: <> + +-Default: ++Default: + + - +pass:[https://raw.githubusercontent.com/StevenBlack/hosts/master/hosts]+ + +@@ -2385,7 +2401,7 @@ The following levels are valid: `none`, `debug`, `info`, `warning`, `error`. + + Type: <> + +-Default: ++Default: + + - +pass:[error]+: +pass:[debug]+ + - +pass:[info]+: +pass:[debug]+ +@@ -2928,7 +2944,7 @@ The following placeholders are defined: + + Type: <> + +-Default: ++Default: + + - +pass:[gvim]+ + - +pass:[-f]+ +@@ -2990,7 +3006,7 @@ The following placeholders are defined: + + Type: <> + +-Default: ++Default: + + - +pass:[xterm]+ + - +pass:[-e]+ +@@ -3006,7 +3022,7 @@ The following placeholders are defined: + + Type: <> + +-Default: ++Default: + + - +pass:[xterm]+ + - +pass:[-e]+ +@@ -3352,7 +3368,7 @@ Comma-separated list of regular expressions to use for 'next' links. + + Type: <> + +-Default: ++Default: + + - +pass:[\bnext\b]+ + - +pass:[\bmore\b]+ +@@ -3367,7 +3383,7 @@ Padding (in pixels) for hints. + + Type: <> + +-Default: ++Default: + + - +pass:[bottom]+: +pass:[0]+ + - +pass:[left]+: +pass:[3]+ +@@ -3380,7 +3396,7 @@ Comma-separated list of regular expressions to use for 'prev' links. + + Type: <> + +-Default: ++Default: + + - +pass:[\bprev(ious)?\b]+ + - +pass:[\bback\b]+ +@@ -3415,7 +3431,7 @@ This setting can only be set in config.py. + + Type: <> + +-Default: ++Default: + + - +pass:[all]+: + +@@ -4074,7 +4090,7 @@ Padding (in pixels) for the statusbar. + + Type: <> + +-Default: ++Default: + + - +pass:[bottom]+: +pass:[1]+ + - +pass:[left]+: +pass:[0]+ +@@ -4125,7 +4141,7 @@ Valid values: + * +progress+: Progress bar for the current page loading. + * +text:foo+: Display the static text after the colon, `foo` in the example. + +-Default: ++Default: + + - +pass:[keypress]+ + - +pass:[url]+ +@@ -4209,7 +4225,7 @@ Padding (in pixels) for tab indicators. + + Type: <> + +-Default: ++Default: + + - +pass:[bottom]+: +pass:[2]+ + - +pass:[left]+: +pass:[0]+ +@@ -4309,6 +4325,77 @@ Type: <> + + Default: +pass:[true]+ + ++[[tabs.new_position.tree.demote]] ++=== tabs.new_position.tree.demote ++Position at which a tab is placed among its new siblings after being demoted with `:tree-tab-demote` ++ ++Type: <> ++ ++Valid values: ++ ++ * +first+: At the beginning. ++ * +last+: At the end. ++ ++Default: +pass:[last]+ ++ ++[[tabs.new_position.tree.new_child]] ++=== tabs.new_position.tree.new_child ++Position of new children among siblings, e.g. after calling `:open --relative ...` or following a link. ++ ++Type: <> ++ ++Valid values: ++ ++ * +first+: At the beginning. ++ * +last+: At the end. ++ ++Default: +pass:[first]+ ++ ++[[tabs.new_position.tree.new_sibling]] ++=== tabs.new_position.tree.new_sibling ++Position of siblings, e.g. after calling `:open --sibling ...`. ++ ++Type: <> ++ ++Valid values: ++ ++ * +prev+: Before the current tab. ++ * +next+: After the current tab. ++ * +first+: At the beginning. ++ * +last+: At the end. ++ ++Default: +pass:[first]+ ++ ++[[tabs.new_position.tree.new_toplevel]] ++=== tabs.new_position.tree.new_toplevel ++Position of new top-level tabs related to the topmost ancestor of current tab, e.g. when calling `:open ...` without `--relative` or `--sibling`. ++ ++Type: <> ++ ++Valid values: ++ ++ * +prev+: Before the current tab. ++ * +next+: After the current tab. ++ * +first+: At the beginning. ++ * +last+: At the end. ++ ++Default: +pass:[last]+ ++ ++[[tabs.new_position.tree.promote]] ++=== tabs.new_position.tree.promote ++Position at which a tab is placed among its new siblings after being promoted with `:tree-tab-promote` ++ ++Type: <> ++ ++Valid values: ++ ++ * +prev+: Before the current tab. ++ * +next+: After the current tab. ++ * +first+: At the beginning. ++ * +last+: At the end. ++ ++Default: +pass:[next]+ ++ + [[tabs.new_position.unrelated]] + === tabs.new_position.unrelated + Position of new tabs which are not opened from another tab. +@@ -4331,7 +4418,7 @@ Padding (in pixels) around text for tabs. + + Type: <> + +-Default: ++Default: + + - +pass:[bottom]+: +pass:[0]+ + - +pass:[left]+: +pass:[5]+ +@@ -4434,6 +4521,8 @@ Format to use for the tab title. + The following placeholders are defined: + + * `{perc}`: Percentage as a string like `[10%]`. ++* `{collapsed}`: If children tabs are hidden, the string `[...]`, empty otherwise ++* `{tree}`: The ASCII tree prefix of current tab. + * `{perc_raw}`: Raw percentage, e.g. `10`. + * `{current_title}`: Title of the current web page. + * `{title_sep}`: The string `" - "` if a title is set, empty otherwise. +@@ -4453,7 +4542,7 @@ The following placeholders are defined: + + Type: <> + +-Default: +pass:[{audio}{index}: {current_title}]+ ++Default: +pass:[{tree}{collapsed}{audio}{index}: {current_title}]+ + + [[tabs.title.format_pinned]] + === tabs.title.format_pinned +@@ -4472,6 +4561,15 @@ Type: <> + + Default: +pass:[true]+ + ++[[tabs.tree_tabs]] ++=== tabs.tree_tabs ++Enable tree-tabs mode. ++This setting requires a restart. ++ ++Type: <> ++ ++Default: +pass:[false]+ ++ + [[tabs.undo_stack_size]] + === tabs.undo_stack_size + Number of closed tabs (per window) and closed windows to remember for :undo (-1 for no maximum). +@@ -4534,7 +4632,7 @@ Valid values: + * +query+ + * +anchor+ + +-Default: ++Default: + + - +pass:[path]+ + - +pass:[query]+ +@@ -4576,7 +4674,7 @@ term, e.g. `:open google qutebrowser`. + + Type: <> + +-Default: ++Default: + + - +pass:[DEFAULT]+: +pass:[https://duckduckgo.com/?q={}]+ + +@@ -4594,7 +4692,7 @@ URL parameters to strip with `:yank url`. + + Type: <> + +-Default: ++Default: + + - +pass:[ref]+ + - +pass:[utm_source]+ +@@ -4654,7 +4752,7 @@ Available zoom levels. + + Type: <> + +-Default: ++Default: + + - +pass:[25%]+ + - +pass:[33%]+ +@@ -4729,6 +4827,7 @@ Lists with duplicate flags are invalid. Each item is checked against the valid v + When setting from a string, pass a json-like list, e.g. `["one", "two"]`. + |ListOrValue|A list of values, or a single value. + |LogLevel|A logging level. ++|NewChildPosition|How new children are positioned. + |NewTabPosition|How new tabs are positioned. + |Padding|Setting for paddings around elements. + |Perc|A percentage. +diff --git a/doc/install.asciidoc b/doc/install.asciidoc +index dd284fb9a..bb4e08f5a 100644 +--- a/doc/install.asciidoc ++++ b/doc/install.asciidoc +@@ -38,7 +38,7 @@ version (Qt 5.7, based on a Chromium from March 2016). Furthermore, it packages + Ubuntu 16.04 doesn't come with an up-to-date engine (a new enough QtWebKit, or + QtWebEngine) and also comes with Python 3.5. + +-You should be able to install a newer Python (3.6+) using the ++You should be able to install a newer Python (3.7+) using the + https://launchpad.net/~deadsnakes/+archive/ubuntu/ppa[deadsnakes PPA] or + https://github.com/pyenv/pyenv[pyenv], and then proceed to + <>. However, this is currently untested. If you +@@ -447,7 +447,7 @@ This installs all needed Python dependencies in a `.venv` subfolder + This comes with an up-to-date Qt/PyQt including a pre-compiled QtWebEngine + binary, but has a few caveats: + +-- Make sure your `python3` is Python 3.6 or newer, otherwise you'll get a "No ++- Make sure your `python3` is Python 3.7 or newer, otherwise you'll get a "No + matching distribution found" error and/or qutebrowser will not run. + - It only works on 64-bit x86 systems, with other architectures you'll get the + same error. +diff --git a/doc/qutebrowser.1.asciidoc b/doc/qutebrowser.1.asciidoc +index a2b2bcec9..e83a4da0b 100644 +--- a/doc/qutebrowser.1.asciidoc ++++ b/doc/qutebrowser.1.asciidoc +@@ -10,14 +10,14 @@ + :homepage: https://www.qutebrowser.org/ + + == NAME +-qutebrowser - a keyboard-driven, vim-like browser based on PyQt5. ++qutebrowser - a keyboard-driven, vim-like browser based on Python and Qt. + + == SYNOPSIS + *qutebrowser* ['-OPTION' ['...']] [':COMMAND' ['...']] ['URL' ['...']] + + == DESCRIPTION + qutebrowser is a keyboard-focused browser with a minimal GUI. It's based +-on Python and Qt5 and is free software, licensed under the GPL. ++on Python and Qt and is free software, licensed under the GPL. + + It was inspired by other browsers/addons like dwb and Vimperator/Pentadactyl. + +diff --git a/misc/Makefile b/misc/Makefile +index b916a20d5..62294ba61 100644 +--- a/misc/Makefile ++++ b/misc/Makefile +@@ -24,9 +24,9 @@ install: man + "$(DESTDIR)$(MANDIR)/man1/qutebrowser.1" + install -Dm644 misc/org.qutebrowser.qutebrowser.desktop \ + "$(DESTDIR)$(DATADIR)/applications/org.qutebrowser.qutebrowser.desktop" +- $(foreach i,$(ICONSIZES),install -Dm644 "icons/qutebrowser-$(i)x$(i).png" \ ++ $(foreach i,$(ICONSIZES),install -Dm644 "qutebrowser/icons/qutebrowser-$(i)x$(i).png" \ + "$(DESTDIR)$(DATADIR)/icons/hicolor/$(i)x$(i)/apps/qutebrowser.png";) +- install -Dm644 icons/qutebrowser.svg \ ++ install -Dm644 qutebrowser/icons/qutebrowser.svg \ + "$(DESTDIR)$(DATADIR)/icons/hicolor/scalable/apps/qutebrowser.svg" + install -Dm755 -t "$(DESTDIR)$(DATADIR)/qutebrowser/userscripts/" \ + $(filter-out misc/userscripts/__pycache__,$(wildcard misc/userscripts/*)) +diff --git a/misc/nsis/qutebrowser.nsi b/misc/nsis/qutebrowser.nsi +index bfc9aa817..7623d8cb2 100755 +--- a/misc/nsis/qutebrowser.nsi ++++ b/misc/nsis/qutebrowser.nsi +@@ -60,7 +60,7 @@ ShowUninstDetails hide + !define URL_UPDATE "https://qutebrowser.org/doc/install.html" + !define HELP_LINK "https://qutebrowser.org/doc/help/" + !define CONTACT "mail@qutebrowser.org" +-!define COMMENTS "A keyboard-driven, vim-like browser based on PyQt5." ++!define COMMENTS "A keyboard-driven, vim-like browser based on Python and Qt." + !define LANGID "1033" ; U.S. English + !define MIN_WIN_VER "8" + !define SETUP_MUTEX "${PRODUCT_NAME} Setup Mutex" ; do not change this between program versions! +diff --git a/misc/org.qutebrowser.qutebrowser.desktop b/misc/org.qutebrowser.qutebrowser.desktop +index d999496ee..741a00371 100644 +--- a/misc/org.qutebrowser.qutebrowser.desktop ++++ b/misc/org.qutebrowser.qutebrowser.desktop +@@ -39,9 +39,9 @@ GenericName[ta]=இணைய உலாவி + GenericName[th]=เว็บเบราว์เซอร์ + GenericName[tr]=Web Tarayıcı + GenericName[uk]=Навігатор Тенет瀏覽器 +-Comment=A keyboard-driven, vim-like browser based on PyQt5 +-Comment[de]=Ein Tastatur-gesteuerter, vim-ähnlicher Browser basierend auf PyQt5 +-Comment[it]= Un browser web vim-like utilizzabile da tastiera basato su PyQt5 ++Comment=A keyboard-driven, vim-like browser based on Python and Qt ++Comment[de]=Ein Tastatur-gesteuerter, vim-ähnlicher Browser basierend auf Python und Qt ++Comment[it]= Un browser web vim-like utilizzabile da tastiera basato su Python e Qt + Icon=qutebrowser + Type=Application + Categories=Network;WebBrowser; +diff --git a/misc/qutebrowser.rcc b/misc/qutebrowser.rcc +deleted file mode 100644 +index ffe9e47f6..000000000 +--- a/misc/qutebrowser.rcc ++++ /dev/null +@@ -1,13 +0,0 @@ +- +- +- ../icons/qutebrowser-16x16.png +- ../icons/qutebrowser-24x24.png +- ../icons/qutebrowser-32x32.png +- ../icons/qutebrowser-48x48.png +- ../icons/qutebrowser-64x64.png +- ../icons/qutebrowser-96x96.png +- ../icons/qutebrowser-128x128.png +- ../icons/qutebrowser-256x256.png +- ../icons/qutebrowser-512x512.png +- +- +diff --git a/misc/qutebrowser.spec b/misc/qutebrowser.spec +index 5eefc82af..8ba435918 100644 +--- a/misc/qutebrowser.spec ++++ b/misc/qutebrowser.spec +@@ -2,6 +2,7 @@ + + import sys + import os ++import pathlib + + sys.path.insert(0, os.getcwd()) + from scripts import setupcommon +@@ -61,6 +62,7 @@ def get_data_files(): + data_files = [ + ('../qutebrowser/html', 'html'), + ('../qutebrowser/img', 'img'), ++ ('../qutebrowser/icons', 'icons'), + ('../qutebrowser/javascript', 'javascript'), + ('../qutebrowser/html/doc', 'html/doc'), + ('../qutebrowser/git-commit-id', '.'), +@@ -86,9 +88,12 @@ setupcommon.write_git_file() + + + if os.name == 'nt': +- icon = '../icons/qutebrowser.ico' ++ # WORKAROUND for PyInstaller 5.0 bug: ++ # https://github.com/pyinstaller/pyinstaller/issues/6759 ++ icons_path = pathlib.Path.cwd() / 'qutebrowser' / 'icons' ++ icon = str(icons_path / 'qutebrowser.ico') + elif sys.platform == 'darwin': +- icon = '../icons/qutebrowser.icns' ++ icon = '../qutebrowser/icons/qutebrowser.icns' + else: + icon = None + +diff --git a/misc/requirements/requirements-check-manifest.txt b/misc/requirements/requirements-check-manifest.txt +index 63f9eddc5..012a3dc05 100644 +--- a/misc/requirements/requirements-check-manifest.txt ++++ b/misc/requirements/requirements-check-manifest.txt +@@ -4,5 +4,5 @@ build==0.7.0 + check-manifest==0.48 + packaging==21.3 + pep517==0.12.0 +-pyparsing==3.0.7 ++pyparsing==3.0.8 + tomli==2.0.1 +diff --git a/misc/requirements/requirements-dev.txt b/misc/requirements/requirements-dev.txt +index 9f7f5074b..f28969147 100644 +--- a/misc/requirements/requirements-dev.txt ++++ b/misc/requirements/requirements-dev.txt +@@ -1,43 +1,45 @@ + # This file is automatically generated by scripts/dev/recompile_requirements.py + +-bleach==4.1.0 ++bleach==5.0.0 + build==0.7.0 + bump2version==1.0.1 + certifi==2021.10.8 + cffi==1.15.0 + charset-normalizer==2.0.12 +-colorama==0.4.4 ++commonmark==0.9.1 + cryptography==36.0.2 + docutils==0.18.1 + github3.py==3.2.0 + hunter==3.4.3 + idna==3.3 + importlib-metadata==4.11.3 +-jeepney==0.7.1 ++jeepney==0.8.0 + keyring==23.5.0 + manhole==1.8.0 + packaging==21.3 + pep517==0.12.0 + pkginfo==1.8.2 ++ply==3.11 + pycparser==2.21 + Pygments==2.11.2 + PyJWT==2.3.0 + Pympler==1.0.1 +-pyparsing==3.0.7 ++pyparsing==3.0.8 + PyQt-builder==1.12.2 + python-dateutil==2.8.2 + readme-renderer==34.0 + requests==2.27.1 + requests-toolbelt==0.9.1 + rfc3986==2.0.0 ++rich==12.2.0 + SecretStorage==3.3.1 +-sip==6.5.1 ++sip==6.6.1 + six==1.16.0 + toml==0.10.2 + tomli==2.0.1 +-tqdm==4.63.1 +-twine==3.8.0 ++twine==4.0.0 ++typing_extensions==4.2.0 + uritemplate==4.1.1 + # urllib3==1.26.9 + webencodings==0.5.1 +-zipp==3.7.0 ++zipp==3.8.0 +diff --git a/misc/requirements/requirements-mypy.txt b/misc/requirements/requirements-mypy.txt +index d8fbba5ee..d5a266759 100644 +--- a/misc/requirements/requirements-mypy.txt ++++ b/misc/requirements/requirements-mypy.txt +@@ -1,9 +1,9 @@ + # This file is automatically generated by scripts/dev/recompile_requirements.py + + chardet==4.0.0 +-diff-cover==6.4.5 ++diff-cover==6.5.0 + importlib-metadata==4.11.3 +-importlib-resources==5.6.0 ++importlib-resources==5.7.1 + Jinja2==3.1.1 + lxml==4.8.0 + MarkupSafe==2.1.1 +@@ -13,7 +13,6 @@ pluggy==1.0.0 + Pygments==2.11.2 + PyQt5-stubs==5.15.2.0 + tomli==2.0.1 +-types-dataclasses==0.6.4 +-types-PyYAML==6.0.5 +-typing_extensions==4.1.1 +-zipp==3.7.0 ++types-PyYAML==6.0.6 ++typing_extensions==4.2.0 ++zipp==3.8.0 +diff --git a/misc/requirements/requirements-mypy.txt-raw b/misc/requirements/requirements-mypy.txt-raw +index 4baeec11f..dd00d3219 100644 +--- a/misc/requirements/requirements-mypy.txt-raw ++++ b/misc/requirements/requirements-mypy.txt-raw +@@ -3,7 +3,6 @@ lxml # For HTML reports + diff-cover + + PyQt5-stubs +-types-dataclasses + types-PyYAML + + # So stubs are available even on newer Python versions +diff --git a/misc/requirements/requirements-pyinstaller.txt b/misc/requirements/requirements-pyinstaller.txt +index d7e46505c..00a767af7 100644 +--- a/misc/requirements/requirements-pyinstaller.txt ++++ b/misc/requirements/requirements-pyinstaller.txt +@@ -1,5 +1,5 @@ + # This file is automatically generated by scripts/dev/recompile_requirements.py + + altgraph==0.17.2 +-pyinstaller==4.10 +-pyinstaller-hooks-contrib==2022.3 ++pyinstaller==5.0 ++pyinstaller-hooks-contrib==2022.4 +diff --git a/misc/requirements/requirements-pylint.txt b/misc/requirements/requirements-pylint.txt +index 3e5ebea9e..d9fd359c7 100644 +--- a/misc/requirements/requirements-pylint.txt ++++ b/misc/requirements/requirements-pylint.txt +@@ -13,18 +13,17 @@ isort==5.10.1 + lazy-object-proxy==1.7.1 + mccabe==0.7.0 + pefile==2021.9.3 +-platformdirs==2.5.1 ; python_version>="3.7" ++platformdirs==2.5.1 + pycparser==2.21 + PyJWT==2.3.0 +-pylint==2.13.3 ++pylint==2.13.5 + python-dateutil==2.8.2 + ./scripts/dev/pylint_checkers + requests==2.27.1 + six==1.16.0 + tomli==2.0.1 +-typed-ast==1.5.2 ; python_version<"3.8" +-typing_extensions==4.1.1 ++typed-ast==1.5.3 ; python_version<"3.8" ++typing_extensions==4.2.0 + uritemplate==4.1.1 + # urllib3==1.26.9 + wrapt==1.14.0 +-platformdirs==2.4.0 ; python_version=="3.6.*" +diff --git a/misc/requirements/requirements-pylint.txt-raw b/misc/requirements/requirements-pylint.txt-raw +index 52633ec1a..54e12a02a 100644 +--- a/misc/requirements/requirements-pylint.txt-raw ++++ b/misc/requirements/requirements-pylint.txt-raw +@@ -10,7 +10,3 @@ pefile + + # Already included via test requirements + #@ ignore: urllib3 +- +-# Python 3.6 +-#@ markers: platformdirs python_version>="3.7" +-#@ add: platformdirs==2.4.0 ; python_version=="3.6.*" +diff --git a/misc/requirements/requirements-pyqt-5.12.txt b/misc/requirements/requirements-pyqt-5.12.txt +index c49484a2d..499f420e5 100644 +--- a/misc/requirements/requirements-pyqt-5.12.txt ++++ b/misc/requirements/requirements-pyqt-5.12.txt +@@ -1,5 +1,5 @@ + # This file is automatically generated by scripts/dev/recompile_requirements.py + + PyQt5==5.12.3 # rq.filter: < 5.13 +-PyQt5-sip==12.9.1 ++PyQt5-sip==12.10.1 + PyQtWebEngine==5.12.1 # rq.filter: < 5.13 +diff --git a/misc/requirements/requirements-pyqt-5.13.txt b/misc/requirements/requirements-pyqt-5.13.txt +index 59d78862f..0fb28e312 100644 +--- a/misc/requirements/requirements-pyqt-5.13.txt ++++ b/misc/requirements/requirements-pyqt-5.13.txt +@@ -1,5 +1,5 @@ + # This file is automatically generated by scripts/dev/recompile_requirements.py + + PyQt5==5.13.2 # rq.filter: < 5.14 +-PyQt5-sip==12.9.1 ++PyQt5-sip==12.10.1 + PyQtWebEngine==5.13.2 # rq.filter: < 5.14 +diff --git a/misc/requirements/requirements-pyqt-5.14.txt b/misc/requirements/requirements-pyqt-5.14.txt +index ac7c0a028..953b3ded6 100644 +--- a/misc/requirements/requirements-pyqt-5.14.txt ++++ b/misc/requirements/requirements-pyqt-5.14.txt +@@ -1,5 +1,5 @@ + # This file is automatically generated by scripts/dev/recompile_requirements.py + + PyQt5==5.14.2 # rq.filter: < 5.15 +-PyQt5-sip==12.9.1 ++PyQt5-sip==12.10.1 + PyQtWebEngine==5.14.0 # rq.filter: < 5.15 +diff --git a/misc/requirements/requirements-pyqt-5.15.0.txt b/misc/requirements/requirements-pyqt-5.15.0.txt +index 6164b89ca..703a8b248 100644 +--- a/misc/requirements/requirements-pyqt-5.15.0.txt ++++ b/misc/requirements/requirements-pyqt-5.15.0.txt +@@ -1,5 +1,5 @@ + # This file is automatically generated by scripts/dev/recompile_requirements.py + + PyQt5==5.15.0 # rq.filter: == 5.15.0 +-PyQt5-sip==12.9.1 ++PyQt5-sip==12.10.1 + PyQtWebEngine==5.15.0 # rq.filter: == 5.15.0 +diff --git a/misc/requirements/requirements-pyqt-5.15.txt b/misc/requirements/requirements-pyqt-5.15.txt +index 03f016177..daa7e7136 100644 +--- a/misc/requirements/requirements-pyqt-5.15.txt ++++ b/misc/requirements/requirements-pyqt-5.15.txt +@@ -2,6 +2,6 @@ + + PyQt5==5.15.6 # rq.filter: < 5.16 + PyQt5-Qt5==5.15.2 +-PyQt5-sip==12.9.1 ++PyQt5-sip==12.10.1 + PyQtWebEngine==5.15.5 # rq.filter: < 5.16 + PyQtWebEngine-Qt5==5.15.2 +diff --git a/misc/requirements/requirements-pyqt.txt b/misc/requirements/requirements-pyqt.txt +index bf667ac97..1641b4fcd 100644 +--- a/misc/requirements/requirements-pyqt.txt ++++ b/misc/requirements/requirements-pyqt.txt +@@ -2,6 +2,6 @@ + + PyQt5==5.15.6 + PyQt5-Qt5==5.15.2 +-PyQt5-sip==12.9.1 ++PyQt5-sip==12.10.1 + PyQtWebEngine==5.15.5 + PyQtWebEngine-Qt5==5.15.2 +diff --git a/misc/requirements/requirements-pyroma.txt b/misc/requirements/requirements-pyroma.txt +index a78ba8560..19fc7f50a 100644 +--- a/misc/requirements/requirements-pyroma.txt ++++ b/misc/requirements/requirements-pyroma.txt +@@ -1,10 +1,15 @@ + # This file is automatically generated by scripts/dev/recompile_requirements.py + ++build==0.7.0 + certifi==2021.10.8 + charset-normalizer==2.0.12 + docutils==0.18.1 + idna==3.3 ++packaging==21.3 ++pep517==0.12.0 + Pygments==2.11.2 +-pyroma==3.3 ++pyparsing==3.0.8 ++pyroma==4.0 + requests==2.27.1 ++tomli==2.0.1 + urllib3==1.26.9 +diff --git a/misc/requirements/requirements-qutebrowser.txt-raw b/misc/requirements/requirements-qutebrowser.txt-raw +index b260fa16c..2025280fc 100644 +--- a/misc/requirements/requirements-qutebrowser.txt-raw ++++ b/misc/requirements/requirements-qutebrowser.txt-raw +@@ -3,7 +3,6 @@ PyYAML + + ## stdlib backports + importlib-resources +-dataclasses + + ## Optional dependencies + Pygments # For :view-source --pygments or on QtWebKit +@@ -17,15 +16,3 @@ typing_extensions # from importlib-metadata + #@ markers: importlib-resources python_version=="3.7.*" or python_version=="3.8.*" + #@ markers: importlib-metadata python_version=="3.7.*" + #@ markers: typing_extensions python_version<"3.8" +-#@ markers: dataclasses python_version<"3.7" +- +-# Python 3.6 +-#@ add: importlib-resources<5.6.0 ; python_version=="3.6.*" +-#@ add: importlib-metadata<4.9 ; python_version=="3.6.*" +-# +-#@ markers: zipp python_version>="3.7" +-#@ add: zipp<3.7 ; python_version=="3.6.*" +-#@ markers: MarkupSafe python_version>="3.7" +-#@ add: MarkupSafe<2.1.0 ; python_version=="3.6.*" +-#@ markers: Jinja2 python_version>="3.7" +-#@ add: Jinja2<3.1.0 ; python_version=="3.6.*" +diff --git a/misc/requirements/requirements-sphinx.txt b/misc/requirements/requirements-sphinx.txt +index bec429e04..be8662be6 100644 +--- a/misc/requirements/requirements-sphinx.txt ++++ b/misc/requirements/requirements-sphinx.txt +@@ -12,7 +12,7 @@ Jinja2==3.1.1 + MarkupSafe==2.1.1 + packaging==21.3 + Pygments==2.11.2 +-pyparsing==3.0.7 ++pyparsing==3.0.8 + pytz==2022.1 + requests==2.27.1 + snowballstemmer==2.2.0 +@@ -24,4 +24,4 @@ sphinxcontrib-jsmath==1.0.1 + sphinxcontrib-qthelp==1.0.3 + sphinxcontrib-serializinghtml==1.1.5 + urllib3==1.26.9 +-zipp==3.7.0 ++zipp==3.8.0 +diff --git a/misc/requirements/requirements-tests.txt b/misc/requirements/requirements-tests.txt +index 787d2791b..990b4c236 100644 +--- a/misc/requirements/requirements-tests.txt ++++ b/misc/requirements/requirements-tests.txt +@@ -1,26 +1,26 @@ + # This file is automatically generated by scripts/dev/recompile_requirements.py + + attrs==21.4.0 +-beautifulsoup4==4.10.0 ++beautifulsoup4==4.11.1 + certifi==2021.10.8 + charset-normalizer==2.0.12 + cheroot==8.6.0 +-click==8.1.0 ; python_version>="3.7" +-coverage==6.3.2 ; python_version>="3.7" ++click==8.1.2 ++coverage==6.3.2 + execnet==1.9.0 +-filelock==3.6.0 ; python_version>="3.7" +-Flask==2.1.0 ; python_version>="3.7" ++filelock==3.6.0 ++Flask==2.1.1 + glob2==0.7 + hunter==3.4.3 +-hypothesis==6.40.0 ; python_version>="3.7" +-icdiff==2.0.4 ++hypothesis==6.43.3 ++icdiff==2.0.5 + idna==3.3 +-importlib-metadata==4.11.3 ; python_version=="3.7.*" ++importlib-metadata==4.11.3 + iniconfig==1.1.1 +-itsdangerous==2.1.2 ; python_version>="3.7" +-jaraco.functools==3.5.0 ; python_version>="3.7" ++itsdangerous==2.1.2 ++jaraco.functools==3.5.0 + # Jinja2==3.1.1 +-Mako==1.2.0 ; python_version>="3.7" ++Mako==1.2.0 + manhole==1.8.0 + # MarkupSafe==2.1.1 + more-itertools==8.12.0 +@@ -32,15 +32,15 @@ pprintpp==0.4.0 + py==1.11.0 + py-cpuinfo==8.0.0 + Pygments==2.11.2 +-pyparsing==3.0.7 +-pytest==7.1.1 ; python_version>="3.7" ++pyparsing==3.0.8 ++pytest==7.1.1 + pytest-bdd==4.1.0 + pytest-benchmark==3.4.1 + pytest-cov==3.0.0 + pytest-forked==1.4.0 + pytest-icdiff==0.5 + pytest-instafail==0.4.2 +-pytest-mock==3.7.0 ; python_version>="3.7" ++pytest-mock==3.7.0 + pytest-qt==4.0.2 + pytest-repeat==0.9.1 + pytest-rerunfailures==10.2 +@@ -51,26 +51,11 @@ requests==2.27.1 + requests-file==1.5.1 + six==1.16.0 + sortedcontainers==2.4.0 +-soupsieve==2.3.1 +-tldextract==3.2.0 ; python_version>="3.7" ++soupsieve==2.3.2.post1 ++tldextract==3.2.1 + toml==0.10.2 +-tomli==2.0.1 ; python_version>="3.7" ++tomli==2.0.1 + urllib3==1.26.9 + vulture==2.3 +-Werkzeug==2.1.0 ; python_version>="3.7" +-zipp==3.7.0 ; python_version>="3.7" +-jaraco.functools<3.5 ; python_version=="3.6.*" +-tomli<2 ; python_version=="3.6.*" +-filelock==3.4.1 ; python_version=="3.6.*" +-hypothesis<6.32 ; python_version=="3.6.*" +-coverage<6.3 ; python_version=="3.6.*" +-pytest-mock<3.7 ; python_version=="3.6.*" +-itsdangerous<2.1.0 ; python_version=="3.6.*" +-tldextract<3.2.0 ; python_version=="3.6.*" +-Mako<1.2.0 ; python_version=="3.6.*" +-pytest<7.1.0 ; python_version=="3.6.*" +-click<8.1.0 ; python_version=="3.6.*" +-Flask<2.1.0 ; python_version=="3.6.*" +-Werkzeug<2.1.0 ; python_version=="3.6.*" +-zipp<3.7 ; python_version=="3.6.*" +-importlib-metadata<4.9 ; python_version=="3.6.*" ++Werkzeug==2.1.1 ++zipp==3.8.0 +diff --git a/misc/requirements/requirements-tests.txt-raw b/misc/requirements/requirements-tests.txt-raw +index 6338a1a97..5586a86ef 100644 +--- a/misc/requirements/requirements-tests.txt-raw ++++ b/misc/requirements/requirements-tests.txt-raw +@@ -35,35 +35,3 @@ pytest-icdiff + tldextract + + #@ ignore: Jinja2, MarkupSafe, colorama +- +-# Python 3.6 +-#@ markers: jaraco.functools python_version>="3.7" +-#@ add: jaraco.functools<3.5 ; python_version=="3.6.*" +-#@ markers: tomli python_version>="3.7" +-#@ add: tomli<2 ; python_version=="3.6.*" +-#@ markers: filelock python_version>="3.7" +-#@ add: filelock==3.4.1 ; python_version=="3.6.*" +-#@ markers: hypothesis python_version>="3.7" +-#@ add: hypothesis<6.32 ; python_version=="3.6.*" +-#@ markers: coverage python_version>="3.7" +-#@ add: coverage<6.3 ; python_version=="3.6.*" +-#@ markers: pytest-mock python_version>="3.7" +-#@ add: pytest-mock<3.7 ; python_version=="3.6.*" +-#@ markers: itsdangerous python_version>="3.7" +-#@ add: itsdangerous<2.1.0 ; python_version=="3.6.*" +-#@ markers: tldextract python_version>="3.7" +-#@ add: tldextract<3.2.0 ; python_version=="3.6.*" +-#@ markers: Mako python_version>="3.7" +-#@ add: Mako<1.2.0 ; python_version=="3.6.*" +-#@ markers: pytest python_version>="3.7" +-#@ add: pytest<7.1.0 ; python_version=="3.6.*" +-#@ markers: click python_version>="3.7" +-#@ add: click<8.1.0 ; python_version=="3.6.*" +-#@ markers: Flask python_version>="3.7" +-#@ add: Flask<2.1.0 ; python_version=="3.6.*" +-#@ markers: Werkzeug python_version>="3.7" +-#@ add: Werkzeug<2.1.0 ; python_version=="3.6.*" +-#@ markers: zipp python_version>="3.7" +-#@ add: zipp<3.7 ; python_version=="3.6.*" +-#@ markers: importlib-metadata python_version=="3.7.*" +-#@ add: importlib-metadata<4.9 ; python_version=="3.6.*" +diff --git a/misc/requirements/requirements-tox.txt b/misc/requirements/requirements-tox.txt +index a87519740..57b098d01 100644 +--- a/misc/requirements/requirements-tox.txt ++++ b/misc/requirements/requirements-tox.txt +@@ -1,20 +1,16 @@ + # This file is automatically generated by scripts/dev/recompile_requirements.py + + distlib==0.3.4 +-filelock==3.6.0 ; python_version>="3.7" ++filelock==3.6.0 + packaging==21.3 +-pip==22.0.4 ; python_version>="3.7" +-platformdirs==2.5.1 ; python_version>="3.7" ++pip==22.0.4 ++platformdirs==2.5.1 + pluggy==1.0.0 + py==1.11.0 +-pyparsing==3.0.7 +-setuptools==61.2.0 ; python_version>="3.7" ++pyparsing==3.0.8 ++setuptools==62.1.0 + six==1.16.0 + toml==0.10.2 +-tox==3.24.5 +-virtualenv==20.14.0 ++tox==3.25.0 ++virtualenv==20.14.1 + wheel==0.37.1 +-setuptools<60 ; python_version=="3.6.*" +-filelock==3.4.1 ; python_version=="3.6.*" +-platformdirs==2.4.0 ; python_version=="3.6.*" +-pip==21.3.1 ; python_version=="3.6.*" +diff --git a/misc/requirements/requirements-tox.txt-raw b/misc/requirements/requirements-tox.txt-raw +index 2a9f30c5a..27d58e1f4 100644 +--- a/misc/requirements/requirements-tox.txt-raw ++++ b/misc/requirements/requirements-tox.txt-raw +@@ -1,12 +1,2 @@ + tox + wheel +- +-# Python 3.6 +-#@ markers: setuptools python_version>="3.7" +-#@ add: setuptools<60 ; python_version=="3.6.*" +-#@ markers: filelock python_version>="3.7" +-#@ add: filelock==3.4.1 ; python_version=="3.6.*" +-#@ markers: platformdirs python_version>="3.7" +-#@ add: platformdirs==2.4.0 ; python_version=="3.6.*" +-#@ markers: pip python_version>="3.7" +-#@ add: pip==21.3.1 ; python_version=="3.6.*" +diff --git a/misc/userscripts/qute-bitwarden b/misc/userscripts/qute-bitwarden +index a0eedeae3..a30f734f2 100755 +--- a/misc/userscripts/qute-bitwarden ++++ b/misc/userscripts/qute-bitwarden +@@ -103,7 +103,7 @@ def qute_command(command): + def ask_password(password_prompt_invocation): + process = subprocess.run( + shlex.split(password_prompt_invocation), +- universal_newlines=True, ++ text=True, + stdout=subprocess.PIPE, + ) + if process.returncode > 0: +@@ -111,7 +111,7 @@ def ask_password(password_prompt_invocation): + master_pass = process.stdout.strip() + return subprocess.check_output( + ['bw', 'unlock', '--raw', master_pass], +- universal_newlines=True, ++ text=True, + ).strip() + + +@@ -122,7 +122,7 @@ def get_session_key(auto_lock, password_prompt_invocation): + else: + process = subprocess.run( + ['keyctl', 'request', 'user', 'bw_session'], +- universal_newlines=True, ++ text=True, + stdout=subprocess.PIPE, + ) + key_id = process.stdout.strip() +@@ -132,14 +132,14 @@ def get_session_key(auto_lock, password_prompt_invocation): + raise Exception('Could not unlock vault') + key_id = subprocess.check_output( + ['keyctl', 'add', 'user', 'bw_session', session, '@u'], +- universal_newlines=True, ++ text=True, + ).strip() + + if auto_lock > 0: + subprocess.call(['keyctl', 'timeout', str(key_id), str(auto_lock)]) + return subprocess.check_output( + ['keyctl', 'pipe', str(key_id)], +- universal_newlines=True, ++ text=True, + ).strip() + + +@@ -147,8 +147,7 @@ def pass_(domain, encoding, auto_lock, password_prompt_invocation): + session_key = get_session_key(auto_lock, password_prompt_invocation) + process = subprocess.run( + ['bw', 'list', 'items', '--session', session_key, '--url', domain], +- stdout=subprocess.PIPE, +- stderr=subprocess.PIPE, ++ capture_output=True, + ) + + err = process.stderr.decode(encoding).strip() +@@ -168,8 +167,7 @@ def get_totp_code(selection_id, domain_name, encoding, auto_lock, password_promp + session_key = get_session_key(auto_lock, password_prompt_invocation) + process = subprocess.run( + ['bw', 'get', 'totp', '--session', session_key, selection_id], +- stdout=subprocess.PIPE, +- stderr=subprocess.PIPE, ++ capture_output=True, + ) + + err = process.stderr.decode(encoding).strip() +@@ -196,7 +194,7 @@ def dmenu(items, invocation, encoding): + def fake_key_raw(text): + for character in text: + # Escape all characters by default, space requires special handling +- sequence = '" "' if character == ' ' else '\{}'.format(character) ++ sequence = '" "' if character == ' ' else r'\{}'.format(character) + qute_command('fake-key {}'.format(sequence)) + + +diff --git a/misc/userscripts/qute-lastpass b/misc/userscripts/qute-lastpass +index edb48dfdc..e99a51a0f 100755 +--- a/misc/userscripts/qute-lastpass ++++ b/misc/userscripts/qute-lastpass +@@ -86,7 +86,7 @@ def qute_command(command): + def pass_(domain, encoding): + domain = re.escape(domain) + args = ['lpass', 'show', '-x', '-j', '-G', '\\b{:s}'.format(domain)] +- process = subprocess.run(args, stdout=subprocess.PIPE, stderr=subprocess.PIPE) ++ process = subprocess.run(args, capture_output=True) + + candidates = json.loads(process.stdout.decode(encoding).strip() or '[]') + err = process.stderr.decode(encoding).strip() +diff --git a/misc/userscripts/qute-pass b/misc/userscripts/qute-pass +index f410802c8..573644dc4 100755 +--- a/misc/userscripts/qute-pass ++++ b/misc/userscripts/qute-pass +@@ -188,7 +188,7 @@ def dmenu(items, invocation): + def fake_key_raw(text): + for character in text: + # Escape all characters by default, space requires special handling +- sequence = '" "' if character == ' ' else '\{}'.format(character) ++ sequence = '" "' if character == ' ' else r'\{}'.format(character) + qute_command('fake-key {}'.format(sequence)) + + +diff --git a/misc/userscripts/readability b/misc/userscripts/readability +index a6a6f2d52..19b687939 100755 +--- a/misc/userscripts/readability ++++ b/misc/userscripts/readability +@@ -10,7 +10,6 @@ + # Usage: + # :spawn --userscript readability + # +-from __future__ import absolute_import + import codecs, os + + tmpfile = os.path.join( +diff --git a/qutebrowser/__init__.py b/qutebrowser/__init__.py +index 94cadc7eb..df320f996 100644 +--- a/qutebrowser/__init__.py ++++ b/qutebrowser/__init__.py +@@ -17,7 +17,7 @@ + # You should have received a copy of the GNU General Public License + # along with qutebrowser. If not, see . + +-"""A keyboard-driven, vim-like browser based on PyQt5.""" ++"""A keyboard-driven, vim-like browser based on Python and Qt.""" + + import os.path + +@@ -28,6 +28,6 @@ __maintainer__ = __author__ + __email__ = "mail@qutebrowser.org" + __version__ = "2.5.2" + __version_info__ = tuple(int(part) for part in __version__.split('.')) +-__description__ = "A keyboard-driven, vim-like browser based on PyQt5." ++__description__ = "A keyboard-driven, vim-like browser based on Python and Qt." + + basedir = os.path.dirname(os.path.realpath(__file__)) +diff --git a/qutebrowser/app.py b/qutebrowser/app.py +index 1ab28e8d0..c046475b5 100644 +--- a/qutebrowser/app.py ++++ b/qutebrowser/app.py +@@ -51,7 +51,6 @@ from PyQt5.QtGui import QDesktopServices, QPixmap, QIcon + from PyQt5.QtCore import pyqtSlot, QUrl, QObject, QEvent, pyqtSignal, Qt + + import qutebrowser +-import qutebrowser.resources + from qutebrowser.commands import runners + from qutebrowser.config import (config, websettings, configfiles, configinit, + qtargs) +@@ -182,8 +181,9 @@ def _init_icon(): + """Initialize the icon of qutebrowser.""" + fallback_icon = QIcon() + for size in [16, 24, 32, 48, 64, 96, 128, 256, 512]: +- filename = ':/icons/qutebrowser-{size}x{size}.png'.format(size=size) +- pixmap = QPixmap(filename) ++ filename = 'icons/qutebrowser-{size}x{size}.png'.format(size=size) ++ pixmap = QPixmap() ++ pixmap.loadFromData(resources.read_file_binary(filename)) + if pixmap.isNull(): + log.init.warning("Failed to load {}".format(filename)) + else: +diff --git a/qutebrowser/browser/browsertab.py b/qutebrowser/browser/browsertab.py +index 661c5f68b..3d3a2ed27 100644 +--- a/qutebrowser/browser/browsertab.py ++++ b/qutebrowser/browser/browsertab.py +@@ -51,6 +51,8 @@ if TYPE_CHECKING: + from qutebrowser.browser import webelem + from qutebrowser.browser.inspector import AbstractWebInspector + ++from qutebrowser.mainwindow.treetabwidget import TreeTabWidget ++from qutebrowser.misc.notree import Node + + tab_id_gen = itertools.count(0) + +@@ -969,6 +971,11 @@ class AbstractTab(QWidget): + self, parent=self) + self.backend: Optional[usertypes.Backend] = None + ++ if parent and isinstance(parent, TreeTabWidget): ++ self.node: AbstractTab = Node(self, parent=parent.tree_root) ++ else: ++ self.node: AbstractTab = Node(self, parent=None) ++ + # If true, this tab has been requested to be removed (or is removed). + self.pending_removal = False + self.shutting_down.connect(functools.partial( +diff --git a/qutebrowser/browser/commands.py b/qutebrowser/browser/commands.py +index 5e1c67224..399ec5714 100644 +--- a/qutebrowser/browser/commands.py ++++ b/qutebrowser/browser/commands.py +@@ -23,6 +23,7 @@ import html + import os.path + import shlex + import functools ++import urllib.parse + from typing import cast, Callable, Dict, Union + + from PyQt5.QtWidgets import QApplication, QTabBar +@@ -37,7 +38,7 @@ from qutebrowser.keyinput import modeman, keyutils + from qutebrowser.utils import (message, usertypes, log, qtutils, urlutils, + objreg, utils, standarddir, debug) + from qutebrowser.utils.usertypes import KeyMode +-from qutebrowser.misc import editor, guiprocess, objects ++from qutebrowser.misc import editor, guiprocess, objects, notree + from qutebrowser.completion.models import urlmodel, miscmodels + from qutebrowser.mainwindow import mainwindow, windowundo + +@@ -111,7 +112,7 @@ class CommandDispatcher: + return widget + + def _open(self, url, tab=False, background=False, window=False, +- related=False, private=None): ++ related=False, sibling=False, private=None): + """Helper function to open a page. + + Args: +@@ -121,6 +122,7 @@ class CommandDispatcher: + window: Whether to open in a new window + private: If opening a new window, open it in private browsing mode. + If not given, inherit the current window's mode. ++ sibling: Open tab in a sibling node of the currently focused tab. + """ + urlutils.raise_cmdexc_if_invalid(url) + tabbed_browser = self._tabbed_browser +@@ -131,10 +133,16 @@ class CommandDispatcher: + if window or private: + tabbed_browser = self._new_tabbed_browser(private) + tabbed_browser.tabopen(url) +- elif tab: +- tabbed_browser.tabopen(url, background=False, related=related) +- elif background: +- tabbed_browser.tabopen(url, background=True, related=related) ++ elif tab or background: ++ if tabbed_browser.is_treetabbedbrowser: ++ tabbed_browser.tabopen(url, background=background, ++ related=related, sibling=sibling) ++ elif sibling: ++ raise cmdutils.CommandError("--sibling flag only works with \ ++ tree-tab enabled") ++ else: ++ tabbed_browser.tabopen(url, background=background, ++ related=related) + else: + widget = self._current_widget() + widget.load_url(url) +@@ -216,7 +224,8 @@ class CommandDispatcher: + "{!r}!".format(conf_selection)) + return None + +- def _tab_close(self, tab, prev=False, next_=False, opposite=False): ++ def _tab_close(self, tab, prev=False, next_=False, ++ opposite=False, new_undo=True): + """Helper function for tab_close be able to handle message.async. + + Args: +@@ -232,17 +241,17 @@ class CommandDispatcher: + opposite) + + if selection_override is None: +- self._tabbed_browser.close_tab(tab) ++ self._tabbed_browser.close_tab(tab, new_undo=new_undo) + else: + old_selection_behavior = tabbar.selectionBehaviorOnRemove() + tabbar.setSelectionBehaviorOnRemove(selection_override) +- self._tabbed_browser.close_tab(tab) ++ self._tabbed_browser.close_tab(tab, new_undo=new_undo) + tabbar.setSelectionBehaviorOnRemove(old_selection_behavior) + + @cmdutils.register(instance='command-dispatcher', scope='window') + @cmdutils.argument('count', value=cmdutils.Value.count) + def tab_close(self, prev=False, next_=False, opposite=False, +- force=False, count=None): ++ force=False, count=None, recursive=False): + """Close the current/[count]th tab. + + Args: +@@ -251,15 +260,37 @@ class CommandDispatcher: + opposite: Force selecting the tab in the opposite direction of + what's configured in 'tabs.select_on_remove'. + force: Avoid confirmation for pinned tabs. ++ recursive: Close all descendents (tree-tabs) as well as current tab + count: The tab index to close, or None + """ + tab = self._cntwidget(count) ++ tabbed_browser = self._tabbed_browser + if tab is None: + return +- close = functools.partial(self._tab_close, tab, prev, +- next_, opposite) +- +- self._tabbed_browser.tab_close_prompt_if_pinned(tab, force, close) ++ if (tabbed_browser.is_treetabbedbrowser and recursive and not ++ tab.node.collapsed): ++ # if collapsed, recursive is the same as normal close ++ new_undo = True # only for first one ++ for descendent in tab.node.traverse(notree.TraverseOrder.POST_R, ++ True): ++ if self._tabbed_browser.widget.indexOf(descendent.value) > -1: ++ close = functools.partial(self._tab_close, ++ descendent.value, prev, next_, ++ opposite, new_undo) ++ tabbed_browser.tab_close_prompt_if_pinned(tab, force, ++ close) ++ new_undo = False ++ else: ++ tab = descendent.value ++ tab.private_api.shutdown() ++ tab.deleteLater() ++ tab.layout().unwrap() ++ else: ++ # this also applied to closing collapsed tabs ++ # logic for that is in TreeTabbedBrowser ++ close = functools.partial(self._tab_close, tab, prev, ++ next_, opposite) ++ tabbed_browser.tab_close_prompt_if_pinned(tab, force, close) + + @cmdutils.register(instance='command-dispatcher', scope='window', + name='tab-pin') +@@ -284,8 +315,9 @@ class CommandDispatcher: + @cmdutils.register(instance='command-dispatcher', name='open', + maxsplit=0, scope='window') + @cmdutils.argument('url', completion=urlmodel.url) ++ @cmdutils.argument('sibling', flag='S') + @cmdutils.argument('count', value=cmdutils.Value.count) +- def openurl(self, url=None, related=False, ++ def openurl(self, url=None, related=False, sibling=False, + bg=False, tab=False, window=False, count=None, secure=False, + private=False): + """Open a URL in the current/[count]th tab. +@@ -299,6 +331,8 @@ class CommandDispatcher: + window: Open in a new window. + related: If opening a new tab, position the tab as related to the + current one (like clicking on a link). ++ sibling: If opening a new tab, position the as a sibling of the ++ current one. + count: The tab index to open the URL in, or None. + secure: Force HTTPS. + private: Open a new window in private browsing mode. +@@ -317,8 +351,8 @@ class CommandDispatcher: + bg = True + + if tab or bg or window or private: +- self._open(cur_url, tab, bg, window, related=related, +- private=private) ++ self._open(cur_url, tab, bg, window, private=private, ++ related=related, sibling=sibling) + else: + curtab = self._cntwidget(count) + if curtab is None: +@@ -454,11 +488,40 @@ class CommandDispatcher: + if not keep: + tabbed_browser.close_tab(tab, add_undo=False, transfer=True) + ++ def _tree_tab_give(self, tabbed_browser, keep): ++ """Helper function to simplify tab-give.""" ++ uid_map = {1: 1} ++ traversed = list(self._current_widget().node.traverse()) ++ # first pass: open tabs ++ for node in traversed: ++ tab = tabbed_browser.tabopen(node.value.url()) ++ ++ uid_map[node.uid] = tab.node.uid ++ ++ # second pass: copy tree structure over ++ newroot = tabbed_browser.widget.tree_root ++ oldroot = self._tabbed_browser.widget.tree_root ++ for node in traversed: ++ if node.parent is not oldroot: ++ uid = uid_map[node.uid] ++ new_node = newroot.get_descendent_by_uid(uid) ++ parent_uid = uid_map[node.parent.uid] ++ new_parent = newroot.get_descendent_by_uid(parent_uid) ++ new_node.parent = new_parent ++ ++ # third pass: remove tabs from old window ++ if not keep: ++ for _node in traversed: ++ self._tabbed_browser.close_tab(self._current_widget(), ++ add_undo=False, ++ transfer=True) ++ + @cmdutils.register(instance='command-dispatcher', scope='window') + @cmdutils.argument('win_id', completion=miscmodels.window) + @cmdutils.argument('count', value=cmdutils.Value.count) + def tab_give(self, win_id: int = None, keep: bool = False, +- count: int = None, private: bool = False) -> None: ++ count: int = None, private: bool = False, ++ recursive: bool = False) -> None: + """Give the current tab to a new or existing window if win_id given. + + If no win_id is given, the tab will get detached into a new window. +@@ -467,6 +530,7 @@ class CommandDispatcher: + win_id: The window ID of the window to give the current tab to. + keep: If given, keep the old tab around. + count: Overrides win_id (index starts at 1 for win_id=0). ++ recursive: Whether to move the entire subtree starting at the tab. + private: If the tab should be detached into a private instance. + """ + if config.val.tabs.tabs_are_windows: +@@ -498,11 +562,14 @@ class CommandDispatcher: + raise cmdutils.CommandError( + "The window with id {} is not private".format(win_id)) + +- tabbed_browser.tabopen(self._current_url()) +- if not keep: +- self._tabbed_browser.close_tab(self._current_widget(), +- add_undo=False, +- transfer=True) ++ if recursive and tabbed_browser.is_treetabbedbrowser: ++ self._tree_tab_give(tabbed_browser, keep) ++ else: ++ tabbed_browser.tabopen(self._current_url()) ++ if not keep: ++ self._tabbed_browser.close_tab(self._current_widget(), ++ add_undo=False, ++ transfer=True) + + def _back_forward(self, tab, bg, window, count, forward, index=None): + """Helper function for :back/:forward.""" +@@ -844,43 +911,79 @@ class CommandDispatcher: + + @cmdutils.register(instance='command-dispatcher', scope='window') + @cmdutils.argument('count', value=cmdutils.Value.count) +- def tab_prev(self, count=1): ++ def tab_prev(self, count=1, sibling=False): + """Switch to the previous tab, or switch [count] tabs back. + + Args: + count: How many tabs to switch back. ++ sibling: Whether to focus the previous tree sibling. + """ + if self._count() == 0: + # Running :tab-prev after last tab was closed + # See https://github.com/qutebrowser/qutebrowser/issues/1448 + return +- newidx = self._current_index() - count +- if newidx >= 0: +- self._set_current_index(newidx) +- elif config.val.tabs.wrap: +- self._set_current_index(newidx % self._count()) ++ if sibling and self._tabbed_browser.is_treetabbedbrowser: ++ cur_node = self._current_widget().node ++ siblings = list(cur_node.parent.children) ++ ++ if siblings and len(siblings) > 1: ++ node_idx = siblings.index(cur_node) ++ new_idx = node_idx - count ++ if new_idx >= 0 or config.val.tabs.wrap: ++ target_node = siblings[(node_idx-count) % len(siblings)] ++ idx = self._tabbed_browser.widget.indexOf( ++ target_node.value) ++ self._set_current_index(idx) ++ else: ++ log.webview.debug("First sibling") ++ else: ++ log.webview.debug("No siblings") + else: +- log.webview.debug("First tab") ++ newidx = self._current_index() - count ++ if newidx >= 0: ++ self._set_current_index(newidx) ++ elif config.val.tabs.wrap: ++ self._set_current_index(newidx % self._count()) ++ else: ++ log.webview.debug("First tab") + + @cmdutils.register(instance='command-dispatcher', scope='window') + @cmdutils.argument('count', value=cmdutils.Value.count) +- def tab_next(self, count=1): ++ def tab_next(self, count=1, sibling=False): + """Switch to the next tab, or switch [count] tabs forward. + + Args: + count: How many tabs to switch forward. ++ sibling: Whether to focus the next tree sibling. + """ + if self._count() == 0: + # Running :tab-next after last tab was closed + # See https://github.com/qutebrowser/qutebrowser/issues/1448 + return +- newidx = self._current_index() + count +- if newidx < self._count(): +- self._set_current_index(newidx) +- elif config.val.tabs.wrap: +- self._set_current_index(newidx % self._count()) ++ if sibling and self._tabbed_browser.is_treetabbedbrowser: ++ cur_node = self._current_widget().node ++ siblings = list(cur_node.parent.children) ++ ++ if siblings and len(siblings) > 1: ++ node_idx = siblings.index(cur_node) ++ new_idx = node_idx + count ++ if new_idx < len(siblings) or config.val.tabs.wrap: ++ target_node = siblings[new_idx % len(siblings)] ++ idx = self._tabbed_browser.widget.indexOf( ++ target_node.value) ++ self._set_current_index(idx) ++ else: ++ log.webview.debug("Last sibling") ++ else: ++ log.webview.debug("No siblings") + else: +- log.webview.debug("Last tab") ++ newidx = self._current_index() + count ++ if newidx < self._count(): ++ self._set_current_index(newidx) ++ elif config.val.tabs.wrap: ++ self._set_current_index(newidx % self._count()) ++ else: ++ log.webview.debug("Last tab") + + def _resolve_tab_index(self, index): + """Resolve a tab index to the tabbedbrowser and tab. +@@ -959,7 +1062,8 @@ class CommandDispatcher: + tabbed_browser.widget.setCurrentWidget(tab) + + @cmdutils.register(instance='command-dispatcher', scope='window') +- @cmdutils.argument('index', choices=['last', 'stack-next', 'stack-prev'], ++ @cmdutils.argument('index', choices=['last', 'parent', ++ 'stack-next', 'stack-prev'], + completion=miscmodels.tab_focus) + @cmdutils.argument('count', value=cmdutils.Value.count) + def tab_focus(self, index: Union[str, int] = None, +@@ -970,11 +1074,15 @@ class CommandDispatcher: + If both are given, use count. + + Args: +- index: The tab index to focus, starting with 1. The special value +- `last` focuses the last focused tab (regardless of count), +- and `stack-prev`/`stack-next` traverse a stack of visited +- tabs. Negative indices count from the end, such that -1 is +- the last tab. ++ index: The tab index to focus, starting with 1. Negative indices ++ count from the end, such that -1 is the last tab. Special ++ values are: ++ - `last` focuses the last focused tab (regardless of ++ count). ++ - `parent` focuses the parent tab in the tree hierarchy, ++ if `tabs.tree_tabs` is enabled. ++ - `stack-prev`/`stack-next` traverse a stack of visited ++ tabs. + count: The tab index to focus, starting with 1. + no_last: Whether to avoid focusing last tab if already focused. + """ +@@ -984,6 +1092,22 @@ class CommandDispatcher: + assert isinstance(index, str) + self._tab_focus_stack(index) + return ++ elif index == 'parent' and self._tabbed_browser.is_treetabbedbrowser: ++ node = self._current_widget().node ++ path = node.path ++ if count: ++ if count < len(path): ++ path_idx = 0 - count - 1 # path[-1] is node, so shift by 1 ++ else: ++ path_idx = 1 # first non-root node ++ else: ++ path_idx = -2 # immediate parent (path[-1] is node) ++ ++ target_node = path[path_idx] ++ if node is target_node or target_node.value is None: ++ raise cmdutils.CommandError("Tab has no parent! ") ++ target_tab = target_node.value ++ index = self._tabbed_browser.widget.indexOf(target_tab) + 1 + elif index is None: + message.warning( + "Using :tab-focus without count is deprecated, " +@@ -1023,17 +1147,31 @@ class CommandDispatcher: + If moving absolutely: New position (default: 0). This + overrides the index argument, if given. + """ ++ # pylint: disable=invalid-unary-operand-type ++ # https://github.com/PyCQA/pylint/issues/1472 + if index in ["+", "-"]: + # relative moving + new_idx = self._current_index() + delta = 1 if count is None else count +- if index == "-": +- new_idx -= delta +- elif index == "+": # pragma: no branch +- new_idx += delta + +- if config.val.tabs.wrap: +- new_idx %= self._count() ++ if self._tabbed_browser.is_treetabbedbrowser: ++ node = self._current_widget().node ++ parent = node.parent ++ siblings = list(parent.children) ++ ++ if len(siblings) <= 1: ++ return ++ rel_idx = siblings.index(node) ++ rel_idx += delta if index == '+' else - delta ++ rel_idx %= len(siblings) ++ new_idx = self._tabbed_browser.widget.indexOf( ++ siblings[rel_idx].value) ++ ++ else: ++ new_idx += delta if index == '+' else - delta ++ ++ if config.val.tabs.wrap: ++ new_idx %= self._count() + else: + # pylint: disable=else-if-used + # absolute moving +@@ -1056,7 +1194,34 @@ class CommandDispatcher: + cur_idx = self._current_index() + cmdutils.check_overflow(cur_idx, 'int') + cmdutils.check_overflow(new_idx, 'int') +- self._tabbed_browser.widget.tabBar().moveTab(cur_idx, new_idx) ++ ++ if self._tabbed_browser.is_treetabbedbrowser: ++ # self._tree_tab_move(new_idx) ++ new_idx += 1 # tree-tabs indexes start at 1 (0 is hidden root tab) ++ tab = self._current_widget() ++ ++ # traverse order is the same as display order ++ # so indexing works correctly ++ tree_root = self._tabbed_browser.widget.tree_root ++ tabs = list(tree_root.traverse(render_collapsed=False)) ++ target_node = tabs[new_idx] ++ if tab.node in target_node.path: ++ raise cmdutils.CommandError("Can't move tab to a descendent" ++ " of itself") ++ ++ new_parent = target_node.parent ++ # we need index relative to parent for correct placement ++ dest_tab = tabs[new_idx] ++ new_idx_relative = new_parent.children.index(dest_tab) ++ ++ tab.node.parent = None # avoid duplicate errors ++ siblings = list(new_parent.children) ++ siblings.insert(new_idx_relative, tab.node) ++ new_parent.children = siblings ++ ++ self._tabbed_browser.widget.tree_tab_update() ++ else: ++ self._tabbed_browser.widget.tabBar().moveTab(cur_idx, new_idx) + + @cmdutils.register(instance='command-dispatcher', scope='window', + maxsplit=0, no_replace_variables=True) +@@ -1874,3 +2039,123 @@ class CommandDispatcher: + + log.misc.debug('state before fullscreen: {}'.format( + debug.qflags_key(Qt, window.state_before_fullscreen))) ++ ++ @cmdutils.register(instance='command-dispatcher', scope='window', ++ tree_tab=True) ++ @cmdutils.argument('count', value=cmdutils.Value.count) ++ def tree_tab_promote(self, count=1): ++ """Promote a tab so it becomes next sibling of its parent. ++ ++ Observes tabs.new_position.tree.promote in positioning the tab among ++ new siblings. ++ ++ Args: ++ count: How many levels the tabs should be promoted to ++ """ ++ if not self._tabbed_browser.is_treetabbedbrowser: ++ raise cmdutils.CommandError('Tree-tabs are disabled') ++ config_position = config.val.tabs.new_position.tree.promote ++ try: ++ self._current_widget().node.promote(count, config_position) ++ except notree.TreeError: ++ raise cmdutils.CommandError('Tab has no parent!') ++ finally: ++ self._tabbed_browser.widget.tree_tab_update() ++ ++ @cmdutils.register(instance='command-dispatcher', scope='window', ++ tree_tab=True) ++ def tree_tab_demote(self): ++ """Demote a tab making it children of its previous adjacent sibling. ++ ++ Observes tabs.new_position.tree.demote in positioning the tab among new ++ siblings. ++ """ ++ if not self._tabbed_browser.is_treetabbedbrowser: ++ raise cmdutils.CommandError('Tree-tabs are disabled') ++ cur_node = self._current_widget().node ++ ++ config_position = config.val.tabs.new_position.tree.demote ++ try: ++ cur_node.demote(config_position) ++ except notree.TreeError: ++ raise cmdutils.CommandError('Tab has no previous sibling!') ++ finally: ++ self._tabbed_browser.widget.tree_tab_update() ++ ++ @cmdutils.register(instance='command-dispatcher', scope='window', ++ tree_tab=True) ++ @cmdutils.argument('count', value=cmdutils.Value.count) ++ def tree_tab_toggle_hide(self, count=None): ++ """If the current tab's children are shown hide them, and vice-versa. ++ ++ This toggles the current tab's node's `collapsed` attribute. ++ ++ Args: ++ count: Which tab to collapse ++ """ ++ if not self._tabbed_browser.is_treetabbedbrowser: ++ raise cmdutils.CommandError('Tree-tabs are disabled') ++ tab = self._cntwidget(count) ++ if not tab.node.children: ++ return ++ tab.node.collapsed = not tab.node.collapsed ++ ++ self._tabbed_browser.widget.tree_tab_update() ++ ++ @cmdutils.register(instance='command-dispatcher', scope='window', ++ tree_tab=True) ++ @cmdutils.argument('count', value=cmdutils.Value.count) ++ def tree_tab_cycle_hide(self, count=1): ++ """Hides levels of descendents: children, grandchildren, and so on. ++ ++ Args: ++ count: How many levels to hide. ++ """ ++ if not self._tabbed_browser.is_treetabbedbrowser: ++ raise cmdutils.CommandError('Tree-tabs are disabled') ++ while count > 0: ++ tab = self._current_widget() ++ self._tabbed_browser.cycle_hide_tab(tab.node) ++ count -= 1 ++ ++ self._tabbed_browser.widget.tree_tab_update() ++ ++ @cmdutils.register(instance='command-dispatcher', scope='window', ++ tree_tab=True) ++ def tree_tab_create_group(self, *name, related=False, ++ background=False): ++ """Wrapper around :open qute://treegroup/name. Correctly escapes names. ++ ++ Example: `:tree-tab-create-group Foo Bar` calls ++ `:open qute://treegroup/Foo%20Bar` ++ ++ Args: ++ name: Name of the group to create ++ related: whether to open as a child of current tab or under root ++ background: whether to open in a background tab ++ """ ++ title = ' '.join(name) ++ path = urllib.parse.quote(title) ++ if background: ++ self.openurl('qute://treegroup/' + path, related=related, bg=True) ++ else: ++ self.openurl('qute://treegroup/' + path, related=related, tab=True) ++ ++ @cmdutils.register(instance='command-dispatcher', scope='window', ++ tree_tab=True) ++ @cmdutils.argument('count', value=cmdutils.Value.count) ++ def tree_tab_suspend_children(self, count=None): ++ """Suspends all descendent of a tab to reduce memory usage. ++ ++ Args: ++ count: Target tab. ++ """ ++ tab = self._cntwidget(count) ++ for descendent in tab.node.traverse(): ++ cur_tab = descendent.value ++ if cur_tab and cur_tab is not tab: ++ cur_url = cur_tab.url().url() ++ if not cur_url.startswith("qute://"): ++ new_url = self._parse_url( ++ "qute://back/#" + cur_tab.title()) ++ cur_tab.load_url(new_url) +diff --git a/qutebrowser/browser/qutescheme.py b/qutebrowser/browser/qutescheme.py +index 68e36d249..6bc8cfef0 100644 +--- a/qutebrowser/browser/qutescheme.py ++++ b/qutebrowser/browser/qutescheme.py +@@ -587,6 +587,18 @@ def qute_warning(url: QUrl) -> _HandlerRet: + return 'text/html', src + + ++@add_handler('treegroup') ++def qute_treegroup(url): ++ """Handler for qute://treegroup/x. ++ ++ Makes an empty tab with a title, for use with tree-tabs as a grouping ++ feature. ++ """ ++ src = jinja.render('tree_group.html', ++ title=url.path()[1:]) ++ return 'text/html', src ++ ++ + @add_handler('resource') + def qute_resource(url: QUrl) -> _HandlerRet: + """Handler for qute://resource.""" +diff --git a/qutebrowser/browser/webengine/notification.py b/qutebrowser/browser/webengine/notification.py +index 9607e3eab..92c532db8 100644 +--- a/qutebrowser/browser/webengine/notification.py ++++ b/qutebrowser/browser/webengine/notification.py +@@ -65,7 +65,9 @@ if TYPE_CHECKING: + + from qutebrowser.config import config + from qutebrowser.misc import objects +-from qutebrowser.utils import qtutils, log, utils, debug, message, version, objreg ++from qutebrowser.utils import ( ++ qtutils, log, utils, debug, message, version, objreg, resources, ++) + from qutebrowser.qt import sip + + +@@ -992,8 +994,8 @@ class DBusNotificationAdapter(AbstractNotificationAdapter): + + icon = qt_notification.icon() + if icon.isNull(): +- filename = ':/icons/qutebrowser-64x64.png' +- icon = QImage(filename) ++ filename = 'icons/qutebrowser-64x64.png' ++ icon = QImage.fromData(resources.read_file_binary(filename)) + + key = self._quirks.icon_key or "image-data" + data = self._convert_image(icon) +diff --git a/qutebrowser/browser/webkit/http.py b/qutebrowser/browser/webkit/http.py +index f36ca14ec..a38cd358a 100644 +--- a/qutebrowser/browser/webkit/http.py ++++ b/qutebrowser/browser/webkit/http.py +@@ -91,6 +91,7 @@ class ContentDisposition: + except IndexError: # pragma: no cover + # WORKAROUND for https://github.com/python/cpython/issues/81672 + # Fixed in Python 3.7.5 and 3.8.0. ++ # Still getting failures on 3.10 on CI though + raise ContentDispositionError("Missing closing quote character") + except ValueError: # pragma: no cover + # WORKAROUND for https://github.com/python/cpython/issues/87112 +@@ -153,7 +154,7 @@ def parse_content_disposition(reply): + """ + is_inline = True + filename = None +- content_disposition_header = 'Content-Disposition'.encode('iso-8859-1') ++ content_disposition_header = b'Content-Disposition' + # First check if the Content-Disposition header has a filename + # attribute. + if reply.hasRawHeader(content_disposition_header): +diff --git a/qutebrowser/browser/webkit/network/networkmanager.py b/qutebrowser/browser/webkit/network/networkmanager.py +index c97c91d66..83eaabda7 100644 +--- a/qutebrowser/browser/webkit/network/networkmanager.py ++++ b/qutebrowser/browser/webkit/network/networkmanager.py +@@ -25,7 +25,7 @@ import dataclasses + from typing import TYPE_CHECKING, Dict, MutableMapping, Optional, Set + + from PyQt5.QtCore import pyqtSlot, pyqtSignal, QUrl, QByteArray +-from PyQt5.QtNetwork import (QNetworkAccessManager, QNetworkReply, QSslSocket, ++from PyQt5.QtNetwork import (QNetworkAccessManager, QNetworkReply, QSslConfiguration, + QNetworkProxy) + + from qutebrowser.config import config +@@ -103,7 +103,8 @@ def _is_secure_cipher(cipher): + + def init(): + """Disable insecure SSL ciphers on old Qt versions.""" +- default_ciphers = QSslSocket.defaultCiphers() ++ sslconfig = QSslConfiguration.defaultConfiguration() ++ default_ciphers = sslconfig.ciphers() + log.init.vdebug( # type: ignore[attr-defined] + "Default Qt ciphers: {}".format( + ', '.join(c.name() for c in default_ciphers))) +@@ -119,7 +120,7 @@ def init(): + if bad_ciphers: + log.init.debug("Disabling bad ciphers: {}".format( + ', '.join(c.name() for c in bad_ciphers))) +- QSslSocket.setDefaultCiphers(good_ciphers) ++ sslconfig.setCiphers(good_ciphers) + + + _SavedErrorsType = MutableMapping[ +@@ -379,10 +380,10 @@ class NetworkManager(QNetworkAccessManager): + if referer_header_conf == 'never': + # Note: using ''.encode('ascii') sends a header with no value, + # instead of no header at all +- req.setRawHeader('Referer'.encode('ascii'), QByteArray()) ++ req.setRawHeader(b'Referer', QByteArray()) + elif (referer_header_conf == 'same-domain' and + not urlutils.same_domain(req.url(), current_url)): +- req.setRawHeader('Referer'.encode('ascii'), QByteArray()) ++ req.setRawHeader(b'Referer', QByteArray()) + # If refer_header_conf is set to 'always', we leave the header + # alone as QtWebKit did set it. + except urlutils.InvalidUrlError: +diff --git a/qutebrowser/commands/command.py b/qutebrowser/commands/command.py +index eee5b7cde..8d3b486fc 100644 +--- a/qutebrowser/commands/command.py ++++ b/qutebrowser/commands/command.py +@@ -67,6 +67,7 @@ class Command: + both) + no_replace_variables: Don't replace variables like {url} + modes: The modes the command can be executed in. ++ tree_tab: Whether the command is a tree-tabs command + _qute_args: The saved data from @cmdutils.argument + _count: The count set for the command. + _instance: The object to bind 'self' to. +@@ -80,7 +81,7 @@ class Command: + def __init__(self, *, handler, name, instance=None, maxsplit=None, + modes=None, not_modes=None, debug=False, deprecated=False, + no_cmd_split=False, star_args_optional=False, scope='global', +- backend=None, no_replace_variables=False): ++ backend=None, no_replace_variables=False, tree_tab=False): + if modes is not None and not_modes is not None: + raise ValueError("Only modes or not_modes can be given!") + if modes is not None: +@@ -109,6 +110,7 @@ class Command: + self.handler = handler + self.no_cmd_split = no_cmd_split + self.backend = backend ++ self.tree_tab = tree_tab + self.no_replace_variables = no_replace_variables + + self.docparser = docutils.DocstringParser(handler) +diff --git a/qutebrowser/completion/models/filepathcategory.py b/qutebrowser/completion/models/filepathcategory.py +index b7d74f57a..fd2cb58ce 100644 +--- a/qutebrowser/completion/models/filepathcategory.py ++++ b/qutebrowser/completion/models/filepathcategory.py +@@ -65,7 +65,7 @@ class FilePathCategory(QAbstractListModel): + try: + return glob.glob(glob.escape(val) + '*') + except ValueError as e: # pragma: no cover +- # e.g. "embedded null byte" with \x00 on Python 3.6 and 3.7 ++ # e.g. "embedded null byte" with \x00 on Python 3.7 + log.completion.debug(f"Failed to glob: {e}") + return [] + +diff --git a/qutebrowser/completion/models/util.py b/qutebrowser/completion/models/util.py +index 21dcf2e9f..67df93c2c 100644 +--- a/qutebrowser/completion/models/util.py ++++ b/qutebrowser/completion/models/util.py +@@ -23,6 +23,7 @@ from typing import Callable, Sequence + + from qutebrowser.utils import usertypes + from qutebrowser.misc import objects ++from qutebrowser.config import config + + + DeleteFuncType = Callable[[Sequence[str]], None] +@@ -46,8 +47,9 @@ def get_cmd_completions(info, include_hidden, include_aliases, prefix=''): + hide_debug = obj.debug and not objects.args.debug + hide_mode = (usertypes.KeyMode.normal not in obj.modes and + not include_hidden) ++ hide_tree = obj.tree_tab and not config.cache['tabs.tree_tabs'] + hide_ni = obj.name == 'Ni!' +- if not (hide_debug or hide_mode or obj.deprecated or hide_ni): ++ if not (hide_tree or hide_debug or hide_mode or obj.deprecated or hide_ni): + bindings = ', '.join(cmd_to_keys.get(obj.name, [])) + cmdlist.append((prefix + obj.name, obj.desc, bindings)) + +diff --git a/qutebrowser/components/braveadblock.py b/qutebrowser/components/braveadblock.py +index b1e5b8a29..977aa3ef2 100644 +--- a/qutebrowser/components/braveadblock.py ++++ b/qutebrowser/components/braveadblock.py +@@ -175,11 +175,12 @@ class BraveAdBlocker: + hasattr(adblock, "__file__")): + proc = subprocess.run( + ['pacman', '-Qo', adblock.__file__], +- stdout=subprocess.PIPE, +- universal_newlines=True, ++ capture_output=True, ++ text=True, + check=False, + ) + logger.debug(proc.stdout) ++ logger.debug(proc.stderr) + raise + + def _is_blocked( +diff --git a/qutebrowser/config/configdata.yml b/qutebrowser/config/configdata.yml +index 771cf0493..e368ae7e6 100644 +--- a/qutebrowser/config/configdata.yml ++++ b/qutebrowser/config/configdata.yml +@@ -2159,6 +2159,40 @@ tabs.new_position.stacking: + Only applies for `next` and `prev` values of `tabs.new_position.related` + and `tabs.new_position.unrelated`. + ++tabs.new_position.tree.new_child: ++ default: first ++ type: NewChildPosition ++ desc: >- ++ Position of new children among siblings, e.g. after calling `:open ++ --relative ...` or following a link. ++ ++tabs.new_position.tree.new_sibling: ++ default: first ++ type: NewTabPosition ++ desc: >- ++ Position of siblings, e.g. after calling `:open --sibling ...`. ++ ++tabs.new_position.tree.new_toplevel: ++ default: last ++ type: NewTabPosition ++ desc: >- ++ Position of new top-level tabs related to the topmost ancestor of current ++ tab, e.g. when calling `:open ...` without `--relative` or `--sibling`. ++ ++tabs.new_position.tree.promote: ++ default: next ++ type: NewTabPosition ++ desc: >- ++ Position at which a tab is placed among its new siblings after being ++ promoted with `:tree-tab-promote` ++ ++tabs.new_position.tree.demote: ++ default: last ++ type: NewChildPosition ++ desc: >- ++ Position at which a tab is placed among its new siblings after being ++ demoted with `:tree-tab-demote` ++ + tabs.padding: + default: + top: 0 +@@ -2219,7 +2253,7 @@ tabs.title.alignment: + desc: Alignment of the text inside of tabs. + + tabs.title.format: +- default: '{audio}{index}: {current_title}' ++ default: '{tree}{collapsed}{audio}{index}: {current_title}' + type: + name: FormatString + fields: +@@ -2237,12 +2271,16 @@ tabs.title.format: + - current_url + - protocol + - audio ++ - collapsed ++ - tree + none_ok: true + desc: | + Format to use for the tab title. + The following placeholders are defined: + + * `{perc}`: Percentage as a string like `[10%]`. ++ * `{collapsed}`: If children tabs are hidden, the string `[...]`, empty otherwise ++ * `{tree}`: The ASCII tree prefix of current tab. + * `{perc_raw}`: Raw percentage, e.g. `10`. + * `{current_title}`: Title of the current web page. + * `{title_sep}`: The string `" - "` if a title is set, empty otherwise. +@@ -2278,6 +2316,8 @@ tabs.title.format_pinned: + - current_url + - protocol + - audio ++ - collapsed ++ - tree + none_ok: true + desc: Format to use for the tab title for pinned tabs. The same placeholders + like for `tabs.title.format` are defined. +@@ -2376,6 +2416,12 @@ tabs.wrap: + type: Bool + desc: Wrap when changing tabs. + ++tabs.tree_tabs: ++ default: false ++ type: Bool ++ desc: Enable tree-tabs mode. ++ restart: true ++ + tabs.focus_stack_size: + default: 10 + type: +@@ -3727,6 +3773,17 @@ bindings.default: + all no-3rdparty never ;; reload + tCu: config-cycle -p -u {url} content.cookies.accept + all no-3rdparty never ;; reload ++ zH: tree-tab-promote ++ zL: tree-tab-demote ++ zJ: tab-next -s ++ zK: tab-prev -s ++ zd: tab-close -r ++ zg: set-cmd-text -s :tree-tab-create-group -r ++ zG: set-cmd-text -s :tree-tab-create-group ++ za: tree-tab-toggle-hide ++ zp: tab-focus parent ++ zo: set-cmd-text --space :open -tr ++ zO: set-cmd-text --space :open -tS + insert: + : edit-text + : insert-text -- {primary} +diff --git a/qutebrowser/config/configtypes.py b/qutebrowser/config/configtypes.py +index 97011b7cf..89969ccfd 100644 +--- a/qutebrowser/config/configtypes.py ++++ b/qutebrowser/config/configtypes.py +@@ -1945,6 +1945,21 @@ class NewTabPosition(String): + ('last', "At the end.")) + + ++class NewChildPosition(String): ++ ++ """How new children are positioned.""" ++ ++ def __init__( ++ self, *, ++ none_ok: bool = False, ++ completions: _Completions = None, ++ ) -> None: ++ super().__init__(none_ok=none_ok, completions=completions) ++ self.valid_values = ValidValues( ++ ('first', "At the beginning."), ++ ('last', "At the end.")) ++ ++ + class LogLevel(String): + + """A logging level.""" +diff --git a/qutebrowser/html/tree_group.html b/qutebrowser/html/tree_group.html +new file mode 100644 +index 000000000..b3717e52b +--- /dev/null ++++ b/qutebrowser/html/tree_group.html +@@ -0,0 +1,65 @@ ++{% extends "base.html" %} ++{% block style %} ++h1, p { ++ margin-left: 3rem; ++} ++ ++pre { ++ margin-left: 6em; ++} ++{% endblock %} ++{% block content %} ++

++ {{ title }} ++

++

++ Group for tree tabs ++

++
++{% raw %}
++                       _.
++                _~.:'^%^ >@~.
++             ,-~              ? =*=
++           $^_`  `  , '   ,    +   -.,
++        (*-^. , *            ;'       >
++      >.      ,>    .     ' .,.,.      %-.,_ ,.-,
++      #    ' ` " - "     *    .,.      *   .^    `
++     *@!    ., *    ' '    ,    ;'   '         .  %!
++      &       "  .`      :'              `   '   . `~,
++     &    '        .`  '   '  .     '":   :          +.
++     ^      .",  ,       `      '   `   * , '   `      |
++      ]     *   .   , ""]   ..    ` . , `  , "  . . '  ,;,
++      %  '         ::,  ,   /    ,            '   ,     ;
++    .* ,*    /       *%     \  .  .  *'  `    ,    '     '.
++   ?     > .   ,      ::. :;^^.     %`      '        `     @
++  /   '   `/      `    &#@%^^      `&``   `     %;;       %
++ ;:       :%   *  *  :$%)\      '  `@%$        @%^      ,).
++ .    #    %&^     (!*^ .\,.   `      ^@%^  $#%%^  `   >
++ \           :#$%  #^&#   :   `  *      %###$%@!       &
++  |  '  *     %$#@)$*}]           `     `#@#%%^      *^
++   :     *'  *  @%&&^:$   `  '   `%%.  #$$$^^-,     7
++    &;            @#$~~   '   `     @#$%&      $,*.-
++     *...*^  .._   %$$#@!   @ .,  *&&#@
++         :..^   -   !%&@}{#&     @#$@%
++                 --_..%#%%$#&% #&%$#;:
++                        $%#^%#@@%%*&;;
++                         a%##@%%@% ;:;
++                           %####j#:::;
++                            &#%Rj;%;;:
++                            &#%%#;::;
++                            $#%##:%::
++                            "#%%#;:;
++                           ."$###:::
++                           #&$%%#:;:
++                           %&#%%#::;
++                           %&%###;::
++                           &&#%%#:;;
++                          *@&#%#};:;
++                          $#%#%%^:::
++                         *@#$#%#;::;:
++                        %%@#$####@$:;:
++                    ...%###pinusc@$%%:._____
++{% endraw %}
++
++
++{% endblock %} +diff --git a/icons/qutebrowser-128x128.png b/qutebrowser/icons/qutebrowser-128x128.png +similarity index 100% +rename from icons/qutebrowser-128x128.png +rename to qutebrowser/icons/qutebrowser-128x128.png +diff --git a/icons/qutebrowser-16x16.png b/qutebrowser/icons/qutebrowser-16x16.png +similarity index 100% +rename from icons/qutebrowser-16x16.png +rename to qutebrowser/icons/qutebrowser-16x16.png +diff --git a/icons/qutebrowser-24x24.png b/qutebrowser/icons/qutebrowser-24x24.png +similarity index 100% +rename from icons/qutebrowser-24x24.png +rename to qutebrowser/icons/qutebrowser-24x24.png +diff --git a/icons/qutebrowser-256x256.png b/qutebrowser/icons/qutebrowser-256x256.png +similarity index 100% +rename from icons/qutebrowser-256x256.png +rename to qutebrowser/icons/qutebrowser-256x256.png +diff --git a/icons/qutebrowser-32x32.png b/qutebrowser/icons/qutebrowser-32x32.png +similarity index 100% +rename from icons/qutebrowser-32x32.png +rename to qutebrowser/icons/qutebrowser-32x32.png +diff --git a/icons/qutebrowser-48x48.png b/qutebrowser/icons/qutebrowser-48x48.png +similarity index 100% +rename from icons/qutebrowser-48x48.png +rename to qutebrowser/icons/qutebrowser-48x48.png +diff --git a/icons/qutebrowser-512x512.png b/qutebrowser/icons/qutebrowser-512x512.png +similarity index 100% +rename from icons/qutebrowser-512x512.png +rename to qutebrowser/icons/qutebrowser-512x512.png +diff --git a/icons/qutebrowser-64x64.png b/qutebrowser/icons/qutebrowser-64x64.png +similarity index 100% +rename from icons/qutebrowser-64x64.png +rename to qutebrowser/icons/qutebrowser-64x64.png +diff --git a/icons/qutebrowser-96x96.png b/qutebrowser/icons/qutebrowser-96x96.png +similarity index 100% +rename from icons/qutebrowser-96x96.png +rename to qutebrowser/icons/qutebrowser-96x96.png +diff --git a/icons/qutebrowser-all.svg b/qutebrowser/icons/qutebrowser-all.svg +similarity index 100% +rename from icons/qutebrowser-all.svg +rename to qutebrowser/icons/qutebrowser-all.svg +diff --git a/icons/qutebrowser-favicon.svg b/qutebrowser/icons/qutebrowser-favicon.svg +similarity index 100% +rename from icons/qutebrowser-favicon.svg +rename to qutebrowser/icons/qutebrowser-favicon.svg +diff --git a/icons/qutebrowser.icns b/qutebrowser/icons/qutebrowser.icns +similarity index 100% +rename from icons/qutebrowser.icns +rename to qutebrowser/icons/qutebrowser.icns +diff --git a/icons/qutebrowser.ico b/qutebrowser/icons/qutebrowser.ico +similarity index 100% +rename from icons/qutebrowser.ico +rename to qutebrowser/icons/qutebrowser.ico +diff --git a/icons/qutebrowser.svg b/qutebrowser/icons/qutebrowser.svg +similarity index 100% +rename from icons/qutebrowser.svg +rename to qutebrowser/icons/qutebrowser.svg +diff --git a/icons/qutebrowser.xpm b/qutebrowser/icons/qutebrowser.xpm +similarity index 100% +rename from icons/qutebrowser.xpm +rename to qutebrowser/icons/qutebrowser.xpm +diff --git a/qutebrowser/mainwindow/mainwindow.py b/qutebrowser/mainwindow/mainwindow.py +index 7f62c2dc4..c99f0b0f1 100644 +--- a/qutebrowser/mainwindow/mainwindow.py ++++ b/qutebrowser/mainwindow/mainwindow.py +@@ -23,7 +23,7 @@ import binascii + import base64 + import itertools + import functools +-from typing import List, MutableSequence, Optional, Tuple, cast ++from typing import List, MutableSequence, Optional, Tuple, cast, Union + + from PyQt5.QtCore import (pyqtBoundSignal, pyqtSlot, QRect, QPoint, QTimer, Qt, + QCoreApplication, QEventLoop, QByteArray) +@@ -199,7 +199,7 @@ class MainWindow(QWidget): + super().__init__(parent) + # Late import to avoid a circular dependency + # - browsertab -> hints -> webelem -> mainwindow -> bar -> browsertab +- from qutebrowser.mainwindow import tabbedbrowser ++ from qutebrowser.mainwindow import treetabbedbrowser, tabbedbrowser + from qutebrowser.mainwindow.statusbar import bar + + self.setAttribute(Qt.WA_DeleteOnClose) +@@ -228,8 +228,14 @@ class MainWindow(QWidget): + + self.is_private = config.val.content.private_browsing or private + +- self.tabbed_browser: tabbedbrowser.TabbedBrowser = tabbedbrowser.TabbedBrowser( +- win_id=self.win_id, private=self.is_private, parent=self) ++ self.tabbed_browser: Union[tabbedbrowser.TabbedBrowser, ++ treetabbedbrowser.TreeTabbedBrowser] ++ if config.val.tabs.tree_tabs: ++ self.tabbed_browser = treetabbedbrowser.TreeTabbedBrowser( ++ win_id=self.win_id, private=self.is_private, parent=self) ++ else: ++ self.tabbed_browser = tabbedbrowser.TabbedBrowser( ++ win_id=self.win_id, private=self.is_private, parent=self) + objreg.register('tabbed-browser', self.tabbed_browser, scope='window', + window=self.win_id) + self._init_command_dispatcher() +@@ -499,8 +505,10 @@ class MainWindow(QWidget): + mode_manager.keystring_updated.connect( + self.status.keystring.on_keystring_updated) + self.status.cmd.got_cmd[str].connect(self._commandrunner.run_safely) +- self.status.cmd.got_cmd[str, int].connect(self._commandrunner.run_safely) +- self.status.cmd.returnPressed.connect(self.tabbed_browser.on_cmd_return_pressed) ++ self.status.cmd.got_cmd[str, int].connect( ++ self._commandrunner.run_safely) ++ self.status.cmd.returnPressed.connect( ++ self.tabbed_browser.on_cmd_return_pressed) + self.status.cmd.got_search.connect(self._command_dispatcher.search) + + # key hint popup +diff --git a/qutebrowser/mainwindow/statusbar/command.py b/qutebrowser/mainwindow/statusbar/command.py +index 92408d34f..199f0a103 100644 +--- a/qutebrowser/mainwindow/statusbar/command.py ++++ b/qutebrowser/mainwindow/statusbar/command.py +@@ -276,7 +276,7 @@ class Command(misc.MinimalLineEditMixin, misc.CommandLineEdit): + text = self.text() + if not text: + text = 'x' +- width = self.fontMetrics().width(text) ++ width = self.fontMetrics().boundingRect(text).width() + return QSize(width, height) + + @pyqtSlot() +diff --git a/qutebrowser/mainwindow/tabbedbrowser.py b/qutebrowser/mainwindow/tabbedbrowser.py +index a96f6d583..4c17b378c 100644 +--- a/qutebrowser/mainwindow/tabbedbrowser.py ++++ b/qutebrowser/mainwindow/tabbedbrowser.py +@@ -24,8 +24,8 @@ import functools + import weakref + import datetime + import dataclasses +-from typing import ( +- Any, Deque, List, Mapping, MutableMapping, MutableSequence, Optional, Tuple) ++from typing import (Any, Deque, List, Mapping, ++ MutableMapping, MutableSequence, Optional, Tuple) + + from PyQt5.QtWidgets import QSizePolicy, QWidget, QApplication + from PyQt5.QtCore import pyqtSignal, pyqtSlot, QTimer, QUrl +@@ -202,6 +202,7 @@ class TabbedBrowser(QWidget): + resized = pyqtSignal('QRect') + current_tab_changed = pyqtSignal(browsertab.AbstractTab) + new_tab = pyqtSignal(browsertab.AbstractTab, int) ++ is_treetabbedbrowser = False + shutting_down = pyqtSignal() + + def __init__(self, *, win_id, private, parent=None): +@@ -452,6 +453,7 @@ class TabbedBrowser(QWidget): + crashed: Whether we're closing a tab with crashed renderer process. + """ + idx = self.widget.indexOf(tab) ++ + if idx == -1: + if crashed: + return +@@ -518,15 +520,24 @@ class TabbedBrowser(QWidget): + entries = self.undo_stack[-depth] + del self.undo_stack[-depth] + ++ # we return the tab list because tree_tabs needs it in post_processing ++ new_tabs = [] + for entry in reversed(entries): + if use_current_tab: + newtab = self.widget.widget(0) + use_current_tab = False + else: +- newtab = self.tabopen(background=False, idx=entry.index) ++ # FIXME:typing mypy thinks this is None due to @pyqtSlot ++ newtab = self.tabopen( ++ background=False, ++ related=False, ++ idx=entry.index ++ ) + + newtab.history.private_api.deserialize(entry.history) + newtab.set_pinned(entry.pinned) ++ new_tabs.append(newtab) ++ return new_tabs + + @pyqtSlot('QUrl', bool) + def load_url(self, url, newtab): +@@ -615,7 +626,7 @@ class TabbedBrowser(QWidget): + + if idx is None: + idx = self._get_new_tab_idx(related) +- self.widget.insertTab(idx, tab, "") ++ idx = self.widget.insertTab(idx, tab, "") + + if url is not None: + tab.load_url(url) +diff --git a/qutebrowser/mainwindow/tabwidget.py b/qutebrowser/mainwindow/tabwidget.py +index 511c2c309..6b162c67e 100644 +--- a/qutebrowser/mainwindow/tabwidget.py ++++ b/qutebrowser/mainwindow/tabwidget.py +@@ -38,7 +38,6 @@ from qutebrowser.browser import browsertab + + + class TabWidget(QTabWidget): +- + """The tab widget used for TabbedBrowser. + + Signals: +@@ -61,8 +60,7 @@ class TabWidget(QTabWidget): + self.setStyle(TabBarStyle()) + self.setTabBar(bar) + bar.tabCloseRequested.connect(self.tabCloseRequested) +- bar.tabMoved.connect(functools.partial( +- QTimer.singleShot, 0, self.update_tab_titles)) ++ bar.tabMoved.connect(self.update_tab_titles) + bar.currentChanged.connect(self._on_current_changed) + bar.new_tab_requested.connect(self._on_new_tab_requested) + self.setSizePolicy(QSizePolicy.Expanding, QSizePolicy.Fixed) +@@ -70,6 +68,7 @@ class TabWidget(QTabWidget): + self.setElideMode(Qt.ElideRight) + self.setUsesScrollButtons(True) + bar.setDrawBase(False) ++ + self._init_config() + config.instance.changed.connect(self._init_config) + +@@ -178,6 +177,9 @@ class TabWidget(QTabWidget): + fields['perc_raw'] = tab.progress() + fields['backend'] = objects.backend.name + fields['private'] = ' [Private Mode] ' if tab.is_private else '' ++ fields['tree'] = '' ++ fields['collapsed'] = '' ++ + try: + if tab.audio.is_muted(): + fields['audio'] = TabWidget.MUTE_STRING +diff --git a/qutebrowser/mainwindow/treetabbedbrowser.py b/qutebrowser/mainwindow/treetabbedbrowser.py +new file mode 100644 +index 000000000..ae5dfb4dc +--- /dev/null ++++ b/qutebrowser/mainwindow/treetabbedbrowser.py +@@ -0,0 +1,350 @@ ++# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et: ++ ++# Copyright 2014-2018 Giuseppe Stelluto (pinusc) ++# ++# This file is part of qutebrowser. ++# ++# qutebrowser is free software: you can redistribute it and/or modify ++# it under the terms of the GNU General Public License as published by ++# the Free Software Foundation, either version 3 of the License, or ++# (at your option) any later version. ++# ++# qutebrowser is distributed in the hope that it will be useful, ++# but WITHOUT ANY WARRANTY; without even the implied warranty of ++# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++# GNU General Public License for more details. ++# ++# You should have received a copy of the GNU General Public License ++# along with qutebrowser. If not, see . ++ ++"""Subclass of TabbedBrowser to provide tree-tab functionality.""" ++ ++import collections ++import dataclasses ++import datetime ++from typing import List, Dict ++from PyQt5.QtWidgets import QSizePolicy ++from PyQt5.QtCore import pyqtSlot, QUrl ++ ++from qutebrowser.config import config ++from qutebrowser.mainwindow.tabbedbrowser import TabbedBrowser ++from qutebrowser.mainwindow.treetabwidget import TreeTabWidget ++from qutebrowser.browser import browsertab ++from qutebrowser.misc import notree ++from qutebrowser.utils import log ++ ++ ++@dataclasses.dataclass ++class _TreeUndoEntry(): ++ """Information needed for :undo.""" ++ ++ url: QUrl ++ history: bytes ++ index: int ++ pinned: bool ++ uid: int ++ parent_node_uid: int ++ children_node_uids: List[int] ++ local_index: int # index of the tab relative to its siblings ++ created_at: datetime.datetime = dataclasses.field( ++ default_factory=datetime.datetime.now) ++ ++ @staticmethod ++ def from_node(node, idx): ++ """Make a TreeUndoEntry from a Node.""" ++ url = node.value.url() ++ try: ++ history_data = node.value.history.private_api.serialize() ++ except browsertab.WebTabError: ++ history_data = [] ++ pinned = node.value.data.pinned ++ uid = node.uid ++ parent_uid = node.parent.uid ++ children = [n.uid for n in node.children] ++ local_idx = node.index ++ return _TreeUndoEntry(url=url, ++ history=history_data, ++ index=idx, ++ pinned=pinned, ++ uid=uid, ++ parent_node_uid=parent_uid, ++ children_node_uids=children, ++ local_index=local_idx) ++ ++ ++class TreeTabbedBrowser(TabbedBrowser): ++ """Subclass of TabbedBrowser to provide tree-tab functionality. ++ ++ Extends TabbedBrowser methods (mostly tabopen, undo, and _remove_tab) so ++ that the internal tree is updated after every action. ++ ++ Provides methods to hide and show subtrees, and to cycle visibility. ++ """ ++ ++ is_treetabbedbrowser = True ++ ++ def __init__(self, *, win_id, private, parent=None): ++ super().__init__(win_id=win_id, private=private, parent=parent) ++ self.is_treetabbedbrowser = True ++ self.widget = TreeTabWidget(win_id, parent=self) ++ self.widget.tabCloseRequested.connect(self.on_tab_close_requested) ++ self.widget.new_tab_requested.connect(self.tabopen) ++ self.widget.currentChanged.connect(self._on_current_changed) ++ self.cur_fullscreen_requested.connect(self.widget.tabBar().maybe_hide) ++ self.widget.setSizePolicy(QSizePolicy.Expanding, QSizePolicy.Expanding) ++ self._reset_stack_counters() ++ ++ def _remove_tab(self, tab, *, add_undo=True, new_undo=True, crashed=False): ++ """Handle children positioning after a tab is removed.""" ++ node = tab.node ++ # FIXME after the fixme in _add_undo_entry is resolved, no need ++ # to save descendents ++ descendents = tuple(node.traverse(render_collapsed=True)) ++ ++ super()._remove_tab(tab, add_undo=False, new_undo=False, ++ crashed=crashed) ++ ++ if not tab.url().isEmpty() and tab.url().isValid() and add_undo: ++ idx = self.widget.indexOf(tab) ++ self._add_undo_entry(tab, idx, new_undo) ++ ++ parent = node.parent ++ ++ if node.collapsed: ++ # node will already be removed from tree ++ # but we need to manually close the tab processes ++ for descendent in descendents: ++ tab = descendent.value ++ tab.private_api.shutdown() ++ tab.deleteLater() ++ tab.layout().unwrap() ++ elif parent: ++ siblings = list(parent.children) ++ children = node.children ++ ++ if children: ++ next_node = children[0] ++ ++ for n in children[1:]: ++ n.parent = next_node ++ ++ # swap nodes ++ node_idx = siblings.index(node) ++ siblings[node_idx] = next_node ++ ++ parent.children = tuple(siblings) ++ node.children = () ++ ++ node.parent = None ++ self.widget.tree_tab_update() ++ ++ def _add_undo_entry(self, tab, idx, new_undo): ++ """Save undo entry with tree information. ++ ++ This function was removed in tabbedbrowser, but it is still useful here because ++ the mechanism is quite a bit more complex ++ """ ++ # TODO see if it's possible to remove duplicate code from ++ # super()._add_undo_entry ++ try: ++ history_data = tab.history.private_api.serialize() ++ except browsertab.WebTabError: ++ pass # special URL ++ else: ++ node = tab.node ++ uid = node.uid ++ parent_uid = node.parent.uid ++ if not node.collapsed: ++ children = [n.uid for n in node.children] ++ local_idx = node.index ++ entry = _TreeUndoEntry(url=tab.url(), ++ history=history_data, ++ index=idx, ++ pinned=tab.data.pinned, ++ uid=uid, ++ parent_node_uid=parent_uid, ++ children_node_uids=children, ++ local_index=local_idx) ++ if new_undo or not self.undo_stack: ++ self.undo_stack.append([entry]) ++ else: ++ self.undo_stack[-1].append(entry) ++ else: ++ entries = [] ++ for descendent in node.traverse(notree.TraverseOrder.POST_R): ++ entries.append(_TreeUndoEntry.from_node(descendent, 0)) ++ # ensure descendent is not later saved as child as well ++ descendent.parent = None # FIXME: Find a way not to change ++ # the tree ++ if new_undo: ++ self.undo_stack.append(entries) ++ else: ++ self.undo_stack[-1] += entries ++ ++ def undo(self, depth=1): ++ """Undo removing of a tab or tabs.""" ++ # TODO find a way to remove dupe code ++ # probably by getting entries from undo stack, THEN calling super ++ # then post-processing the entries ++ ++ # save entries before super().undo() pops them ++ entries = list(self.undo_stack[-depth]) ++ new_tabs = super().undo(depth) ++ ++ for entry, tab in zip(reversed(entries), new_tabs): ++ if not isinstance(entry, _TreeUndoEntry): ++ continue ++ root = self.widget.tree_root ++ uid = entry.uid ++ parent_uid = entry.parent_node_uid ++ parent_node = root.get_descendent_by_uid(parent_uid) ++ if not parent_node: ++ parent_node = root ++ ++ children = [] ++ for child_uid in entry.children_node_uids: ++ child_node = root.get_descendent_by_uid(child_uid) ++ children.append(child_node) ++ tab.node.parent = None # Remove the node from the tree ++ tab.node = notree.Node(tab, parent_node, ++ children, uid) ++ ++ # correctly reposition the tab ++ local_idx = entry.local_index ++ if tab.node.parent: # should always be true ++ new_siblings = list(tab.node.parent.children) ++ new_siblings.remove(tab.node) ++ new_siblings.insert(local_idx, tab.node) ++ tab.node.parent.children = new_siblings ++ ++ self.widget.tree_tab_update() ++ ++ @pyqtSlot('QUrl') ++ @pyqtSlot('QUrl', bool) ++ @pyqtSlot('QUrl', bool, bool) ++ def tabopen( ++ self, url: QUrl = None, ++ background: bool = None, ++ related: bool = True, ++ sibling: bool = False, ++ idx: int = None, ++ ) -> browsertab.AbstractTab: ++ """Open a new tab with a given url. ++ ++ Args: ++ related: Whether to set the tab as a child of the currently focused ++ tab. Follows `tabs.new_position.tree.related`. ++ sibling: Whether to set the tab as a sibling of the currently ++ focused tab. Follows `tabs.new_position.tree.sibling`. ++ ++ """ ++ # pylint: disable=arguments-differ ++ # we save this now because super.tabopen also resets the focus ++ cur_tab = self.widget.currentWidget() ++ tab = super().tabopen(url, background, related, idx) ++ ++ tab.node.parent = self.widget.tree_root ++ if cur_tab is None or tab is cur_tab: ++ self.widget.tree_tab_update() ++ return tab ++ ++ # get pos ++ if related: ++ pos = config.val.tabs.new_position.tree.new_child ++ parent = cur_tab.node ++ # pos can only be first, last ++ elif sibling: ++ pos = config.val.tabs.new_position.tree.new_sibling ++ parent = cur_tab.node.parent ++ # pos can be first, last, prev, next ++ else: ++ pos = config.val.tabs.new_position.tree.new_toplevel ++ parent = self.widget.tree_root ++ ++ self._position_tab(cur_tab, tab, pos, parent, sibling, related, background) ++ ++ return tab ++ ++ def _position_tab( ++ self, ++ cur_tab: browsertab.AbstractTab, ++ tab: browsertab.AbstractTab, ++ pos: str, ++ parent: notree.Node, ++ sibling: bool = False, ++ related: bool = True, ++ background: bool = None, ++ ) -> None: ++ toplevel = not sibling and not related ++ siblings = list(parent.children) ++ if tab.node in siblings: # true if parent is tree_root ++ # remove it and add it later in the right position ++ siblings.remove(tab.node) ++ ++ if pos == 'first': ++ rel_idx = 0 ++ if config.val.tabs.new_position.stacking and related: ++ rel_idx += self._tree_tab_child_rel_idx ++ self._tree_tab_child_rel_idx += 1 ++ siblings.insert(rel_idx, tab.node) ++ elif pos in ['prev', 'next'] and (sibling or toplevel): ++ # pivot is the tab relative to which 'prev' or 'next' apply ++ # it is always a member of 'siblings' ++ pivot = cur_tab.node if sibling else cur_tab.node.path[1] ++ direction = -1 if pos == 'prev' else 1 ++ rel_idx = 0 if pos == 'prev' else 1 ++ tgt_idx = siblings.index(pivot) + rel_idx ++ if config.val.tabs.new_position.stacking: ++ if sibling: ++ tgt_idx += self._tree_tab_sibling_rel_idx ++ self._tree_tab_sibling_rel_idx += direction ++ elif toplevel: ++ tgt_idx += self._tree_tab_toplevel_rel_idx ++ self._tree_tab_toplevel_rel_idx += direction ++ siblings.insert(tgt_idx, tab.node) ++ else: # position == 'last' ++ siblings.append(tab.node) ++ parent.children = siblings ++ self.widget.tree_tab_update() ++ if not background: ++ self._reset_stack_counters() ++ ++ def _reset_stack_counters(self): ++ self._tree_tab_child_rel_idx = 0 ++ self._tree_tab_sibling_rel_idx = 0 ++ self._tree_tab_toplevel_rel_idx = 0 ++ ++ @pyqtSlot(int) ++ def _on_current_changed(self, idx): ++ super()._on_current_changed(idx) ++ self._reset_stack_counters() ++ ++ def cycle_hide_tab(self, node): ++ """Utility function for tree_tab_cycle_hide command.""" ++ # height = node.height # height is always rel_height ++ if node.collapsed: ++ node.collapsed = False ++ for descendent in node.traverse(render_collapsed=True): ++ descendent.collapsed = False ++ return ++ ++ def rel_depth(n): ++ return n.depth - node.depth ++ ++ levels: Dict[int, list] = collections.defaultdict(list) ++ for d in node.traverse(render_collapsed=False): ++ r_depth = rel_depth(d) ++ levels[r_depth].append(d) ++ ++ # Remove highest level because it's leaves (or already collapsed) ++ del levels[max(levels.keys())] ++ ++ target = 0 ++ for level in sorted(levels, reverse=True): ++ nodes = levels[level] ++ if not all(n.collapsed or not n.children for n in nodes): ++ target = level ++ break ++ for n in levels[target]: ++ if not n.collapsed and n.children: ++ n.collapsed = True +diff --git a/qutebrowser/mainwindow/treetabwidget.py b/qutebrowser/mainwindow/treetabwidget.py +new file mode 100644 +index 000000000..12de178c2 +--- /dev/null ++++ b/qutebrowser/mainwindow/treetabwidget.py +@@ -0,0 +1,105 @@ ++# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et: ++ ++# Copyright 2014-2018 Giuseppe Stelluto (pinusc) ++# ++# This file is part of qutebrowser. ++# ++# qutebrowser is free software: you can redistribute it and/or modify ++# it under the terms of the GNU General Public License as published by ++# the Free Software Foundation, either version 3 of the License, or ++# (at your option) any later version. ++# ++# qutebrowser is distributed in the hope that it will be useful, ++# but WITHOUT ANY WARRANTY; without even the implied warranty of ++# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++# GNU General Public License for more details. ++# ++# You should have received a copy of the GNU General Public License ++# along with qutebrowser. If not, see . ++ ++"""Extension of TabWidget for tree-tab functionality.""" ++ ++from qutebrowser.mainwindow.tabwidget import TabWidget ++from qutebrowser.misc.notree import Node ++from qutebrowser.utils import log ++ ++ ++class TreeTabWidget(TabWidget): ++ """Tab widget used in TabbedBrowser, with tree-functionality. ++ ++ Handles correct rendering of the tree as a tab field, and correct ++ positioning of tabs according to tree structure. ++ """ ++ ++ def __init__(self, win_id, parent=None): ++ # root of the tab tree, common for all tabs in the window ++ self.tree_root = Node(None) ++ super().__init__(win_id, parent) ++ self.tabBar().tabMoved.disconnect(self.update_tab_titles) ++ ++ def _init_config(self): ++ super()._init_config() ++ # For tree-tabs ++ self.update_tab_titles() # Must also be called when deactivating ++ self.tree_tab_update() ++ ++ def get_tab_fields(self, idx): ++ """Add tree field data to normal tab field data.""" ++ fields = super().get_tab_fields(idx) ++ ++ tab = self.widget(idx) ++ fields['collapsed'] = '[...] ' if tab.node.collapsed else '' ++ ++ # we remove the first two chars because every tab is child of tree ++ # root and that gets rendered as well ++ rendered_tree = self.tree_root.render() ++ try: ++ pre, _ = rendered_tree[idx+1] ++ tree_prefix = pre[2:] ++ except IndexError: # window or first tab are not initialized yet ++ tree_prefix = "" ++ log.misc.error("tree_prefix is empty!") ++ ++ fields['tree'] = tree_prefix ++ return fields ++ ++ def update_tree_tab_positions(self): ++ """Update tab positions according to the tree structure.""" ++ nodes = self.tree_root.traverse(render_collapsed=False) ++ for idx, node in enumerate(nodes): ++ if idx > 0: ++ cur_idx = self.indexOf(node.value) ++ self.tabBar().moveTab(cur_idx, idx-1) ++ ++ def update_tree_tab_visibility(self): ++ """Hide collapsed tabs and show uncollapsed ones. ++ ++ Sync the internal tree to the tabs the user can actually see. ++ """ ++ for node in self.tree_root.traverse(): ++ if node.value is None: ++ continue ++ if any(ancestor.collapsed for ancestor in node.path[:-1]): ++ if self.indexOf(node.value) != -1: ++ # node should be hidden but is shown ++ cur_tab = node.value ++ idx = self.indexOf(cur_tab) ++ if idx != -1: ++ self.removeTab(idx) ++ else: ++ if self.indexOf(node.value) == -1: ++ # node should be shown but is hidden ++ parent = node.parent ++ tab = node.value ++ name = tab.title() ++ icon = tab.icon() ++ if node.parent is not None: ++ parent_idx = self.indexOf(node.parent.value) ++ self.insertTab(parent_idx + 1, tab, icon, name) ++ tab.node.parent = parent # insertTab resets node ++ ++ def tree_tab_update(self): ++ """Update titles and positions.""" ++ self.update_tree_tab_visibility() ++ self.update_tree_tab_positions() ++ self.update_tab_titles() +diff --git a/qutebrowser/misc/checkpyver.py b/qutebrowser/misc/checkpyver.py +index e9a7a1eef..7d6a524c3 100644 +--- a/qutebrowser/misc/checkpyver.py ++++ b/qutebrowser/misc/checkpyver.py +@@ -43,11 +43,11 @@ except ImportError: # pragma: no cover + # to stderr. + def check_python_version(): + """Check if correct python version is run.""" +- if sys.hexversion < 0x03060100: ++ if sys.hexversion < 0x03070000: + # We don't use .format() and print_function here just in case someone + # still has < 2.6 installed. + version_str = '.'.join(map(str, sys.version_info[:3])) +- text = ("At least Python 3.6.1 is required to run qutebrowser, but " + ++ text = ("At least Python 3.7 is required to run qutebrowser, but " + + "it's running with " + version_str + ".\n") + if Tk and '--no-err-windows' not in sys.argv: # pragma: no cover + root = Tk() +diff --git a/qutebrowser/misc/earlyinit.py b/qutebrowser/misc/earlyinit.py +index 034d7ff74..4b3df4db2 100644 +--- a/qutebrowser/misc/earlyinit.py ++++ b/qutebrowser/misc/earlyinit.py +@@ -19,7 +19,7 @@ + + """Things which need to be done really early (e.g. before importing Qt). + +-At this point we can be sure we have all python 3.6.1 features available. ++At this point we can be sure we have all python 3.7 features available. + """ + + try: +@@ -235,7 +235,6 @@ def check_libraries(): + modules = { + 'jinja2': _missing_str("jinja2"), + 'yaml': _missing_str("PyYAML"), +- 'dataclasses': _missing_str("dataclasses"), + 'PyQt5.QtQml': _missing_str("PyQt5.QtQml"), + 'PyQt5.QtSql': _missing_str("PyQt5.QtSql"), + 'PyQt5.QtOpenGL': _missing_str("PyQt5.QtOpenGL"), +diff --git a/qutebrowser/misc/notree.py b/qutebrowser/misc/notree.py +new file mode 100644 +index 000000000..9d180ad4c +--- /dev/null ++++ b/qutebrowser/misc/notree.py +@@ -0,0 +1,354 @@ ++# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et: ++ ++# Copyright 2019 Giuseppe Stelluto (pinusc) ++# ++# This file is part of qutebrowser. ++# ++# qutebrowser is free software: you can redistribute it and/or modify ++# it under the terms of the GNU General Public License as published by ++# the Free Software Foundation, either version 3 of the License, or ++# (at your option) any later version. ++# ++# qutebrowser is distributed in the hope that it will be useful, ++# but WITHOUT ANY WARRANTY; without even the implied warranty of ++# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++# GNU General Public License for more details. ++# ++# You should have received a copy of the GNU General Public License ++# along with qutebrowser. If not, see . ++ ++"""Tree library for tree-tabs. ++ ++The fundamental unit is the Node class. ++ ++Create a tree with with Node(value, parent): ++root = Node('foo') ++child = Node('bar', root) ++child2 = Node('baz', root) ++child3 = Node('lorem', child) ++ ++You can also assign parent after instantiation, or even reassign it: ++child4 = Node('ipsum') ++child4.parent = root ++ ++Assign children: ++child.children = [] ++child2.children = [child4, child3] ++child3.parent ++> Node('foo/bar/baz') ++ ++Render a tree with render_tree(root_node): ++render_tree(root) ++ ++> ('', 'foo') ++> ('├─', 'bar') ++> ('│ ├─', 'lorem') ++> ('│ └─', 'ipsum') ++> ('└─', 'baz') ++""" ++import enum ++from typing import Optional, TypeVar, Sequence, List, Tuple, Iterable, Generic ++import itertools ++ ++# For Node.render ++CORNER = '└─' ++INTERSECTION = '├─' ++PIPE = '│' ++ ++ ++class TreeError(RuntimeError): ++ """Exception used for tree-related errors.""" ++ ++ ++class TraverseOrder(enum.Enum): ++ """To be used as argument to traverse(). ++ ++ Implemented orders are pre-order and post-order. ++ Attributes: ++ PRE: pre-order (parents before children). Same as in Node.render ++ POST: children of a node are always yield before their parent. ++ POST_R: Like POST, but children are yield in reverse order ++ """ ++ ++ PRE = 'pre-order' ++ POST = 'post-order' ++ POST_R = 'post-order-reverse' ++ ++ ++uid_gen = itertools.count(0) ++ ++# generic type of value held by Node ++T = TypeVar('T') # pylint: disable=invalid-name ++ ++ ++class Node(Generic[T]): ++ """Fundamental unit of notree library. ++ ++ Attributes: ++ value: The element (ususally a tab) the node represents ++ parent: Node's parent. ++ children: Node's children elements. ++ siblings: Children of parent node that are not self. ++ path: List of nodes from root of tree to self value, parent, and ++ children can all be set by user. Everything else will be updated ++ accordingly, so that if `node.parent = root_node`, then `node in ++ root_node.children` will be True. ++ """ ++ ++ sep: str = '/' ++ __parent: Optional['Node[T]'] = None ++ # this is a global 'static' class attribute ++ ++ def __init__(self, ++ value: T, ++ parent: Optional['Node[T]'] = None, ++ childs: Sequence['Node[T]'] = (), ++ uid: Optional[int] = None) -> None: ++ if uid is not None: ++ self.__uid = uid ++ else: ++ self.__uid = next(uid_gen) ++ ++ self.value = value ++ # set initial values so there's no need for AttributeError checks ++ self.__parent: Optional['Node[T]'] = None ++ self.__children: List['Node[T]'] = [] ++ ++ # For render memoization ++ self.__modified = False ++ self.__set_modified() # not the same as line above ++ self.__rendered: Optional[List[Tuple[str, 'Node[T]']]] = None ++ ++ if parent: ++ self.parent = parent # calls setter ++ if childs: ++ self.children = childs # this too ++ ++ self.__collapsed = False ++ ++ @property ++ def uid(self) -> int: ++ return self.__uid ++ ++ @property ++ def parent(self) -> Optional['Node[T]']: ++ return self.__parent ++ ++ @parent.setter ++ def parent(self, value: 'Node[T]') -> None: ++ """Set parent property. Also adds self to value.children.""" ++ # pylint: disable=protected-access ++ assert(value is None or isinstance(value, Node)) ++ if self.__parent: ++ self.__parent.__disown(self) ++ self.__parent = None ++ if value is not None: ++ value.__add_child(self) ++ self.__parent = value ++ self.__set_modified() ++ ++ @property ++ def children(self) -> Sequence['Node[T]']: ++ return tuple(self.__children) ++ ++ @children.setter ++ def children(self, value: Sequence['Node[T]']) -> None: ++ """Set children property, preserving order. ++ ++ Also sets n.parent = self for n in value. Does not allow duplicates. ++ """ ++ seen = set(value) ++ if len(seen) != len(value): ++ raise TreeError("A duplicate item is present in in %r" % value) ++ new_children = list(value) ++ for child in new_children: ++ if child.parent is not self: ++ child.parent = self ++ self.__children = new_children ++ self.__set_modified() ++ ++ @property ++ def path(self) -> List['Node[T]']: ++ """Get a list of all nodes from the root node to self.""" ++ if self.parent is None: ++ return [self] ++ else: ++ return self.parent.path + [self] ++ ++ @property ++ def depth(self) -> int: ++ """Get the number of nodes between self and the root node.""" ++ return len(self.path) - 1 ++ ++ @property ++ def index(self) -> int: ++ """Get self's position among its siblings (self.parent.children).""" ++ if self.parent is not None: ++ return self.parent.children.index(self) ++ else: ++ raise TreeError('Node has no parent.') ++ ++ @property ++ def collapsed(self) -> bool: ++ return self.__collapsed ++ ++ @collapsed.setter ++ def collapsed(self, val: bool) -> None: ++ self.__collapsed = val ++ self.__set_modified() ++ ++ def __set_modified(self) -> None: ++ """If self is modified, every ancestor is modified as well.""" ++ for node in self.path: ++ node.__modified = True # pylint: disable=protected-access ++ ++ def render(self) -> List[Tuple[str, 'Node[T]']]: ++ """Render a tree with ascii symbols. ++ ++ Tabs appear in the same order as in traverse() with TraverseOrder.PRE ++ Args: ++ node; the root of the tree to render ++ ++ Return: list of tuples where the first item is the symbol, ++ and the second is the node it refers to ++ """ ++ if not self.__modified and self.__rendered is not None: ++ return self.__rendered ++ ++ result = [('', self)] ++ for child in self.children: ++ if child.children: ++ subtree = child.render() ++ if child is not self.children[-1]: ++ subtree = [(PIPE + ' ' + c, n) for c, n in subtree] ++ char = INTERSECTION ++ else: ++ subtree = [(' ' + c, n) for c, n in subtree] ++ char = CORNER ++ subtree[0] = (char, subtree[0][1]) ++ if child.collapsed: ++ result += [subtree[0]] ++ else: ++ result += subtree ++ else: ++ if child is self.children[-1]: ++ result.append((CORNER, child)) ++ else: ++ result.append((INTERSECTION, child)) ++ self.__modified = False ++ self.__rendered = list(result) ++ return list(result) ++ ++ def traverse(self, order: TraverseOrder = TraverseOrder.PRE, ++ render_collapsed: bool = True) -> Iterable['Node']: ++ """Generator for all descendants of `self`. ++ ++ Args: ++ order: a TraverseOrder object. See TraverseOrder documentation. ++ render_collapsed: whether to yield children of collapsed nodes ++ Even if render_collapsed is False, collapsed nodes are be rendered. ++ It's their children that won't. ++ """ ++ if order == TraverseOrder.PRE: ++ yield self ++ ++ if self.collapsed and not render_collapsed: ++ if order != TraverseOrder.PRE: ++ yield self ++ return ++ ++ f = reversed if order is TraverseOrder.POST_R else lambda x: x ++ for child in f(self.children): ++ if render_collapsed or not child.collapsed: ++ yield from child.traverse(order, render_collapsed) ++ else: ++ yield child ++ if order in [TraverseOrder.POST, TraverseOrder.POST_R]: ++ yield self ++ ++ def __add_child(self, node: 'Node[T]') -> None: ++ if node not in self.__children: ++ self.__children.append(node) ++ ++ def __disown(self, value: 'Node[T]') -> None: ++ self.__set_modified() ++ if value in self.__children: ++ self.__children.remove(value) ++ ++ def get_descendent_by_uid(self, uid: int) -> Optional['Node[T]']: ++ """Return descendent identified by the provided uid. ++ ++ Returns None if there is no such descendent. ++ ++ Args: ++ uid: The uid of the node to return ++ """ ++ for descendent in self.traverse(): ++ if descendent.uid == uid: ++ return descendent ++ return None ++ ++ def promote(self, times: int = 1, to: str = 'first') -> None: ++ """Makes self a child of its grandparent, i.e. sibling of its parent. ++ ++ Args: ++ times: How many levels to promote the tab to. to: One of 'next', ++ 'prev', 'first', 'last'. Determines the position among siblings ++ after being promoted. 'next' and 'prev' are relative to the current ++ parent. ++ ++ """ ++ if to not in ['first', 'last', 'next', 'prev']: ++ raise Exception("Invalid value supplied for 'to': " + to) ++ position = {'first': 0, 'last': -1}.get(to, None) ++ diff = {'next': 1, 'prev': 0}.get(to, 1) ++ count = times ++ while count > 0: ++ if self.parent is None or self.parent.parent is None: ++ raise TreeError("Tab has no parent!") ++ grandparent = self.parent.parent ++ if position is not None: ++ idx = position ++ else: # diff is necessarily not none ++ idx = self.parent.index + diff ++ self.parent = None ++ ++ siblings = list(grandparent.children) ++ if idx != -1: ++ siblings.insert(idx, self) ++ else: ++ siblings.append(self) ++ grandparent.children = siblings ++ count -= 1 ++ ++ def demote(self, to: str = 'last') -> None: ++ """Demote a tab making it a child of its previous adjacent sibling.""" ++ if self.parent is None or self.parent.children is None: ++ raise TreeError("Tab has no siblings!") ++ siblings = list(self.parent.children) ++ ++ # we want previous node in the same subtree as current node ++ rel_idx = siblings.index(self) - 1 ++ ++ if rel_idx >= 0: ++ parent = siblings[rel_idx] ++ new_siblings = list(parent.children) ++ position = {'first': 0, 'last': -1}.get(to, -1) ++ if position == 0: ++ new_siblings.insert(0, self) ++ else: ++ new_siblings.append(self) ++ parent.children = new_siblings ++ else: ++ raise TreeError("Tab has no previous sibling!") ++ ++ def __repr__(self) -> str: ++ try: ++ value = str(self.value.url().url()) # type: ignore ++ except Exception: ++ value = str(self.value) ++ return "" % (self.__uid, value) ++ ++ def __str__(self) -> str: ++ # return "" % self.value ++ return str(self.value) +diff --git a/qutebrowser/misc/sessions.py b/qutebrowser/misc/sessions.py +index a28f3a848..faaa6897f 100644 +--- a/qutebrowser/misc/sessions.py ++++ b/qutebrowser/misc/sessions.py +@@ -249,6 +249,9 @@ class SessionManager(QObject): + tab: The WebView to save. + active: Whether the tab is currently active. + """ ++ # FIXME understand why this happens ++ if tab is None: ++ return {} + data: _JsonType = {'history': []} + if active: + data['active'] = True +@@ -290,12 +293,28 @@ class SessionManager(QObject): + if getattr(active_window, 'win_id', None) == win_id: + win_data['active'] = True + win_data['geometry'] = bytes(main_window.saveGeometry()) +- win_data['tabs'] = [] + if tabbed_browser.is_private: + win_data['private'] = True +- for i, tab in enumerate(tabbed_browser.widgets()): +- active = i == tabbed_browser.widget.currentIndex() +- win_data['tabs'].append(self._save_tab(tab, active)) ++ ++ if tabbed_browser.is_treetabbedbrowser: ++ # a dict where keys are node UIDs, and values are dicts ++ # with tab data (the result of _save_tab) and a list of ++ # children UIDs ++ tree_data = {} ++ root_node = tabbed_browser.widget.tree_root ++ for i, node in enumerate(root_node.traverse(), -1): ++ node_data = {} ++ active = i == tabbed_browser.widget.currentIndex() ++ node_data['tab'] = self._save_tab(node.value, active) ++ node_data['children'] = [c.uid for c in node.children] ++ node_data['collapsed'] = node.collapsed ++ tree_data[node.uid] = node_data ++ win_data['tree'] = tree_data ++ else: ++ win_data['tabs'] = [] ++ for i, tab in enumerate(tabbed_browser.widgets()): ++ active = i == tabbed_browser.widget.currentIndex() ++ win_data['tabs'].append(self._save_tab(tab, active)) + data['windows'].append(win_data) + return data + +@@ -461,6 +480,45 @@ class SessionManager(QObject): + except ValueError as e: + raise SessionError(e) + ++ def _load_tree(self, tabbed_browser, tree_data): ++ tree_keys = list(tree_data.keys()) ++ if not tree_keys: ++ return None ++ ++ root_data = tree_data.get(tree_keys[0]) ++ if root_data is None: ++ return None ++ ++ root_node = tabbed_browser.widget.tree_root ++ tab_to_focus = None ++ index = -1 ++ ++ def recursive_load_node(uid): ++ nonlocal tab_to_focus ++ nonlocal index ++ index += 1 ++ node_data = tree_data[uid] ++ children_uids = node_data['children'] ++ ++ if tree_data[uid]['tab'].get('active'): ++ tab_to_focus = index ++ ++ tab_data = node_data['tab'] ++ new_tab = tabbed_browser.tabopen(background=False) ++ self._load_tab(new_tab, tab_data) ++ ++ new_tab.node.parent = root_node ++ children = [recursive_load_node(uid) for uid in children_uids] ++ new_tab.node.children = children ++ new_tab.node.collapsed = node_data['collapsed'] ++ return new_tab.node ++ ++ for child_uid in root_data['children']: ++ child = recursive_load_node(child_uid) ++ child.parent = root_node ++ ++ return tab_to_focus ++ + def _load_window(self, win): + """Turn yaml data into windows.""" + window = mainwindow.MainWindow(geometry=win['geometry'], +@@ -469,15 +527,32 @@ class SessionManager(QObject): + tabbed_browser = objreg.get('tabbed-browser', scope='window', + window=window.win_id) + tab_to_focus = None +- for i, tab in enumerate(win['tabs']): +- new_tab = tabbed_browser.tabopen(background=False) +- self._load_tab(new_tab, tab) +- if tab.get('active', False): +- tab_to_focus = i +- if new_tab.data.pinned: +- new_tab.set_pinned(True) ++ ++ # plain_tabs is used in case the saved session contains a tree and ++ # tree-tabs is not enabled, or if the saved session contains normal ++ # tabs ++ plain_tabs = win.get('tabs', None) ++ if win.get('tree'): ++ if tabbed_browser.is_treetabbedbrowser: ++ tree_data = win.get('tree') ++ tab_to_focus = self._load_tree(tabbed_browser, tree_data) ++ tabbed_browser.widget.tree_tab_update() ++ else: ++ tree = win.get('tree') ++ plain_tabs = [tree[i]['tab'] for i in tree if ++ tree[i]['tab']] ++ if plain_tabs: ++ for i, tab in enumerate(plain_tabs): ++ new_tab = tabbed_browser.tabopen(background=False) ++ self._load_tab(new_tab, tab) ++ if tab.get('active', False): ++ tab_to_focus = i ++ if new_tab.data.pinned: ++ new_tab.set_pinned(True) ++ + if tab_to_focus is not None: + tabbed_browser.widget.setCurrentIndex(tab_to_focus) ++ + if win.get('active', False): + QTimer.singleShot(0, tabbed_browser.widget.activateWindow) + +diff --git a/qutebrowser/resources.py b/qutebrowser/resources.py +deleted file mode 100644 +index ebe256809..000000000 +--- a/qutebrowser/resources.py ++++ /dev/null +@@ -1,5474 +0,0 @@ +-# -*- coding: utf-8 -*- +- +-# Resource object code +-# +-# Created by: The Resource Compiler for PyQt5 (Qt v5.6.0) +-# +-# WARNING! All changes made in this file will be lost! +- +-from PyQt5 import QtCore +- +-qt_resource_data = b"\ +-\x00\x00\x22\xfe\ +-\x89\ +-\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\ +-\x00\x00\x80\x00\x00\x00\x80\x08\x06\x00\x00\x00\xc3\x3e\x61\xcb\ +-\x00\x00\x00\x04\x73\x42\x49\x54\x08\x08\x08\x08\x7c\x08\x64\x88\ +-\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0d\xd7\x00\x00\x0d\xd7\ +-\x01\x42\x28\x9b\x78\x00\x00\x00\x19\x74\x45\x58\x74\x53\x6f\x66\ +-\x74\x77\x61\x72\x65\x00\x77\x77\x77\x2e\x69\x6e\x6b\x73\x63\x61\ +-\x70\x65\x2e\x6f\x72\x67\x9b\xee\x3c\x1a\x00\x00\x20\x00\x49\x44\ +-\x41\x54\x78\x9c\xed\x9d\x77\x7c\x5c\xd5\x95\xf8\xbf\xf7\xcd\x8c\ +-\xa4\x51\xef\xdd\x72\xaf\x72\x93\x3b\xc6\x18\x1b\xdb\x31\xc5\x10\ +-\x4c\xc0\x21\x64\x03\x84\xb0\xc9\x26\x6c\xd8\x90\x6c\x60\x7f\xd9\ +-\x7c\x36\x24\xd9\x92\xfc\xb2\x69\x64\x61\x37\xc1\xa1\x98\xc0\x62\ +-\x02\x36\x60\x83\x0d\xb8\x60\x83\xbb\x2d\xc9\xd8\x72\xc1\x45\xb6\ +-\xac\x66\xd5\x51\x9d\xd1\x94\x77\xf6\x8f\xc1\x46\xb2\x66\x34\x33\ +-\x7a\x33\x92\x9c\xf0\xfd\x7c\xfc\xb1\xf4\xde\xbb\x45\x73\xcf\xdc\ +-\x7b\xde\xb9\xe7\x9c\xab\xf8\x0b\x43\x44\xd4\x8b\x1f\x31\x17\x97\ +-\xbe\xc8\xa9\x33\xc5\xa9\xab\x31\x5d\xba\xca\xd5\x3d\x12\xef\x11\ +-\x15\xed\x11\x2c\xba\x07\xcd\x03\xca\xe5\x41\x69\x80\xc9\x84\x98\ +-\x35\x11\x4d\xa1\x6b\x0a\x97\xd5\xac\xda\xe6\x14\xc8\x4e\x93\x26\ +-\x15\x08\xe7\x94\xc8\x59\xb7\xc5\x74\x7c\x56\x26\xe5\x4a\x29\x19\ +-\xec\xbf\x31\x9c\xa8\xc1\xee\x80\x51\x36\x1e\x91\x89\x8d\x5d\xfa\ +-\x7d\x0e\x8f\x5a\xd2\xde\xc5\xf8\x0e\xa7\x8a\x77\xeb\xc6\xff\xae\ +-\x09\x19\xc2\x84\xcc\x9e\x63\x2d\xd0\xa6\x90\x23\x22\xea\x80\x86\ +-\xec\x12\xdd\xb4\x6b\x46\x81\xaa\x36\xda\xd6\x60\x72\xd5\x09\xc0\ +-\x9a\xc3\x12\x87\x47\xff\x76\x47\x97\x76\x77\x7b\x17\x13\xda\x5d\ +-\x44\x4b\x84\xbe\x93\x37\x8c\xd1\x49\x8c\xee\xfb\x19\x81\x93\x9a\ +-\xb0\x49\xd7\xf4\xcd\x89\x1d\xe6\xf7\xc7\x8e\x55\x5d\x91\xe9\x4d\ +-\x64\xb8\x2a\x04\xe0\x95\xdd\x62\x75\x44\xeb\xdf\x6d\x77\x69\xf7\ +-\x36\x77\x32\xb6\xcb\x1d\xf9\x7e\x47\x9b\x61\xd9\x58\x1d\xb3\x16\ +-\x42\x21\x45\x0b\xf0\x86\xd2\xe5\x15\x4f\xad\xe9\xdd\x59\xb3\x94\ +-\x2b\x52\xfd\x0b\x17\x43\x5a\x00\xb6\x9c\x95\xa9\x95\xcd\xf2\xcb\ +-\x4a\x9b\xba\xc1\xe9\x21\x94\xa1\x30\xcc\xac\x7c\x21\x3f\xc9\xd0\ +-\xd4\x72\x11\x58\xab\x69\xda\x1f\xa6\xe7\xa8\xb2\x30\x75\x2b\xec\ +-\x0c\x39\x01\x78\xfc\x71\xd1\x72\x6f\xe4\xb1\x96\x2e\x1e\x6d\xef\ +-\x22\x79\x20\x34\x2e\x93\x82\x11\xa9\xc2\xc8\x54\xa1\xa4\x5a\xc3\ +-\x66\x87\xcf\x8d\xd5\x89\x36\x87\xab\x05\xd9\x25\xf0\xf3\x19\xb9\ +-\xa6\x8d\x43\x4d\x89\x1c\x32\x02\xf0\x78\x99\x44\xe5\x74\xf0\x0b\ +-\x5b\x27\x5f\xef\x70\x12\x13\x8e\x3a\x2d\x1a\xc4\x45\x83\x08\xb4\ +-\x3b\xc1\xa3\x43\x42\x34\x98\xba\xcd\x25\x69\xb1\xc2\xa8\x34\x21\ +-\xd6\x02\x27\xeb\x14\x27\x1b\x14\xf3\x0a\x84\xac\xf8\x88\x8c\x53\ +-\xb1\x42\x7e\x32\x3d\xd7\xf4\xe6\x50\x11\x84\xc1\x17\x00\x11\xf5\ +-\x3f\x7b\xf5\xff\x6c\xb2\xab\xbf\x77\xb8\x55\x54\xb8\xaa\xcd\x49\ +-\x14\x66\xe5\xc9\xe5\xc1\x6e\xeb\x82\x03\x95\x1a\xf3\x86\xe9\xc4\ +-\x5e\xd1\x8a\x08\x1c\xae\x55\x9c\x6b\xf2\x7e\x1c\x63\xd3\x84\xac\ +-\x04\x21\x35\x16\xb4\x88\x7c\x42\x72\x50\x94\xfc\x70\x66\xae\xe5\ +-\x9d\x48\xd4\x1e\x0a\x83\x2a\x00\xcf\xee\x97\x3b\x1a\xec\xac\x6e\ +-\xeb\x22\x25\xdc\x75\x27\xc6\x40\x7c\x94\x20\xc0\xc4\x0c\x21\x31\ +-\x06\x6a\x5a\x15\x26\x0d\x32\xbb\x7d\xbb\x05\x28\xa9\x52\x54\xd8\ +-\x7a\x7f\x14\x23\x53\x84\x69\xb9\x91\xfc\xa2\xaa\x2d\x26\x93\x7a\ +-\x64\x5a\xb6\x3a\x1a\xc1\x46\xfa\xee\xc1\x60\x34\xfa\xdb\x0f\xa5\ +-\x40\x53\xb2\xb1\xa1\x53\x4d\x89\xd4\x2b\xdc\x25\xac\x16\x58\x34\ +-\xca\xff\x7a\x7e\xa2\x5e\x71\xa2\xce\xf7\xc7\x30\x31\x53\x18\x9f\ +-\x11\xe1\x0e\x2a\x5c\x4a\xf8\xb5\x5d\xd7\x1e\x9f\x3f\x4c\xd9\x23\ +-\xdb\x58\x6f\x06\x54\xb3\x06\x28\xae\x72\x2d\xf5\x08\x27\xeb\x3b\ +-\x22\x3f\xf8\x26\x05\xd7\x0c\xf7\x3f\xf8\x3a\xde\xe9\x3f\x3f\x49\ +-\xc8\x49\x14\xaf\x7e\xd0\x4d\x16\xba\xdc\x91\xed\x1f\x00\x82\x45\ +-\xe0\xd1\x18\x4d\xff\xe8\x50\xa5\xeb\x86\x01\x68\xb1\x07\x61\xd3\ +-\x73\x03\xb1\xbd\x5c\x62\x92\xa2\xf4\xc7\x75\xe1\xfb\x6a\x80\x04\ +-\x2f\x39\x96\x3e\x0d\x39\x1a\xde\x6f\xf9\xa7\x78\x97\x0c\x9b\x1d\ +-\x8a\xab\xb4\x1e\xca\xe2\x00\x30\x46\x29\x6d\x4b\x49\xa5\xe7\x69\ +-\x8f\xa6\x3d\x32\x2b\x57\x75\x0e\x44\xa3\x03\xb2\x04\xbc\x50\x2c\ +-\xb7\x35\x77\xca\x8b\x0e\x8f\x8a\xb7\x3b\xc1\x23\x5e\xe5\x4a\x8f\ +-\xf0\x0c\x60\x36\xc1\x92\xd1\x9f\xcc\x00\x0a\x3a\x9d\xb0\xaf\x42\ +-\x63\x6a\x8e\x90\x11\x37\x24\x94\x70\xdf\x28\x8e\x68\x4a\xfb\xd2\ +-\x40\xd8\x0f\x22\x2e\x00\xff\x7b\x58\xfe\x4d\x53\xf2\x8f\x29\x56\ +-\x89\x2a\x6f\x52\x54\xb5\x28\xa6\x64\x7b\x5f\xbd\x5a\xed\xd0\xee\ +-\x52\x34\x77\xc2\xe9\xc6\xc8\x74\xc5\xa2\x81\x28\x88\xb7\x40\xa7\ +-\x0b\x32\xe2\x84\xe9\xb9\x82\xc5\x14\x91\xe6\xc2\x89\x5d\x89\x7c\ +-\xb3\x28\xdf\xfc\x7c\x24\x1b\x89\xd8\x12\xf0\xc4\x29\x89\xb6\x34\ +-\xb2\x2b\x25\x46\x66\x26\xc5\x08\xc7\x2e\x2a\xaa\x5b\xbd\x83\x2c\ +-\x78\x25\x2f\xd1\x0a\x66\x93\x60\x56\x8a\xd3\x8d\xc6\xda\x53\x40\ +-\x6a\x1c\xa4\xc6\x08\xe7\x6d\x0a\xa7\xc7\x7b\xdd\xa3\x43\x6a\xac\ +-\x90\x99\x00\x79\x89\x42\x5c\xd8\x5e\x34\x23\x8e\x55\x94\x7a\xae\ +-\xb8\xda\x33\xa5\x28\x47\x7b\x54\x29\xa5\x47\xa2\x91\x88\x7c\xed\ +-\x9e\xfa\x40\x52\xba\x90\xb2\x9c\x44\x72\x86\x27\x0b\x3b\xce\x6a\ +-\x74\x76\xb3\x8a\x5f\xda\x64\x29\xab\x55\x9c\x32\xf8\xcd\x8f\x36\ +-\x7b\x07\x76\x44\x8a\xf7\x55\xef\x50\x95\xe2\x82\x4d\x91\x1e\x07\ +-\xa3\x52\x85\xcc\x38\xc1\x1c\xe1\x6f\xbb\xae\x0b\x95\xb5\xf5\x14\ +-\xe4\x66\x46\xa4\x7e\x85\x5a\x6f\x73\xaa\x7b\x16\x8f\x54\x8e\xf0\ +-\xd7\x1d\x66\x9e\xde\x27\x23\x6d\x76\x4a\xd2\xe3\x24\x69\x5a\xae\ +-\x50\x52\xa5\x38\x7f\xc5\x3b\x76\x51\xae\x60\xb5\xc0\x9e\xf3\x8a\ +-\x4b\x2b\x71\x76\xbc\x30\x2e\x53\x88\x36\x43\x79\xa3\x0a\xb8\x24\ +-\xe4\x26\x7a\x97\x91\x34\x2b\xa8\x6e\x8f\x96\x5d\x54\x24\x44\xc3\ +-\xb0\x64\x19\x10\x05\xe7\xe3\xb3\x95\xfc\x6a\xf5\x6b\x4c\x1a\x5b\ +-\xc0\xc3\x5f\x5d\x19\xb1\x76\x44\xa9\xed\xae\x68\x75\xfb\xbc\x34\ +-\xd5\x1a\xce\x7a\xc3\xba\x04\x3c\xbb\x5f\x66\x5f\x6c\xe7\x03\xb7\ +-\x10\x5d\x98\x25\xb8\x75\xa8\x6c\xe9\x3d\x0c\xa5\x35\x9f\x2e\x05\ +-\x97\xa8\x6d\x57\x34\x74\x2a\x34\xc5\xe5\xe9\xdb\x1f\x33\xf3\x84\ +-\x61\xdd\x76\x09\x3a\x3a\xed\xe8\x22\xb4\xb5\xdb\x49\x46\x70\xb7\ +-\x7b\xa8\x75\x5a\x88\x8f\x8b\x21\x3a\x3a\x8a\x28\x73\xf8\x57\xba\ +-\xd6\xb6\x0e\xfe\xe7\xa5\xb7\xd8\xb8\x75\x2f\xba\x2e\x4c\x1a\x5b\ +-\x10\xf6\x36\xba\xa3\x44\x16\x47\x39\x64\xdb\xe1\x5a\xb9\x79\x5a\ +-\xb6\xaa\x0b\x57\xbd\x61\xfb\x64\x5e\x3a\x28\x0b\xce\xb7\xca\x76\ +-\xbb\x5b\x99\xf3\x92\xbc\x26\xd8\xe2\x6a\x85\xa7\xdb\x28\x9b\x14\ +-\xa4\xc7\x0b\xf1\x51\x90\x1e\xeb\x1d\xe8\x23\xb5\x0a\xf7\x27\xab\ +-\x9b\xfb\x8a\x55\x4e\x44\xc7\xd6\xdc\x44\x53\x7d\x2d\x4d\xf5\x17\ +-\x69\x6a\xaa\xc7\xde\xd6\xc2\xfa\x2e\x1b\xcd\x2d\x6d\xb4\xb4\x75\ +-\xe0\xf1\x04\x5e\x1a\x35\x4d\x11\x67\xb5\x92\x10\x6f\x25\x3b\x23\ +-\x95\x9c\xcc\x54\xee\xbe\x75\x11\x23\x87\x65\x87\xfc\x77\xea\xba\ +-\xf0\xe6\x96\x3d\xfc\xe1\xa5\xb7\x68\x6d\x1f\x90\x37\xb5\xee\xcc\ +-\xf4\x78\xf4\x0f\x4b\x6a\xe4\x73\x45\x39\xea\x5c\x38\x2a\x0c\x8b\ +-\x00\xac\x2e\x95\xa2\xf3\xcd\x6c\xb3\xbb\x95\x19\xa0\xae\x4d\xb1\ +-\xfd\xac\xa2\xf5\x8a\x15\x2b\x3e\x06\x26\x65\x08\x2d\x5d\x8a\x33\ +-\x4d\xd0\xd8\xa9\xe8\x6e\x0c\x72\xd8\x3b\xa9\x3c\x7f\x86\xea\xca\ +-\x73\xd4\x5c\x38\x47\x6d\x75\x05\x2e\xa7\xd3\x70\xff\x74\x5d\x68\ +-\xeb\xe8\xa4\xad\xa3\x93\xea\x8b\x5e\x6d\xf3\xda\x59\x93\x43\x16\ +-\x80\xb2\x53\xe7\xf8\xe5\xd3\xaf\xf1\xf1\xd9\x4a\xc3\x7d\x32\xc0\ +-\x58\x11\x7d\xcb\xfe\x3a\x59\x30\x27\x53\xd5\x1a\xad\xcc\xb0\x00\ +-\x3c\x75\x40\xc6\xd7\x35\xc9\x5e\x87\x5b\x59\x2e\x5d\x73\xe9\xe0\ +-\xf2\xa1\xae\xb4\xd8\x61\xfb\xd9\x9e\xd6\x95\xa6\x86\x8b\x9c\x39\ +-\x79\x94\xb3\x27\xcb\xa8\xba\x50\x8e\xae\x47\x44\xd9\x35\x44\x73\ +-\x4b\x1b\xff\xfd\xa7\x8d\x6c\x7a\xff\x00\x12\x69\xf3\x65\x30\x08\ +-\xa3\xcd\x2e\xfd\x9d\x92\x72\xb9\xbe\x68\xa4\xb2\x19\xa9\xca\x90\ +-\x00\xac\xde\x2d\xa9\x4d\x76\xf6\x87\xba\x8b\xe7\xec\x72\x70\xe2\ +-\x68\x31\x65\xa5\x07\xa8\xaa\x38\x6b\xa4\x0b\x11\x45\xd7\x85\x77\ +-\x3f\x38\xc4\xef\x9e\x7f\x9d\x96\xd6\x8e\xc1\xee\xce\x95\x4c\xd5\ +-\xa3\x65\xdd\xa9\x53\x72\x93\x11\x37\xb4\x7e\x0b\xc0\xef\x0f\x8a\ +-\xa5\xdd\x2e\x47\xda\x1d\x2a\x31\xd8\x32\xcd\x4d\x0d\xec\xdb\xf9\ +-\x2e\x27\x8e\x16\xe3\x76\x0d\x6d\x6f\xa9\x8f\x8e\x9f\xe5\x57\xab\ +-\xd7\x71\xfa\x7c\xd5\x60\x77\xc5\x2f\x4a\x64\x71\x6b\x2c\x2f\xbf\ +-\x22\x72\xe7\x2a\xa5\x02\xa8\xce\xbe\xe9\xb7\x00\x78\xba\xe4\x40\ +-\x93\x5d\xe5\x06\xf3\x6c\x8b\xad\x89\x7d\x3b\xdf\xe3\x68\xc9\xde\ +-\x21\x39\xc5\x77\xa7\xa9\xb9\x95\x27\xff\xb4\x81\x77\x77\x1e\x1a\ +-\x1a\xd3\x7d\x00\x14\x72\x7b\xeb\x01\xb6\x01\xd7\xf7\xa7\x7c\xbf\ +-\x04\x60\xf5\x7e\xcf\x53\x15\x36\x35\x2d\xd0\x73\x2e\x97\x93\x5d\ +-\xdb\xde\xa6\x78\xef\x8e\x21\x3f\xf0\x6e\x8f\x87\xd7\x36\x7d\xc8\ +-\x1f\x5f\xd9\x4c\x67\x67\xd8\xed\x2d\x91\x45\x58\xf8\xcc\x41\xcf\ +-\xbf\x3f\x30\xcb\xf4\x83\x50\x8b\x86\x2c\x00\x2f\x95\xc8\xed\xa7\ +-\x1b\xe4\x9b\x81\x9e\x3b\x7f\xe6\x24\xef\x6d\x58\x8b\xad\xd9\xa0\ +-\x8d\x77\x00\xb8\x50\x53\xcf\x0f\xfe\xff\x33\x94\x5f\x30\xac\x54\ +-\x0f\x0a\x49\x56\x38\x51\xa7\xfd\xd3\x73\x25\xf2\xd6\xfd\x45\x6a\ +-\x57\x28\x65\x43\x12\x80\xff\xda\x27\x69\x17\x6c\xf2\xb2\x5b\xfc\ +-\xdb\xd8\x74\x8f\x87\x6d\x9b\xd7\x51\x7a\x60\x17\x5c\x05\x53\x28\ +-\x40\xf9\x85\x8b\x57\xed\xe0\x03\x64\x27\x0a\x4e\x0f\x2a\xd9\x2a\ +-\xab\x0f\x1e\x94\xa9\xa1\xb8\xa3\x87\x24\x00\xca\x23\xdb\x3b\x5c\ +-\xca\xef\x0e\xbb\xa3\xb3\x83\x37\xd6\x3e\xcb\x85\x73\xa7\x42\xa9\ +-\xf6\x33\x0c\x12\x67\xb9\xec\xd7\x30\x81\x04\xfd\xa7\xc0\x3f\x05\ +-\x5b\x36\x68\x97\x87\xe7\x8b\x3d\xdf\xad\xeb\x50\x53\xfc\xdd\x6f\ +-\xac\xaf\xe5\x4f\x7f\xf8\xe5\x67\x83\x3f\xf8\x3c\xba\xe5\x63\x59\ +-\x11\xec\xc3\x41\x09\xc0\x4b\x07\x25\xbd\xa6\x55\xfb\x99\xbf\x19\ +-\xbd\xb9\xb1\x9e\xb5\xcf\xfd\xd7\x55\xb1\xde\xff\xa5\xe3\xf2\xa0\ +-\x0e\xd7\xf2\xca\x1f\x3f\x94\x84\x60\x9e\x0f\x4a\x00\x5a\xdc\xb2\ +-\xa9\xd3\x89\xc5\xd7\xbd\xb6\x56\x1b\x7f\x5e\xf3\x14\x9d\xed\x6d\ +-\xa1\xf4\xf3\x33\x22\xc4\xb1\x3a\x45\x8b\x03\xab\xd3\xc4\x6b\xc1\ +-\x3c\x1f\x50\x00\x5e\x2c\x95\xe5\x17\xdb\xd4\x2c\x5f\xf7\xec\x9d\ +-\xed\xbc\xf2\xdc\x93\xb4\xda\x9a\x42\xed\xe7\x67\x84\x19\x9b\x03\ +-\xf6\x55\x28\xca\x3f\x89\x6d\xb8\xd8\xce\xb2\x67\x8a\x25\xa0\x6d\ +-\x20\xa0\x12\xd8\xd8\x2e\x6b\x74\x1f\x5a\xbf\x88\xce\x9b\xaf\x3c\ +-\x4b\x73\x63\xd8\x76\x26\x03\x92\x92\x94\x80\x35\x26\x8a\x96\xb6\ +-\x4e\x3a\x3a\x07\xdc\x83\x7a\x48\x22\x02\xa5\xd5\xbd\x7d\x2e\x74\ +-\x01\x5b\x3b\x2f\x03\x39\x7d\x95\xef\x53\x00\x9e\x2b\xf1\xfc\xbf\ +-\xb3\xf5\xca\xa7\x9b\xcb\x9e\x1d\xef\x70\xa1\xfc\x74\xa8\xfd\x0d\ +-\x9a\x28\x8b\x85\x59\x53\xc7\x32\xaf\x68\x22\x85\x63\x87\x33\x72\ +-\x78\xce\xe5\x7d\xfd\x27\x9e\x5d\xcf\x2b\x6f\xed\x8c\x58\xdb\x57\ +-\x13\x67\x9a\x7a\x0f\xfe\x25\x6c\x0e\xb2\xd7\x1c\x92\x47\xee\x9d\ +-\xa9\x7e\xed\xaf\xbc\x5f\x01\x10\x11\xf5\xcb\x9d\xf2\xcf\xbe\xee\ +-\xd5\xd7\x56\xb3\x77\xe7\x7b\x21\x77\x36\x18\x72\xb3\xd2\xb8\xfb\ +-\xd6\x45\x2c\xbb\x6e\x06\x09\x71\xb1\x11\x69\xe3\x2f\x05\xa7\xc7\ +-\x1b\xd8\xd2\x17\xf5\x1d\xf2\x63\x20\x74\x01\x78\xa1\x44\x7f\xbc\ +-\xb5\x4b\x8b\xeb\x75\x43\x84\x77\x37\xbc\x8c\xee\xe9\xd7\xde\x83\ +-\x5f\x92\x12\xe3\xf8\xc6\x3d\x2b\xb8\x65\xf1\x1c\x4c\x03\xec\x90\ +-\x7f\xb5\x52\xde\xa4\x70\x07\x18\x86\x16\x87\x4a\x78\x7a\x9f\x7c\ +-\xff\x6f\xe7\xaa\x5f\xf8\xba\xef\x57\x00\x1a\xda\xd5\xf7\x7c\x5d\ +-\xff\xb8\xac\x98\x9a\xca\xf3\xa1\xf4\x33\x20\x4b\xae\x9d\xce\xf7\ +-\x1e\xbc\x93\xc4\x84\xde\xf2\xf6\x19\xfe\xb1\x07\x69\xef\x6b\x76\ +-\xf0\x43\xc0\xa7\x00\xf8\xfc\xaa\xbd\x75\xd4\xfd\x25\xab\x85\xb8\ +-\x2b\x5d\xa8\x93\xa2\x75\x0e\xec\x78\x2b\xa4\x4e\xf6\x85\xa6\x69\ +-\x3c\xfc\xd5\x95\xfc\xf8\x91\xfb\x3e\x1b\xfc\x10\xd1\x05\x9a\xec\ +-\xc1\xb9\xbd\xb6\x77\x91\xf8\xdc\x01\xf9\xba\xaf\x7b\x3e\x67\x80\ +-\x9c\x14\xed\xde\x9c\x14\x01\x84\x56\x07\xd4\xb4\x29\xa2\x4c\x70\ +-\xaa\xac\x98\x9a\xba\xf0\x18\x7b\x2c\x66\x13\xff\xf2\x9d\xaf\xb0\ +-\x78\x5e\xc0\x4d\xc5\xcf\xb8\x02\x11\x28\xad\xea\xed\x72\xd7\x17\ +-\xad\x5d\xfc\x08\xf8\xc3\x95\xd7\x7b\xcd\x00\x25\x17\x64\x2c\xc8\ +-\xf2\x4b\xbf\x27\xc6\xc0\xf8\x0c\x6f\xf6\x8c\x57\xc3\xa4\x79\x6b\ +-\x9a\xe2\xc7\xdf\xbd\xff\xb3\xc1\xef\x07\xad\x0e\xd8\x75\x5e\xa3\ +-\xc2\x87\xb7\x75\x5f\x34\xda\xc9\x7d\xb1\x58\x16\x5e\x79\xbd\xf7\ +-\x0c\xa0\xe9\x0f\xe2\x23\x5e\xe0\x6c\x45\x0d\xc7\x4e\x87\x67\xed\ +-\xff\xd6\x57\x6e\x63\xe1\x9c\xc9\x61\xa9\xeb\xaf\x85\xa6\x4e\xaf\ +-\xc6\x5f\xdf\xa1\xfa\xb5\xc9\x2a\x02\xad\x4e\x7e\x06\xcc\xef\x7e\ +-\xbd\x87\x00\x1c\x3c\x28\x16\x41\xbf\xd7\x57\x05\x9b\xde\x3f\x10\ +-\x7a\xab\x3e\x98\x3f\x73\x12\x77\xdf\xba\x28\x2c\x75\x0d\x15\xd2\ +-\x92\x13\x99\x57\x34\x29\xa4\x32\x9d\x8e\x2e\x6c\x2d\xed\xb4\x77\ +-\xd8\x69\x6d\xef\xc4\x6a\x8d\x22\x3a\xca\x42\x7c\xac\x95\xcc\xb4\ +-\x64\x34\xed\xd3\xc9\xd9\xe1\x86\xbd\x15\x5a\xc0\x78\x89\x40\x34\ +-\x75\xc8\xdc\xb7\xdf\x96\xe8\x9b\x6f\xfe\xd4\x87\xb0\x87\x00\xa8\ +-\x1c\xcf\x8d\xa0\x7c\xfa\x4a\xef\xdc\x77\xc4\x58\xeb\x40\x42\x5c\ +-\x2c\x8f\xfe\xdd\x2a\xc3\xf5\x0c\x15\xcc\x26\x13\x77\xde\x7c\x1d\ +-\x0f\xdc\xb5\x9c\xd8\x58\xff\x69\x8d\xda\x3a\x3a\x29\x3d\x76\x96\ +-\xd2\xb2\xd3\x9c\xa9\xa8\xa1\xbc\xa2\x96\x46\x9b\xff\x00\x9f\xe8\ +-\x28\x0b\xa3\x0b\x72\x19\x33\x32\x97\x59\xd3\x26\xa1\xa7\x14\x1a\ +-\x1e\x7c\x80\x2e\x8f\xd2\xea\x33\xf5\xef\x00\x3f\xbf\xfc\x37\x74\ +-\x7f\x40\x13\xb5\xca\x97\xaf\x47\x45\xd5\x45\xaa\x2e\x36\x18\xee\ +-\xc0\x7d\x77\x2e\x23\x3d\x25\xc9\x70\x3d\x43\x81\x19\x85\x63\x78\ +-\xe4\xc1\x2f\xf8\x8d\x2d\xa8\x6f\x6a\x61\xfb\xee\x52\xb6\xed\x2e\ +-\xe5\xd8\xe9\xf3\xe8\x21\xc4\xc2\x77\x39\x5d\x1c\x3b\x7d\x9e\x63\ +-\xa7\xcf\xf3\xe6\x7b\x7b\x88\xb1\xc6\x32\xbe\xb0\x88\x19\x73\x17\ +-\x92\x96\x19\x7a\x30\x4b\x77\xda\x5d\xda\x03\xf8\x12\x80\xed\xe5\ +-\x12\x23\x4a\xbf\xcd\x57\xa1\xfd\x87\x3f\x36\xd4\x28\x78\xa7\xc9\ +-\x95\xcb\xaf\x35\x5c\xcf\x60\x93\x99\x96\xcc\x43\xf7\x7e\x9e\x25\ +-\xd7\x4e\xf7\x79\xbf\xf8\xe8\x29\xfe\xfc\xd6\x4e\x76\x1d\x3a\x16\ +-\x36\x3f\x48\x87\xbd\x93\xc3\x07\x77\xf1\xd1\xa1\x3d\x14\x4e\x9f\ +-\xc3\xa2\xe5\x9f\x27\xc6\xda\x3f\x2b\x69\x73\x27\x63\x5f\xd9\x2e\ +-\xf1\xab\x16\xab\x76\xe8\x26\x00\x89\xd1\xee\x45\x88\xe6\xd3\xc5\ +-\xbb\xec\xe3\x73\xfd\x6a\xac\x3b\x77\xdd\xb2\x90\xe8\x28\x9f\x3b\ +-\xca\x57\x05\x16\xb3\x89\x55\x2b\x16\x71\xdf\x9d\xcb\x88\x8d\xe9\ +-\xed\x14\x75\xfc\x74\x05\x4f\xbd\xb0\x81\x92\xb2\xc8\xed\x8f\x88\ +-\xe8\x1c\x2d\xd9\x4b\xf9\xe9\x63\xac\xb8\xf3\x5e\x86\x8d\x18\x1b\ +-\x72\x1d\x4e\x0f\xaa\x23\x5e\x7f\x88\x4f\x66\x81\xcb\x02\xa0\x44\ +-\xbb\xc9\x5f\xa1\xb2\x53\xc6\xb4\x7f\x93\x49\xe3\xc6\x45\x3e\x77\ +-\x94\xaf\x0a\x66\x4f\x1b\xc7\x23\x5f\xfb\x82\xcf\xf0\xef\x96\xd6\ +-\x0e\x7e\xff\xd2\x46\x36\x6e\xdb\x17\xd2\x34\x6f\x84\x8e\xb6\x56\ +-\xfe\xfc\xfc\x53\x2c\x5d\xb1\x8a\xa9\x33\xaf\x09\xb9\xbc\x03\xed\ +-\x0b\x5c\x29\x00\x80\x4f\x01\xe8\x74\x74\x51\x53\x67\x6c\xbf\x7f\ +-\xce\xd4\xf1\x57\xe5\xda\x9f\x95\x9e\xc2\xb7\xef\xbf\x9d\x45\xf3\ +-\xa6\xf6\xba\xa7\xeb\x3a\xaf\xbf\xb7\x87\xd5\xff\xfb\xf6\x60\x04\ +-\x89\xa2\xeb\x3a\xef\x6e\x58\x8b\xee\xf1\x30\x7d\xce\x82\x90\xca\ +-\xb6\x3b\xe4\xb2\x6b\x9f\x19\xa0\xf4\x82\xe4\xe9\xe8\x3e\xe7\x93\ +-\xca\xea\x7a\xc3\x01\x12\x73\x8b\x26\x1a\x2a\x3f\xd0\x98\x4d\x26\ +-\x56\x2e\xbf\x96\xbf\xbd\xe7\x66\xbf\xd3\xfd\xaf\x57\xaf\x0b\x9b\ +-\x5d\xa4\xdf\x88\xb0\xf5\xed\x57\x49\x48\x4a\x66\xf4\xf8\xe0\xed\ +-\x2a\xed\x4e\x15\xf3\x52\xa9\x14\xde\x33\x5d\x95\x99\x01\x3c\x9a\ +-\x67\x81\xf2\x93\x4e\xe1\x42\x8d\x71\xed\x7f\xe6\x94\xd0\xd7\xaa\ +-\xc1\xe2\x9a\xa2\x89\xfc\xc3\xd7\xee\x20\x3f\x3b\xbd\xd7\xbd\xa6\ +-\xe6\x56\x9e\xfa\xd3\x06\xde\x19\x42\x51\x43\x22\xc2\x5b\xeb\xfe\ +-\xc4\xfd\xdf\x7a\x8c\xc4\xa4\xe0\xf2\x6d\x8a\x80\xc3\xcd\x57\x81\ +-\x7f\x34\x03\x28\xd4\x7c\x5f\x0f\x7a\x04\x4e\x56\xb5\x18\xea\x60\ +-\x62\x7c\x2c\x23\xf2\xb3\x0c\xd5\x31\x10\xe4\x66\xa5\xf1\xf0\xfd\ +-\x2b\x59\x30\xbb\xb0\xd7\xbd\xa1\x1e\x35\xe4\x74\xd8\xd9\xbc\xfe\ +-\x25\x56\xdd\xf7\xad\x9e\xe9\x52\xfa\xa0\xcb\x25\x8b\xe0\xb2\x0e\ +-\x20\xb3\x7d\x65\x8b\xd9\x57\xa1\x38\x5d\xd3\x6e\xa8\x73\x05\xb9\ +-\x99\xa8\x20\x3b\x35\x58\x4c\x1e\x37\x9c\x17\x7e\xfd\x98\xcf\xb7\ +-\x94\xe2\xb2\xd3\xfc\x7a\xf5\x6b\x43\x3e\x70\xa4\xa2\xfc\x63\x4e\ +-\x96\x95\x32\x7e\x72\x51\x50\xcf\x3b\xdc\x6a\x34\x80\x59\x44\xb4\ +-\x92\x6a\xbd\x97\xbf\x7f\x6d\xbb\xa2\xae\x5d\x61\xef\x34\x16\x16\ +-\x9d\x9f\xd3\x7b\x2a\x1d\x6a\xa4\x26\xf7\xf6\xa0\xae\x6b\xb4\xf1\ +-\xe4\x9a\x37\xd8\xba\xab\x74\x10\x7a\xd4\x3f\x3e\xd8\xb2\x81\xb1\ +-\x13\xa7\xa2\x99\x02\x67\xc5\xea\x70\x92\x24\x22\xca\x5c\x5c\xc9\ +-\x28\xa5\x11\xdf\xfd\xa6\x47\xf7\x66\xf0\x02\x0c\x87\x71\xe7\x66\ +-\x0d\x7d\x01\xe8\x8e\xcb\xed\x61\xed\x86\xf7\x79\xfe\xb5\x77\xb1\ +-\x3b\x8c\x67\x27\x19\x48\x6c\xcd\x8d\x9c\x2c\x2b\x61\xe2\xd4\xc0\ +-\xaf\xdc\x4e\x0f\xea\xc5\x8f\x98\x6b\x46\xf3\x4c\x04\x45\x5b\x17\ +-\xd8\xec\x8a\x76\x27\x54\xb7\x7a\x7f\x07\xd0\xdd\xc6\x12\xe6\xc6\ +-\xf7\x61\x23\x1f\x2c\x8a\x0a\xc7\x30\x61\x54\x7e\xaf\xeb\xfb\x4b\ +-\x4f\xf2\x9b\x67\xd6\x51\x51\x3d\x70\x9e\xce\xe1\xe6\xd0\x9e\x1d\ +-\x41\x09\x00\x80\xcb\xa5\x2f\x33\x97\x56\xab\x7b\xaa\x5b\x34\x5c\ +-\x7e\xac\x96\x1e\xdd\x98\x00\xc4\xf8\x78\x8d\x1a\x2c\xfc\x99\x71\ +-\x6b\xea\x9a\xf8\xdd\x73\xeb\xd9\xb9\x7f\xd0\xb2\xb6\x87\x8d\xda\ +-\xea\x0a\x1a\x2e\x56\x93\x9e\x15\x38\x75\x83\xee\x61\xa2\xd9\xad\ +-\x6b\xa3\xfd\x0d\x3e\x80\xa6\x19\xcb\xb2\x68\x8d\x1e\xfc\xd4\x9c\ +-\x51\x66\x33\x77\x7f\x7e\x11\x5f\x59\xb9\x0c\x6b\xcc\xa7\xfd\xe9\ +-\x72\xba\x78\xf1\xf5\x6d\xbc\xf8\xfa\x56\xba\x9c\x91\xcb\x58\x12\ +-\x17\x6b\x65\x46\xe1\x68\x46\x0f\xcf\x25\x2b\x3d\x85\xb8\x38\x2b\ +-\x1d\x1d\x76\x6a\xea\x1b\x39\x72\xe2\x1c\x87\x8f\x9f\x09\xab\x15\ +-\xf1\xf8\x91\x62\xae\x0b\x42\x00\x5c\xa2\x46\x9a\x9d\x6e\xc9\xee\ +-\x2b\x5f\x64\xf7\x7d\xe9\xfe\x30\xd8\x89\x21\xe6\xcf\x9c\xc4\xc3\ +-\x5f\x5d\xd9\xeb\xbd\xfe\xc3\x03\x65\x3c\xf1\xdc\xfa\xcb\x59\xc3\ +-\xc2\x4d\x6c\x4c\x34\x8b\xae\x99\xc6\xe2\xf9\xd3\x99\x35\x65\x1c\ +-\x96\x3e\xd2\x95\x56\x5f\x6c\xe4\xf7\x2f\x6d\x0c\x9b\xc2\x79\xea\ +-\xf8\x47\x5c\xb7\x34\x70\x7c\xa8\x47\x57\xd9\xe6\xf4\x38\x1c\xcd\ +-\x0e\xfc\xba\x17\x2b\x83\x33\x80\xbd\x6b\x70\x14\xa9\xfc\xec\x74\ +-\x1e\x7e\x60\x25\xf3\x67\xf4\x74\xd4\xb8\x50\x53\xcf\x6f\x9f\x5d\ +-\xcf\xde\xe2\xe3\x11\x69\x37\x36\x26\x9a\x95\x37\x2e\xe0\x4b\xb7\ +-\x2d\x22\x39\x31\x3e\x70\x01\xbc\x36\x88\x1f\x3f\x72\x1f\xb3\xa7\ +-\x4e\xe0\xe7\xbf\x5f\x8b\x18\x9c\x0d\x9a\x1a\x2e\xd2\xd6\x62\x23\ +-\x21\x29\xb9\xcf\xe7\x9c\x3a\x49\xe6\xf1\x19\xe2\xcc\x4a\x10\x76\ +-\x95\xfb\xd6\x03\x2c\x16\x63\x53\xb8\xdd\x31\xb0\xe7\x28\x5a\x63\ +-\xa2\xb8\xf7\x8e\x65\x7c\xf1\xb6\x45\x3d\x32\x84\xda\x1d\x4e\xd6\ +-\xac\x7b\x8f\xb5\x6f\xbe\x8f\xd3\xa0\x62\xeb\x0b\x4d\x53\xac\xb8\ +-\x61\x2e\x5f\xbf\xe7\x96\xa0\x07\xfe\x4a\x96\x5e\x3f\x97\x92\x4a\ +-\x37\xef\x6c\x78\xd5\x70\x7f\x2a\xce\x9e\xa4\xb0\x68\x6e\x9f\xcf\ +-\x38\x3d\x58\xcd\x28\x52\x93\x63\x60\x6e\x81\xb0\xfb\xbc\xea\x95\ +-\xc3\x3f\x26\xd6\x58\x74\x4e\x93\x6d\xe0\xa2\x86\x97\x5e\x5b\xc4\ +-\xb7\xee\xbd\x8d\xcc\xb4\x9e\x92\xbf\x6d\xcf\x61\xfe\xeb\xf9\xd7\ +-\xa9\x6b\x30\x94\x52\xcf\x2f\x93\xc6\x0c\xe7\x91\x07\xef\x60\xe2\ +-\x18\x63\xe9\x62\x6b\x5b\x15\x53\x66\x2e\xe0\xd4\x89\x63\x9c\x3d\ +-\x75\xcc\x50\x5d\x35\xd5\x15\x01\x05\x40\x74\xcc\x66\x20\x16\x20\ +-\x3d\x4e\x58\x30\x52\x38\x5a\xab\xd1\x62\xe7\x72\x8a\x57\x6b\x3f\ +-\x1d\x0f\x2e\x71\xa1\x26\xf2\xaf\x54\x05\x79\x59\x7c\xe7\x81\x95\ +-\xcc\x99\x36\xbe\xc7\xf5\x8a\xea\x3a\x7e\xfb\xec\x7a\xf6\x95\x9c\ +-\x88\x48\xbb\x89\xf1\xb1\xdc\x7f\xd7\x72\xee\xbc\x69\x81\x61\x5d\ +-\x09\xbc\x87\x59\x29\xa5\xb1\xf8\xa6\x95\x94\x9f\x3e\x6e\x68\xbf\ +-\xe1\x62\xf5\x85\x80\xcf\x78\x74\x34\x33\xc2\xe5\x39\x3e\xd5\x0a\ +-\x0b\x47\xea\x78\xc4\x9b\xee\xb5\xb1\x13\xce\x25\xf7\x6f\x3a\xbb\ +-\x44\x45\x55\xbd\xa1\xf2\x7d\x91\x10\x17\xcb\x83\x77\xdf\xc4\xed\ +-\x9f\x9b\xdf\x23\x9c\xac\xb3\xd3\xc1\x33\x7f\x7e\x87\x57\xdf\xfe\ +-\x00\x77\x98\x43\xd8\xc0\xab\x18\xaf\x5c\x3e\x9f\x07\xef\xbe\x29\ +-\xac\xf1\x8b\xd6\x28\xef\x49\x2a\x29\x69\x99\x8c\x18\x33\x91\x72\ +-\x03\xb3\x40\xc3\xc5\x1a\x44\xa4\x4f\x33\xbc\x0e\xca\x0c\xf4\x5a\ +-\xe4\x4d\xca\x7b\xee\x5e\x4e\x22\xb8\x0a\x53\x30\xb2\x22\x5d\xa8\ +-\xa9\xa7\xc9\xd6\xe6\xd3\xdc\xda\x6f\x94\xe2\xb6\xa5\xf3\x7a\xad\ +-\xb7\x22\xc2\x7b\x1f\x14\xf3\xe4\x9a\x37\xfb\x74\xba\x34\xc2\xd4\ +-\x89\xa3\xf8\xee\x83\x77\x30\x66\x78\x5e\x8f\xeb\x9d\x8e\x2e\x9f\ +-\x5b\xc7\xa1\xa0\x8b\xf7\x20\x2b\x80\x09\x93\x8b\x0c\x09\x80\xcb\ +-\xe5\xa4\xa3\xad\x95\xf8\x44\xff\x7e\x18\x1e\x8f\x57\x00\xfa\x24\ +-\x27\x33\xb5\xdf\x9d\x00\xef\xa0\x1c\x38\x7c\x92\xe5\xd7\xfb\xb6\ +-\x4e\x9d\x6b\x56\xd8\x5d\xde\x24\x47\x3a\xde\x17\xd2\x40\x5b\x47\ +-\x0f\xde\x7d\x53\xaf\x0f\xfb\xf4\xf9\x2a\x7e\xb5\x7a\x1d\x1f\x1d\ +-\x8f\x4c\xea\xd9\xb4\xe4\x44\x1e\xba\xf7\x36\x96\x5d\x37\xa3\xc7\ +-\xb7\xca\xd6\xda\xce\x1f\x5e\x7a\x8b\x98\x98\x68\x1e\xbe\xff\x76\ +-\x43\x6d\x98\x14\x8c\x4b\x17\x4e\xd6\x2b\x46\x8c\x9e\xe0\xdd\xd9\ +-\x33\xb0\x0c\xd8\x6c\x0d\x7d\x0a\x00\x78\x77\x03\x9d\x80\xd5\xdf\ +-\x03\x99\x69\xc9\x44\x99\xcd\x86\x34\xe7\xad\xbb\x4a\x7a\x08\x80\ +-\xd3\x03\xcd\x9d\xde\x63\x62\xea\x3b\x14\xb3\xf3\x85\xd6\x2e\xaf\ +-\xef\xbb\x49\x11\xf0\x50\xa7\xee\x83\xdf\xd6\xd1\xc9\xea\x97\x37\ +-\xb1\xfe\x9d\xdd\x11\xb1\x39\xf8\x73\xfd\xf6\x78\x74\x5e\x7f\x77\ +-\x37\xab\x5f\xde\x44\x5b\x47\x27\xab\x6e\xe9\x15\x74\xd3\x2f\x26\ +-\x66\x0a\x9a\x82\x13\x24\x92\x9a\x96\x41\x53\x43\xff\x75\xa8\xd6\ +-\xe6\x26\x28\x18\xed\xf7\xbe\xd9\x84\x98\x51\x38\x11\xff\x02\xa0\ +-\x69\x1a\xa3\x86\xe7\x72\xe2\x4c\x45\xbf\x3b\xb2\xa7\xe4\x38\xe7\ +-\x2e\xd4\x92\x9c\x9e\x4d\x71\xb5\xd6\x2b\xa6\xed\x70\x8d\xc2\xad\ +-\x7f\xfa\x06\xb2\xfb\xbc\xa2\x30\x0b\xb2\x13\x04\xb7\x07\xe2\xa2\ +-\xb8\x7c\xc8\x53\x5d\xbb\xa2\xc3\x05\xe9\xb1\x3a\xbb\xf6\x1e\xe2\ +-\xc9\x35\x6f\xd2\xdc\x12\x99\x37\x8d\xa2\xc2\xd1\x3c\xf2\xb5\x2f\ +-\x30\xaa\xa0\x67\x92\x8d\xd2\x63\x67\xf8\xf5\x1f\xd7\x71\xe6\x7c\ +-\x75\x44\xda\x1d\x9f\x21\xc4\x46\xc1\x3a\x83\x02\xd0\xd9\xd1\xf7\ +-\x56\xbe\x02\x31\x23\x74\x00\x7d\xce\x13\xe3\x46\xe5\x19\x12\x00\ +-\x11\xe1\xc9\x17\x36\x70\xd3\xaa\x6f\xd0\x7a\x85\x59\x20\xca\x04\ +-\xc9\x56\xa1\xae\x5d\x75\x7b\x1e\x8e\xd6\x2a\x8e\x7e\xb2\x23\x19\ +-\x65\xc2\x7b\xca\x98\xc3\xbb\x51\x55\x5b\x55\xc1\xb6\xb7\x5f\xa5\ +-\x3a\xcc\x61\xea\x97\xc8\x4c\x4f\xe6\xef\xef\xbb\x9d\x1b\xae\xe9\ +-\x19\xbb\x58\xd7\x68\xe3\xa9\x35\x6f\xb2\x65\x57\x49\x44\xda\xed\ +-\xce\xb0\x24\x61\xf2\xa8\x0c\xce\x9c\xec\x7f\x1d\x0e\x47\xdf\xbe\ +-\x8a\x9a\x86\x6e\x16\xa1\x49\x29\xfa\x34\x1c\x4f\x1a\x33\x9c\x37\ +-\xdf\xdb\xd3\xff\x9e\x00\x7b\x8a\x8f\x11\x97\xfb\x21\xd3\x67\xf7\ +-\x74\x60\x8c\x36\x43\x8a\x15\xea\xfa\x10\x56\xa7\x07\x4e\xd4\x29\ +-\xec\x9d\xed\x7c\xb0\x65\x23\x47\x8a\xf7\x46\xc4\x25\xcb\xdf\x9e\ +-\x81\xd3\xed\x66\xed\x9b\xef\xb3\x66\xdd\x7b\x03\xba\x45\x9c\x97\ +-\x6e\x4c\x71\x76\xd8\x03\x08\x80\xc2\x6d\x56\x9a\x34\xd0\x47\xea\ +-\x57\x08\x9f\x4f\xdf\xd6\xb7\x5e\xc5\xa4\x99\x98\xd2\xcd\x95\xb9\ +-\xad\x0b\x4e\x06\x48\x73\xd2\xd9\xd1\xc6\x81\x5d\xdb\x39\x7c\xe0\ +-\x43\x9c\xce\xc8\x58\x16\xaf\x29\x9a\xc8\xc3\x0f\xac\x64\x58\x4e\ +-\x46\x8f\xeb\xbb\x8b\x8f\xf1\xc4\x33\xeb\xa9\xac\x35\xee\x1b\x19\ +-\x2a\x56\x83\x6f\x15\x81\x3e\x2b\xb3\x49\xec\x66\xd0\x1a\x7a\x1e\ +-\xdf\xd4\x9b\x9c\xcc\x54\xf2\xb3\xd3\x0d\x7f\x08\x22\xc2\x3b\x6f\ +-\xbe\xcc\xb9\x33\x27\x58\xb0\xf4\x56\x52\x52\xfd\x3b\x8b\x78\x3c\ +-\x6e\xce\x9d\x3e\xc1\xc7\xc7\x0e\xf3\x71\x59\x29\x2e\x57\x64\xbe\ +-\x79\xfe\x7c\x01\x2b\x6b\x1b\x78\xe2\xd9\xf5\xec\x3e\x64\xcc\x22\ +-\x67\x04\xa3\x02\xa0\x07\xc8\x1f\x13\x63\x52\x2d\x66\x90\xa0\x16\ +-\xf7\x85\x73\xa7\xf2\xd2\x1b\xdb\x0c\x75\xe8\x12\x27\xcb\x4a\x39\ +-\x79\xec\x30\xf9\x05\x23\xc9\x1d\x36\x8a\xe4\xd4\x34\x2c\x51\xd1\ +-\x74\x39\xec\xb4\xb5\xda\x68\xb8\x58\xc3\x85\x73\xa7\x71\x76\x45\ +-\xce\x01\x33\x3a\xca\xc2\xdf\xac\x5c\xc2\x97\x6f\xbf\x81\x28\xcb\ +-\xa7\xbe\x80\x76\x87\x93\x17\xd6\xbf\xc7\xcb\x6f\x44\x66\xcf\x20\ +-\x14\x4c\x86\x77\x62\xfb\x16\x00\xb3\x46\x8d\x19\xe1\x5c\x30\x95\ +-\x2d\x5d\x50\x14\x36\x01\x00\x40\x84\xca\xf3\x67\xa9\x3c\x3f\xf0\ +-\x47\xc6\x2c\x9c\x3b\x85\x6f\xdf\x77\x7b\x2f\x1b\xc7\xd6\x5d\xa5\ +-\x3c\xb9\xe6\x0d\xea\x1a\x23\xb3\x67\x10\x2a\x46\x37\xd2\x02\x0a\ +-\x80\xd2\xcf\x99\x45\xa4\x3c\x18\xaf\xdd\x71\x23\xf3\x19\x37\x32\ +-\x9f\x8f\xcb\x07\xf5\xc4\x2c\x43\x14\xe4\x66\xf2\x9d\x07\xee\x60\ +-\xce\xf4\x9e\x7b\x06\x75\x0d\x36\x7e\xfa\xbb\x17\x23\x1a\xd7\xd7\ +-\x1f\x3a\x0d\x0a\x80\xc9\xe4\xdf\xce\x17\x1f\x05\x09\xd1\xec\x36\ +-\xeb\x16\xd3\x31\xd3\x95\x07\xf6\xf9\x61\xd5\x8a\xeb\xf9\xd7\xdf\ +-\xbd\x68\xa8\x53\x83\x41\x54\x54\x34\xd7\x5c\xff\x39\x96\x2e\x5e\ +-\xcc\xc8\x3c\x8d\x2b\x75\x9e\x13\x67\x2b\x87\xdc\xe0\x03\x74\x18\ +-\x8c\x41\x30\x59\x7a\xba\xb9\x9b\x14\x0c\x4f\xf1\x1e\xba\x99\x62\ +-\x05\x37\xda\x1b\xe6\x59\x99\x94\x97\x54\xd3\x0a\x04\x3c\xfc\x69\ +-\xc9\xb5\x45\xfc\x71\xed\x26\xc3\xb1\x82\x03\xc9\x84\xc9\x33\x58\ +-\xb4\xfc\x76\xe2\x13\x93\x68\x71\xc1\xee\xf3\x30\x3a\x15\x26\x66\ +-\x09\xa6\xa1\x1d\xae\x60\x38\x27\xc3\x88\x34\x0b\xb3\x87\x09\x36\ +-\x3b\xc4\x46\x41\x6e\x82\xf7\x68\x5e\x00\x14\x2d\xb3\x73\xa8\xd4\ +-\x94\x52\x02\x12\x94\x37\xa4\xc5\x6c\xe2\xeb\xf7\xdc\x62\xa8\x53\ +-\x03\x45\x7a\x66\x0e\x5f\xbc\xff\xdb\xac\xb8\xeb\xbe\x1e\xf6\x70\ +-\x11\x38\x51\xeb\x66\xf3\x47\x1d\x01\x93\x2c\x0e\x36\x95\x06\xc3\ +-\xf2\x32\x92\xe3\xc9\x4b\x14\x0a\xb3\x84\x91\x29\xdd\x06\x1f\x50\ +-\x22\x47\x94\x52\xa2\x01\x88\xa8\xa0\x13\x00\x2d\xbd\xb6\x88\x19\ +-\x85\x63\x0c\x75\x2c\x92\x44\xc5\x58\x59\x7c\xe3\x4a\xee\xfd\xe6\ +-\xa3\x0c\x1b\xd9\xbb\x9f\xa7\x4f\x1c\xe5\xb9\x27\xff\x83\x63\xa7\ +-\xcf\x19\x3e\xb9\x3c\x92\x88\x08\x15\x55\xc6\x7c\x29\xfa\xda\x81\ +-\x15\xa5\xf6\xc1\x27\xa1\x61\x1a\xb2\x4b\x50\xff\x10\x4c\xa5\x4a\ +-\x29\x7e\xf0\xf7\x5f\xe2\xde\xef\xfd\x62\x68\xc5\xc9\x29\x45\xe1\ +-\xb4\xd9\x2c\x5c\x7a\x2b\x71\x09\xbd\x57\xb3\xe6\xa6\x06\xb6\xbf\ +-\xfd\x5a\x0f\x4f\x1b\xdb\x10\xea\xfe\x95\x9c\xa9\xa8\xa6\xdd\x60\ +-\x46\xf4\xb4\x14\xff\xab\xba\x20\xbb\xe0\x13\x01\x10\xdd\xb4\x0b\ +-\x53\xf0\x3b\x69\xd9\x19\xa9\xfc\xf4\x91\xfb\xf8\xfe\x7f\x3c\x3d\ +-\xe8\x5e\xbf\x00\x99\xd9\x79\xdc\x70\xf3\x9d\xe4\x0f\x1f\xd5\xeb\ +-\x9e\xdb\xe5\x62\xff\xae\x2d\xec\xff\x60\x2b\x6e\x77\x4f\xd7\xef\ +-\xba\x76\x45\x63\xc7\xd0\x88\xf2\xbd\x92\x83\x1f\x19\x3f\x7a\xa7\ +-\x20\xb7\x0f\x43\x9b\xd9\xb4\x07\x3e\x11\x80\x19\x05\xaa\xba\xb8\ +-\xca\xf3\x31\x30\x2e\xd8\xca\xe7\x16\x4d\xe0\x91\xaf\xdd\xc1\xaf\ +-\x56\xbf\x36\x68\xa1\xd2\x31\xd6\x58\x16\xdc\x70\x0b\xd3\x66\xcf\ +-\x47\xa9\xde\x46\x93\x8f\x8f\x1d\xe6\xfd\xcd\xeb\x69\x6d\x69\xf6\ +-\x59\x5e\x04\x0e\x56\x69\x44\x0f\x41\x19\xd8\x57\x6a\xcc\x6b\x59\ +-\xd3\x14\x79\xd9\x19\xfe\x6e\x97\x5d\x3a\x78\xfa\xb2\x5a\x20\xc2\ +-\x26\xa5\x82\x17\x00\x80\x95\xcb\xaf\xc5\x6c\x32\xf1\x9f\x4f\xff\ +-\x39\xa8\x63\xdc\xc3\x85\x52\x8a\x29\x33\xae\xe1\xba\x25\x2b\xb0\ +-\xc6\xf5\xce\x31\xdc\xdc\x58\xc7\x96\xb7\x5e\xe5\x7c\x10\x5b\x69\ +-\x76\x17\x98\x86\x98\x32\x58\xd7\x68\xe3\xd0\x11\x63\xaf\xa5\xf9\ +-\xd9\x19\x7e\x73\x32\x09\x6c\xba\xf4\xf3\xa7\x7a\xa1\xa6\x6f\x42\ +-\xb4\xa0\xf4\x80\xee\xdc\xba\x74\x1e\xf9\x39\xe9\xfc\xe8\x37\x2f\ +-\xd0\xd4\x1c\x19\x37\xac\xee\x14\x8c\x1c\xc7\xc2\xcf\xdd\x4a\x76\ +-\x6e\x6f\x0f\x5c\xa7\xb3\x8b\xbd\x3b\xde\xe5\xd0\x9e\xed\x78\x42\ +-\xf0\x05\xec\x6b\x27\x72\x30\xd8\xfc\xfe\x01\xc3\x4b\xeb\xa4\xb1\ +-\xfe\x3d\x94\x95\xe8\x9b\x2f\xfd\xfc\x69\x96\xb0\x0e\xf3\xfb\x6d\ +-\x71\x7a\x0b\xd2\xb7\x6f\x80\x2f\x8a\x0a\xc7\xf0\xe2\x6f\x1e\xe3\ +-\x5f\xff\x67\x23\xbb\xf7\xee\x43\x24\xbc\xb3\x81\xa6\x69\x8c\x9d\ +-\x30\x95\xe9\xf3\x16\x32\x6c\xb8\x6f\x0f\x97\x13\x47\x4b\xd8\xf1\ +-\xce\xeb\xb4\xb5\x86\x6e\xc6\xad\x6a\x1b\x3a\x6f\x03\x76\x87\x93\ +-\x57\x37\x7d\x60\xb8\x9e\xc2\x71\x23\xfc\xdd\xb2\x45\xb7\x98\x2f\ +-\x37\x70\x59\x00\xc6\x8e\x55\x5d\xc5\xd5\x9e\x37\x00\x9f\xa9\x62\ +-\x03\x11\x15\x1d\xcb\xb5\x37\xdd\xcd\xf8\x59\x8b\x29\xd9\xf7\x01\ +-\xc7\x8f\x16\xe3\x30\x90\x5b\x40\xd3\x34\xf2\x86\x8d\x64\x5c\x61\ +-\x11\xe3\x26\x4d\xf3\xa9\xd9\x83\xf7\xbc\xc2\x2d\x1b\x5f\xfd\x8b\ +-\x39\xaf\xf0\xd5\xb7\x77\x86\x25\x96\xe2\x4a\x73\x77\x37\xd6\x15\ +-\x16\xaa\xcb\x5b\xab\x3d\x53\xc5\xea\xf2\x8a\x28\xd5\x2f\x01\xe8\ +-\x74\x79\xbd\x5a\x53\xd3\xb3\x58\x72\xcb\x9d\x2c\xbe\xd1\xeb\xdb\ +-\x7e\xf6\xd4\x31\xea\x6b\xaa\xa8\xaf\xab\xc6\xe5\xf4\xbf\xa5\x9b\ +-\x98\x9c\x4a\x6a\x7a\x26\x19\xd9\x79\x0c\x1b\x3e\x9a\x61\x23\xc6\ +-\x60\x89\xf2\xbf\x1d\xea\xec\x72\xb0\xfb\xfd\xcd\x14\xef\xdb\x19\ +-\xf6\xd3\x4b\x06\x8b\x8b\x0d\xcd\xbc\xf0\xfa\x56\xc3\xf5\x14\xe4\ +-\x65\x91\xe7\x27\x2f\x83\xa6\xf4\xb5\xdd\x7f\xef\x21\x00\xb6\x3c\ +-\xd3\x3b\x49\x35\x7a\x0d\xd2\xf7\x49\x53\xbe\x48\x8a\xf1\x7a\xf6\ +-\x34\x7f\xf2\xea\xaa\x99\x4c\x8c\x1e\x3f\xf9\x72\xf6\x2a\x11\xa1\ +-\xad\xd5\x86\xdb\xe9\xc4\xe5\x72\xe2\xec\xea\x22\xc6\x1a\xeb\xfd\ +-\x17\x1b\x1b\x52\x08\xda\xb9\xd3\x27\xd8\xb4\xfe\x45\x3a\xda\x23\ +-\xaf\x73\x0c\x14\x22\xc2\xcf\xff\x7b\x6d\x58\x6c\x2b\x8b\xe6\xf9\ +-\x3d\xe0\xb5\xd6\x5d\x6d\xde\xde\xfd\x42\x0f\x01\x58\xac\x94\xbb\ +-\xb8\xca\xb3\x06\x78\x2c\xd4\x46\x35\x05\x85\x59\x3a\x1f\x9e\xf3\ +-\xbd\x87\xad\x94\x0a\x3a\x8b\x55\x20\xca\x4f\x1d\xfb\x8b\x1a\x7c\ +-\x80\x35\xeb\xde\x63\xff\x61\x03\x0e\x80\xdd\xb8\x71\xa1\x6f\x17\ +-\x7c\xa5\xf8\xe3\x95\x07\x4b\xf7\x1a\x2d\xd1\xb5\xd5\x04\x72\x11\ +-\xf2\x81\xcb\x03\xc7\xeb\xff\x7a\x0f\x7b\x0a\x72\x43\xd5\x27\x5b\ +-\x77\x95\xb2\xfa\xe5\xcd\x81\x1f\x0c\x82\xa9\x13\x46\x51\x90\xe7\ +-\x33\x2b\x9b\xb8\x4d\xda\x33\x57\x5e\xec\x35\x62\x33\x87\xa9\xd3\ +-\x28\xb5\xe9\xca\xeb\x81\xf8\xa8\x56\xd1\x68\x2c\x9f\xd4\x55\x4d\ +-\x55\x8b\xc2\xd6\x0f\xcb\xed\xd6\x5d\xa5\xfc\xf4\x89\x3f\x85\xcd\ +-\x98\xe6\xff\x2c\x06\xb5\x71\x76\x96\xea\xe5\x7d\xe3\xd3\x63\x40\ +-\x74\xcf\x2f\x95\xd2\x6e\x0e\xa5\xe1\x01\x4a\x93\x3b\x64\x71\xeb\ +-\xb0\xa3\x5c\xa3\xe0\x93\xbd\xf6\xa4\x18\xef\xff\xfe\x10\x11\xd6\ +-\x6e\xdc\xc1\x53\x2f\x6c\x08\x9b\x39\xbd\x20\x37\x93\x05\xb3\x7d\ +-\x67\x0c\x15\x15\xc2\xb1\x71\x33\xf3\x2d\xdb\x8a\xab\x3c\xc5\xc0\ +-\x8c\x60\x1b\xcf\x4d\x04\x83\x39\x25\xaf\x7a\x44\xe0\x7c\xb3\xe2\ +-\x7c\xb3\x57\xe7\xb9\x7e\xa4\x4e\xb2\x0f\x21\x68\xb2\xb5\xf1\x9f\ +-\x7f\x78\x25\xec\x39\x89\xbe\x7e\xcf\x2d\x68\x5a\x6f\x9b\x86\x52\ +-\xb2\x6f\x46\xae\xf2\x69\x5c\xf0\xeb\x33\xa4\x90\x9f\x08\xea\xf5\ +-\x60\x1b\xcf\x4e\x10\xd2\xe3\xa0\xa1\x63\xe8\x18\x55\x06\x13\x11\ +-\x6f\xdc\xe3\x74\xeb\xa7\x53\xa3\xcb\xed\x61\xc3\xd6\xbd\x3c\xfd\ +-\xd2\xdb\xb4\x75\x84\x37\xc1\xf4\xd4\x09\xa3\xb8\x7e\xae\x1f\xed\ +-\xdf\xc3\x4f\xfc\x95\xf3\x2b\x00\x45\x79\xe6\x37\x8a\xab\xdd\xfb\ +-\x11\x35\x27\x98\x0e\x98\x14\x5c\x3b\x5c\x38\x7a\x11\xce\x0c\xe1\ +-\x7d\xf6\x81\xa4\xa9\x53\x01\x42\x6b\x5b\x07\x9b\x77\x1c\x64\xed\ +-\xc6\x1d\x5c\x6c\xf0\xbd\x31\x65\x84\x28\xb3\x99\x47\xbf\x71\x97\ +-\xef\x50\x70\x91\x03\xd3\xf3\x4d\x7e\x75\xba\x3e\xa3\x83\x05\xf9\ +-\x17\x85\x0a\x5a\x3d\x55\x0a\x26\x67\x09\x4d\x9d\xea\xb2\x3d\xe0\ +-\xaf\x11\xb7\xcb\x45\x7d\x5d\x35\x25\x95\xe7\xd8\xb4\xf6\x38\x87\ +-\x8e\x9c\x8a\xa8\x8b\xf9\xd7\xee\xbe\x91\x11\x7e\x8e\xae\x11\xe4\ +-\x9f\xbc\x5e\x5f\xbe\xe9\x53\x00\x66\xe6\x5a\xde\x29\xae\xd6\xdf\ +-\x46\x24\x68\x85\x50\x29\x98\x9e\xab\xf3\xfe\x59\xcd\x48\x64\xf3\ +-\x55\xc7\x91\xd2\xfd\x9c\x39\x79\x14\x87\xc3\x1e\x30\x24\x2b\x9c\ +-\xcc\x99\x3e\x9e\x2f\xdd\x76\x83\xbf\xdb\x6b\x67\xe6\x5b\xfa\xf4\ +-\xe5\x0f\xf8\xe2\x2e\x1e\xf5\x0f\x78\x43\xc8\x83\x26\x29\xc6\xeb\ +-\x7d\xfa\xd7\x84\xd3\x61\xc7\xd6\xdc\x38\xa0\x83\x3f\x72\x58\x36\ +-\x8f\x7f\xe7\x5e\x9f\x8a\x9f\x40\x9b\xa6\x6b\x3e\xcf\x7f\xee\x4e\ +-\x40\x01\x98\x39\x4c\x9d\x56\xf0\x9b\x50\x3b\x37\x21\x43\xe8\x23\ +-\x35\xde\x67\x18\x24\x33\x3d\x99\x5f\xfe\xf3\x37\x48\x8c\xf7\x9d\ +-\xa2\x46\x09\x8f\x4f\x1f\xa6\xaa\x02\xd5\x13\x94\xe9\xce\xae\x6b\ +-\x8f\x03\x21\x79\x28\xc4\x98\xbd\xd9\x2e\x3e\x23\xfc\x24\x27\xc6\ +-\xf3\x9b\x7f\xf9\x26\x99\xe9\x7e\xf3\x00\x96\xe9\xb5\xda\xef\x82\ +-\xa9\x2b\x28\x01\x98\x3f\x4c\xd9\x45\xf4\x6f\x10\xa2\x89\x78\x4c\ +-\x9a\x10\x77\xf5\x1e\x14\x36\x24\x19\x96\x93\xc1\x53\xff\xfa\x6d\ +-\x9f\x07\x58\x7d\x82\x2e\x4a\xfb\xe6\x95\x36\x7f\x7f\x04\x6d\xbc\ +-\x9f\x99\x6f\xd9\x26\xc2\x13\xc1\x3e\x0f\xde\x0d\xa2\x49\x59\x9f\ +-\xcd\x02\xe1\x62\xfa\xa4\xd1\xfc\xf7\xbf\x3d\xdc\xd7\xe0\x23\xc2\ +-\xcf\x66\xfa\x31\xfa\xf8\x22\xa4\xdd\x9b\x44\xbb\xf6\x18\x70\x38\ +-\x94\x32\x79\x49\x42\x5e\xd2\x67\x42\x60\x04\xa5\x14\xab\x6e\x59\ +-\xc8\x6f\x7f\xf4\xad\x00\x59\x48\x65\xaf\xd4\x6a\x8f\x87\x52\x77\ +-\xc0\x2c\x61\xdd\x19\x3b\x56\x75\x95\xd6\xc8\x97\x75\x5d\xdf\x07\ +-\xf4\xf6\xc6\xf4\xc3\xf4\x5c\xa1\xb1\x43\xe1\x18\xdc\x68\xeb\xcb\ +-\xa4\x65\x64\x93\x9e\x61\xec\x08\xd6\x81\x62\x58\x4e\x06\x8f\xfe\ +-\xdd\x2a\x8a\x02\x07\xe3\x34\x98\xc4\x74\xd7\x8c\x20\xa7\xfe\x4b\ +-\x84\x24\x00\x00\xd3\x73\x54\xd9\xa1\x6a\xf7\x57\x94\xa8\xd7\x08\ +-\x9c\xd1\x0d\x00\x8b\x06\x63\xd3\x85\x23\xb5\x83\x6b\x21\x8c\x8a\ +-\x8e\x61\xfe\xe2\x9b\x98\x31\xe7\xba\xa0\x8e\x55\x19\x4c\xcc\x26\ +-\x13\x5f\xbc\x75\x11\x0f\xac\x5a\x1e\xcc\x89\xab\x02\xf2\xb5\x69\ +-\xf9\x2a\xe4\xd0\xed\x90\x05\x00\x60\x66\xae\x79\x7d\x71\xb5\xe7\ +-\x57\x08\x01\xdf\x33\x2f\x91\x95\x20\x94\xd5\x2a\x06\x2b\x8c\x64\ +-\xf4\xb8\x42\x96\xae\x58\x15\x30\x83\xf6\x60\x63\x36\x99\x58\xb2\ +-\xa0\x88\xaf\xde\xb5\xdc\xe7\xd1\x75\x3e\x11\x7e\x36\x23\xdf\xfc\ +-\x66\xbf\xda\xeb\x4f\x21\x80\xa2\x1c\xed\xd1\x92\x6a\x3d\x1f\xf8\ +-\x62\x30\xcf\xc7\x47\x79\xf3\xff\x1d\xae\x55\x03\x6a\x21\xcc\xc8\ +-\xca\x63\xc9\x2d\xbe\xa3\x86\x86\x12\xb1\x31\xd1\x2c\xbb\x6e\x26\ +-\x7f\xb3\x72\x49\xa8\xc9\x39\x5f\x2e\xca\xd3\x7e\xd8\xdf\x76\xfb\ +-\x2d\x00\x4a\x29\xfd\xe0\x41\xf9\x8a\x96\x23\xc9\x20\xcb\x83\x29\ +-\x33\x22\x55\x88\x8f\x86\xd2\x6a\xef\xd9\x44\x91\x24\x3a\xc6\xca\ +-\xfc\xc5\x37\x51\x34\xe7\xba\xb0\x24\x72\x8e\x14\xe3\x47\x0f\xe3\ +-\xf3\x4b\xaf\x61\xe9\x82\x19\xc4\x5a\x43\xcd\x09\xa4\xb6\x25\x74\ +-\xaa\xfb\x95\x52\xfd\x9e\x58\xfb\x2d\x00\x00\xb3\x66\x29\xd7\x87\ +-\xf5\x72\x57\xac\x53\xb6\x03\x33\x83\x29\x93\x1e\x27\xdc\x30\x46\ +-\x28\x6f\x52\x9c\xac\x57\x38\xc3\xed\xd0\xab\x14\x93\xa7\xcf\x61\ +-\xe1\xb2\x5b\x89\x8d\x0b\x63\x7e\xe2\x30\x61\x31\x9b\x98\x3a\x71\ +-\x14\xd7\xce\x2c\x64\xfe\xac\xc2\xe0\xa7\xf9\x5e\xc8\xc1\x68\x8b\ +-\xf6\xf9\xb1\x63\x95\xa1\x34\x22\x86\x04\x00\x60\x41\x86\x6a\x3b\ +-\x58\x2d\x37\x2a\xd1\x3f\x54\xe0\xd7\x19\xbd\x3b\x9a\x82\xd1\x69\ +-\xc2\x88\x14\xa1\xaa\x4d\x71\xba\x5e\xf5\x4a\x20\xd9\x1f\xb2\x72\ +-\xf2\x59\xb2\xe2\x2e\x72\xf3\x47\x18\xaf\x2c\x4c\x58\xad\xd1\x4c\ +-\x1a\x53\xc0\xe4\x71\x23\x99\x3c\x61\x04\xd3\xc6\x8f\xec\x91\x72\ +-\xb6\x5f\x28\xce\x58\x4c\xa6\x15\x85\x99\xca\x70\x4c\x93\x61\x01\ +-\x00\x98\x95\xab\x1a\x4a\x6a\xe4\x46\xd1\xf5\x77\x81\xa0\x93\x0a\ +-\x9a\x34\x28\x48\x12\xf2\x13\x85\x13\xf5\x8a\x53\x0d\xfd\xd3\x0f\ +-\x62\xac\xb1\x5c\xb7\x64\x05\x53\x67\xcd\xef\xd7\x29\xa5\xa9\x69\ +-\x19\x4c\x2e\x9a\x47\xab\xad\x89\x56\x5b\x23\x76\xbb\x1d\x67\x97\ +-\x23\xa8\x08\x27\xb3\xc5\x42\x74\xb4\x95\xec\x8c\x24\xb2\xd3\x12\ +-\xc9\x4a\x4b\x26\x2f\x27\x83\x11\x79\x59\x0c\xcb\xcd\x20\x3b\x23\ +-\xd5\xe7\x66\x8d\x01\x4e\x81\xb6\x6c\x4a\x96\xba\x18\x8e\xca\xc2\ +-\xda\xb3\x7d\x95\x92\x66\x51\x9e\x8d\xa0\xe6\xf5\xa7\x7c\x65\x8b\ +-\xe2\x50\x55\x60\x21\xd8\xbe\x69\x1d\x87\xf6\xee\xb8\x1c\x24\xba\ +-\x70\xe9\x0a\x62\x62\x83\x36\x4b\x04\x8d\xc7\xe3\xc1\xed\xea\xc2\ +-\xe1\x70\xe0\x71\xb9\xd0\xcc\x66\x34\xa5\x88\x8e\x89\x41\xd3\xcc\ +-\x58\xa2\xbc\xb1\x0c\xf1\x51\xb0\x64\x8c\x1e\xec\xb1\xbd\x06\x90\ +-\x83\x26\x93\xe9\x96\x69\xd9\x2a\x6c\xa7\x70\x84\x65\x06\xb8\xc4\ +-\xdc\x7c\xd5\x58\x56\x27\xcb\xba\x5c\xf2\x6a\xb0\x8a\x61\x77\xf2\ +-\x93\x84\xba\x76\xa8\xb0\x05\xfe\x24\x07\x62\xba\x37\x99\x4c\x98\ +-\x4c\xb1\x44\xc7\xf4\x7d\x28\x44\x7a\x9c\x0c\xc0\xe0\xab\x6d\xce\ +-\x18\x6d\xe5\xbc\x34\x15\xd6\x80\x88\x88\x74\xbb\xac\x4c\xa2\xba\ +-\x92\xf5\xe7\x81\xbb\x43\x2d\x5b\xdb\xa6\xd8\x5b\xd1\x77\xb7\x9a\ +-\x1a\xea\x48\x49\xcb\x18\x32\x87\x52\x8f\x48\x11\xa6\xe7\x46\xf0\ +-\xdd\x56\xd4\xba\x16\x97\xfa\xf2\xe2\x91\x2a\xec\x39\x4d\xc2\x3a\ +-\x03\x5c\xa2\xb0\x50\x39\x45\xe4\xcb\xa5\xd5\x7a\x85\xc0\xf7\x09\ +-\x41\xd0\x52\xac\x12\xf0\xf1\xd4\x74\xff\x9b\x21\x03\x8d\x22\xa2\ +-\xce\x2f\x82\xf0\xb3\xa2\x3c\xf5\x43\x23\xaf\x7a\x7d\x11\xb1\x17\ +-\x64\xa5\x94\x5e\x94\x67\x7a\x0c\xf4\xcf\x01\x41\x2b\x2c\xd1\x66\ +-\xaf\x2f\x8d\x61\x08\x64\x00\x00\x02\x6f\x49\x44\x41\x54\xc1\xd5\ +-\x42\x4e\x62\xdf\xfe\xff\x06\x68\x50\xba\xac\x98\x91\x6f\xfa\x41\ +-\xa4\x06\x1f\x22\x28\x00\x97\x98\x91\x67\xd9\x62\x12\x6d\x96\x42\ +-\x3e\x0c\xb6\x4c\xd4\x55\x24\x00\x63\x23\xe1\xf4\xa2\x64\xbf\xd2\ +-\xb4\xd9\x45\xc3\xcc\x6f\x87\xbf\xf2\x9e\x0c\x88\x89\x6c\x5a\xbe\ +-\xaa\xb4\xe5\x9a\x16\x0b\xfc\x18\x02\x6f\x07\x0c\xf5\x04\x8e\x97\ +-\xc8\x88\x0b\xfb\xb7\x5f\x80\x27\xf4\x6a\xd3\x82\xa2\x1c\x75\x2e\ +-\xac\x35\xfb\x61\xc0\x3f\xea\xe2\x1a\xb9\x1e\x5d\x7f\x12\x28\xf4\ +-\xf7\xcc\x8e\xb3\xda\x90\x76\x2b\x57\x0a\xd2\x63\x85\x19\x79\x82\ +-\x35\x5c\x1e\x4f\x8a\x23\x82\xf6\x50\x28\xce\x1c\xe1\x69\x76\x10\ +-\xd8\x2e\x62\x4e\xae\xd1\x1f\xd2\x85\x9f\x2a\xe8\x65\xaf\x1d\x8a\ +-\x02\x90\x11\x27\x8c\x48\x85\x84\x28\x21\x2e\x3a\xac\xb3\x54\xa7\ +-\xc0\x2f\x62\x6c\xda\xbf\x77\xcf\xdc\x31\x50\x0c\xea\x64\x5b\x5c\ +-\x21\xb9\x68\xfa\xcf\x50\x7c\xa5\xfb\xf5\x7d\x17\x14\x35\xad\x43\ +-\x63\x1d\x48\xb1\x7a\xdd\xda\xfa\x3a\xc5\xac\xbf\x28\xd4\x46\x8f\ +-\x52\x0f\xcd\xca\x55\xfd\x3f\x90\xc9\x70\x1f\x86\x00\xc5\x95\xae\ +-\x25\x28\xf5\x23\x50\xd7\x01\x1c\xa9\x55\x83\x1e\x5e\x66\x36\x41\ +-\x51\x4e\xa4\xdc\xd9\x64\xaf\x88\xfc\x73\xa0\xa0\x8d\x81\x60\x48\ +-\x08\xc0\x25\x8a\xab\x65\x21\x22\x3f\x28\xab\x65\xf9\x60\xe7\xf1\ +-\xbd\xa6\x40\xc8\x4a\x08\xf3\xe0\x2b\xd9\xaf\x3c\xfc\x78\x20\xb4\ +-\xfb\x60\x19\x52\x02\x70\x89\x67\x0f\xca\x3d\x2d\x0e\xfe\xa3\xd9\ +-\x4e\xc1\x60\x84\x97\x59\x2d\xb0\x7c\x5c\xd8\x5e\xbd\x05\xd4\x56\ +-\x41\x7f\x62\x66\x9e\x79\x43\xb8\x2a\x0d\x17\x43\x52\x00\x2e\xf1\ +-\xec\x61\x99\x67\xb7\xf3\xef\xb6\x4e\x59\xe8\x70\xab\x01\x73\xe2\ +-\x8b\x31\xc3\x8d\xe3\x0d\x0a\x80\xa2\x06\x61\x8d\xee\xd1\x9e\x9e\ +-\x55\xa0\xce\x84\xa7\x67\xe1\x67\x48\x0b\xc0\x25\x5e\x29\x93\x28\ +-\x87\x53\xff\x5e\xab\x5d\x7b\xc0\x66\x67\xb4\xd3\x13\xf9\x7e\xdf\ +-\x3c\x41\x27\x2a\x74\x91\x6b\x56\xf0\xba\xae\xf4\xb5\xad\x39\xe6\ +-\xad\x8b\x95\x1a\x22\x7e\xd0\xfe\xb9\x2a\x04\xa0\x3b\x1b\x0e\x4a\ +-\xac\x4d\xe9\x0f\xb5\x3b\xd5\xdd\xad\x0e\x55\xd8\xe9\x8a\x4c\xae\ +-\xe7\x25\x63\x74\x12\x82\xf3\xd0\x2a\x43\xb1\x19\xd1\x37\x47\xdb\ +-\xcc\x3b\x07\xe3\x55\xce\x08\x57\x9d\x00\x5c\xc9\x9a\xc3\x32\xd9\ +-\xe9\xd2\xbf\xea\x74\xa9\xc5\x76\x37\xa3\x3b\x9d\x2a\xc1\x65\x70\ +-\x86\x48\xb1\xc2\x75\xa3\xf4\xde\x66\x52\x45\x8b\x12\x39\x82\x52\ +-\x07\x74\xe4\xc3\x28\x93\x69\x57\xb8\x1c\x33\x06\x8b\xab\x5e\x00\ +-\x7a\x21\xa2\x9e\x29\x61\xa1\x86\x7e\x9d\xcb\xc5\x14\xa7\x68\xa3\ +-\x3c\x3a\x99\x2e\xb7\x24\xba\x45\xc5\xb8\xdd\x58\x04\x34\x5d\xc0\ +-\xad\x7b\x77\x94\x2d\x1a\xa2\x29\x44\x53\xe8\x9a\x26\xee\x59\xf9\ +-\x1c\x4e\x8e\x91\x72\x81\x0b\x4a\x28\x17\x4d\x2f\x57\x98\x8f\xcf\ +-\xc8\x55\x91\x39\xac\x78\x10\xf9\x3f\x06\x8e\x97\x48\x80\x7c\xb0\ +-\xcc\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\ +-\x00\x00\x9a\xb3\ +-\x89\ +-\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\ +-\x00\x02\x00\x00\x00\x02\x00\x08\x06\x00\x00\x00\xf4\x78\xd4\xfa\ +-\x00\x00\x00\x04\x73\x42\x49\x54\x08\x08\x08\x08\x7c\x08\x64\x88\ +-\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0d\xd7\x00\x00\x0d\xd7\ +-\x01\x42\x28\x9b\x78\x00\x00\x00\x19\x74\x45\x58\x74\x53\x6f\x66\ +-\x74\x77\x61\x72\x65\x00\x77\x77\x77\x2e\x69\x6e\x6b\x73\x63\x61\ +-\x70\x65\x2e\x6f\x72\x67\x9b\xee\x3c\x1a\x00\x00\x20\x00\x49\x44\ +-\x41\x54\x78\x9c\xec\xdd\x77\x78\x5c\xe5\x95\x3f\xf0\xef\x7b\x67\ +-\xd4\xbb\x2c\xc9\x2a\x96\xdc\x3b\x6e\xb2\xc1\xc6\xa6\x98\xde\xc1\ +-\x18\x30\xa1\xf7\x40\x1a\x09\xd9\xdd\xb4\xcd\x66\xbd\xc9\x66\xb3\ +-\xbf\x4d\x02\x29\xd4\xd8\xc6\x14\x63\xc0\x60\x63\xc0\x31\xee\x06\ +-\xf7\x22\xc9\x72\x91\x9b\x24\xcb\xb2\x7a\xd7\xf4\x76\xef\x3d\xbf\ +-\x3f\x06\x83\x8b\xca\x48\x9a\xb9\x77\xca\xf9\x3c\x4f\x9e\x80\x34\ +-\xba\xef\x41\x65\xde\x73\xdf\x7b\xde\xf3\x0a\x30\xc6\x82\xda\xda\ +-\xb5\x14\x63\xce\xc3\x68\x08\x8c\x54\x14\x75\x98\x42\xc8\x96\x15\ +-\x0c\x56\x49\xca\x50\x55\x4a\x57\x48\xa4\xc8\x2a\x25\x79\x54\x11\ +-\x07\xc0\x08\xc0\xa8\x10\x19\x05\xc1\xa0\x02\x92\x4a\x30\x00\x80\ +-\xa2\x08\x10\x20\x08\x10\xb2\x0a\x10\x01\x42\x00\x51\x12\x40\x00\ +-\x24\x40\x35\x18\x08\x00\x60\x14\x82\x84\x80\x4c\x44\x30\x1a\x84\ +-\x8b\x54\x22\x49\x12\xee\x28\x03\x39\x8d\x06\x61\x33\x08\x32\x1b\ +-\x25\x74\x18\x04\xb5\x19\x0d\x52\xb3\x41\xa8\x8d\x31\x46\xaa\x8f\ +-\x8d\x36\x9c\xca\x88\x46\x95\x29\x1f\xcd\xd7\x08\x21\xeb\xf7\x5d\ +-\x63\x8c\xf5\x46\xe8\x1d\x00\x63\x91\x6c\x75\x05\xe5\xbb\xad\x98\ +-\xe1\x94\xd5\x49\xb2\x8a\xb1\xb2\x2a\x0d\x75\xab\xc8\x71\x2b\x94\ +-\xee\xf6\x20\xde\xa3\x8a\x28\x8f\x1a\x5a\x7f\xa7\x42\x00\x31\x06\ +-\xe0\x8a\x61\x6a\x7b\x62\x0c\x1a\x20\xa8\x45\xa8\xa2\x96\x04\xea\ +-\x08\xa8\x05\xa8\x5a\x22\x43\x8d\x22\xa1\x76\x46\xae\x68\xd5\x3b\ +-\x5e\xc6\x22\x55\x48\xbd\xb1\x30\x16\x6a\x56\x10\x19\x94\x43\x98\ +-\xe1\xf6\xa8\x73\x5d\x0a\x0a\x3d\xaa\x34\x4a\x56\x28\xc7\xa3\x8a\ +-\x54\x97\x8c\x58\x97\x1c\xbe\x7f\x83\x39\xc9\x84\x99\xf9\xd4\xdb\ +-\xcb\x1c\x10\xa8\x20\x12\x95\x00\x55\x80\x50\x21\x84\x5a\x29\x24\ +-\x63\xc5\xd4\x6c\x9c\x11\x42\xa8\x5a\xc4\xca\x58\x24\x0a\xdb\x37\ +-\x1f\xc6\xb4\xf6\xee\x41\x2a\x94\x9d\xea\x0d\x1e\x21\xcd\x74\x7b\ +-\x68\xbc\x5b\x15\xb9\x76\x0f\x92\xdc\x61\x3c\xc9\xf7\x44\x08\xe0\ +-\xba\x51\x2a\x12\xa3\xfb\x7d\x09\x37\x80\x0a\x08\x51\x46\x44\x47\ +-\x25\xa2\x32\x61\x30\x1c\x3d\x99\x8d\xe3\x0b\x84\x50\xfc\x17\x29\ +-\x63\x91\x29\x22\xdf\x98\x18\x1b\x88\x37\x8a\x28\x3e\x5a\xc1\x6d\ +-\x32\x70\x9b\x4b\xa6\x19\x4e\x19\x05\x0e\x59\x24\x7a\x14\xfe\x7b\ +-\xba\xd0\xd0\x54\xc2\xb4\xbc\x5e\x57\x01\xfa\x46\xc0\x03\x42\x39\ +-\x08\xc5\x42\x42\xb1\x02\xa9\x18\x40\xc9\x8c\x5c\x61\xf7\xef\x40\ +-\x8c\x85\x37\x7e\xc3\x62\xac\x07\x2b\x88\x0c\x9e\xc3\xb8\x49\xf6\ +-\xa8\xf3\x1c\x2e\x31\xdb\xae\x60\xb8\xc5\x29\xe2\x15\x3f\xcf\x69\ +-\xe1\x4a\x08\xe0\xb2\x21\x84\x9c\xe4\x80\x7f\xc3\x64\x00\x47\x01\ +-\xec\x03\x68\x8f\xc1\x60\xd8\x3b\x79\x30\x8e\xf2\x23\x04\xc6\xba\ +-\xc7\x09\x00\x63\xe7\x78\xa3\x88\x0a\x62\x49\x7d\xc2\xa1\x48\xd7\ +-\x39\x15\x4c\xb0\x3a\x91\xee\xe6\x3b\xfb\x01\x91\x04\x70\xa9\x36\ +-\x49\xc0\x85\xcc\x80\xd8\x2f\x04\xed\x21\x41\x3b\xed\x46\xc3\x8e\ +-\x2b\x32\x85\x45\xeb\x20\x18\x0b\x56\xfc\xc6\xc6\x22\xda\xf2\xc3\ +-\x34\xd8\xe5\x52\x9f\x70\x79\xc4\x3c\xab\x5b\x4c\xb4\xb8\x91\x48\ +-\x7c\x77\xef\x77\x02\xc0\x98\x4c\xc2\xf8\x2c\x5d\xbf\xb9\x0a\x80\ +-\x13\x82\xb0\x03\xa0\x4d\x8a\x64\xd8\xca\xbb\x10\x58\x24\xe3\x04\ +-\x80\x45\x94\x65\xe5\x94\x2c\xcc\xea\x53\x76\x45\xba\xc7\xe2\xa4\ +-\xa9\x66\x97\x48\x50\x79\xc2\xd7\xcc\xc4\xc1\x84\xd1\x19\x41\xf3\ +-\x0d\x57\x09\x38\x28\x01\x1b\x09\xea\x46\x93\xdb\xb8\xe3\x9a\xe1\ +-\xc2\xa9\x77\x50\x8c\x69\x85\x13\x00\x16\xf6\xde\x2d\xa6\x05\x0e\ +-\x0f\x3d\x66\x77\x8b\x99\x66\x37\x06\xc9\xfc\x54\x58\x37\x71\x51\ +-\xc0\x4d\x63\x82\xf6\x07\xe0\x20\x88\xed\x12\x68\xa3\xa2\x4a\xeb\ +-\x67\xe4\x8b\xc3\x7a\x07\xc4\x58\x20\x71\x02\xc0\xc2\xce\x3b\x07\ +-\x29\x41\x52\xd5\x67\x6c\x2e\xf1\x70\x87\x03\x53\xec\x1e\x61\xd4\ +-\x3b\x26\xe6\x65\x94\x80\xdb\xc7\x07\x6d\x02\x70\xa1\x6a\x41\x58\ +-\xaf\x0a\x5a\x63\x76\x1b\x36\xf2\xea\x00\x0b\x37\x9c\x00\xb0\xb0\ +-\xf0\xce\x41\x1a\xae\xb8\xd5\x9f\xdb\x3c\xd2\x6d\x1d\x0e\xe4\xf1\ +-\x96\xbc\xe0\x14\x6d\x00\x6e\x1d\x17\x32\x09\xc0\xb9\x6c\x02\x62\ +-\x03\x48\xfd\x2c\x9a\x0c\x9f\x4d\xcc\x17\xed\x7a\x07\xc4\xd8\x40\ +-\xf1\x9b\x24\x0b\x59\xcb\x8b\x68\x9c\x83\xf0\x82\xc5\x8d\xbb\x4c\ +-\x76\x0c\xe6\xad\x79\xc1\xcf\xc7\xee\x80\xc1\x4e\x01\x68\x8f\x10\ +-\xe2\x23\xc5\x2d\xad\x98\x31\x4c\x34\xe8\x1d\x10\x63\xfd\xc1\x09\ +-\x00\x0b\x29\xcb\x0e\xd1\x24\x9b\x13\x0b\x2d\x76\xba\xd1\xec\x16\ +-\x89\x7a\xc7\xc3\xfa\xe6\xf2\x02\xc2\xe0\xa4\x90\x4f\x00\xce\xa5\ +-\x00\xb4\x93\x20\x56\x08\x49\x5a\x51\x98\x23\x5a\xf4\x0e\x88\x31\ +-\x5f\x71\x02\xc0\x82\xde\x6b\x3b\x29\xcb\x18\xa5\xfe\xc6\xea\x92\ +-\x16\x74\x3a\x91\xc9\xdb\xf4\x42\x53\x4e\x12\x61\x66\x41\x58\xff\ +-\xf0\x14\x80\xf6\x90\x10\xef\x38\xa2\xa4\xf7\xb9\xe7\x00\x0b\x76\ +-\x9c\x00\xb0\xa0\xf4\x46\x11\xc5\x47\xab\xea\x2f\xac\x1e\xf1\x78\ +-\xbb\x5d\xe4\xf3\xf2\x7e\x68\x8b\x8f\x02\xe6\x8e\x54\x11\x6d\xd0\ +-\x3b\x12\xcd\xd8\x01\x7c\x26\x88\x96\x95\xe7\x19\xd6\xf1\xd9\x05\ +-\x2c\x18\x71\x02\xc0\x82\xca\xd2\x7d\x34\xdf\xa6\xe0\x67\x26\x3b\ +-\x66\xb8\x14\x44\xce\x74\x11\xc6\x24\x00\x57\x0c\x57\x91\x1e\xaf\ +-\x77\x24\x3a\x11\x68\x00\xe1\x23\x52\xa5\x25\xd3\xf3\xc5\x21\xbd\ +-\xc3\x61\xec\x2c\x4e\x00\x98\xee\x76\xb4\x50\x12\xd9\xd5\x27\x0e\ +-\xd4\x88\x85\xad\x76\x91\xa6\x77\x3c\xcc\xbf\xc6\xea\xdf\x01\x30\ +-\x88\xd0\x4e\x00\x4b\x63\xa2\x0c\x1f\x4e\xcc\x12\x56\xbd\xa3\x61\ +-\x91\x8d\x13\x00\xa6\x9b\xa2\x7a\x1a\x27\x91\xfa\x78\xb3\x4d\x7c\ +-\xff\x50\xbd\x48\xb2\xba\xf5\x8e\x88\xf9\x5b\x94\x04\xdc\x34\x56\ +-\x85\x51\xd2\x3b\x92\xe0\x42\x80\x45\x22\xbc\x4f\x90\x5e\x2d\x1c\ +-\x22\x0e\xea\x1d\x0f\x8b\x4c\x9c\x00\x30\xcd\xdc\xb7\x82\x0c\x57\ +-\x66\x23\xfd\xca\x11\xca\x5c\x59\x48\xcf\xb6\x5a\x70\x5d\x55\x07\ +-\xd0\x68\xe1\x5f\xc3\x70\x35\x24\x85\x30\x63\x08\xdf\xfd\xf7\xa2\ +-\x98\x04\xfe\xe1\x52\xa4\x77\x67\xe7\x0b\x87\xde\xc1\xb0\xc8\xc1\ +-\xef\xbc\x2c\xe0\x7e\xf6\x29\x25\xa5\x27\xe1\x05\x99\xf0\x82\x42\ +-\x48\x89\x96\x20\x5c\x32\x10\x92\xed\x60\x22\x5c\x7c\x34\x30\x24\ +-\x99\x90\x12\x0b\x78\x14\xa0\xde\x02\x34\x5b\xbb\x7f\x1b\x99\x94\ +-\x4d\x18\x39\x88\x13\x00\x1f\x35\x43\xe0\x1f\xaa\x5b\x7a\x95\x7b\ +-\x0b\x30\x2d\x70\x02\xc0\x02\x66\xe1\x46\x2a\x88\x33\xe0\xbf\x9d\ +-\x0a\xee\x57\x08\xd1\x7a\xc7\xc3\xfa\x2f\x29\x06\x18\x93\x41\x18\ +-\x92\x42\x10\x17\xbc\x6b\x1c\x6a\x10\x38\xd5\xde\xf5\x5b\xc9\x94\ +-\x5c\xc2\xf0\x34\x4e\x00\xfa\xc8\x0d\x21\x3e\x85\x2a\x5e\x2a\x1c\ +-\x22\x76\xeb\x1d\x0c\x0b\x5f\x9c\x00\x30\xbf\xfb\xed\x16\x9a\x19\ +-\x6b\xc0\x9f\xad\x6e\xcc\x06\xf1\xef\x58\x28\x33\x1a\x80\x71\x99\ +-\x84\x11\x83\x08\xdd\x3d\xc6\x3f\xde\x22\x70\xbc\xf9\xe2\x1f\xb3\ +-\x80\xb7\xfa\x7f\x50\xa4\x56\xff\xfb\x81\x00\xed\x50\x05\x5e\x2a\ +-\xcc\x31\xac\x16\x42\xf0\xa2\x19\xf3\x2b\x7e\x73\x66\x7e\xb1\x70\ +-\x21\x49\x62\x36\xee\x89\x8e\xc2\xef\x1c\x1e\x8c\xd5\x3b\x1e\x36\ +-\x30\x42\x00\x43\xd3\x08\xe3\x32\x09\xb1\x3d\x1c\xa5\xe4\x56\x80\ +-\x2f\x4f\x49\xb0\x5f\x50\xc0\x29\x00\x4c\x08\xae\xa3\x7f\x43\x9a\ +-\x20\x9c\x82\x84\xbf\x75\xba\xa4\x37\xf8\x50\x22\xe6\x2f\x9c\x00\ +-\xb0\x01\x59\xb8\x82\xa2\xa5\x41\xf8\xbe\x00\xfe\xdd\xa3\x20\x43\ +-\xef\x78\xd8\xc0\x65\x25\x12\x2e\xc9\x26\x24\xc7\xf4\xfc\x3a\xb3\ +-\x13\x28\xaa\x95\x60\x76\x9d\xff\xf1\x28\x09\x98\x3e\x84\x90\x1d\ +-\x5e\x2d\x7f\x83\x45\x13\x01\xaf\x4b\x6e\xe9\x2f\xd3\x86\x8b\x4e\ +-\xbd\x83\x61\xa1\x8d\x13\x00\xd6\x2f\x0b\x57\x50\x74\x54\x06\x7e\ +-\xa0\x12\xfe\xd3\xa3\x20\x45\xef\x78\xd8\xc0\xa5\xc5\x01\xe3\xb2\ +-\x08\x83\x13\x7b\x9e\xb8\x89\x80\x8a\x76\x81\xe3\x4d\x02\x17\x76\ +-\x68\x34\x08\xe0\xaa\x11\x2a\x52\x62\x03\x18\x28\x03\x80\x4e\x00\ +-\x7f\x33\xca\xd2\x5f\x26\x0f\x15\x1d\x7a\x07\xc3\x42\x13\x27\x00\ +-\xac\x4f\xbe\x5b\x44\x51\x05\x26\xfc\x80\x80\xff\xf4\x28\x48\xd5\ +-\x3b\x1e\x36\x30\xb1\x46\xef\x1d\xff\xd0\x34\xf2\xe9\x59\xbd\xac\ +-\x02\xfb\x6b\x04\x9a\xba\xa9\xfc\x1f\x9a\x46\x98\x96\xcb\x77\xfe\ +-\x1a\xb2\x02\x78\x25\x46\x95\xfe\x8f\x8f\x28\x66\x7d\xc5\x09\x00\ +-\xf3\xc9\x77\x8b\x28\x6a\x98\x19\xdf\x53\x88\xfe\xcb\xa3\x08\x9e\ +-\xf8\x07\xc0\x28\x01\x83\x12\x08\x83\x13\x81\xd4\x38\x42\x8c\x01\ +-\x88\x36\x7a\xef\xac\x01\x40\x56\x00\x97\x02\x98\x9d\x02\x56\x37\ +-\xd0\x6a\x13\xe8\xe8\x62\x77\x78\xac\x11\xc8\x4b\x21\xa4\xc7\x01\ +-\x49\x31\x84\x18\x23\xce\xab\xd0\x97\x15\xc0\xad\x7a\xff\x5f\x56\ +-\xcf\xbf\x5b\x8f\x92\x80\xb8\x28\x42\x52\x2f\xcb\xfc\xe7\x72\x2b\ +-\xc0\xee\x6a\xa9\xcb\x58\xce\x9a\x30\x98\x30\x86\x9f\xfb\xeb\xc1\ +-\x0a\xe0\xcd\x28\xa3\xf4\x3f\x93\x06\x8b\x26\xbd\x83\x61\xa1\x81\ +-\x13\x00\xd6\xa3\x85\x5b\xc9\x68\x00\x9e\x82\x82\xff\xf1\xa8\x48\ +-\xd7\x3b\x9e\x50\x66\x10\xc0\xa8\x0c\xc2\xa8\x0c\x42\x54\x1f\x3b\ +-\xe3\xb5\x3b\x80\xbd\x67\x24\xb8\x64\xef\xbf\x8f\x1c\x44\x98\x30\ +-\x98\x60\xd0\xe8\x2f\xd8\xe1\x01\x76\x55\x4b\xb0\xb8\x7a\x7e\xdd\ +-\x88\x74\xc2\xe4\x1c\x4e\x00\x74\x64\x05\xf0\x8a\xea\x94\xfe\x30\ +-\x63\xa4\x30\xe9\x1d\x0c\x0b\x6e\xdc\xa0\x93\x75\x8d\x48\xfc\xd7\ +-\x7a\x7a\xcc\xa0\xa2\xce\xe3\xc1\xeb\x3c\xf9\x0f\x4c\x8c\x11\xb8\ +-\x72\xb8\x8a\xf1\x59\x7d\x9f\xfc\x01\x20\x3d\xce\xdb\x55\xef\x2c\ +-\x01\x68\x36\xf9\x5b\x5c\xc0\xb6\xaa\xde\x27\x7f\x00\xa8\x35\x09\ +-\x38\x3c\x81\x8f\x89\x75\x2b\x11\xc0\xcf\xa5\x58\xb5\xb2\xa4\x4e\ +-\xf9\xf9\xd6\x2a\xe2\x6a\x0c\xd6\x2d\x5e\x01\x60\x17\xf9\xaf\x4d\ +-\x74\x4d\x94\x84\x37\x9d\x32\x86\xe9\x1d\x4b\x38\x90\x04\x70\xd5\ +-\x70\x15\xa9\x71\x03\xbb\x4e\x55\x87\xc0\xc1\xfa\x6f\xff\x64\x53\ +-\xe3\x80\xb1\x19\x84\xec\xe4\xc0\x35\x5b\xb0\xb8\x80\x1d\xa7\xbf\ +-\x5d\x79\xf0\x45\x8c\x11\xc8\x4f\x21\x64\x26\x02\xf1\x51\xde\x47\ +-\x13\x11\x74\x0c\x70\xb0\x39\x43\xa0\x85\x95\xb9\x86\x77\xf8\x48\ +-\x62\x76\x21\x4e\x00\xd8\x37\x7e\xbd\x81\x46\xc7\x1b\x69\xa9\x53\ +-\x16\x73\xf4\x8e\x25\x9c\x0c\x4b\x23\x4c\xf5\x43\x61\x9c\xc9\x09\ +-\x6c\xad\xbc\x78\xf9\x20\x23\x01\x98\x59\xa0\xf6\x6b\x65\xa1\x27\ +-\x66\xa7\x77\xd9\xdf\xd9\x87\xc9\xbf\x3b\x06\x09\x48\x8e\xf1\xae\ +-\x62\x0c\x4d\x23\x3e\x1c\x48\x7b\xc7\x49\xa8\x2f\x4c\xcf\x8d\x5a\ +-\xa7\x77\x20\x2c\x78\x70\x02\xc0\xb0\x70\x1d\xa5\xc7\xc6\xe2\x25\ +-\x87\x07\x0f\x53\xf7\x0d\xdf\x58\x3f\x4d\xcf\x23\xe4\xa7\xfa\xe7\ +-\xb9\x78\x69\x83\xc0\xe9\x2e\xda\xee\xfa\xbb\xf8\xce\xec\x02\x76\ +-\xf6\xf1\xce\xdf\x57\xa9\xb1\xc0\x95\x23\x54\xcd\x1e\x61\xb0\x6f\ +-\x09\x88\x35\x8a\x22\x7e\x32\xa3\x40\x54\xea\x1d\x0b\xd3\x1f\xff\ +-\x09\x46\xb0\x85\x2b\x28\x3a\x26\x13\xbf\xf4\x28\xf8\xa5\xac\xa2\ +-\x0f\xf5\xe0\xac\xaf\x92\x63\x81\x84\x68\xef\x9d\xaf\xa2\x7a\x0f\ +-\xd2\xf1\xa8\x02\x1e\x19\x20\x01\xc4\x18\x80\xb4\x38\xc2\xc8\x0c\ +-\x42\x42\x54\xcf\xd7\xaa\x33\x79\x7b\xef\x77\x38\x00\x95\xbc\xcb\ +-\xeb\xa3\x06\x11\xc6\x64\xfa\x27\x01\x30\x3b\xbd\xcb\xfe\xee\x00\ +-\x2e\x18\xf3\x21\x41\xba\x72\x01\xf8\x8b\x3d\x5a\xfa\xfd\x15\x99\ +-\xc2\xa2\x77\x30\x4c\x3f\x9c\x00\x44\xa8\xdf\x6d\xa2\x7b\x85\x84\ +-\x57\xdd\x32\x32\xf5\x8e\x85\x7d\x2b\x4a\x02\xe6\x8e\x54\x91\xa0\ +-\xd3\xd1\x49\x76\x0f\xb0\xfd\x94\x04\x47\x00\xee\xfc\xcf\x95\x9b\ +-\x4c\xb8\x2c\x9f\x13\x00\x9d\xb5\x0a\x81\xff\x2e\xcf\x91\x5e\xe6\ +-\xfa\x80\xc8\xc4\x09\x40\x84\xf9\xf5\x17\x34\x36\x36\x16\xef\xbb\ +-\x3d\x98\xa6\x77\x2c\xac\x6b\xc3\xd2\x09\x53\x75\xd8\x4a\xe7\x92\ +-\x81\xed\x55\x12\xac\xee\xde\x5f\x3b\x50\xfe\xaa\x8b\x60\x7e\x51\ +-\x02\x21\xbd\x50\x98\x2b\xb6\xe9\x1d\x08\xd3\x16\x27\x00\x11\x62\ +-\xe1\x56\x8a\x8d\x06\xfe\xe0\x91\xf1\x23\x85\xc0\x35\xd9\x41\x4a\ +-\x08\xe0\x8a\xa1\x2a\x06\x25\x68\x3b\xae\xac\x00\xdb\xab\x25\x98\ +-\x7a\x68\xf2\xe3\x4f\x53\x72\x08\xc3\xd3\x39\x01\x08\x26\x02\x62\ +-\x8d\x64\x10\xcf\x4f\xc9\x16\x55\x7a\xc7\xc2\xb4\xc1\x05\x5f\x11\ +-\xe0\x77\x1b\xe8\x56\xa3\x8a\x5a\xa7\x07\x3f\xe1\xc9\x3f\xb8\x8d\ +-\xcb\x24\xcd\x27\x7f\x22\x60\x5f\xad\xd0\x6c\xf2\x17\x00\x1f\x14\ +-\x14\x84\x08\x74\xbb\xa2\xa8\x47\x0e\xd4\x29\xff\xb6\x95\xa8\x87\ +-\x33\x20\x59\xb8\xe0\x15\x80\x30\xf6\xab\x75\x94\x93\x18\x8d\x37\ +-\x9d\x32\x6e\xd6\x3b\x16\xd6\xbb\xa1\xa9\x84\xa9\x79\x81\xdb\xd3\ +-\xdf\x9d\xc3\x8d\x02\x95\x6d\xda\x8d\x9a\x16\x07\x5c\x3d\x82\x8f\ +-\xb6\x0f\x72\x07\x85\x24\x3d\x33\x2d\x47\xec\xd7\x3b\x10\x16\x38\ +-\x9c\x00\x84\xa1\x85\x0b\x49\xc2\x95\x78\x52\x22\xfc\x4d\x56\x31\ +-\xc0\xf6\x33\x4c\x0b\x39\x49\xde\xa2\x38\xa1\xf1\x5f\x64\x4d\xa7\ +-\x40\x71\x9d\xb6\x83\x4e\xc8\xf2\xdf\x8e\x05\x16\x50\x32\x80\x57\ +-\x0d\x06\xe9\x57\x53\xb2\x85\x4d\xef\x60\x98\xff\xf1\x23\x80\x30\ +-\xb3\x70\x03\x4d\x95\xae\xc0\x61\x55\xc1\x22\x9e\xfc\x43\x43\x66\ +-\x02\xe1\x52\x1d\x26\x7f\x93\x03\x28\xad\xd7\xfe\x1e\xa0\xc3\xa9\ +-\xf9\x90\xac\x7f\x8c\x00\x9e\x57\x65\xf5\x50\x49\x9d\xe7\x7a\xbd\ +-\x83\x61\xfe\xc7\x09\x40\x18\x39\x50\x45\xa9\x83\x93\xe8\x5d\x59\ +-\xc5\x04\xbd\x63\x61\xbe\x49\x8e\x05\x66\x16\x10\x24\x1d\xd6\xe2\ +-\xa2\x0c\xde\x53\x09\xb5\xd6\x60\x16\x68\xb1\xf1\xe2\x63\xa8\x20\ +-\x81\x11\x80\xb4\xa1\xa4\x56\x79\x67\x6f\x2d\x0d\xd2\x3b\x1e\xe6\ +-\x3f\xfc\x57\x18\x26\x8a\xeb\xe4\x3b\x04\xc4\x6b\x0e\x0f\xf2\x36\ +-\x96\x4b\x50\x79\x85\x35\xe8\x49\x02\xb8\x76\x94\x8a\x44\x9d\xf6\ +-\xfc\x9f\x65\xf3\x00\x1d\x76\xef\x21\x3e\x17\x36\xff\x91\x55\x6f\ +-\xb3\x21\xa7\x07\x30\xbb\xfc\x77\xd0\x4f\x4e\x32\x61\x26\xf7\x01\ +-\x08\x45\x4d\x20\xfa\x59\xe1\x10\xe3\x3b\x7a\x07\xc2\x06\x8e\x13\ +-\x80\x10\x57\x72\x86\x72\x61\xa0\xd7\x01\xba\xe3\xec\xc7\x76\x55\ +-\x0b\x34\x5b\xf9\x47\x1b\xec\x46\x0f\x22\x4c\xcc\x0e\xad\x49\xd0\ +-\xad\x00\x66\xa7\x80\xc9\xe9\x6d\x17\xec\xf0\x00\x4e\x59\xc0\xe1\ +-\x06\x3c\x7d\xa8\xeb\x8b\x31\x02\xb7\x8c\xe5\x42\xc0\x50\x45\x10\ +-\xab\xc9\x23\xbe\x3f\x63\x98\x68\xd0\x3b\x16\xd6\x7f\x3c\x4b\x84\ +-\xb0\xe2\x7a\xf9\x6e\x41\x62\x11\x80\xf3\x96\xe5\x0e\x35\x78\x5b\ +-\xc5\xb2\xe0\x76\xc3\x18\xb5\xd7\xb6\xbf\xa1\xc4\xad\x00\x76\x37\ +-\xd0\x66\x17\xa8\x6c\x17\xb0\xf7\xd0\x50\xc8\x20\x80\x3b\x26\x70\ +-\x02\x10\xe2\x5a\x05\xe8\xe9\x69\x79\xc6\x4f\xf5\x0e\x84\xf5\x0f\ +-\xd7\x00\x84\xa0\x5d\x35\x14\x57\x52\xa7\xfc\x55\x90\x58\x85\x0b\ +-\x26\x7f\x00\x01\x39\xc0\x85\xf9\x57\x7c\x34\xc2\x6a\xf2\x07\xbc\ +-\x67\x12\xa4\xc6\x01\x23\x07\x11\xae\x1d\xa9\x62\x70\x0f\x7b\xfd\ +-\xf5\x6a\x75\xcc\xfc\x2a\x83\x20\x56\x97\xd4\x2a\xef\x94\x35\x53\ +-\xa2\xde\xc1\xb0\xbe\xe3\x04\x20\xc4\x94\xd4\xd3\x8c\x58\x49\x2d\ +-\x05\xf0\x7c\x57\x9f\xb7\xb9\x81\x06\x0b\xdf\xfd\x07\x3b\x63\x98\ +-\xff\x88\x8c\x12\x30\x2b\x9f\x30\xa2\x9b\x6e\x7f\x63\x79\x1b\x60\ +-\xf8\x10\x78\xc4\xe9\x51\x8b\x8a\xeb\x69\xba\xde\xa1\xb0\xbe\x09\ +-\xf3\xb7\xa1\xf0\x41\x44\xa2\xb4\x41\x7d\x9e\x08\xff\x07\xa0\xcb\ +-\xfb\xa7\x56\x9b\x77\x4f\xb7\xbf\x0a\xb5\x58\xe0\x24\x46\x03\xd7\ +-\x8f\xf6\xef\x12\xb8\x4a\x00\x44\xf0\x65\xf5\x75\x66\x81\x53\x6d\ +-\x02\x2e\x19\x88\x8f\x26\x8c\x1c\x04\x0c\x4e\xe4\x04\x20\x0c\xc9\ +-\x04\xfc\xbe\x32\x57\xfa\x1d\x1f\x2e\x14\x1a\x38\x01\x08\x01\xfb\ +-\xea\x28\xdf\x48\xca\xbb\x10\xe2\x6a\x59\xf5\x56\x64\x3b\x65\x01\ +-\xab\x0b\xb0\xb8\x01\x8b\x0b\xb0\xba\x7b\x7e\xe6\xca\x82\x8b\x10\ +-\xc0\x8d\x63\x54\xc4\xf9\xa1\xe1\x6a\x93\x45\xe0\x58\x8b\x40\xa7\ +-\x03\xc8\x4f\x25\x4c\xcf\xe3\xc9\x95\xe9\x87\x84\xd8\x6a\x54\xc5\ +-\xa3\x53\x86\x88\x5a\xbd\x63\x61\x3d\xe3\x04\x20\xc8\x2d\xde\xa7\ +-\xfc\xa5\xcd\x2e\xfd\x50\x56\x61\x50\x54\xef\xb6\x2c\x16\x1e\x06\ +-\x7a\x22\x1e\x01\x38\xda\x28\x50\x7e\x4e\x1b\x5f\x01\xe0\x9a\x91\ +-\x2a\x92\x63\x07\x1e\x1f\x63\xfd\x26\x60\x12\xa0\xef\x4f\xcb\x35\ +-\x2e\xd7\x3b\x14\xd6\x3d\x4e\x00\x82\xd4\x3b\x15\x94\x65\x6d\xc5\ +-\xf6\x46\x33\xc6\xe8\x1d\x0b\x0b\x9c\x59\x05\xd4\xaf\x83\x71\x88\ +-\x80\xd2\x06\x81\xea\x8e\x8b\xff\x84\xa7\xe6\x12\x86\xa5\xf1\x2a\ +-\x00\x0b\x0a\x6f\xc6\x44\x49\x3f\x9e\x98\x25\xac\x7a\x07\xc2\x2e\ +-\x16\x6c\x8f\x0b\x19\x80\x77\x8a\xe9\xa6\xa6\x3a\x54\xfb\x63\xf2\ +-\x8f\x36\x00\x19\x09\x84\xdc\x64\xc2\xa0\x78\x68\xde\x6e\x96\xf5\ +-\x6c\x7f\xad\x40\x53\x17\x45\x9b\x66\x17\x50\xde\x26\x50\xd3\x29\ +-\x40\x17\xcc\xe5\x44\xc0\x81\xfa\xae\x27\x7f\x00\x88\x0d\xb3\xdd\ +-\x05\x2c\xa4\x3d\xe9\xf4\xa8\x45\x25\x0d\xc4\xdd\x49\x83\x10\x4f\ +-\x07\x41\x66\xd1\x3e\xfa\x53\xa3\x05\x3f\xf5\x28\xdf\xfe\x6c\xa2\ +-\x24\x20\x3e\x06\x88\x96\x08\x06\x01\x98\x7c\xe8\xc8\x96\x95\x48\ +-\x18\x9b\x41\x48\xbf\x60\xd2\xb7\xb9\x81\xf2\x56\x81\x33\x9d\xe2\ +-\xa2\x6e\x81\x67\x5f\x77\xe1\x84\xc3\x02\x4b\x08\x60\x64\x3a\x21\ +-\x2f\x85\x20\xab\x02\xa7\xda\x81\x46\xb3\xc0\xd9\x1f\xc3\xf0\x74\ +-\xc2\xe4\x1c\xef\x29\x81\x1e\x15\x28\xea\x26\x69\x00\xbc\xdb\xf0\ +-\xae\x1e\xae\x72\xa2\xc7\x82\x0a\x01\x16\x41\xf4\x64\xe1\x10\xe3\ +-\xc7\x7a\xc7\xc2\xbe\xc5\x6f\x13\x41\x62\x61\x19\x25\xa6\x77\xe2\ +-\xab\x56\x1b\x0a\x25\xe1\x9d\xc0\x73\x92\x80\xf4\x78\x42\x62\xf4\ +-\xf9\x93\x38\x11\xb0\xb5\x52\x82\xd9\x75\xf1\x75\x84\x00\xa6\xe6\ +-\x10\x86\xf6\xb2\x04\xec\x94\x81\x3a\x93\x80\xd9\xe5\xed\xca\x96\ +-\x1e\x0f\x0c\x8a\x23\x18\x25\xa0\xc6\x2c\x70\xa8\x5e\x70\xbd\x41\ +-\x10\xc9\x49\x22\x24\xc7\x02\xa7\x3b\x44\xb7\x7d\x1e\xd2\xe2\x80\ +-\xcb\x87\xaa\x88\x36\x68\x1b\x1b\x63\x3e\x22\x00\xff\x57\x91\x2b\ +-\xfd\x3b\xef\x12\x08\x0e\x9c\x00\x04\x81\x37\x8a\xa8\xd0\x64\xc3\ +-\x97\x1e\x05\x49\xa3\x06\x79\x9f\xdf\x46\xf5\xf0\x26\xee\x51\x81\ +-\xf5\x27\xa4\x2e\x27\xe8\x58\x23\x70\xb3\x1f\x5a\xac\x36\x98\x05\ +-\xf6\xd6\xf0\xaf\x47\x28\x30\x48\xc0\x98\x0c\xc2\xe8\x0c\x7d\x0e\ +-\x15\x62\xac\x4f\x04\x7d\x69\x90\x0c\xf7\x4f\xc9\x16\xcd\x7a\x87\ +-\x12\xe9\xb8\x06\x40\x67\xaf\xef\xa5\xe7\x9a\x3b\x69\xbf\x00\x92\ +-\xae\x19\xa9\x62\x74\x46\xcf\x93\x3f\x00\x94\x35\x75\x7f\x77\xee\ +-\x94\x81\x56\xfb\xc0\xe3\xca\x49\x26\x24\xc7\x0c\xfc\x3a\x2c\x70\ +-\xa2\x24\x60\x74\x06\xe1\x86\xd1\x2a\xc6\x66\xf2\xe4\xcf\x42\x04\ +-\x89\xb9\x8a\xa2\x16\x95\xd6\xd0\x65\x7a\x87\x12\xe9\xf8\x2d\x43\ +-\x47\xaf\xed\x52\x96\x37\x5a\xa5\x07\x0c\x12\x70\xcd\xa8\xde\xfb\ +-\xc2\x77\x38\x80\x63\xcd\xbd\x1f\xf4\x93\x12\x07\xcc\xf5\xc3\x73\ +-\xe0\x9e\x0a\xcd\x98\x3e\x84\x00\x32\xe2\x09\x05\xa9\x40\x6e\x32\ +-\xc1\xc0\x29\x3c\x0b\x5d\x2e\x21\xe8\x87\xd3\x72\x8d\x8b\xf5\x0e\ +-\x24\x52\xf9\xa1\x0d\x09\xeb\xab\xa5\x07\x28\xd5\x62\xa7\xfd\x0d\ +-\x56\x31\x0a\x00\x26\x66\x53\xb7\x93\x3f\x01\x68\xb6\x08\x9c\x68\ +-\x15\x68\xf7\xf1\xce\xde\xe4\xf0\x36\x08\x1a\xe8\x1d\xbc\xca\x35\ +-\x00\x3e\x33\x4a\xde\xa5\x78\xb7\xe2\xff\x22\x4a\x01\x6f\x71\x5f\ +-\x4e\x12\x61\x48\x2a\x21\x9e\xab\xfc\x59\x78\x88\x21\x12\x8b\x4a\ +-\x6a\x95\xab\x9c\x24\x3d\x3b\x3b\x5f\x38\xf4\x0e\x28\xd2\x70\x02\ +-\xa0\xb1\xa5\xfb\xe8\xd2\x16\x33\x7d\x69\x75\x89\x78\x00\x18\x94\ +-\x00\x0c\x4b\xed\x7a\xc6\x30\xbb\x80\x92\x3a\x09\x9d\x7d\xfc\xb3\ +-\x48\x8e\xf5\xd6\x02\x0c\x84\xa2\x02\xcd\x36\xbe\xfb\xef\x4e\x72\ +-\x0c\x90\x9b\x42\xc8\x48\x20\xa4\xc6\x7a\x13\x00\xc0\xfb\x7d\xdb\ +-\x50\x2e\x0d\xf8\x40\x26\xa3\x01\xc8\x88\x23\x64\x27\x01\xd9\xc9\ +-\x34\xe0\x9f\x27\x63\x41\x4b\xe0\x91\x58\xa1\x8c\xde\xd7\x4c\x77\ +-\x5f\x96\x25\x1a\xf5\x0e\x27\x92\xf0\x3b\xbc\x86\x16\xef\xa7\x47\ +-\x9a\x2c\x58\xea\x92\x61\x00\xbc\xcf\x70\xe7\x8e\x54\xbb\x3c\x19\ +-\xad\xb2\x4d\xa0\xac\xe9\xe2\xad\x7a\xbe\xb8\x66\xa4\x8a\x14\x1f\ +-\x3a\xc1\xc9\x2a\x70\xaa\x5d\xa0\xc9\x2a\x10\x25\x08\x83\x12\x80\ +-\xac\x04\x6f\x0d\xc2\xb1\x16\xef\x1e\x74\xf6\x2d\x83\x00\x86\xa4\ +-\x7a\x0f\xb8\xe9\xee\xfb\x7b\xb8\x51\xa0\xb2\xad\xef\xdf\x37\xa3\ +-\xe4\xdd\xf1\x91\x11\x0f\x64\x26\x7a\x93\x0a\xde\xca\xc7\x22\x4c\ +-\x1d\x48\xba\xad\x70\x88\x38\xa8\x77\x20\x91\x82\xdf\x62\x34\xf2\ +-\xda\x5e\xfa\x7d\x93\x19\xbf\x3a\x3b\xa1\x0b\x01\xcc\xcc\xbf\xb8\ +-\x0b\x1c\x01\x38\xd4\x20\x50\xd5\xde\xbf\x1f\x4d\x5a\x1c\x70\xf5\ +-\x88\xde\xd7\xee\x9d\x32\xb0\xbb\x5a\x82\xc9\xd9\xaf\x61\x22\x4a\ +-\x7c\x94\x77\x2f\xfe\xd0\x34\xea\x76\x8b\x9d\xc5\xe5\xfd\xb9\xb5\ +-\xf8\xb8\x6a\x22\x09\xef\xd6\xcb\x8c\x04\x42\x56\x02\x21\x35\x0e\ +-\x5c\xc4\xc7\x22\x1e\x01\x16\x08\x75\xc1\xf4\xdc\xa8\x75\x7a\xc7\ +-\x12\x09\xf8\x2d\x27\xd0\x88\xc4\x2b\xbb\x69\x65\xb3\x55\xdc\x7d\ +-\x76\xaa\x17\x02\x28\xcc\x23\xe4\xa7\x5c\x7c\x7b\xdf\xdf\x3b\xc8\ +-\xb3\x86\xa5\x13\xa6\xe6\xf4\xbc\x6c\xe0\x51\x80\x6d\x55\x12\x2c\ +-\x5d\xf4\x11\x60\xdf\xca\x88\xf7\x9e\x5c\x97\x9d\x44\xdd\xde\x8d\ +-\x13\x80\x63\x4d\x02\x15\xad\x02\xbd\xa5\x5d\x42\x00\x99\x09\x84\ +-\xbc\x64\xef\x2e\x0b\xde\xaf\xcf\x58\x97\x64\x12\xf8\xc1\xf4\x5c\ +-\xc3\x3f\xf4\x0e\x24\xdc\xf1\x93\xc5\x00\xfa\xdb\x5a\x8a\xa1\x1d\ +-\xd8\xdb\xe4\x10\x53\xce\x7e\x4c\x00\x98\x92\xdd\xf5\xe4\x5f\xd5\ +-\x31\xb0\xc9\x1f\x80\x4f\x93\x4a\x69\x83\xe0\xc9\xbf\x0b\xdf\x14\ +-\xdb\x25\x7b\x5b\x27\x27\x76\x79\xe8\xf2\xf9\xaa\xda\x05\x4e\xb6\ +-\xf6\xfe\x33\x1b\x92\x42\x98\x98\x4d\x7e\x39\xfd\x8f\x69\xab\xe4\ +-\x48\x39\x52\x93\x13\x31\xa2\x20\x47\xef\x50\x22\x85\x51\x10\xde\ +-\x28\xa9\x53\x26\x4e\xcb\x95\x7e\x22\x84\xe0\xde\xa4\x01\xc2\x6f\ +-\x47\x01\xf2\xca\x56\xca\x76\x4a\x28\x35\x39\x30\xf8\xdc\x8f\x4f\ +-\xc8\x26\x0c\x4b\xbf\xf8\xf7\xd9\xec\x04\x0e\x37\x0c\x7c\x41\xc6\ +-\xdd\x4b\xf1\x59\xbd\x59\xa0\xce\xc4\x0b\x3f\x67\x89\xaf\x97\xe2\ +-\x73\x93\xbc\x93\x7e\x5c\x1f\x2b\xec\x9b\x7b\x39\xe2\x24\xda\x00\ +-\x4c\xc9\x25\xe4\x25\xf3\x7b\x58\xa8\x69\xed\x30\xe1\xb5\x65\x6b\ +-\xb0\x61\x5b\x31\x5e\xfc\xf5\x73\x9c\x00\x68\xef\xf9\xd2\x7a\x35\ +-\x7b\x6b\x15\x3d\x76\xcd\x70\xc1\x0f\x2b\x03\x80\x13\x80\x00\x78\ +-\x79\x37\x15\x5a\x5c\xd8\x6e\x77\x21\xfe\xdc\x8f\x8f\xcd\x24\x8c\ +-\x1e\x74\xf1\x44\x40\x00\x0e\x36\x4a\xfd\x2a\xf8\xbb\x90\xc9\x29\ +-\xbe\xbe\xe2\xc5\xdc\x0a\x70\x70\x80\x49\x86\x10\xde\x67\xe2\xb1\ +-\x51\x40\xb4\x81\x10\x63\xf0\x16\xb0\x49\xc2\xfb\x3f\xa7\xec\x3d\ +-\x6f\xa0\xdd\x2e\xa0\x04\xe9\x9c\x27\xce\x69\xb5\x9c\x93\x44\x88\ +-\x19\xc0\x5f\x41\x4f\x4d\x9b\x06\x27\x11\xa6\xe5\x72\x05\x7f\xa8\ +-\x91\x15\x05\xab\xd6\xed\xc4\xa2\x0f\xd6\xc2\xe1\xe0\xa5\x32\x3d\ +-\x11\xb0\x20\x25\x5a\xc9\x2b\xaa\xa7\x79\x33\x72\x45\xab\xde\xf1\ +-\x84\x1b\x7e\x6b\xf2\xb3\xc5\x7b\xe9\xb6\x46\x2b\x56\xbb\x95\xf3\ +-\xbf\xb7\x79\x29\x84\xf1\x59\x5d\xcf\x88\x8d\x66\x81\x36\x9b\x7f\ +-\xc6\xef\x74\x7a\x27\xe1\xae\x26\x9d\xb2\xa6\xee\xfb\xc8\xf7\x26\ +-\x27\x99\x30\x22\xdd\x5b\xa9\x6e\xf0\x21\x87\x70\x78\x08\x1b\xcb\ +-\xfd\x93\xd4\xf8\x4b\x52\x0c\x50\x90\xe6\x7d\xfc\xe2\xaf\x49\x39\ +-\x33\x11\xa8\xe9\x3c\xff\x63\x71\x51\xc0\xe4\x6c\x42\x0e\xdf\xf5\ +-\x87\x9c\x92\xb2\x0a\xbc\xb4\x78\x25\xaa\x6a\x78\x37\x5a\xf0\x10\ +-\x73\x24\x52\x77\x1f\xa8\xa1\x5b\xa7\xe5\x8b\x72\xbd\xa3\x09\x27\ +-\x9c\x00\xf8\xd1\x92\xbd\xf4\x5c\xbd\x05\xaf\x7a\xd4\xf3\x8b\x2b\ +-\xe3\xa2\x80\x29\x3d\x14\xe6\xf9\xf2\x0c\xd9\x57\x44\x40\x45\xab\ +-\xc0\x25\xd9\xe7\x8f\x57\x6f\xee\x7f\x57\xbf\x31\x19\x84\x09\x83\ +-\xfb\x36\x99\x35\x5a\xfb\xb7\x85\x31\x10\x52\xe3\x80\x71\x99\x84\ +-\xc1\x49\xe4\xf7\xaa\xd7\xfc\x64\x82\x65\x90\xf7\xbf\x37\x3e\x8a\ +-\x90\x9f\xea\xed\x0f\xc0\x0d\xfa\x42\x4b\x4b\xbb\x09\xaf\xbf\xb7\ +-\x06\xeb\xbf\x2a\xd2\x3b\x14\xd6\xb5\x51\x24\xa9\xdb\x8b\xea\xe9\ +-\xd6\x19\xb9\xa2\x44\xef\x60\xc2\x05\x27\x00\x7e\xb2\x68\xaf\xf2\ +-\xef\x35\x66\xfa\x6f\x95\x2e\x9e\x62\xa6\xe5\x76\x5f\xf1\xdd\xee\ +-\xf0\xb6\xf8\xf5\xa7\x53\x6d\x02\x19\x09\xf8\x66\x8b\x61\xab\x4d\ +-\xa0\xa4\xbe\xff\x53\x5f\xbd\x59\xc0\x68\xf0\xf6\x08\x48\xe9\x65\ +-\x7f\xba\x43\xf6\x8e\x5f\x31\xc0\x62\x46\x7f\x88\x31\x7a\x4f\x46\ +-\x0c\xe4\x9d\xb8\x10\xde\x4e\x8e\x13\xbb\x79\xec\xc2\x82\xdb\xd9\ +-\xe5\xfe\xc5\xef\xaf\x85\xdd\xc9\xcb\xfd\x41\x6e\xb0\x04\x75\xcb\ +-\x81\x3a\xba\x6d\x5a\x9e\xd8\xa9\x77\x30\xe1\x80\x13\x00\x3f\x78\ +-\x6d\x37\xfd\xb5\xd6\x84\xe7\xbb\x9a\x02\xf2\x92\x09\x59\x89\xdd\ +-\x4f\x0e\x35\x01\xe8\xb5\xaf\x02\xd8\x5b\x23\x90\x9d\xe4\x3d\xed\ +-\xa9\xc1\xdc\xfb\x16\xb5\x9e\x58\xdd\xc0\xd1\x26\x81\xa3\x10\x30\ +-\x4a\x40\x42\x0c\x90\x18\x45\x88\x32\x7a\x9b\x19\xa9\x04\xb8\x64\ +-\xc0\xec\x14\x5d\x1e\x51\xac\x87\xac\x44\xc2\xf4\xbc\x81\x3d\xdf\ +-\x67\xe1\xad\xf8\x70\x39\x5e\x5c\xb2\x12\xd5\xb5\x4d\x7a\x87\xc2\ +-\x7c\x45\x48\x21\xa8\x1b\x0e\xd4\x79\xe6\x4d\xcb\x8b\xda\xa8\x77\ +-\x38\xa1\x8e\xdf\x1e\x07\xe8\x95\xdd\xf4\x41\xa3\x05\xf7\x77\x35\ +-\xc5\x4b\x02\x17\x2d\xc5\x9f\x8b\x08\xa8\x33\x07\xe6\x4e\x99\xc8\ +-\x3b\xf1\xfb\x9b\xac\x7a\xcf\x1a\x30\x39\xf4\xbf\xc3\xef\x4e\x7e\ +-\x2a\xa1\x30\xb7\xfb\xbd\xfb\x2c\xb2\x35\xb7\x75\xe2\x8d\xe5\xff\ +-\xe4\xe5\xfe\xd0\x15\x4f\x90\x3e\x2f\xae\x97\x1f\x98\x9e\x6b\xfc\ +-\x44\xef\x60\x42\x19\x27\x00\x03\xf0\xf2\x2e\x75\x53\x93\x05\xd7\ +-\x75\xf7\xf9\x82\xd4\x9e\xb7\x95\x75\x3a\xbd\x95\xf9\xcc\x7f\xd2\ +-\xe2\x80\x69\x79\xfe\x7f\xd6\xcf\x42\x9f\xcb\xed\xc1\x7b\xab\x37\ +-\x63\xd9\x27\x5b\xe0\xf6\x78\xf4\x0e\x87\x0d\x4c\x8c\x80\xf8\xb0\ +-\xb8\x56\x7e\x78\xfa\x10\xe3\x0a\xbd\x83\x09\x55\x9c\x00\xf4\x07\ +-\x91\x78\x65\x17\xbe\x6a\xb2\xe2\xca\x9e\x5e\x36\x2a\xa3\xe7\xe7\ +-\xc2\x81\xb8\x43\x8f\x64\x02\xc0\xd4\x5c\xd5\xa7\x02\x3c\x55\x25\ +-\x58\x6d\x76\x98\x6d\x0e\x58\xac\x76\xd8\xec\x4e\xd8\x1d\x2e\xb8\ +-\x3c\x1e\x38\x1c\x2e\xd8\x9d\x2e\xb8\xdd\x1e\xd8\xbe\xde\x06\xa6\ +-\x28\xca\x45\xcf\x88\xdd\x6e\x0f\xdc\xee\xf3\x27\x12\xa7\xcb\x03\ +-\x83\x41\x42\x94\xf1\xdb\xa2\x8f\xa8\xe8\x28\xc4\x44\x7b\x33\xc1\ +-\x98\xa8\x28\x44\x47\x47\x21\x3e\x2e\x1a\x46\x83\x01\x49\x09\xf1\ +-\x30\x18\x24\x24\xc4\xc7\x21\x39\x29\x1e\x49\x09\x71\x48\x4a\x88\ +-\x43\x72\x62\x02\xe2\xe3\x06\x78\x9c\x23\xfb\xc6\xf6\xfd\x47\xf0\ +-\xf7\xb7\x56\xa3\xbe\xa9\x4d\xef\x50\x98\xbf\x10\xa2\x84\x10\xcb\ +-\x4b\xea\xe4\xc4\xc2\x3c\xe3\x9b\x7a\x87\x13\x8a\x38\x01\xe8\x2b\ +-\x22\xf1\xb7\x5d\xd8\xd9\x64\xc3\xe5\x3d\xbd\x2c\x2d\x0e\x3d\x76\ +-\x92\x73\x78\xd0\xef\x7e\xff\xfd\x21\x04\x90\x14\x0d\x24\xc6\x10\ +-\x12\xa2\xbd\x8f\x27\x5c\x32\xd0\xe9\x14\x30\x39\xfd\x7f\x84\xad\ +-\x1e\x12\x25\x3b\xda\x9a\x3b\x50\x61\xb2\xa2\xad\xc3\x8c\x4e\xb3\ +-\x15\x6d\x9d\x16\xb4\x77\x9a\xd1\x69\xb2\xa2\xc3\x6c\x83\xd9\x6a\ +-\x83\xd9\x62\x87\xd5\x1e\xfc\x27\x8f\x1a\x0c\x12\x92\x13\x13\xbe\ +-\x4e\x0a\xe2\x91\x9c\x18\x87\xa4\xa4\x78\xa4\xa7\x24\x21\x2b\x23\ +-\x0d\x99\x83\x52\x90\x91\x96\x8c\xec\xcc\x74\xa4\xa7\x24\xc1\x60\ +-\xe0\xbd\x07\x17\xaa\x69\x68\xc1\x5f\x97\x7e\x82\x3d\x25\xc7\xf4\ +-\x0e\x85\x05\x86\x01\x10\x8b\x8b\xeb\x95\xe4\xe9\xb9\x86\xbf\xe8\ +-\x1d\x4c\xa8\xe1\x04\xa0\x0f\x16\x2e\x24\x29\x7d\x17\xed\x6f\xb5\ +-\x89\xc2\xde\x5e\xdb\x53\xe5\xb9\x47\x05\xf6\xd4\x48\xf0\x0c\xa4\ +-\x32\xcf\x07\xd1\x06\x6f\x33\x9a\xc1\x89\xde\xa2\xb8\xae\x76\x22\ +-\xd4\x98\xbc\xcd\x81\xe4\x10\x78\x14\xe1\xb0\xd9\xd0\xd1\xde\x02\ +-\x53\x47\x2b\x4c\x1d\xed\xb0\x58\x3a\x61\x31\x75\xc2\xd4\xd1\x06\ +-\x8b\xb9\x13\x6e\x57\x78\x35\x0b\x53\x14\x15\x1d\x26\x0b\x3a\x4c\ +-\x96\x5e\x5f\x2b\x49\xd2\xd7\x89\x41\x2a\x86\xe4\x64\x60\x58\x5e\ +-\x36\x0a\xf2\xb2\x30\x2c\x2f\x0b\xf9\xb9\x59\x11\x97\x1c\x38\x5d\ +-\x6e\xbc\xb3\x6a\x23\x3e\xf8\xf4\x4b\xb8\xe5\x01\x9e\xcd\xcc\x82\ +-\x9d\x10\x84\x97\x4a\xea\x94\xe4\xc2\x3c\xc3\x6f\xf5\x0e\x26\x94\ +-\x70\x02\xe0\xa3\xfb\x56\x90\x21\x3d\x17\xc5\xad\xb6\x6f\xfb\xfa\ +-\xf7\xa4\xab\x23\x7e\x01\xef\x79\xf1\xbb\xab\x25\x98\xfc\x74\x03\ +-\x2a\x7d\xdd\x99\x2f\xda\x08\x44\x49\x84\x68\x23\x90\x12\xeb\x6d\ +-\xd8\x93\xd6\xc3\x96\x3d\xb7\x02\x1c\x69\x14\x38\x13\x64\x47\xfe\ +-\x7a\x3c\x6e\xb4\xb5\x34\xa2\xbd\xa5\x09\x1d\x6d\x2d\xe8\x68\x6b\ +-\x41\x67\x7b\x2b\x3a\xda\x5b\xe0\x72\x06\xff\x5d\xbb\x5e\x54\x55\ +-\x45\x6b\x87\x09\xad\x1d\x26\x1c\x2d\xaf\x3e\xef\x73\x7f\xff\xaf\ +-\x1f\x60\xda\xc4\x51\x3a\x45\xa6\xbd\xad\x7b\x0e\xe2\xe5\xb7\x3e\ +-\x45\x53\x6b\x87\xde\xa1\x30\x6d\xfd\x57\x49\x9d\x12\x5f\x98\x67\ +-\xf8\x85\xde\x81\x84\x0a\x4e\x00\x7c\xb0\x70\x2b\x19\x53\x8d\x28\ +-\x6d\xb5\x63\xa2\xaf\x5f\xd3\x55\x71\x9f\x4b\x06\xf6\xd5\x48\x68\ +-\xb7\x0f\x3c\x26\x21\xbc\xcd\x85\xf2\x53\x7d\xeb\xcc\x77\x96\x42\ +-\x5f\x1f\x60\xd3\x22\x74\x2d\x40\x54\x55\x15\x1d\xad\xcd\x68\x6d\ +-\x6e\x40\x4b\x53\x03\xda\x5a\x1a\xd0\xda\x54\x8f\xce\x8e\x36\x50\ +-\x38\x3c\x8f\x60\x9a\x3b\x53\xd7\x84\x17\x97\xac\x42\xd1\xa1\x93\ +-\x7a\x87\xc2\xf4\xf3\xf3\x92\x3a\xc5\x55\x98\x67\xf8\x4f\xbd\x03\ +-\x09\x05\x9c\x00\xf4\x62\xe1\x42\x92\x52\xa2\x51\xd2\x6e\xf3\x7d\ +-\xf2\x07\x80\xca\x36\x81\x9c\x24\x6f\xcb\x59\x22\xa0\xd6\x2c\x50\ +-\xd6\x28\xe0\xf4\xd3\x6a\x64\x66\x02\x61\x58\x9a\xef\x13\xa5\x4b\ +-\x06\xaa\x3b\x05\xaa\xda\x05\x1c\x1a\x17\x40\x13\xa9\x68\x6f\x6d\ +-\x46\x53\x5d\x0d\x1a\xeb\x6b\xd0\xd4\x50\x83\xe6\x86\x5a\x78\x3c\ +-\x6e\x6d\x03\x61\x61\xc9\xe9\x72\x63\xf9\xa7\x5b\xb0\x6c\xd5\x66\ +-\x5e\xee\x67\x00\xf0\x9b\x92\x7a\xc5\x51\x98\x6b\xf8\x5f\xbd\x03\ +-\x09\x76\x9c\x00\xf4\x84\x48\xa4\xed\xc4\xae\x36\x1b\x26\xf5\xf5\ +-\x4b\xad\x2e\x60\x63\xb9\x84\xf4\x38\x82\xd5\x25\xe0\xf0\xf3\xfb\ +-\x92\x2f\x8f\x74\x55\x00\x2d\x56\x81\x5a\x13\x50\x6f\xd2\xee\x70\ +-\x1e\xbb\xd5\x82\xda\x33\xa7\x50\x7f\xe6\x14\x1a\xeb\x6a\xd0\xdc\ +-\x58\x0b\xb7\x3b\x48\x3a\x04\xb1\xb0\xb2\x69\xe7\x01\xbc\xf2\xf6\ +-\xa7\x68\x69\x37\xe9\x1d\x0a\x0b\x26\x84\x3f\x94\xd4\x2a\xee\xc2\ +-\x21\x86\x17\xf5\x0e\x25\x98\x71\x02\xd0\x83\xbf\xed\xa4\xaf\x5a\ +-\xed\x62\x66\x7f\xbf\x5e\x51\x81\x16\x5b\x60\x9e\xb1\xb7\x58\x05\ +-\x2c\x2e\x42\xd2\x05\x3b\xc5\x3c\x8a\xf7\x24\xbe\x06\x8b\xb7\x85\ +-\xaf\x16\xcb\xfc\x56\x8b\x09\x75\x67\xaa\x50\x57\x7d\x0a\x75\x35\ +-\xa7\xd0\xd4\x50\x1b\x1e\xdb\x0a\x58\xd0\x3a\x53\xdf\x8c\xbf\x2c\ +-\x59\x85\x7d\x07\x4f\xe8\x1d\x0a\x0b\x56\x02\x7f\x3a\x50\x2f\x5b\ +-\xa6\xe5\x1a\x17\xe9\x1d\x4a\xb0\xe2\x04\xa0\x1b\xaf\xec\xa6\x8d\ +-\x4d\x96\x9e\xf7\xf9\xeb\x49\x56\x81\x2f\x2b\x25\x64\x24\x7a\x9b\ +-\x0d\x39\x3d\x80\xc3\xe3\x6d\xc5\x1b\xe8\xb9\xd7\x6e\xb5\xe0\x74\ +-\xe5\x71\x54\x55\x1c\x47\xcd\xe9\x72\x58\xcd\x7c\xf7\xc5\xb4\x61\ +-\xb7\x3b\xb1\x64\xc5\x3a\xac\xfc\x62\x07\x64\x25\x04\xb6\xae\x30\ +-\x3d\x09\x22\xf1\x5a\x71\xad\x6c\xe2\x66\x41\x5d\xe3\x04\xa0\x0b\ +-\xaf\xec\xa2\x8f\x9a\x2c\xb8\x5e\xef\x38\x7a\xa3\x10\xd0\x64\x09\ +-\x7c\x15\xbf\xaa\xaa\x68\x69\xac\x43\xe5\xc9\x23\xa8\x3c\x51\x86\ +-\xe6\x86\x5a\x2e\xd4\x63\x9a\xdb\x59\x54\x86\x3f\x2f\xfe\x18\xcd\ +-\xad\x9d\xbd\xbf\x98\x31\x2f\x83\x90\xc4\xb2\xe2\x3a\xd9\x31\x3d\ +-\xcf\xf8\xb9\xde\xc1\x04\x1b\x4e\x00\x2e\xf0\xf7\x5d\xca\xe2\x26\ +-\x2b\xee\xd5\x3b\x0e\xbd\x39\xec\x56\x54\x1c\x3b\x8c\x8a\xe3\x87\ +-\x71\xe6\x74\x39\x3c\x6e\x2e\xd8\x63\xfa\xa8\xa8\xae\xc3\x8b\x8b\ +-\x57\xe1\xd0\xb1\x53\x7a\x87\xc2\x42\x11\x21\x4a\x40\x7c\x5c\x5c\ +-\xef\xb9\x6b\x7a\x6e\xd4\x3a\xbd\xc3\x09\x26\x9c\x00\x9c\xe3\x95\ +-\x3d\xca\x1f\x9a\xcd\xd2\x53\x7a\xc7\xa1\x17\xb3\xa9\x03\xa7\x2b\ +-\x8e\xa1\xf2\xf8\x11\x54\x55\x1c\x83\xaa\x06\xb8\x53\x11\x63\x3d\ +-\xb0\xda\x1d\x58\xf2\xc1\x3a\xac\x5a\xbf\x03\x8a\xc2\xbf\x8b\x6c\ +-\x40\xa2\x05\x49\x2b\x4b\xea\xe9\x96\xc2\x5c\xb1\x4d\xef\x60\x82\ +-\x05\x27\x00\x5f\x5b\xbc\x87\x7e\x5c\x6b\xc6\x2f\x22\x6d\x61\xbb\ +-\xa3\xad\x05\x27\x8e\x1c\x40\xf9\xf1\x43\x68\xaa\xaf\xd1\x3b\x1c\ +-\xc6\x40\x44\xf8\xe2\xcb\xfd\x78\x6d\xd9\x1a\x9f\xba\x20\x32\xe6\ +-\xa3\x78\x40\xfd\xac\xa8\x9e\xae\x9d\x91\x2b\x4a\xf4\x0e\x26\x18\ +-\x70\x02\x00\xe0\xf5\xfd\x74\x57\xbd\x09\x2f\x45\xca\x3d\x86\xcb\ +-\x69\xc7\x89\xb2\x52\x94\x95\xee\x47\x5d\x4d\x15\x57\xec\xb3\xa0\ +-\x71\xb2\xaa\x16\x2f\x2d\x5e\x85\xc3\x27\xaa\xf4\x0e\x85\x85\x23\ +-\x42\x8a\x04\x75\x7d\x71\x0d\x5d\x3e\x3d\x5f\x54\xe8\x1d\x8e\xde\ +-\x22\x3e\x01\x78\x7d\x2f\xcd\x68\x35\x63\xa5\xac\x86\xf7\x09\xb2\ +-\x8a\x22\xe3\x74\xc5\x71\x1c\x3d\xb8\x1f\x15\xc7\x0f\x43\xe1\x0a\ +-\x6a\x16\x44\x2c\x36\x3b\xde\xfc\x70\x3d\x56\xae\xdb\xc1\x8f\x9e\ +-\x58\xa0\x65\x08\x49\xfd\xec\x50\x35\xcd\x99\x3c\x54\x44\x74\xbf\ +-\xe8\x88\x4e\x00\x5e\xd9\x47\xf9\xed\x36\x6c\x73\x2b\xe8\xe2\x98\ +-\x9c\xf0\xd0\xdc\x58\x87\x83\xfb\x77\xe2\xf8\x91\x12\xee\xa5\xcf\ +-\x82\x8e\xaa\x12\xd6\x6c\xde\x83\xd7\x97\xff\x13\x66\x8b\x4d\xef\ +-\x70\x58\xe4\x18\x2f\x1b\x95\xd5\xe5\xe5\x74\xe3\xe8\xd1\x22\x62\ +-\xbb\x94\x45\x6c\x02\xb0\x70\x2d\x25\x5b\xed\x28\x75\x7a\x10\xa7\ +-\x77\x2c\xfe\xa6\x28\x0a\x2a\x8e\x1f\xc6\xa1\xe2\x5d\xa8\xae\xe4\ +-\x46\x29\x2c\x38\x9d\x3c\x55\x8b\x3f\x2f\x5a\x89\xb2\xf2\xd3\x7a\ +-\x87\xc2\x22\x92\xb8\xca\x12\xaf\xbe\x45\x44\x0f\x0a\x21\x22\xf2\ +-\x39\x68\x44\x26\x00\xf7\xad\x20\x43\x42\x22\x4a\x2c\x4e\xa4\xeb\ +-\x1d\x8b\x3f\x59\xcd\x26\x1c\x2a\xd9\x85\x03\x7b\x77\xc0\x61\xb7\ +-\xea\x1d\x0e\x63\x5d\x32\x5b\xed\x58\xba\x82\x97\xfb\x59\x50\xf8\ +-\x4e\x49\xbd\x7a\x02\xc0\x42\xbd\x03\xd1\x43\x44\x26\x00\x73\x72\ +-\x68\x7d\xbb\x43\x8c\xd4\x3b\x0e\x7f\xa9\xa9\xaa\x40\xd1\xae\x2d\ +-\x38\x55\x7e\x94\x1b\xf4\xb0\xa0\xa5\xaa\x2a\x56\x6f\xdc\x8d\x45\ +-\xcb\xd7\xc2\x62\xf3\xc3\x91\x98\x8c\xf9\x81\x00\x7e\x73\xa0\x56\ +-\xae\x9a\x36\xc4\xf8\xb6\xde\xb1\x68\x2d\xe2\x12\x80\x57\x77\xd1\ +-\xff\x35\x5a\x71\x9d\xde\x71\x0c\x18\x11\x2a\x4f\x96\x61\xdf\xf6\ +-\x4d\xde\x4a\x7e\xc6\x82\xd8\xf1\xca\x33\x78\x71\xd1\x2a\x1c\xad\ +-\xa8\xd6\x3b\x14\xc6\x2e\x24\x48\x12\x8b\x4a\xea\x3c\x75\x85\x79\ +-\x51\x9b\xf4\x0e\x46\x4b\x11\x95\x00\xbc\xb6\x87\x9e\x6c\x32\xe3\ +-\xdf\xf4\x8e\x63\x20\x54\x45\xc1\xf1\xc3\x25\xd8\xbb\x63\x13\xda\ +-\x5a\x1a\xf5\x0e\x87\xb1\x1e\x99\x2d\x36\x2c\xfd\x68\x03\x56\xae\ +-\xdb\x0e\x55\xe5\xd5\x29\x16\xa4\x08\x51\x80\xb4\x72\x4f\x0d\x5d\ +-\x39\x2b\x5f\x1c\xd2\x3b\x1c\xad\x44\x4c\x02\xf0\xc6\x1e\xba\xa2\ +-\xd9\x8a\x45\xa1\xfa\xc4\x51\xf6\x78\x70\xa8\x64\x17\x8a\x76\x6e\ +-\x85\xd9\x14\xd1\x3b\x57\x58\x08\x50\x14\x15\x2b\xd7\xed\xc0\x92\ +-\x0f\xd7\xc1\x66\xe7\xdd\x27\x2c\x24\x24\x1f\x6f\xa6\x6d\x6f\x14\ +-\xd1\x4d\xcf\xce\x10\x7b\xf5\x0e\x46\x0b\x11\x91\x00\xbc\xb1\x8d\ +-\x72\x3a\x1c\xd8\xe8\x51\x21\xe9\x1d\x4b\x5f\x11\x11\x4e\x1e\x3d\ +-\x88\x6d\x1b\x3f\x83\xa9\xa3\x4d\xef\x70\x18\xeb\x55\xe9\xd1\x4a\ +-\xbc\xb4\x64\x15\x2a\xab\xeb\xf5\x0e\x85\xb1\x3e\x69\x30\x8b\x14\ +-\x83\x84\xcd\x4b\xb7\xd2\x90\x27\xae\x11\x61\x7f\xea\x54\xd8\x27\ +-\x00\x0b\xb7\x92\xd1\x02\x2a\xb2\x7b\x44\xac\xde\xb1\xf4\x55\x75\ +-\xe5\x09\x6c\x5d\xbf\x1a\xad\x4d\xfc\x46\xca\x82\x5f\x5b\xa7\x19\ +-\xaf\xbe\xfb\x39\x36\x6c\x2b\xe6\x62\x54\x16\x72\x08\x80\x4b\x06\ +-\x54\x42\x42\x5c\x02\xf6\x02\x18\xab\x77\x4c\x81\x16\xf6\x09\xc0\ +-\xa0\x18\xac\x69\xb1\x8a\x5c\xbd\xe3\xe8\x8b\xba\x33\xa7\xb0\x7d\ +-\xd3\xe7\xa8\xad\xe6\xd3\xcf\x58\xf0\x3b\xbb\xdc\xbf\xf8\xc3\x2f\ +-\x60\xb7\x3b\xf5\x0e\x87\xb1\x7e\x11\x00\x06\xc5\x13\x5a\x6c\x02\ +-\x2d\x36\x8c\x79\x63\x2f\xbd\xf7\xec\x4c\xf1\x90\xde\x71\x05\x52\ +-\x58\x27\x00\xaf\xec\xa4\x9f\x35\x5b\x71\x93\xde\x71\xf8\xaa\xb5\ +-\xa9\x1e\x5f\xae\xff\x14\xa7\x2b\x8f\xeb\x1d\x0a\x63\x3e\x29\x3e\ +-\x5c\x8e\x97\xde\x5c\x85\xd3\x35\x5c\x90\xca\x42\xdf\x98\x4c\xa0\ +-\xe5\xeb\x86\x94\x0d\x26\x3c\xf8\x66\x11\x6d\x7d\x72\x86\x58\xac\ +-\x6f\x54\x81\x13\xb6\x09\xc0\x2b\xbb\x68\x76\xab\x0d\x7f\x08\x85\ +-\x85\x48\x8f\xdb\x8d\xfd\xbb\x36\x63\xef\xb6\x8d\xdc\xa3\x9f\x85\ +-\x84\xd6\x0e\x13\x5e\x5b\xb6\x86\x97\xfb\x59\x58\xc9\x4c\x20\x64\ +-\x27\x01\x8d\x16\x01\x15\x40\xa3\x19\xaf\xff\x63\x1f\xed\xfe\xee\ +-\x65\xa2\x4c\xef\xd8\x02\x21\x2c\x13\x80\x85\xbb\x28\xdd\xe2\xc2\ +-\x06\x85\x82\xbf\xe8\xaf\xf2\xc4\x11\x6c\xfa\xe7\x47\xb0\x98\xc2\ +-\xbe\xde\x84\x85\x01\x59\x51\xb0\x6a\xdd\x4e\x2c\xfa\x60\x2d\x1c\ +-\x8e\x88\x6d\xa1\xce\xc2\xd8\xf8\x2c\x42\xa3\xc5\x7b\x36\x9c\x53\ +-\x86\xc1\xe2\xc4\x8e\x85\x55\x94\xb3\x70\xb8\x08\xbb\xe7\x5b\xe1\ +-\x97\x00\x10\x89\xa4\x6d\xb4\xd7\xe4\x11\x09\x7a\x87\xd2\x93\xf6\ +-\xd6\x66\x6c\x59\xbb\x92\x97\xfb\x59\xc8\x28\x39\x52\x8e\x17\x97\ +-\xf0\x72\x3f\x0b\x6f\x29\xb1\x40\x72\x2c\x60\xfe\x7a\xba\x37\x39\ +-\x91\x9a\xd3\x84\x2d\x00\x66\xeb\x1a\x58\x00\x84\x5d\x02\xf0\xb7\ +-\x5d\xea\xbb\xad\x2e\x69\x94\xde\x71\x74\xc7\xe3\x71\x63\xe7\x96\ +-\xb5\x28\xd9\xbb\x0d\x2a\x2f\xf7\xb3\x10\xd0\xd8\xd2\x8e\xbf\xbd\ +-\xb5\x1a\xdb\xf6\x1e\xd6\x3b\x14\xc6\x34\x91\x10\x4d\x30\x3b\xbf\ +-\x3d\x21\xbe\xd1\x82\xcb\xdf\x2b\x51\x7e\xfb\x50\xa1\xe1\x37\x3a\ +-\x86\xe5\x77\x61\x95\x00\xbc\xbe\x87\x1e\x6e\xb0\x20\x68\xab\x36\ +-\x1b\x6a\xab\xb1\x76\xd5\x32\x74\xb4\x35\xeb\x1d\x0a\x63\xbd\x3a\ +-\xbb\xdc\xbf\xf8\xfd\xb5\xb0\x3b\x79\xb9\x9f\x45\x0e\xf9\x82\x7b\ +-\x33\x22\xa0\xba\x53\xfa\xf5\xea\x13\xb4\x71\xde\x58\xb1\x5d\x9f\ +-\xa8\xfc\x2f\x6c\x12\x80\xd7\x0e\xd0\xb0\xb6\x0e\x5a\x4a\x24\x7a\ +-\x7f\xb1\xc6\x14\x45\xc1\xae\xad\x5f\x60\xdf\x8e\xcd\x20\x0a\xd5\ +-\x5e\x84\x25\xdb\xf2\xe7\x00\x00\x20\x00\x49\x44\x41\x54\x2c\x92\ +-\xd4\x37\xb5\xe1\x85\xdf\xbe\x8e\xba\xa6\x56\xbd\x43\x61\x4c\x73\ +-\x2e\xf9\xe2\x79\xc4\x29\x43\x9c\x6e\xa6\x2f\xf6\x94\x53\xee\xac\ +-\xd1\xc2\xac\x43\x58\x7e\x17\x1e\x09\x00\x91\x70\xee\xa0\xed\x2e\ +-\x59\x04\xdd\x7f\x4f\x6b\x73\x03\xd6\xae\x5a\x86\xe6\x86\x5a\xbd\ +-\x43\x61\xcc\x67\x4d\xad\x1d\x3c\xf9\xb3\x88\xa5\x74\xb3\xb1\xa5\ +-\xdd\x21\x12\x8e\x76\xd2\x66\x00\x97\x6a\x1a\x50\x80\x04\x7d\x95\ +-\xbc\x2f\x5e\xdd\xa3\x2e\xe9\x70\x88\x21\x7a\xc7\x71\x2e\x22\x15\ +-\xfb\x76\x6c\xc2\xbb\xaf\xff\x89\x27\x7f\xc6\x18\x0b\x21\xe9\xf1\ +-\xdd\x6f\x6d\xad\xee\x14\x33\x3e\x2c\x55\xfe\x43\xc3\x70\x02\x26\ +-\xe8\xee\x98\xfb\xea\xd5\x1d\x74\x4b\xb3\x95\x9e\xd0\x3b\x8e\x73\ +-\x59\xcd\x26\x7c\xfe\xd1\x5b\xa8\x3b\xc3\x9d\xfc\x18\x63\x2c\xd4\ +-\x4c\xca\x26\x38\x3d\x40\x8b\xed\xdb\x47\x01\x51\x12\x90\x18\xe3\ +-\x2d\x10\x54\x20\x7e\x55\x54\x4f\x6f\xcf\xc8\x15\x67\x74\x0c\x73\ +-\xc0\x42\x3a\x01\xf8\xdf\x8d\x94\x62\xf2\xd0\x4a\x35\x88\x9e\xfb\ +-\xd7\x54\x57\x62\xcd\x47\x6f\xc1\x66\x09\x8b\x47\x44\x8c\x31\x16\ +-\x71\xa2\x0d\xc0\x9c\x61\x04\x97\x4c\xf0\xa8\x80\x51\x02\x62\xcf\ +-\x9f\x2d\x63\x41\xea\xbb\x2b\x88\xae\x5d\x20\x44\xc8\x6e\xe7\x0a\ +-\xe9\x47\x00\xb1\x71\xd8\xea\xf0\x88\x38\xbd\xe3\x00\x00\x10\xa1\ +-\x78\xcf\x57\xf8\xe8\xed\x57\x78\xf2\x67\x8c\xb1\x30\x10\x63\x04\ +-\x12\xa3\x2f\x9a\xfc\xbf\x26\xae\x1a\x5d\xaf\xfe\x54\xeb\x98\xfc\ +-\x29\x64\x13\x80\xd7\xf6\xd0\xbf\xb4\xdb\x31\x4d\xef\x38\x00\xc0\ +-\xe3\x76\xe1\xf3\x15\x6f\x61\xeb\x17\xab\x78\x6f\x3f\x63\x8c\x45\ +-\x08\x12\xf8\xfd\x81\x06\x0a\xd9\x82\xc0\x90\x4c\x00\xfe\xbe\x97\ +-\x86\xb7\x59\xf1\xff\xf4\x8e\x03\x00\xda\x5b\x9a\xf0\xee\x3f\xfe\ +-\x8c\x13\x47\x4b\xf5\x0e\x85\x31\xc6\x98\x96\x08\x51\xa4\xaa\x6f\ +-\x17\xd5\x53\xbc\xde\xa1\xf4\x47\x48\x26\x00\xb2\x07\x5b\xdc\x2a\ +-\x0c\x7a\xc7\x51\x7e\xfc\x30\xde\x7d\xe3\x4f\x68\x6f\x69\xd2\x3b\ +-\x14\xc6\x18\x63\xfa\x18\x2f\x41\xfd\x93\xde\x41\xf4\x47\xc8\x25\ +-\x00\x6f\xec\xa6\xbf\x77\xd8\x31\x4c\xef\x38\x0e\x17\xef\xc6\xe7\ +-\x1f\xbe\x09\x8f\xc7\xad\x77\x28\x8c\x31\xc6\xf4\x44\xf8\x5e\x49\ +-\x9d\x7c\xa7\xde\x61\xf4\x55\x48\x25\x00\x4b\xf7\xd0\xac\x26\x3b\ +-\x7e\xa0\x6b\x10\x44\xd8\xf5\xe5\x17\x58\xff\xd9\x07\x50\x55\xee\ +-\xea\xc7\x18\x63\x0c\x00\xc4\xe2\x7d\xcd\x94\xad\x77\x14\x7d\x11\ +-\x32\x09\xc0\xc2\x85\x24\xb5\xbb\xf1\xb9\xac\x40\xb7\x3d\x7f\x8a\ +-\xa2\x60\xcd\xaa\x77\xb1\x6b\xeb\x3a\xbd\x42\x60\x8c\x31\x16\x9c\ +-\x32\xa3\x3c\xb4\x48\xef\x20\xfa\x22\x64\x12\x80\xc1\x37\x61\x89\ +-\xc9\x89\x0c\xbd\xc6\xf7\xb8\x5d\xf8\xe4\xbd\x7f\xe0\xf8\xa1\x62\ +-\xbd\x42\x60\x8c\x31\x16\xc4\x08\x74\xfb\xfa\x93\xca\x8f\xf4\x8e\ +-\xc3\x57\x21\x91\x00\x2c\xda\x43\x93\x5b\xed\x78\x4c\xaf\xf1\xad\ +-\x16\x13\xde\x5b\xf4\x12\x4e\x57\x1e\xd7\x2b\x04\xc6\x18\x63\x21\ +-\xe0\x70\xbd\x78\xe9\xbd\x03\x34\x55\xef\x38\x7c\x11\x12\x09\x80\ +-\xc5\x8d\x7f\x7a\x74\x5a\xfa\xb7\x5b\x2d\xf8\xe8\x9d\x57\xd1\xda\ +-\xdc\xa0\xc7\xf0\x8c\x31\xc6\x42\x44\x87\x03\x30\xbb\x85\xa1\xc5\ +-\x8e\x35\x7a\xc7\xe2\x8b\xa0\x4f\x00\x5e\xdf\xad\xfc\xae\xd3\x09\ +-\x5d\x0e\xfa\xb1\xdb\x2c\xf8\xf0\xed\x97\xd1\xd6\xdc\xa8\xc7\xf0\ +-\x8c\x31\xc6\x42\xc8\xa9\x76\xef\x7d\x6a\xbb\x0d\x79\x6f\x15\x29\ +-\x7f\xd4\x39\x9c\x5e\x05\x75\x02\xf0\xda\x2e\xca\x6b\xb5\x4b\xbf\ +-\xd4\x63\x6c\xbb\xcd\x82\x0f\x97\xf2\xe4\xcf\x18\x63\xac\x77\x76\ +-\x37\x50\x67\xfa\x76\xa1\xba\xce\x24\x7e\xfa\xfe\x01\x1a\xa6\x5f\ +-\x44\xbd\x0b\xea\x04\x40\x56\x69\xbd\x5b\xd1\xbe\xe1\xcf\x37\x93\ +-\x7f\x0b\x4f\xfe\x8c\x31\xc6\x7a\x57\xd6\x24\xa0\x9e\x73\x8a\xb0\ +-\x4b\x11\x52\x9b\x13\xff\xd4\x2f\xa2\xde\x05\x6d\x02\xb0\x78\x2f\ +-\x3d\xdd\x6a\x17\x13\xb5\x1e\xd7\x61\xb7\x62\xc5\x5b\xaf\xf0\xe4\ +-\xcf\x18\x63\xcc\x27\xed\x0e\xa0\xde\x7c\x71\x99\x5a\x8b\x05\x13\ +-\x96\x16\x51\xd0\xee\x0a\x08\xca\x04\xe0\x8f\x07\x29\xa1\xc5\x8e\ +-\x97\xa9\xf7\x97\xfa\x95\xcb\x69\xc7\x87\x4b\x5f\xe6\x82\x3f\xc6\ +-\x18\x63\x3e\x21\x02\x0e\x37\x48\xe8\x6a\xbe\x22\x00\xcd\x56\xfc\ +-\x71\xc9\x0e\x4a\xd2\x3a\x2e\x5f\x04\x65\x02\x90\xe2\xc2\x27\x0e\ +-\x0f\x62\xb4\x1c\x53\x55\x14\x7c\xfa\xe1\x52\x9e\xfc\x19\x63\x8c\ +-\xf9\xec\x68\xb3\x40\x87\xa3\xfb\xcf\xdb\xdc\x88\xf1\x18\xb1\x52\ +-\xbb\x88\x7c\x17\x74\x09\xc0\xf2\x52\xba\xa2\xc1\x8c\x1b\x34\x1d\ +-\x94\x08\xeb\x3e\x7b\x1f\x67\x4e\x9d\xd4\x74\x58\xc6\x18\x63\xa1\ +-\xab\xbc\x4d\xa0\xa2\xb5\xf7\x1d\xea\x4d\x16\xdc\xf0\xee\x01\x9a\ +-\xad\x41\x48\x7d\x12\x74\x09\x40\xab\x15\x2b\x14\x8d\x5b\xec\xef\ +-\xfa\x6a\x1d\x8e\x96\xee\xd7\x76\x50\xc6\x18\x63\x21\x49\x56\x81\ +-\xd2\x7a\x81\xb2\x46\xd1\xe5\xd2\xff\x85\x14\x02\xda\xec\x58\x11\ +-\xf0\xc0\xfa\x28\xa8\x12\x80\xb7\x8b\x94\x9f\xb7\xda\x91\xa3\xe5\ +-\x98\xc7\x8f\x94\x60\xd7\x97\xeb\xb5\x1c\x92\x31\xc6\x58\x08\x52\ +-\x01\x54\x77\x0a\x6c\xae\x90\x70\xba\xa3\x6f\xbd\xe9\xda\x6d\xc8\ +-\x7b\xa7\x44\xf9\x45\x60\x22\xeb\x9f\xa0\x49\x00\xde\x39\x48\x09\ +-\x8d\x56\xf1\x5b\x2d\xc7\xac\xa9\xae\xc4\x17\xab\xde\xf3\x56\x71\ +-\x30\xc6\x18\x63\x5d\x70\xc9\xc0\x89\x16\x81\x8d\x27\x24\x1c\xa8\ +-\x13\x70\x78\xfa\x77\x9d\x46\xb3\xb4\xf0\x8d\x22\x8a\xf7\x6f\x74\ +-\xfd\x67\xd4\x3b\x80\xb3\x5c\x6e\xac\xb0\xb9\x45\xb4\x56\xe3\xb5\ +-\xb7\x34\x61\xf5\xf2\xc5\x50\x14\x59\xab\x21\x19\x63\x8c\x85\x10\ +-\xbb\x07\x28\x6f\x15\x38\xd3\x21\xa0\xf8\xe1\x3e\xd1\xea\x46\x4c\ +-\xaa\x82\xe5\x00\xe6\x0d\xfc\x6a\x03\x17\x14\x2b\x00\x2b\xca\x68\ +-\x6a\xa3\x19\xb7\x68\x35\x9e\xdb\xed\xc2\xea\x0f\x97\xc0\xe5\xb4\ +-\x6b\x35\x24\x63\x8c\xb1\x10\xe1\x92\x81\x92\x3a\x81\x4d\x27\x25\ +-\x54\xb5\xfb\x67\xf2\x3f\xab\xc9\x8a\x3b\x97\x1d\xa2\x49\xfe\xbb\ +-\x62\xff\x05\xc5\x0a\x40\xab\x05\x1f\x68\x76\xd8\x0f\x11\xd6\x7f\ +-\xb2\x1c\xed\x2d\x4d\x9a\x0c\xc7\x18\x63\x2c\x74\xb4\xd8\x04\xf6\ +-\xd7\x08\xb8\x95\xc0\x5c\xdf\xa3\x40\x74\x58\xf0\x31\x80\xb1\x81\ +-\x19\xc1\x77\xba\xaf\x00\x2c\x3f\x40\xf3\x9a\x2c\xda\x7d\x23\xf6\ +-\xef\xda\x82\x13\x47\x4b\xb5\x1a\x8e\x31\xc6\x58\x88\x68\xb6\x0a\ +-\xec\x3e\x1d\xb8\xc9\xff\xac\x56\x1b\xc6\xbc\xb9\x8f\xee\x0f\xec\ +-\x28\xbd\xd3\x7d\x05\xa0\xc5\x8e\x7f\x68\x55\x83\x57\x77\xe6\x14\ +-\xb6\x6f\x0a\x89\x53\x1a\xd9\x05\x24\x49\x60\x50\x6a\x32\x72\xb2\ +-\x06\x21\x2d\x35\x11\xc9\x89\xf1\x48\x4a\x8c\x47\x72\x42\x3c\x84\ +-\x00\x0c\x06\x03\x14\xc5\xfb\x57\x5b\x79\xa6\x01\x1b\xb6\x15\xeb\ +-\x1c\x31\x63\x2c\x94\x58\x5d\xc0\xfe\x1a\x01\x2d\x76\xa1\x13\x80\ +-\x0e\x27\x5e\x05\xf0\xa1\x06\xc3\x75\x4b\xd7\x04\x60\x59\x89\xf2\ +-\x8b\x93\xad\xc8\xd4\x62\x2c\xb7\xd3\x81\xb5\x2b\xdf\x85\xaa\x6a\ +-\xdc\x64\x80\xf5\x89\x10\x02\xf9\x39\x99\x18\x3b\x72\x08\x46\xe4\ +-\xe7\x60\x58\x7e\x36\x86\xe7\x67\x63\x70\x46\x1a\xa2\x8c\xbe\x9d\ +-\x0b\xb5\xff\xe0\x49\x4e\x00\x18\x63\x3e\x53\x09\xd8\x73\x46\x82\ +-\x47\xc3\xe9\xc1\xe4\x44\xfa\xd2\x62\xfa\xd5\x13\xd3\xc5\xff\x68\ +-\x37\xea\xf9\x74\x4b\x00\x16\x12\x19\x1b\xb7\xe3\x37\x5a\x8d\xb7\ +-\xe1\xf3\x15\x30\x75\xb6\x6b\x35\x1c\xf3\x91\xc1\x20\x61\xc2\xa8\ +-\xa1\x28\xbc\x64\x34\xa6\x8c\x1f\x81\xf1\xa3\xf3\x91\x94\x10\x34\ +-\xbb\x64\x18\x63\x11\xe0\x78\x8b\x80\xd5\xad\xfd\xb8\x2d\x16\xfc\ +-\xc7\x8a\x32\xfa\xd3\x82\x89\x42\x87\xd1\x75\x4c\x00\x86\x15\xab\ +-\xaf\x9d\x72\x4a\x71\x5a\x8c\x55\x56\xba\x0f\xc7\x8f\x94\x68\x31\ +-\x14\xf3\x41\x5a\x4a\x12\xae\xb8\x74\x22\xe6\x4c\xbf\x04\x85\x97\ +-\x8c\x42\x7c\x9c\xa6\xc7\x3e\x30\xc6\xd8\x37\xcc\x4e\xa0\xa2\x45\ +-\x9b\x1a\xf4\x0b\x59\xdd\x88\xb5\x39\xd4\x97\x01\x7c\x57\x8f\xf1\ +-\x75\x49\x00\x96\xed\xa1\xe4\x5a\x0b\x1e\xd7\x62\x2c\x8b\xb9\x13\ +-\x9b\xbf\x58\xa5\xc5\x50\xac\x07\xe9\xa9\x49\xb8\x6e\xf6\x34\x5c\ +-\x33\x7b\x0a\x2e\x19\x33\x1c\x92\xa4\xcf\x1f\x1c\x63\x8c\x9d\xeb\ +-\x50\xa3\x36\xcf\xfd\xbb\xd3\x68\x91\x9e\x58\xb6\x87\xfe\xf5\xe1\ +-\x59\xc2\xac\xf5\xd8\xba\x24\x00\x2e\x89\xde\xb2\x7b\x84\x26\x63\ +-\x6f\xf8\xec\x43\xb8\x9d\x3d\x1c\xd5\xc4\x02\x26\xda\x68\xc4\xd5\ +-\xb3\x26\xe3\xe6\xab\x2f\xc5\x8c\xc9\x63\x60\x30\xe8\xbe\xe9\x84\ +-\x31\xc6\xbe\xd1\x60\x16\x68\xb5\xe9\x7b\x33\xe2\xf0\xc0\x68\x8f\ +-\xc7\x5b\x00\xe6\x6b\x3d\xb6\xe6\x09\xc0\x8a\x72\xca\xac\xa8\xa1\ +-\xbb\xb4\x18\xeb\x70\xc9\x1e\x54\x95\x1f\xd5\x62\x28\x76\x8e\xcc\ +-\xf4\x14\xdc\x71\xfd\x2c\xdc\x7d\xd3\x1c\xa4\xa5\x04\xe5\x31\xd8\ +-\x8c\xb1\x08\xa7\x10\x70\xa4\x29\x38\x56\x22\x9b\xad\x34\xef\x8d\ +-\x22\x2a\x78\x76\x86\x38\xa3\xe5\xb8\x9a\x27\x00\x56\x13\xde\x75\ +-\xca\x22\xe0\xb7\x82\x36\xab\x19\x5b\xd7\xaf\x0e\xf4\x30\xec\x1c\ +-\x13\x47\x0f\xc3\x43\xf3\xae\xc5\x15\x97\x5e\xc2\x4b\xfc\x8c\xb1\ +-\xa0\x56\xd9\x2a\x60\xd3\xa5\xf4\xee\x62\x6e\x45\x08\xd5\x43\x6f\ +-\x03\xb8\x46\xcb\x71\x35\x4d\x00\x56\x1f\xa6\xfc\xb2\x66\xdc\xa8\ +-\xc5\x58\x5b\xbf\xf8\x84\x97\xfe\x35\x32\xab\x70\x3c\x1e\x9e\x77\ +-\x1d\xa6\x4e\x18\xa9\x77\x28\x8c\x31\xd6\x2b\x97\x0c\x9c\x6c\x0d\ +-\xae\x9b\x94\x56\xbb\xb8\xfa\x9d\xbd\x34\xfc\xd1\x99\xa2\x4a\xab\ +-\x31\x35\x4d\x00\xda\xec\x78\xdb\xa5\x41\xcb\xdf\xea\xca\x13\x5c\ +-\xf5\xaf\x81\x4b\xc6\x0c\xc3\xb3\x0f\xdd\x86\x69\x13\x47\xe9\x1d\ +-\x0a\x63\x8c\xf9\xec\x74\x87\x80\x1c\x64\x2d\x61\x3c\x0a\x84\x03\ +-\x58\x0a\x60\xae\x56\x63\x6a\x96\x00\xbc\x7f\x98\xf2\x4f\xb5\x04\ +-\xfe\x3f\x4c\x51\x64\x6c\xfa\xe7\x47\x81\x1e\x26\xa2\x8d\x28\xc8\ +-\xc1\xf7\x1f\xbe\x03\xb3\x0a\xc7\xeb\x1d\x0a\x63\x8c\xf5\x09\x11\ +-\x50\xdd\x11\x5c\x77\xff\x67\x35\x5b\x71\x95\x96\xab\x00\x9a\x25\ +-\x00\x56\x07\xde\x71\xc9\x81\xbf\xfb\x2f\xda\xb9\x15\x1d\x6d\x2d\ +-\x81\x1e\x26\x22\x25\x25\xc4\xe3\xa9\xfb\x6f\xc6\xdd\x37\xcd\xe1\ +-\x8a\x7e\xc6\x58\x48\xea\x70\x7a\x8f\xf9\x0d\x46\x1e\x05\xc2\x29\ +-\xf0\x26\x34\xaa\x05\xd0\x24\x01\x58\x79\x90\x86\x1c\x6f\xc5\xd5\ +-\x81\x1e\xc7\x66\x35\x63\xcf\xf6\x8d\x81\x1e\x26\xe2\x08\x21\x70\ +-\xfb\x75\x33\xf1\xdc\x83\xb7\x23\x25\x39\x41\xef\x70\x18\x63\xac\ +-\xdf\x3a\x1d\xc1\x79\xf7\x7f\x56\x93\x05\x57\xbf\x57\x42\x43\x1f\ +-\x2a\x14\xd5\x81\x1e\x4b\x93\x04\xa0\xd3\x83\x25\x5a\x3c\xfb\xdf\ +-\xbe\x69\x0d\x3c\x6e\x57\xa0\x87\x89\x28\xb9\x83\x07\xe1\x67\xcf\ +-\x2e\xc0\x8c\xc9\x63\xf4\x0e\x85\x31\xc6\x06\xcc\x25\xeb\x1d\x41\ +-\xcf\x3c\x0a\x84\xd5\x83\xa5\x00\xae\x0d\xf4\x58\x01\x5f\xc7\x5d\ +-\x55\x4b\x83\x9a\xcd\xb8\x3e\xd0\xe3\x34\x35\xd4\xa2\xac\x74\x5f\ +-\xa0\x87\x89\x18\x42\x08\x2c\xb8\xed\x2a\xbc\xfd\xe7\x9f\xf1\xe4\ +-\xcf\x18\x0b\x1b\x5a\x9d\x3e\x3b\x10\xcd\x56\xcc\x7d\xbb\x94\xf2\ +-\x02\x3d\x4e\xc0\x57\x00\x2c\xcd\x78\xcd\x21\x07\x3e\xd1\xd8\xb6\ +-\xf1\x33\x50\x28\xfc\x64\x43\x40\x5a\x4a\x12\xfe\xfd\x07\x0f\x70\ +-\x91\x1f\x63\x2c\xec\x44\xf9\x76\xa8\xa8\xae\x3c\x0a\x84\xdd\x41\ +-\xaf\x03\xb8\x23\x90\xe3\x04\x74\x62\xde\xb5\x8b\xe2\x9a\xcc\x74\ +-\x77\x20\xc7\x00\x80\xda\xea\x53\xa8\xae\x3c\x11\xe8\x61\x22\xc2\ +-\x8c\xc9\x63\xf0\xd6\x9f\xff\x95\x27\x7f\xc6\x58\x58\x8a\x8f\xd2\ +-\x3b\x02\xdf\xb4\xdb\xc5\x2d\x0b\x8b\x28\xa0\x47\xa3\x06\x74\x05\ +-\xa0\x32\x56\xfd\xb3\xd5\x2a\x05\x74\x0c\x49\x00\x25\xdb\x3f\x0f\ +-\xe4\x10\x11\x41\x92\x04\x9e\xbe\xff\x56\x3c\x32\xff\x3a\x08\x11\ +-\xdc\x45\x32\x8c\x31\xd6\x5f\xc1\xba\x03\xe0\x42\x2e\x05\x86\x3c\ +-\x8f\xfa\x27\x00\xdf\x0f\xd4\x18\x01\x5b\x01\x58\x41\x64\x68\xb6\ +-\x8a\x27\x02\x75\x7d\x00\x88\x35\x02\x71\xe6\x32\x9c\x2c\x3f\x15\ +-\xc8\x61\xc2\x5e\x42\x7c\x1c\xfe\xf7\x17\x4f\xe3\xd1\x7b\xae\xe7\ +-\xc9\x9f\x31\x16\xb6\x5c\x32\x70\x52\xa7\xa3\x7f\xfb\xa3\xd3\x2d\ +-\x3d\x0e\xa2\x80\x05\x1c\xb0\x04\x20\xe1\x24\x9e\x4b\x8c\x41\xec\ +-\x88\x74\xc2\xb0\x34\x42\x4e\x32\x21\x31\x1a\x7e\xdb\x0a\x90\x18\ +-\x0d\x5c\x35\x5c\xc5\xc7\x9f\x6e\xf0\xd3\x15\x23\x53\x41\x6e\x16\ +-\x16\xfd\xe1\xc7\x98\x5d\x38\x41\xef\x50\x18\x63\x2c\xa0\xca\x1a\ +-\x05\x3c\x41\xd6\x01\xb0\x27\x36\x17\xe2\x16\xed\xc3\xbf\x06\xea\ +-\xfa\x01\x5b\x9e\xcf\x49\x54\x1e\xca\x49\xbc\x70\xba\x27\xb8\x15\ +-\xa0\xcd\x2e\xd0\x6a\x03\x5a\x6d\x02\x66\x27\xd0\xd7\xd2\xbd\xb4\ +-\x38\x60\x56\x81\x8a\xb2\xe3\xe5\x28\x2b\x3f\xed\xa7\x88\x23\xcf\ +-\x84\xd1\x43\xf1\xc7\x5f\x3e\xc3\x7b\xfb\x19\x63\x61\xaf\xde\x2c\ +-\x70\xc6\x14\x3a\x77\xff\x67\x99\xdd\xf8\x37\x00\x7f\x0c\xc4\xb5\ +-\x03\x92\x00\x14\xd7\xd3\x74\x90\x7a\x79\x57\x9f\x8b\x36\x00\x39\ +-\x49\x84\x9c\x24\x00\x20\x38\x65\xa0\xc1\x22\x50\xdd\x2e\xd0\xe9\ +-\xec\xfd\xda\xc3\xd3\x08\x97\xe4\x10\x0c\x02\x78\x67\xd5\x26\xff\ +-\x06\x1e\x41\xae\xbc\xf4\x12\x2c\x7c\xe1\x51\xc4\x44\x87\x48\x45\ +-\x0c\x63\x8c\xf5\x93\xc5\x05\x94\xd6\x87\xde\xe4\x0f\x00\x26\x07\ +-\x32\x97\xee\xa3\xf9\x4f\x5c\x26\x56\xf9\xfb\xda\x01\x49\x00\x04\ +-\xa9\x3f\xf5\xf5\xb5\xb1\x46\xef\xa4\x3e\x3c\x8d\xd0\x62\x13\xa8\ +-\x6a\x07\x1a\xcd\x02\xe7\xae\xd2\x18\x04\x30\x28\x81\x30\x36\x93\ +-\x30\xe8\xeb\x9a\xc8\xa3\x15\xd5\x28\x3a\x74\xd2\xcf\x91\x47\x86\ +-\xbb\x6e\x98\x8d\x7f\x79\xe6\x1e\x48\x12\xb7\xf3\x65\x8c\x85\x37\ +-\x97\x0c\xec\xa9\x96\xe0\x56\xf4\x8e\xa4\xff\xcc\x1e\xfa\x5f\x00\ +-\xc1\x9f\x00\x94\x9c\xa1\x5c\x40\xbd\xb7\x3f\x5f\x9b\x99\x40\xc8\ +-\x4c\x00\x14\x22\x98\x9c\x80\xa2\x0a\x44\x49\x84\xa4\x18\xe0\xc2\ +-\xd6\xf3\x1f\x7c\xba\xd5\x1f\xe1\x46\x9c\xfb\x6e\xbd\x0a\xcf\x3f\ +-\x31\x8f\x8b\xfd\x18\x63\x61\xcf\x25\x03\x3b\xab\x25\xd8\x42\xa4\ +-\xf2\xbf\x3b\x1d\x36\x31\xfa\x1f\xfb\x68\xea\x77\x2f\x13\xa5\xfe\ +-\xbc\xae\xdf\x13\x00\x61\x54\xbf\x4f\x84\xe8\x81\x5c\xc3\x20\x80\ +-\xf4\x38\xa0\xbb\xea\x80\x96\x76\x13\xb6\xed\x3b\x32\x90\x21\x22\ +-\xd2\x5d\x37\xcc\xe6\xc9\x9f\x31\x16\x11\xac\x6e\xef\x9d\xbf\xd5\ +-\xad\x77\x24\x03\xa7\x02\x20\xc2\x5f\xe0\xe7\xa3\x82\xfd\xba\x06\ +-\x5c\x5e\x4e\x31\x44\xf8\xae\x3f\xaf\xd9\x95\x95\x5f\x6c\x87\xac\ +-\x84\xf0\x7a\x8e\x0e\xee\xbd\xf5\x4a\xfc\xeb\x77\xef\xe5\xc9\x9f\ +-\x31\x16\xf6\x1a\x2d\x02\x5f\x55\x86\xc7\xe4\x7f\x56\xab\x15\x57\ +-\xbe\x73\x90\xfc\x5a\xb1\xed\xd7\x04\xc0\x9c\xa0\xdc\x07\x20\xd3\ +-\x9f\xd7\xbc\x90\xcb\xed\xc1\x67\x9b\xf6\x04\x72\x88\xb0\x73\xe3\ +-\x55\xd3\xf1\xe3\x27\xee\xe6\xc9\x9f\x31\x16\xd6\x64\xc5\x5b\xec\ +-\xb7\xf7\x4c\x68\x6d\xf7\xf3\x85\x4b\x81\x24\x7b\xf0\x7b\x7f\x5e\ +-\xd3\xaf\x09\x80\x20\x3c\xe7\xcf\xeb\x75\x65\xd3\x8e\x12\x98\x2d\ +-\xb6\x40\x0f\x13\x36\x66\x4e\x1b\x87\x5f\xfd\xe0\x01\x9e\xfc\x19\ +-\x63\x61\x8b\x00\x9c\x31\x09\x6c\xae\x90\x70\xba\x43\xf4\x79\x6b\ +-\x79\xa8\x30\x39\xe8\x31\x7f\x5e\xcf\x6f\x09\x40\x49\x03\x4d\x00\ +-\xc4\x1c\x7f\x5d\xaf\x3b\x9f\x6d\xe4\xbb\x7f\x5f\x8d\x1b\x59\x80\ +-\xdf\xfd\xcb\xe3\x30\x1a\x42\xe0\xf4\x0b\xc6\x18\xeb\x23\xc2\xd7\ +-\xcb\xfd\xa7\x24\x94\xd4\x0a\x38\x82\xfc\xa8\xdf\x81\xea\x74\x88\ +-\xd4\xe5\x07\xc9\x6f\x07\x04\xf9\xaf\x08\x90\xd4\x1f\xfa\xed\x5a\ +-\xdd\xa8\xaa\x69\xe4\xc6\x3f\x3e\x1a\x9c\x91\x86\x3f\xfe\xea\x69\ +-\xc4\xc7\xc6\xe8\x1d\x0a\x63\x8c\xf9\x95\xc3\xf3\x75\x63\x9f\x4e\ +-\x01\x93\x0f\xfd\x63\xc2\x05\x01\xe8\xb4\xd1\x6f\x01\xf8\xe5\x00\ +-\x1c\xbf\x24\x00\x65\xcd\x94\xe8\xf2\xa8\x0f\xf9\xe3\x5a\x3d\xf9\ +-\x7c\x33\xdf\xfd\xfb\x22\x3a\x2a\x0a\xbf\xff\xb7\xc7\x91\x96\x92\ +-\xa4\x77\x28\x8c\x31\xe6\x17\x6e\x05\xa8\x35\x09\xd4\x9a\x04\x3a\ +-\xec\x7d\xef\x20\x1b\x2e\xda\x1d\x62\xca\x8a\x12\xca\x5c\x50\x28\ +-\x5a\x06\x7a\x2d\xbf\x24\x00\x6e\x59\x79\x00\x10\xc9\xfe\xb8\x56\ +-\xf7\x63\xc8\x58\xf7\x55\x51\x20\x87\x08\x1b\x3f\x7b\x6e\x01\xc6\ +-\x8d\x2c\xd0\x3b\x0c\xc6\x18\xf3\x8b\x8a\x36\x81\xe3\x2d\x02\x32\ +-\x6f\xfe\x82\x5b\x81\x30\x7b\xd4\xff\x05\xf0\xd4\x40\xaf\xe5\x97\ +-\x1a\x00\x22\x3c\xe9\x8f\xeb\xf4\x64\x4f\xc9\x71\x2e\xfe\xf3\xc1\ +-\x7d\xb7\x5e\x85\x9b\xaf\x9e\xa1\x77\x18\x8c\x31\xe6\x17\xe5\xad\ +-\x02\x47\x1a\x79\xf2\x3f\x57\xa7\x4b\xea\x57\xb3\xbd\x0b\x0d\x38\ +-\x01\x28\xad\xa5\x31\x80\x98\xe9\x8f\x60\x7a\xb2\x69\x3b\xdf\xfd\ +-\xf7\x66\xcc\x88\x21\xf8\xfe\xa3\x77\xea\x1d\x06\x63\x8c\xf9\x85\ +-\xc5\x05\x1c\x6f\xe6\x1d\x4c\x17\x32\x3b\x91\xfc\xee\x7e\xba\x61\ +-\xa0\xd7\x19\x70\x02\x40\x42\x7d\x0a\xfe\x3b\xe5\xb7\x4b\x76\x87\ +-\x0b\x3b\x8b\x8f\x06\x72\x88\x90\x17\x17\x1b\x8d\x85\x3f\x79\x04\ +-\x51\x46\xae\xf8\x67\xcc\x9f\xa6\x4f\x1a\x8d\x91\x05\xd9\x7a\x87\ +-\x11\x91\x0e\x35\x08\x28\x91\xfa\xb0\xbf\x17\x36\x05\xbf\x19\xe8\ +-\x35\x06\x54\x03\xb0\x95\xc8\x48\x0d\xea\x23\x81\xae\xc6\xd8\xbe\ +-\xef\x30\x5c\xee\x10\x6f\xe6\x1c\x60\x3f\x7a\xfc\x6e\x14\xe4\x66\ +-\xe9\x1d\x06\x63\x61\x23\x2b\x23\x15\x3f\x7c\x6c\x1e\xae\xbd\x7c\ +-\x8a\xde\xa1\x68\x4a\x55\x09\x36\x87\x03\x09\x71\x71\x90\x24\xfd\ +-\xee\xbe\x6b\x4d\x02\x2d\x36\xbe\xfb\xef\x4e\x87\x9d\x2e\x7f\xa3\ +-\x88\xa2\x9e\x9d\x21\xfa\x3d\x39\x0e\x28\x01\x48\xae\x53\x6e\x86\ +-\x10\x39\x03\xb9\x86\x2f\x36\xef\x3c\x10\xe8\x21\x42\xda\x55\x33\ +-\x27\xe1\xce\xeb\x67\xe9\x1d\x06\x63\x61\x21\xda\x68\xc4\xfd\x77\ +-\xce\xc5\xa3\xf3\x6f\x40\x5c\xec\x80\x8e\x35\xd1\x9d\x5b\x96\xd1\ +-\xd0\xd8\x86\xa6\xb6\x4e\x74\x74\x5a\xd0\xd6\x69\x46\x6b\x87\x19\ +-\x1d\x26\x0b\x5a\xdb\x4d\xb0\x3b\xdd\xb0\x5a\x1d\xf0\xc8\x32\x1c\ +-\x4e\x37\x1c\x4e\x57\xb7\x6d\xd6\xa3\x8c\x06\xc4\xc6\xc4\x20\x3e\ +-\x2e\x06\xa9\x29\x89\x48\x4d\x4e\x40\x4a\x52\x02\x52\x93\x12\x90\ +-\x92\x9c\x80\xec\x8c\x74\xe4\xe7\x66\x62\x48\x4e\x26\x92\x13\xe3\ +-\x07\x14\xb7\xdd\x0d\x1c\x0c\xd1\xe3\x7b\xb5\xe2\x90\x85\x21\xd1\ +-\x80\x1f\x03\xf8\x53\x7f\xaf\x31\xa0\x04\x40\x12\xe2\x91\x40\xaf\ +-\xce\xd8\x1d\x2e\x3e\xf6\xb7\x07\x89\xf1\x71\xf8\x97\x67\xfc\x52\ +-\x0f\xc2\x58\xc4\x9b\x39\x6d\x1c\x7e\xfc\x44\xe8\xad\xa6\xb5\x77\ +-\x98\x51\x7e\xba\x1e\xa7\xeb\x9a\x50\xdb\xd0\x82\xda\xc6\x16\xd4\ +-\x36\xb4\xa2\xa9\xb5\x13\xaa\xea\x9f\x9e\xb8\x1e\x59\x81\x47\xb6\ +-\xc3\x62\xb3\xa3\xa9\xb5\xa3\xc7\xd7\x26\x27\x25\xa0\x20\x27\x13\ +-\xf9\xb9\x99\x18\x9e\x9f\x8d\x89\x63\x86\x62\xdc\xc8\x02\xc4\x44\ +-\x47\xf5\x3a\x8e\x53\x06\xf6\xd4\x48\x61\xd7\xca\x37\x10\x3a\x1c\ +-\x78\x0e\x7a\x24\x00\x3b\x5a\x28\x89\xdc\xea\xed\xfd\xfd\x7a\x5f\ +-\xed\x29\x3d\x0e\xb7\x1c\xe6\xed\x9d\x06\xe0\xb9\x87\x6f\xc7\xa0\ +-\xd4\x80\xee\xc0\x64\x2c\xec\xe5\x64\xa5\xe3\x47\x8f\xdf\x8d\xab\ +-\x2e\xbb\x44\xef\x50\x7a\xd5\xdc\xda\x89\x23\xe5\xd5\xa8\x38\x5d\ +-\x8b\x93\x55\x75\x28\x3f\x55\x87\xb6\x4e\xb3\xde\x61\x9d\xc7\x6c\ +-\xb1\xe1\x88\xc5\x86\x23\x27\x4f\x7f\xf3\x31\xa3\xc1\x80\x31\xc3\ +-\x87\xe0\x92\xb1\x43\x31\x71\xcc\x70\x4c\x1e\x3f\x1c\x99\xe9\x29\ +-\xe7\x7d\x9d\x43\x06\x76\x9e\x96\x60\x75\x69\x1c\x70\x88\xea\x70\ +-\x60\xc4\x40\x7a\x02\xf4\x3b\x01\x48\x70\x29\xf3\x49\x88\x81\xad\ +-\xf3\xf8\x60\xfb\xbe\x43\x81\x1e\x22\x64\x4d\x18\x3d\x14\x77\x5e\ +-\x7f\xb9\xde\x61\x30\x16\xb2\xa2\x8c\x06\xcc\xbb\x71\x0e\x9e\x79\ +-\xf0\xd6\xa0\xec\x9a\xa9\xaa\x2a\xaa\xeb\x9a\x71\xf8\x78\x15\x0e\ +-\x1e\x3f\x85\xc3\xc7\xab\x50\xdf\xd4\xa6\x77\x58\xfd\x22\x2b\x0a\ +-\x8e\x56\x54\xe3\x68\x45\x35\xf0\xcf\x6d\x00\x80\x61\xf9\xd9\x98\ +-\x33\x7d\x22\xe6\x4c\x9f\x80\x21\x43\x87\x63\x7f\x8d\x21\xec\xdb\ +-\xf9\xfa\x93\x47\x81\xb0\xc8\xea\x7f\x02\xe8\x57\x27\xde\x7e\x27\ +-\x00\x24\xa4\x07\x02\xdd\x8b\x49\x56\x14\xec\x2e\x3e\x16\xd0\x31\ +-\x42\x95\xd1\x60\xc0\x2f\xbe\x77\xbf\xae\x45\x3a\x8c\x85\xb2\xd9\ +-\xd3\x27\xe0\xc7\x4f\xde\x8d\xbc\xc1\x19\x7a\x87\x72\x9e\x86\xe6\ +-\x76\xec\x2b\x3d\x8e\x7d\x87\x4e\xa0\xe8\x50\x39\x6c\x76\x87\xde\ +-\x21\x05\xcc\xe9\x9a\x46\x9c\xae\x69\xc4\x7b\xab\x37\x23\x39\x25\ +-\x0d\xa3\xc6\x4f\xc2\xa8\xb1\x93\x90\x3f\x7c\x34\x1f\x60\xe6\x23\ +-\xb3\x4b\x2c\x80\x96\x09\xc0\xc1\x46\xca\x52\x14\xf5\xba\xfe\x7c\ +-\x6d\x5f\x1c\x3e\x5e\x05\x6b\x18\xff\xf2\x0f\xc4\x5d\x37\x5e\x8e\ +-\x11\x05\x01\xaf\xbf\x64\x2c\xec\xe4\x0d\xce\xc0\x8f\x9f\xbc\x1b\ +-\xb3\xa7\x4f\xd0\x3b\x14\x00\xde\x1b\x9d\x03\x47\x2a\xb1\xb3\xf8\ +-\x08\xf6\x95\x9e\xc0\x99\xfa\x66\xbd\x43\xd2\x85\xd9\xd4\x81\x92\ +-\x3d\xdb\x50\xb2\x67\x1b\x92\x53\xd3\x31\x65\xfa\x6c\x4c\x2a\x9c\ +-\x85\xf8\x44\x6e\x69\xde\x93\x4e\xa7\xc8\x7c\xbb\x94\xc6\x3c\x36\ +-\x55\xf4\xb9\x58\xae\x5f\x09\x80\xa2\xa8\xf7\xf7\xf7\x6b\xfb\x62\ +-\xdf\xc1\x13\x81\x1e\x22\x24\xc5\xc5\xc5\xe0\xf1\x7b\x6f\xd4\x3b\ +-\x0c\xc6\x42\x4a\x4c\x74\x14\x1e\x9a\x77\x2d\x1e\xbe\xfb\x3a\x44\ +-\x47\xf5\x5e\x8c\x16\x48\x2e\xb7\x07\x45\x87\x4e\x62\x67\x71\x19\ +-\xb6\xef\x3b\x82\x0e\x93\x45\xd7\x78\x82\x8d\xb9\xb3\x1d\xdb\x37\ +-\xaf\xc1\xae\x2f\xbf\xc0\xa8\x71\x93\x30\x79\xfa\x6c\x0c\x1d\x31\ +-\x06\xe0\x55\x81\x8b\x10\x01\x1e\x0f\xfe\x03\xc0\x23\x7d\xfd\xda\ +-\x7e\x4e\xe2\x74\x7f\x80\x7b\xff\x00\xe0\x04\xa0\x3b\x8f\xdf\x73\ +-\x03\x1f\xf4\xc3\x58\x1f\x5c\x35\x73\x12\x7e\xf4\xd8\x3c\xe4\x64\ +-\xa5\xeb\x16\x83\xac\x28\xd8\x57\x7a\x02\x1b\xb6\x15\x61\xfb\xfe\ +-\x23\xdc\xdb\xc4\x07\x8a\xa2\xe0\x44\x59\x29\x4e\x94\x95\x22\x3d\ +-\x73\x30\x2e\x9d\x7d\x2d\x26\x4e\xb9\x14\x12\x1f\x71\x7e\x1e\xab\ +-\x93\x6e\xed\xcf\xd7\xf5\x39\x01\x38\xdc\x44\x83\x3d\xb2\x1a\xf0\ +-\xca\x33\x93\xd9\x86\xf2\xaa\xda\x40\x0f\x13\x72\x06\x67\xa4\xe1\ +-\xde\x5b\xaf\xd2\x3b\x0c\xc6\x42\x42\x41\x6e\x16\x7e\xf2\xe4\x7c\ +-\x5c\x36\x75\xac\x6e\x31\x1c\xad\xa8\xc6\xfa\xaf\x8a\xb0\x79\x67\ +-\x29\x3a\xcd\x56\xdd\xe2\x08\x75\xed\x2d\x4d\x58\xff\xe9\xfb\xd8\ +-\xfd\xd5\x7a\xcc\xbc\xe2\x7a\x5c\x52\x38\x0b\x06\x4e\x04\x00\x00\ +-\x9d\x0e\x91\xfe\x41\x29\x8d\xf9\x4e\x1f\x1f\x03\xf4\x39\x01\xf0\ +-\x78\xd4\xf9\x10\xfe\x39\x44\xa8\x27\xfb\x0f\x9f\x84\xaa\x72\x0f\ +-\xc8\x0b\x3d\x7e\xef\x8d\x3e\xed\xa5\x65\x2c\x92\xc5\xc5\x46\xe3\ +-\xb1\x7b\x6e\xc4\xfd\x77\xcc\xd5\xa5\x3d\xb6\xcd\xee\xc0\xfa\xed\ +-\x25\xf8\x6c\xc3\x6e\x54\x54\xd7\x69\x3e\x7e\x38\x33\x77\xb6\x63\ +-\xe3\x9a\x15\xd8\xbf\x6b\x0b\xae\xbc\xfe\x0e\x8c\x9d\x30\x25\xe2\ +-\x1f\x0d\xa8\x00\x6c\x6e\xf5\x17\x40\xdf\x0e\xe6\xeb\xfb\x23\x00\ +-\x21\xee\xd1\xe2\x24\xe6\x92\x23\xe5\x01\x1f\x23\xd4\x64\x0d\x4a\ +-\xc5\xcd\x73\x2f\xd5\x3b\x0c\xc6\x82\xda\xb5\x97\x4f\xc1\x0f\x1f\ +-\x9f\x87\xac\x41\xa9\x9a\x8f\x7d\xea\x4c\x3d\x3e\x5c\xb3\x0d\x5b\ +-\x76\x1d\x80\xc3\xe9\xd6\x7c\xfc\x48\xd2\xd9\xde\x8a\xcf\x57\x2c\ +-\x45\xf1\x90\x61\xb8\xf6\xb6\x7b\x90\x9d\x1b\xd9\x47\xa0\x5b\x5c\ +-\xa2\xcf\x7d\x79\xfa\x94\x00\xec\xad\xa5\x41\x80\x7a\x75\x5f\x07\ +-\xe9\x8f\xd2\xa3\xa7\xb4\x18\x26\xa4\x3c\x70\xd7\x35\x7c\xd8\x0f\ +-\x63\xdd\x28\xc8\xcd\xc2\x8f\x9f\xb8\x1b\x33\xa7\x8d\xd3\x7c\xec\ +-\x43\xc7\x4e\x61\xd9\xea\xcd\xd8\x5d\x72\x0c\x44\xbc\x72\xa9\xa5\ +-\xfa\xda\xd3\x78\xef\x1f\x2f\x62\xfc\xe4\x19\xb8\xf6\xe6\xbb\x11\ +-\x1b\x9f\xa0\x77\x48\xba\x30\x39\x45\xe6\x7b\x25\x34\xf4\xa1\x42\ +-\x51\xed\xeb\xd7\xf4\x29\x01\x30\x0a\xe5\x4e\x40\x04\xbc\xfa\xbf\ +-\xd3\x6c\x45\x4d\x84\x6e\x85\xe9\x4e\x5a\x4a\x12\xee\xb8\x8e\xfb\ +-\xfd\x33\x76\xa1\xb8\xb8\x18\x3c\x79\xdf\x4d\xb8\xef\xb6\xab\x60\ +-\xd4\xf0\x99\xb0\xaa\x12\xbe\xdc\x7b\x08\x6f\x7d\xb4\x01\xa7\xce\ +-\xd4\x6b\x36\x2e\xbb\x18\x11\xe1\xe8\xc1\xfd\xa8\x3e\x75\x02\x37\ +-\xde\x71\x3f\x46\x8e\x0d\xfe\x8e\x8e\xfe\xa6\x10\xe0\x54\xf1\x0b\ +-\x00\xdf\xf3\xf5\x6b\xfa\x34\x99\x0b\x48\x77\x69\xb1\xfc\x7f\xe8\ +-\x58\x15\x67\xd1\x17\xb8\xef\xd6\xab\x10\x1b\x13\xda\x07\x93\x30\ +-\xe6\x4f\x42\x08\x5c\x7f\xc5\x34\xfc\xe0\xd1\x3b\x91\x91\x96\xd2\ +-\xfb\x17\xf8\x09\x11\x61\xcb\xae\x83\x78\xeb\xe3\xf5\xa8\xaa\x69\ +-\xd4\x6c\x5c\xd6\x3b\x9b\xc5\x8c\x4f\x96\x2f\xc2\x25\xd3\x66\xe2\ +-\xda\x5b\xe6\x23\x3a\x26\x56\xef\x90\x34\x65\x71\xd2\x9d\x08\x44\ +-\x02\x50\x5e\x4e\x31\x16\x04\xbe\xf9\x0f\x00\x1c\x3c\x56\xa9\xc5\ +-\x30\x21\x23\x3a\x2a\x0a\x77\xdd\xc0\x2d\x7f\x19\x3b\x6b\x44\x41\ +-\x2e\x5e\x78\xea\x6e\x4c\x9b\x38\x4a\xd3\x71\x0f\x1e\xab\xc4\xcb\ +-\x6f\x7f\x86\x63\x15\x67\x34\x1d\x97\xf5\xcd\x91\x03\x7b\x51\x53\ +-\x55\x8e\x3b\x16\x3c\x81\xec\xbc\xc8\xa9\x0d\x30\x3b\x45\xce\xb2\ +-\x3d\x94\xfc\xf0\x2c\xe1\xd3\xe1\x10\x3e\x27\x00\xd6\x58\xe5\x3a\ +-\x40\x24\xf6\x3f\x34\xdf\x95\x9d\xf4\xf9\x11\x46\x44\xb8\x66\xf6\ +-\x14\xa4\x24\x47\xe6\x73\x2d\xc6\xce\x95\x10\x1f\x87\xa7\xee\xbf\ +-\x19\xf7\xdc\x7c\x05\x0c\x86\x80\x6f\x46\xfa\x46\x63\x4b\x3b\x5e\ +-\x7e\xfb\x53\x7c\xb9\x87\xcf\x26\x09\x15\xa6\xce\x76\xbc\xbf\xe4\ +-\x2f\xb8\xfa\xc6\x79\x28\x9c\x15\x19\x5b\xa7\x65\x15\xc2\x23\xd4\ +-\xef\x01\xf8\x7f\xbe\xbc\xde\xe7\x04\x40\x95\xc4\x6d\x5a\x6c\xb4\ +-\x50\x14\x15\xe5\xa7\x79\xdb\xcc\xb9\xee\xbe\x69\x8e\xde\x21\x30\ +-\xa6\x2b\x21\x04\x6e\xbe\x7a\x06\xbe\xf7\xf0\x1d\x48\x4f\xd5\xae\ +-\x09\x96\xdb\xe3\xc1\x7b\xab\xb7\x60\xd9\x27\x9b\xb9\x71\x4f\x08\ +-\x52\x14\x05\x5b\xbe\x58\x89\x86\xda\xd3\xb8\xe9\xae\x07\x60\xd4\ +-\xb9\x03\xa4\x16\x9c\x24\x2d\x80\xbf\x13\x00\x01\xf4\xab\xd3\x50\ +-\x5f\x9d\xaa\x69\xe0\x3f\xb4\x73\x8c\x1e\x96\x87\x4b\xc6\x0c\xd3\ +-\x3b\x0c\xc6\x74\x33\x7a\x58\x1e\x5e\x78\x6a\x3e\x26\x8f\x1f\xa1\ +-\xe9\xb8\x3b\x8b\xca\xf0\xd7\xa5\x9f\x84\xec\xe9\x7b\xec\x5b\xc7\ +-\x0e\x17\xa3\xb3\xa3\x15\xf3\xbe\xf3\x34\x12\x92\xc2\xfb\xf8\x74\ +-\xb3\x93\x26\xf9\xfa\x5a\x9f\x12\x80\xe2\x1a\x9a\x0c\xa8\xc3\xfa\ +-\x1d\x51\x1f\x9c\xa8\xe4\xee\x7f\xe7\xe2\xbb\x7f\x16\xa9\x92\x12\ +-\xe2\xf1\xcc\x03\xb7\x60\xde\x8d\xb3\x21\x49\xda\x2d\xf7\xd7\x34\ +-\xb4\xe0\xaf\x4b\x3f\xc1\x9e\x12\x3e\x89\x34\x9c\x34\xd4\x56\xe3\ +-\xbd\x45\x2f\x62\xfe\xc3\xcf\x22\x23\x2b\x7c\x0f\x52\xb3\xb9\x45\ +-\xd4\x7b\x25\x74\xfd\x43\x85\x62\x53\x6f\xaf\xf5\x6d\x05\x40\x52\ +-\x6f\x1e\x70\x54\x3e\x3a\x5e\xc9\xc5\x35\x67\x45\x19\x0d\x98\x7b\ +-\xf9\x14\xbd\xc3\x60\x4c\x53\x42\x08\xdc\x78\xd5\x74\xfc\xf0\xd1\ +-\x3b\x35\x3d\xf3\xc2\xe9\x72\x63\xf9\xa7\x5b\xb0\xec\x93\x2d\x70\ +-\x7b\x78\x15\x32\x1c\x99\x4d\x1d\x78\x7f\xc9\xdf\x30\xff\xe1\xef\ +-\x22\x2f\x7f\xb8\xde\xe1\x04\x8c\xd3\x43\xcf\x02\xf0\x4f\x02\x20\ +-\x20\x6e\xd0\x62\xfb\x1f\x00\x9c\xac\xe2\xe7\xff\x67\xcd\x9c\x36\ +-\x0e\xc9\x89\xf1\x7a\x87\xc1\x98\x66\xc6\x8d\x2c\xc0\x4f\x9f\x99\ +-\x8f\x09\xa3\x86\x6a\x3a\xee\x96\x5d\xa5\x78\xf9\x9d\x4f\xd1\xdc\ +-\xda\xa9\xe9\xb8\x4c\x7b\x2e\xa7\x1d\x2b\xdf\x79\x0d\x77\x7d\xe7\ +-\x29\x0c\x1d\xa9\xdf\x19\x11\x81\x64\xf6\xc0\xa7\xaa\xc7\x5e\x13\ +-\x80\xad\x55\x14\x0b\xa8\x9a\xac\x43\x13\x11\xaa\x6a\x79\x5f\xed\ +-\x59\xd7\xcd\x29\xd4\x3b\x04\xc6\x34\x91\x9c\x94\x80\xe7\x1e\xbc\ +-\x0d\xb7\x5f\x37\x0b\x92\xa4\x5d\x5f\xf7\xaa\x9a\x46\xbc\xb4\x64\ +-\x15\xb7\x1e\x8f\x30\x6e\xb7\x0b\xab\xde\xfb\x07\xee\x7e\xf0\x19\ +-\x0c\x1b\xa5\x7d\xe7\xc8\x40\x33\x3b\x91\xb5\xa2\x88\x52\x16\xcc\ +-\x10\xa6\x9e\x5e\xd7\x6b\x02\x90\x1a\x2d\x5f\x49\x90\xe2\xfc\x17\ +-\x5a\xf7\x1a\x5b\x3a\xe0\x70\xb8\xb4\x18\x2a\xe8\xc5\xc5\x46\xe3\ +-\x8a\x19\x91\xd7\xcd\x8a\x45\x16\x49\x12\xb8\xe1\xca\xe9\xf8\xd1\ +-\x63\x77\x21\x35\x59\x93\x5d\xc6\x00\x00\x87\xd3\x8d\xf7\x3f\xdb\ +-\x82\x77\x57\x6d\x82\x47\x56\x34\x1b\x97\x05\x0f\x45\x91\xb1\xfa\ +-\x83\xc5\x98\xff\xd0\x77\x51\x30\x7c\x8c\xde\xe1\xf8\x95\xa2\x0a\ +-\xd8\x55\x3c\x03\xe0\x4f\x3d\xbd\xae\xd7\x04\x40\x85\x74\x83\x56\ +-\xf9\x38\xdf\xfd\x7f\x6b\xce\xf4\x89\x88\x8b\xe5\xce\x7f\x2c\x7c\ +-\x4d\x1c\x3d\x0c\x3f\x7d\x7a\x3e\xc6\x8e\xcc\xd7\x6c\x4c\x22\xc2\ +-\xfa\x6d\xc5\x78\x75\xd9\xe7\x68\xef\xf0\xa9\x57\x0a\x0b\x63\xb2\ +-\xc7\x83\x4f\x96\x2f\xc2\xbd\x8f\x7c\x0f\x79\x05\xda\xee\x32\x09\ +-\x34\x87\x4c\xf3\x31\xd0\x04\x40\x00\x37\xf8\x2d\xa2\x5e\x54\x9d\ +-\x69\xd0\x6a\xa8\xa0\x37\x87\xef\xfe\x59\x98\x4a\x4e\x8c\xc7\xe3\ +-\xf7\xdd\x84\x7b\x6f\xb9\x52\xd3\xe5\xfe\xf2\xd3\x75\x78\x69\xf1\ +-\x2a\x1c\x3a\xce\x07\x8d\xb1\x6f\x79\xdc\x6e\x7c\xb2\x7c\x11\x1e\ +-\x7c\xfa\x27\x48\xcf\x18\xac\x77\x38\x7e\x63\x97\x45\xaf\xdb\x01\ +-\x7b\x4c\x00\xca\x6a\x28\xdd\x05\x75\xb2\xff\x42\xea\x19\xf7\xd5\ +-\xf6\x92\x24\x09\x97\x4d\x09\xcf\xe2\x14\x16\xb9\x24\x49\xc2\xdd\ +-\x37\xcd\xc6\x33\x0f\xdc\x8a\xc4\x78\x4d\x9e\x2a\x02\x00\xcc\x56\ +-\x3b\x16\xbd\xbf\x16\x9f\x6e\xdc\x0d\x55\x55\x35\x1b\x97\x85\x0e\ +-\xa7\xc3\x8e\x95\xcb\xde\xc0\x83\x4f\xfd\x24\x6c\xfa\x04\x58\x9c\ +-\x48\x5c\x51\x4a\x79\x0b\xa6\x8a\x6e\x2b\xeb\x7b\x4c\x00\xdc\x06\ +-\xe5\x2a\x90\xd0\x6c\x03\x6e\x5d\x23\x37\xdc\x00\x80\xf1\x23\x0b\ +-\xb8\xf5\x2f\x0b\x2b\x93\xc7\x8f\xc0\x4f\x9f\x9e\x8f\x51\x43\xf3\ +-\x34\x1b\x53\x55\x09\x6b\x36\xef\xc1\xeb\xcb\xff\x09\xb3\xc5\xa6\ +-\xd9\xb8\x2c\x34\x99\x3a\xda\xf0\xc9\xf2\x45\xb8\xff\xc9\x1f\x21\ +-\x2a\x2a\xf4\x1f\xbf\xaa\x00\xec\xb2\xfa\x04\x80\xff\xee\xee\x35\ +-\xbd\x3c\x02\x10\x9a\x36\x50\xae\x6b\x6a\xd5\x72\xb8\xa0\x75\xf9\ +-\xf4\xf1\x7a\x87\xc0\x98\x5f\xa4\xa7\x25\xe3\xfb\x0f\xdf\x81\x9b\ +-\xae\x9a\x0e\x21\xb4\x5b\xee\x3f\x51\x59\x83\x17\x17\xaf\x42\x59\ +-\xf9\x69\xcd\xc6\x64\xa1\xaf\xb1\xfe\x0c\xd6\x7f\xf6\x01\x6e\xbf\ +-\xe7\x51\xbd\x43\xf1\x0b\x97\x2c\xdd\x8a\xfe\x26\x00\x44\xb8\xda\ +-\xef\x11\x75\xc3\xee\x74\xa1\xc3\x64\xd5\x6a\xb8\xa0\x36\x6b\x5a\ +-\xf8\x6d\x4b\x61\x91\xc5\x60\x90\x30\xff\xa6\x2b\xf0\xf4\x77\x6e\ +-\x46\x82\x96\xcb\xfd\x16\x1b\x96\x7e\xb4\x01\x2b\xd7\x6d\x87\xaa\ +-\xf2\x91\xe2\xac\xef\x8e\x1f\x2a\x46\x4e\x6e\x01\xa6\x5f\x3e\x57\ +-\xef\x50\x06\xcc\xea\x41\x8f\xc5\x64\xdd\x26\x00\x7b\xda\x28\x19\ +-\x4e\x55\xb3\x36\x74\x0d\x4d\x6d\x20\xe2\x3f\xd8\xc4\xf8\x38\x8c\ +-\x19\xae\x5d\x55\x34\x63\xfe\x36\x6d\xe2\x48\xbc\xf0\xd4\x3d\x18\ +-\x51\xa0\x5d\xbb\x55\x45\x51\xb1\x6a\xfd\x0e\x2c\xf9\x60\x1d\xac\ +-\x76\x87\x66\xe3\xb2\xf0\xf4\xd5\x86\x4f\x91\x95\x9b\x8f\xfc\xa1\ +-\x23\xf5\x0e\x65\x40\x2c\x4e\x24\xad\xaa\xa0\xac\xf9\xa3\x44\x73\ +-\x57\x9f\xef\x36\x01\x88\xb1\x2b\x57\x90\x24\x0c\x81\x0b\xed\x7c\ +-\xfc\xfc\xdf\x6b\xd2\xd8\x61\x9a\x56\x46\x33\xe6\x2f\x83\x52\x93\ +-\xf1\xbd\x47\xb4\x5f\xee\x2f\x3d\x5a\x89\x97\x96\xac\x42\x65\x75\ +-\xbd\x66\x63\xb2\xf0\xa6\xaa\x2a\xfe\xf9\xf1\xdb\x78\xfc\x7b\x3f\ +-\x47\x6c\x7c\xe8\xd6\x63\xa9\x04\x98\x4d\xea\xe3\x00\xfe\xaf\xab\ +-\xcf\x77\x9b\x00\xa8\x42\xcc\xd1\x72\x1a\x6a\x68\x69\xd7\x70\xb4\ +-\xe0\x35\x69\x5c\xf8\xf6\xa7\x66\xe1\xc9\x68\x30\xe0\xee\x9b\xe6\ +-\xe0\x99\xef\xdc\x82\xf8\xf8\x58\xcd\xc6\x6d\xed\x30\xe1\xb5\x65\ +-\x6b\xb0\x61\x5b\x31\xaf\x1e\x32\xbf\xb3\x9a\x4d\x58\xff\xd9\x07\ +-\xb8\xeb\x3b\x4f\xe9\x1d\xca\x80\x38\x3d\xe2\x36\xf4\x35\x01\x80\ +-\x24\x2e\x87\x86\x7f\x54\xad\xed\x3d\x76\x2c\x8c\x18\x97\x70\x02\ +-\xc0\x42\xc8\x8c\xc9\x63\xf0\xd3\xa7\xe6\xa3\x20\x4f\xbb\xfd\xd3\ +-\x1e\x59\xc1\x47\x6b\xbe\xc2\x5b\x1f\x6f\x80\xdd\xc9\x9d\x43\x59\ +-\xe0\x94\x1f\x3b\x84\xc3\xc5\xbb\x31\x69\xfa\xe5\x7a\x87\xd2\x6f\ +-\x0e\x59\x4c\xec\xee\x73\x5d\x26\x00\x44\x24\x1d\xa8\x57\xa7\x07\ +-\x2e\xa4\x8b\x35\xb7\x75\x68\x39\x5c\x50\x32\x18\x24\x8c\xd3\xb0\ +-\x2b\x1a\x63\xfd\x95\x99\x9e\x82\x67\x1f\xba\x1d\x37\x5f\x3d\x43\ +-\xd3\x71\x4b\x8e\x94\xe3\xa5\x25\xab\xb8\x67\x08\xd3\xcc\x96\x75\ +-\xab\x50\x30\x62\x0c\x52\xd2\x06\xe9\x1d\x4a\xbf\xd8\x5c\x48\x5f\ +-\x41\x64\x58\x20\xc4\x45\x3d\xaf\xbb\x4c\x00\x4a\x6a\x71\x89\x90\ +-\xa0\x69\x37\x84\x96\x36\x8b\x96\xc3\x05\xa5\x51\xc3\xf2\x10\x1f\ +-\x1b\xa3\x77\x18\x8c\x75\x2b\xda\x68\xc4\x77\xee\x9a\x8b\x47\xe7\ +-\xdf\x80\xd8\x18\xed\xf6\x4a\x37\x34\xb7\xe3\xef\x6f\xaf\xc6\xb6\ +-\xbd\x87\x35\x1b\x93\x31\xc0\xdb\x29\x70\xd3\x3f\x3f\xc6\x3d\x0f\ +-\x3f\xab\x77\x28\xfd\xe2\x56\x20\xdc\x07\x70\x23\x80\x2f\x2e\xfc\ +-\x5c\x97\x09\x80\x64\x50\x66\x12\x69\x53\x01\xd0\xee\x00\xca\x5b\ +-\x05\xaa\x1b\x79\x05\x60\xf4\xb0\x5c\xbd\x43\x60\xac\x5b\xd3\x27\ +-\x8d\xc6\x4f\x9f\xba\x07\x43\x87\x68\xbb\xdc\xff\xc9\xfa\x9d\x58\ +-\xfc\xfe\x5a\x5e\xee\x67\xba\xa9\x2a\x3f\x8a\x63\x87\x8a\x30\x7e\ +-\xb2\xb6\x2b\x5e\xfe\xe2\x26\xcc\x83\xaf\x09\x00\x91\x98\x19\xe8\ +-\x80\x14\x02\x0e\x35\x08\x54\x77\x08\x80\x08\x56\x0b\x1f\xcc\x31\ +-\x22\x5f\xbb\x6d\x53\x8c\xf9\x2a\x77\xf0\x20\xfc\xe8\xf1\x79\xb8\ +-\xf2\x52\x6d\xcf\xa7\xd8\xbe\xff\x08\xfe\xfe\xd6\x6a\xd4\x37\xf1\ +-\x0e\x21\xa6\xbf\x2d\xeb\x56\x61\xf8\xe8\x09\x88\x8d\x8b\xd7\x3b\ +-\x94\x3e\x73\xbb\xd1\x65\x11\x43\xd7\x45\x80\x02\x97\x21\x80\xf5\ +-\x7f\xb2\x0a\xec\x3e\x23\xa1\xed\xeb\xee\x9c\x6e\x97\x13\x8a\x22\ +-\x07\x6e\xc0\x10\x31\x8a\x57\x00\x58\x10\x89\x32\x1a\x30\xef\xc6\ +-\x39\x78\xe6\xc1\x5b\x35\x7d\x34\x55\xdb\xd8\x8a\xbf\xbd\xf9\x09\ +-\x76\x95\x1c\xd5\x6c\x4c\xc6\x7a\xe3\xb0\xd9\xb0\x73\xeb\x5a\x5c\ +-\x77\xeb\xbd\x7a\x87\xd2\x67\x76\x0f\x75\x79\xd4\xe1\x45\x09\xc0\ +-\xd6\x2a\x8a\x05\xd4\x80\xb6\xa2\x3b\x50\x27\xbe\x99\xfc\x01\xc0\ +-\xe1\xb0\x07\x72\xb8\x90\x31\x3c\x3f\x5b\xef\x10\x18\x03\xe0\xbd\ +-\xeb\x7f\xef\xaf\xbf\x44\xee\x60\xed\x0a\x9f\x1c\x4e\x37\xde\x5e\ +-\xb9\x01\x1f\x7e\xfe\x25\x3c\xf2\x45\xf5\x4a\x8c\xe9\xee\xe0\xfe\ +-\x9d\x98\x32\x7d\x36\x32\x06\x87\xd6\xcd\x9a\xc5\x2d\x12\x56\x94\ +-\x51\xe2\x82\x89\xe2\xbc\x76\xbb\x17\x1d\xf4\x93\x66\xc4\x64\x10\ +-\xa2\x02\x15\x48\x9d\x59\xa0\xce\x7c\x7e\x7d\x81\xc3\xc1\x07\x75\ +-\xa4\xa5\x24\x21\x2d\x25\x49\xef\x30\x18\x03\x00\x0c\xce\x48\xd3\ +-\x74\xf2\xdf\xb2\xab\x14\x0f\xfd\xf8\x0f\x58\xf6\xc9\x66\x9e\xfc\ +-\x59\xd0\x52\x55\x15\x9b\xd7\xae\xd2\x3b\x8c\x3e\x53\x54\xc0\xe9\ +-\xc2\xed\x17\x7e\xfc\xa2\x15\x00\x45\xa8\xd3\x02\x55\xfe\x27\xab\ +-\xc0\x91\xc6\x8b\xaf\xee\xb4\xf3\x0a\x00\xdf\xfd\xb3\x48\x54\x5d\ +-\xdb\x84\x17\x97\xac\x44\xf1\xe1\x72\xbd\x43\x61\xcc\x27\x35\xa7\ +-\xcb\x51\x79\xb2\x0c\x23\xc7\x74\xbb\xbd\x3e\x28\xb9\x65\xdc\x0c\ +-\xe0\x83\x73\x3f\x76\x51\x02\x20\x80\x69\x81\x0a\xe0\x54\x9b\x80\ +-\xc3\x73\xf1\xc7\x1d\x76\x3e\x04\x28\x2f\x3b\x34\xf7\x98\x32\xd6\ +-\x1f\x0e\xa7\x1b\xef\x7f\xb6\x05\xcb\x56\x6d\x86\x5b\xe6\xfa\x1f\ +-\x16\x5a\xb6\x6f\x5a\x83\x11\xa3\x27\x68\xda\xf2\x7a\xa0\x5c\x32\ +-\x2e\xea\xed\x73\x71\x11\xa0\x44\xd3\x10\x80\x2d\x80\x8a\x0a\x54\ +-\xb6\x77\x7d\x5d\xa7\x83\x0f\xef\xc8\xce\x4c\xd3\x3b\x04\xc6\x34\ +-\xb1\x71\x47\x09\x5e\x79\xfb\x33\xb4\x76\x70\xf7\x4f\x16\x9a\x5a\ +-\x9b\xea\x71\xa2\xec\x00\xc6\x5d\x52\xa8\x77\x28\x3e\x73\x29\x54\ +-\x70\xe1\xc7\xce\x4b\x00\x56\x10\x19\x50\xaf\x4e\x0a\xc4\xe0\xa7\ +-\x3b\x04\x5c\xdd\x24\xfa\x6e\xb7\x33\x10\x43\x86\x94\xec\x8c\x74\ +-\xbd\x43\x60\x2c\xa0\x4e\x9d\x69\xc0\x4b\x4b\x56\xe2\x40\x59\xa5\ +-\xde\xa1\x30\x36\x60\x3b\xb7\xac\xc5\x98\x09\x53\x21\x49\x17\x95\ +-\xd2\x05\x25\x87\x5b\x24\x11\x91\x24\x84\x50\xcf\x7e\xec\xbc\x04\ +-\x60\x4c\x1d\x46\xaa\x02\x7e\x3f\xbc\x5b\x21\xa0\xa2\xb5\xfb\x55\ +-\x05\x8f\xc7\xed\xef\x21\x43\x4e\x76\x16\xaf\x00\xb0\xf0\x74\x76\ +-\xb9\xff\xdd\x55\x9b\xb8\xc0\x8f\x85\x8d\x8e\xb6\x16\x9c\x38\x52\ +-\x12\x32\xcd\x81\x5c\x0a\xc4\x07\x87\x70\x29\x80\xbd\x67\x3f\x76\ +-\x5e\x02\xa0\x48\xca\x44\x11\x80\xe5\xff\x33\x1d\x02\x8e\x1e\x1e\ +-\xf3\x79\x5c\xdc\xe1\x2b\x3b\x93\x57\x00\x58\xf8\xd9\x59\x54\x86\ +-\x3f\x2f\xfe\x18\xcd\xad\x9d\x7a\x87\xc2\x98\xdf\xed\xdd\xb1\x19\ +-\xe3\x27\x4d\x07\x42\xa4\x16\xc0\xa3\xa8\x37\xa0\xbb\x04\x00\xaa\ +-\x98\x00\x3f\xff\x77\x38\x65\xe0\x58\x73\xcf\x17\x75\xbb\x23\x3b\ +-\x01\x30\x18\x24\x64\xa4\xa5\xe8\x1d\x06\x63\x7e\x53\x59\x5d\x8f\ +-\x17\x17\xaf\xc2\xc1\x63\xbc\xdc\xcf\xc2\x57\x6b\x53\x3d\x2a\xcb\ +-\x8f\x86\xcc\x8e\x00\x97\x2c\x5d\x76\xee\xbf\x9f\x97\x00\x08\x81\ +-\x09\xfe\x1e\xf0\x70\x83\x80\xbb\x97\x55\x3f\x8f\x3b\xb2\x1f\x01\ +-\xa4\x24\x25\xc0\x60\x08\x8d\xe7\x48\x8c\xf5\xc4\x6a\x77\x60\xc9\ +-\x07\xeb\xb0\x6a\xfd\x0e\x28\x8a\xda\xfb\x17\x30\x16\xe2\xf6\xef\ +-\xd8\x14\x32\x09\x80\x47\xa6\xf3\x9a\xfc\x5d\xb8\x0b\xc0\xaf\x09\ +-\xc0\xb1\xe6\x8b\x9b\xfe\x74\x19\x54\x84\xd7\x00\x24\x25\x86\x5e\ +-\x6f\x69\xc6\xce\x45\x44\xf8\xe2\xcb\xfd\x78\xfd\xbd\x35\x68\xef\ +-\xe4\x93\x3d\x59\xe4\xa8\xad\x3e\x85\xc6\xfa\x33\xc8\xce\xbd\xa8\ +-\xc8\x3e\xe8\x38\x3c\xe2\xbc\x03\x67\xbe\xb9\xed\x24\x22\x09\xc0\ +-\x58\x7f\x0c\xe2\x56\x80\x92\x3a\x81\x13\x2d\xbe\x3d\x4f\x50\xd5\ +-\xc8\x2e\x0c\x4a\x4d\x4a\xd4\x3b\x04\xc6\xfa\xad\xfc\x74\x1d\x7e\ +-\xf0\x1f\x2f\xe3\x7f\x5e\x79\x9f\x27\x7f\x16\x91\x0e\xec\xdb\xa1\ +-\x77\x08\x3e\xb1\xcb\x48\x58\xe8\x9d\xeb\x01\x9c\xb3\x02\x70\xa8\ +-\x09\x43\x81\xfe\xef\x00\x90\x55\xa0\xd3\x21\xd0\x68\x01\xce\x74\ +-\xf6\xbe\xec\x7f\x2e\x55\x8d\xec\xa5\xc2\xa4\xc4\x58\xbd\x43\x60\ +-\x61\x28\xca\x68\xc0\x82\xdb\xe7\x62\xfc\xa8\xc0\xdc\x99\x58\x6c\ +-\x76\x2c\x5a\xbe\x16\xab\x37\xee\x8e\xf8\xbf\x61\x16\xd9\x4e\x1c\ +-\x2e\xc1\xdc\x1b\xee\x42\x5c\x42\x82\xde\xa1\xf4\xc8\xa3\x40\x8c\ +-\x2c\xc2\x0c\x00\xfb\x80\x73\x12\x00\x55\x91\x47\x75\x71\x34\xc0\ +-\xf9\x5f\xac\x02\x36\x17\x60\xf3\x08\xd8\xdd\x80\xdd\x0d\xd8\x3c\ +-\x80\xcd\x25\x60\x97\x01\xea\xe7\x09\x82\xaa\x12\xd9\x2b\x00\xc9\ +-\x89\xc1\xfd\x4b\xc3\x42\xcf\xf4\x49\xa3\xf1\xc2\x93\xf3\x31\x2c\ +-\x00\x2d\xa6\x89\x08\xeb\xb7\x15\xe3\x95\x77\x3e\x43\x87\x2f\xeb\ +-\x2f\xd6\x00\x00\x20\x00\x49\x44\x41\x54\x89\xef\xf8\x19\x93\x65\ +-\x0f\x8e\x1c\xd8\x83\x4b\xaf\xb8\x4e\xef\x50\x7a\x27\xd4\xcb\x71\ +-\x61\x02\x40\x24\x8d\xba\x70\x07\x80\x4a\x40\xbb\x5d\xa0\xc5\x06\ +-\x34\x5b\x05\x3a\x9d\xfd\x9f\xe4\x7b\x12\xe9\x77\x0f\xc9\x5c\x03\ +-\xc0\xfc\x24\x6f\x70\x06\x9e\x7f\x62\x1e\xe6\xcc\x08\x4c\x51\xd2\ +-\xf1\xca\x33\x78\x71\xf1\x2a\x1c\x2d\xaf\x0e\xc8\xf5\x19\x0b\x55\ +-\x07\x8b\x77\xe1\xd2\x39\xd7\x06\xfd\x96\x40\x19\x98\x7a\xf6\x9f\ +-\xbf\x49\x00\x4a\x1b\xc5\x7d\x46\x01\x18\x0d\x80\x5b\x06\x3a\x9d\ +-\x02\x26\x87\xb7\x89\x4f\xa0\x45\x7a\x0d\x40\x62\x82\xdf\x7b\x2f\ +-\xb1\x08\x13\x17\x1b\x8d\x47\xee\xbe\x1e\xdf\xb9\x73\x2e\xa2\xa3\ +-\xfc\x7f\x98\xa7\xd9\x62\xc3\x1b\xcb\xd7\xe2\xf3\xcd\xbb\xa1\xaa\ +-\x1a\xbc\x29\x30\x16\x62\x3a\xdb\x5b\x51\x5b\x73\x0a\x43\x0a\x46\ +-\xea\x1d\x4a\x8f\x64\x45\x8c\x39\xfb\xcf\xdf\x24\x00\x16\x27\xc6\ +-\xb5\xd9\xf5\xc9\x5c\x22\x7d\x05\x20\xda\x78\xf1\x91\x0c\x8c\xf9\ +-\xea\xda\xd9\x53\xf1\xc3\x47\xef\x42\x56\x46\xaa\xdf\xaf\xad\xaa\ +-\x84\xcf\x37\xed\xc6\x1b\xef\xaf\x85\xd9\xc2\xc7\x76\x33\xd6\x93\ +-\xb2\x03\xfb\x82\x3e\x01\x70\x2b\x62\xc8\xd9\x7f\xfe\x66\xe6\x71\ +-\xc9\x82\x7b\xd1\xea\xc4\x68\x34\xe8\x1d\x02\x0b\x41\x05\xb9\x59\ +-\xf8\xc9\x93\xf3\x71\xd9\x54\xbf\x6c\xde\xb9\xc8\x89\xca\x1a\xbc\ +-\xb8\x78\x15\xca\xca\x4f\x07\xe4\xfa\x8c\x85\x9b\x13\x65\xa5\xb8\ +-\xf6\xd6\x7b\x10\x15\x15\xad\x77\x28\xdd\x72\xcb\xf8\xe6\xe8\x59\ +-\x23\x00\x2c\x24\x92\x9c\x9b\x28\x16\xfe\x6e\x03\xe8\xa3\x50\x3a\ +-\x52\x31\x10\x38\x01\x60\x7d\x91\x18\x1f\x87\x27\xef\xbf\x19\xf7\ +-\xdc\x7c\x45\x40\x1a\x48\x75\x9a\xad\x78\xfd\xbd\x35\x58\xbb\x75\ +-\x1f\x2f\xf7\x33\xd6\x07\x6e\x97\x13\x15\xc7\x0f\x7b\xdb\x03\x07\ +-\x29\xa7\x07\xdf\x14\x9d\x19\x01\x20\x7f\x1f\x26\x55\x07\xe0\x0c\ +-\x00\x5f\x09\x9d\x12\x8f\x60\x61\xe4\x47\x00\xcc\x07\x42\x08\xdc\ +-\x78\xd5\x74\xfc\xe0\x91\x3b\x91\x9e\x9a\xe4\xf7\xeb\xab\x2a\x61\ +-\xc3\xf6\x62\xfc\xfd\xed\xd5\x30\x99\x79\xb9\x9f\xb1\xfe\x38\x71\ +-\xe4\x40\x50\x27\x00\x6e\x05\x62\x65\x11\xe5\xdc\x33\x43\x34\x78\ +-\x67\x1e\x23\x2e\xeb\xe5\x6b\x02\x4a\x48\x91\x9d\x00\x44\xf1\x0a\ +-\x00\xeb\xc5\x84\x51\x43\xf1\x93\xa7\xef\xc6\x84\x51\x43\x03\x72\ +-\xfd\xc3\x27\xaa\xf0\xd2\xe2\x55\x38\x59\x55\x1b\x90\xeb\x33\xff\ +-\xca\x48\x4b\x41\x6e\xf6\x20\x0c\x1e\x94\x8a\x41\x69\xc9\x48\x4b\ +-\x49\x44\x52\x42\x3c\x62\xa2\xa3\x10\x15\xfd\x6d\x11\xa8\xd3\xe9\ +-\x82\xc5\xe6\x40\x87\xc9\x82\xf6\x4e\x0b\x1a\x9a\xdb\x71\xaa\xa6\ +-\x81\x13\xbc\x00\x3a\x5d\x71\x1c\x1e\xb7\x0b\x51\xd1\x31\x7a\x87\ +-\xd2\x25\x02\xe0\x10\x98\x05\xe0\x13\x23\x00\x78\x3c\xea\xd4\xde\ +-\x7a\x00\x04\x52\xc4\xaf\x00\x18\x38\x01\x60\x5d\x4b\x4b\x49\xc2\ +-\x73\x0f\xdd\x86\x5b\xe6\x5e\x06\x29\x00\x89\x72\x7b\xa7\x05\xaf\ +-\xbf\xb7\x06\x5f\x7c\xb9\x1f\x14\x88\x3d\xbe\x6c\x40\x24\x49\xc2\ +-\xb0\x21\xd9\x98\x30\x3a\x1f\x13\x46\x0d\xc5\xc8\x61\x39\x18\x96\ +-\x37\x18\x09\xf1\x03\xdb\x39\x64\x32\xdb\x50\x56\x5e\x8d\x92\x23\ +-\xe5\x28\x3d\x7a\x0a\x27\xab\x6a\xf8\x71\x8f\x9f\xc8\xb2\x07\x95\ +-\x27\xcb\x30\xee\x92\x42\xbd\x43\xe9\x96\x4c\x98\x8a\xb3\x09\x80\ +-\x42\x62\x84\x9e\xc1\x44\xfa\x0a\x80\x24\xf1\x41\x40\xec\x7c\x06\ +-\x83\x84\x7b\x6e\xbe\x02\x4f\xde\x7f\x33\x12\x07\xf8\x66\xdf\x15\ +-\x45\x51\xb1\x6a\xfd\x0e\x2c\xf9\x60\x1d\xac\x76\x87\xdf\xaf\xcf\ +-\xfa\x2f\x6b\x50\x2a\x66\x4e\x1b\x87\x99\x53\xc7\xe3\xd2\xc9\xa3\ +-\x07\x3c\xd9\x77\x25\x25\x39\x01\xb3\xa7\x4f\xc0\xec\xe9\xde\xe3\ +-\x5f\x5a\xda\x4d\xd8\xba\xab\x14\x9b\x76\x1e\xe0\x1e\x0f\x7e\x70\ +-\xb2\xac\x34\xb8\x13\x00\x55\x1d\x03\x7c\x5d\x03\xa0\xa8\x22\x4f\ +-\xcf\x60\x22\x7d\x05\x40\x96\x65\xbd\x43\x60\x41\xa4\x70\xe2\x28\ +-\xfc\xe4\xa9\xf9\x18\x51\x90\xd3\xfb\x8b\xfb\xe1\xe0\xb1\x4a\xbc\ +-\xb4\xf8\x13\x54\x54\xd7\x05\xe4\xfa\xac\x6f\x24\x49\xc2\xd4\xf1\ +-\x23\x30\xab\x70\x3c\x66\x4d\x1b\x87\x11\x05\xb9\x9a\xc7\x90\x99\ +-\x9e\x82\x05\xb7\x5f\x8d\x05\xb7\x5f\x8d\xf2\xd3\x75\x78\xff\xb3\ +-\xad\xd8\xb2\xb3\x14\x72\x84\x77\x69\xed\xaf\xaa\xf2\x63\xf0\x78\ +-\xdc\x41\xbb\x1b\x40\x51\xa5\x21\xc0\xd7\x09\x80\xac\x22\x43\xcf\ +-\x60\x44\x84\x2f\x81\xf3\x1f\x19\x03\x80\xac\x8c\x54\xfc\xf0\xd1\ +-\xbb\x70\xed\xec\xa9\xbd\xbf\xb8\x1f\xda\x3a\xcd\x78\xf5\xdd\xcf\ +-\xb1\x61\x5b\x31\x2f\xf7\x07\x81\x61\xf9\xd9\xb8\xf5\xea\x4b\x71\ +-\xe3\xd5\xd3\x91\x91\x96\xa2\x77\x38\xdf\x18\x3d\x2c\x0f\xbf\x79\ +-\xfe\x61\x3c\xfb\xe0\x6d\x58\xf4\xfe\x5a\xac\xe7\xdf\x97\x3e\xf3\ +-\x78\xdc\xa8\x39\x5d\x81\x11\xa3\xfd\x7a\xc0\xae\xdf\xa8\x84\xc1\ +-\xc0\xd7\x09\x80\x47\x81\xff\x4b\x8a\xfb\xc0\x68\xf4\x7f\xe7\xb2\ +-\x50\x22\xcb\x9c\x00\x44\xb2\xe8\xa8\x28\x7c\xe7\xce\xb9\x78\x74\ +-\xfe\xf5\x88\x8d\xf1\xff\x1d\x83\xac\x28\x58\xf9\xc5\x0e\x2c\x59\ +-\xb1\x0e\x76\xbb\xd3\xef\xd7\x67\xbe\x4b\x4e\x8c\xc7\xf5\x73\xa6\ +-\xe1\xe6\x6b\x2e\x0d\x58\x41\xa7\xbf\x0c\xce\x48\xc3\xaf\x7f\xf4\ +-\x10\xe6\xdf\x72\x05\xfe\xb2\xf8\x13\x1c\xad\xe0\x47\x03\x7d\x51\ +-\x55\x7e\x34\x68\x13\x00\x97\x42\x69\xc0\xd7\x09\x80\x4a\xd0\xb5\ +-\x5c\x31\xd2\xb7\xc1\x79\x38\x01\x88\x58\x73\x66\x4c\xc4\xf3\x4f\ +-\xcc\x43\xde\xe0\xc0\x2c\xc2\x95\x94\x55\xe0\xa5\xc5\x2b\x51\x55\ +-\xd3\x18\x90\xeb\x33\xdf\x0c\xcb\xcf\xc6\x83\x77\x5e\x83\xeb\xaf\ +-\x2c\x0c\xb9\xce\x9f\x13\x46\x0d\xc5\xeb\xff\xf3\x3c\xde\x5e\xb9\ +-\x11\x6f\x7d\xbc\x01\x8a\x12\xd9\x9d\x5b\x7d\x55\x55\x7e\x4c\xef\ +-\x10\xba\x25\xab\x48\x00\xbe\x5d\x01\xd0\xf5\x37\xd2\x10\xe9\x2b\ +-\x00\xfc\x08\x20\xe2\x14\xe4\x66\xe1\xf9\xc7\xe7\x61\x56\xe1\xf8\ +-\x80\x5c\xbf\xa5\xdd\x84\x57\xde\xfe\x14\x9b\x76\x1e\x08\xc8\xf5\ +-\x99\x6f\xa6\x4d\x1c\x85\x07\xee\xba\x06\x97\x4f\x1b\x1f\xd2\x0d\ +-\xcf\x24\x49\xc2\x13\xf7\xdd\x84\x19\x93\xc7\x60\xe1\x4b\xef\xa2\ +-\xa9\xb5\x43\xef\x90\x82\x5e\x67\x7b\x2b\xda\x5b\x9b\x91\x9e\x91\ +-\xa5\x77\x28\x17\xf1\x28\x22\x1a\x00\x8c\x2b\xca\x28\xba\xa6\x8d\ +-\x84\xd9\x25\x02\x72\xd2\x9f\x2f\x8c\x01\x38\xbc\x24\x94\x28\x9c\ +-\x00\x44\x8c\xf8\xd8\x18\x3c\x76\xef\x0d\x58\x70\xfb\xdc\x80\xf4\ +-\x7f\xf0\xc8\x0a\x3e\x5a\xf3\x15\xde\xfa\x78\x03\xec\xff\x9f\xbd\ +-\xfb\x8e\x8e\xb3\x3a\x13\x3f\xfe\xbd\xef\x14\xf5\x51\xb1\x7a\x97\ +-\x6d\xc9\xb6\x64\xcb\x96\x2c\xdb\xe0\x8a\x0b\x60\x1b\x07\x5c\x08\ +-\x09\x25\x05\x30\x21\x85\x24\x40\x36\xbb\xd9\x24\xfb\x4b\x76\xb3\ +-\x9b\xb6\xd9\x40\x08\x29\x24\xb4\x84\x90\x50\x8d\xe9\x60\x70\x01\ +-\x8c\x71\x95\x4d\x71\xc5\x4d\xdd\x92\x65\xf5\xae\x99\xf7\xfe\xfe\ +-\x10\x26\x36\xc8\xb6\xca\xbc\x65\x34\xf7\x73\x4e\xce\xf1\x91\x67\ +-\xee\x7d\x82\x47\x73\x9f\xf7\x96\xe7\x76\x75\xfb\xbd\x7d\xe5\xc2\ +-\x84\x10\xcc\x9b\x31\x89\xeb\x97\x2f\x64\xc2\xd8\x4c\xab\xc3\xf1\ +-\xab\x49\xe3\x72\xb8\xef\x67\xdf\xe6\xbb\xff\xf3\x67\x3e\x3c\xae\ +-\x36\x91\x5e\xc8\xf1\x23\xfb\x6d\x99\x00\xf4\x78\x71\xdc\x27\xa5\ +-\xcb\x99\xe7\x21\x61\x6c\x8c\xa4\xa3\x47\x72\xe8\x94\xa0\xac\x41\ +-\x60\x76\x1e\x10\xec\x4b\x00\xed\x9d\xea\x8b\x7a\xa4\x13\x42\xb0\ +-\x68\x76\x11\x5f\xff\xc2\x95\x24\xc4\x19\xb3\xe1\x6b\xc7\xbb\x87\ +-\xb8\xeb\xc1\x35\x94\x57\xd5\x1a\xd2\xbe\x72\x61\x53\x27\xe5\xf2\ +-\xf5\x1b\x3e\xc3\xb8\x31\x19\x56\x87\x62\x98\xf8\xd8\x68\x7e\xf7\ +-\x93\x6f\xf2\x83\x5f\x3d\xc8\x8e\x77\x0f\x59\x1d\x8e\xad\x55\x1c\ +-\xfd\x90\xe2\x19\xf3\xac\x0e\xe3\x53\x7c\x12\x92\x0f\x32\xda\x89\ +-\x46\x22\x40\xb8\x1b\xa6\xa4\x48\xd2\x3d\x92\xd2\x6a\x8d\x8e\x1e\ +-\xf3\x82\x09\xf6\x25\x80\xb6\xb6\x0e\xab\x43\x50\x0c\x34\x36\x2b\ +-\x8d\x3b\x56\xaf\x60\xf2\x04\x63\x6e\x09\x3b\xd9\xd0\xcc\x1f\x1f\ +-\x7d\x81\x57\xdf\xd8\x69\x48\xfb\xca\x85\xe5\x64\x24\x73\xe3\x35\ +-\x8b\x59\x70\xf1\x64\xab\x43\x31\x45\x78\x58\x08\xbf\xfc\xf7\xaf\ +-\xf0\x6f\x3f\xff\x33\xdb\xf7\x1c\xb4\x3a\x1c\xdb\xaa\x28\x3b\x82\ +-\x94\xd2\x96\xcb\x3f\xed\x9d\x4c\x70\x22\xbc\x09\xc8\x7f\x16\xa2\ +-\x89\x8f\x80\x79\x39\x3a\x5b\xca\x34\x9a\x4d\xda\x30\xec\x76\xdb\ +-\xf3\xac\xa4\x59\x5a\x54\x02\x30\x22\x79\x22\xc3\x59\x7d\xed\x52\ +-\x96\x5f\x7a\xb1\x21\xc5\x9e\x7a\xbc\x5e\x1e\x7b\x76\x23\x7f\x5d\ +-\xf3\x3a\x5d\xdd\x26\x66\xec\xca\xc7\x12\xe3\x63\xf8\xea\x75\xcb\ +-\x58\x34\xbb\xd8\x90\x4a\x8d\x76\xe6\x72\x3a\xf8\xaf\xef\xdc\xc8\ +-\xea\xef\xff\x81\xca\x0a\x75\x42\xa0\x3f\x5d\x9d\x1d\xd4\xd7\x55\ +-\x93\x90\x64\x69\xa9\x9d\x7e\xf5\xf8\xf4\x31\x4e\x9f\x14\xb1\x9f\ +-\xfc\xd8\x86\x38\x61\x76\x8e\xce\xdb\xc7\x35\x9a\x4c\x28\x12\xe6\ +-\x0e\xf1\x7f\xa5\xab\x40\xd2\xd2\xae\x12\x80\x91\x44\xd3\x04\xcb\ +-\x16\x5e\xc4\xad\xd7\x5e\x41\xb4\x27\xc2\x90\x3e\xde\xd9\xbd\x9f\ +-\xdf\x3c\xb0\x86\xca\x13\xf5\x86\xb4\xaf\x9c\xdf\xe9\xa3\x9b\x5f\ +-\x58\xb1\x88\xb0\xd0\xe0\x7d\x80\x39\xd2\x18\xca\xf2\xeb\x6e\xe5\ +-\xd1\x3f\xff\x9a\xc6\x06\xf5\x59\xec\x4f\xc5\xf1\xc3\xb6\x4c\x00\ +-\xa4\x24\xc9\x89\x14\x31\xfd\x15\xe2\x73\x69\x70\x71\xa6\xce\x1b\ +-\xc7\x8c\x5f\x0e\x08\x0d\x0d\x35\xb6\x03\x9b\x6b\x6d\x53\xa5\x58\ +-\x47\x8a\x49\xe3\x72\xb8\xe3\xe6\x95\xe4\x8d\x4e\x37\xa4\xfd\xea\ +-\xda\x53\xdc\xf3\xf0\x33\x6c\xde\xb1\xd7\x90\xf6\x95\x0b\x33\xfa\ +-\xe8\x66\xa0\xa8\x6a\x16\x1c\x6b\x14\x84\x86\x47\xf0\x99\xcf\xdd\ +-\xc4\xdf\xff\x7c\x17\x5e\x6f\xaf\xd5\x61\xd9\x4e\xe5\xf1\x23\xb6\ +-\xdc\x07\x20\x25\xf1\x4e\xa1\x11\x7b\xae\x5d\x7f\x21\xce\xbe\x24\ +-\xe0\xad\x63\x1a\x3d\x06\x6e\x54\x0f\xf6\x19\x80\x56\xb5\x04\x10\ +-\xf0\xe2\x62\x3d\xac\xbe\x66\x31\xcb\x16\x5e\x64\xc8\x54\x70\x77\ +-\x4f\x2f\x4f\xbd\xf4\x26\x0f\x3f\xb5\x8e\xce\x2e\x35\xdd\x6f\x85\ +-\xf4\xe4\x78\xbe\x75\xe3\x8a\x8f\xeb\xe7\x07\xb3\x2e\x2f\xbc\x5b\ +-\xf3\xcf\xcf\x79\x62\x72\x1a\x0b\x96\xae\x64\xdd\x73\x8f\x5b\x18\ +-\x95\x3d\x55\x55\x1c\xb3\x3a\x84\x7e\x49\x4d\x8b\x75\x22\x39\xef\ +-\x96\xe4\xa8\x10\x98\x91\xd1\xb7\x27\xc0\x67\xd0\xf1\x80\x90\x90\ +-\xe0\x9e\x01\x38\xd5\xdc\x6a\x75\x08\xca\x10\x39\x1d\x0e\xae\x5e\ +-\x3a\x87\x9b\x3e\x7b\x39\xe1\xe1\xc6\x7c\x8e\x37\xef\xd8\xcb\x3d\ +-\x0f\x3f\x43\x75\xed\x29\x43\xda\x57\xce\x2f\x3c\x34\x84\x2f\xae\ +-\xba\x94\xcf\x7d\xc6\x98\xa3\x9b\x81\xe8\xc3\x7a\xf1\xa9\x87\xc2\ +-\xc2\xa9\x33\x29\x3b\x7a\x88\x83\x1f\xa8\xda\x13\x67\x6a\x6f\x6d\ +-\xa1\xb5\xb9\x89\xa8\xe8\x18\xab\x43\x39\x8b\xae\xcb\x18\x27\x82\ +-\x98\x0b\x9d\xfb\x1b\x15\x01\x85\x29\x92\xdd\xd5\xc6\x6c\x72\x71\ +-\x07\xf9\x12\x40\x67\x67\x37\x6d\x1d\x9d\x86\xdc\xfa\xa6\x18\xc7\ +-\xe8\x4b\x7b\xaa\x6a\xeb\xf9\xcd\x03\xcf\xb0\xa5\x74\x9f\x21\xed\ +-\x2b\x17\x36\x73\x6a\x3e\x77\xae\x5e\x45\x72\x42\x9c\xd5\xa1\xd8\ +-\x4a\x6d\x5b\xff\x63\xc1\xc2\x25\xab\x38\x7e\xf8\x20\xdd\x5d\x6a\ +-\x56\xf3\x4c\x35\x55\x65\xb6\x4b\x00\x7c\x92\xe8\x0b\xce\x00\x9c\ +-\x96\x15\x2b\x69\xeb\xe9\xcb\xfc\xfc\x2d\x34\x54\x0d\x7c\x35\x75\ +-\x0d\xe4\x66\xdb\x6f\xa3\x88\xf2\x69\x29\x89\x71\x7c\xf3\x4b\xcb\ +-\x99\x3b\x63\x92\x21\xed\x77\x75\xf7\xf0\xd7\x35\xaf\xf3\xd8\xb3\ +-\x1b\xe9\x51\x37\x45\x5a\x62\x4c\x56\x2a\x77\xdc\xbc\x92\x29\xf9\ +-\xc6\x1c\xdd\x0c\x74\xfa\x39\x1e\x1a\xc3\x23\xa3\x98\xb3\xf0\x0a\ +-\x5e\x7f\xf1\x49\x73\x03\xb2\xb9\x9a\xaa\x32\xf2\xf2\xed\x75\x44\ +-\x54\xd7\x45\xa4\x13\x44\x24\x03\x2c\xfd\x93\x9f\x28\xe9\xea\x85\ +-\x8a\x66\xff\x26\x01\xa1\xa1\xc6\xec\x94\x0e\x24\x27\x4e\x36\xaa\ +-\x04\xc0\xe6\x42\xdc\x2e\xae\x5f\xbe\x80\xeb\x97\x2f\x24\xc4\x6d\ +-\x4c\xed\x8a\x4d\x5b\xdf\xe3\xb7\x0f\xaf\x55\xa5\x56\x2d\x12\x15\ +-\x11\xce\x2d\xd7\x2e\x61\xf9\x65\x33\x0d\x39\xba\x39\x52\x24\x45\ +-\x4a\x8e\x35\xf4\x3f\x0e\x4c\x9e\x36\x8b\xbd\x7b\xb6\x53\x53\xa5\ +-\x8e\x06\x9e\x76\xa2\xb2\xdc\xea\x10\x3e\xc5\x27\x09\x73\x02\xe1\ +-\x03\x7d\x83\x10\x50\x9c\x26\x71\x68\x70\xbc\xd1\x7f\x49\x40\x68\ +-\x78\x38\x9a\xa6\xa1\xeb\xc1\x7b\xc9\xc4\x89\x93\x0d\x56\x87\xa0\ +-\x9c\xc7\xbc\x8b\x0a\xb9\xed\x8b\x57\x91\x92\x68\xcc\x54\x70\x79\ +-\x55\x2d\x77\x3d\xb8\x46\x55\x56\xb3\x88\x19\x47\x37\x47\x92\xdc\ +-\x51\x92\xb2\x06\x41\x7f\xdf\xd8\x42\x08\xe6\x2c\x5a\xc6\x13\x7f\ +-\xf9\x9d\xe9\x71\xd9\x55\x6d\x4d\x05\x48\xd9\x37\x88\xda\x84\xd7\ +-\x27\x43\x9d\xa0\x87\xd1\xdf\x39\xc0\x73\x10\x02\x26\xa7\x4a\xa2\ +-\x42\x60\x7f\x9d\xc0\xeb\x87\x31\x5b\x08\x41\x58\x44\x24\xed\xad\ +-\x2d\xc3\x6f\x2c\x40\xd5\x9e\x54\x4f\x7c\x76\x94\x95\x9e\xc4\xed\ +-\x37\xae\x64\xda\xe4\x3c\x43\xda\xef\xe8\xea\xe6\xe1\xa7\xd6\xf1\ +-\xe4\x0b\x6f\xa8\x5b\x21\x2d\x32\x31\x2f\x9b\x3b\x6e\x5e\x39\xa2\ +-\xcb\xf7\xfa\x5b\xb8\x1b\xd2\x63\x24\xe5\x4d\xfd\x8f\x1d\x99\xa3\ +-\xf3\x48\xcf\x1c\x43\x65\xf9\x11\x93\x23\xb3\xa7\x9e\xee\x2e\x9a\ +-\x9b\x1a\x88\x8e\x1d\x65\x75\x28\x1f\xd3\x25\x6e\x27\x88\x01\xcf\ +-\x00\x9c\x26\x80\x31\xa3\x24\xc9\x51\x92\x7d\xb5\x82\x13\xad\x62\ +-\xd8\x27\x04\xc2\x83\x3c\x01\x28\xaf\xae\xb3\x3a\x04\xe5\x0c\x61\ +-\xa1\x6e\xae\xbd\x72\x3e\x37\xac\x5c\x64\xd8\xf5\xad\x6f\xef\xdc\ +-\xcb\xaf\xef\x7f\x5a\x4d\xf7\x5b\xc4\x13\x15\xc1\x97\xaf\xbe\x8c\ +-\xab\x97\xcc\x09\xba\x2a\x7e\xfe\x90\x17\x7f\xee\x04\x00\x60\xe6\ +-\x82\xc5\x3c\xf1\xb0\x9a\x05\x38\xed\x64\x6d\x8d\xcd\x12\x00\xe1\ +-\x1c\xd4\x12\xc0\x27\x45\xb8\x61\x5a\x86\xc4\xeb\x93\x34\x76\x09\ +-\x9a\x3a\xa1\xa5\x1b\x5a\xbb\x04\x2d\xdd\xe7\xde\x28\xd2\x9f\xf0\ +-\x88\xa8\xa1\x86\x31\x22\x1c\x29\xab\xb1\x3a\x04\x85\xbe\xd9\xa8\ +-\xcb\xe7\x4e\xe5\xeb\x37\x7c\x86\xb8\x58\x8f\x21\x7d\x1c\xab\x38\ +-\xc1\xaf\xef\x7f\x8a\xdd\x7b\xd5\xd3\x91\x15\xcc\x38\xba\x19\x0c\ +-\x22\x43\xc0\x13\x0a\x2d\xe7\x28\x19\x9f\x99\x93\x47\x5a\x46\x8e\ +-\x6d\xcf\xc1\x9b\xad\xbe\xb6\x9a\xb1\xe3\x27\x5a\x1d\xc6\xc7\xa4\ +-\xc4\xe1\x04\x86\xbd\x05\xdf\xe9\x80\x84\x08\x49\xc2\xc7\x4b\x67\ +-\x12\xaf\x0f\x6a\xda\x04\xd5\x2d\x50\xdb\x2a\x2e\x98\x0c\x04\x7b\ +-\x02\x50\x5b\xdf\x48\x6b\x7b\x07\x51\x11\x43\xce\xc7\x94\x61\xca\ +-\xcb\x49\xe7\xf6\x9b\x57\x50\x38\x7e\xb4\x21\xed\x77\x76\xf5\xf0\ +-\x8f\xe7\x36\xf0\xc8\x9a\xd7\xd5\x74\xbf\x45\x8c\x3e\xba\x19\x6c\ +-\x22\xdc\x92\x96\xae\x73\xcf\x02\x4c\x9e\x36\x4b\x25\x00\x1f\xa9\ +-\xaf\xab\xb6\x3a\x84\xb3\x09\x34\x27\x60\x48\x0a\xec\x74\x40\x46\ +-\xb4\x24\x23\x1a\xba\xbd\x92\x8a\x66\x41\x6d\x2b\x34\x74\xf4\xbf\ +-\x5c\x10\x11\x11\x69\x44\x18\x01\xe5\x48\x59\x8d\x3a\x76\x64\x81\ +-\x68\x4f\x04\xb7\x5e\x7b\x85\x61\x55\xfc\xa4\x94\xac\x7b\x73\x17\ +-\xbf\xfb\xdb\xf3\x34\x34\x06\xef\x32\x97\x95\x92\x13\xe2\xb8\xed\ +-\x4b\x57\x71\xc9\x45\x85\x56\x87\x32\xa2\xf4\x5e\x20\x8f\xcd\x2b\ +-\x98\xc2\x86\x57\x9e\xa1\xab\xa3\xdd\x9c\x80\x6c\xec\x64\x9d\xbd\ +-\x66\x79\x75\xbd\x2f\x01\x30\x66\x81\xf3\x0c\x21\x4e\x18\x3b\x4a\ +-\x32\x76\x14\xf8\xa4\xa4\xa9\xb3\x6f\x99\xa0\xad\xa7\x6f\xc9\xa0\ +-\xad\x5b\x10\xe9\xb1\x57\x91\x04\x2b\xa8\x04\xc0\x5c\x9a\xa6\xb1\ +-\xfc\xb2\x99\xac\xfe\xfc\x12\x3c\x91\xc6\xcc\xbc\x1c\x2e\xab\xe2\ +-\xd7\xf7\xaf\xe1\xbd\xfd\x47\x0d\x69\x5f\x39\xbf\x10\xb7\x8b\xeb\ +-\xae\x5a\xc0\xf5\xcb\x17\x10\x1a\x12\xbc\x97\xf6\x18\xa5\xa3\xe7\ +-\xfc\x09\xb3\xd3\xe9\x62\xe2\x94\xe9\xec\xdc\xb2\xd1\xa4\x88\xec\ +-\xab\xf1\xd4\x49\x74\x9f\x0f\xcd\x61\x8f\x6a\x92\x52\x22\x9c\x12\ +-\x9c\x66\x6e\x7f\x71\x08\x18\x15\x0e\xa3\xc2\xcf\x9c\x06\x90\x68\ +-\x27\x63\xd8\xf4\xaa\x89\x81\xd8\xd0\xc1\xa3\x15\x56\x87\x10\x34\ +-\x26\x4f\x18\xc3\x1d\xab\x57\x30\x36\xcb\x98\xda\x0b\x6d\x1d\x9d\ +-\xfc\xf9\x1f\x2f\xf1\xcc\xab\x5b\x82\xfa\x78\xab\x95\xe6\x4e\x9f\ +-\xc8\x6d\x5f\x5a\x4e\x6a\x92\x7d\x36\x5e\x8d\x24\x3d\x3e\xe8\x18\ +-\xc0\xdd\x3f\x93\x8a\x2e\x52\x09\x00\xa0\xfb\x7c\x34\x37\x35\x10\ +-\x3b\x2a\xc1\xea\x50\x80\xbe\x3d\x7a\x4e\x01\xb6\x48\x47\x52\x12\ +-\x07\x54\x90\x70\x44\x7b\x77\x9f\x7a\x4a\x34\x5a\x42\x5c\x34\x5f\ +-\xff\xc2\x95\x2c\x9a\x5d\x84\x30\xe0\x4c\xae\x94\x92\x97\x37\xed\ +-\xe0\x0f\x7f\x7b\x81\x46\x75\xc7\x83\x25\x32\x53\x13\xb9\xfd\xe6\ +-\x95\x4c\x9f\x3c\xce\xea\x50\x46\xb4\xd6\xee\x81\xbd\x6e\x54\x62\ +-\x32\x71\x09\x49\x34\x9c\xac\x35\x36\xa0\x00\xd0\xd8\x70\xd2\x36\ +-\x09\x00\x20\x9c\xd8\x24\x01\x48\x1c\x15\x6b\x75\x08\x96\xab\xaa\ +-\xad\xa7\xae\xbe\x89\xc4\x78\xb5\x1c\xe2\x6f\x4e\x87\x83\x15\x97\ +-\xcf\xe2\x96\xcf\x2f\x31\x6c\xe7\xf7\xa1\xa3\x95\xdc\xf5\xc0\x1a\ +-\xde\x3f\xa8\x36\x3d\x59\xc1\x8c\xa3\x9b\xca\x3f\xf5\xf8\x06\x9e\ +-\x40\xe7\xe5\x4f\x66\xeb\x1b\xeb\x0c\x8c\x26\x30\x34\x35\x9c\xb4\ +-\x3a\x84\x8f\xf9\xa4\xb4\x4f\x02\x30\x2a\x26\x0a\xa7\xc3\x81\xd7\ +-\x17\xdc\xbb\xa3\xdf\xdd\x7f\x94\x4b\xe7\x14\x5b\x1d\xc6\x88\x32\ +-\x75\x52\x2e\x77\xdc\xb4\x92\xec\x8c\x64\x43\xda\x6f\x69\xeb\xe0\ +-\xa1\x27\x5e\xe5\xe9\x57\x36\xab\xe9\x7e\x0b\x08\x21\x98\x7f\x51\ +-\x21\xb7\x7d\x69\xb9\x4a\x9e\x4d\x14\xe2\x90\x0c\xb4\x88\x5c\xee\ +-\xf8\x42\x95\x00\xd0\xb7\x0f\xc0\x2e\xa4\x14\xd8\x26\x01\xd0\x34\ +-\x8d\xf8\xb8\xe8\xa0\x2f\x89\xbb\x7b\xdf\x61\x95\x00\xf8\x49\x5a\ +-\x52\x3c\xdf\xba\x71\x39\xb3\x4a\x0a\x0c\x69\xdf\xe7\xd3\x59\xbb\ +-\x6e\x0b\xf7\x3f\xf6\x32\xad\xed\xea\xf6\x33\x2b\x18\x7d\x74\xb3\ +-\xa7\xb7\x97\xc7\x9e\xdb\xc4\x94\x82\x31\x86\xf5\x11\xa8\x62\xc3\ +-\x20\xcc\x09\x9d\x03\xb8\xaf\x2a\x29\x25\x1d\x4f\x4c\x1c\x2d\x4d\ +-\xc1\xfd\xfd\x6e\xa7\x04\x40\xc7\x84\x13\x00\x83\x91\x9a\x18\x17\ +-\xf4\x09\xc0\xce\xf7\xac\xab\x05\xaf\x03\x75\xad\x82\x50\x97\x24\ +-\x26\x80\xeb\xa3\x84\x84\x38\xf9\xca\xb5\x4b\xf9\xfc\x95\x97\xe0\ +-\x76\x19\x73\x69\xcf\xee\xbd\x87\xb9\xfb\xc1\x67\x38\x52\x66\xb3\ +-\xb3\xbd\x41\xc2\x13\x15\xc1\x57\xae\x5d\xca\x95\x8b\x2e\x32\xec\ +-\xd2\x9e\xb7\x77\xee\xe5\x9e\x87\xd6\x52\x55\x5b\xcf\x5d\xff\xf1\ +-\x35\x43\xfa\x08\x64\x42\x40\x7e\xb2\x64\x57\xe5\x00\x66\x01\x84\ +-\x20\x6b\xcc\x38\xde\xdf\xf5\x8e\xf1\x81\xd9\x58\x73\x43\xbd\xd5\ +-\x21\x9c\xc5\x09\xf8\xb0\x49\x22\x90\x9e\x9a\x40\xe9\xde\xc3\x56\ +-\x87\x61\xa9\xea\xda\x53\x1c\x3a\x56\x49\x5e\x4e\xba\xa9\xfd\x76\ +-\xf6\xc2\xd6\x72\x8d\xe6\xae\xbe\x29\xd5\x29\xa9\x92\xac\x98\x61\ +-\xd6\x77\xb6\x48\xe1\xf8\xd1\x86\x3d\xad\xd5\x37\x36\xf3\x87\xbf\ +-\xbd\xc0\xba\x37\x77\x21\x65\x60\xfe\xf7\x09\x64\x9a\x26\xb8\x74\ +-\xce\x54\xbe\xf9\xa5\xab\x88\xf1\x18\x53\x3b\xa4\xf2\x44\x3d\xf7\ +-\x3c\xf8\x0c\x5b\x4a\xf7\x19\xd2\xfe\x48\x92\x11\x2d\xa9\x6f\x83\ +-\xb2\xf3\x94\x04\x3e\x2d\x33\x7b\x6c\xd0\x27\x00\x2d\xcd\x4d\xb6\ +-\xb9\x14\x48\xc3\x66\x09\x40\x46\x8a\x6d\x76\x47\x5a\xea\xcd\x6d\ +-\xef\x9b\x9a\x00\x34\x77\xc1\xd6\x32\xed\xe3\xa9\x3c\x29\xe1\x60\ +-\x9d\x08\xd8\x04\xc0\x08\x5e\x9f\x8f\x35\xaf\xbc\xcd\x9f\x1f\x7b\ +-\x89\xce\xce\x01\x6e\x7f\x56\xfc\x6a\xc2\xd8\x4c\xee\x58\xbd\x92\ +-\xfc\xb1\x59\x86\xb4\xdf\xd5\xdd\xc3\xdf\x9f\xdd\xc0\xdf\xd6\xac\ +-\xa7\xc7\x3b\x80\x79\x6d\x05\x80\xc9\x69\x92\x2e\x5f\x5f\xc5\xd7\ +-\xf3\x49\xcf\x1e\x6b\x52\x44\xf6\xe5\xf3\x79\xe9\xe8\x68\xb3\x45\ +-\xe5\x5b\x21\xe4\xc7\x09\x80\x2d\x64\xa4\x24\x5a\x1d\x82\x2d\xbc\ +-\xb1\xed\x3d\x56\x7f\x7e\x89\x29\x7d\x55\x34\x09\xde\x3d\x21\xf8\ +-\x64\x65\xda\xa8\xd0\xf3\x0f\xfe\x9d\x5e\x68\xec\x10\x44\x87\x4a\ +-\x22\x46\x78\x7d\x95\x77\x76\xef\xe7\x9e\x07\x9f\xa1\xa2\xc6\x3e\ +-\xeb\x77\xc1\x24\x2e\xd6\xc3\x37\x6e\xf8\x0c\x97\xcd\x9d\x6a\xd8\ +-\xd1\xcd\xd7\x37\xef\xe6\xf7\x8f\x3c\xc7\xc9\x86\x66\xbf\xb7\x3f\ +-\xd2\x69\xc0\xf4\x0c\xc9\xce\x0a\xa8\x39\x4f\x12\x10\xe5\x89\x21\ +-\x3a\x76\x14\xcd\x8d\xa7\xcc\x0b\xce\x86\x5a\x9a\x1b\x6d\x91\x00\ +-\x38\x84\x90\x4e\x09\x83\x38\xcc\x61\xac\xf4\x64\x55\xb0\x03\xfa\ +-\x2e\x8b\x29\xab\xac\x25\x2b\x3d\xc9\xb0\x3e\xba\xbd\xb0\xa7\x5a\ +-\xf4\xfb\x0b\xeb\x76\x40\x61\x72\xff\x09\x80\x94\x70\xb0\x5e\x70\ +-\xa8\xae\xef\x2e\x70\x81\x20\x29\x4a\x32\x2e\x41\x12\x3b\xec\x5b\ +-\x25\xec\xa5\xaa\xb6\x9e\x7b\x1e\x5a\xcb\xdb\x3b\xf7\x5a\x1d\x4a\ +-\x50\x72\x38\x34\xae\x5e\x32\x87\x9b\xaf\x59\x6c\xd8\xd1\xcd\xc3\ +-\x65\x55\xdc\x75\xff\x33\xbc\xbb\x5f\x5d\xcc\x34\x1c\x0e\xd1\x97\ +-\x04\xbc\x5b\x03\xc7\x1b\xcf\x3d\xa2\xa4\x67\x8d\x09\xfa\x04\xa0\ +-\xb5\xb9\x89\xe4\xd4\x4c\xab\xc3\x00\x90\x4e\x01\xb6\x99\xeb\x4a\ +-\x4d\x89\x47\xd3\x34\x75\x94\x0a\x78\x7e\xfd\x56\x6e\xfb\xd2\x55\ +-\x7e\x6f\x57\x07\x8e\x9d\x12\x1c\x3c\x29\xe8\x39\xc7\xdc\xcf\x94\ +-\xd4\xfe\x9f\xea\xa5\x84\xd2\x6a\x41\xc5\x19\xeb\x7d\x12\x38\xd1\ +-\x2a\xa8\x6d\x15\x64\x44\x4b\x0a\x92\x25\x21\xb6\x58\x50\x1a\xba\ +-\xce\xae\x1e\x1e\x79\xe6\x75\x1e\x7b\x6e\x13\x3d\xbd\x03\x28\x75\ +-\xa6\xf8\x5d\x51\xc1\x18\xee\x5c\x7d\x35\x39\x06\x1e\xdd\xbc\xff\ +-\xb1\x97\x59\xbb\x4e\x55\x6a\xf4\x17\x21\xfa\xbe\x3b\x22\x43\x60\ +-\x6f\xad\xa0\xbf\x2d\x32\x49\xa9\xe9\xec\xdd\xb3\xdd\xfc\xe0\x6c\ +-\xa4\xa5\xd9\x1e\xd7\x7f\x6b\xa2\x6f\xed\xdf\x36\x09\x80\xdb\xe9\ +-\x24\x3d\x39\x9e\xf2\xea\x3a\xab\x43\xb1\xdc\x4b\x9b\x76\xf0\x95\ +-\xeb\x96\xfa\x6d\x17\x7b\x5b\x0f\x54\x35\x0b\x8e\x37\x88\xf3\x1e\ +-\xdb\x09\x77\x43\xaa\xe7\xd3\xbf\xb9\xba\x84\xed\x15\x82\x13\xe7\ +-\x98\xe2\x93\x40\x79\xb3\xa0\xba\x4d\x30\x3e\x41\x32\x7a\x94\xc4\ +-\x98\xbd\xd9\xc6\xda\xf0\xce\xbb\xdc\xfb\x97\xb5\xd4\xd5\x37\x59\ +-\x1d\x4a\x50\x4a\x88\x8b\xe6\x1b\x5f\xba\x8a\x45\xb3\x8a\x0c\x69\ +-\x5f\xd7\x25\x2f\xac\xdf\xca\x7d\xff\x78\x91\xe6\x16\x75\x41\x8d\ +-\x11\xc6\x8e\x92\x44\xb8\x60\x67\x95\xc0\xf7\x89\xdc\x2a\x21\xd1\ +-\x98\xd2\xdb\x81\xa4\xb5\xc5\x1e\xdf\x2d\x42\x20\x9d\xc0\x39\x6e\ +-\x73\xb6\xc6\xe8\xcc\x64\x95\x00\x00\x2d\xad\xed\x6c\x7a\xe7\x3d\ +-\x2e\x9b\x3b\x75\x50\xef\xd3\x81\xf6\x8f\x2e\x58\x6a\xeb\xe9\x2b\ +-\xd7\xd9\xd0\xd1\xf7\xe7\x81\xf0\xe9\xe0\x93\x7d\x53\x7a\xa7\x75\ +-\xf4\xc2\xf6\x0a\x8d\xa6\xce\x0b\xbf\xdf\xeb\x83\x0f\x4e\xf4\x25\ +-\x0a\xd3\xd2\xf5\x80\x99\x0d\x28\xaf\xae\xe3\xee\x07\xd7\xb0\x7d\ +-\xcf\x41\xab\x43\x09\x4a\x66\x54\x6a\x3c\x70\xa4\x9c\xbb\xee\x7f\ +-\x86\xbd\x1f\x1e\x37\xa4\x7d\xe5\x9f\x52\x3c\x92\xd9\x2e\xc9\xd6\ +-\x72\x8d\xee\x33\x1e\x38\x12\x92\x53\xad\x0b\xca\x26\x3a\xda\xed\ +-\x51\x22\x5c\xd3\xd0\x9d\xc0\x00\xbe\xd6\xcd\x33\x3a\x33\x85\x4d\ +-\x5b\xdf\xb3\x3a\x0c\x5b\x58\xbb\x6e\xcb\x80\x12\x80\x86\x0e\xa8\ +-\x6c\x16\xd4\x77\x08\xda\xba\xfa\x92\x80\xa1\xea\xf6\xc2\xd6\x32\ +-\x41\x7a\x34\x38\xb4\xbe\xb6\x8f\x37\x0a\xf4\x41\x1e\x08\xa8\x6f\ +-\x87\x37\x8e\x69\xcc\xce\xd2\x09\xb7\xf1\x26\xc1\xf6\x8e\x4e\x1e\ +-\x78\xfc\x15\x9e\x7e\x65\x33\xbe\x4f\x3e\xae\x28\xa6\x28\x29\xcc\ +-\xe3\xce\x9b\x57\x92\x99\x66\xcc\x9e\x97\x86\xc6\x16\x7e\xff\xb7\ +-\xe7\x79\x55\x1d\xdd\x34\x55\x6c\x18\xcc\xcd\xd1\xd9\x52\xa6\xd1\ +-\xfe\xd1\x03\x48\x68\x58\x38\x91\x9e\x68\xda\x5a\x82\x77\xb3\x65\ +-\x47\x9b\x3d\x12\x00\x64\x5f\x02\x60\xab\x12\x66\x63\x32\x55\x86\ +-\x78\xda\x7b\x07\x8e\xb2\x7b\xef\x61\x8a\x0a\xfa\x3f\x3e\xd3\xda\ +-\x0d\x7b\x6a\x34\x4e\xf9\x79\x26\xf3\x64\xbb\xe0\xa4\x1f\xda\xec\ +-\xe8\x81\xb7\x8e\x6b\xcc\xca\xd6\x89\xb4\x59\x12\x20\xa5\xe4\xd5\ +-\x37\x77\xf1\xfb\x47\x9e\xa3\xa1\xc9\x26\xbf\x90\x41\x26\x21\x2e\ +-\x9a\x5b\xaf\x5f\xc6\xe2\x79\x25\x86\xb4\x7f\xfa\xe8\xe6\x03\x8f\ +-\xbf\x42\x7b\x87\xad\x9e\x73\x82\x46\x84\xbb\x2f\x09\x78\xa7\xfc\ +-\x9f\x33\x88\x09\x49\x69\x41\x9d\x00\x74\xb6\xb7\x59\x1d\x02\x00\ +-\x42\xe0\x73\x82\xec\x18\x68\x3d\x67\x33\x8c\xce\x4a\xb1\x3a\x04\ +-\x5b\xb9\xff\xb1\x57\xf8\xdd\x4f\x6e\xfb\xd4\xcf\x4f\xb5\xc3\x3b\ +-\x15\xda\xa7\x8e\xef\xd9\x4d\x67\x2f\xbc\x71\x44\x63\x6a\xba\x24\ +-\x39\xca\x98\xa7\xaf\x2e\x6f\xdf\xfe\x86\x96\xee\xbe\xe5\x0f\xaf\ +-\x14\x68\x02\x22\x5d\x92\x84\x48\x48\x8d\x96\x67\x2d\x69\xec\x3f\ +-\x5c\xce\x5d\x0f\xac\x61\xdf\x87\x65\x86\xc4\xa3\x9c\x9f\xdb\xe9\ +-\xe4\xf3\x57\x5d\xc2\x17\x56\x5c\x4a\x58\xa8\x31\x99\xe1\x8e\x77\ +-\x0f\x71\xf7\x43\x6b\x28\xab\x54\x37\xd0\x59\x2d\xc4\x09\xb3\xb3\ +-\x75\xb6\x57\x08\xea\xda\x04\x71\xf1\x89\x1c\xfb\x30\x78\x8b\x2c\ +-\x75\xd8\x24\x01\x70\x38\xe8\x75\x82\xd6\xd9\xb7\x85\xcb\x1e\xd2\ +-\x92\xe2\x09\x0b\x75\xd3\xd9\x35\xc0\x45\xeb\x11\xee\xdd\xfd\x47\ +-\xd8\xf5\xfe\x87\x4c\x9d\x94\xfb\xf1\xcf\xba\xbd\xb0\xbd\xd2\xfe\ +-\x83\xff\x69\xbd\x3a\x6c\x2d\x17\xc4\x86\x09\xe2\xc3\x25\x0e\xad\ +-\xef\x67\x1d\x3d\xd0\xe9\x15\x74\xf6\xf6\xa5\xa0\x2e\x07\xc4\x84\ +-\x49\x32\xa2\x21\x31\x72\x60\x9f\xc9\x63\x8d\x82\xbd\x27\x04\xde\ +-\x7e\x66\xef\x1b\x10\x94\x37\xc3\xfe\x3a\x41\x51\x9a\xc4\xe5\x6b\ +-\xe5\xbe\xbf\xbf\xc8\x8b\x1b\xb6\xa1\x0f\x76\x4d\x43\xf1\x8b\x8b\ +-\x8a\x27\xf0\xed\x1b\x57\x18\x56\xf4\xab\xa6\xae\x81\x7b\xff\xfa\ +-\x2c\x6f\xa8\x65\x44\x5b\x71\x6a\x70\x51\xa6\x64\x77\x35\x78\xa2\ +-\x83\xfb\xe6\xd7\x8e\xf6\x56\x5b\x54\x03\xd4\xa0\xc7\x76\x4b\x00\ +-\x9a\x26\xc8\xcb\xc9\x50\xe7\x72\xcf\x70\xdf\xa3\x2f\xf2\xc7\x9f\ +-\x7e\x1b\x4d\xeb\xfb\xc0\x1c\x38\x29\xce\xda\x58\x13\x28\x1a\x3b\ +-\xa1\xb1\xf3\xdc\x1f\xfa\x2e\x2f\xb4\x76\x0b\x2a\x9a\x20\x21\x02\ +-\x0a\x53\x24\x51\x21\xfd\xbf\xd6\x27\xe1\xbd\x1a\x41\xd9\x79\xce\ +-\x1c\x9f\xd6\xd6\xad\x73\xef\xe3\x9b\xd9\xba\xe9\x65\xda\x3b\x6c\ +-\xf5\x71\x0f\x1a\xa9\x49\xa3\xf8\xe6\x97\x97\x33\x67\xda\x44\x43\ +-\xda\xef\xee\xe9\xe5\xd1\xb5\xeb\x79\x74\xed\x06\xba\x7b\xd4\xd1\ +-\x4d\x3b\xd2\x04\x14\xa7\x49\x0e\x66\xc6\xb2\xd1\xea\x60\x2c\xe4\ +-\xf3\xf9\xe8\xee\xee\x22\x24\xd4\xda\xc2\x29\x4e\x21\xbb\x9d\x20\ +-\xed\x31\x1f\x71\x86\x09\x63\x55\x02\x70\xa6\x7d\x87\xcb\x78\xf6\ +-\xb5\x2d\xac\xb8\x7c\x16\x3d\x3e\x28\x1f\x40\xdd\xed\x40\x77\xb2\ +-\x5d\xb0\xf1\xb0\x20\x67\x54\x5f\x91\x21\xf7\x19\x77\x56\x36\x75\ +-\xc2\xae\x2a\x8d\xd6\x01\x54\xe4\xad\x38\x7e\x98\xf5\x2f\x3d\x4d\ +-\x7d\xad\xba\xb4\xc7\x0a\x6e\x97\x8b\x1b\x56\x2c\xe0\xfa\xe5\x0b\ +-\x09\x71\x1b\x73\x31\xd3\x9b\xdb\xde\xe7\xb7\x7f\x59\x4b\x4d\x5d\ +-\x70\x5f\x24\x16\x08\x04\x50\x32\x36\xb8\x67\x00\x00\x3a\x3b\xda\ +-\x2d\x4f\x00\x1c\x1a\x9d\x4e\x04\x4d\x36\x5a\x01\x00\x20\x3f\xd7\ +-\x98\x5a\xdf\x81\xec\x0f\x8f\xbe\xc0\x9c\xe9\x13\x69\xf0\xc5\x7c\ +-\xea\x6c\xad\xbf\x64\xc4\x48\x0a\x92\x24\x5e\x1d\xb6\x95\x0f\x6c\ +-\x80\x35\x92\x0e\x1c\x39\x25\x28\x6b\x12\x24\x46\x48\x5c\x0e\x68\ +-\xed\x12\x34\x0e\x60\xd1\xaa\xad\xb5\x99\x37\x5f\x7b\x9e\x7d\xef\ +-\xed\xa4\xdf\x8a\x24\x8a\xe1\x66\x4e\xcd\xe7\xf6\x9b\x56\x92\x9a\ +-\x64\x4c\x85\xcf\xf2\xea\x3a\xee\x79\x78\x2d\x5b\x4b\xf7\x1b\xd2\ +-\xbe\x62\x8c\xe4\x04\x95\x00\x74\x77\x5b\x7f\xfa\x5e\x13\xa2\xc5\ +-\x89\x4e\x93\x8d\xf6\x00\x02\x7d\x97\x7e\x28\x67\xeb\xe8\xe8\xe2\ +-\x37\x0f\xad\x65\xe6\x15\x37\x1a\xd2\x7e\xa8\x13\x8a\x52\x25\x1f\ +-\xad\x32\x50\x90\x24\xd9\x5a\x6e\x8f\x0f\x86\xd7\x07\xd5\x2d\x03\ +-\x8b\xc5\xe7\xf3\xb2\x73\xcb\x46\xb6\xbe\xb9\x8e\xde\x1e\xb5\x8f\ +-\xc4\x0a\xe9\xc9\xf1\x7c\xeb\xa6\x15\xcc\x2c\xce\x37\xa4\xfd\x8e\ +-\x8e\x2e\x1e\x7c\xf2\x55\x9e\x7a\xe9\x2d\xbc\xbe\x00\xd9\x08\xa3\ +-\x7c\xcc\x13\x15\x41\x78\x68\x08\x1d\x5d\xc1\x7b\xa9\x56\x4f\xb7\ +-\xf5\xa7\x52\x84\x90\x2d\x4e\x29\xb0\xdd\x84\x72\x4a\x62\x1c\x71\ +-\x31\x51\xea\x78\xd6\x27\x6c\xdc\xb2\x07\x57\xfc\x3b\x14\x4e\xbd\ +-\xd8\xef\x6d\x87\xb9\xf8\x78\xf0\x07\x88\x0e\x95\xd8\xe9\x74\xc8\ +-\x40\x94\x1d\x39\xc8\x86\x57\xd6\x70\xaa\xee\x84\xd5\xa1\x04\xa5\ +-\x10\xb7\x8b\xeb\x97\x2f\xe0\x86\x15\x0b\xfd\x56\xc1\xf2\x4c\x52\ +-\x4a\x36\x6e\x7d\x4f\x55\x6a\x1c\x01\x62\xa2\x23\x83\x3a\x01\xe8\ +-\xea\xb2\x7e\x06\xc0\x21\x44\x93\x2d\x97\x00\x00\x26\xe6\x65\xf1\ +-\xe6\xf6\x0f\xac\x0e\xc3\x76\x36\xbc\xf4\x34\xc9\x69\x99\x24\x26\ +-\xfb\xb7\xa4\x66\x6b\x0f\x78\xf5\xbe\xdd\xba\xc0\x39\xef\x09\xb0\ +-\xa3\xa6\x86\x7a\x36\xbe\xbc\x86\x23\x87\xd4\xa5\x3d\x56\x99\x77\ +-\x51\x21\xdf\xfc\xd2\x55\x24\x27\xc4\x19\xd2\xfe\xa1\xa3\x95\xdc\ +-\xf5\xc0\x1a\xde\x3f\x78\xcc\x90\xf6\x15\x73\x45\x45\x86\x43\x6d\ +-\xf0\x5e\x0a\xd4\xd3\x65\xfd\x0c\x00\x9a\xde\xe0\x44\x97\x4d\x56\ +-\x1f\x47\xe8\xcf\x94\xfc\xb1\x2a\x01\xe8\x87\xd7\xdb\xcb\xf3\x8f\ +-\x3f\xc8\x75\xab\xef\x24\x2c\x22\xc2\x7f\xed\x7e\x54\xc2\xb7\x30\ +-\x45\x22\x80\xc3\xa7\xec\xf7\x99\xf8\xa4\xde\x9e\x1e\xb6\x6d\x7e\ +-\x8d\x1d\x9b\x37\xe0\xf3\x05\xe0\xb1\x88\x11\x20\x33\x35\x91\xdb\ +-\x6f\x5e\xc9\xf4\xc9\xe3\x0c\x69\xbf\xb9\xa5\x9d\xfb\xfe\xf1\x22\ +-\x2f\xac\xdf\xaa\x8e\x6e\x8e\x20\x9e\xc8\x11\x76\x75\xe8\x20\x75\ +-\xdb\x60\x09\x40\x83\x7a\xa7\x26\x64\xa3\xb4\xe1\x54\xef\x94\x82\ +-\x31\x56\x87\x60\x5b\x8d\x0d\xf5\x3c\xfd\xe8\x1f\xf9\xdc\x97\x6f\ +-\xc3\xe5\x3e\xc7\x39\xb9\x21\x38\xde\x28\xa8\x6e\xe9\x2b\xa2\xd3\ +-\x65\xe3\xf1\x54\x4a\xc9\x81\xf7\x77\xf1\xe6\xeb\xcf\xd3\xda\xac\ +-\xa6\x82\xad\x10\x16\xea\xe6\xcb\x57\x5f\xc6\x35\xcb\x2e\xc1\xe5\ +-\x74\x5c\xf8\x0d\x83\xa4\xeb\x3a\x6b\x5f\x7b\x87\xfb\xff\xf1\x12\ +-\x2d\x6d\xea\xe8\xe6\x48\xe3\x89\x0c\xb7\x3a\x04\x4b\x75\xdb\x62\ +-\x09\x40\xab\x75\x22\x9d\x27\x11\xf6\xab\x81\x3e\x36\x2b\x95\xc8\ +-\xf0\x30\xda\x54\x09\xcf\x7e\x9d\xa8\x2a\x67\xcd\xa3\x7f\x66\xd5\ +-\x17\x6e\xc5\xe9\xf4\xdf\x7a\xab\xdd\xa7\xfe\xcb\x8e\x1c\xe4\x8d\ +-\xd7\x9e\xa3\xae\xa6\xd2\xea\x50\x82\xd6\xcc\xa9\xf9\xdc\xb9\x7a\ +-\x95\x61\xd3\xfd\xfb\x0e\x97\x71\xf7\xfd\xcf\xb0\xef\xb0\xaa\xd4\ +-\x38\x52\x45\x45\x04\x77\x02\xd0\xdb\x6b\xfd\x06\x65\xcd\xc1\x87\ +-\x4e\x9f\x97\x5a\xcd\x98\xe3\xb9\xc3\xa2\x69\x1a\x85\x13\x72\xd8\ +-\xb2\x2b\x78\x4b\x46\x5e\x48\xc5\xf1\x0f\x59\xf3\xb7\x3f\xb1\xfc\ +-\xf3\x37\xe1\xb6\xf8\x4c\xa9\xd1\x4e\x54\x95\xf3\xe6\x6b\xcf\x53\ +-\x7e\xec\x90\xd5\xa1\x04\xad\xcc\xd4\x44\x6e\xbf\x69\x25\xd3\xa7\ +-\x18\x33\xdd\x7f\xaa\xa9\x85\xdf\x3f\xf2\x3c\xeb\xd4\xa5\x3d\x23\ +-\x9e\x27\x2a\xb8\x13\x00\x9f\xd7\xfa\x29\x56\xb7\x8b\x03\xce\xd6\ +-\x2c\x4e\x46\x57\xa3\x83\xfd\xae\x6f\x2f\x9e\x98\xab\x12\x80\x0b\ +-\x28\x3f\x76\x88\x7f\x3c\xf8\x5b\x56\xdd\x70\x2b\x91\x9e\x68\xab\ +-\xc3\xf1\xbb\xea\xca\xe3\xec\xd8\xbc\x9e\x0f\x0f\xbc\xaf\xce\xf3\ +-\x5b\x24\x2c\x2c\x84\x9b\xaf\x59\xcc\xd5\x4b\xe7\xe0\x74\xf8\x7f\ +-\xba\xbf\xd7\xeb\xe3\x89\x17\x36\xf1\x97\xa7\x5e\x0b\xea\x9d\xe1\ +-\xc1\x24\x2c\xc4\x7f\x4b\x97\x81\xc8\xdb\x6b\x6d\xb5\x4a\x87\x00\ +-\xf2\x39\xe6\x9c\x2f\x84\xb7\xb4\xca\xd7\x00\xc4\x5b\x1a\x51\x3f\ +-\x2e\x9a\x32\x9e\x7b\xff\xf2\xac\xd5\x61\xd8\xde\xc9\xda\x2a\x1e\ +-\xbd\xff\xd7\x5c\xb1\xea\x4b\xa4\x67\x8d\xb6\x3a\x9c\x61\x93\x52\ +-\x72\xe4\xe0\x5e\x76\x6e\x59\x4f\x65\xd9\x51\xab\xc3\x09\x5a\x42\ +-\x08\x2e\x9d\x53\xcc\xd7\xbf\xf0\x19\xe2\x63\x8d\x49\x2e\xb7\x96\ +-\xee\xe7\x9e\x87\xd7\x52\x5e\x5d\x67\x48\xfb\x8a\x3d\xb9\x5c\x4e\ +-\xab\x43\xb0\x94\xd7\x6b\x6d\x02\x10\xe2\xc4\x77\x8d\x10\xbe\xd3\ +-\xff\x0a\x75\xd8\x30\x01\xc8\xce\x48\x26\x39\x21\x8e\x13\x27\x55\ +-\x89\xcf\x0b\x69\x6d\x6e\xe2\xf1\x87\x7e\xcb\x45\xf3\x2e\xe3\xe2\ +-\x79\x97\xa3\x69\xb6\x9b\xd0\xb9\x20\xaf\xb7\x97\xfd\xef\xee\x64\ +-\xc7\x96\x8d\x34\xd4\xab\x5b\xdc\xac\x34\x3a\x33\x95\x3b\x57\xaf\ +-\x64\x4a\xbe\x31\x9b\x71\xab\x6a\xeb\xb9\xe7\xa1\xb5\xbc\xbd\x53\ +-\x1d\xdd\x0c\x46\x0e\x47\xe0\x7d\x3f\xf9\x93\xd5\x09\x80\xdb\x21\ +-\xbb\x01\x9c\x00\x52\x88\x5a\x21\xa5\x31\x65\xbb\x86\xe9\xa2\xa2\ +-\xf1\xac\x5d\xb7\xc5\xea\x30\x02\x82\x94\x3a\xef\x6c\x7a\x85\x63\ +-\x87\xf6\xb1\x60\xe9\x2a\x52\x33\xb2\xad\x0e\x69\x40\xaa\x2a\x8e\ +-\xb1\x6f\xcf\x0e\x0e\x7c\x50\x4a\xb7\x1d\xce\xc7\x06\xb1\x88\xf0\ +-\x30\x6e\xfe\xdc\x62\x56\x2d\x9e\x6d\xc8\x97\x74\x57\x77\x0f\x7f\ +-\x5d\xf3\x3a\x8f\x3d\xb7\x89\x1e\x8b\xa7\x41\x15\xeb\xb8\x9c\xc1\ +-\x3d\x03\xe0\xb3\x38\x01\x70\x39\x44\x1b\x7c\x94\x00\x08\x29\x6b\ +-\x2c\x8d\xe6\x3c\x2e\x2a\xca\x57\x09\xc0\x20\x9d\xa8\x2e\xe7\xef\ +-\x0f\xdc\xcd\xf8\x49\xc5\xcc\x59\xb8\x8c\xe8\x18\x63\x76\x6b\x0f\ +-\x47\x4b\x73\x23\xfb\xf6\xec\x60\xdf\x7b\x3b\x68\xa8\x57\xd3\xbf\ +-\x56\x13\x42\xb0\x78\x5e\x09\x5f\xbb\xe1\x33\xc4\xc5\x44\x19\xd2\ +-\xc7\x86\x2d\x7b\xb8\xf7\xaf\xcf\xaa\x2a\x7e\x8a\x21\x7b\x49\x02\ +-\x89\xb7\xd7\xda\x4d\x80\x0e\x4d\x36\xc1\x47\x09\x00\x50\x61\x61\ +-\x2c\xe7\x55\x3c\x69\x2c\x6e\x97\x4b\x3d\x2d\x0c\x96\x94\x1c\x78\ +-\x6f\x17\x87\x3e\xd8\x4d\x5e\xfe\x14\x4a\x66\xcd\x27\x39\xd5\xc2\ +-\x3b\x16\xa4\xa4\xee\x44\x15\xc7\x0e\xef\xe7\xd8\x87\xfb\xa8\x2a\ +-\x3f\xa6\x76\x7a\xdb\x44\x5e\x4e\x3a\x77\xac\x5e\xc9\xa4\x71\x39\ +-\x86\xb4\x7f\xb4\xbc\x86\xbb\x1f\x58\x43\xe9\xde\xc3\x86\xb4\xaf\ +-\x04\x1e\x23\x6a\x47\x04\x12\x9f\xc5\x77\x58\x38\x34\x4e\xc0\xe9\ +-\x25\x00\xa8\xb0\x5f\x29\xa0\x3e\xe1\xa1\x21\xcc\x98\x32\x8e\xb7\ +-\x76\xa8\xaa\x80\x43\xa1\xeb\x3a\x07\x3e\x28\xe5\xc0\x07\xa5\x24\ +-\xa7\x66\x32\x7e\x52\x31\xe3\x26\x16\x11\xe5\x89\x31\xbc\xef\xee\ +-\xae\x0e\x8e\x1f\x3e\xd8\x37\xe8\x1f\xde\x4f\x7b\x6b\x8b\xe1\x7d\ +-\x2a\x03\x17\x15\x11\xce\x2d\xd7\x2e\x61\xf9\x65\x33\x0d\xd9\x33\ +-\xd2\xd6\xd1\xc9\x83\x8f\xbf\xc2\xd3\xaf\x6c\xc6\x67\xd4\x15\x96\ +-\x4a\x40\x72\x06\xf9\x12\x00\xd2\xda\xdf\x07\x0d\x59\x01\xa7\x97\ +-\x00\x90\x15\x76\xbe\xf8\x65\xfe\xc5\x53\x54\x02\xe0\x07\x27\xaa\ +-\xcb\x39\x51\x5d\xce\x1b\xeb\x9e\x25\x21\x39\x8d\x8c\xec\xb1\x64\ +-\x64\x8f\x25\x25\x3d\x8b\x88\x48\xcf\xb0\xda\xee\x6c\x6f\xa7\xbe\ +-\xfe\x04\xf5\xb5\xd5\x9c\xa8\x2a\xa7\xa6\xaa\x8c\xc6\xfa\x3a\xf5\ +-\x94\x6f\x43\x9a\x26\x58\x3a\x7f\x3a\x5f\xbd\x7e\x19\x31\x9e\x48\ +-\xbf\xb7\xaf\xeb\x92\x97\x37\x6d\xe7\x8f\x8f\xbe\x48\x63\xb3\xba\ +-\xd0\x4b\xf9\x34\x5d\x0f\xee\x84\x50\x5a\x7c\x01\x8f\xdb\xc1\x41\ +-\xf8\x28\x01\xd0\x70\x54\xe8\xd8\xf7\x1f\x64\x56\x49\x3e\x6e\xa7\ +-\x93\x1e\x1b\x14\x4f\x18\x09\xa4\x94\xd4\xd5\x54\x52\x57\x53\xc9\ +-\xae\x77\x36\x01\x10\x12\x1a\xc6\xa8\x84\x24\x62\xe2\x12\x08\x8f\ +-\x88\x24\x22\x32\x8a\x90\xd0\x30\x34\xcd\xf1\x71\xb9\xe1\x9e\xee\ +-\x2e\x7a\x7b\xbb\xe9\xed\xee\xa1\xbd\xad\x95\xd6\x96\x46\xda\x5b\ +-\x5b\x68\x6c\x3c\x49\x67\x7b\xbb\x85\xff\x8f\x94\x81\x1a\x37\x26\ +-\x83\xef\xac\x5e\x45\x7e\x6e\x96\x21\xed\xab\x2a\x7e\xca\x40\xf4\ +-\x06\xf9\x77\xb9\xb4\xf8\x5e\x0b\x87\x53\xdb\x0d\x1f\x25\x00\xdd\ +-\x92\x72\x97\x7d\x27\x00\x88\x08\x0f\xa3\xa4\x30\x8f\x2d\xa5\xaa\ +-\x28\x90\x51\xba\xbb\x3a\xa9\xae\x38\x4e\x75\xc5\x71\xab\x43\x51\ +-\x0c\x10\x15\x11\xce\x8d\xd7\x5c\xce\xd5\x4b\x66\x1b\x32\xdd\xdf\ +-\xd2\xd6\xc1\x43\x4f\xbc\xca\xd3\xaf\x6c\x0e\xfa\xa7\x3b\xe5\xc2\ +-\x7a\x2d\xde\x04\x67\x35\x2b\x67\x00\x84\x80\x70\xc1\x76\xf8\x28\ +-\x01\x98\x91\x2e\x4e\x95\x56\xf9\x3a\x00\xdb\xd6\x67\x5c\x38\xab\ +-\x48\x25\x00\x8a\x32\x48\x9a\x26\x58\xb6\xf0\x22\xbe\x7a\xdd\x15\ +-\x78\xa2\xfc\x77\x7b\xe4\x69\x3e\x9f\xce\xd3\xaf\x6c\xe6\xc1\xc7\ +-\x5f\x51\xf7\x76\x28\x03\xe6\x0d\xf2\x3d\x21\x56\xce\x00\x84\xb8\ +-\xd0\x57\x4e\x16\x75\xf0\xcf\x53\x00\x48\xc9\x51\x21\x98\x68\x59\ +-\x54\x17\x30\x77\x46\x21\x61\xf7\x3f\x45\x67\xa7\x2a\x15\xaa\x28\ +-\x03\x91\x37\x3a\x9d\xef\xdc\xb2\x8a\x82\xdc\x6c\x43\xda\xdf\xbd\ +-\xf7\x30\x77\x3d\xf0\x0c\x47\xcb\xab\x0d\x69\x5f\x19\xb9\x82\x7e\ +-\x09\xc0\xc2\xbd\x51\x61\x0e\x3e\xbe\x5e\xf3\x9f\x5b\x31\x85\x38\ +-\x0c\xd2\xb6\x09\x40\x58\xa8\x9b\xf9\x17\x4d\xe6\xa5\x8d\xdb\xad\ +-\x0e\x45\x51\x6c\x2d\xc6\x13\xc9\xad\xd7\x5d\xc1\x15\x0b\x66\xa0\ +-\x69\xfe\x5f\xdb\xab\xab\x6f\xe2\xde\xbf\x3e\xcb\x86\x2d\x7b\xfc\ +-\xde\xb6\x12\x1c\xbc\x5e\x9b\x5f\x3b\x6a\x30\x2b\x97\x00\x5c\x9a\ +-\x3c\x75\xfa\xcf\x67\x9c\xc5\x90\xb6\x3f\xa4\xbb\xe4\x92\x69\x2a\ +-\x01\x50\x94\x73\xd0\x34\x8d\xe5\x97\x5e\xcc\x2d\xd7\x2d\x35\xe4\ +-\xba\xd5\x9e\xde\x5e\x1e\x7b\x6e\x13\x8f\x3c\xf3\x3a\x9d\x5d\xd6\ +-\x5f\x67\xaa\x04\xae\x9e\x20\xdf\x03\x60\x65\xa9\x76\x97\xe3\x9f\ +-\x75\x7f\x3e\x4e\x00\x84\xe4\x88\x8d\x4f\x02\x02\x30\x25\x7f\x0c\ +-\xa9\x49\xa3\xa8\xae\x3d\x75\xe1\x17\x2b\x4a\x10\x99\x34\x2e\x87\ +-\x3b\x56\xaf\x24\x2f\x27\xdd\x90\xf6\xdf\xde\xb9\x97\x7b\x1e\x5a\ +-\x4b\x55\x6d\xbd\x21\xed\x2b\xc1\x25\xd8\xf7\x8b\x38\x2c\xac\x84\ +-\xe8\x72\xc8\x8f\xef\x54\xff\x67\x02\x20\xf4\x23\xd2\x7e\x37\x02\ +-\x9f\x45\x08\xc1\x95\x8b\x2e\xe6\x8f\x8f\xbe\x60\x75\x28\x8a\x62\ +-\x0b\x9e\xa8\x08\xbe\x7c\xf5\x65\x5c\xbd\x64\x8e\x21\xd3\xfd\x95\ +-\x27\xea\xb9\xe7\xc1\x67\xd4\x06\x5c\xc5\xaf\x9a\x5b\x83\xfb\xd8\ +-\xb0\x10\xd6\x25\x00\x4e\xc9\xbb\x1f\xff\xf9\xf4\x1f\x34\x87\xf3\ +-\x70\x20\x54\xeb\x5a\xb6\x70\x06\x0f\x3e\xf1\xaa\x2a\x0d\xac\x04\ +-\x35\x87\x43\x63\xe5\xe5\xb3\xb9\xf9\xf3\x8b\x89\x0c\x0f\xf3\x7b\ +-\xfb\x5d\xdd\x3d\x3c\xf4\xe4\x3a\x9e\x78\x61\x13\xbd\x41\xbe\x5e\ +-\xab\xf8\x5f\x6b\x5b\xc7\x85\x5f\x34\x82\x99\x3d\x03\x20\x04\xc4\ +-\x86\x41\x72\x94\x24\x42\x68\xeb\x4e\xff\xfc\xe3\x04\xa0\x30\x89\ +-\xb2\xdd\xd5\x74\x02\xfe\xff\x36\xf1\xa3\x18\x4f\x24\x0b\x66\x4e\ +-\xe6\x95\x37\x76\x5a\x1d\x8a\xa2\x58\x62\xf2\x84\x31\xdc\xb9\x7a\ +-\x25\x63\xb2\x52\x0d\xeb\x63\xff\xe1\x72\x1e\x5d\xbb\xde\xb0\xf6\ +-\x95\xe0\xd6\xdc\x12\xdc\x09\x80\x66\x42\x02\x20\x04\x24\x44\x48\ +-\xd2\x3c\x90\xe2\x91\xb8\xfb\xba\x6c\x2b\x4a\x15\x07\x4f\xbf\xe6\ +-\x8c\x25\x00\xa1\xef\xaa\xf2\x1d\x10\x50\x89\xce\xf1\xc3\x00\x00\ +-\x20\x00\x49\x44\x41\x54\x64\x78\x64\xc3\xb4\x72\xf1\x6c\x95\x00\ +-\x28\x41\x27\x32\xd2\xc3\x67\xae\xba\x92\x2b\x2e\x99\x4a\x46\xb4\ +-\xd5\xd1\x28\xca\xd0\xb5\xb6\x07\x77\x02\xe0\x30\x70\x13\x60\x84\ +-\x0b\xb2\xe3\x24\x19\x31\x92\xd0\x4f\x5e\xb9\x20\xe4\x3e\x21\xc4\ +-\xc7\x47\x10\x3e\xf9\xd7\xfb\x08\x80\x04\x20\x3f\x37\x8b\x49\xe3\ +-\x72\x78\xff\xe0\x31\xab\x43\x51\x14\xc3\x69\x9a\x46\xf1\x8c\xb9\ +-\xcc\x9c\xbf\x04\x77\x48\x28\x7b\xaa\x61\xef\x09\x18\x3d\x4a\x32\ +-\x36\x5e\xe2\xb2\xf7\xd6\x1d\x45\xf9\x94\x96\x20\x5f\x02\x70\x7e\ +-\x54\x5e\xdd\x5f\x34\x20\xd9\x23\xc9\x8e\xed\x7b\xea\x17\xe7\xd8\ +-\x0e\x24\xa5\x38\x6b\x33\xcf\x59\x09\x80\x26\xd8\x17\x28\x77\xb7\ +-\x5c\xbf\x7c\x21\xdf\xfb\xc5\xfd\x56\x87\xa1\x28\x86\xca\xc8\x19\ +-\xcb\xc2\xa5\x57\x13\x9f\x98\x72\xd6\xcf\x7b\x75\x38\x78\x52\x70\ +-\xac\x41\x30\x21\x49\x92\x1d\x2b\xed\x7e\x88\x47\x51\x00\xf0\xfa\ +-\x7c\x41\x9f\x00\xb8\x5c\x6e\xbf\xb4\xe3\x74\x40\x4e\x8c\x64\x4c\ +-\x7c\x3f\x4f\xfb\xfd\xd0\xfa\x1e\xf2\xff\xf9\xfe\xb3\xff\x5a\xee\ +-\xb3\xf3\xad\x80\x67\x9a\x55\x92\xcf\xe8\xcc\x14\x8e\x96\xd7\x58\ +-\x1d\x8a\xa2\xf8\x5d\x44\xa4\x87\x79\x97\x5e\x49\xfe\xe4\x12\xce\ +-\x99\xce\x03\x3d\x3e\x78\xb7\x5a\x50\xd1\x24\x28\x4a\xd5\x89\xf2\ +-\xef\x83\x85\xa2\xf8\x5d\x5d\x7d\x53\xd0\xdf\x17\xe1\x0e\x19\xde\ +-\x2f\xaa\xd3\x01\x39\xb1\x92\xdc\xf8\x8f\xd7\xf6\x07\x46\xca\xb3\ +-\x12\x80\xb3\x26\x0f\x85\xee\x08\x98\xb3\x3e\x42\x08\xae\xbb\x6a\ +-\x81\xd5\x61\x28\x8a\x5f\x69\x0e\x07\xc5\x33\xe6\x71\xf3\xb7\x7e\ +-\x40\xfe\x94\x69\xe7\x1d\xfc\xcf\xd4\xd0\x01\x9b\x8e\x6a\x1c\x39\ +-\x25\x2c\xbe\x68\x54\x51\xce\xef\x44\x7d\xa3\xd5\x21\x58\x2e\x35\ +-\xd6\x4d\x8a\x47\x12\xe6\x1a\xdc\xfb\xc2\x9c\x50\x90\x2c\x59\x9c\ +-\xa7\x53\x90\x34\xc8\xc1\x1f\xd0\x9c\x8e\x73\xcf\x00\x1c\x4a\xe3\ +-\xc8\xd8\x6a\x6c\x7d\x29\xd0\x99\x16\xcd\x2e\xe2\xe1\x27\x5f\xa5\ +-\xf2\x84\x2a\x4e\xa2\x04\xbe\xcc\xd1\x79\x2c\x5a\x7a\x35\x71\x09\ +-\x49\x43\x7a\xbf\x4f\x87\xf7\x4f\x08\xea\xdb\xa1\x28\x6d\xf0\x5f\ +-\x0e\x8a\x62\x86\x13\x75\x0d\x56\x87\x60\xb9\xf4\x38\x37\x33\x32\ +-\x24\x20\x69\xe9\x82\x13\x6d\x82\xba\x56\x68\xec\x14\xf8\x3e\x91\ +-\xc1\x6b\x40\x42\xa4\x24\x3b\x0e\x92\x23\xcf\xbd\xbe\x3f\x00\x6d\ +-\x85\x49\x9c\x75\x4f\xf7\x59\x09\xc0\x35\x42\xf8\x76\x57\x7b\xdf\ +-\x97\x52\xcc\x18\x72\x17\x26\x72\x3a\x1c\xdc\xfc\xb9\x25\xfc\xe7\ +-\x6f\x1e\xb1\x3a\x14\x45\x19\xb2\xa8\xe8\x18\x2e\xb9\x7c\x05\xe3\ +-\x0a\xa6\xf8\xa5\xbd\x9a\x56\x41\xcb\x51\xc1\xb4\x74\x9d\x18\x5b\ +-\x1f\xea\x55\x82\xd1\x89\x93\x6a\x06\x20\x2c\xf4\x9f\x4b\x00\x9e\ +-\x50\xf0\x84\x4a\xf2\xe2\xc1\xa7\x4b\x9a\xbb\xa0\xb5\x47\x80\x84\ +-\x70\x37\xc4\x86\x49\x9c\x7e\xd8\xe8\x2b\x90\x7b\x84\x10\x67\xad\ +-\xbd\x7c\xaa\x59\x89\xd8\x3d\xfc\xae\xcc\xb3\x70\x56\x11\x63\xb3\ +-\xd2\xac\x0e\x43\x51\x06\xed\xf4\x74\xff\x4d\xb7\x7d\xdf\x6f\x83\ +-\xff\x69\xed\x3d\xf0\xd6\x31\x8d\xa3\x0d\x81\xb1\xa7\x47\x09\x1e\ +-\x27\x4e\xaa\x19\x80\xe8\x73\x5c\xcd\xed\xd0\x20\x2e\x1c\xb2\x62\ +-\x24\x59\xb1\x92\x84\x08\xff\x0c\xfe\xd0\xff\xd8\xde\x4f\x02\x40\ +-\x40\x25\x00\x9a\x26\x58\xfd\xf9\x25\x56\x87\xa1\x28\x83\x92\x3d\ +-\x76\x3c\x5f\xfe\xfa\xf7\x58\xb0\x74\x25\x2e\x3f\x1f\x09\x3a\xcd\ +-\x27\xe1\xbd\x1a\xc1\xae\x2a\x81\x37\xb8\xf7\x5c\x29\x36\x52\xa3\ +-\x96\x00\xce\x99\x00\x18\x4b\x7e\xea\xfa\xce\x4f\x1d\x1c\x10\x68\ +-\xa5\x10\x58\xdf\x16\xb3\xa7\x15\x50\x54\x30\x86\xdd\x7b\x8f\x58\ +-\x1d\x8a\xa2\x9c\x57\xa4\x27\x9a\xb9\x0b\x3f\xd3\xb7\xc1\xcf\x24\ +-\x15\x4d\x82\xa6\xce\xbe\x25\x01\x4f\xa8\x69\xdd\x2a\x4a\xbf\x8e\ +-\xa8\x93\x5b\x44\x7b\xcc\xdf\x66\xa7\xe1\xb8\xf0\x0c\x40\x54\x3b\ +-\xef\x23\x08\xb8\x42\xfb\xb7\xdf\xb4\xd2\xd2\x2b\x16\x15\xe5\x7c\ +-\x9c\x4e\x17\x17\xcd\xbd\x9c\x9b\xbf\xf5\x43\x53\x07\xff\xa6\xc6\ +-\x53\xb4\x34\x37\xd2\xda\xdd\xb7\x24\xd0\x14\xdc\x97\xb0\x29\x16\ +-\xab\x6f\x6c\xa6\x25\xc8\x2f\x02\x02\xf0\x44\x9a\x3e\x03\xd0\x13\ +-\xd1\xc1\xa7\x4e\xf9\x7d\x6a\xc4\xcc\xcd\x15\xdd\x48\xf6\x9b\x13\ +-\x93\xff\x8c\xc9\x4a\x65\xf9\x65\x33\xad\x0e\x43\x51\x3e\x25\x6b\ +-\xcc\x38\xbe\xf8\xb5\xef\x32\x7b\xe1\x52\xbf\x15\x00\xb9\x10\x6f\ +-\x6f\x2f\x5b\x36\xbd\xcc\xc3\xf7\xfe\x8c\xe6\x86\xbe\xeb\xb3\x7b\ +-\x75\xd8\x52\xa6\xd1\xd1\x63\x4a\x08\x8a\xf2\x29\x47\xcb\x4f\x58\ +-\x1d\x82\x2d\x58\xb0\x04\xb0\x2f\x37\x57\x74\x7f\xf2\x87\xfd\xd6\ +-\x0e\x92\xb0\x4d\x40\xa1\xf1\x31\xf9\xd7\xea\xcf\x2f\xe1\xf5\xb7\ +-\x77\xab\x0c\x53\xb1\x85\xd8\xb8\x78\xe6\x2f\x59\xc9\xe8\xbc\x02\ +-\x53\xfb\x3d\x7c\xe0\x7d\x36\xbe\xf2\x0c\xcd\x8d\xa7\x3e\xf5\x77\ +-\x3d\x3e\x78\xef\x84\xe0\xa2\x4c\x55\x2d\x40\x31\x9f\x2a\xdc\x06\ +-\xe1\xa1\x21\x84\xb8\x07\x59\x00\x60\xb8\x04\x5b\xfb\xfb\x71\xbf\ +-\x09\x80\x40\x6e\x03\x71\x8b\xb1\x11\xf9\x9f\x27\x32\x9c\x6f\x7f\ +-\x79\x39\x3f\xf9\xed\xa3\x56\x87\xa2\x04\x31\x97\xcb\xcd\xb4\xd9\ +-\x0b\x98\x3e\x7b\x11\x4e\xa7\x79\xbf\xe8\x8d\x0d\xf5\x6c\x7c\x79\ +-\x0d\x47\x0f\xed\x3d\xef\xeb\x6a\x5b\x05\x3d\x3e\x55\x27\x40\x31\ +-\x9f\x4a\x00\x20\x3e\xce\xfc\x9b\xbc\x84\x2e\xb7\xf5\xf7\xf3\x7e\ +-\x13\x00\x87\xc3\xb1\xcd\xe7\x0b\xac\x8d\x80\xa7\x5d\x3e\xaf\x84\ +-\x75\x9b\x77\xb1\x6d\xf7\x01\xab\x43\x51\x82\xd0\xb8\xfc\x29\xcc\ +-\x5b\xbc\x1c\x4f\x74\xac\x69\x7d\xf6\xf6\xf6\xb0\xf5\xcd\x75\xec\ +-\x7c\x7b\x23\x3e\x9f\xf7\x82\xaf\x97\x40\x53\xa7\x20\x31\x52\xcd\ +-\x02\x28\xe6\xfa\xf0\x58\x95\xd5\x21\x58\xce\x8a\x04\xc0\xa7\x39\ +-\x06\x3e\x03\x50\x98\xc4\xbe\xdd\x35\x34\x23\x09\xc8\x4b\x47\xff\ +-\xf5\xd6\x6b\xb8\xe1\x8e\x5f\xd0\xd9\xf9\xa9\x25\x0f\x45\x31\x44\ +-\x5c\x7c\x22\xf3\x17\xaf\x24\x27\x77\x82\xa9\xfd\x1e\x39\xf8\x01\ +-\x1b\x5e\x7a\x9a\xe6\xa6\xc1\x1d\xad\xea\x08\xb8\x6d\xbe\x4a\xa0\ +-\xeb\xe8\xe8\x52\x27\x00\x80\x84\x51\xa6\x0f\xab\x4d\x53\x53\x38\ +-\xd4\xdf\x5f\xf4\xbf\x04\x20\x84\x5e\x5a\xa5\xef\x04\xb9\xd0\xd8\ +-\xb8\x8c\x91\x14\x1f\xcb\x37\xbf\x78\x15\xbf\xbc\xef\x09\xab\x43\ +-\x51\x46\x38\x97\x3b\x84\x59\xf3\x97\x50\x3c\x63\x2e\x9a\xc3\xbc\ +-\x39\xf5\x86\xfa\x5a\xd6\xbf\xf4\x34\x65\x47\x0e\x0e\xe9\xfd\x5d\ +-\x17\x9e\x28\x50\x14\xbf\xda\xfb\x61\x79\xd0\x5f\x02\x04\x90\x60\ +-\xfa\x0c\x80\xd8\xfa\xc9\x0a\x80\xa7\x9d\xf3\x02\x41\x21\xe4\x56\ +-\x29\x09\xc8\x04\x00\xe0\xca\x4b\x2f\x66\xe7\xfb\x87\xd8\xb0\xe5\ +-\x53\xb5\x0f\x14\xc5\x2f\xc6\xe4\x15\xb0\x68\xd9\x35\x44\x45\xc7\ +-\x98\xd6\x67\x6f\x6f\x0f\x3b\xde\x5e\xcf\xb6\x37\x5f\x1f\xd0\x74\ +-\xff\xb9\x74\xaa\x19\x00\xc5\x64\xef\x1d\x38\x6a\x75\x08\xb6\x90\ +-\x38\xca\xbc\xef\x0b\x00\x49\xff\xeb\xff\x70\x9e\x04\x40\x0a\xf9\ +-\x36\x32\xb0\xcb\x88\x7e\xf7\xd6\xcf\xb2\xf7\x50\x19\xb5\xea\xf6\ +-\x29\xc5\x8f\x12\x92\xd2\x58\xb8\x6c\x15\xe9\x99\x63\x4c\xed\xf7\ +-\xc8\xc1\x0f\x58\xff\xe2\x53\xb4\x34\x0f\xff\xf3\xdc\xd0\x21\x40\ +-\xdd\x1b\xa8\x98\x48\x25\x00\x7d\x92\xe2\xcd\xdb\x1f\x04\x20\xd0\ +-\x37\x9f\xeb\xef\xce\x99\x00\x74\x38\x1d\x9b\xc3\x7b\x74\xef\xf9\ +-\x5e\x63\x77\x51\x11\xe1\xfc\xf0\x9b\xd7\x71\xfb\x7f\xfd\x81\x40\ +-\xdd\xd4\xa8\xd8\x47\x48\x68\x38\xb3\x17\x2c\x65\xca\xf4\x59\x08\ +-\x61\x5e\xd1\xa9\xfa\xba\x1a\xd6\xbf\xf4\x14\x15\xc7\x0e\xfb\xad\ +-\xcd\xb6\x6e\x68\xee\x84\x68\x75\x59\x90\x62\x02\x5d\xd7\xd9\x77\ +-\xb8\xdc\xea\x30\x6c\x21\x2d\x69\x94\x79\x9d\x09\x7a\x1d\x9a\xf3\ +-\x9d\x73\xfd\xf5\x39\xbf\xc5\x66\x27\x88\xd6\xfe\x6a\x07\x07\x9a\ +-\xa2\x82\xb1\x7c\xfd\x0b\x57\x5a\x1d\x86\x12\xc8\x84\x20\x7f\xf2\ +-\x34\x6e\xfe\xd6\xf7\x29\x9a\x31\xc7\xb4\xc1\xbf\xb7\xa7\x87\x2d\ +-\x9b\x5e\xe6\x91\x3f\xfe\xaf\x5f\x07\x7f\xe8\x7b\xf6\xdf\x5b\x27\ +-\xd4\x1c\x80\x62\x8a\xbd\x1f\x96\xa9\x4d\xd9\x80\x10\x82\x14\x33\ +-\x13\x00\x29\x77\x4e\x4e\x16\xe7\x2c\x8c\x73\xfe\xa7\x7b\x21\xde\ +-\x44\x52\xe2\xf7\xa0\x4c\xf6\xb9\x65\xf3\x38\x52\x56\xcd\x4b\x1b\ +-\xb7\x5b\x1d\x8a\x12\x60\x92\x52\xd2\x59\x78\xc5\x67\x49\xcd\xc8\ +-\x36\xb5\xdf\x23\x07\x3f\xe0\xf5\x17\x9f\xa4\xb5\xb9\xc9\xb0\x3e\ +-\xea\xda\x04\x47\x4e\xc1\xd8\x51\x2a\x0d\x50\x8c\xb5\xb5\x54\x1d\ +-\xcb\x86\xbe\x13\x00\xe6\x16\x01\x12\x6f\x9e\xef\x6f\xcf\x9b\x00\ +-\x08\x29\xdf\x94\x88\x3b\xfd\x1b\x90\x35\xee\x5c\xbd\x8a\x23\xe5\ +-\x35\x1c\x3c\x52\x61\x75\x28\x4a\x00\x08\x0b\x8f\x64\xee\xa2\x65\ +-\x4c\x2c\xbe\x08\x21\xcc\xdb\x0b\x73\xb2\xb6\x8a\xf5\x2f\x3e\x45\ +-\x65\x99\x39\xeb\xa5\x7b\x6b\x05\x9e\x10\x54\x4d\x00\xc5\x50\x5b\ +-\xf7\x04\x5c\x75\x79\x43\x98\x3a\xfd\x0f\x08\x5d\x0e\x3d\x01\x70\ +-\xeb\x8e\xb7\xba\x35\x5d\xe7\x3c\x4b\x05\x81\x22\x34\xc4\xcd\xff\ +-\x7e\x6f\x35\xb7\xfe\xe0\x37\xea\x3a\x4a\xe5\x9c\x84\xd0\x98\x32\ +-\x6d\x16\xb3\x17\x2e\x25\x24\xd4\xbc\x1b\xbb\xba\xbb\x3a\xd9\xbc\ +-\xe1\x45\xf6\x6c\x7f\x1b\x29\xcd\xdb\xaf\x22\x25\xec\xa8\x10\xcc\ +-\x1d\x2d\x89\x32\xe6\x56\x62\x25\xc8\x35\x34\xb5\x72\xe8\x68\xa5\ +-\xd5\x61\xd8\x42\x7a\x4a\x82\x99\xdd\xf9\xf0\x3a\xb6\x9c\xef\x05\ +-\xe7\x1d\xd8\x0b\x32\x44\x83\x84\x77\xfd\x1b\x93\x75\xe2\x62\x3d\ +-\xfc\xea\xfb\x5f\xc1\x13\x69\xfe\x55\x8c\x8a\xfd\x25\xa7\x65\x72\ +-\xdd\x2d\xb7\xb3\xf0\x8a\xab\xcd\x1b\xfc\xa5\x64\xdf\x9e\x1d\x3c\ +-\xf0\xdb\xff\x61\xf7\xb6\xb7\x4c\x1d\xfc\x4f\xeb\xd5\xe1\x9d\x72\ +-\x0d\xaf\xcf\xf4\xae\x95\x20\xb0\x75\xf7\x7e\xa4\x54\x33\x4c\x00\ +-\x39\xe9\xc9\xe6\x75\x26\xe4\xae\xa2\x1c\x71\xde\x35\xc4\x0b\xee\ +-\xf0\xd7\xe0\x35\x09\x45\xfe\x8b\xca\x5a\x59\xe9\x49\xfc\xfc\x7b\ +-\x37\xf3\x9d\xff\xbe\x8f\xce\x2e\x75\x2d\x9a\x02\x11\x91\x1e\xe6\ +-\x5d\x76\x25\xf9\x85\x25\x60\xe2\x74\x7f\x6d\x75\x05\xeb\x5f\x7c\ +-\x8a\xea\xca\xe3\xa6\xf5\x79\x2e\x1d\x3d\x7d\x9b\x02\x27\xa7\xa8\ +-\x2f\x6a\xc5\xbf\xb6\xec\x3a\xff\xdd\x14\xc1\x24\x27\x23\xc5\xb4\ +-\xbe\x04\xe2\xb5\x0b\xbd\xe6\x82\x53\xfb\x12\xfd\x82\x8d\x04\x9a\ +-\xc2\xf1\xa3\xf9\xbf\x1f\xdc\x4a\x58\xa8\x39\x57\xb3\x2a\xf6\xa4\ +-\x69\x1a\xc5\x33\xe6\x71\xf3\xb7\x7e\x40\xfe\xe4\x69\xa6\x0d\xfe\ +-\xdd\x5d\x1d\x6c\x78\x69\x0d\x7f\xfb\xd3\xaf\x6d\x31\xf8\x9f\x76\ +-\xbc\x51\xd0\xad\x2a\x04\x2a\x7e\xd4\xd1\xd1\xc5\x3b\xa5\x6a\xfd\ +-\xff\xb4\xd1\x59\xe6\xcd\x00\x48\xa1\x5d\x70\xec\xbe\xe0\x0c\x40\ +-\x73\x8f\x73\x73\xb4\x5b\xef\x04\x46\xd4\x89\xe1\xc2\x09\xa3\xf9\ +-\x9f\x7f\xb9\x89\xef\xfd\xfc\x7e\x7a\xbc\xea\x5b\x2f\xd8\x64\x8e\ +-\xce\x63\xe1\x92\x55\x8c\x4a\x34\xf1\x17\x52\x4a\xde\x2f\x7d\x87\ +-\x37\x5f\x7f\x81\xae\x0e\xfb\x5d\x59\x2d\x25\x54\x36\x0b\xc6\xa8\ +-\x53\x01\x8a\x9f\xbc\xb9\xe3\x03\xba\x7b\x54\xd9\x49\xe8\xab\x4b\ +-\x33\x2a\xc6\x63\x56\x77\xed\x51\x6d\xfd\x5f\x01\x7c\xa6\x0b\x26\ +-\x00\xf3\x73\x44\x57\x69\x95\xbe\x19\xe4\xa5\xfe\x89\xcb\x3e\xa6\ +-\x4f\x19\xc7\x2f\xbf\x7f\x0b\xdf\xff\xe5\x83\x74\x74\xa9\x33\xaa\ +-\xc1\x20\x2a\x3a\x86\x4b\x2e\x5f\xc1\xb8\x82\x29\xa6\xf6\x5b\x53\ +-\x55\xc6\xfa\x17\x9e\xe2\x44\xb5\xbd\x8b\xa1\x34\x75\x59\x1d\x81\ +-\x32\x92\xbc\xb6\x79\x97\xd5\x21\xd8\x46\x4e\xa6\x79\x0f\x1b\x02\ +-\xb1\x31\x37\x57\x5c\x70\x50\x1b\x50\x95\x3f\x81\x7c\x4d\xc2\x88\ +-\x4b\x00\x00\x4a\x0a\xf3\xf8\xcd\x8f\xbf\xce\xbf\xfc\xf4\x4f\x34\ +-\xb7\xd8\xef\xa9\x4c\xf1\x0f\xcd\xe1\x60\x4a\xc9\x6c\xe6\x2c\xba\ +-\x02\x97\xdb\xbc\xed\xee\x5d\x9d\x1d\x6c\xd9\xf8\x0a\xbb\xb7\x5b\ +-\xb3\xc1\x6f\xb0\xbc\xf6\x0f\x51\x09\x10\x4d\x2d\x6d\xec\x7c\xaf\ +-\xdf\x4b\xe8\x82\xd2\xf8\xd1\xe9\xa6\xf5\x25\x85\x1c\xd0\xd2\xfd\ +-\x80\x12\x00\xcd\xa1\xbd\xec\xf3\xe9\xbf\x1c\x5e\x48\xf6\x35\x61\ +-\x6c\x26\xbf\xfd\xf1\x37\xf8\xee\x4f\xff\xac\xee\x0d\x18\x81\x46\ +-\xe7\xe6\x33\x7f\xc9\x4a\x62\x47\x99\x77\x04\x47\x4a\x9d\x3d\x3b\ +-\xde\x66\xf3\xfa\x97\xe8\xee\xea\x30\xad\xdf\xe1\x0a\x31\xef\x42\ +-\x43\x65\x84\x5b\xff\xf6\x1e\x55\x82\xfd\x0c\xe3\x46\x67\x98\xd6\ +-\x97\x43\x6a\xaf\x0e\xe4\x75\x03\x4a\x00\x26\x27\x8b\x0f\x4a\xab\ +-\x7c\xc7\x80\x9c\x61\x45\x65\x63\xa3\x33\x53\x78\xf0\x97\xdf\xe1\ +-\xfb\xff\xfb\x10\xef\xee\x3f\x62\x75\x38\x8a\x1f\x44\x45\xc7\x30\ +-\x67\xc1\x32\xf2\xa7\x4c\x33\xb5\xdf\x13\xd5\xe5\xac\x7f\xe1\x29\ +-\x6a\xaa\xca\x4c\xed\xd7\x1f\xd4\xdd\x00\x8a\xbf\x3c\xfb\xda\x79\ +-\x8f\xa0\x07\x9d\x09\x63\x4d\x4a\x00\x04\x47\x26\xa7\x8a\x01\xdd\ +-\x13\x3e\x98\x8b\x7e\x5e\x04\x6e\x1b\x5a\x44\x81\x21\xda\x13\xc1\ +-\xaf\xff\xe3\x56\x7e\xfe\xfb\xc7\x78\x6d\x73\xa9\xd5\xe1\x28\x43\ +-\xe4\x72\xb9\x99\x3e\x67\x11\xd3\x66\x2d\xc0\xe9\x34\xaf\xec\x66\ +-\x47\x5b\x2b\x6f\xbc\xf6\x1c\x7b\xdf\xdd\xd1\xb7\xa3\x2e\x00\xa9\ +-\xeb\xda\x15\x7f\xd8\xb3\xef\x08\x47\xcb\x6b\xac\x0e\xc3\x36\xc2\ +-\xc2\x42\x48\x4f\x49\x34\xab\xbb\x67\x07\xfa\xc2\x01\x27\x00\x52\ +-\xe8\x2f\x0a\xa9\x8d\xe8\x04\x00\x20\xc4\xed\xe2\x47\xb7\x7f\x81\ +-\x89\xe3\x72\xf8\xdd\x5f\x9e\x55\x27\x04\x02\x4c\x5e\xfe\x64\x2e\ +-\xb9\x7c\x39\x9e\x98\x38\xd3\xfa\xd4\x75\x9d\xdd\xdb\xdf\xe2\xed\ +-\x8d\x2f\xd3\xd3\xd5\x69\x5a\xbf\x46\xd8\x57\x27\xf0\x84\x5a\x1d\ +-\x85\x12\xe8\x9e\x5d\xa7\x9e\xfe\xcf\x34\x2e\x27\x1d\x4d\x33\xe7\ +-\x98\xb1\xd4\xf5\x17\x07\xfa\xda\x01\x27\x00\x9e\x76\xe7\xc6\x96\ +-\x70\xbd\x55\x40\xd4\xd0\xc2\x0a\x2c\xab\x96\xcc\x26\x3f\x37\x93\ +-\x1f\xdd\xf5\x57\xaa\x6b\x4f\x59\x1d\x8e\x72\x01\x29\xe9\x59\x5c\ +-\x72\xf9\x72\xd2\x32\x47\x9b\xda\x6f\xc5\xf1\xc3\xac\x7f\xe9\x69\ +-\xea\x6b\xab\x4d\xed\xd7\x28\x3e\x1d\xb6\x94\x09\xb4\x66\xf3\x0a\ +-\x22\x29\x23\x4b\x63\x73\x2b\x9b\xb6\x8e\x98\x02\xb2\x7e\x51\x90\ +-\x97\x6d\x56\x57\x2d\xa1\xcd\xce\xcd\x03\x7d\xf1\x80\x13\x80\xdc\ +-\x5c\xd1\xbd\xbb\x4a\x7f\x5d\x22\x57\x0c\x2d\xae\xc0\x33\x61\x6c\ +-\x26\x0f\xff\xea\xbb\xdc\xf3\xf0\x33\xbc\xb0\x7e\x9b\xd5\xe1\x28\ +-\xfd\x48\x48\x4a\xe3\xe2\x4b\x2e\x27\x6f\x42\xa1\xa9\x55\xfc\xda\ +-\x5a\x9b\xd9\xb4\xee\x59\x0e\xbc\x5f\x1a\xb0\xd3\xfd\xe7\x22\x25\ +-\x1c\x6f\x50\x09\x80\x32\x34\x6b\xd7\x6d\xa1\x57\xd5\x95\x3e\xcb\ +-\xe4\x09\xe6\x3c\x98\x08\x78\xa5\xa0\x40\x0c\xb8\xc4\xed\x60\xf6\ +-\x00\x80\xd4\x9f\x43\x88\xa0\x49\x00\x00\xc2\xc3\x42\xf8\xde\xd7\ +-\x3e\xcf\xdc\x19\x85\xfc\xe2\xf7\x8f\x73\xaa\xa9\xc5\xea\x90\x14\ +-\x20\x31\x25\x9d\x8b\xe7\x5d\x4e\xee\xf8\x49\xa6\x0e\xfc\xba\xcf\ +-\x47\xe9\xd6\x37\x78\x7b\xd3\x2b\xf4\xf6\xa8\xda\x11\x8a\x72\xa6\ +-\x8e\xae\x6e\x9e\x7c\xe9\x2d\xab\xc3\xb0\x15\x4d\x13\x4c\x1a\x9f\ +-\x6d\x4a\x5f\xba\x90\xcf\x0f\xe6\xf5\x83\x4b\x00\x7a\x1d\x6b\x71\ +-\xeb\xf7\x01\x41\x57\x43\x77\x66\x71\x3e\x8f\xdd\xfb\x03\x1e\x7e\ +-\x6a\x1d\xff\x78\x6e\x23\xba\xda\x2d\x65\x3e\x21\xc8\x1a\x9d\x47\ +-\xf1\x8c\xb9\x8c\xc9\x2b\x30\x75\xe0\x07\xa8\x38\x76\x98\xf5\x2f\ +-\x3d\x45\x7d\x9d\xda\xdc\xa4\x28\xfd\x59\xfb\xea\xdb\xb4\xb4\xaa\ +-\x7a\x2a\x67\xca\xc9\x48\x21\x2a\xc2\x94\xcb\xc5\x7a\x5c\xbd\x8e\ +-\x01\xaf\xff\xc3\x20\x13\x80\xa2\x1c\xd1\x54\x5a\xa5\xbf\x31\x12\ +-\xab\x02\x0e\x44\x58\xa8\x9b\xaf\xdd\xb0\x8c\x84\xd1\x45\x3c\xf9\ +-\xe4\xd3\x54\x55\x1c\xb3\x3a\xa4\xa0\xe0\x0e\x09\x25\x7f\x72\x09\ +-\xc5\x33\xe6\x12\x17\x9f\x64\x7a\xff\xad\x2d\x4d\x6c\x7a\xe5\x19\ +-\x0e\xee\xdd\x63\x7a\xdf\x8a\x12\x28\xba\x7b\x7a\x79\xec\x85\x37\ +-\xac\x0e\xc3\x76\x26\x8f\x37\xe7\xf4\xbc\x14\xe2\xb5\xc2\x2c\x31\ +-\xa8\x42\x36\x83\x9b\x01\x00\xa4\x94\x4f\x0b\x31\x32\xab\x02\x0e\ +-\x44\x63\x27\x38\xa3\x33\xb8\xf6\xe6\x6f\x73\x68\xff\x7b\xbc\xf5\ +-\xfa\xf3\x34\x9e\x3a\x69\x75\x58\x23\x52\x72\x6a\x26\x93\x4b\x66\ +-\x32\x6e\x52\x31\x6e\x13\xab\xf7\x9d\xe6\xf3\xf9\xd8\xb5\x65\x23\ +-\xef\xbc\xf9\x2a\xbd\x3d\xea\xe6\x48\x45\x39\x9f\x17\x37\x6c\xa3\ +-\xa1\x51\x2d\x91\x7e\x52\xd1\xa4\x5c\x73\x3a\x92\xfa\xd3\x83\x7d\ +-\xcb\xa0\x13\x00\xb7\x4b\x5b\xdb\xeb\xd5\x7f\x07\x04\x65\xcd\xb0\ +-\x43\xf5\x1f\x4d\x3b\x0b\x41\x5e\xfe\x64\xc6\x8e\x9b\xc8\x07\x7b\ +-\xb6\xb3\xed\xad\xd7\x68\x6e\x54\xa7\x05\x86\x2b\x22\xd2\xc3\xf8\ +-\x49\xc5\x14\x4c\x9e\x46\x62\x8a\x79\xa5\x33\x3f\xe9\xf8\xe1\x03\ +-\x6c\x78\xf9\x69\x1a\xea\xeb\x2c\x8b\x41\x51\x02\x45\x67\x57\x0f\ +-\x7f\x79\x6a\xc4\x5d\x1c\x3b\x6c\x9a\xa6\x51\x62\x4e\x02\xe0\x95\ +-\xc2\x31\xa8\xf5\x7f\x18\x42\x02\x30\x29\x49\xd4\x96\x56\x79\xdf\ +-\x06\x31\x77\xb0\xef\x0d\x74\xad\xdd\x70\xa2\xf5\xec\x75\x67\xcd\ +-\xe1\xa0\x70\xea\xc5\x4c\x9c\x32\x9d\xfd\xef\xed\x64\xdb\xdb\xeb\ +-\x69\x38\x59\x6b\x51\x84\x81\xc9\x1d\x12\xca\xd8\x09\x93\xc8\x2f\ +-\x2c\x21\x6b\x74\x1e\x42\x5c\xf0\x96\x6a\xc3\x34\x37\x35\xb0\xe9\ +-\x95\x67\xf8\x70\xff\x7b\x96\xc5\xa0\x28\x81\xe6\x1f\xcf\x6d\x54\ +-\x1b\xa4\xfb\x91\x3f\x36\xd3\xa4\xf5\x7f\xb1\xb1\x24\x55\xd4\x0f\ +-\xf6\x5d\x83\x4e\x00\x00\x24\xe2\x49\x01\x41\x97\x00\x94\x35\x8a\ +-\x73\x9e\xf8\xd2\x1c\x0e\x0a\x8a\x66\x50\x30\x65\x3a\xc7\x8f\x1e\ +-\xa4\xf4\x9d\x37\x38\x76\x78\x3f\x72\x84\x1d\x11\xf3\x97\xb0\xf0\ +-\x48\xc6\x8e\x9f\x48\xee\x84\x42\xb2\xc6\x8c\xc3\xe1\x18\xd2\x47\ +-\xd1\x6f\xbc\xde\x5e\x76\xbc\xbd\x81\xed\x6f\xbd\x4e\x6f\xaf\x9a\ +-\xee\x57\x94\x81\x3a\xd5\xd4\xc2\x63\xcf\x6d\xb4\x3a\x0c\x5b\x9a\ +-\x3e\x65\x9c\x29\xfd\x48\x21\x9f\x1a\xca\xfb\x86\xf4\xad\x2b\x34\ +-\xed\x71\x74\xfd\xae\xa1\xbe\x3f\x50\xd5\xb5\x0d\x60\xd7\xb9\x10\ +-\x64\x8f\x19\x4f\xf6\x98\xf1\x34\x37\x9e\xe2\x83\x3d\xdb\xd9\xbb\ +-\x7b\x1b\x2d\xcd\xea\x92\xa1\x51\x09\xc9\xe4\xe4\x4e\x60\x4c\xde\ +-\x44\xd2\xb3\x47\x5b\xfa\xa4\x7f\xa6\x23\x87\xf6\xb2\xf1\xe5\x35\ +-\x34\x35\x0c\x3a\x81\x56\x94\xa0\xf7\xc0\x63\x2f\xab\xeb\xd4\xcf\ +-\x61\xda\x64\x53\x12\x80\x1e\xaf\xae\x0d\x7a\xfd\x1f\x86\x38\x80\ +-\x17\xa7\x88\x93\xa5\x55\xfa\xeb\x20\x17\x0f\xe5\xfd\x81\x48\x02\ +-\xed\x83\x7c\x30\x8c\x8e\x1d\xc5\xac\xf9\x4b\x98\x79\xc9\x62\x2a\ +-\xcb\x8e\x70\xf8\xc0\xfb\x1c\x3e\xf0\x7e\xd0\xec\x15\x08\x8b\x88\ +-\x20\x2b\x27\x8f\xec\xb1\x13\xc8\x1e\x33\x9e\x48\x4f\xb4\xd5\x21\ +-\x9d\xa5\xa9\xa1\x9e\x8d\x2f\xaf\xe1\xc8\xa1\xbd\x56\x87\xa2\x28\ +-\x01\xe9\xd0\xb1\x4a\x5e\xd8\xb0\xdd\xea\x30\x6c\x29\xc6\x13\x49\ +-\x41\x6e\x96\x09\x3d\x89\x97\x67\xa4\x8b\x21\x0d\x2a\x43\x7f\x82\ +-\x17\xfa\xdf\x91\x22\x68\x12\x00\x24\xe8\x43\x9c\xcd\x17\x42\x90\ +-\x91\x3d\x96\x8c\xec\xb1\xcc\x5f\xbc\x82\x53\x27\x4f\x70\xe4\xe0\ +-\x07\x1c\x39\xb8\xb7\xef\x28\xe1\x08\x59\x26\x88\x88\xf4\x90\x9e\ +-\x35\x9a\xd4\xcc\xd1\xa4\x67\x8e\x26\x31\x25\x1d\x61\xf2\x59\xfd\ +-\x81\xf0\xf6\xf6\xb2\xfd\xed\xd7\xd9\xfe\xd6\x7a\xbc\xde\x5e\xab\ +-\xc3\x51\x94\x80\xa4\xeb\x92\xff\xfb\xd3\xd3\xaa\x26\xca\x39\xcc\ +-\x9e\x56\x80\xa6\x19\x3f\xcb\x29\xd1\xff\x31\xd4\xf7\x0e\x39\x01\ +-\x70\x68\x8e\x35\x3e\x9f\xfe\x07\x20\x62\xa8\x6d\x04\x12\x21\xc0\ +-\xa9\x41\xaf\x1f\x3e\xeb\xa3\x12\x92\x19\x95\x90\xcc\xf4\xd9\x8b\ +-\x68\x6b\x6d\xa6\xaa\xe2\x18\x35\xe5\xc7\xa8\xae\x3c\x4e\x6d\x75\ +-\x05\x3e\x9f\xfd\xcb\x68\x46\x45\xc7\x90\x98\x9c\x4e\x62\x72\x1a\ +-\x09\xc9\x69\xa4\xa6\x67\xdb\xee\x09\xbf\x3f\x1f\x1e\x78\x9f\x4d\ +-\x2f\xaf\xa1\xb9\xa9\xc1\xea\x50\x14\x25\xa0\x3d\xf5\xd2\x9b\xec\ +-\xfd\xf0\xb8\xd5\x61\xd8\xd6\xec\x92\x49\x66\x74\xd3\xee\x74\x38\ +-\x5e\x18\xea\x9b\x87\x9c\x00\x4c\x4e\x16\xed\xa5\x55\xbe\x17\x80\ +-\xcf\x0d\xb5\x8d\x40\x13\x13\x26\x39\xd9\xee\xdf\x27\xda\xc8\xa8\ +-\x68\xc6\xe5\x4f\x61\x5c\xfe\x14\x00\x7c\x3e\x2f\x27\xaa\x2b\xa8\ +-\xa9\x38\xce\xa9\x93\x27\x68\xac\x3f\x49\xc3\xa9\x3a\x3a\xda\x5b\ +-\xfd\xda\xef\x40\x68\x0e\x07\xd1\x31\x71\xc4\xc4\x25\x10\x1b\x97\ +-\x40\xec\xa8\x04\xe2\xe2\x13\x49\x4a\x49\x27\x34\x3c\xb0\xf2\xbe\ +-\x86\xfa\x3a\x36\xbe\xb2\x86\x63\x1f\xee\xb7\x3a\x14\x45\x09\x78\ +-\xb5\xf5\x8d\xdc\xff\xd8\xcb\x56\x87\x61\x5b\x61\xa1\x6e\xa6\x4d\ +-\xce\x33\xbe\x23\xc9\x9a\xc9\xc9\x62\xc8\xa5\x17\x87\xb5\x89\x4f\ +-\x48\xf9\x88\x14\x22\x68\x12\x80\xc4\x28\x38\x69\x70\x95\x4b\x87\ +-\xc3\x49\x5a\x46\x0e\x69\x19\x67\x57\x8f\xea\xe9\xea\xa4\xa1\xe1\ +-\x24\x8d\xa7\x4e\xd2\xda\xd4\x48\x47\x47\x1b\x9d\x1d\xed\x74\x75\ +-\xb4\xd3\xd9\xd1\x4e\x67\x67\x3b\x1d\xed\x7d\xc1\xf9\xbc\xbd\xfd\ +-\x4e\x6d\xbb\x5c\x6e\x1c\x4e\x27\xa1\xa1\x61\x38\x5c\x2e\x9c\x4e\ +-\x17\x61\xe1\x11\x84\x47\x46\x11\x11\xe9\x21\x32\xd2\x43\x44\x44\ +-\x14\x11\x9e\x68\x22\x3d\x31\x44\xc7\xc4\x99\x32\x85\x65\xa4\xde\ +-\x9e\x1e\xb6\xbe\xb9\x8e\x9d\x5b\x36\xe2\xf3\xa9\xab\x9d\x15\x65\ +-\xb8\xa4\x94\xfc\xf2\xbe\x27\xd4\xc6\xbf\xf3\x98\x3e\x65\x3c\x21\ +-\x6e\x97\xe1\xfd\x08\xa1\x3f\x32\x9c\xf7\x0f\x2b\x01\xf8\x30\xcd\ +-\xf1\xca\xd8\x6a\xbd\x12\xb0\xae\x62\x8b\x89\x72\x62\x25\x65\x8d\ +-\x82\x36\x0b\x3e\xf7\xee\xd0\x30\x92\x53\x33\x49\x4e\xcd\x1c\xf4\ +-\x7b\xa5\xd4\x6d\xb3\xe3\xde\x4c\x07\xf7\xee\x61\xd3\xab\xcf\xd0\ +-\xda\xdc\x64\x75\x28\x8a\x32\x62\x3c\xf5\xf2\x5b\x6c\xdb\x7d\xc0\ +-\xea\x30\x6c\x6d\xe1\xcc\x22\x33\xba\xa9\xfc\x30\xd5\xb9\x61\x38\ +-\x0d\x0c\x6b\x54\xb8\x46\x08\x1f\xf0\xe8\x70\xda\x08\x24\x4e\x0d\ +-\x66\x66\xe9\x84\x1b\x9f\xd8\xf9\x55\xb0\x0d\xfe\xed\xad\x2d\x3c\ +-\xf1\x97\xdf\xf1\xfc\x13\x0f\xa9\xc1\x5f\x51\xfc\xe8\x68\x79\x0d\ +-\x7f\x78\x64\xc8\x4b\xce\x41\x21\x2c\x2c\x84\x59\x25\x05\xc6\x77\ +-\x24\x78\xe8\xa3\x31\x78\xc8\x86\x3d\x32\x68\x52\x7b\x90\xbe\x53\ +-\x72\x41\x21\xdc\x05\xb3\xb2\x75\xdc\x41\x59\x08\x39\x30\xd4\xd7\ +-\xd5\x50\x7e\xf4\x90\xd5\x61\x28\xca\x88\xd2\xe3\xf5\xf2\x5f\xbf\ +-\x79\x94\x9e\x5e\x75\x72\xe6\x7c\x2e\x99\x51\x68\xc6\xf4\xbf\xd4\ +-\xbd\xda\x5f\x86\xdb\xc8\xb0\x13\x80\x29\xe9\xe2\x10\xc8\x77\x86\ +-\xdb\x4e\x20\x89\x70\xc3\xf4\x4c\x1d\xfb\x1d\x70\x53\x14\x45\x31\ +-\xc6\x6f\x1e\x78\x86\xc3\x65\x55\x56\x87\x61\x7b\x8b\x66\x15\x1b\ +-\xdf\x89\x90\x6f\x94\x64\x8a\x23\xc3\x6d\xc6\x5f\x73\xc3\x0f\xfa\ +-\xa9\x9d\x80\x11\x1f\x0e\xf1\x11\x41\x33\xf1\xa1\x28\x4a\x10\x7b\ +-\xee\xf5\xad\x3c\xfb\xda\x16\xab\xc3\xb0\xbd\x51\x31\x1e\x4a\x0a\ +-\x4d\xd8\xfd\xaf\xf3\x90\x3f\x9a\xf1\x4b\x02\x10\xe2\x72\x3c\x0e\ +-\x04\xdd\x4d\x10\x21\x41\x55\x08\x59\x51\x94\x60\xb4\xf7\xc3\xe3\ +-\xdc\x7d\xff\x90\x2a\xcd\x06\x9d\xa5\x0b\xa6\xe3\x70\x18\xbe\xe7\ +-\xaa\x49\xd7\x1c\x43\xaa\xfd\xff\x49\x7e\x89\xb4\x20\x51\xb4\x49\ +-\xf8\x9b\x3f\xda\x0a\x14\xbd\x3a\x7e\xaf\x09\xa0\x28\x8a\x62\x27\ +-\xf5\x8d\xcd\x7c\xff\x17\x0f\xd1\xe3\x55\x47\x68\x2f\x44\x08\xc1\ +-\xd2\xf9\xd3\x0d\xef\x47\x4a\xfe\x52\x92\x2a\x3a\xfc\xd1\x96\xdf\ +-\x52\x15\xa1\x69\xbf\x23\x48\x36\x03\x4a\x09\x7b\xaa\x04\xdd\xea\ +-\x77\x42\x51\x94\x11\xaa\xa3\xa3\x8b\xef\xfe\xcf\x9f\xd5\x35\xbf\ +-\x03\x34\x25\x7f\x34\x19\x29\x09\x86\xf7\xe3\x70\x68\x7f\xf6\x57\ +-\x5b\x7e\x4b\x00\x8a\x53\xc4\x3e\x81\x7c\xdb\x5f\xed\xd9\x95\x94\ +-\x50\x5a\x2d\xa8\x6a\x51\x4f\xff\x8a\xa2\x8c\x4c\x3d\x5e\x2f\xdf\ +-\xfb\xe5\x83\x7c\x78\x5c\x6d\xfa\x1b\xa8\xcf\x2c\xbc\xd8\xf8\x4e\ +-\x84\xdc\x34\x25\x45\xf8\xed\xf6\x32\xff\x2e\x56\x08\xfe\xe8\xd7\ +-\xf6\x6c\xc6\x27\x61\x5b\x85\xa0\xa2\x49\x0d\xfe\x8a\xa2\x8c\x4c\ +-\x52\x4a\x7e\xf1\x87\xc7\x29\xfd\xe0\x43\xab\x43\x09\x18\xb1\xd1\ +-\x51\x5c\x72\x71\xa1\xe1\xfd\x48\xe9\xdf\x31\xd6\xaf\x09\x40\x64\ +-\xbb\xe3\x29\xe0\xa4\x3f\xdb\xb4\x0b\x9f\x0e\xdb\xca\x05\x27\x5a\ +-\xd5\xe0\xaf\x28\xca\xc8\x24\xa5\xe4\x57\x7f\x7a\x8a\x57\xdf\xd8\ +-\x69\x75\x28\x01\x65\xc5\xe5\x33\x71\xbb\x0c\x3f\xfb\x5f\x1b\xda\ +-\xe4\x78\xc6\x9f\x0d\xfa\x35\x01\xc8\xcd\x15\xdd\x23\x71\x16\xc0\ +-\x27\x61\x4b\x99\x46\x5d\x9b\x1a\xfc\x15\x25\x18\x95\x35\x8e\xfc\ +-\x0d\x4e\x52\x4a\xee\xba\xff\x69\x75\xdc\x6f\x90\x5c\x4e\x07\xcb\ +-\x2f\x9d\x69\x78\x3f\x02\xfe\x50\x50\x20\x7a\xfc\xd9\xa6\xdf\xcf\ +-\x2b\xe8\x3d\xda\x1f\x00\xbf\x06\x69\xb5\xbd\x27\x04\xa7\xfc\xb2\ +-\xe7\x52\x51\x94\x40\x54\xd5\x22\xd8\x59\x29\xd0\x47\x68\x16\x70\ +-\xfa\xc9\x7f\xcd\xab\x23\x7e\x1b\x97\xdf\x2d\x98\x55\x44\x5c\xac\ +-\xc7\xe8\x6e\xba\x7b\x5d\xda\x7d\xfe\x6e\xd4\xef\x09\x40\x49\xb6\ +-\xa8\x11\x92\x27\xfc\xdd\xae\x55\x7a\x7d\x50\xd6\xa8\x9e\xfc\x15\ +-\x25\xd8\x55\x35\x0b\x36\x1f\xd7\x46\xdc\xe9\x1f\x9f\x4f\xe7\x67\ +-\xbf\x7f\x4c\x3d\xf9\x0f\x81\x10\x82\xeb\xae\x9c\x6f\x7c\x3f\xf0\ +-\xf7\xe9\x89\xe2\x84\xbf\xdb\x35\xa4\x62\x81\x4f\xd3\xee\x32\xa2\ +-\x5d\x2b\x74\x7b\xfb\x96\x00\x14\x45\x51\x1a\x3a\x60\xe3\x11\x8d\ +-\xda\x11\xb2\x17\xa8\xab\xbb\x87\x7f\xff\xe5\x03\xbc\xb4\x71\xbb\ +-\xd5\xa1\x04\xa4\x99\x53\xf3\x19\x93\x95\x6a\x7c\x47\x52\xbb\xc7\ +-\x88\x66\x0d\x49\x00\x4a\x52\x45\xa9\x40\x6e\x36\xa2\x6d\xb3\x85\ +-\x3a\x51\x35\xff\x15\x45\xf9\x58\x97\x17\xb6\x96\x0b\xde\xad\x11\ +-\xf4\xea\x56\x47\x33\x74\xad\xed\x1d\xdc\xf9\x93\xfb\xd8\xb2\x6b\ +-\x9f\xd5\xa1\x04\xac\xeb\x97\x2f\x30\xa1\x17\xb1\xa1\x28\x5d\xec\ +-\x31\xa2\x65\xc3\x6a\x16\xea\x82\x11\x31\x0b\xe0\x74\x40\x74\x98\ +-\xd5\x51\x28\x8a\x62\x27\x12\x38\xd6\x20\x78\xed\x90\xc6\xa1\xfa\ +-\xc0\x2b\x0a\x76\xbc\xe2\x04\x5f\xf9\xde\xdd\xbc\x77\xe0\xa8\xd5\ +-\xa1\x04\xac\xa2\x82\xb1\x14\x8e\x1f\x6d\x78\x3f\x12\xfd\x6e\xa3\ +-\xda\x36\xac\x9a\x7d\x71\x8a\x63\xed\xee\x6a\x7d\x1f\x90\x6f\x54\ +-\x1f\x66\x49\x8e\x92\x34\x75\xaa\x79\x00\x45\x51\xce\xd6\xe3\x83\ +-\x7d\xb5\x82\xfd\x75\x82\xa8\x10\x88\x09\x91\xb8\x9d\x7d\x0f\x0e\ +-\x0e\x01\x2e\x0d\x22\x42\x20\x36\x4c\xe2\x34\xbc\x44\xfc\xc0\xbc\ +-\xb9\xfd\x03\x7e\xf2\xdb\xbf\xd1\xd9\xd9\x6d\x75\x28\x01\xed\xc6\ +-\xcf\x5e\x66\x46\x37\xfb\x8b\x53\x1d\x2f\x1a\xd5\xb8\x61\x09\x80\ +-\x10\x42\x2f\xad\xf2\xfe\x1a\xc4\xfd\x46\xf5\x61\x96\x54\x8f\xe4\ +-\x40\x9d\x4a\x00\x14\x45\xe9\x9f\x94\xd0\xd2\x05\x2d\x5d\xfd\x7f\ +-\x4f\x84\x3a\x05\x33\x32\x75\x62\x2d\x9c\x4d\xd4\x75\xc9\xc3\x4f\ +-\xbd\xca\x43\x4f\xae\x43\x4a\xb5\xb1\x69\x38\xa6\x4e\xca\xa5\x78\ +-\x62\xae\xf1\x1d\x49\xf9\x73\x21\x84\x61\x0b\x4d\x86\xe6\xa4\x7a\ +-\x8d\xe3\xaf\x40\x85\x91\x7d\x98\xc1\x13\x02\xd1\xa1\x56\x47\xa1\ +-\x28\x4a\xa0\xea\xdb\x37\xa0\xd1\x65\xd1\x52\x41\x43\x53\x2b\xff\ +-\xf2\xd3\xfb\x78\xf0\x89\x57\xd5\xe0\xef\x07\xb7\x5c\xbb\xd4\x8c\ +-\x6e\x2a\x43\x9a\x1d\x8f\x19\xd9\x81\xa1\x09\x40\x49\x89\xe8\x15\ +-\x60\xc8\xee\x45\xb3\x65\xc4\xa8\x5f\x1a\x45\x51\x86\xae\xdb\x0b\ +-\x1f\x9c\x30\x7f\x26\x71\xfb\xbb\x07\xf9\xf2\x77\x7f\xc5\xf6\x3d\ +-\x07\x4d\xef\x7b\x24\x9a\x55\x52\xc0\xc4\xbc\x6c\xc3\xfb\x11\x82\ +-\x5f\xf9\xbb\xf0\xcf\x27\x19\xbe\x2a\xd5\xee\xd6\xee\x03\x1a\x8d\ +-\xee\xc7\x68\x69\x1e\xa9\x4e\x03\x28\x8a\x32\x2c\x55\x2d\x82\x96\ +-\x2e\x73\xfa\xea\xe8\xe8\xe2\x57\x7f\x7a\x92\xef\xfc\xf7\x7d\x34\ +-\x34\xaa\x1b\xfd\xfc\x41\xd3\x34\x6e\xbd\xee\x0a\x33\xba\x6a\x70\ +-\x3b\xb5\x07\x8c\xee\xc4\xf0\x04\x60\x76\x82\x68\x05\x7e\x6b\x74\ +-\x3f\x46\x0b\x73\x41\x8c\x3a\x0d\xa0\x28\xca\x30\x48\x09\x47\x1b\ +-\x8c\x7f\x94\xd8\xb6\xfb\x00\x5f\xb8\xf3\x97\xac\x5d\xb7\x45\x4d\ +-\xf9\xfb\xd1\x55\x97\x5e\xcc\xe8\xcc\x14\xe3\x3b\x92\xdc\x5d\x90\ +-\x28\xda\x8c\xee\xc6\xb0\x4d\x80\x67\xd2\xbb\xb4\x5f\x6b\xa1\xfa\ +-\xb7\x80\x18\x33\xfa\x33\x4a\x5a\xb4\xa4\x51\x9d\x06\x50\x14\x65\ +-\x18\x2a\x9b\x05\x05\x49\x12\x97\xc3\xff\x6d\x9f\x6a\x6a\xe1\x77\ +-\x7f\x7d\x8e\x75\x6f\xee\xf2\x7f\xe3\x41\x2e\x22\x3c\x8c\x9b\xae\ +-\xb9\xdc\xf8\x8e\x04\xcd\xa2\x47\x33\xe5\xa1\xd9\x94\x83\x29\x25\ +-\x63\x44\x33\x82\x7b\xcd\xe8\xcb\x48\xd9\xb1\x12\x8f\xda\x0c\xa8\ +-\x28\xca\x30\x78\x75\xfc\x7e\xb1\x58\xaf\xd7\xc7\xdf\x9f\xdd\xc0\ +-\xb5\xdf\xfa\x99\x1a\xfc\x0d\xf2\xa5\x55\x8b\x88\x8d\x8e\x32\xbe\ +-\x23\xc9\xaf\x8b\x72\x44\x93\xf1\x1d\x99\x34\x03\x00\x20\xba\xb5\ +-\xff\x93\x6e\xfd\x36\x02\x78\x16\xc0\xa9\xc1\x9c\x1c\x9d\x3d\x55\ +-\x82\xaa\x16\x35\x13\xa0\x28\xca\xd0\xd4\xb6\x41\x5a\xf4\xf0\xdb\ +-\x91\x52\xb2\x79\xe7\x5e\xfe\xf0\xc8\xf3\x94\x57\xd7\x0d\xbf\x41\ +-\xa5\x5f\x59\xe9\x49\x7c\xf6\x8a\x79\xc6\x77\x24\x68\x16\xdd\xc6\ +-\x94\xfd\xed\x8f\x69\x09\x40\x51\x8e\x68\xda\x55\xe9\xfb\xbd\x10\ +-\x7c\xdf\xac\x3e\x8d\xe0\xd2\xa0\x24\x43\x92\xd0\x00\xfb\xea\x04\ +-\x3d\x3e\xab\x23\x52\x14\x25\xd0\xd4\xb5\x09\x24\xc3\xdb\x58\xfc\ +-\xde\xfe\xa3\xdc\xf7\xf7\x97\x78\x77\xff\x11\xbf\xc5\xa5\x7c\x9a\ +-\x10\x82\xef\xac\x5e\x85\xcb\x69\xc0\x9a\xcd\x27\xfb\x92\xdc\x65\ +-\xd6\xd3\x3f\x98\x98\x00\x00\x78\xd1\x7e\xed\x42\xbf\x0d\x30\xfc\ +-\xee\x44\x23\x09\x20\x3b\x4e\x92\xe2\x91\xec\xa9\x11\xd4\xa8\xd9\ +-\x00\x45\x51\x06\xa1\xcb\xdb\x57\x38\x68\x28\xf5\x45\xb6\xbf\x7b\ +-\x90\x47\xd6\xbc\xce\xee\xbd\x87\xfd\x1f\x98\xf2\x29\x8b\xe7\x95\ +-\x98\x53\xf4\x07\x1a\xe9\xd1\x7e\x63\x46\x47\xa7\x99\x9a\x00\xcc\ +-\x48\x17\xa7\x76\x57\xf9\x7e\x2d\xe1\xc7\x66\xf6\x6b\x94\x10\x27\ +-\x4c\xcf\x90\x7c\x58\xdf\x57\x0e\x54\x51\x14\x65\xa0\xea\xdb\x05\ +-\xd1\xa1\x03\xdb\xa1\xaf\xeb\x3a\x1b\xde\x79\x97\xbf\xaf\xdd\xc0\ +-\xa1\x63\x95\x06\x47\xa6\x9c\xe6\x89\x8a\xe0\x1b\x5f\xbc\xd2\x94\ +-\xbe\x84\xe0\x7f\xcd\x7c\xfa\x07\x93\x13\x00\x00\xb7\x4b\xfb\xbf\ +-\xee\x5e\xfd\x6b\x40\x92\xd9\x7d\x1b\x41\x00\x79\xf1\x92\xce\x1e\ +-\x38\xd6\xa8\x92\x00\x45\x51\x06\xa6\x75\x00\x25\x5e\x1a\x1a\x5b\ +-\x78\xf9\x8d\x1d\xac\x5d\xb7\x85\x9a\xba\x06\xe3\x83\x52\xce\x72\ +-\xe7\xea\x55\xc4\x78\x22\xcd\xe8\xaa\xae\xdd\xa5\x99\xbe\x51\xde\ +-\xf4\x04\xa0\x20\x51\xb4\xed\xaa\xf6\xfd\x5c\xc8\x91\x71\x5b\xe0\ +-\x69\x13\x53\x24\x4d\x5d\x82\xc6\x4e\xab\x23\x51\x14\x25\x10\xb4\ +-\x75\x0b\xfa\xee\x15\x3c\x9b\xd7\xe7\x63\xdb\xee\x03\xbc\xbc\x69\ +-\x3b\x9b\x77\xec\xc5\xeb\x53\x1b\x8d\xac\x30\x77\xc6\x24\x16\xcd\ +-\x2a\x32\xa5\x2f\x09\xff\xf5\x51\xcd\x1c\x53\x99\x9e\x00\x00\x84\ +-\x36\x6a\xbf\xef\x8e\xd1\xbf\x05\xe4\x58\xd1\xbf\x11\x1c\x02\x8a\ +-\xd3\x74\x36\x1e\xd1\xd0\x55\xdd\x0d\x45\x51\x2e\xa0\xf5\x8c\xcb\ +-\xf8\x74\x5d\xe7\xbd\x03\xc7\xd8\xb0\x65\x0f\xeb\xb7\xec\xa6\xb9\ +-\xa5\xdd\xba\xc0\x14\xa2\x3d\x11\xfc\xcb\x2d\x9f\x35\xab\xbb\xe3\ +-\x9e\x0e\xcd\x92\x4b\xf3\x2c\x49\x00\x0a\x0a\x44\x4f\x69\x95\xf7\ +-\xbf\x41\x18\x5e\xea\xd0\x4c\x51\x21\x30\x3e\x51\xaa\xfd\x00\x8a\ +-\xa2\x5c\x50\x6b\x7b\x27\x6f\x6c\x3d\xc8\xe6\x9d\x1f\xb0\xa5\x74\ +-\x9f\x1a\xf4\x6d\xe4\x3b\xb7\x7c\x96\xb8\x18\x13\xce\xfc\x03\x48\ +-\xf9\xa3\xdc\x5c\x61\xc9\xdd\xcc\x96\x24\x00\x00\x87\x53\x1d\x7f\ +-\x19\x5b\xad\x7f\x1b\x28\xb4\x2a\x06\x23\x8c\x8d\x97\x54\x36\x9b\ +-\x57\xef\x5b\x51\x94\xc0\xd0\xd9\xd1\x46\x4d\x65\x19\x95\x65\x47\ +-\x29\x3f\x76\x88\xda\xea\x4a\xa4\x34\xec\xa6\x57\x65\x88\x96\x2d\ +-\x9c\xc1\x82\x8b\x27\x9b\xd5\xdd\x9e\xc3\x69\x8e\x47\xcd\xea\xec\ +-\x93\x2c\x4b\x00\xae\x11\xc2\xb7\xa7\xb2\xf7\x76\x5d\x68\x1b\xac\ +-\x8a\xc1\x08\x1a\x30\x25\x45\xe7\xad\x63\x5a\x3f\xab\x7b\x8a\xa2\ +-\x8c\x74\x5e\x6f\x2f\x2d\x4d\x0d\xd4\xd7\x9d\xe0\x54\x5d\x0d\xf5\ +-\x75\x35\x9c\xa8\xae\xa0\xb9\xf1\x94\xd5\xa1\x29\x17\x90\x99\x9a\ +-\xc8\xb7\x6f\x5c\x69\x5e\x87\x9a\x76\xfb\x35\x42\x58\xb6\xc9\xc3\ +-\xb2\x04\x00\x60\x4a\xba\x6b\xe3\xae\x2a\x7d\xad\x40\x2e\xb7\x32\ +-\x0e\x7f\x8b\x0b\x87\xcc\x18\x49\x59\x93\x5a\x0a\x50\x94\x91\xe0\ +-\x83\x3d\xdb\xa9\xad\xa9\x38\xeb\x67\x5e\x6f\x2f\x3d\xdd\xdd\x74\ +-\x76\x76\xd0\xdd\xd9\x4e\x7b\x5b\x2b\x2d\x4d\x8d\xb4\xb7\xa9\x9b\ +-\xf7\x02\x91\xdb\xe9\xe4\xc7\xb7\x7f\x81\xb0\x50\xb7\x29\xfd\x09\ +-\x78\xa2\x28\x45\xbc\x61\x4a\x67\xe7\x60\x69\x02\x00\xa0\x3b\xc5\ +-\x77\x1c\x5e\xb9\x04\x08\xb1\x3a\x16\x7f\xca\x4f\x92\xd4\xb4\xaa\ +-\x4a\x81\x8a\x32\x12\xec\x7f\x6f\x27\xfb\xad\x0e\x42\x31\xd4\xb7\ +-\x6e\x5a\x41\xde\xe8\x74\xb3\xba\xeb\x42\xd3\xfe\xcd\xac\xce\xce\ +-\xc5\x94\xcb\x80\xce\x67\x5a\x92\x38\x2a\xc0\xd4\xea\x47\x66\x08\ +-\x71\x42\x7e\xa2\x5a\x04\x50\x14\x45\xb1\xbb\x4b\xe7\x14\xb3\xfc\ +-\xb2\x99\xe6\x75\x28\xf8\x55\x51\x8a\x38\x6e\x5e\x87\xfd\xb3\x3c\ +-\x01\x00\x68\x77\x6b\xff\x8d\xa0\xc6\xea\x38\xfc\x2d\x2b\x56\x12\ +-\x1b\x66\x75\x14\x8a\xa2\x28\xca\xb9\x8c\xce\x4c\xe5\xdf\xbe\xfa\ +-\x39\x33\xbb\xac\x0a\x71\x6a\xbf\x30\xb3\xc3\x73\xb1\x45\x02\x30\ +-\x3b\x41\xb4\x22\xe5\x7f\x58\x1d\x87\xbf\x09\x01\x93\x53\x74\x84\ +-\xda\x0a\xa0\x28\x8a\x62\x3b\x31\x9e\x48\x7e\xf6\x6f\x37\x12\x1a\ +-\x62\xce\xba\x3f\x80\x14\xf2\x7b\x05\x89\xa2\xcd\xb4\x0e\xcf\xc3\ +-\x16\x09\x00\x40\x51\xaa\xe3\x21\xa4\xdc\x61\x75\x1c\xfe\x16\x13\ +-\xd6\x37\x13\xa0\x28\x8a\xa2\xd8\x87\xdb\xe5\xe2\x67\xff\x76\x13\ +-\x69\x49\xf1\xa6\xf5\x29\x84\xdc\x56\x9c\x62\xdd\xb1\xbf\x4f\xb2\ +-\x4d\x02\x20\x84\xd0\x85\x70\xdc\x4e\x7f\xb5\x31\x03\x5c\x7e\xa2\ +-\xc4\x6d\xfc\x4d\x92\x8a\xa2\x28\xca\x00\x08\x21\xf8\xf7\xaf\x7f\ +-\x9e\x49\xe3\x4c\x2d\x46\x2b\x7d\x38\xfe\x45\x08\x61\x9b\x31\xce\ +-\x36\x09\x00\x40\x51\x9a\xd8\x22\xe0\x49\xab\xe3\xf0\x37\xb7\x03\ +-\x26\x24\xd9\xe6\xdf\x5c\x51\x14\x25\xa8\x7d\xed\xfa\x65\x5c\x3a\ +-\xa7\xd8\xdc\x4e\x25\x7f\x2b\x49\x15\x9b\xcd\xed\xf4\xfc\x6c\x95\ +-\x00\x00\x48\xa1\xfd\x2b\x30\xe2\xae\xd4\xc9\x8e\x91\x78\x46\xd4\ +-\x41\x47\x45\x51\x94\xc0\xb3\x6c\xe1\x0c\xae\x5b\xbe\xc0\xec\x6e\ +-\xdb\x34\xa9\xfd\xbb\xd9\x9d\x5e\x88\xed\x12\x80\xe2\x54\x51\x06\ +-\xfc\xa7\xd5\x71\xf8\x9b\x10\x50\xa0\x66\x01\x14\x45\x51\x2c\x33\ +-\xa3\x68\x3c\xdf\xfd\xca\x35\xa6\xf7\x2b\x05\xff\x31\x25\x43\x54\ +-\x99\xde\xf1\x05\xd8\x2e\x01\x00\x68\x4e\xd5\xfe\x0f\xd8\x65\x75\ +-\x1c\xfe\x96\x14\x25\x89\x0b\xb7\x3a\x0a\x45\x51\x94\xe0\x33\x6e\ +-\x4c\x06\x3f\xb9\xf3\xcb\x38\x1c\x26\x0f\x7b\x52\xee\x38\x92\xa2\ +-\xfd\xd6\xdc\x4e\x07\xc6\x96\x09\xc0\x7c\x21\xbc\x48\xed\x66\x04\ +-\xbd\x56\xc7\xe2\x6f\x93\x92\x75\xd4\xa9\x40\x45\x51\x14\xf3\xe4\ +-\x66\xa7\x71\xd7\x0f\x6f\x25\x3c\xcc\xf4\x75\x58\xaf\x26\x1c\xb7\ +-\x5a\x59\xef\xff\x7c\x6c\x99\x00\x00\x14\xa7\x8b\x77\x85\xe4\x2e\ +-\xab\xe3\xf0\xb7\xd8\xb0\xbe\x99\x00\x45\x51\x14\xc5\x78\x63\xb3\ +-\xd2\xf8\xcd\x8f\xbe\x86\x27\x2a\xc2\xfc\xce\x05\x3f\x9f\x92\x26\ +-\x76\x9b\xdf\xf1\xc0\xd8\x36\x01\x00\xe8\xd4\xb5\x1f\x03\x87\xad\ +-\x8e\xc3\xdf\xf2\x13\xa5\x2a\x0e\xa4\x28\x8a\x62\xb0\x31\x59\xa9\ +-\xd6\x0d\xfe\x70\xa8\xb9\x5b\xfb\x1f\x2b\x3a\x1e\x28\x5b\x27\x00\ +-\x33\x33\x44\xa7\xd0\xf5\x5b\x18\x61\xb5\x01\x3c\xa1\x90\xe1\x19\ +-\x51\xff\x97\x14\x45\x51\x6c\x25\x33\x2d\x89\xbb\x7e\x78\x2b\xd1\ +-\x1e\x4b\x06\x7f\x29\xa5\xfe\xb5\xf9\x39\xa2\xcb\x8a\xce\x07\xca\ +-\xd6\x09\x00\x40\x51\x86\x6b\x13\xf0\x90\xd5\x71\xf8\xdb\xf8\x44\ +-\x89\x43\xcd\x02\x28\x8a\xa2\xf8\x5d\x66\x5a\x12\xf7\xfe\xf8\xeb\ +-\xc4\xc5\x7a\xac\x09\x40\x70\xdf\xd4\x74\xd7\x06\x6b\x3a\x1f\x38\ +-\xdb\x27\x00\x00\x7a\x97\x76\x27\x60\xbb\x23\x14\xc3\x11\xee\x86\ +-\xec\x38\x35\x0b\xa0\x28\x8a\xe2\x4f\x79\x39\xe9\xdc\xfb\x9f\xdf\ +-\xb0\x72\xf0\xaf\x11\xdd\xf6\x3b\xf3\xdf\x9f\x80\x48\x00\x4a\xc6\ +-\x88\x66\x21\xe5\x1d\x56\xc7\xe1\x6f\x79\xf1\x12\xa7\x2a\x11\xac\ +-\x28\x8a\xe2\x17\x25\x85\x79\x7d\x83\x7f\x4c\x94\x65\x31\x48\xe4\ +-\x37\x8a\x72\x44\x93\x65\x01\x0c\x42\x40\x24\x00\x00\x45\xe9\xce\ +-\x27\x25\x62\xad\xd5\x71\xf8\x53\x88\x13\xc6\x8e\x52\xb3\x00\x8a\ +-\xa2\x28\xc3\xb5\xe4\x92\x69\xfc\xea\x07\x5f\x21\x3c\x3c\xd4\xba\ +-\x20\x84\x78\x6a\x6a\xaa\xf3\x19\xeb\x02\x18\x9c\x80\x49\x00\x00\ +-\x64\xaf\xf8\x3a\x50\x6f\x75\x1c\xfe\x94\x1b\x2f\x89\x30\xef\x26\ +-\x4a\x45\x51\x94\x11\xe7\xfa\xe5\x0b\xf9\xfe\x37\xae\xc5\xe9\xb0\ +-\x74\x4a\xb5\xce\xe5\x10\xb7\x59\x19\xc0\x60\x05\x54\x02\x50\x92\ +-\x2d\x6a\x04\x72\xb5\xd5\x71\xf8\x93\x43\xc0\xc4\x64\x35\x0b\xa0\ +-\x28\x8a\x32\x58\x9a\xa6\xf1\xdd\xaf\x7c\x96\xaf\xdd\xb0\x0c\x61\ +-\xed\xd9\x6a\x29\x91\xab\x27\x25\x89\x5a\x2b\x83\x18\xac\x80\x4a\ +-\x00\x00\x8a\xd2\x9c\xcf\x0a\xc9\x9f\xac\x8e\xc3\x9f\x52\xa2\x24\ +-\x49\x91\x2a\x09\x50\x14\x45\x19\xa8\xb0\xb0\x10\xfe\xf7\xdf\x6f\ +-\xe1\xaa\xcb\x66\x5a\x1d\x0a\x02\x7e\x3f\x35\xcd\xf9\xbc\xd5\x71\ +-\x0c\x56\xc0\x25\x00\x00\x3e\x4d\xbb\x03\x38\x60\x75\x1c\xfe\x34\ +-\x29\x45\x1d\x0b\x54\x14\x45\x19\x88\xcc\xd4\x44\xfe\xf4\xd3\xdb\ +-\x99\x51\x34\xde\xea\x50\x00\xf6\xfb\xfa\x6e\xb1\x0d\x38\x01\x99\ +-\x00\x94\xa4\x8a\x0e\x5d\x68\xd7\x03\x3d\x56\xc7\xe2\x2f\x91\xee\ +-\xbe\xfd\x00\x8a\xa2\x28\xca\xb9\xcd\x9d\x3e\x91\x3f\xff\xfc\x76\ +-\x72\x32\x92\xad\x0e\x05\xa0\x5b\x48\xed\xba\x92\x54\xd1\x61\x75\ +-\x20\x43\x11\x90\x09\x00\x40\x49\xaa\x28\x45\xf0\x23\xab\xe3\xf0\ +-\xa7\x71\x09\xea\xb6\x40\x45\x51\x94\xfe\x38\x1c\x1a\x5f\xbb\x61\ +-\x19\x3f\xfd\xd7\x9b\x89\x08\x0f\xb3\x3a\x9c\x3e\x92\xef\x17\xa5\ +-\x8b\x3d\x56\x87\x31\x54\x01\x9b\x00\x00\x14\xa5\x68\xbf\x04\x61\ +-\xfb\x6a\x4b\x03\x25\x04\x94\xa4\xe9\xb8\x02\xfa\x5f\x45\x51\x14\ +-\xc5\xbf\xe2\x63\xa3\xf9\xed\x7f\x7e\x83\xeb\x97\x2f\xb4\x3a\x94\ +-\x33\x88\xd7\x8a\xd2\xb4\xbb\xad\x8e\x62\x38\x02\x7a\xa8\x11\x42\ +-\xe8\x9a\x2e\xbe\x08\x34\x58\x1d\x8b\xbf\x84\xbb\x61\x6a\xba\xba\ +-\x2c\x48\x51\x14\x05\xa0\x78\x62\x2e\x0f\xfe\xef\x77\x28\x1c\x3f\ +-\xda\xea\x50\xce\xd4\xe8\x45\xdc\x2c\x84\xd0\xad\x0e\x64\x38\x02\ +-\x3a\x01\x00\x98\x92\x21\xaa\xa4\x90\xb7\x58\x1d\x87\x3f\x25\x47\ +-\x49\x72\x55\x81\x20\x45\x51\x82\x98\xdb\xe5\xe2\x6b\x37\x2c\xe3\ +-\xee\xff\xf7\x55\x4b\x2b\xaa\xe2\xe9\xdb\x00\x00\x1a\x00\x49\x44\ +-\x41\x54\xfb\xf5\x47\x48\x79\xeb\xf4\x34\x51\x61\x75\x1c\xc3\x15\ +-\xf0\x09\x00\xc0\xd4\x54\xe7\x1a\x09\x0f\x5b\x1d\x87\x3f\x4d\x48\ +-\x94\x24\x44\xa8\x24\x40\x51\x94\xe0\x33\x26\x2b\x95\x3f\xfd\xfc\ +-\xdb\x5c\xbf\x7c\x21\x9a\x66\xaf\x61\x4a\x48\xfe\x54\x94\xee\x7c\ +-\xd2\xea\x38\xfc\xc1\x69\x75\x00\xfe\x12\xea\xd2\xbe\xd9\xdd\xab\ +-\x4f\x07\xf2\xad\x8e\xc5\x1f\x84\x80\xe2\x74\xc9\xc6\xc3\x82\x1e\ +-\x9f\xd5\xd1\x28\x81\x2a\x26\x2e\x1e\x4f\x4c\xac\xd5\x61\x28\xca\ +-\x80\x38\x1d\x0e\xbe\xb8\xea\x52\xbe\xb4\xea\x52\x1c\x0e\x7b\x0d\ +-\xfc\x00\x08\xde\xd7\x1c\xda\x9d\x56\x87\xe1\x2f\x23\x26\x01\x28\ +-\x48\x14\x6d\x7b\x2a\xe5\x0a\x5d\xd3\xb7\x23\x89\xb6\x3a\x1e\x7f\ +-\x08\x73\xc2\xe4\x54\xc9\x8e\x0a\xb5\x21\x40\x19\x1c\xa7\xcb\xc5\ +-\xf4\xd9\x0b\x99\x3e\x7b\x11\x4e\xa7\xcb\xea\x70\x14\xe5\x82\xb2\ +-\x33\x92\xf9\xe1\x6d\xd7\x32\x7e\x4c\xa6\xd5\xa1\x9c\x4b\x93\xf4\ +-\x69\x2b\x27\xa7\x8a\x76\xab\x03\xf1\x97\x11\x93\x00\x00\x4c\x49\ +-\x17\x87\x4a\xab\xbc\x5f\xa4\xef\xd2\xa0\x11\x31\x6a\xa6\x79\x24\ +-\x47\x23\x04\xa7\x46\xcc\x47\x4e\x31\x5a\xee\x84\x42\xe6\x2f\x5e\ +-\x81\x27\x26\xce\xea\x50\x14\xe5\x82\xdc\x4e\x27\x9f\xbf\x6a\x3e\ +-\x5f\xbe\xfa\x52\xdc\x2e\xdb\x26\xab\x52\x0a\x79\xd3\xd4\x0c\x71\ +-\xd8\xea\x40\xfc\x69\x44\x25\x00\x00\xc5\x69\xce\xe7\x4a\x2b\x7d\ +-\x3f\x47\x10\x10\xf7\x31\x0f\xc4\xc4\x24\x9d\x37\x8f\x6a\xa8\x1d\ +-\x01\xca\xf9\xc4\xc6\xc5\x33\x7f\xe9\x2a\x46\xe7\x8e\x88\x55\x30\ +-\x25\x08\x14\x17\x8c\xe5\xce\xd5\xab\xc8\xb6\x47\x51\x9f\xf3\xf9\ +-\x49\x20\xdd\xf2\x37\x50\x23\x2e\x01\x00\x28\x4a\xd3\x7e\xb8\xbb\ +-\x5a\x16\x81\x5c\x6c\x75\x2c\xfe\x10\x1b\x06\x31\x61\xd0\xd8\x69\ +-\x75\x24\x8a\x1d\xb9\x5c\x6e\xa6\xcd\x5e\xc0\x8c\x39\x97\xe2\x70\ +-\x8c\xc8\x5f\x69\x65\x84\x89\x8f\x8d\xe6\xab\x37\x2c\x63\xf1\xbc\ +-\x12\xab\x43\x19\x00\xf1\xda\xe1\x54\xf1\x5f\x56\x47\x61\x84\x11\ +-\xf9\x6d\x21\x84\xd0\xf7\x56\xc8\xeb\xbb\x35\xb9\x13\xc8\xb1\x3a\ +-\x1e\x7f\x48\x8a\x92\x34\x76\x8e\x88\x55\x0d\xc5\x8f\xc6\xe4\x15\ +-\xb0\xf0\x8a\xab\xd5\x74\xbf\x12\x10\x1c\x0e\x8d\x95\x97\xcf\xe6\ +-\x96\x6b\x97\x12\x1e\x16\x62\x75\x38\x03\x51\xa6\x0b\x71\xdd\x35\ +-\x42\x8c\xc8\xad\xd8\x23\x32\x01\x00\x28\xc8\x10\x0d\xbb\x2b\xe5\ +-\x4a\x29\xf4\x2d\x80\x4d\xea\x46\x0e\x5d\x6c\xa8\xd5\x11\x28\x76\ +-\x32\x2a\x31\x99\x85\x4b\x56\x91\x39\x3a\xcf\xea\x50\x14\x65\x40\ +-\x2e\x2a\x9e\xc0\x6d\x5f\xb8\x32\x10\xa6\xfb\x4f\xeb\x92\x42\x5b\ +-\x55\x92\x2a\xea\xad\x0e\xc4\x28\x23\x36\x01\x00\x28\x4a\x17\x7b\ +-\x4a\xab\xbd\xb7\x22\xc5\x5f\xad\x8e\x65\xb8\x3c\xa1\x92\x11\xb2\ +-\xaf\x51\x19\x06\x97\xdb\xcd\xb4\x59\x6a\xba\x5f\x09\x1c\xf9\xb9\ +-\x59\x7c\xf5\x86\x65\x14\x17\x8c\xb5\x3a\x94\x41\x91\xc8\xaf\x4f\ +-\x4d\x15\xbb\xac\x8e\xc3\x48\x23\xfe\x1b\xa4\x38\xd5\xf9\x48\x69\ +-\xa5\x6f\x16\x82\x5b\xad\x8e\x65\x38\xc2\x5c\x10\xe1\x86\xf6\x11\ +-\x73\xff\xa1\x32\x58\x63\xf2\x0a\x58\xb8\xec\xb3\x78\xa2\xd5\xb9\ +-\x7e\xc5\xfe\xb2\xd2\x93\xb8\xf9\x73\x4b\x98\x7f\x51\x21\x22\xf0\ +-\x6a\x9b\xdf\x3b\x35\xcd\xf9\x90\xd5\x41\x18\x6d\xc4\x27\x00\x00\ +-\x51\x9d\xda\xb7\xdb\x22\x7c\x53\xa4\x14\x33\xac\x8e\x65\x38\xb2\ +-\x62\x24\xfb\xea\x02\xee\x17\x49\x19\xa6\xd8\x51\x89\x2c\xba\xe2\ +-\x6a\xb2\xc6\x8c\xb3\x3a\x14\x45\xb9\xa0\xa4\xf8\x58\xbe\xb4\xea\ +-\x52\x96\x2d\x9c\x61\xbb\x2a\x7e\x03\x23\xb7\x84\x34\x39\xbe\x63\ +-\x75\x14\x66\x08\x8a\x04\x20\x37\x57\x74\x6f\xaf\x93\xcb\x9d\xbd\ +-\xfa\x56\x20\xcb\xea\x78\x86\x6a\x6c\xbc\xa4\xa2\x59\xd0\xda\x6d\ +-\x75\x24\x8a\x19\xdc\xa1\x61\xcc\x9a\xbf\x84\xa2\xe9\x73\x02\xf4\ +-\x8b\x54\x09\x26\x69\x49\xf1\x5c\x77\xd5\x7c\x96\x2e\x98\x81\xcb\ +-\xe9\xb0\x3a\x9c\xa1\x3a\xe6\x72\x3a\x56\x16\x14\x88\xa0\x98\x6b\ +-\x0d\x8a\x04\x00\x60\x7a\xa2\x38\xb1\xab\x5a\x2e\x11\x52\x7f\x1b\ +-\x08\xc8\x39\x54\x4d\x40\x71\x9a\xce\xdb\xc7\x35\xbc\x01\x7d\x07\ +-\x95\x72\x5e\x42\x90\x5f\x58\xc2\x25\x97\x5d\x45\x78\xa4\xbd\x2e\ +-\x41\x51\x94\x4f\x1a\x93\x95\xca\xb5\x57\xce\xe7\xd2\xd9\xc5\xf6\ +-\x2c\xdf\x3b\x50\x82\x66\x87\xa6\x5d\x39\x29\x49\xd4\x5a\x1d\x8a\ +-\x59\x82\x26\x01\x00\x98\x9a\x2a\xf6\x97\xd6\xc8\x15\xe8\xfa\xab\ +-\x40\x40\x9c\x41\xf9\xa4\xd8\x30\x98\x9e\x21\xd9\x56\x2e\xf0\xa9\ +-\xca\x40\x23\x4e\x62\x72\x1a\x0b\x96\x5e\x4d\x7a\x96\xad\xae\x3e\ +-\x55\x94\x4f\x29\x1c\x3f\x9a\xeb\x97\x2f\x60\xe6\xd4\xfc\x40\x5c\ +-\xe3\x3f\x9b\xa0\x17\x5d\x5f\x35\x39\xd5\xf1\x81\xd5\xa1\x98\x29\ +-\xa8\x12\x00\x80\xe2\x14\xf1\x46\x69\x95\xf7\x46\x10\x8f\x12\xa0\ +-\xdb\xea\x13\x23\x25\xd3\x33\x61\x47\xa5\xc0\x3b\x22\x4f\xa7\x06\ +-\x9f\x90\xd0\x70\xe6\x2c\xba\x82\xc9\x25\x33\x11\x22\x80\x9f\xa2\ +-\x94\x11\xcd\xe1\xd0\x98\x3d\x6d\x22\xd7\x5e\x39\x9f\x89\x79\xd9\ +-\x56\x87\xe3\x2f\x12\x5d\xae\x2e\x4e\x77\xad\xb7\x3a\x10\xb3\x05\ +-\x5d\x02\x00\x50\x9c\xe6\xfc\x47\x69\x95\x6f\x3c\xf0\xff\xac\x8e\ +-\x65\xa8\x92\x22\x25\x73\x73\x24\xef\x94\x69\x74\xf6\x5a\x1d\x8d\ +-\x32\x64\xa7\xa7\xfb\x2f\xbf\x8a\xf0\x08\x35\xdd\xaf\xd8\x53\x5c\ +-\xac\x87\x25\xf3\xa6\xb1\xe2\xf2\x99\x24\x27\x8c\xb0\xa2\x53\x92\ +-\x1f\x15\xa7\x3b\x03\xfe\xa8\xf8\x50\x04\x65\x02\x00\x50\x94\xaa\ +-\xfd\x78\x77\x8d\x9e\x8d\xe4\x8b\x56\xc7\x32\x54\x9e\x10\x98\x37\ +-\x5a\xa7\xb4\x4a\x50\xd7\x16\x90\x93\x19\x41\x2d\x29\x25\x9d\x85\ +-\x57\x7c\x96\xd4\x8c\x6c\xab\x43\x51\x94\x7e\x8d\x1b\x93\xc1\x67\ +-\x97\xce\x65\xd1\xec\x22\x9c\x8e\x80\xdd\xd8\x77\x3e\xff\x28\x4a\ +-\xd3\xfe\xdb\xea\x20\xac\x12\xb4\x09\x80\x10\x42\xee\xdc\x29\x57\ +-\x6b\x29\x32\x0d\xe4\x42\xab\xe3\x19\xaa\x50\x27\x5c\x9c\x25\x29\ +-\x6b\x80\xf7\x6b\x05\x3e\xb5\x39\xd0\xf6\x42\xc3\x23\x98\xbb\x68\ +-\x19\x93\x8a\x2f\x0e\xfc\xb5\x53\x65\xc4\x89\xf1\x44\x72\xd9\x9c\ +-\x62\xae\xba\x74\x26\x59\xe9\x49\x56\x87\x63\x1c\x29\xdf\x88\xea\ +-\x74\xdc\x28\x84\x08\xda\xdd\x54\x41\x9b\x00\x00\x94\x94\x88\xde\ +-\x9d\x47\xe4\x2a\x11\x22\x37\x0b\xc1\x44\xab\xe3\x19\x2a\x01\x64\ +-\xc7\x49\xe2\x23\x24\xbb\x6b\x34\x75\x75\xb0\x4d\x09\x21\x98\x50\ +-\x58\xc2\xfc\xc5\xcb\x09\x0b\x8f\xb4\x3a\x1c\x45\xf9\x98\xdb\xe9\ +-\xa4\x64\x72\x1e\x8b\x2f\x99\xce\x9c\x69\x13\x03\xf9\x18\xdf\x40\ +-\xed\x73\xfa\x1c\x2b\x72\x73\x45\x50\x1f\xaa\x0e\xea\x04\x00\xa0\ +-\x64\x8c\x68\xde\x5d\x23\x3f\x23\x75\x7d\x2b\x10\xd0\xe9\x6e\x64\ +-\x08\xcc\xce\xd6\x29\x6b\x14\xec\xab\x15\xf4\xa8\x0d\x82\xb6\x91\ +-\x94\x9a\xc1\xa2\x2b\x3e\x4b\x4a\x7a\xc0\x96\xa1\x50\x46\xa0\x71\ +-\x63\x32\xb8\x7c\x6e\x09\x97\xcf\x99\x4a\xb4\x27\xc2\xea\x70\xcc\ +-\x72\x02\xa1\x2d\x2d\xcc\x12\x8d\x56\x07\x62\xb5\xa0\x4f\x00\x00\ +-\x8a\x52\xc4\xf1\x5d\xd5\xf2\x0a\x81\xbe\x1e\x49\xb4\xd5\xf1\x0c\ +-\x87\x00\xb2\x63\x25\xa9\x1e\xc9\xc1\x93\x82\x63\xa7\x04\x6a\x55\ +-\xc0\x3a\xe1\x11\x51\xcc\xbd\xf4\x33\x4c\x9c\x32\x1d\xd4\x74\xbf\ +-\x62\x31\x4d\x13\x4c\x18\x93\xc5\xbc\x19\x93\x98\x3f\x73\x0a\x29\ +-\x89\x23\x6c\x43\xdf\x85\x35\x09\xa9\x2d\x29\x4a\x13\x65\x56\x07\ +-\x62\x07\x2a\x01\xf8\xc8\xd4\x54\xb1\xab\xb4\x52\x2e\x41\xe8\xeb\ +-\x80\x80\x9f\x9f\x75\x3b\x60\x52\xb2\x24\x27\xb6\xaf\x7c\x70\x4d\ +-\x8b\x20\x68\x17\xba\x2c\xf0\xf1\x74\xff\xe5\x2b\x08\x8b\x08\x9a\ +-\x27\x2b\xc5\x86\x34\x4d\x63\x62\x5e\x36\x97\x5c\x3c\x99\xf9\x17\ +-\x4f\x26\x21\x2e\xa0\x9f\x71\x86\xa3\x43\x0a\xed\xca\xe2\x34\xb1\ +-\xc7\xea\x40\xec\x42\x25\x00\x67\x28\x4e\x17\xef\x94\x56\xf6\x2e\ +-\x47\x68\x2f\x00\x23\xe2\x02\xde\xc8\x90\xbe\xc2\x41\x2d\x5d\x7d\ +-\x33\x02\xd5\x2a\x11\x30\x5c\x7a\xd6\x68\x16\x5e\x71\x35\x09\x49\ +-\x69\x56\x87\xa2\x04\xa9\x88\xf0\x30\x4a\x0a\x73\x99\x33\x6d\x12\ +-\xb3\x4a\xf2\x89\x8a\x08\xb7\x3a\x24\xab\x75\x6a\x52\x5f\x36\x25\ +-\xcd\xf1\x96\xd5\x81\xd8\x89\x4a\x00\x3e\xa1\x38\xdd\xb5\x7e\x57\ +-\x75\xef\x72\x21\xb5\x67\x09\xd0\x6a\x81\xfd\xf1\x84\xc2\xb4\x0c\ +-\x49\x43\x87\xe4\xc0\x49\xc1\xc9\x36\x95\x08\xf8\x5b\x44\x94\x87\ +-\x79\x8b\xae\x24\x7f\x72\x89\x9a\xee\x57\x4c\xa5\x69\x82\xdc\x9c\ +-\x74\x4a\x26\xe5\x31\xad\x30\x8f\xc9\xf9\x63\x82\x61\x23\xdf\xc0\ +-\x08\x7a\xa5\x2e\xaf\x99\x92\xee\xda\x68\x75\x28\x76\xa3\x12\x80\ +-\x7e\x4c\x4d\x75\xbd\xba\xab\xda\x7b\x9d\x90\xe2\x71\x46\xd8\x7f\ +-\xa3\xb8\x70\x98\x99\x25\x69\xed\x96\x94\x37\x0a\xaa\x5a\x04\x1d\ +-\xaa\x90\xd0\xb0\x68\x0e\x07\xc5\xd3\xe7\x30\x73\xfe\x12\xdc\x21\ +-\x23\x62\xe2\x48\x09\x00\x29\x89\x71\x14\x15\x8c\x65\xc6\x94\x09\ +-\x4c\x2b\xcc\xc5\x13\xa5\x96\x9a\xfa\xe1\x43\xca\x2f\x4e\x4d\x77\ +-\xbe\x60\x75\x20\x76\x34\xa2\x06\x37\x7f\x9a\x9a\xea\x5c\xb3\xbb\ +-\xd2\xbb\x5a\x0a\xf1\x20\x30\xe2\x6a\xb3\x46\x85\x40\x41\xb2\x24\ +-\x3f\x59\xd2\xd4\x09\x95\xcd\x82\xca\x66\x41\xb7\xd7\xea\xc8\x02\ +-\x4b\x46\xf6\x58\x16\x2e\x5d\x45\x7c\x52\xaa\xd5\xa1\x28\x23\x5c\ +-\x6a\xd2\x28\x26\x8d\xcf\x61\xf2\xf8\xd1\x94\x14\xe6\x91\x9a\x34\ +-\xca\xea\x90\xec\x4e\x0a\x21\xbf\x5a\x94\xea\x7c\xcc\xea\x40\xec\ +-\x4a\x25\x00\xe7\x51\x94\xee\xfc\xcb\xae\x2a\x5f\xa4\x80\x7b\xad\ +-\x8e\xc5\x28\x82\xbe\x0b\x86\x62\xc3\x24\x05\x49\x7d\xb3\x02\x07\ +-\xeb\x85\x2a\x2f\x7c\x01\x91\x9e\x68\x2e\xb9\x7c\x39\xe3\x27\x16\ +-\x5b\x1d\x8a\x32\x02\x85\x87\x87\x32\x3e\x27\x9d\xf1\xb9\x99\x14\ +-\x8e\x1b\x4d\xe1\x84\x1c\x3c\x91\x41\xbf\x8e\x3f\x18\x52\xc0\x6d\ +-\x45\xa9\xce\xfb\xad\x0e\xc4\xce\x54\x02\x70\x01\x53\xd3\x1c\xbf\ +-\xdb\x55\xed\x73\x09\xc9\x5d\x56\xc7\x62\x34\x4d\xf4\x15\x14\xca\ +-\x88\xe9\xdb\x27\x70\xf8\x94\x40\xaa\x8d\x02\x67\xd1\x1c\x0e\xa6\ +-\x94\xcc\x66\xf6\xc2\xa5\x6a\xba\x5f\xf1\x0b\xa7\xc3\xc1\x98\xec\ +-\x54\x0a\xc7\xe5\x30\x6e\x4c\x06\xe3\x46\xa7\x93\x95\x96\x84\xa6\ +-\xa9\x7d\x24\xc3\xf0\xef\x45\x69\x8e\xdf\x5b\x1d\x84\xdd\xa9\x04\ +-\x60\x00\xa6\xa6\x3a\xee\x2e\xad\xf6\x8d\x42\xf2\x43\xab\x63\x31\ +-\x83\x43\x83\x82\xa4\xbe\x5a\x02\xa5\x55\x1a\xad\x41\x5d\x2b\xeb\ +-\x9f\x32\xb2\x73\x59\xb4\xec\x6a\x46\x25\x24\x5b\x1d\x8a\x12\x80\ +-\x1c\x0e\x8d\xa4\xf8\x58\xb2\xd3\x93\xc8\xc9\x48\x21\x27\x23\x99\ +-\x9c\xf4\x24\x72\xb2\x52\x70\x3b\xd5\x57\xb1\xbf\x48\xf8\xcf\xa9\ +-\x69\x8e\x5f\x58\x1d\x47\x20\x50\x9f\xba\x01\x2a\x4e\x75\xfc\x47\ +-\x69\x95\xaf\x0d\xf8\xb9\xd5\xb1\x98\x25\x36\x0c\x2e\x19\xa3\xf3\ +-\x7e\x8d\xe0\x78\x63\xf0\x3e\x8d\x78\xa2\x63\x99\xb7\x78\x39\xe3\ +-\xf2\xa7\x58\x1d\x8a\x12\x00\xa2\x3d\x11\xa4\x27\x25\x90\x9e\x1a\ +-\x4f\x46\x4a\x02\x69\xc9\xf1\x64\xa5\x25\x92\x9d\x91\xac\x06\x7a\ +-\xe3\xfd\x62\x6a\x9a\xe3\xc7\x56\x07\x11\x28\x82\xf7\x5b\x7d\x88\ +-\x76\x55\xf9\xfe\x55\x40\xd0\x65\x97\xe5\x4d\x82\x77\x6b\x02\xe3\ +-\xb2\xa1\xb2\x23\x07\x79\xf2\xaf\xc3\x9f\xfd\x73\x38\x9c\x94\xcc\ +-\x9a\xcf\x45\x73\x2f\xc3\xe5\x72\xfb\x21\xb2\xc0\xa1\xeb\x3a\x4d\ +-\xa7\x4e\x72\xaa\xbe\x96\xc6\xfa\x3a\x4e\xd5\xd7\xd2\x74\xea\x24\ +-\x2d\xcd\x8d\xb4\xb7\xb5\xa0\xeb\x01\xf0\x41\x30\x48\xb4\x27\x82\ +-\xa4\x51\xb1\x24\xc6\x47\x93\x9c\x10\x47\xe2\xa8\x18\x12\xe3\x63\ +-\x49\x4b\x1a\x45\x46\x6a\x02\x91\xe1\x61\x56\x87\x18\x9c\x24\xff\ +-\xaf\x38\xdd\xf1\x13\xab\xc3\x08\x24\x2a\x1d\x1d\xa4\xa9\x69\x8e\ +-\x5f\x96\x56\xfa\x5a\x10\xfc\x8e\x11\x78\x3a\xe0\x5c\x32\x63\x24\ +-\x31\x61\x92\x77\xca\xb4\xa0\xd8\x20\x98\x93\x9b\xcf\x82\x25\x2b\ +-\x89\x1d\x95\x60\x75\x28\x96\xd0\x34\x8d\xb8\x84\x24\xe2\x12\x3e\ +-\x7d\x3d\x86\x94\x92\xf6\xb6\x16\x5a\x9b\x9b\x68\x6b\x6d\xa6\xb5\ +-\xa5\x91\xd6\xe6\x66\xda\xdb\x5a\xe8\xee\xec\xa0\xab\xb3\x83\xce\ +-\xae\x0e\xba\xbb\x3a\xe9\xea\xe8\xc0\xe7\xb3\xf7\xd1\x12\x21\x34\ +-\x42\xc3\xc3\x08\x0d\x0d\x27\x34\x2c\x9c\xf0\xf0\x48\xc2\x23\xa3\ +-\x88\x88\x8c\x26\x35\x3e\x82\x29\xd9\x51\xc4\xc5\xf4\xfd\x2f\x29\ +-\x3e\x96\x10\xb7\xcb\xea\x90\x95\xb3\x49\x21\xb8\xa3\x28\xcd\xf1\ +-\x1b\xab\x03\x09\x34\x2a\x01\x18\x82\xe2\x74\xc7\x1f\x77\x57\x7b\ +-\x5b\xa5\x14\x0f\x13\x44\xff\x0d\x3d\x21\x30\x6f\xb4\xce\x3b\x65\ +-\x1a\xcd\x5d\x56\x47\x63\x8c\xe8\xd8\x51\xcc\x5f\xbc\x82\xb1\xe3\ +-\x27\x59\x1d\x8a\x6d\x09\x21\x88\x8c\x8a\x26\x32\x6a\x60\x25\x65\ +-\x7b\x7b\x7a\xe8\xea\xea\xa0\xbb\xb3\x83\xce\xce\x0e\xba\xba\x3a\ +-\xe9\xed\xee\xc2\xeb\xed\xa5\xa7\xbb\x1b\x5d\xf7\xd1\xd5\xd9\x89\ +-\xae\xfb\xe8\xe9\x3e\xbd\xe1\x44\xd2\xdd\xd5\xf9\x71\x1b\xba\xcf\ +-\x87\x4f\xd7\x71\xb9\xce\x1e\x7c\xdd\xa1\x61\x88\x33\x26\x32\x1d\ +-\x4e\x07\x2e\xd7\x47\xf5\xbb\x04\x84\x86\x86\xe1\x74\xba\x71\xb9\ +-\x5c\xb8\x43\xc3\x70\xb9\xfb\xfe\x1c\x12\x1a\x4e\x68\x68\x18\xa1\ +-\x61\xe1\xe7\xdc\xcc\x29\x80\x39\xa3\x75\xe2\xd4\x03\xbd\x9d\xf9\ +-\x24\xf2\x96\xe2\x54\xe7\x43\x56\x07\x12\x88\x82\x66\xf0\xf2\xb7\ +-\xa2\x54\xe7\xa3\xbb\x2a\xbd\xbd\x42\x13\x7f\x43\x12\x34\x8f\x04\ +-\xa1\x4e\x98\x93\xad\xb3\xad\x42\x70\xb2\x7d\xe4\xac\x20\x39\x1c\ +-\x0e\x26\x97\xcc\x66\xf6\xa2\x2b\x70\xbb\x47\x4c\x01\x48\x5b\x70\ +-\xb9\xdd\xb8\xdc\x6e\xa2\x3c\x31\x56\x87\x32\x28\x29\x1e\xa9\x06\ +-\x7f\x7b\xeb\x41\xca\xeb\xa7\xa6\x3b\x9f\xb2\x3a\x90\x40\xa5\x12\ +-\x80\x61\x98\x9a\xee\x7c\x62\x77\xa5\xb7\x5d\x0a\xf1\x24\x10\x34\ +-\x5f\x15\x4e\x07\x5c\x9c\x25\xd9\x5e\x01\x27\x5a\x03\x3f\x09\x18\ +-\x93\x57\xc0\xfc\xa5\xab\x88\x89\x55\x85\x55\x94\x3e\x1a\x90\x9f\ +-\xa4\xce\xc0\xda\x58\xb7\xf8\xff\xed\xdd\x6d\x70\x5c\xd5\x79\x07\ +-\xf0\xff\x73\xee\xae\x24\xdb\xb2\x5e\x2d\x59\xda\xd5\xe2\x37\x6c\ +-\x6c\x64\x90\x57\xf2\x2b\xd8\x99\x18\x28\xae\x71\x9a\x74\x02\x69\ +-\x9b\x69\x93\x69\x87\xbc\x4d\x69\x53\x32\xd3\x4e\x68\x3f\x04\xdb\ +-\x9d\x29\xc3\x4c\x98\x14\xe7\xa5\x81\xa4\x69\x52\xd3\x21\x75\x20\ +-\x0d\x31\x34\x38\x09\x38\x30\x40\xec\xc1\x92\x4d\x8c\x0c\x06\x1b\ +-\xc7\xb5\x91\x8d\x85\x25\x59\x96\xb4\xd2\xee\xde\xf3\xf4\x83\x70\ +-\x6b\xc2\x9b\x25\xed\xee\xd9\x7b\xf7\xff\x9b\xf1\x17\x8d\xb4\xfa\ +-\x5b\x7b\xf6\x9c\xe7\x9e\x7b\xee\x39\xd0\x3f\x4e\xb6\x44\x1e\x71\ +-\x1d\x24\xc8\x58\x00\x4c\x51\xb2\x25\xf2\x58\xd7\x29\xdd\xa8\xd6\ +-\xee\x14\x60\xa6\xeb\x3c\x85\x62\x64\xfc\x6c\x81\x67\x8f\x09\xfa\ +-\x52\x1f\xfc\xfd\xc5\xa8\xa6\x6e\x16\xd6\x6f\xfc\x38\x16\x2c\x6a\ +-\x75\x1d\x85\x8a\x4c\x73\x95\xa2\xb2\xb4\xd6\x7d\x06\xc9\x30\x60\ +-\xff\x30\x19\x8f\xfe\xd2\x75\x90\xa0\x63\x01\x90\x03\xed\xcd\xf2\ +-\xd4\xfe\x53\x7a\xbd\x5a\xfb\x38\x80\x92\x39\x60\xdb\x13\x60\x45\ +-\xc2\xe2\xc9\x23\x06\x99\x00\x2d\x0a\x8f\x44\xa3\x58\xb9\xf6\x7a\ +-\xac\x5c\x7b\x03\x22\x91\x92\xb9\x7b\x43\x13\x30\xbb\x64\x4a\xf9\ +-\xc0\x19\x10\x98\x4d\xc9\xb8\xf7\x9c\xeb\x20\x61\xc0\x02\x20\x47\ +-\x92\xcd\xf2\x7c\x67\x8f\xde\x28\x6a\x1f\x03\xf0\xce\xa5\xd3\x21\ +-\x35\x2d\x0a\x2c\xa8\x1f\xdf\x39\x30\x08\x16\x2c\x6a\xc5\x75\x9b\ +-\x6e\x41\x75\x4d\xc9\xd4\x69\x34\x09\x65\xec\x19\x8b\xd1\x69\x03\ +-\x73\xd3\xb2\xb8\xec\x77\x1d\x24\x2c\xd8\xcc\x73\xa8\x23\x26\x9d\ +-\x2f\x9c\xd6\x35\xbe\x6f\x1f\x03\xb0\xc4\x75\x9e\x42\x99\x5b\xa7\ +-\x38\xfc\x66\x71\x6f\x1b\x5c\x5b\xdf\x80\xeb\x36\x7e\x1c\xf3\x16\ +-\x5e\xe9\x3a\x0a\x05\x40\xd6\x77\x9d\x80\x7e\x47\x37\xc4\x6c\x5a\ +-\x16\x93\xe3\xae\x83\x84\x09\x0b\x80\x1c\x6b\x6b\x92\x63\xbf\x39\ +-\xae\xd7\x66\xa2\xfa\xb0\xa8\xae\x77\x9d\xa7\x10\x2a\x22\xe3\xc7\ +-\x0c\x9f\x1d\x76\x9d\xe4\x9d\xa2\xd1\x32\xac\x58\x7b\x1d\x56\xad\ +-\xfb\x3d\x78\x1e\x9b\x3b\x5d\x9a\xa1\xb4\xeb\x04\xf4\xff\xe4\x49\ +-\x49\xcb\xcd\xc9\x79\x32\xe0\x3a\x49\xd8\xb0\x47\xcc\x83\xab\xe7\ +-\x48\x7f\x77\xb7\xfe\xfe\x58\xad\x7e\x07\x8a\x4f\xbb\xce\x53\x08\ +-\x0d\xd3\x15\x67\x8b\xec\xb1\xc0\x05\x8b\x5a\x71\xfd\xa6\x5b\x50\ +-\xc5\xe9\x7e\x9a\xa0\x61\x16\x00\x45\x41\x81\xef\x57\x0c\xc8\xe7\ +-\x5b\x5b\x85\xef\x48\x1e\x14\x57\x8f\x1d\x32\xaa\x2a\x5d\x3d\xf6\ +-\x4e\x01\xbe\x82\x90\xff\xad\x7b\x87\x05\xcf\xfe\xb6\x38\xfe\x8b\ +-\x6f\x9e\x39\x85\x91\xe1\xf3\xb8\x6c\xde\x22\xd7\x51\x28\xa0\xe2\ +-\x55\x8a\x15\x89\x22\xbe\xa7\x15\x7e\xaa\xc0\xd6\xf6\x98\xd9\x22\ +-\x22\x7c\x23\xf2\x84\x33\x00\x79\xf4\x56\xc3\xdd\xbc\xff\x64\xf6\ +-\x98\x8a\xdc\x0f\x20\xb4\x0f\x16\xd5\x4f\x57\x18\x11\xd8\x22\xf8\ +-\xa8\xce\x6a\x6c\x06\xd0\xec\x3a\x06\x05\x58\x75\xc9\xec\xea\x51\ +-\x94\xd2\x10\xfd\x4c\x47\x2c\xb2\xdd\x75\x90\xb0\x2b\x99\xbd\xec\ +-\x5d\x4a\xb6\x44\x7e\xa0\x6a\x37\x02\x08\xed\x3d\x2c\x23\x40\xf5\ +-\xbb\xef\xa8\x4a\x14\x28\x22\x40\xac\xaa\x08\x2a\xd9\xd2\xd4\x2f\ +-\xd6\x6e\x68\xe7\xe0\x5f\x10\x2c\x00\x0a\xa4\xa3\x25\xfa\x24\x8c\ +-\xb9\x16\xc0\x6f\x5d\x67\xc9\x97\xea\x0a\x76\x9a\x14\x7c\x31\x6e\ +-\x02\xe4\xca\x31\x15\x73\x6d\x32\x11\xfd\x95\xeb\x20\xa5\x82\x05\ +-\x40\x01\xb5\x37\xcb\xa1\x6c\xd4\xac\x01\x74\x8f\xeb\x2c\xf9\x50\ +-\xc5\x19\x00\x0a\x38\x03\x60\x49\x03\x0b\xd9\xc2\xd3\xe7\x3c\xcf\ +-\xac\xee\x88\xc9\x4b\xae\x93\x94\x12\x16\x00\x05\xb6\xb2\x51\x4e\ +-\x9f\x8b\x79\xeb\x00\xdc\xed\x3a\x4b\xae\x55\x97\xb3\xe3\xa4\x60\ +-\x9b\x57\xaf\xa8\xe4\x59\x50\x05\x25\x8a\xfb\xcb\x07\xbc\xf5\x6d\ +-\x4d\x72\xc6\x75\x96\x52\xc3\x45\x80\x0e\xac\x17\xc9\x02\xb8\xa3\ +-\xb3\x27\xfb\xa2\xa8\xdc\x07\x60\xba\xeb\x4c\xb9\x50\x35\x6d\xfc\ +-\x51\x07\x96\x01\x14\x44\x65\x1e\x70\x05\xaf\xfe\x0b\x69\x14\xd0\ +-\xdb\x92\x2d\x91\xef\xb9\x0e\x52\xaa\x38\x03\xe0\x50\x47\x2c\xf2\ +-\x80\xa8\xb9\x16\xc0\x31\xd7\x59\x72\x21\x6a\xc6\xb7\x06\x26\x0a\ +-\xa2\x25\xb3\x15\x65\x9e\xeb\x14\x25\xe3\x7f\xc4\x98\x0f\xb5\xc7\ +-\x39\xf8\xbb\xc4\x02\xc0\xb1\x64\x8b\x1c\xc8\xa8\x59\x01\xc8\x2e\ +-\xd7\x59\x72\xa1\x8a\x0b\x01\x29\x80\x66\x94\x01\x73\x6b\xd8\x76\ +-\x0b\x42\xe5\x67\xe5\xd6\x24\x93\xcd\xf2\xbc\xeb\x28\xa5\x8e\x05\ +-\x40\x11\x58\xd5\x22\x67\x93\x31\xd9\x08\xe0\x0e\x00\x01\x3a\x57\ +-\xef\x9d\xf8\x28\x20\x05\xd1\xa2\x59\x0a\x29\x8e\x7d\xac\xc2\x4c\ +-\x01\xdc\x9d\x8c\xcb\x47\x5a\x13\xd2\xe7\x3a\x0c\xb1\x00\x28\x1a\ +-\x22\xa2\xed\x71\xef\x6e\x55\xfd\x18\x02\xbc\x5f\xc0\x74\x3e\x3e\ +-\x45\x01\x33\x2d\x02\x24\x6a\x79\xf5\x9f\x67\x83\x2a\x7a\x73\x7b\ +-\xdc\xbb\x43\x44\x02\x7d\x91\x13\x26\x2c\x00\x8a\x4c\x47\x4b\xe4\ +-\x51\xb1\x66\xa5\x2a\x5e\x74\x9d\x65\x32\x2a\xa3\xec\x48\x29\x58\ +-\xe6\xd6\x29\x3b\xc2\xfc\x7a\x59\xc5\xac\xee\x88\x45\xfe\xcb\x75\ +-\x10\x7a\x3b\xb6\xfb\x22\x94\x4c\xc8\xab\x15\x65\x66\x0d\x80\xc0\ +-\x2d\x90\xe1\x39\xea\x14\x24\x46\x80\xb9\xbc\xfa\xcf\x1b\x05\xbe\ +-\xe3\x79\x66\x39\x9f\xef\x2f\x4e\x2c\x00\x8a\x54\x6b\xa3\x0c\xb5\ +-\xc7\xbd\x5b\x55\xf4\x66\x00\x67\x5d\xe7\xb9\x54\x5c\x45\x4d\x41\ +-\x12\xaf\x56\x94\xb3\x68\xcd\x87\x01\x40\x3f\xd9\x11\xf7\x3e\xd7\ +-\xd6\x24\x45\x78\x50\x38\x01\x2c\x00\x8a\x5e\x47\x2c\xf2\xe3\x6c\ +-\xd4\x2c\x05\xe4\x71\xd7\x59\x2e\x05\x17\x52\x51\x90\xcc\xaf\xe3\ +-\xd5\x7f\xee\xc9\x13\xc6\x9a\xa5\xed\xf1\xc8\x0f\x5d\x27\xa1\xf7\ +-\xc7\x02\x20\x00\x56\x36\xca\xe9\x64\x4c\x6e\x12\xc1\xed\x00\xc6\ +-\x5c\xe7\x21\x0a\x83\xba\xe9\x40\x2d\x4f\xfd\xcb\x1d\x41\x46\x81\ +-\x2d\xc9\x98\xdc\xb8\x2c\x21\xaf\xbb\x8e\x43\x1f\x8c\x05\x40\x40\ +-\x88\x88\x26\x63\xde\xbd\x9e\x67\x96\x43\x70\xd0\x75\x1e\xa2\xa0\ +-\x5b\x50\xcf\xab\xff\x1c\x7a\xc9\xa8\x59\xd5\x11\xf7\x36\x73\x95\ +-\x7f\x70\xb0\x00\x08\x98\xb6\x26\x79\x71\xd4\x37\xab\x00\x6c\x03\ +-\x77\xdd\x25\x9a\x94\xda\x69\x3c\xf2\x37\x67\x14\xdb\x3d\xcf\xac\ +-\x58\x16\x97\xfd\xae\xa3\xd0\xc4\xf0\x8e\x6d\x80\x75\xf6\x64\x36\ +-\x88\x9a\xef\x03\x68\x72\x9d\xe5\x82\xd1\x2c\xf0\xf8\x61\xd6\x95\ +-\x54\xbc\x0c\x80\x75\xf3\x2d\xa7\xff\xa7\xae\x57\xa1\xb7\x76\xc4\ +-\x23\x3b\x5d\x07\xa1\xc9\x61\x4f\x1d\x60\x1d\xb1\xe8\x2e\x9b\x31\ +-\xed\x80\xfc\xd4\x75\x96\x0b\x7c\x5e\x54\x51\x91\x5b\xda\xac\x1c\ +-\xfc\xa7\x4a\xe5\xe1\x68\xc4\x5c\xc5\xc1\x3f\xd8\x38\x03\x10\x12\ +-\xfb\x4f\x66\x3f\xa1\x22\xdf\x02\x30\xcb\x65\x8e\xc1\x51\xe0\xc9\ +-\xa3\xac\x2b\xa9\xf8\x08\xc6\x4f\xfb\x5b\xdc\xc8\x2a\x75\x0a\x4e\ +-\x43\xf5\xaf\xdb\x5b\x22\x0f\xb9\x0e\x42\x53\xc7\x9e\x3a\x24\x92\ +-\x2d\x91\x1f\x79\x9e\x69\x85\x62\xbb\xcb\x1c\x9c\x01\xa0\x62\x34\ +-\x2d\x02\x2c\x4f\x70\xf0\x9f\x02\x85\x62\x7b\xb9\x35\xad\x1c\xfc\ +-\xc3\x83\x33\x00\x21\xd4\x75\x32\x7b\x0b\x44\xbe\x0e\x07\x6b\x03\ +-\xfa\x53\xc0\x53\xaf\xb1\xae\x24\xf7\x44\x80\xda\x0a\xa0\xa5\x46\ +-\x31\xb7\x56\x61\xd8\xdb\x4d\x8a\x02\x87\x45\xcc\xe7\xda\x63\xf2\ +-\xb4\xeb\x2c\x94\x5b\xfc\x48\x84\xd4\xbe\xa3\x5a\x6d\x2a\xec\x56\ +-\x00\xb7\x01\x28\xd8\xfe\x7c\xe7\x52\xc0\x6e\x16\x00\x94\x67\x82\ +-\xf1\x83\xa7\x2a\xa2\x40\x85\x37\xbe\x9b\xdf\x85\x7f\x15\x11\xa0\ +-\x22\xa2\x98\x59\x01\x78\xec\xe1\xa6\x22\x0b\xe0\x9e\x73\x69\xb3\ +-\x79\xfd\x3c\x19\x75\x1d\x86\x72\x8f\x1f\x8f\x90\xdb\xd7\xa3\xed\ +-\x46\xed\xfd\x00\x3a\x0a\xf1\xfb\xce\x8d\x02\xbb\xb9\x06\x80\xf2\ +-\xc0\x08\x90\xa8\x51\x34\x57\x01\xf5\xd3\x14\x51\x6e\x3b\x9d\x37\ +-\x0a\xec\x87\x98\xcf\x76\xc4\xa4\xd3\x75\x16\xca\x1f\xf6\xd4\x21\ +-\xb7\x3c\x26\x5d\xf6\x94\x59\x03\xe0\x0e\x00\x23\xf9\xfe\x7d\xdc\ +-\x0a\x98\x72\x4d\x64\xfc\xc4\xbe\x0d\x8b\x2c\x92\x31\x45\x53\x25\ +-\x07\xff\x3c\x1a\x56\xc1\x97\x8e\xc6\xcc\x0a\x0e\xfe\xe1\xc7\xee\ +-\xba\x84\x1c\x38\xa1\x71\x2b\xf6\x2e\x08\x3e\x95\xaf\xdf\x31\x92\ +-\x01\x7e\xfe\x0a\xeb\x4a\xca\x8d\xa6\x4a\xc5\x95\xb3\x15\x55\x15\ +-\xae\x93\x84\x9e\x42\xe4\x21\x40\xfe\xae\x3d\x26\xc7\x5d\x87\xa1\ +-\xc2\x60\x01\x50\x82\x0e\x9c\xcc\xac\xf7\x61\xb6\x89\x60\x69\xae\ +-\x5f\xdb\x02\xd8\x79\xc8\x40\xb9\xd8\x9a\xa6\xa0\x7e\x06\xb0\xb8\ +-\x41\xd1\x30\x83\x0d\x29\xff\x74\x9f\xc0\xbb\x3d\x19\x97\x67\x5d\ +-\x27\xa1\xc2\x62\x01\x50\xa2\x76\xab\x46\x6a\x4e\xd9\xdb\x14\xd8\ +-\x02\x45\x75\x2e\x5f\x7b\xd7\x2b\x06\xa9\x4c\x2e\x5f\x91\x4a\x81\ +-\x00\x98\x5d\xa9\x58\xd4\xa0\xa8\x9b\xee\x3a\x4d\x49\xe8\x51\xc1\ +-\x96\xf6\x66\xf3\x5d\xee\xdf\x5f\x9a\x58\x00\x94\xb8\x83\x6f\xe8\ +-\xec\x6c\xc6\x6e\x55\xc1\xad\xc8\xd1\xd3\x02\xcf\x1d\x17\x9c\x19\ +-\x62\xd3\xa2\x4b\x23\x18\xdf\x97\x7f\x51\x83\xa2\x9a\x53\xfd\x85\ +-\x30\x2a\x82\x7b\x8c\x31\x77\xb5\x35\xc9\xb0\xeb\x30\xe4\x0e\x7b\ +-\x69\x02\x00\xec\xeb\xd1\xc5\x06\xba\x15\xaa\x9f\x98\xea\x6b\x1d\ +-\x3c\x2d\x38\x7a\x96\x4d\x8b\x3e\x58\xe3\x5b\xf7\xf8\x6b\x38\xf0\ +-\x17\x84\x40\x1e\x35\x9e\x7c\xb1\xad\x49\x8e\xb9\xce\x42\xee\xb1\ +-\x97\xa6\xb7\xe9\x7a\x3d\x73\x03\x60\xbe\x0a\xa0\x6d\xb2\xaf\x71\ +-\xbc\x5f\xb0\xbf\x87\x4d\x8b\xde\xdb\xf4\x32\xa0\xad\x49\x31\x7b\ +-\x26\xef\xf1\x17\x82\x02\xfb\x45\xcc\xed\xdc\xcc\x87\x2e\xc6\x5e\ +-\x9a\xde\x61\x87\xaa\xb7\xa0\xc7\xff\xb4\x40\xee\x04\x30\x67\xa2\ +-\x3f\xdf\x37\x02\x3c\x7d\x8c\x4f\x02\xd0\x3b\x09\x80\xf9\xf5\x8a\ +-\x2b\x1b\x15\x1e\x9b\x48\x21\x1c\x83\xea\xe6\x64\xdc\x7b\x80\xf7\ +-\xf9\xe9\x77\xb1\x00\xa0\xf7\xd4\xdd\xad\x65\xa3\xb5\xf6\xcf\x45\ +-\xb1\x05\x13\xd8\x56\x38\xed\x03\xff\xfd\x32\x7b\x77\x7a\xbb\x32\ +-\x0f\x68\x8f\x2b\x9a\x78\xd5\x5f\x08\x6f\x02\xf8\xea\xb9\xb4\xb9\ +-\x97\xbb\xf8\xd1\x7b\x61\x01\x40\x1f\xe8\x85\xd3\x3a\xc3\xf7\xed\ +-\x5f\x61\x7c\x33\xa1\x9a\x4b\xf9\x99\x9d\x87\x0c\x0f\x06\xa2\xff\ +-\x53\x11\x01\xae\x99\x6b\x51\x55\xee\x3a\x49\xb8\x29\x70\x5e\x80\ +-\x6f\xa5\x2b\xcc\x3f\xad\xae\x97\x41\xd7\x79\xa8\xb8\xb1\x00\xa0\ +-\x4b\xf6\x4c\xaf\xce\x9c\x9e\xb6\x7f\x89\x4b\x28\x04\x76\x1d\x36\ +-\x48\x65\x0b\x93\x8b\x8a\x5b\x45\x04\x58\x3b\xcf\xa2\xb2\xcc\x75\ +-\x92\xf0\xba\x30\xf0\x47\xb2\xe6\xee\xab\xe7\x48\xbf\xeb\x3c\x14\ +-\x0c\x2c\x00\x68\xc2\x2e\x2a\x04\xbe\x0c\xa0\xf6\xdd\xbe\xe7\xf1\ +-\xc3\x06\xa3\x2c\x00\x4a\x9e\x08\xb0\xe6\x32\x45\x63\x25\xa7\x83\ +-\xf2\x81\x03\x3f\x4d\x05\x0b\x00\x9a\xb4\xfd\xc7\xb4\x06\x65\xf6\ +-\x6f\x14\xf8\x22\x80\xba\x0b\x5f\x3f\x33\x24\x78\xee\x38\x9b\x16\ +-\x01\x0b\xea\x15\x57\x35\x71\xf0\xcf\x83\xb3\x50\xdc\x6b\xc7\xcc\ +-\xb6\xe5\x0b\xe4\x9c\xeb\x30\x14\x4c\xec\xa5\x69\xca\x76\x1f\xd3\ +-\x8a\xea\xa8\xff\x47\x2a\xf2\x0f\x02\x5c\xf1\x9b\x53\x82\xd7\xfa\ +-\xd8\xb4\x4a\x9d\x27\xc0\x8d\x8b\x2c\xca\x23\xae\x93\x84\xca\x69\ +-\x05\xee\xd3\x51\xf3\x35\x0e\xfc\x34\x55\xec\xa5\x29\x67\x54\xd5\ +-\x74\xf5\xf8\x9b\x0e\x9d\x31\x5f\x7f\xb5\x57\x26\xfc\xf8\x20\x85\ +-\x4b\x53\xa5\x62\xf5\x1c\x5e\xfd\xe7\xc8\x11\x11\x7c\xa3\x72\xd8\ +-\x7c\x7b\xe1\x42\x19\x73\x1d\x86\xc2\x81\x05\x00\xe5\xc5\xbf\x77\ +-\xe9\xad\x83\x29\xbd\xb3\x77\x44\x12\x3c\x18\xa8\x34\x2d\x6e\x54\ +-\x2c\x6e\xe0\x9b\x3f\x15\x2a\xb2\x1b\x6a\xbf\xd6\x1e\xf3\x1e\x15\ +-\x11\xfe\x31\x29\xa7\x58\x00\x50\x5e\xfd\xdb\x41\xfd\x70\x6a\x08\ +-\xff\xdc\x3b\xa4\x6d\xbe\xb2\xb9\x95\x92\xe5\x2d\x8a\x96\x6a\x8e\ +-\x59\x93\x90\x86\xc8\x23\xd6\x97\x7b\x96\x27\x64\xaf\xeb\x30\x14\ +-\x5e\xec\x91\xa9\x20\x76\x74\xeb\xe5\x83\x43\xf8\xe6\x9b\x23\xb8\ +-\x7e\x24\x93\x9b\x43\x87\xa8\xb8\xad\x4c\x28\x62\x55\x2c\x00\x26\ +-\xe0\x0d\x05\xbe\x5d\x16\x31\xff\x72\xd5\x6c\x79\xc3\x75\x18\x0a\ +-\x3f\x16\x00\x54\x50\xbb\x77\x6b\xc5\x89\x99\xf6\x2b\x7d\xa3\xf2\ +-\xd9\xfe\x94\xcc\xe2\xed\x81\xf0\xea\x88\x2b\x12\x35\x7c\x83\x2f\ +-\x41\xa7\x0a\xee\x1f\xf3\xcd\xf6\x6b\x12\x92\x72\x1d\x86\x4a\x07\ +-\x0b\x00\x72\xe6\x27\x2f\xe8\xba\x33\x29\xbd\xeb\xcc\xb0\xac\x49\ +-\xfb\xe0\xde\xc1\x21\xb3\xa4\x51\x71\x05\xd7\x00\xbc\x3b\xc1\x39\ +-\xb1\xf8\x4f\x5f\xcd\x37\x96\x27\xe4\xa0\xeb\x38\x54\x9a\x58\x00\ +-\x90\x73\x3b\xba\xb5\x2e\x95\xb2\xff\x38\x30\x2a\x9f\xec\x4b\x49\ +-\x2d\x67\x05\xc2\x21\x51\xad\xe8\x68\xe1\x9b\x79\x11\x85\xea\xd3\ +-\x00\xbe\x67\x8d\xf7\xd0\xf2\x98\x8c\xb8\x0e\x44\xa5\x8d\x05\x00\ +-\x15\x95\x07\xbb\x74\xf9\xf9\x2c\xb6\xf6\x8f\xe0\x86\xe1\x34\xa2\ +-\xae\xf3\xd0\xe4\x55\x96\x01\x37\x2c\xe4\x01\x74\x00\x5e\x07\xf0\ +-\x80\x5a\xf3\xdd\x8e\x84\x1c\x71\x1d\x86\xe8\x02\x16\x00\x54\x94\ +-\x76\xa8\x7a\x63\x9d\xf6\x4b\xe7\xd2\xf2\x85\xfe\x94\xcc\xcf\xf8\ +-\x6c\xab\x41\x23\x00\x6e\x5a\x62\x11\x2d\xc1\x9b\x3b\x0a\x9c\x17\ +-\xc5\x4f\x44\xec\xf6\x65\xb1\xc8\x13\x3c\x8a\x97\x8a\x11\x3b\x55\ +-\x2a\x7a\xf7\xed\xd3\xea\xa8\xb5\x7f\x3b\x92\x35\x9f\xea\x1b\xc1\ +-\x9c\x2c\xbb\xd2\xc0\x58\x37\xd7\xa2\x7e\x86\xeb\x14\x05\xe3\x03\ +-\xb2\x1b\x6a\xb7\x97\x97\x79\x3f\x6e\x6d\x94\x21\xd7\x81\x88\xde\ +-\x0f\x0b\x00\x0a\x94\x07\xf7\xeb\xdc\x54\xc6\x6e\x1e\x4c\x9b\x8f\ +-\x0c\x8c\xa0\x9e\xb5\x40\x71\xbb\xba\x59\x31\xbf\x2e\xd4\xeb\x00\ +-\xb2\x80\xfc\x4a\xc4\xee\x28\xf3\xbd\x87\x5b\x13\xd2\xe7\x3a\x10\ +-\xd1\xa5\x62\x01\x40\x81\xf5\x1f\xcf\xeb\xfc\x51\xb5\x5f\x1e\x4e\ +-\x9b\x8f\xf6\xa7\xd0\xe4\x87\x7a\x9c\x09\xa6\x39\xb5\x8a\x64\x2c\ +-\x74\x6f\x8c\x0f\xe8\x1e\x11\xf9\x51\xc4\x33\x3f\xe4\x33\xfb\x14\ +-\x54\x2c\x00\x28\x14\x1e\xec\xd2\xd8\x98\xda\xbf\x1f\x1a\x35\x1f\ +-\xeb\x1f\x45\x0b\xd7\x0c\x14\x87\xc6\x4a\xc5\x35\xe1\x38\x0f\x60\ +-\x10\x22\xbb\x14\xf6\xa7\x9a\xf2\x76\xf2\x20\x1e\x0a\x03\x76\x92\ +-\x14\x3a\xdb\x5e\xd5\xf2\xca\x7e\x7c\x7e\x2c\xab\x7f\x7a\x2e\x8d\ +-\x65\x23\x69\x29\x73\x9d\xa9\x54\xd5\x4d\x03\x3e\x34\x3f\x98\x37\ +-\x6a\x44\xf1\x1a\x80\x5f\x5a\xd1\x47\x2b\x06\xbc\x5d\xad\xad\x92\ +-\x76\x9d\x89\x28\x97\x58\x00\x50\xe8\x3d\x70\x40\x6f\x1c\x19\xd3\ +-\x2f\x0c\xa7\x65\xed\xe0\x98\x36\xf8\x96\xcd\xbe\x50\x66\xcd\x00\ +-\xd6\xce\x0d\x4c\x01\x30\xa4\x22\x4f\x19\xe8\x2f\xc4\x9a\x9f\x2d\ +-\x6b\x91\x57\x5c\x07\x22\xca\x27\xf6\x84\x54\x52\x76\xee\xd3\xe9\ +-\xc3\x11\xfb\x67\xc3\x19\xf3\x27\xe7\xc7\xd0\x31\x90\x42\x95\x0d\ +-\xc5\x0c\x75\x71\x8a\x57\x29\x56\x24\x8a\xf6\x0f\xec\x43\xb5\x4b\ +-\x8c\xfc\x5c\xc5\xfc\xa2\xbc\x0f\xbf\xe6\x55\x3e\x95\x12\x16\x00\ +-\x54\xd2\xfe\xb5\x4b\x63\x9a\xb5\x9f\x19\xf3\x65\xe3\x48\x5a\xae\ +-\x1c\x4a\xa3\x8a\x3b\x11\xe6\xce\x8a\x84\x22\x5e\x3c\x07\x02\xf9\ +-\x00\x0e\x00\x78\x56\x54\x9f\x29\x53\xef\x09\xae\xda\xa7\x52\xc6\ +-\x02\x80\xe8\x22\x8f\x1c\xd4\xd9\xe7\xc6\xec\x5f\xa4\x7c\xb3\x71\ +-\x38\x8d\xa5\x43\x63\xa8\xcd\x5a\x7e\x4e\x26\x23\x56\xa5\x58\xe9\ +-\xf6\xea\x7f\x00\x90\xbd\x0a\xdd\x23\xb0\xcf\x78\x5e\xe4\xd7\x6d\ +-\x4d\x32\xec\x32\x10\x51\x31\x61\xc7\x46\xf4\x3e\x76\x74\x6b\x59\ +-\x6a\x14\x9b\xc6\x7c\xfb\xd1\x74\x46\x56\xa7\xb2\x32\x67\x28\x8d\ +-\x69\x9c\x25\x78\x7f\x65\x1e\x70\xdd\xe5\x16\x15\x91\x02\xfd\x42\ +-\x41\x06\x8a\x6e\x28\xf6\x0a\x74\x8f\x35\xde\xde\xf6\x66\xbc\x2c\ +-\x22\x7c\xa7\x88\xde\x03\x0b\x00\xa2\x09\xda\xb6\x47\xab\x66\x18\ +-\xfc\x41\xd6\xda\x0d\x59\x6b\x92\xa9\x2c\xe6\x8c\xa4\x51\xc9\x99\ +-\x82\x71\x02\x60\xd5\x1c\x45\x53\x65\xde\xc6\xde\x21\x00\x87\xa1\ +-\x38\x24\x06\x9d\x3e\x4c\x67\xda\x47\x27\x8f\xd2\x25\x9a\x18\x76\ +-\x58\x44\x39\xb0\x79\xb3\x9a\xcb\x6e\xc2\xea\x2c\xec\x86\x6c\x56\ +-\x56\xa5\xad\x2c\x4c\x67\x31\x3b\x95\xd1\x19\xbe\x96\xd6\xc7\x6c\ +-\xe1\x2c\x45\xeb\xec\x9c\x0c\xfe\x63\x00\x8e\x42\xa4\x5b\x55\x0f\ +-\x19\xd5\x6e\xf1\xbc\x43\x6d\x4d\x78\x89\x7b\xeb\x13\x4d\x5d\x69\ +-\xf5\x4c\x44\x05\xb6\x63\x87\x7a\xa9\xcb\xb1\xd2\xfa\x76\x6d\x06\ +-\x26\x99\xce\xe0\x8a\x6c\x56\x63\x63\x56\x6a\xc6\x7c\x94\x67\x43\ +-\xb6\x61\x51\xed\x34\x60\xdd\x7c\x8b\x09\x9c\xff\x33\x08\xe0\x35\ +-\x88\x1c\x81\xea\x11\x11\x3d\x0a\x5f\x8f\x18\x89\x1c\xb9\x3a\x8e\ +-\xd7\x39\x85\x4f\x94\x3f\xa1\xea\x7c\x88\x82\xe6\x07\x7b\x75\x91\ +-\x6f\xd0\x61\xad\x6d\xf3\x55\x16\x66\x14\x2d\xea\x4b\x43\x56\x51\ +-\x93\xce\x62\xfa\x98\x8f\xb2\xa0\xdc\x5a\x10\x01\x3e\x3c\xcf\xa2\ +-\x7a\x1a\x00\xc0\x02\xe8\x55\x45\xaf\x88\xbc\x01\xd5\x1e\x05\x4e\ +-\x08\x70\x42\xa1\x27\x55\xbd\xe3\x5e\x16\x27\x92\xf3\x64\xc0\x6d\ +-\x6a\xa2\xd2\x15\x88\x8e\x85\xa8\x94\x6d\xee\xd6\xca\xc4\x18\x16\ +-\x4b\x16\x0b\x44\xec\x65\x6a\x4d\xb3\x2f\x68\xb0\x16\xf5\x59\xd5\ +-\x3a\xa8\x54\x66\xad\xce\x54\x48\xd4\x2a\xca\xad\x22\x6a\x15\x9e\ +-\x6f\x35\xaa\x16\xc6\x42\xde\x76\x41\x9e\xb1\x90\x8b\x17\x31\x46\ +-\x0c\x60\x0c\x14\x6f\x7d\x2d\xe2\xa9\x42\x45\x01\x58\x23\xb0\x62\ +-\xd4\x37\x40\xd6\x33\x92\x8e\x18\x8c\x1a\xd1\x51\x4f\x64\xd0\x18\ +-\x1d\x14\xc1\x80\x81\xf6\x89\x67\x7a\x23\x6a\x4f\x2e\x69\x34\x4f\ +-\xd9\x72\xf4\xae\x68\xc0\x19\x4e\xd3\x13\x15\xb7\xff\x05\x82\x22\ +-\xaa\x2f\x56\xbc\x39\x1a\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\ +-\x60\x82\ +-\x00\x00\x07\xda\ +-\x89\ +-\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\ +-\x00\x00\x20\x00\x00\x00\x20\x08\x06\x00\x00\x00\x73\x7a\x7a\xf4\ +-\x00\x00\x00\x04\x73\x42\x49\x54\x08\x08\x08\x08\x7c\x08\x64\x88\ +-\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0d\xd7\x00\x00\x0d\xd7\ +-\x01\x42\x28\x9b\x78\x00\x00\x00\x19\x74\x45\x58\x74\x53\x6f\x66\ +-\x74\x77\x61\x72\x65\x00\x77\x77\x77\x2e\x69\x6e\x6b\x73\x63\x61\ +-\x70\x65\x2e\x6f\x72\x67\x9b\xee\x3c\x1a\x00\x00\x07\x57\x49\x44\ +-\x41\x54\x58\x85\x9d\x97\x6b\x50\x54\xe7\x19\xc7\x7f\xef\xd9\x0b\ +-\xec\x72\x0f\x77\x64\xb9\x09\x2a\xa0\x46\x44\xb4\x01\x43\x84\x18\ +-\x31\xd5\x54\x21\xd3\x66\xd2\xcc\x34\x56\x33\xd3\x69\xcd\x4c\x6a\ +-\x9c\xd6\x74\x3a\xcd\x74\xfc\xd0\xd4\xde\x92\x69\xda\xa9\xe9\x34\ +-\x37\xe3\x2d\x35\xa3\x24\xc6\x4b\xea\x2d\x4a\x0c\x04\x04\x2d\xa0\ +-\x48\x50\x50\x58\x40\x60\x57\xb9\x2e\xcb\x5e\xce\xdb\x0f\xe8\xba\ +-\xcb\x6e\x84\xf4\xf9\xf4\x9e\xe7\xfd\x3f\xcf\xff\x7f\xce\x79\xce\ +-\xf3\x3e\x47\x30\x43\xfb\xb8\x49\xc6\x0f\x3b\xd4\xad\x23\x0e\x65\ +-\x8d\xdd\x29\x53\x9c\x6e\x61\xb0\xbb\xd1\x48\x09\xb3\x22\xa4\x3d\ +-\x3f\x49\x6d\x92\x42\x5c\x12\xc8\xd3\x36\xbd\xe6\xc8\xf2\x58\x31\ +-\x32\x93\xbc\x62\x3a\xc0\xbe\x26\xb9\xc2\x3a\xca\x5b\xd6\x51\xe6\ +-\xb8\xe5\xa4\x4f\xaf\x01\x83\x0e\x0c\x3a\x89\x51\x37\xb9\xce\x8a\ +-\x91\xde\x61\x36\x60\x9f\x50\x95\x1d\x79\x26\xd1\xf6\x7f\x09\xf8\ +-\xb2\x4b\x1a\x5a\x7a\xe5\x71\xf3\x90\x28\x76\x4b\xdf\x3d\x8d\x80\ +-\xd2\x4c\x15\xa3\x0e\xae\xf4\x0b\x86\xec\x50\x98\x2a\xfd\x93\x08\ +-\x9c\x52\xf2\xc6\xb0\x43\x79\xb5\x24\x5d\xd8\x67\x2c\xe0\x40\x93\ +-\x2c\x1c\x9b\x90\x95\x42\x10\xdb\x3f\x2a\x18\x99\xb8\xbf\x17\x16\ +-\x04\x2e\x15\xe6\xc4\x4a\x12\xc3\x24\xc1\x5a\xff\x78\x55\x95\x28\ +-\x8a\x77\x6a\x59\xa3\x3a\x35\x15\x4b\xd2\x44\xef\xb4\x02\x76\xd7\ +-\xcb\x67\x1c\x2a\xef\x76\x0d\x61\x88\x36\x4a\xcc\x7d\x23\xdc\xea\ +-\xed\x62\xc0\x62\x21\x42\x19\x21\x44\xa7\x62\x34\x04\x93\x9e\x1c\ +-\x4f\xf1\xb2\x05\x3e\xb1\x36\x9b\x9d\x77\x0e\x7c\xc6\xac\x84\x18\ +-\xca\xcb\x8a\xa6\xa6\x36\x4b\x55\x59\x93\x6f\x12\x8d\xde\x4e\x1f\ +-\xfd\x7b\xea\xe4\xca\x1b\x83\xec\x1d\x19\x9f\x50\x9a\x2f\xd6\xd0\ +-\x78\xa1\x1a\x4b\xbf\x9f\x68\x00\x72\x32\x53\x3d\x02\xa4\x94\x9c\ +-\xa8\x6a\xe0\xef\xbb\x3e\xc1\x3a\x38\xcc\x4b\x1b\xcb\x03\x85\x24\ +-\x0b\x45\x3d\x72\xa4\x5d\x2e\x5f\x93\x21\x6e\xfa\x09\x78\xeb\x82\ +-\x8c\x30\x8f\xca\xc3\xad\x5f\xb7\x2a\x47\x0f\xee\xc6\x36\x3a\xa3\ +-\x22\x06\x60\xfb\x5f\x77\x73\xa2\xaa\x61\x26\xd0\xe4\x20\x97\x7a\ +-\xec\xcb\x2e\x99\x5f\x68\x12\xe3\x3e\x02\x54\x87\x3c\x59\x75\xae\ +-\x2a\xf8\xf4\xf1\x83\x20\x03\x14\xd4\x03\xac\xbb\xd7\x3a\x63\x6c\ +-\x98\x81\xec\xd6\x01\xb9\x0f\x58\x0f\xa0\x00\x7c\x78\x49\x96\xd4\ +-\x5d\xbe\xbe\xe4\xcc\x14\x72\x45\x11\xac\x2c\xca\x63\xfb\xd6\x0d\ +-\x3c\xb3\xf6\xb1\x6f\x25\x2a\x90\xb9\x25\x7c\x7e\x5d\xa1\xdd\x2a\ +-\xd6\xfd\xab\x4e\x2e\x85\xbb\x4f\x20\x54\xe7\xde\x72\xfe\x3f\x87\ +-\x90\x5e\xe4\xc6\xe0\x20\x5e\xdb\xb6\x89\xfc\x05\x59\x00\x58\xef\ +-\x0c\xcd\x88\x24\x3b\x33\x85\xa5\x0b\xe7\x06\xdc\x33\x0f\x0a\xc6\ +-\x1c\x93\x6b\xbb\x4b\xbe\x0b\xe4\x6a\x6b\xac\x32\xfc\x7a\x73\xc7\ +-\x13\x5d\x66\xb3\x0f\xf8\x95\xcd\xcf\x7a\xc8\x67\x62\x11\xe1\x21\ +-\xfc\xe4\x87\x6b\x59\x5b\xba\x0c\x97\xea\xa6\xa1\xb9\x8d\xb6\x1b\ +-\x3d\x58\x07\x87\x09\x35\x18\x50\x43\xe2\x08\x49\xc8\x41\xa7\xd3\ +-\x03\x70\xc7\x26\xb2\xf7\x36\xc9\x78\xad\xde\xee\x5e\xd3\xd0\x7c\ +-\x2d\xd8\x3b\xd9\xdc\xd9\x26\x4a\x1f\x79\x78\xc6\xe4\xab\x4b\x0a\ +-\x58\x59\x94\x47\x70\xb0\x9e\xbd\x1f\x9f\x66\xdf\xe1\x33\x0c\x0d\ +-\x8f\xf9\xe1\x8c\xa1\x61\xac\x5e\xf7\x2c\x19\x73\x72\x71\xba\x11\ +-\xb6\x09\xf5\x57\x0a\x88\xd2\x76\x73\x9f\x0f\xf0\xd1\x82\xf9\xd3\ +-\x92\xce\x9f\x9b\xea\x59\x57\x94\x15\x71\xe5\xeb\x9b\x3c\xbf\xe5\ +-\x0f\xec\xdc\xf3\x69\x40\x72\x00\xdb\xe8\x08\x95\xfb\xdf\xc6\xdc\ +-\x79\x1d\x00\xa7\x53\x79\x5c\xdb\x37\xc2\xf2\x6e\xcb\xb8\x0f\x30\ +-\x29\x2e\xfa\x1b\x89\x33\x52\x92\xd8\xb2\xa9\x9c\xbc\xdc\x4c\x00\ +-\x7a\xfa\xac\xbc\xf9\x5e\x25\x55\x75\xcd\xd3\x8a\x06\x50\xdd\x6e\ +-\x4e\x1e\x3e\xc0\x86\x9f\x6d\xc3\xe6\x24\x4d\x7b\xb9\x5f\xc9\x9c\ +-\x70\xf9\x36\x44\xad\xce\xbf\xbf\x86\x87\x18\xf9\xf9\xc6\x0a\xca\ +-\xcb\x8a\xd0\x68\x14\x26\x1c\x4e\xf6\x54\x9e\x62\x4f\xe5\x69\x26\ +-\x1c\x4e\x0f\x4e\xa7\xd5\xf0\xc4\xa3\xf9\xac\x5e\x51\x80\x29\x31\ +-\x96\x7e\xeb\x20\x7f\xd9\x75\x92\xd6\x96\xfb\x02\x2d\xfd\xbd\xf4\ +-\x76\x77\x62\x48\x4f\x35\x68\x8b\xd2\xa4\x7a\x2c\xd2\x80\xf7\x91\ +-\x75\xab\xdf\xff\xbb\x2e\x7b\x6c\x89\x67\x7d\xae\xb6\x99\xbf\xbd\ +-\x5f\x49\x4f\x9f\x2f\x6e\x59\xde\x3c\x5e\xfa\x71\x39\x29\x49\x71\ +-\x1e\x5f\x74\x54\x04\x6b\x7f\xb0\x09\xeb\xce\x3f\x62\xe9\xeb\xf1\ +-\xf8\xcd\x37\xae\x91\x9c\x92\xaa\xd1\x06\x69\x24\x0b\x33\x62\xa9\ +-\xae\xb9\x9f\xe8\xf8\xd9\x7a\x2a\xbe\xbb\x82\x6b\x56\x0d\x63\x4e\ +-\x88\x0c\x86\xb8\x50\xc9\xcd\x9e\x01\x3e\xd8\x77\x90\xaf\x2e\x5d\ +-\xf5\x21\x4e\x8a\x8f\xe6\xc5\xe7\xd7\x53\xbc\xd4\xbf\x76\x14\x01\ +-\x39\x09\x82\xdc\x85\x4b\x38\x7b\xe2\x13\x8f\xdf\x6a\xe9\x07\x26\ +-\xfb\xc0\x70\xde\xfc\xcc\x18\xef\xa0\xf6\xce\x1e\x5e\xdc\xfe\x0e\ +-\x8b\x8b\x56\x11\x16\x1e\x8e\xd5\xd2\x4f\x4b\x63\x3d\x57\x9b\xea\ +-\x71\xbb\xdd\x1e\x5c\x90\x5e\xc7\x73\xeb\x4b\x79\x6e\xfd\xe3\x04\ +-\xe9\x75\xb8\xdd\x2a\x87\x3e\x3b\x4f\x58\x88\xc1\xe7\x89\xcd\x8d\ +-\x95\xa4\x25\x45\x71\xd6\x8b\xc3\x31\x31\x8e\x5e\x83\x5b\x8b\x94\ +-\x1d\xb9\x59\xa9\x31\xe9\xa6\x04\x3a\xba\x6e\x79\x00\x57\x5b\x2e\ +-\x73\xb5\xe5\xb2\xdf\x1d\xdd\xb3\x45\x0b\x17\xb0\x75\xd3\x3a\xd2\ +-\x67\x4d\x16\xec\xc5\xcb\xd7\x78\xfd\xed\x43\xb4\x77\xf6\x04\x3c\ +-\x8c\x92\xc3\x5d\x3e\xd7\x1a\x54\x52\x22\xa5\x59\x3b\x39\x46\x51\ +-\xf0\xf2\x0b\x4f\xb3\x65\xfb\x4e\x5c\x5e\x77\x18\xc8\xa2\xa2\x63\ +-\x29\x7d\xb2\x82\xf4\xac\x1c\xae\xd9\x20\x4d\xaa\xbc\xf9\xde\x21\ +-\xfe\x7d\xe4\xdc\x03\xe3\x7a\xfb\x2c\x3e\xd7\x19\x09\x46\xb2\x63\ +-\xe5\x71\x45\x20\x4f\x03\xe4\xe5\x66\xf2\xbb\x6d\x1b\x79\x28\x32\ +-\x3c\x60\x02\x83\x31\x94\xe2\x95\x4f\xb1\x61\xf3\x2b\x24\x26\xa7\ +-\x71\xa9\xee\x0b\xc6\x1c\xd0\x71\x47\xd0\xdc\x7a\x33\x60\x8c\xb7\ +-\x55\xd5\xfa\x7e\xa6\x69\xc9\xf1\x08\xe4\x29\x6d\x90\x4e\xf3\xe9\ +-\x84\x53\x1d\x03\x42\x0a\x17\xe7\xf0\xcf\x3f\xfd\x9a\x5d\x27\x5a\ +-\x19\xb4\x0e\x60\x9f\x18\x27\x24\x34\x9c\xb8\x84\x59\xcc\x32\xa5\ +-\x23\x14\x85\xa6\x86\x1a\xaa\x4e\x1d\x26\x32\x32\x86\x45\x05\xcb\ +-\x69\xec\x15\x0c\x06\x1c\xb6\xee\xdb\xc9\xf3\x17\x69\xbb\xd1\xed\ +-\xe3\xcb\x5f\x90\x35\xae\xd7\x6b\x8e\x69\x73\xe3\xc4\x68\x43\xb7\ +-\x7b\x3f\xb0\x09\x40\x55\x82\x98\x93\xe3\xdf\x86\x6f\x0f\xf4\x71\ +-\xf4\xd0\x6e\x6e\x75\x77\x02\x10\x19\x79\xbf\x6e\xa7\x9e\xde\xa3\ +-\x5e\x23\x5c\xed\x7f\x5b\xd9\xf1\x8f\xfd\x3e\xfb\x39\x99\xa9\x64\ +-\xa5\x27\xef\xce\x8d\x13\xa3\x5a\x00\xa1\x2a\x3b\xa4\x46\xfd\x11\ +-\x12\x5d\x7c\xa8\x24\xca\x20\xb8\xe3\xdb\x1c\xb9\xd1\x7e\xd5\x43\ +-\x3e\x9d\x35\xb6\xdf\xe6\xe4\xf9\x8b\x9c\xa9\xbe\xc4\xb9\xaf\x9a\ +-\x7c\x4e\x59\x45\x51\xd8\xbc\xe1\x7b\x4e\x55\xab\xfc\x1e\xee\x1e\ +-\xc7\x79\x26\xd1\x56\xdf\xed\x7e\x43\xc0\x2f\x34\x0a\x2c\x4a\x54\ +-\xf9\xbc\x43\xf9\xb6\x73\x89\xc7\xea\xaa\xcf\x52\x57\xed\xef\x57\ +-\x14\xc1\xcb\x2f\x3c\xcd\xc3\xf3\x32\xfe\xbc\x38\x5e\xb4\xc3\xdd\ +-\x81\x04\x60\xd8\xa1\xbc\x0a\xb2\x06\x20\xc2\x00\x69\x91\x0f\x66\ +-\x8f\x88\x8e\x79\xe0\xfe\x54\x8b\x8e\x0c\xe7\xf5\xdf\xfc\x94\xf5\ +-\xab\x1e\xa9\x0e\xb3\x29\xbf\xbd\xe7\xf7\x34\xfd\x92\x74\x61\xaf\ +-\xed\x97\xe5\x5a\xa7\x5a\x0b\x98\xe6\xc5\x49\x86\xec\x82\xdb\x53\ +-\x5e\x45\x48\x68\x38\x2b\xca\xd6\x91\xbd\x20\x7f\x5a\x52\x21\x04\ +-\xb3\x53\x92\x78\x6a\xe5\x77\x78\xb2\xa4\x00\x63\x70\x50\x8f\xa2\ +-\x2a\xdf\xcf\xca\x12\x9e\x2a\xf1\x1b\xcb\xeb\xbb\xe4\x42\xa1\xa8\ +-\x47\x80\x64\x09\xf4\x0c\x09\xea\xcd\x82\x86\xda\x2f\x18\xbc\x63\ +-\xa1\x70\xc5\x6a\xf4\x41\x3e\xe3\x03\x6d\x2d\x8d\xdc\xb6\xf4\x31\ +-\x61\xb7\x13\x1f\xae\x65\x76\x82\x91\xa4\x84\x68\xb2\x67\x9b\x88\ +-\x8a\x08\xbb\x07\xeb\x52\x55\x65\xcd\x12\x93\x68\xf2\x11\x19\x48\ +-\x79\x43\xaf\x8c\x45\x75\x7f\x04\xa2\x18\xe0\x5c\x87\x82\x75\x4c\ +-\x22\xc4\xb4\x7f\x72\x14\xa7\xab\x3c\x64\x9c\xea\x95\xd5\x2e\x9d\ +-\xa6\x62\x69\x9c\xb8\x35\x75\x47\x99\xea\x00\x58\x9c\x28\x06\xc2\ +-\x6c\x9a\x55\xc0\x76\x60\x4c\xaf\x99\x9e\x3c\x3a\x04\x16\x25\xca\ +-\xa9\xe4\x0e\x24\xaf\x85\xd9\x34\x25\x81\xc8\x61\x06\x3f\xa7\xb5\ +-\xfd\x32\xe1\x4a\xa7\xfc\xa8\x73\x50\x14\xba\xd4\xc0\xf8\xb4\x28\ +-\xc9\xa2\x24\x9f\xa2\x1d\x13\x92\x3d\x2e\x9d\xb2\xa3\xe0\x6e\xb5\ +-\x7f\x93\x4d\xff\x4c\xef\xda\x07\x17\x64\xa2\x4b\xaa\xbf\xb4\x39\ +-\x45\x99\xdd\x25\x4c\xe3\x4e\x8c\x6e\x15\x45\x05\xe6\x27\xc8\x91\ +-\xcc\x68\xf5\x8a\x44\x5c\x94\xaa\x3c\x13\xac\xd7\x1c\xcd\x8d\x13\ +-\xa3\x33\xc9\xfb\x3f\xd5\x8a\xed\x13\x27\x02\xa0\xfb\x00\x00\x00\ +-\x00\x49\x45\x4e\x44\xae\x42\x60\x82\ +-\x00\x00\x10\xb6\ +-\x89\ +-\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\ +-\x00\x00\x40\x00\x00\x00\x40\x08\x06\x00\x00\x00\xaa\x69\x71\xde\ +-\x00\x00\x00\x04\x73\x42\x49\x54\x08\x08\x08\x08\x7c\x08\x64\x88\ +-\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0d\xd7\x00\x00\x0d\xd7\ +-\x01\x42\x28\x9b\x78\x00\x00\x00\x19\x74\x45\x58\x74\x53\x6f\x66\ +-\x74\x77\x61\x72\x65\x00\x77\x77\x77\x2e\x69\x6e\x6b\x73\x63\x61\ +-\x70\x65\x2e\x6f\x72\x67\x9b\xee\x3c\x1a\x00\x00\x10\x33\x49\x44\ +-\x41\x54\x78\x9c\xcd\x9b\x79\x7c\x55\x45\x96\xc7\xbf\x75\xef\xcd\ +-\xcb\xbe\xef\x8f\x40\xd8\x95\x1d\x42\x02\x88\x0e\x04\x11\x05\x45\ +-\x11\x5a\x47\xe4\x23\xbb\x1f\x46\xdb\x71\x9b\xd6\x19\x9d\xed\xe3\ +-\xa7\xfb\xd3\xfd\x69\x5b\xc7\xb5\x6d\x07\x51\x36\x31\x2a\x22\x88\ +-\x8d\xf4\x20\x9b\x18\x10\x24\x31\x21\x40\x80\x84\x26\x10\x42\xf6\ +-\x7d\x7b\xc9\x5b\xee\xad\xf9\x23\x24\x64\x79\xb9\x79\x59\xb0\xfb\ +-\xf7\xd7\xab\x3a\x55\xa7\x4e\x9d\x5b\x75\xea\xd4\x39\xf5\x04\x37\ +-\x19\x9b\x4f\xc9\x71\x86\xcb\x58\xed\x70\x29\x49\x0e\x9d\xa1\x76\ +-\x9d\x08\xa7\x0b\x8b\x21\x51\x9d\x06\x42\x00\x9a\x82\xf4\x52\x71\ +-\xcd\x1c\x22\x73\xfc\xbd\xe5\x19\xe0\x02\x42\x66\xab\x8a\x9a\x3a\ +-\x29\x46\x94\xdd\x4c\xf9\xc4\x80\x73\x94\x52\x6c\xce\x60\x55\x93\ +-\x93\xa7\x6a\x9b\x18\x6f\x73\xe2\xed\x69\xd7\xd1\x91\x92\xb1\x51\ +-\xb2\x23\x37\x49\xb6\x50\xf8\x16\x94\x4f\x13\xac\x22\x7d\xa0\xc5\ +-\x1d\x30\x05\x6c\xc8\x92\xc3\xa4\x9d\x77\x6a\x6c\xcc\x6b\x70\x78\ +-\x3e\x69\x21\x20\x36\x50\x52\xd1\x28\x98\x33\xd2\xc0\x57\x33\x6d\ +-\x7e\x4e\xc0\xa6\x46\x8b\xb2\xfe\x8e\x48\x51\xdf\x6f\xa1\x19\x00\ +-\x05\x6c\x3d\x2e\xc7\xd4\x49\x36\x55\xd9\x98\xe6\x32\xcc\xf9\xc5\ +-\x04\x4a\xa2\x03\xa1\xb0\x16\x62\x03\x41\x15\x10\xe6\x27\x29\xaa\ +-\x13\x54\x35\x41\x62\x9c\xc4\xa2\x7a\x34\x6c\xb5\x84\x77\xbc\x5c\ +-\xca\xdb\x13\xe3\x45\x75\x7f\xe4\xef\xb3\x02\x5e\xc9\x96\x96\xe8\ +-\x3a\x63\x4b\xb9\x4d\x79\xc4\xa5\x7b\xc6\xc7\xd7\x0b\x46\x86\x4b\ +-\xe2\x82\x25\x42\x80\x45\x85\x9c\x72\xc1\xf9\xb2\x96\xee\xe1\xfe\ +-\xf0\x0f\x43\x8d\xde\x88\x51\x25\x04\xbf\x9e\x1c\xab\xbc\x2b\x84\ +-\xe8\x55\xc7\x56\xf4\x49\x01\x3f\x15\xc8\x91\xb9\x55\xc6\xbe\xf3\ +-\xa5\xca\xf0\xde\xf4\xb3\xa8\x70\xf7\x68\x03\x4d\x69\x29\x4b\xa0\ +-\xbc\x41\xd0\xec\x82\xba\x66\xa8\x77\xc0\x6d\x43\xa4\x29\x0f\xf7\ +-\x90\xc7\x0c\x5d\x5d\x99\x38\x44\x5c\xea\x6d\xcf\x5e\x2b\x60\xc7\ +-\x59\xfd\xf9\x9a\x26\xf1\xfb\xaa\x46\x61\x89\x0d\x92\x54\x37\x41\ +-\x45\xa3\x67\x6c\x84\x80\xd1\x11\x12\x45\x80\x97\x0a\xc3\xc3\xfa\ +-\x32\x59\xf7\x90\x50\x2f\x90\xeb\x12\x06\x69\x9f\xf5\xa6\x9f\xb9\ +-\xc9\x69\x87\xed\x52\xaa\xae\x2c\xf6\xf8\x6a\x72\x7e\x4e\xbd\x20\ +-\xd2\x5f\x32\x2c\x54\xe2\xd4\x05\x15\x8d\xdd\xf7\xf3\xb7\xc0\x90\ +-\x10\x49\x49\xbd\x40\x08\xd0\xd4\x16\xa3\x17\x60\xf1\x5c\x48\xbb\ +-\xc3\x89\xb7\xc5\xcb\xb4\x8d\x80\x40\x10\x9f\x66\x14\xe9\x49\x53\ +-\x62\x95\x17\x3d\xdd\x12\x1e\x7d\xba\x6d\x27\x64\x50\xb5\x2e\x4f\ +-\x4f\x88\x95\xf1\x27\xae\x2a\xd8\x1c\x10\xe0\x0d\x0a\x50\x67\x87\ +-\x48\x7f\x89\xa6\x42\x71\xdd\x0d\x76\x01\x16\x48\x18\x64\x10\xe6\ +-\x07\xf5\x8d\x36\x6a\x9a\x20\xdc\x4f\xc1\xcf\xcf\xc7\x93\x21\x01\ +-\xb8\x5c\x50\xc2\x9b\x1f\x7e\xc9\xb2\x45\x77\x32\x23\x61\x8c\xc7\ +-\xfd\x80\x14\xa3\x58\x59\x95\x98\x28\x9c\x3d\x35\xec\x71\x05\xfc\ +-\x39\x5d\xfa\xe5\xd9\xc9\x6d\xb4\x8b\xe8\x8b\x15\x60\x73\x80\x97\ +-\x02\xf1\x21\x92\x06\x07\xd4\x3b\x04\xe5\x8d\x82\xaa\xf2\x52\xf2\ +-\x2f\xe7\x52\x51\x56\x4c\x6d\x55\x25\xcd\x0d\x95\x54\x56\x56\xe1\ +-\x74\xe9\x5d\x78\xfa\xf9\x78\x13\x15\x19\xca\xff\xfc\xc7\x3a\xa2\ +-\x23\x42\xbb\xd0\x6d\xb6\x66\x36\x7e\xb1\x8f\x1d\x7b\x53\x71\xe9\ +-\x3a\xcb\x16\xdd\xe9\xe9\xc4\x5b\xb1\x4c\x58\x65\x70\x7a\xba\x5c\ +-\xdc\x93\x12\x4c\x15\xf0\x8a\x94\x4a\xfe\x0f\x9c\xae\x6c\x24\x1a\ +-\xa0\xa0\xa6\xe5\x0b\x3b\x0d\x38\x53\x2c\xc9\xcb\x3d\x47\x4e\x76\ +-\x26\x57\xf3\x72\x69\x6c\xa8\xf3\x58\x3a\x5b\xb3\x9d\x2b\x05\x25\ +-\xd8\xed\x8e\x0e\xf5\x52\x4a\xf6\xa7\x66\xf0\xde\xd6\xaf\xa9\xac\ +-\xf1\x9c\x9f\x3b\x08\x29\xef\x13\xb1\x72\x8b\x94\xf2\x31\xb3\xed\ +-\x60\xaa\x80\xe8\x1f\x49\x2b\x6e\x64\x44\xfb\x3a\x97\xd3\x49\x56\ +-\xfa\x31\xd2\x8e\x1d\xa2\xa1\xbe\xb6\x5f\x42\xb6\xc7\xa5\xfc\x22\ +-\xde\xf8\x70\x27\x59\xe7\x7b\x6d\xc8\xcd\xf0\xe8\xe1\x4b\x46\x3d\ +-\xf0\x4f\xdd\x35\xe8\x56\x01\x1b\xd3\xe4\x1b\x57\xaa\x49\x68\x5f\ +-\x97\x97\x9b\xcd\x81\x3d\x5f\x50\x57\xdb\x2f\xdf\xa3\x03\xec\x0e\ +-\x27\xef\x6f\xfb\x33\xbb\xf6\x1d\x43\xd7\xfb\x74\x94\x9b\xc2\x69\ +-\x88\x75\x1f\xa5\x49\xfb\xda\x24\xf1\x8c\x3b\xba\x5b\x05\xa4\xa4\ +-\xcb\x3b\xf2\x6a\x79\xae\xb5\x6c\xe8\x3a\x07\xf7\x7e\x49\x56\xfa\ +-\xb1\x01\x17\xb0\xb4\xbc\x8a\x1d\x7b\x53\x07\x9c\x6f\x2b\xc2\xfc\ +-\x24\x5e\x8a\x5c\x9d\x56\x2a\xdf\x4a\x8a\x16\x79\x9d\xe9\x4a\xe7\ +-\x8a\xed\xdb\xa5\x5a\x62\x63\x8f\xe3\xba\x77\xe7\x74\x3a\xf8\x62\ +-\xeb\xfb\x37\x65\xf2\x3f\x07\x54\x01\x21\xbe\x04\x94\x57\xcb\x5d\ +-\xdb\xb7\xcb\x2e\x8e\x76\x17\x05\xd4\x0e\x35\x36\xd7\x34\x13\x0c\ +-\x2d\x5f\xfe\xeb\xcf\x37\x51\x70\xe5\xe2\xcf\x21\xeb\x4d\x43\x95\ +-\x0d\x32\x8b\xc4\xc4\xda\x78\xe3\xa3\xce\xb4\x0e\x0a\xd8\x7d\x41\ +-\x5a\xcb\x1a\x94\x65\xad\xe5\xd4\x83\xdf\x70\xf9\xe2\x39\x8f\x07\ +-\x0a\x09\x0a\x20\x79\xc6\x44\x1e\x5f\xba\x80\x7b\xe7\x4c\xeb\x97\ +-\xd0\x03\x85\xf3\x65\x82\xef\x2f\x2b\xd8\x5d\x50\xd2\xa0\x2c\xff\ +-\x24\x43\xc6\xb7\xa7\x77\xb0\x01\xe5\x75\x6c\xb5\xbb\x5a\x94\x72\ +-\x2d\x3f\x8f\xf4\x1f\x0e\x79\x34\xc8\xd0\xc1\x31\xac\x5c\x32\x8f\ +-\x39\x33\x27\xa1\xa9\x2d\xab\xec\x44\xc6\x79\xf6\x1e\x3e\x39\x30\ +-\xb3\xe8\x23\x1a\x9d\x90\x5b\x71\xc3\x39\x73\xea\x28\x0d\x4e\xb6\ +-\x00\xc9\xad\x75\x6d\x0a\xd8\x7e\x51\x46\xe6\x17\xb5\x10\x34\x05\ +-\xd2\xbf\xdb\x8d\x94\xe6\xbe\xba\x10\x82\x47\x16\xce\x66\xdd\xb2\ +-\x7b\xb1\x78\x99\xbb\xaa\x7f\x0b\x54\xda\x04\x9d\xa7\x50\xd6\xc0\ +-\xac\xf7\x4f\xc9\x41\x4f\x4e\x16\x85\xd0\x4e\x01\xa3\xfc\x8c\x95\ +-\x23\x47\xa2\xd6\xdb\x21\x2b\x3b\x87\xbf\xe6\x5d\xe9\x71\x80\xa7\ +-\x56\x3c\xc0\xd2\xfb\x93\x07\x54\xe8\x81\x42\x79\xa3\xe0\x6c\x71\ +-\x57\x4f\xdf\xa9\x23\x34\x3b\xef\x01\x0f\x42\x3b\x05\x18\x92\x95\ +-\x42\x40\xa0\x37\xec\x3f\x72\xa2\xc7\x01\x96\xde\x9f\xfc\xb3\x4c\ +-\xde\x4b\x53\x09\x0a\xf2\x73\x4b\xb3\x35\xd9\xa9\x6f\xb4\xa1\xaa\ +-\x0a\x81\xfe\x7e\x78\x5b\xbc\x30\x24\xfc\x78\x55\x50\xd6\x20\xe8\ +-\x6e\xfd\x56\x36\xb1\xa0\xf5\xb7\x06\x90\x59\x2c\x93\xa4\x61\x8c\ +-\x87\x16\xc7\xe4\xf8\x4f\xe7\x4d\x85\x8a\x8a\x08\xe1\xf1\xa5\x0b\ +-\x4c\xdb\x0c\x04\xa6\x4d\xba\x85\xe7\xd6\x2e\x61\x88\x35\x0a\x80\ +-\xe2\xb2\x2a\x8e\x67\x9e\xe7\x44\xc6\x39\x2e\x5c\x2a\xa0\xaa\xe6\ +-\x46\x54\x4c\x51\x04\x71\x31\x91\x0c\x1d\x39\x86\x61\xe3\xa7\x13\ +-\x19\x3d\xa8\x5b\xbe\x36\x07\x96\xad\x69\x72\xf9\x8a\x24\xf1\x71\ +-\xcb\x0a\x90\xc6\xa3\xad\xc4\xb3\x39\x57\xb0\x35\xdb\x4d\x05\x7b\ +-\x62\xd9\x42\x7c\xbc\x7b\x71\x9f\xed\x25\x62\x22\xc3\x78\x7a\xe5\ +-\x22\x66\xcf\x98\x08\xc0\x99\x9c\xcb\x6c\xdd\xb1\x9f\x13\xa7\x2e\ +-\x74\x6b\x97\x0c\x43\x72\xb5\xa8\x8c\xab\x45\x65\xa4\xa6\x7e\xcf\ +-\xb8\xc9\xd3\xb8\x73\xc1\x12\x2c\xde\xee\x6f\x9f\x8d\x3a\xcf\x00\ +-\x2d\x0a\x90\x92\xbb\x5b\x09\x17\xaf\x14\x9a\x0a\x17\x1c\xe4\xcf\ +-\x9c\x99\x93\xfb\x34\xb1\x9e\x60\xd1\x34\x1e\x5d\x74\x27\xcb\x97\ +-\xcc\xc5\xc7\xdb\x42\x79\x55\x2d\x7f\xda\xfa\x35\xfb\x8f\x66\xf4\ +-\x8a\x8f\x94\x92\xb3\x99\x3f\x52\x5a\x74\x8d\x87\x56\x3c\x81\x7f\ +-\x40\x50\x97\x36\x75\xcd\x8c\x07\xd0\xb2\x4a\x64\x94\xae\x1b\x63\ +-\x5b\x09\x97\xf2\x8b\x4c\x99\x4f\x9f\x7c\x2b\x5e\x9a\x67\x91\xcb\ +-\xde\x60\x66\xc2\x58\x9e\x59\xb3\x98\xb8\x98\x08\x9c\x2e\x9d\x94\ +-\xaf\x0e\xb1\x79\xc7\xb7\x3d\xae\x46\x33\x94\x97\x16\xf2\xf5\x67\ +-\x1b\x79\x64\xf5\xd3\x28\x6a\x47\x99\x1b\x1d\xf8\x7c\x98\x26\xc7\ +-\x6b\xba\x4b\x9f\x85\x10\x02\x5a\x82\x1b\x7f\x2d\x32\x8f\x36\x8f\ +-\x1b\x35\xb4\xcf\x02\xb9\x83\x9f\x9f\x0f\xaf\xbe\xf4\x38\xb7\x27\ +-\x8e\x03\xe0\x64\x56\x0e\x6f\x7d\xb4\x93\xab\x45\x03\x93\x0f\x29\ +-\x2c\xb8\xcc\x89\xd4\x6f\x99\x99\xdc\xd5\x66\x29\x18\xcb\x35\x29\ +-\xc4\x78\x01\x48\x09\x99\x85\x0a\x8d\xb6\x66\x53\x86\x83\x63\x23\ +-\x07\x44\xb0\x56\x44\x84\x06\x13\x91\x18\x4c\x49\x79\x15\xef\x6e\ +-\xd9\xcd\x91\x13\xa7\x07\x94\x3f\x40\xda\xb1\xc3\x24\x4c\x9f\x8d\ +-\x8f\x6f\xc7\xd3\xc4\xe1\x12\xd3\xb4\xbc\x4a\x31\xaf\xa6\x19\xaa\ +-\x6d\x82\x06\x07\xd8\x1d\xe6\x0a\x08\x0c\xf0\xed\xb7\x40\x16\x4d\ +-\xe3\x91\x07\x92\x89\x89\x0e\xc7\xe1\x74\x92\xb2\xfb\x30\xdb\x76\ +-\x1d\xa4\xb9\x53\x80\x64\xa0\xe0\x74\xd8\x39\x75\xf2\x28\x33\x66\ +-\xdf\xdd\xa1\xbe\x59\x17\xc3\xb5\x2b\xd5\x4c\xae\xb7\xdf\x70\x18\ +-\xbc\x54\xf3\xfd\x6d\xf1\xf2\x38\x8e\xea\x16\xed\xf7\xfa\xb1\xf4\ +-\x6c\xde\xde\xb4\x8b\xa2\xd2\x4a\x8f\xfa\x46\x85\x87\x90\x7c\xdb\ +-\x24\x26\x8f\x19\x41\x54\x44\x30\x0d\x8d\xcd\x5c\xb8\x54\xc0\xe7\ +-\x7b\x8e\x50\x5d\x6b\xbe\x75\x2f\x9e\xcf\xea\xa2\x00\x97\x2e\xc3\ +-\xb5\x61\x61\x34\x9d\x29\xc1\xaf\xf5\x74\xb1\x58\xcc\x8f\x37\xbb\ +-\xb3\xc7\x38\xa3\x5b\xc4\xc5\x44\xf0\xcc\x9a\xc5\xcc\x4c\x18\xcb\ +-\xb5\x92\x0a\x5e\xfc\xed\x07\x1c\xcf\x34\xf7\x37\x5a\x11\x1e\x12\ +-\xc4\xe3\x4b\x17\xb0\x60\x4e\x52\xdb\x5d\xa3\x15\x89\x13\x47\x33\ +-\x3f\x39\x89\xb5\x2f\xff\x91\xca\x8a\xf2\x6e\x79\x94\x96\x14\x52\ +-\x5f\x5b\x43\x60\x70\x48\x5b\x9d\xc3\x10\xde\xda\xf0\x30\x29\xbc\ +-\x14\x38\x53\x22\x70\xe8\x20\x34\x73\x05\x54\x55\x37\x78\x24\x74\ +-\x2b\x7c\x7d\x2c\xac\x58\x32\x8f\x47\x1e\x48\xc6\xd0\x0d\x3e\xf8\ +-\x74\x2f\x9f\xed\x3e\x8c\xc3\xe5\xea\xb1\xaf\xa6\xaa\x3c\x7c\xdf\ +-\x2c\x56\x3f\x7c\x0f\x7e\xbe\xdd\xa7\x1b\x7d\xfd\x83\xb8\x67\xf1\ +-\x63\xa4\x6c\x78\xb3\x7b\x66\x52\x52\x5c\x98\xdf\x41\x01\xba\x8e\ +-\xaa\x01\x01\x83\x43\x5a\xd2\x55\x35\xcd\x90\x1a\x16\x40\xbe\x49\ +-\x58\x2e\xef\x6a\x31\x77\x24\x8d\xeb\x51\x78\x21\x04\x77\xdd\x3e\ +-\x85\x5f\xae\x78\x80\xa8\xf0\x10\x0e\x9f\xc8\xe2\x8f\x9b\x77\x53\ +-\x5a\xe1\x59\x38\x2d\x71\xe2\x68\x9e\x5f\xb3\x84\xf8\xb8\x68\x0c\ +-\xc3\x3c\x54\xe6\xe7\x05\x71\x71\x43\x19\x34\x78\x18\x85\x05\x97\ +-\xbb\x6d\x57\x55\x5e\xda\xa1\xac\x1b\x88\xb6\x78\x80\x10\x10\xea\ +-\x0b\x13\x46\x44\x99\x0e\x76\xe2\x54\xcb\xb2\x35\x68\xb9\x70\x9c\ +-\x29\x69\xf1\xbb\x3b\x67\x87\x92\x26\x8d\xe6\x95\xe7\x57\xd0\xd4\ +-\x64\xe7\xb9\x5f\xbf\xcf\x7f\xbd\xbe\xd9\xa3\xc9\x47\x47\x84\xf2\ +-\x9b\x17\x56\xf1\xd6\x7f\x3f\x89\xaf\xaf\x37\xaf\xbc\xb9\x95\xb4\ +-\xac\x5c\xd3\x3e\x42\xc0\xad\xd1\x92\x61\xa3\xcd\x73\x07\x95\x15\ +-\xa5\x5d\xea\x34\xa0\x01\x08\x6b\xad\x88\x8f\x8b\x36\x65\x72\xfa\ +-\x7c\x1e\xc7\x4f\xe7\x53\x69\x19\x86\x4b\x07\x1f\x0d\xf2\xae\xdb\ +-\xb0\xd8\xa0\x96\x4c\x50\x98\x1f\x5c\x2e\x77\x71\xe4\xe0\x3e\xf6\ +-\x1d\x38\x82\x4b\xef\x9a\x1b\xe8\x0c\x8b\xa6\xb1\x74\xd1\x1c\x56\ +-\x2c\xb9\x0b\x45\x55\xf8\x78\xe7\x01\xb6\xee\xdc\x4f\x53\xb3\x83\ +-\xf9\xb3\x93\x7a\xec\x3f\x3a\x42\x92\x78\x4b\x2c\x47\x0f\x76\xdf\ +-\xa6\xa9\xb1\xe3\xf6\x55\x15\xa4\x06\xd4\xd3\x4e\x01\x63\x47\x0e\ +-\x41\x08\x61\x1a\x0b\x78\xf5\xfd\x14\x1e\x5e\xf5\x34\xfe\x01\x41\ +-\x68\x2a\x34\x5f\xdf\xce\x45\x75\x02\x5d\xd7\xc9\x3e\x75\x92\x63\ +-\x87\xf6\x7a\x9c\x2b\xb8\x6d\xca\x18\x9e\x5d\xbb\x84\xb8\x98\x08\ +-\x7e\xc8\x38\xc7\x3b\x1b\x77\x71\xad\xa4\xc2\xa3\xbe\xed\x31\x66\ +-\x70\x80\x29\xdd\xe9\xec\x78\xcc\xaa\x2a\xba\x06\x54\x00\x6d\x61\ +-\xa2\xe8\x88\x50\x46\xc6\x5b\x4d\xef\x04\x15\xe5\x65\x6c\x7e\xef\ +-\x55\x12\x67\x26\x13\x6d\x1d\x8c\xb7\xb7\x2f\x75\x75\xd5\x14\xe6\ +-\x5f\x22\xe7\xec\x29\x8f\x27\x6e\x8d\x0e\xe7\xd9\xd5\x8b\xb9\x3d\ +-\x71\x1c\xd7\x4a\x2a\xf8\xd7\xdf\x6d\xe0\x87\x0c\xcf\x43\x70\x9d\ +-\xe1\xd3\xc3\x09\xe6\xb0\x77\x74\xab\x2d\x8a\xb4\x6b\x40\x2e\x30\ +-\xb5\x3d\x61\xf6\x8c\x89\x3d\x5e\x8a\x9a\x6c\x0d\xa4\x1e\xd8\xd3\ +-\x37\x41\xbd\x2d\x3c\xb6\x78\x2e\xcb\x16\xcd\x01\x21\x58\x9f\xf2\ +-\x0d\x9f\x7f\xfd\x9d\x47\x27\x83\x19\x7a\x3a\xa2\x0d\xd9\x71\x2b\ +-\xfa\x5a\x44\xb1\x26\x20\xa7\xf3\x62\x5f\x72\xcf\xed\x7c\xb2\xfb\ +-\x10\x4d\x4d\x7d\xbf\x88\x74\x87\xd1\x63\x27\x71\xf7\x7d\x0f\x92\ +-\x38\x32\x14\x2f\x2f\x49\x41\x61\x29\x1f\xef\x3c\x30\x20\xbc\x6b\ +-\xeb\x6d\xa6\xf4\x60\x7f\x1f\x62\x02\x24\xde\x5e\x30\x2c\x54\x12\ +-\xe2\xc3\x16\x4d\x0a\x79\x16\xd9\xd1\x82\x07\x05\xfa\xb3\x74\x61\ +-\x32\x9b\xbe\xd8\x37\x20\x82\x01\x84\x86\x47\x31\xf7\xbe\x5f\x30\ +-\x74\xc4\xad\x00\xec\x3e\x72\x96\xa4\x31\x71\x0c\xed\x7a\x53\xed\ +-\x33\x0a\x8a\xba\x77\x84\x00\xa2\x42\x7d\x99\x11\x7f\xe3\x73\x4b\ +-\x21\xb3\x35\x55\x51\x53\x75\xdd\x90\x74\x4a\x95\xaf\x7c\x68\x1e\ +-\x69\x59\x39\x9c\xcd\xbd\xd2\x2f\xa1\x2c\x16\x6f\x6e\x9b\x7d\x0f\ +-\x09\xb7\x25\xa3\xaa\x2a\xd5\x55\x15\x1c\xfe\xcb\x4e\xf2\x72\xb3\ +-\x89\x7a\xf6\xdf\x19\x64\x6e\xb7\x7a\x85\xec\xdc\xee\x7d\x00\x68\ +-\xf1\x28\xdb\xc1\x90\xa8\xa9\xda\xa4\x18\x51\xf6\xd3\x35\x3d\x5b\ +-\x88\x96\x00\x41\x2b\x34\x55\xe5\x77\x2f\xae\xe6\x57\xbf\xfd\xa0\ +-\x47\x7b\xd0\x1d\xc6\x4c\x98\xca\xec\xbb\x17\x11\x10\x14\x8c\xd3\ +-\xe9\xe0\xf8\x77\xfb\x48\x3b\x76\x10\x5d\x6f\xd9\xeb\x4e\xe3\x46\ +-\xc6\xb9\xbf\x70\xb8\x5c\x9c\x3c\x65\xee\x2f\x8c\x88\xb7\xb6\xfd\ +-\x96\x90\x95\x68\x15\x15\x1a\x80\xa2\xb0\x5f\xca\x8e\x0a\x00\x08\ +-\x0b\x0d\xe2\xbd\x5f\xff\x33\xaf\x6f\xfc\x8a\xfd\x47\x4e\xf6\x18\ +-\x26\x07\x40\x08\x46\x8c\x1a\xcb\xb4\x59\xf3\x18\x34\x78\x18\x00\ +-\xb9\xe7\xb2\xf8\x6e\xdf\x57\xd4\xd5\x54\x75\x69\x5e\x54\x37\x30\ +-\x0a\x38\x78\x34\x93\xfa\x46\x73\x1b\x30\x6a\xa8\xb5\x7d\xf1\x00\ +-\x5c\x0f\x8a\x4a\x94\x14\x30\x9e\x77\xd7\xc9\xcf\xcf\x87\x07\x7f\ +-\xf1\x28\xd6\xb1\xc9\x9c\xc9\xfc\x91\xcb\x17\xcf\x53\x5d\x59\x8e\ +-\x94\x37\xdc\xd3\x80\xa0\x60\xa2\x63\x07\x33\x7c\xd4\x58\x86\x8f\ +-\x1e\xd7\xe6\x6f\x57\x57\x96\x71\xf0\x9b\x2f\xb9\x72\xe9\x42\xb7\ +-\x42\x35\xf7\xcf\xf0\x03\x2d\xd1\xe1\xf5\x9f\x7c\x63\xda\xc6\xdf\ +-\xcf\x97\x71\xb7\x0c\x6d\x2b\x2b\x52\x49\x81\xeb\x0a\x48\xb0\x8a\ +-\xf4\x9f\xae\xe9\x67\x3b\x6f\x83\x56\xc4\x04\x42\x44\xb4\x95\x39\ +-\xf3\x17\x33\x67\xfe\x62\x5c\x2e\x27\x0e\x7b\x33\x86\x6e\xe0\xe3\ +-\xeb\x87\xe6\x26\x29\x52\x5c\x98\xcf\x67\x1f\xbd\x8d\xee\x81\x17\ +-\xd8\x5f\xfc\xef\x27\x7b\xa8\xa8\x36\x7f\xab\x70\x7b\xe2\x58\x2c\ +-\x5a\xdb\x55\xfe\xdc\x94\x38\x71\x0a\xda\xe5\x06\x15\xc1\x96\xee\ +-\x3a\x17\x75\xf2\x6b\x34\xcd\x0b\x3f\xff\x40\x02\x82\x82\xdd\x4e\ +-\x1e\xa0\xd9\xd6\x38\x60\x93\xaf\x6e\xea\x9e\xb6\x6d\xd7\x41\x76\ +-\xfe\xdf\xd1\x1e\x79\x2c\x9c\x3b\xe3\x46\x41\xd2\x96\x24\x6d\x53\ +-\x40\xa3\x45\x59\x0f\xb8\xbd\xad\x34\xde\x9c\x40\x8d\xc7\xc8\x29\ +-\x17\xa4\x5e\x51\x28\xa8\xbd\x61\x2f\xec\x0e\x27\x6f\x6f\xdc\xc5\ +-\xfa\x14\xf3\xa5\x0f\x30\x69\xcc\x08\x12\xc6\x8d\x6c\x2d\x56\xd9\ +-\xbc\x95\x0d\xad\x85\x36\x05\x5c\x7f\x7b\xfb\xae\x3b\x06\x13\x62\ +-\x25\xbe\x7f\xc3\xd4\x9f\x04\x2a\x1b\x21\xa7\x4c\xe0\x70\xb9\xf8\ +-\xcb\x77\x69\xac\x7e\xe1\x75\xbe\xd8\xfb\x7d\x8f\x86\x59\x51\x14\ +-\x7e\xb9\x62\x61\x7b\x66\x6f\xb5\x7f\x67\xdc\x21\xbe\xa5\xb9\x94\ +-\xb7\x5c\x9a\xf1\x24\xd0\x21\xf2\x19\xe4\x0d\x09\x83\x24\x3f\x5c\ +-\xe9\x3e\xdd\x74\x33\x91\x93\x7d\x8a\xa2\x6b\xf9\x54\x96\x14\xf2\ +-\xc6\xb5\x4b\xd4\x35\x98\x5b\xfb\xf6\x78\x6c\xf1\xdc\xf6\x91\xec\ +-\x52\xc3\xae\xbc\xd3\x9e\xde\x41\x01\x13\xe3\x45\x75\x46\xa1\xeb\ +-\x25\x10\x5d\x1e\x12\x44\xfa\x4b\xac\xc1\x50\x58\x3b\x30\xc7\x56\ +-\x6f\x70\x36\xf3\xc7\x3e\xf5\xbb\x3d\x71\x1c\x6b\xff\x71\xfe\x8d\ +-\x0a\x21\x5f\x4c\x1c\x21\x3a\x58\xcb\x2e\x2f\x44\xa6\x58\xd5\x4d\ +-\x20\xdd\xbe\x87\x19\x1f\x2d\x51\xbb\xf4\xf8\xfb\xc4\xb4\xc9\xb7\ +-\xf0\x9b\x5f\xad\x44\x6d\x13\x58\x7e\x3f\x25\x56\xdd\xd6\xb9\x5d\ +-\x97\xe9\x08\x21\xa4\xa1\xab\x2b\x11\x74\x39\x57\x5a\x5f\x7b\xff\ +-\xbd\xe3\xe1\x7b\x67\xf1\xda\xcb\xeb\xda\xbf\x59\xa8\xd1\x35\x75\ +-\xb5\x10\xa2\x8b\xf0\x6e\xbf\x67\xe2\x10\x71\x09\x43\x3e\xee\x8e\ +-\x76\x4b\xa4\x24\xd0\xe3\xbf\x43\xb8\x87\xa2\x28\x24\xcc\x98\x45\ +-\x50\x70\x58\xcf\x8d\x7b\x81\xd8\xa8\x30\xde\xf8\xcf\x27\x78\x76\ +-\xcd\xe2\x76\x5f\x1e\xa4\x90\x6b\xdd\xbd\x10\x03\x93\x77\x82\x09\ +-\x71\xda\x8e\x8c\x22\xfd\x0d\x24\xff\xd2\xbe\x5e\x11\x30\x2a\x42\ +-\x92\x59\xd8\x37\x83\x18\x37\x64\x04\x73\xef\x7b\x88\xc8\x18\x6b\ +-\xcf\x8d\x3d\x44\x74\x44\x28\xcb\x16\xdd\xc9\xfd\x77\x4d\xef\xf2\ +-\x52\x45\xc0\x1f\x12\xac\xda\xce\xee\xfa\x9a\x66\x39\xa6\xc4\x2a\ +-\x2f\x64\x14\x19\x61\x02\x56\xb5\xaf\x1f\x12\x22\xf1\xd1\xe0\x74\ +-\x89\xa0\xc1\xc3\x90\x81\x7f\x40\x10\xc9\xf7\x2c\x62\xcc\x84\xa9\ +-\x2d\x51\xcc\x7e\x22\x2a\x22\x84\xc4\x09\xa3\x99\x3b\x73\x0a\x49\ +-\x93\x46\xa3\x28\x6e\x17\x73\xca\x64\xab\xf2\xb2\x19\x1f\x53\x05\ +-\x08\x21\x64\x7a\xba\x5c\x27\xac\x32\x0a\x29\xef\xed\x20\x40\x80\ +-\x64\xee\x08\x49\x69\x83\xe0\x74\xb1\xc0\xd6\x4d\x30\x46\x51\x55\ +-\x12\xa6\xcf\x62\x66\xf2\x7c\xb7\xb9\x7a\xcd\xcb\x42\x78\x54\x0c\ +-\x75\x35\xd5\x38\x1d\x5d\xb5\xa9\xaa\x1a\xb1\x51\x61\xc4\xc5\x86\ +-\x63\x8d\x0c\x63\x78\xbc\x95\xa9\x13\x46\xf5\x98\xa3\x14\x88\x3d\ +-\x7a\xb1\x58\x25\x06\x99\x3f\x9b\xf7\xe8\x53\x1c\x96\x52\x0b\x2e\ +-\x32\xd6\x03\x6b\xdc\xd1\x9b\x5d\x70\xf8\x52\xcb\x53\xb4\x56\x5c\ +-\xbe\x78\x8e\x93\x47\x0f\x71\xd7\xc2\x87\x08\x8f\x8c\xf1\x64\x18\ +-\x00\x1c\xf6\x66\xa4\x34\x10\x08\x2c\x3e\xbe\xf8\x59\x60\xde\xa8\ +-\x1e\xfe\x8c\xd4\x09\x42\xb2\x4d\x2f\x51\xd6\x78\xf2\x5c\xde\x63\ +-\xbe\x52\x4a\x91\x51\x64\xfc\x41\xc0\x0b\xee\xe8\xa7\x8a\x05\x57\ +-\xaa\x6e\xb0\x73\x39\x9d\xdd\xde\x13\x7a\x83\xd8\x20\xc9\xf4\xc1\ +-\x1e\x5b\x1b\x29\xe0\xb5\xc9\x56\xe5\x25\x77\x16\xdf\x1d\x3c\x3e\ +-\xd5\x85\x10\x72\xea\x20\xf5\x45\x21\xe4\x62\xdc\xdc\x19\x02\x3b\ +-\x05\x64\x07\x62\xf2\xd0\x62\x70\x3d\x44\x9d\x94\x72\xe9\x94\x41\ +-\xea\xbf\x79\x3a\x79\xe8\x85\x02\x5a\x31\xc5\xaa\x7d\xa5\x6b\x4a\ +-\x22\xc8\x0e\x2f\x9c\x6f\x86\x83\x34\x38\x44\x12\xe6\x51\x36\x5e\ +-\x7e\xaf\xaa\xca\xe4\xa9\x71\xda\xf6\xde\x8e\xd1\x67\x73\x2c\xa5\ +-\x14\x99\x85\xfa\x72\x84\x78\x0d\x88\xba\x5a\x2b\xc8\xb8\xd6\x7f\ +-\xeb\x1e\xee\x0f\xb7\x46\x4a\x42\x7c\x24\x5e\x3d\xbf\xc4\xa9\x92\ +-\x82\x97\x13\x62\x95\x0d\xbd\xf9\xea\xed\xd1\x6f\x89\x33\x2f\xcb\ +-\x10\x69\x31\x9e\x29\x69\x10\x2f\x9c\xc8\x17\x81\xfd\xe1\x35\xc5\ +-\x2a\x89\x0f\xf5\x68\x1e\x95\x48\xde\x36\xec\xca\x3b\x9d\x7d\xfb\ +-\xde\x62\xc0\x6e\x36\x9b\x4e\xca\x18\x17\xf2\x4f\xd5\x36\xb1\xa0\ +-\xc1\x81\xe7\xff\x8c\xba\x0e\x4d\x85\x85\xb7\x9a\x67\x81\xa5\xe4\ +-\x2c\xb0\xd1\xc7\xa2\x6c\x18\x17\x25\x7a\x97\xa7\xef\x06\x37\xe5\ +-\x6a\xb7\x35\x4d\x2e\x6f\xd2\x79\xaa\xce\xce\xc4\x06\x3b\xbe\x9e\ +-\xae\xcd\xfb\xc7\x1a\xa8\x1d\x25\x32\x80\xd3\x12\xf6\x2b\x52\x49\ +-\x69\x0d\x63\x0d\x24\x6e\xfa\xdd\x76\xeb\x4f\x72\x8c\xcb\x30\x56\ +-\x39\x75\x91\x60\xd7\x19\xe5\x70\x89\x08\x97\x81\xc5\x65\xa0\xb9\ +-\x0c\x84\x04\xbc\x14\x64\xb0\xaf\x6c\x9a\x19\x6f\x9c\x03\x91\x23\ +-\x24\x17\xa4\x22\xb3\x25\x6a\x6a\xa2\x55\xf4\x3e\x4b\xda\x0b\xfc\ +-\x3f\xcf\xc2\x42\x82\x41\x31\x16\x33\x00\x00\x00\x00\x49\x45\x4e\ +-\x44\xae\x42\x60\x82\ +-\x00\x00\x03\xb1\ +-\x89\ +-\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\ +-\x00\x00\x10\x00\x00\x00\x10\x08\x06\x00\x00\x00\x1f\xf3\xff\x61\ +-\x00\x00\x00\x04\x73\x42\x49\x54\x08\x08\x08\x08\x7c\x08\x64\x88\ +-\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0d\xd7\x00\x00\x0d\xd7\ +-\x01\x42\x28\x9b\x78\x00\x00\x00\x19\x74\x45\x58\x74\x53\x6f\x66\ +-\x74\x77\x61\x72\x65\x00\x77\x77\x77\x2e\x69\x6e\x6b\x73\x63\x61\ +-\x70\x65\x2e\x6f\x72\x67\x9b\xee\x3c\x1a\x00\x00\x03\x2e\x49\x44\ +-\x41\x54\x38\x8d\x5d\x93\x5d\x4c\x9b\x75\x14\xc6\x7f\xff\xb7\x6f\ +-\x8b\x6d\x0a\x2b\x8c\x41\xd9\x04\x5c\x1d\x96\x16\x27\xac\x2c\xab\ +-\xba\x10\x03\xce\x69\x9c\x2e\x12\x8c\x2e\x3a\x13\x89\x0e\x83\x9a\ +-\x5d\xe0\xc7\x05\xd1\x99\x18\xbd\x51\xb6\xcc\x45\x13\xa2\x75\xd3\ +-\x69\x1c\x31\xce\x68\xc0\x1b\x98\xd3\x18\x97\xe9\x36\x98\xb8\x15\ +-\x5a\xfa\xa1\x80\xb4\x0c\x3b\x69\xf9\x18\xb4\xd0\xf7\xef\xc5\xe4\ +-\x0d\xf3\x5c\x9d\x9c\xe7\x39\x1f\x4f\xce\x39\x82\xff\xd9\xd1\xf3\ +-\xf2\xd1\xf4\x32\xaf\xcd\x66\x70\x0a\x30\x59\x4d\x52\x7a\xcb\x64\ +-\x40\x4a\x4e\xa9\xaa\xe2\xab\xb6\x8b\xcb\xab\xf9\x62\xc5\xe9\xbe\ +-\x20\x2d\x33\xaa\xec\x09\x27\x44\x7d\x56\x03\xa3\x02\xf7\xdc\xaa\ +-\x31\xbb\x28\x28\xc9\x93\x48\x29\x11\x42\x64\x05\x74\x9a\x92\x4a\ +-\x5b\x55\x95\xc8\xe8\x05\x8e\x5d\x94\xb6\xf9\x05\x6d\xf8\xdc\x80\ +-\xdf\x1e\x1d\x19\x42\xa6\x53\x90\x4d\xf3\x54\xe3\x0e\xb6\xd5\x38\ +-\xf9\xe1\x97\x41\xce\x0f\x06\x79\xf5\xb9\xc7\x56\xfa\x9e\x4e\x8d\ +-\x88\x5d\xf5\xf5\x62\x51\x05\x98\x9c\x9c\x3e\xf3\x91\xef\xa8\x7d\ +-\x32\x36\x76\x83\x9c\xfb\xea\x6a\xe9\xfd\xa9\x9f\x37\x8f\x7c\xce\ +-\x9d\x1e\xd7\x2a\x44\x36\x2c\x6f\x90\x3e\x60\xaf\xf2\x8d\x5f\xd6\ +-\x75\x75\x9d\x70\x4f\xc6\xc6\x70\x94\xad\xe7\xf0\x81\x56\xb6\x54\ +-\x6d\xd2\xa9\x8b\x99\x25\x00\x8a\xd7\xe6\xeb\xb1\x85\x25\x38\x3b\ +-\xa6\x3c\xf9\xd9\x45\xf9\x88\x9a\x8c\x47\x9e\x0d\x8d\x04\x31\xdf\ +-\x94\x43\x47\xfb\x3e\x8a\x0a\x6d\x74\xf5\xfc\xa8\x93\xd7\xda\x72\ +-\x39\xb0\x7f\x2f\xaa\x6a\xe0\xf5\x8e\x4f\xb8\x9a\x9c\xc3\x5c\x58\ +-\x86\xb7\xee\x7e\x66\x2d\xe6\x37\xd4\x68\x7c\xe6\x01\x80\x6a\xb7\ +-\x83\xa2\x42\x9b\x9e\x78\x47\xa5\x03\xcf\xed\x9b\x98\x9b\xbf\xc6\ +-\xa7\x27\xfb\x18\x0a\x8d\xae\x92\x10\x61\x32\x1e\xe3\xe9\x67\x5a\ +-\x5d\xea\x5c\xd6\x58\x00\x60\x50\x14\x1d\x6e\xd9\xf3\x20\x45\x85\ +-\x36\x3e\xfc\xe2\x3b\x7a\x4e\xff\x8a\xd5\x62\x66\x7f\x73\x23\x3b\ +-\xee\xae\xe1\xec\xc8\x55\x3a\xde\xeb\x64\x34\x12\x24\x36\xf5\xb7\ +-\x49\xdd\xee\x2a\x48\x77\x82\x3a\x70\x29\xcc\xd7\x3f\xff\x81\x31\ +-\x77\x1d\x61\x7f\x84\xde\xde\x5e\xe6\xaf\x2d\xf0\x50\x83\x97\x96\ +-\x27\x76\x31\x95\x48\x52\x90\x9f\x47\x83\x27\x8f\xaf\x1c\x15\x84\ +-\x02\x7e\x92\xff\x24\x50\x37\xde\x6c\x1f\xad\xdd\x5c\xe1\xee\xbf\ +-\x14\xe2\xd0\xe1\x23\xfa\x14\xeb\x4b\xcb\x69\x6d\x6d\x62\x4b\xb9\ +-\x99\xf6\x77\x8e\x61\xb1\xe4\xd0\xd1\xde\x82\xd9\x08\x6b\x72\xb2\ +-\x00\x6c\xb0\xa4\x13\xaa\x94\xf4\xbd\xfd\x4a\xb3\xfb\xd0\xf1\x53\ +-\x0c\x87\xc7\xb1\x58\xad\xdc\xe6\xaa\x46\xd3\xb2\x84\x26\x66\x99\ +-\xf8\x6b\x82\xdf\x03\x51\x7d\x8d\x57\x12\xd3\xf8\x83\x51\x00\x9c\ +-\xe5\x6b\xba\x55\x55\x55\x7c\x56\x8b\xf9\xc5\xa6\xc6\xdd\x86\x50\ +-\xe2\xfa\x61\xf6\x75\x7f\xc9\xe0\x85\x33\xec\xdc\xbd\x87\xf9\xff\ +-\x8e\x75\x2a\xb5\xc4\xb9\xdf\x82\xbc\x7f\xfc\x5b\x16\x16\x33\x6c\ +-\xab\xae\x94\x9b\x9d\x8e\x83\x4a\xb5\x5d\x5c\x16\xd0\xe9\x5c\x27\ +-\x31\xab\xd7\xc7\x9f\x49\x4d\x03\x60\x34\x1a\x75\x49\xd1\x48\x98\ +-\xb6\xb7\x3a\x89\x8e\xc5\x71\x57\x94\xf3\xd2\xbe\x26\x9f\xa7\x44\ +-\x0c\xa9\x00\xa6\xa4\xd2\x26\x6d\xb2\xd2\x5b\xa6\xdd\x3b\x10\x53\ +-\xc8\xcd\xb3\xf1\xf0\xe3\xcd\x38\xdd\x35\xfc\x19\x0e\x50\x7a\x4b\ +-\x05\xc5\x36\x13\xa5\xc5\x36\xbc\x35\x2e\xee\xaa\x75\x7f\x2f\xae\ +-\x18\x5e\xd0\x7f\x01\xc0\xef\x97\xa6\xb4\x4d\x3b\x38\x9e\x12\xcf\ +-\xf7\x8f\xa3\x20\x74\x88\x7c\x33\x6c\x2f\xd7\x50\x0d\x64\x81\x0f\ +-\xb4\xb8\xf2\xf2\xd6\xad\x62\xe9\x86\x02\x2b\x76\x32\x20\xeb\xa7\ +-\x92\xbc\x3b\x93\xa6\x2a\xb3\x4c\x4e\xae\x09\xad\x6e\xa3\x36\x2c\ +-\x14\x7a\x11\xca\xc7\x9e\x12\x31\xb4\x9a\xff\x2f\xc7\xd3\x35\x8d\ +-\xdf\xe8\x52\x39\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\ +-\ +-\x00\x00\x0c\x01\ +-\x89\ +-\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\ +-\x00\x00\x30\x00\x00\x00\x30\x08\x06\x00\x00\x00\x57\x02\xf9\x87\ +-\x00\x00\x00\x04\x73\x42\x49\x54\x08\x08\x08\x08\x7c\x08\x64\x88\ +-\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0d\xd7\x00\x00\x0d\xd7\ +-\x01\x42\x28\x9b\x78\x00\x00\x00\x19\x74\x45\x58\x74\x53\x6f\x66\ +-\x74\x77\x61\x72\x65\x00\x77\x77\x77\x2e\x69\x6e\x6b\x73\x63\x61\ +-\x70\x65\x2e\x6f\x72\x67\x9b\xee\x3c\x1a\x00\x00\x0b\x7e\x49\x44\ +-\x41\x54\x68\x81\xb5\x9a\x79\x70\xd5\x55\x96\xc7\x3f\xe7\xf7\x7e\ +-\x2f\xfb\x1e\x08\x21\x0b\x90\x8d\x80\x49\x34\x31\x09\x8b\x10\xe8\ +-\xb8\x01\x5a\xb6\xb4\xd6\xa8\x88\x38\x8e\xd8\x3d\x88\xe5\x14\xf6\ +-\xbe\x59\xd3\xce\x54\x69\x6b\xd3\x5a\x25\x53\xad\xe8\xb4\x82\x2c\ +-\xda\x2d\x22\x4d\xf7\x40\x43\x77\xc9\xe2\x02\x91\x10\x76\x12\x48\ +-\x08\x31\xfb\x9e\x97\x3d\x6f\xfb\xdd\xf9\xe3\x25\x21\x21\xbf\x97\ +-\x0d\xfc\xfe\x45\xce\x3d\xf7\x9c\xef\xb9\xef\xfe\xce\xbd\xe7\x5c\ +-\x84\x9b\x80\xf7\x2f\xa8\x4c\x7a\x8c\x67\x7a\x5d\xb2\xd8\xee\x96\ +-\x38\xbb\x93\x10\x97\x81\xee\x34\x10\x01\x74\x0d\x35\x27\x4a\x35\ +-\x25\x44\x70\x5a\x50\x25\xa0\x8e\xbb\xac\x96\x43\xf3\xa2\xa4\xfe\ +-\x46\x7d\xcb\x64\x27\x6e\x3d\xad\x66\xf7\xd9\xd5\xab\x9d\x76\xb9\ +-\xa7\xb3\x8f\x40\x35\x8a\xae\x06\xa4\x46\x29\x52\xa7\x5e\xa7\xa5\ +-\xd4\x09\x44\xb6\x39\x95\xb6\x73\x7e\x9c\xb4\x4c\x86\xc7\x84\x03\ +-\xd8\x5a\xa4\x16\x76\xf4\xa9\x77\x5a\xba\x25\xdd\x30\x61\x1d\xe2\ +-\x07\x53\x03\x15\xb6\x5e\x21\x22\x40\x11\xee\x0f\x15\x6d\x70\xdb\ +-\x74\x45\xa0\x8f\x57\xb3\xdd\xa2\x78\x57\x94\xb6\x31\x33\x5e\x6a\ +-\xbe\x95\x00\xfe\xfc\x95\xf2\x6f\xd6\xd4\x9e\xc6\x4e\xb9\xd7\x8c\ +-\xf8\x00\x74\x0d\xe6\xcf\x50\x04\xfb\x2a\x7c\x75\x38\x51\x25\xd4\ +-\x76\x08\xa1\x7e\x90\x9f\x64\x8c\xe5\xa6\x47\xc1\xef\x42\x7a\xb4\ +-\x57\x52\x52\xc4\x7e\xd3\x02\xd8\x71\x5a\x2d\x33\x0c\xb5\xa5\xd2\ +-\x26\xd1\x76\xd7\xe8\xba\xba\x06\x77\x26\x1b\xf4\x38\x60\x4a\xa0\ +-\x47\x66\x77\x41\x6b\x8f\x30\x3d\x64\xb4\x8d\x36\x0c\xa7\x35\xa5\ +-\x3d\x9a\x19\x27\x97\xc7\x52\xd4\xc6\x52\xf8\xf8\xbc\xfb\xa7\xfe\ +-\x16\xe3\x2f\x55\x36\x89\xbe\x33\xc9\x20\x3e\xd4\x9c\x44\x90\x0f\ +-\x4c\x0f\xf1\xac\x7a\x79\x8b\x60\x1d\x62\xd9\x57\x67\x04\x79\x97\ +-\xdb\x3d\x9a\xdb\x4c\xb7\x18\x85\x27\x6b\x5d\xdf\xbb\xa1\x00\xde\ +-\x39\xae\x3e\xf0\xd5\xe4\xe5\x8b\x8d\x9a\xaf\xdd\x05\xa7\x6a\x85\ +-\xea\x0e\x61\x5a\x90\xf2\xa4\x17\xc0\xde\xdd\xc1\x14\xe7\x15\xc2\ +-\x7a\x4b\xe8\xad\x3d\x4f\x40\xe7\x05\x1c\xcd\x97\x69\x69\xaa\xc3\ +-\xe1\x74\x9a\xda\x3d\x76\xaa\x98\xb5\x3f\x7d\x7d\x54\x62\x02\xc1\ +-\xa2\xe4\xe3\xa2\x6a\xf7\xba\xd1\xf4\x74\x6f\x03\x7f\x3c\xa1\xb6\ +-\x56\xb6\xb1\xa6\xa9\x47\x70\xb8\x21\x22\x00\x3a\xfa\x14\x15\x65\ +-\x97\x39\x7a\xb5\x94\xaa\xab\xa5\x34\x35\xd4\xe0\xf4\x42\x12\xe0\ +-\xd7\xcf\xaf\x66\xf9\xd2\x9c\xc1\xbf\x6b\x1b\x5a\x78\x73\xcb\xa7\ +-\x7c\x71\xe2\x02\x7e\xbe\xde\xbf\xe8\x21\xb0\x20\xbc\x55\x54\xe3\ +-\xb6\xde\x1e\x6b\xd9\x34\xee\x00\xde\x3f\xe1\x7e\xad\xc2\xc6\x93\ +-\x0a\xcf\xfe\x75\x3a\xec\xfc\xe3\xf8\x71\x4e\x1e\x3b\x4c\x87\xad\ +-\x75\x3c\x8e\x87\xc1\xee\x70\xb2\x6b\xdf\x51\xb6\xec\x3a\x48\x6f\ +-\x9f\x63\xc2\xf3\x81\x37\x0e\x95\xba\xda\xf2\x53\xf4\xed\xd7\x0f\ +-\x8c\x08\x60\xfb\xd7\xea\xae\xf2\x76\x7e\xac\xfa\xb7\xec\xb9\x93\ +-\xc7\x38\x7c\xf0\x2f\xd8\xfb\x7a\x27\xe3\x98\x2b\xdf\xd4\xf2\x8b\ +-\xd7\xde\xa3\xb6\x61\x52\x69\x7e\x00\x96\x0e\xa7\xf6\xee\xce\x0b\ +-\xaa\xf6\xf1\x34\xf9\x6c\xe8\xc0\xb0\x6f\xe0\xaf\x85\x2a\xa0\xa1\ +-\x4f\xed\x75\x19\x88\xdb\xed\xe2\xff\x3e\xd9\xc6\x81\xbd\x1f\x4d\ +-\x9a\x3c\x40\x69\x45\xed\x8d\x92\x07\x20\x3e\x54\xf9\xa5\x84\x1a\ +-\xbf\xff\xe0\x80\x0a\x1c\x2a\x1f\x16\x40\x9d\x9b\xdd\xed\x7d\x12\ +-\xa0\x94\xc1\xbe\x4f\xb6\x51\x7c\xb6\xf0\x86\x1d\xdf\x2c\x28\x05\ +-\x65\xcd\x92\xe9\x08\x57\x3b\x87\xca\x07\x03\xf8\xe8\x8c\x4a\x6f\ +-\xec\xe2\x5e\x80\x63\x87\x0f\x72\xe9\xc2\xe9\x51\x0d\x66\xa5\x25\ +-\xf3\x83\x55\xf7\xf3\x9b\x17\x9e\xc4\x47\xf7\x9a\x0b\x6e\x1a\x8e\ +-\x55\x0a\xc5\x8d\x42\x7d\xa7\x3c\xb0\xfb\xa4\x9a\x3b\x20\x1f\xf4\ +-\x6c\xeb\x51\x5b\x1d\x6e\x91\x8e\xd6\x06\x0a\x3e\x3f\xe8\xd5\xd0\ +-\xec\xc4\x38\x7e\xbe\xee\x51\x66\x27\xc6\x0d\xca\x7e\xfb\x87\x8f\ +-\x60\x8c\x03\xee\x46\xd0\xde\x07\x8d\x5d\x9e\xbc\xed\x70\x23\x0d\ +-\x0e\xb5\x1d\xc8\x86\xfe\x5f\xa0\xa0\x5a\x45\xde\x12\xcd\xdc\xac\ +-\x18\x45\x59\xe1\xdf\x71\x7b\x39\x64\xf2\x72\xd3\xd9\xfc\xf2\x86\ +-\x61\xe4\xbf\x6d\x38\x0d\x28\x6e\x18\x7e\x61\x68\xee\x91\xac\x3f\ +-\x5f\x50\x33\xa0\xff\x17\xb0\x6a\xc6\x6a\xab\x0f\xfe\xe2\xea\xe5\ +-\xf3\x82\x33\xa6\x86\x66\x27\xc6\xf1\xd2\x8f\xfe\x15\xab\x6e\xb9\ +-\x29\xc4\xe6\x26\xc7\x0f\x27\xd5\xd6\x4e\x6d\x43\x0b\xad\xb6\x2e\ +-\x34\x11\x66\xc6\x46\x11\x18\x1e\xc5\xd7\x55\x16\x1c\xd7\xad\xa7\ +-\xd3\x8d\x74\x76\x1b\x2f\x03\x4f\x78\xb6\x90\x52\x6b\x40\xf8\xaa\ +-\xa8\x18\xa7\x6b\xe4\xea\x8b\x08\x2f\xac\x7d\xe8\xa6\xec\xf5\x88\ +-\xf0\x10\xd6\x3f\xf1\x00\xcb\x96\x64\x53\xd7\xd8\xca\xa7\x07\xbe\ +-\xe4\xf3\xaf\xcf\x51\x55\xd7\x34\x42\x37\x34\x2c\x82\xec\x3b\xbe\ +-\x43\x66\x6e\x1e\x9a\x36\xfc\xd2\x60\xeb\x93\x07\x01\xf4\xc2\x0a\ +-\x35\x1d\x8c\x6c\x80\xe2\xb2\x4a\x53\xa7\x73\x92\xe2\xc9\x48\x4d\ +-\xb8\x21\xe2\x16\x8b\xc6\xc3\x2b\xf2\x58\xfb\xc8\x32\x00\x36\x6d\ +-\xd9\xc3\xee\xbf\x7f\x39\xea\x9d\xa8\xdd\xd6\xca\x67\xfb\x76\x53\ +-\x56\x72\x9e\x95\x8f\xad\xc5\xc7\xd7\x6f\x70\xac\xa3\x4f\x82\x76\ +-\x9d\x55\x73\x74\x8b\x8f\x3b\x5f\x29\xcf\xcd\xa6\xb4\xa2\xd6\xd4\ +-\x50\x5e\x6e\xc6\x0d\x91\xcf\x4a\x4b\xe2\x85\xb5\x0f\x93\x10\x1f\ +-\xcd\xfe\xc3\x27\x78\x7b\xc7\xdf\x68\xb5\x75\x8e\x7b\x7e\x65\xf9\ +-\x65\xf6\xef\xde\xce\x83\x8f\xad\x65\xe0\x12\xa6\x80\x1e\xa7\xf1\ +-\x6f\xba\x52\x32\x1f\xa0\xca\x26\x54\x37\xf5\x98\x1a\x48\x4e\x88\ +-\x99\x34\xf9\xbc\xdc\x34\x96\x2f\xcd\xe1\x72\x79\x35\xcf\xfe\xea\ +-\x4d\xce\x5f\xae\x98\x94\x9d\xd2\x92\x73\x5c\x2a\x3e\x43\xea\x2d\ +-\x99\x83\xb2\x5e\x97\xe4\xeb\x55\x36\xc9\xeb\xe8\x83\x8a\x36\xc1\ +-\xe9\xe8\x33\x9d\x1c\x19\x1a\x3c\x61\x87\x33\x62\xa7\x91\x9a\x18\ +-\x87\xdb\x50\x6c\x7c\xe7\x63\xf6\xfe\xf3\x38\x86\x31\x66\x41\x33\ +-\x2a\x0a\x8e\xfe\x63\x58\x00\xdd\x0e\x49\xd0\x4b\x9a\x24\xbd\xbb\ +-\xff\x7e\xe5\x6b\x35\xbf\x5d\xfb\xfb\xfb\x8e\xdb\x89\xbf\xbf\x2f\ +-\x4f\xff\xcb\x32\x1e\x5e\xb1\x98\xfd\x87\x4e\xb0\xf9\xc3\x7d\x74\ +-\x74\x76\x7b\xd5\xcf\xce\x48\x61\xd9\x92\x1c\x66\x27\xc6\x22\x08\ +-\x27\xcf\x95\xf2\xfe\xae\x83\x74\x76\x8d\xdc\x0d\x8d\x75\xd5\xb4\ +-\xb5\x36\x13\x1e\x31\x05\x00\xb7\x41\xb0\x9e\x13\xaf\x7a\x8e\x55\ +-\x48\xa8\xc3\x0d\x4a\x33\xbf\xe2\xda\xda\xbb\x98\x11\x13\x35\x2a\ +-\x71\x11\xe1\xde\x25\xd9\xac\x5f\xf3\x00\xf5\x4d\xad\x3c\xfb\xeb\ +-\x4d\x5c\xba\x52\xe5\x55\x3f\x69\x66\x0c\x1b\x9e\xfe\x1e\x59\x69\ +-\xc9\x23\xe4\xfe\x53\x66\xb1\xf1\x8d\x4d\xa6\xe7\xd1\x37\x57\x4a\ +-\x08\x8f\x58\x0c\x80\xcb\xad\xac\x7a\xb8\x9f\xf2\xbf\x2b\x59\x51\ +-\xdf\x25\x7c\x1a\x18\x40\xa3\x89\xb3\x86\x16\xdb\xa8\xe4\x67\x27\ +-\xc4\xb1\xee\x89\xfb\x89\x9f\x3e\x95\xb7\xb6\xff\x8d\xfd\x87\x4f\ +-\xa0\x94\x97\xca\x2d\xc0\x9f\x67\x1e\x5b\xc1\xca\x65\x77\xa0\x5b\ +-\xcc\xcf\x94\x94\xc4\x59\x24\xa5\xa6\x73\xf9\xe2\xc8\x33\xa9\xb9\ +-\xb1\x6e\xf0\xdf\x0e\x43\x3c\xc9\xd5\x57\x87\x99\x61\x8a\xf4\xc4\ +-\xa9\xa6\x06\x8f\x1e\x3f\x8b\xdd\x05\x15\xad\xc2\x85\x7a\xe1\x62\ +-\x83\xd0\x37\xe4\xea\xf0\xe6\x4b\xeb\xb9\x5c\x5e\xc3\xaa\xe7\x5f\ +-\x61\xdf\xa1\xaf\x4d\xc9\x8b\x08\xf7\xe5\xcf\xe3\xc3\x4d\xbf\x60\ +-\x76\x62\x2c\xff\xf1\x9f\x7f\xf0\xba\x20\x33\xc3\x15\xe9\xe9\xb7\ +-\x9a\x8e\xb5\x36\x0f\x5f\x62\x1d\xe8\x02\x22\x00\x12\x67\x4c\x37\ +-\x9d\xf4\x45\xe1\x79\x76\x1c\xa9\x24\x22\x7a\x16\xfe\x3a\xf4\xba\ +-\xe0\x4a\x8b\xe0\x6f\x85\x8a\xab\x65\xec\xff\xeb\x27\x34\xd4\x99\ +-\xa7\x60\x80\xd4\xa4\x78\x7e\xf8\xcc\x43\x44\x4f\x8d\xe0\x7f\x3e\ +-\xd8\xcb\xc1\xa3\x27\xf1\xf5\xb1\x7a\xd5\xf7\xb7\xc2\xd2\xb4\x30\ +-\x76\x9b\x8c\xd9\x7b\xaf\x7d\x1b\x3e\x9a\x32\x74\x84\x36\x94\x27\ +-\x80\x79\x99\xa9\xa6\x06\x9d\x2e\x37\x3b\xb7\x6c\x66\xc1\x92\x7b\ +-\x99\x91\x90\x82\x52\x8a\xc6\xba\x6a\x2e\x9e\x2d\xa4\xaa\xa2\xcc\ +-\x2b\x91\x90\xe0\x40\xfe\x7d\xd5\x7d\xac\xc8\xcf\xe5\x93\xfd\x5f\ +-\xb0\xe1\xbf\xde\xa6\xb7\x77\x5c\xdd\x12\xa6\x86\x07\x99\x73\x71\ +-\x5e\xab\xe8\x74\x8b\x38\x75\xa5\xe4\x8a\xa0\x92\x00\xe2\xa7\x4f\ +-\x25\x65\x56\x2c\xa5\x15\x23\x7b\x4b\x7d\xbd\x3d\x1c\x3e\xb0\x67\ +-\x5c\xce\x35\x4d\xe3\xfe\xbb\x16\xf0\xec\xea\xfb\x69\x69\xeb\xe0\ +-\xa9\x1f\xff\x9e\xca\x9a\x86\x71\xcd\x1d\x40\x4f\xaf\x79\x4a\x37\ +-\xfa\x3f\x6c\x4d\x20\xc2\x9f\x1a\xcd\xd3\xab\xbc\x86\x35\x0f\xdf\ +-\x33\x21\x47\xd7\x23\x26\x7e\x16\xab\x7f\xf0\x23\xd2\x96\x3c\x4a\ +-\x7d\xa7\xc6\xa5\xf2\xea\x09\x93\x07\x68\xb5\x75\x99\xca\x23\x43\ +-\xfc\xb9\x63\xa6\x62\x79\xaa\xc1\xed\x31\xc6\x5e\x0d\xd4\xf1\xa1\ +-\x0a\xf9\x0b\x6e\x25\x2f\x37\x7d\xc2\x0e\x03\x82\x82\x59\xb1\xf2\ +-\x71\x1e\x5f\xbb\x01\x8b\xc5\xc2\x8e\xf7\x36\xb1\xe7\xc8\x05\x26\ +-\x7b\x76\x95\x56\x54\x9b\x07\x10\x16\x48\x54\x90\xc2\xc7\x02\x06\ +-\xea\x98\x6e\xd5\x2d\x9f\x39\x5d\x86\xa2\xbf\x4b\x27\x22\xbc\xf8\ +-\xfc\x6a\x7e\xfe\xda\x7b\x14\x9d\x2f\x1d\xd3\x91\x66\xb1\x90\x95\ +-\xbb\x98\x45\xf9\x2b\x00\x38\x74\x60\x0f\xa7\x0a\x8e\x62\x18\x06\ +-\x19\x99\x0b\x68\x99\x64\x39\x7d\xa4\xe0\x9c\xa9\x7c\x48\xa2\x51\ +-\x3e\x56\xcb\x11\x3d\x63\x9a\x34\x14\x55\xbb\x0a\x11\xc9\x1d\x18\ +-\x09\x08\xf0\xe3\x8d\x17\xd7\xf1\xda\xce\xaf\xf8\xe2\xe8\x61\xda\ +-\xdb\x46\x16\xe5\x11\x53\xa6\x91\x3c\x27\x83\xcc\xdc\x45\x84\x84\ +-\x86\x73\xf1\x4c\x21\x47\xfe\xb9\x97\xee\xce\x8e\x61\x7a\xd5\xed\ +-\x13\x6f\x80\x9f\xbe\x78\x85\xd2\xab\xe6\x3d\xde\x5b\x52\x66\x0e\ +-\xf0\x2f\xc8\x98\x26\x0d\x9e\x0b\xbe\xc8\x36\x20\x77\xa8\xa2\xc5\ +-\xa2\xb1\x68\xf1\x12\xe6\x66\xe5\xd1\xd6\xda\x44\x6b\x4b\x13\x86\ +-\xdb\x4d\x60\x70\x08\x61\x61\x91\x04\x04\x5d\xbb\x1f\xfd\x69\xcb\ +-\x26\xaa\xae\x9a\x67\x23\x35\xc1\x2d\x64\x77\x38\x79\xfd\x7f\x77\ +-\x9b\x9e\x25\x3e\x56\x2b\x0b\xb2\x3c\xe5\xb0\x20\xdb\xa0\xbf\x22\ +-\x73\x2a\x6d\xa7\x55\x8c\x57\x80\xc1\x96\x85\xd3\x80\x2e\x3b\x20\ +-\x42\x78\x64\x14\xe1\x91\xde\xaf\x12\xf5\xd5\xe6\x75\xc4\x68\x70\ +-\x1b\xd0\xda\xe3\xe9\xf8\x0d\xc0\xe1\x72\xf1\xe2\xc6\x2d\x94\x57\ +-\x9a\x9f\x29\x77\x2d\xca\x24\xc0\x73\x2f\xeb\x76\x28\xed\x4f\xd0\ +-\x5f\x13\xcf\x8f\x93\x16\x51\xbc\x3b\x54\x59\x17\xcf\x09\xfd\x6d\ +-\xe2\xe8\x55\x8d\x2f\x2b\x3c\x5b\xec\x62\xd9\x37\x7c\xff\x67\x6f\ +-\xf0\x55\xd1\x45\x53\x5d\xab\x6e\x61\xcd\x43\x77\x7b\xfe\x10\xde\ +-\x1e\x78\x10\x19\xa4\x28\x4a\xdb\xa8\xc4\xf8\x3e\xfd\xbf\x82\x08\ +-\x2c\x9a\x65\xf0\x59\x99\x36\xa2\x26\xbd\x19\x30\x0c\x83\xe2\xb3\ +-\x85\x14\xd8\x5a\xd8\x51\x53\xc2\xd9\x92\xf2\x51\xf5\x9f\x7e\x64\ +-\x39\x33\x62\xa2\x50\xd0\xe9\xd6\xb5\x8d\x03\xf2\xc1\x00\x32\xe3\ +-\xa5\xa6\xa8\xc6\xfd\xdf\xc0\x6f\x07\x64\x7e\x3a\xcc\x8d\x52\x9c\ +-\xa9\x9b\xf4\x4b\x94\x57\x0c\x74\xfe\xc6\x83\xa5\x0b\x6e\x65\xf5\ +-\xca\x3b\x01\x10\xc5\x4b\x43\xdf\xd6\x86\x15\x00\x46\x9d\xf6\xba\ +-\x82\x53\x43\x65\xb3\xc2\x15\xc1\xe3\x2f\x07\x6e\x3a\xee\xcb\x9f\ +-\xc7\x6f\x36\x3c\x39\x50\xd4\x17\x19\xf5\xda\x9b\x43\xc7\x87\x05\ +-\x90\x93\x23\x4e\x0c\xed\x11\x60\x30\x17\x8a\x40\x56\xcc\xc4\x4f\ +-\xa3\xd0\xf0\x48\xa6\x46\xc7\x4e\x8e\x35\x10\x12\x14\xc0\x2f\x9f\ +-\x5b\xc5\x2f\x9f\x5b\x35\xd0\xca\xe9\xb2\xa0\x3d\x9e\x93\x23\xc3\ +-\xfa\xf9\x23\x3e\xd3\xec\x78\x29\x3b\x59\xeb\x7a\x4a\x94\x7c\x0c\ +-\x58\xc0\x93\x29\xe2\x42\xd5\xb8\x72\xba\x6e\xb5\x72\xfb\xfc\xa5\ +-\x2c\x5c\xba\x0c\xab\x8f\x0f\x4d\xf5\x13\x7a\xb3\x23\x66\x5a\x24\ +-\x0f\xde\xb3\x90\xef\xde\xb3\x90\xe0\xc0\xc1\x14\xe5\x06\xb5\xfa\ +-\xb6\x58\xb9\x34\xc2\x9f\x99\x91\xec\x18\xfd\xd3\x93\xb5\xee\xf5\ +-\xa2\xd8\x3c\x20\xcb\x89\x53\xc4\x86\xc0\xa5\x66\xc1\xe6\xe5\x74\ +-\x4d\x9e\x93\x4e\xfe\xf2\x87\x08\x0d\x8f\x1c\x37\x61\x7f\x3f\x1f\ +-\x92\x67\xc6\x92\x9d\x91\x42\x76\x46\x0a\xb7\xcd\x4d\xbc\xbe\x07\ +-\xa4\x44\xd4\xba\xac\x18\x7d\xaf\xd9\xfc\x51\x97\xf4\x54\xb5\xeb\ +-\x29\x25\xf2\x2e\x43\x02\x55\xca\xf3\xd4\x54\x69\xbb\x36\x75\xeb\ +-\x5b\xaf\x92\x77\xf7\x03\x24\xa6\xdc\x32\xc2\x86\xcb\xe5\xc4\xd6\ +-\xda\x4c\x6f\x4f\x37\x2e\xa7\x03\x43\x29\x74\x8b\x4e\x4c\xa4\x1f\ +-\x77\xa7\x87\x11\x3e\x7a\xc3\xc0\xad\x14\xcf\x65\xc7\x59\x36\x7b\ +-\x53\x18\x73\x4f\x9c\xaa\x75\xad\x34\x94\x7c\x20\x30\xe8\xa9\xbd\ +-\x17\x0e\x95\x5f\x5b\x25\xc3\xed\x46\xf3\x52\x1e\x7a\x43\x5a\xb4\ +-\x22\x25\x72\xd4\x57\xcb\x0e\x50\x6b\x6e\x8f\x35\x5f\xf9\x01\x8c\ +-\xf9\x4a\x99\x15\xa3\xef\xd1\x0c\x2d\x7b\x68\x76\xf2\xbf\xae\xf6\ +-\x9f\x28\x79\x1f\x0b\x24\x84\x8d\x4a\xbe\x48\x19\x5a\xf6\x58\xe4\ +-\x61\x1c\x01\x00\x64\xc5\x4b\x69\x47\x8c\x36\x4f\x84\x0d\x0a\x3a\ +-\x2d\xe3\x9a\x35\x12\x91\x81\x90\x1d\xa7\xf8\x4e\x92\x81\x97\x1e\ +-\x71\x8f\x82\x97\x7c\x6d\xda\xc2\xec\x78\xf1\x5e\xea\x0d\xc1\x84\ +-\x4f\xa8\xc2\x0a\x35\xdd\xe2\x63\xfc\x64\x5f\xb1\xb6\xc1\xee\x1e\ +-\xff\xfc\xb4\x69\x8a\x94\x29\x5e\x57\xbd\x1b\x61\xb3\x4b\xd7\x7e\ +-\x37\xd1\xff\x00\x32\xe9\x23\xf6\xc3\x53\x6a\x56\x97\xd3\x78\xb5\ +-\xa3\x4f\xee\xeb\xb0\x4b\x90\x97\x2e\xca\x20\x16\x27\x18\x4c\x09\ +-\x18\x26\x52\xa0\x0a\x14\xb2\xdd\xcf\xd0\x3e\x4c\x8b\x97\x89\x3f\ +-\x7f\x72\x03\x01\x0c\xc5\xae\xb3\x6a\x4e\xbb\xdd\x58\xef\x72\x69\ +-\x77\xf4\x38\xd5\x4c\xbb\x21\x21\x2e\xb7\xb2\xba\x0c\x11\x05\x58\ +-\x35\x8c\xc5\x09\xc6\x37\x21\xbe\x72\x49\x94\x2a\x31\x44\x1d\xd7\ +-\x2d\x96\x43\xb7\x45\x8b\x59\x1b\x6a\x42\xf8\x7f\xd2\xb5\x8d\x07\ +-\x16\x9e\x74\x46\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\ +-\ +-\x00\x00\x19\xd5\ +-\x89\ +-\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\ +-\x00\x00\x60\x00\x00\x00\x60\x08\x06\x00\x00\x00\xe2\x98\x77\x38\ +-\x00\x00\x00\x04\x73\x42\x49\x54\x08\x08\x08\x08\x7c\x08\x64\x88\ +-\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x02\x0b\x00\x00\x02\x0b\ +-\x01\xf7\x4d\xfa\xeb\x00\x00\x00\x19\x74\x45\x58\x74\x53\x6f\x66\ +-\x74\x77\x61\x72\x65\x00\x77\x77\x77\x2e\x69\x6e\x6b\x73\x63\x61\ +-\x70\x65\x2e\x6f\x72\x67\x9b\xee\x3c\x1a\x00\x00\x19\x52\x49\x44\ +-\x41\x54\x78\x9c\xe5\x9d\x79\x60\x95\xd5\x9d\xf7\x3f\xe7\x79\xee\ +-\xbd\xd9\x57\x12\x02\xd9\x48\x08\x10\x20\xec\x84\x4d\x50\x36\x17\ +-\x16\x99\x22\x52\xec\x54\x5b\x44\x5c\xea\x54\xa7\xd5\xa9\xd3\xce\ +-\x74\x3a\xb5\x9d\xb7\x7d\x6b\x3b\x6f\xa5\x76\x46\xe5\xd5\xb8\x80\ +-\x5a\x14\x45\x05\x51\x51\x16\x95\x45\xd6\x40\xd8\x24\x21\x10\x42\ +-\xc8\x4a\xf6\xe5\xee\xf7\x39\xf3\xc7\x85\x90\xe5\xde\x9b\xfb\xe4\ +-\xde\x04\x3a\xfd\xfe\x95\x9c\xe7\x9c\xdf\x39\xf7\xfc\xce\xf2\x3b\ +-\xbf\xe5\x1c\xc1\x0d\x8a\x37\xf6\xcb\x54\x87\x91\x85\x4e\x8d\x5c\ +-\x97\x53\xe6\x38\x34\x91\x6e\x77\xc9\x38\xa7\x26\x8c\x2e\x0d\x55\ +-\x93\xa8\x0e\x0d\xa1\x00\xaa\x82\x34\x28\x38\x85\x82\x2b\x33\x4e\ +-\x56\x0c\x4b\xe0\x88\x40\x16\x69\xc8\x33\x8a\x50\x0b\x5d\x66\x8a\ +-\x72\xb3\x44\xd3\xf5\xfe\x4d\x9e\x20\xae\x77\x03\xae\xe2\x85\xaf\ +-\x65\x86\x41\xe5\x01\xbb\x4b\x2e\x32\xdb\xc5\xa8\x56\x3b\xe1\x52\ +-\xea\xa7\xa3\x0a\x98\x95\xa9\x11\x17\xd6\x39\x5d\x48\xce\x03\xdb\ +-\x41\x6e\x57\x5d\xea\xf6\x71\x43\x44\x43\x50\x1a\x1e\x20\xae\x2b\ +-\x03\x5e\xde\x27\x87\x49\x83\xf6\x74\xab\x4d\x2c\x6e\xb4\x8a\xd8\ +-\xde\x74\xb8\x27\xcc\xca\x90\x24\x44\xf8\x24\xe6\x02\xb9\x57\x08\ +-\xde\xc0\xa6\x6e\x9c\x98\x29\x1a\x83\x53\xb3\x7e\xf4\x3b\x03\x5e\ +-\xdd\x25\x43\x0d\xd1\x3c\xd9\x68\x95\x8f\xd4\x9a\x45\x7a\xb0\x3a\ +-\x3d\xcc\x00\x36\x27\x24\x44\x4a\x6e\x1a\xa2\x8b\xa8\x55\xc0\x66\ +-\x34\xf9\xfa\x84\x54\xf5\x53\x21\x84\x16\x9c\x16\xf9\x87\x7e\x63\ +-\xc0\x33\x7b\x64\x54\x84\xca\x1f\x9b\x2c\x72\xa5\xcd\x29\x8c\xc1\ +-\xa2\x1b\x61\x82\x11\x89\x92\xc4\x70\xc9\xbe\x52\x85\xf1\xc9\x92\ +-\x44\xdf\xa3\xdf\x17\x4e\x21\xe5\xef\x9b\x52\xd4\xb7\xe6\x0a\xe1\ +-\x0c\x56\x1b\x7d\xa1\xcf\x19\xf0\xcc\x19\x19\x15\xd5\x28\xd7\xd5\ +-\xb7\x89\x25\x76\x17\xaa\xde\xf2\x06\x15\x26\x25\x4b\xe2\xc3\x25\ +-\x56\x27\x14\x54\x28\x4c\x4c\xd1\x08\x35\xb8\xbf\x1b\x55\x68\xb1\ +-\xc2\xbe\x52\x05\x4d\xc2\x94\x34\x49\x5c\x98\xc4\xa0\x04\xd4\xec\ +-\x62\x90\xbf\x6b\x4a\x56\x5f\xef\x6b\x46\xf4\x29\x03\x9e\x3f\x20\ +-\x9f\x6a\x32\xf3\x1f\x16\x07\x21\xbd\xa5\x61\x50\x20\x3a\x14\x4c\ +-\xaa\x64\x5a\x9a\xa4\xc5\x0e\x8a\x80\x48\x93\xfb\x7b\x8b\x0d\x76\ +-\x97\x28\xd8\x5d\xd7\xca\xa4\x44\x4b\xa6\xa4\x05\x65\x6d\x2b\x10\ +-\x28\x3f\x9c\x98\x22\xf6\x06\x83\x98\x27\xf4\x09\x03\xde\x29\x90\ +-\x99\xa5\x8d\xf2\xcb\x16\x9b\x48\x0b\x16\xcd\x09\x83\x25\x19\xf1\ +-\x9d\x3b\x55\x4a\xf8\xaa\x44\xa1\xc1\xd2\x39\x6f\x46\x9c\x64\x42\ +-\x72\x90\x36\x17\x90\x48\xde\x50\x0d\xca\x4f\xc6\x0f\x12\x35\xc1\ +-\x22\x7a\x15\x41\x67\xc0\xd1\x0a\xe7\xd2\x36\xbb\x78\xf5\xb3\x22\ +-\x25\x36\x58\x34\x23\x4d\x70\xeb\x70\xdf\x7b\xa3\xc5\x09\x6d\x36\ +-\x28\xa9\x77\xff\xa4\x20\xcd\x80\x8e\xa8\x13\xc8\xd5\x13\x53\x0c\ +-\x1f\x06\x93\x68\xd0\x18\xf0\xcc\x19\x19\x15\xd9\x20\x77\x59\xec\ +-\x4c\x6e\xb5\x0b\xa2\x42\x40\x93\xd0\x6a\x77\x8f\xd4\x40\xa0\x08\ +-\x98\x31\x44\x62\x50\x24\x2e\x0d\x8e\x57\x2a\xcc\x1b\xd6\xaf\xc2\ +-\xca\x55\x48\xe0\xcf\x21\x8d\xca\x53\x39\x39\xc2\x1e\x0c\x82\x41\ +-\x61\xc0\xba\x7c\x39\x3b\xd2\x24\xf3\x92\x22\x65\xd6\xc9\x2a\x41\ +-\x45\x8b\x60\xd1\x48\x0d\xa3\xe2\xee\xfc\x03\x17\x05\x55\xad\xfa\ +-\xaa\x12\x40\xa8\x11\x2c\x8e\x6b\x69\x06\x15\x52\xa2\x24\x59\x03\ +-\x24\xd1\xa1\xc1\x68\x79\x2f\x21\xe4\x41\x21\xd4\x7b\x26\x0e\x16\ +-\x17\x02\x26\x15\x28\x81\xbc\x83\xf2\x21\x4d\xe3\xb9\x61\x89\x5a\ +-\xe8\xbe\x52\x05\x9b\x13\x42\x0d\x70\xc7\x08\x8d\xea\x56\xc1\xe9\ +-\x1a\x81\xd9\x0e\x4e\x3f\x07\x6c\x98\x11\x52\x63\x24\x99\x71\x92\ +-\xb3\xb5\x82\xb2\x66\x41\x66\x9c\x24\x29\x4a\x12\x1f\x0e\x81\x09\ +-\x37\x6e\x34\x34\xb5\x10\x17\x13\x15\x28\x99\x7a\xa4\x72\xe7\xa4\ +-\x54\xf1\x75\x20\x44\x02\x62\xc0\x4b\x07\xe4\xd3\x8d\x56\xf9\x8b\ +-\xb9\x59\x52\xd9\x7f\x51\x50\x73\x65\x94\x2b\x02\x26\xa7\x4a\x0a\ +-\x2a\x04\x76\x97\x5b\x92\x19\x9d\x24\x31\xaa\x70\xb2\x4a\x60\xf3\ +-\x20\xd8\x0d\x8c\x94\x64\x27\xba\x3b\xf9\x6a\xa3\x2e\xd4\x0b\x92\ +-\xa2\x24\x61\x41\x3a\x35\x38\x5d\x2e\x36\x7d\xba\x97\x8d\x5b\xbf\ +-\x64\xe3\xf3\xbf\x08\x06\xc9\x36\x29\xb4\xe5\x93\x93\x8d\x9f\xf6\ +-\x96\x80\xa1\xb7\x05\x5f\x38\xe0\x7a\xfe\x52\x33\x8f\x4e\x4e\x81\ +-\x26\x2b\x5c\x6e\xbb\xc6\x4b\x4d\x42\xe1\x65\xc1\xc0\x48\x49\x65\ +-\xb3\xc0\xa9\xc1\xf1\xca\xee\xbc\x76\xd8\xed\x34\xd4\xd5\x80\xb5\ +-\x11\x11\xd2\x44\xc9\x51\x33\xad\x66\x2b\x9a\x26\x69\x6d\xb3\x20\ +-\x71\x6f\x1e\x61\x21\x26\x42\x42\x8c\x44\x84\x85\x12\x16\x16\xca\ +-\xe0\x81\xf1\x0c\x49\x1e\x48\x72\xd2\x00\xbf\xdb\x7b\xf0\x58\x21\ +-\x6b\x5e\xd9\xc4\xc5\x8a\x1a\xa2\xa3\x22\x7a\xfb\xb3\xbb\x22\x42\ +-\x48\xe5\xc3\xfc\x72\xe7\xfd\x93\x52\x0c\x7f\xe9\x0d\x81\x5e\x31\ +-\x60\xed\x7e\xd7\xda\x8a\x66\xe5\x61\x29\xa1\xbc\x19\xea\xda\x94\ +-\xf6\x8d\x36\xdc\x04\xd3\xd2\x34\xea\xcc\x82\x0b\x0d\x02\xd7\x95\ +-\x74\x87\xc3\x4e\x65\xd9\x05\x2a\x2e\x95\x50\x59\x56\xca\xe5\x9a\ +-\x4a\x9a\x9b\x1a\x7a\xbd\x43\xe7\x8e\x1b\xc1\x9a\x7f\x7f\xb4\xc7\ +-\x7c\x55\x97\xeb\x79\xee\xb5\x0f\xf8\xea\xc0\x89\x5e\xd5\xe3\x07\ +-\x4c\x20\xde\xc8\x2f\x77\xca\x49\x29\x86\x0d\x7a\x0b\xeb\x66\xc0\ +-\x0b\x07\xe4\x6f\x2a\x9a\x79\xf8\x6a\xbf\x55\x36\x77\x1e\xd9\x66\ +-\x3b\xec\x3a\xe7\x5e\xa9\x2d\x6d\x6d\x14\x9e\x3a\xca\xf9\xa2\x53\ +-\x5c\x2c\x39\x8b\xd3\xe9\xe8\x4a\xae\xcf\x60\x77\x38\xf8\xcb\xe6\ +-\x5d\xac\xdf\xb4\x03\xab\x2d\x28\x02\x8b\x2f\x28\x08\xb1\xee\x48\ +-\x85\xa3\x61\x72\xb2\x71\x9b\x9e\x82\xba\x18\xf0\xda\x21\xf9\xf0\ +-\x85\x46\xfe\xb5\xa7\x41\x5b\x7a\xae\x90\xe3\x47\xf6\x51\x7c\xe6\ +-\x04\x2e\x97\xcb\x77\xe6\x3e\xc0\xbe\xfc\xd3\xfc\x29\xef\x7d\xca\ +-\xab\x6b\xfb\xaf\x52\x89\x51\xa0\x6c\xca\xbf\x24\x6f\xd5\xb3\x31\ +-\xfb\xcd\x80\x75\x05\x72\x5e\x69\xad\x7c\x51\x93\xde\xf7\xed\x4b\ +-\xa5\xe7\xd9\xbb\x73\x2b\x65\x17\x8a\xfd\x25\x1b\x54\x54\x54\xd7\ +-\xf1\xe2\x1b\x5b\xd8\xf9\x75\xc1\x75\xa9\x1f\x08\x6f\x75\x68\x1f\ +-\xad\x3f\x22\x97\x7e\x6f\xb2\xd8\xed\x4f\x01\xbf\x18\xb0\xf6\x73\ +-\x19\x53\xd9\xc0\x16\x87\x4b\x78\xec\xfd\xc6\xfa\x5a\x3e\xdb\xf2\ +-\x36\x17\xcf\x17\xe9\x69\x6c\xd0\x60\xb3\x3b\x78\xe3\xfd\x1d\xbc\ +-\xf9\xc1\x4e\xec\x8e\xfe\x5b\xe6\x3c\x21\xdc\x48\x7c\xbd\x55\x6e\ +-\xc9\xdb\x23\xd3\x56\xcf\x12\x2d\x3d\xe5\xf7\x8b\x01\xf6\x08\xf6\ +-\xb5\xb5\x12\xde\xed\x83\x94\x1c\xda\xb7\x93\xbd\xbb\x3e\xc1\x79\ +-\x1d\x7f\xf8\xd3\xcf\xae\x63\xf7\xa1\x93\xd7\xad\xfe\x8e\x50\x04\ +-\x84\xa8\xc4\x28\x06\x36\x03\x73\x7b\xca\xdf\x23\x03\x5e\x3a\x20\ +-\x7f\x5f\xd6\xc4\xe8\xae\xe9\x0e\xbb\x9d\x4f\xde\x7f\x83\xa2\xd3\ +-\xd7\x6d\xba\xb7\xc3\xd2\xf7\x9b\xac\x2e\x4c\x4d\x93\x80\x9c\x7d\ +-\xb4\xc2\xb9\x74\x62\xb2\xe1\x03\x5f\x79\x7d\x1e\x2c\x5f\xc9\x97\ +-\xa3\xab\x5b\xf9\x49\xd7\xf4\xd6\x96\x26\xfe\x92\xb7\xe6\x86\xe8\ +-\xfc\x1b\x18\xc2\xe1\x14\x79\xaf\xe4\xcb\x6e\x83\xb7\x23\x7c\x32\ +-\xa0\xd9\xc2\x56\xbb\xab\xf3\x69\xd9\x6a\x6e\x63\xe3\xba\xe7\xa9\ +-\xa9\x2a\x0f\x46\x23\xff\x57\xa3\xa4\x41\xc4\xb7\x9a\xe5\x66\x5f\ +-\x79\xbc\x32\xe0\xd5\xc3\xf2\x47\xf5\x6d\x64\x74\x4c\xb3\xdb\x6d\ +-\xbc\xf7\xe6\x5a\xea\x6a\xaa\x82\xd4\xc4\xff\x9d\x70\x6a\x50\x5c\ +-\x27\x38\x53\x23\xa8\x35\x8b\xac\xbc\xc3\xf2\x71\x6f\x79\x3d\x32\ +-\xe0\xd5\x12\x19\x5a\xd3\xca\xef\xba\xa6\x6f\xff\x68\x23\x95\x97\ +-\x4a\x83\xd2\x48\x21\x04\x43\x52\x93\xc8\x1d\x37\x82\x5b\xa6\x8d\ +-\xc5\x68\xd0\x6d\xad\xbc\x21\xd1\x62\x83\xed\x67\x15\x4e\x56\x5d\ +-\xd3\x02\xd4\xb6\xc8\x3f\xbc\x5a\x22\x3d\xea\x6f\x3d\x6e\xc2\xce\ +-\xcb\xda\x4b\x6d\x76\xa5\x53\x81\xa2\xd3\x05\x9c\x2e\x38\x14\x50\ +-\xe3\x84\x10\x4c\x9f\x30\x92\x3b\xe7\x4f\x67\xfc\xe8\xa1\xc4\x46\ +-\x47\xb6\x7f\x5b\xb4\xea\xdf\x70\xb4\xb4\x05\x44\xff\x7a\x43\x4a\ +-\x38\x5c\xae\x60\xed\xa2\x6c\x6c\x73\x88\x10\xad\x56\x7b\x1e\x78\ +-\xa0\x6b\x99\x6e\x0c\x78\xba\x44\x86\xd6\x96\x72\x4f\xc7\x34\x8b\ +-\xb9\x95\xcf\x3f\x7a\xbb\xd7\x0d\x13\x42\xb0\x70\xce\x14\xee\xbb\ +-\x6b\x3e\xe9\xc9\x03\x7b\x4d\xe7\x46\x47\x75\xab\xa0\xc9\xe2\xf9\ +-\x5b\x4d\x8b\xf8\xde\xda\xc3\xf2\xb1\x47\x72\x85\xb9\x63\x7a\x37\ +-\x06\xa4\xd5\xf2\xa7\x52\x3b\x9d\x14\xc0\x27\x0e\xec\xc4\xd2\xd6\ +-\xbb\xd1\x39\x70\x40\x2c\xff\xfe\xa3\xfb\x98\x30\x3a\xab\x57\xe5\ +-\xff\x9a\xd0\xe6\x43\x1a\xb6\x38\x85\x01\xa7\xf6\x67\x60\x75\xc7\ +-\xf4\x4e\x7b\x80\x94\x52\x64\xc4\x69\xf3\x26\xa5\x4a\x92\xa3\x25\ +-\xe1\x46\x48\x0b\x6f\xe1\xd0\x7e\xbf\x4e\xd5\xdd\x30\x32\x2b\x9d\ +-\xbc\xdf\x3f\xf9\x37\xd1\xf9\x0e\xed\x9a\x3d\xda\x1b\x9a\xac\xca\ +-\xbd\xef\x48\xd9\x69\xb3\xeb\xc4\x80\x63\xe5\xae\x45\x71\x61\x0c\ +-\x4b\x8f\x91\x4c\x4d\x93\xdc\x3e\x42\xe3\xd0\xbe\x5d\x58\xac\xfa\ +-\x0f\x3a\xa3\x86\xa5\xf3\xdc\x2f\x1f\x0d\x86\xe5\xe9\x86\x47\x9d\ +-\x19\xbe\x3a\xaf\xd0\xda\x43\x37\xb5\xda\x09\xb1\xe6\x6b\x3f\xeb\ +-\x98\xd6\x79\x06\x28\xca\xca\x8e\xff\x6b\x9a\x64\xdb\x97\x87\x75\ +-\x37\x68\xe0\x80\x58\x7e\xf7\xb3\xd5\x84\x87\x5f\x4f\xc3\x6d\xdf\ +-\xa3\xcd\x0e\xfb\x4a\x05\x7b\x4a\x14\x5a\x6c\xfe\x95\xa9\xb7\x28\ +-\x9d\x8c\x18\xed\x7b\xc0\xe1\x73\x32\x06\xa9\xdd\xd9\xf1\xe3\xa9\ +-\xb3\x17\xb8\x5c\xaf\xcf\xab\x5b\x08\xc1\xcf\xfe\xe1\x3b\x0c\x88\ +-\x8d\xd6\x55\xae\xbf\x30\x34\x3d\x99\x27\x1f\x5c\xe6\xf5\x7b\x45\ +-\x75\x1d\x45\x25\xe5\x94\x96\x57\x51\x53\xdb\x44\x4b\x9b\x19\xa7\ +-\xcb\x45\x88\xc9\x48\x54\x44\x38\x99\x69\x83\x18\x96\x91\xcc\xf0\ +-\xa1\xe9\x1c\xb9\x64\xa4\xde\xcb\xa6\xeb\x0d\x8d\x66\x52\x5e\x3b\ +-\x2c\xb3\xee\xcf\x15\xe7\xa0\x03\x03\x44\x88\xf6\x1d\xa0\x93\x53\ +-\xf7\x17\xbd\x50\xeb\xde\x3a\x73\x22\x53\xc7\x67\xeb\x2e\xd7\xd7\ +-\x88\x08\x0f\x63\xf5\x3d\x0b\xb8\x7b\xc1\x2c\x54\xf5\xda\xc4\x77\ +-\xba\x5c\x1c\x3a\x5e\xc4\xae\x7d\xc7\x38\x7c\xbc\x88\x9a\x3a\xff\ +-\x1c\xa5\xc3\x23\x22\xc8\xce\x99\xc4\xf8\x29\x33\x49\x18\x38\xd8\ +-\xef\x76\x68\x80\x4d\xd3\x9e\x06\xbe\x07\x1d\x19\x20\xe4\xbd\x5d\ +-\x6d\xf4\xfb\x8f\x9d\xf1\x9b\x30\x80\xa2\x28\xac\x5a\x71\x87\xae\ +-\x32\x7d\x0d\x21\x04\x0b\x66\xe7\xf2\xe8\x7d\x4b\x88\x8f\xbd\xb6\ +-\x1f\x99\xad\x36\xb6\x6c\xdf\xcf\xdb\x5b\xbe\xf0\xbb\xd3\x3b\xc2\ +-\xdc\xd6\xc6\xd1\x83\xbb\x29\x38\xbc\x97\xf1\xb9\x33\x99\x39\x6f\ +-\x11\xa1\x61\xdd\x15\xc6\x9e\xd0\x6a\x53\xda\x57\x1a\x03\x5c\x59\ +-\x7e\xd0\x6e\xea\x98\xc9\x6a\xb3\x53\x56\x71\x59\x57\xa3\xa6\x4f\ +-\x18\x79\x43\xc9\xf9\x23\x32\x53\x79\xe2\xc1\x65\x8c\xcd\xce\x6c\ +-\x4f\x73\xb9\x34\xde\xdf\xb6\x97\x57\x36\x6e\xa3\x39\x08\x07\x3f\ +-\x4d\xd3\x38\x7a\x70\x37\xe7\x8a\x4e\xb1\xfc\xbe\x1f\x10\x9f\x98\ +-\xd4\x63\x99\x66\x2b\xb1\x6b\x0f\xcb\xf4\x47\x72\xc5\x45\x03\x80\ +-\x12\xea\x9a\x0d\xa2\x93\x78\x74\xbe\xac\x12\x4d\xd3\xe7\x7d\xb6\ +-\x68\xde\x34\x5d\xf9\xfb\x0a\x51\x11\xe1\x3c\xf4\xdd\x45\x2c\xbd\ +-\x6d\x06\x8a\x72\x6d\xb9\x29\xf8\xe6\x1c\x7f\x7c\x79\x13\xe7\x4a\ +-\x2b\x82\x5e\x67\x73\x63\x3d\x6f\xe5\xad\x61\xd9\x7d\x8f\x90\x9c\ +-\x9a\xe1\x33\xaf\x94\x60\x70\x69\x8f\x00\x3f\x37\x00\x08\x29\xe6\ +-\x76\xb5\x34\x9e\x3d\xaf\x4f\xdb\xa9\xaa\x0a\x53\xc7\x8d\xd0\x55\ +-\x26\xd8\x10\x42\x70\xfb\x2d\x93\x79\xec\xfb\x7f\xd7\x49\xfc\xad\ +-\x6b\x6c\xe6\xf9\xf5\x5b\xf8\xec\xab\x23\xc8\x60\x45\x84\x78\x80\ +-\xd5\x62\xe6\x83\xb7\x5e\xe6\xfb\x8f\x3e\x45\x64\x54\x8c\xcf\xbc\ +-\x16\xa7\x58\xcc\x55\x06\x48\xc1\xbc\xae\x19\x4a\xab\xea\x74\x55\ +-\x3e\x72\x68\xfa\x75\x15\x3b\x47\x66\xa5\xf3\xe4\x43\xcb\x18\x3d\ +-\x6c\x48\x7b\x9a\xd3\xe5\x62\xe3\xd6\xaf\x78\x65\xe3\x36\x2c\x16\ +-\x3f\xe5\xc4\x00\x61\x6e\x6b\x61\xeb\x7b\xeb\x58\xb1\xf2\x87\x08\ +-\xe1\x5d\xdb\xdf\x6a\x17\xd9\x00\x86\x2b\xeb\xff\xd8\x8e\x1f\xcf\ +-\xd7\x0b\x0a\x2b\xf5\x35\x38\x2b\xc3\x7f\x49\x20\xd8\x78\xe0\xdb\ +-\x77\x30\x26\x3b\x13\x45\xb9\x36\x8d\x8f\x9c\x38\xcb\x1f\xf3\xde\ +-\xa3\xf4\x52\x75\xbf\xb7\xa7\xac\xa4\x98\xfc\x03\xbb\x99\x3c\x7d\ +-\xb6\xd7\x3c\x16\x27\xa1\x9b\x8a\xe5\x40\x83\xc1\x44\xb6\xd6\x41\ +-\xfc\xb1\x3a\xe1\x74\x8d\xc0\x66\xd1\x27\xe0\x5e\xcf\xcd\x77\xdc\ +-\xa8\xa1\xed\x7f\x57\xd7\x36\xf0\x5f\xaf\x7d\xc8\xae\xfd\xd7\xd7\ +-\x5a\xf7\xf5\x97\xdb\x18\x37\x69\x3a\x46\x93\xe7\xd8\x14\x29\xa1\ +-\xb1\x91\x85\x06\x4d\x75\x65\x23\x05\x1a\xd0\x6a\x85\x53\x35\x02\ +-\xa7\x0b\x6c\x36\xab\xae\x0a\x13\xe2\x7d\xaf\x79\xc1\x46\x4c\x54\ +-\x67\x91\xcf\xee\x74\xb2\xe1\xc3\x2f\x58\xb7\xe9\xf3\xfe\x70\xc4\ +-\xea\x11\x56\x73\x1b\xc7\xf3\xf7\xfb\x9c\x05\x4e\xa7\x76\x8b\xe1\ +-\x64\xa5\x72\x4f\x9d\x59\xd0\x68\xed\xec\x25\xe8\xb0\xeb\x63\x40\ +-\x78\x68\xaf\xa3\x90\x74\x21\x32\x3c\x8c\xd5\xdf\x59\xc0\xb2\x3b\ +-\x66\xb5\xa7\x7d\x7d\xf4\x1b\xfe\x94\xb7\x89\x4b\x55\xfd\xe8\x88\ +-\xe5\x07\x4e\xf4\xc4\x00\x29\x46\x1a\x1a\xad\x62\x7c\xd7\x10\x1f\ +-\x00\x45\xd5\xe7\xb5\x18\x62\x0a\x5a\xe0\xa3\x47\x28\x8a\x60\xd1\ +-\xdc\xa9\x3c\xf2\xdd\xc5\xed\x12\x4e\x45\x75\x1d\x7f\x7a\xf5\x7d\ +-\xf6\x1e\x3e\x15\x30\xfd\xb8\x98\x28\x66\xe6\x8e\x26\x33\x6d\x30\ +-\xc9\x49\x03\x08\x0b\x31\x51\xdb\xd0\xcc\xb1\xd3\xc5\xec\xd8\x77\ +-\xac\x57\x9b\x78\x6d\x75\x05\x8d\x0d\x75\xc4\xc6\x79\x76\x22\x76\ +-\x6a\xa4\x1a\x9c\x12\x8f\xea\xca\xb0\x10\x7d\x23\xda\xe1\xe8\xbb\ +-\x60\xc2\xd1\xc3\x86\xf0\xc4\x83\xcb\x18\x35\x2c\x1d\x08\xae\x23\ +-\xd6\x8c\x89\xa3\xf8\xfb\x6f\xcd\x65\xc2\xe8\xac\x4e\x67\x86\xab\ +-\x58\x30\x3b\x97\x1f\xdc\x7b\x27\xbf\x7f\xf1\x6d\xbe\x3a\xa8\xdf\ +-\xf7\xe8\x5c\xe1\x49\xaf\xb3\xc0\xe1\x12\xb1\x86\x99\xe9\x5a\xc5\ +-\x91\x72\x11\x53\xd5\xd2\xf9\x20\x20\x8c\x26\x5d\x15\x59\xec\xc1\ +-\x5f\x77\xe3\x62\xa2\xf8\xc1\xbd\x8b\x59\x38\x67\x6a\xbb\x84\xf3\ +-\xd5\x81\x13\xfc\xf9\xf5\x0f\xa8\xac\xa9\x0f\x88\xf6\xd8\xec\x4c\ +-\x1e\xbf\xff\x5b\x8c\x1e\x3e\xa4\xc7\xbc\xb1\xd1\x91\x3c\xfd\xe4\ +-\x2a\x1e\xff\xcd\x7a\x4e\x9d\x38\xa6\xab\x1e\x5f\x0c\xb0\x3b\x65\ +-\xa8\xc1\xa8\x12\x3e\x25\x4d\xb2\xaf\x54\x50\xd7\xe1\x64\x6e\xd2\ +-\xc9\x80\xfa\x86\x1e\xbd\xf0\xfc\x86\xaa\x2a\xdc\xbd\x60\x16\x0f\ +-\xdc\xb3\x80\xc8\x70\xb7\x7e\xf0\x62\x45\x0d\x6b\xf2\x36\x71\xb0\ +-\xa0\x30\x20\xda\xf1\xb1\x51\x3c\x7a\xdf\x12\x16\xcc\xce\x45\x78\ +-\xf6\xb4\xf4\x88\x46\xab\xca\xbc\x3b\xbf\x43\xe9\x85\x12\x5a\x5b\ +-\xfc\xd7\x10\x57\x55\x94\x79\xfd\x26\x11\xaa\x01\x88\x52\x05\xcc\ +-\x1c\xa2\x51\xd9\x22\xb8\xdc\xea\xb6\x6d\x9a\xbc\x88\x4f\xde\x50\ +-\x56\x19\x9c\x08\xce\x49\x63\x86\xf3\xc4\xea\x65\x64\xa6\x0d\x02\ +-\xdc\x4a\xb3\xd7\xdf\xfd\x9c\x77\x3e\xfa\x02\x87\xb3\xf7\x9e\xd6\ +-\xaa\xaa\x70\xf7\xc2\x9b\x59\xbd\xe2\x0e\x22\xc2\xc3\x7a\x2e\xd0\ +-\x05\x03\x22\x24\x61\xa1\x61\xe4\xde\x34\x97\x2f\xb6\xf9\x74\x76\ +-\xeb\x04\xbb\xd5\x42\x6b\x4b\x93\xc7\x93\xb1\x4b\x43\x31\x00\x91\ +-\xe0\xf6\x69\x4c\x89\x96\xa4\x44\x03\x48\xea\xb3\xe3\x38\xac\x23\ +-\xfa\xe9\x4c\xb1\x77\x4e\xfb\x83\xa4\x01\xb1\xfc\xe4\xe1\x6f\x33\ +-\x6f\xc6\xf8\xf6\xb4\xed\x7b\x8f\xf2\xdf\xaf\x7f\xa8\xdb\x26\xd1\ +-\x15\x13\x73\xb2\x78\x62\xf5\xdd\x0c\x4d\x77\x1f\x16\xed\x4e\x27\ +-\x26\x83\x3e\x21\x43\x00\x52\xc0\x98\x09\x53\xf9\xf2\xb3\xcd\x48\ +-\xe9\xbf\x9e\xac\xfe\x72\xb5\x37\x06\x08\xaf\xad\x18\x76\x65\x04\ +-\xfa\x8b\xd3\xc5\x17\x69\x69\x33\x13\x15\x71\x4d\x3e\x77\x68\x70\ +-\xa2\x52\x30\x3c\x41\xa2\x0a\x77\x94\xa3\xc9\x8b\xfb\xcf\xda\xdf\ +-\xfd\xb8\xbd\x53\xce\x5f\xac\xe4\xd9\xbc\xf7\x38\x7a\xea\x9c\xae\ +-\x36\x74\x45\x62\x7c\x0c\x3f\x5c\xf9\x2d\x6e\x9d\x39\xb1\x3d\x6d\ +-\xe7\xd7\x05\xac\x7f\xef\x73\x5e\xfd\xcf\x6e\x1e\x97\x3e\xa1\x08\ +-\x18\x91\x20\x29\x94\x11\x0c\x4e\x49\xa7\xe2\xd2\x05\xbf\xcb\xd6\ +-\x5d\xae\x26\x7d\xa8\x67\x3d\x99\x01\x68\x05\xe2\xbb\x7e\x18\x92\ +-\xa2\xef\x64\xab\x69\x1a\x1f\xef\x3a\xc4\xf2\xc5\xb3\xb9\xd4\x28\ +-\xa8\x35\x43\x4d\xab\xc0\xe1\x82\xc8\x10\x28\xaa\x15\x20\x61\x4c\ +-\x52\xf7\x88\x77\x4d\x82\xaa\x1a\x68\x33\x5b\xc8\x7b\x67\x1b\xef\ +-\x7d\xb2\x1b\x97\xab\xf7\x71\xc0\x46\x83\xca\x8a\x3b\xe7\xb0\x72\ +-\xf9\x6d\xed\xe7\x93\x92\xb2\x2a\x9e\xcd\xdb\x44\xfe\xc9\xb3\xbd\ +-\x8e\x11\x1b\x35\x50\x62\x52\x21\x29\x39\x4d\x17\x03\x9a\x9a\x3c\ +-\x0b\x0c\xaa\x82\x34\x00\x2d\x78\x60\x40\xe2\x80\x18\xc2\xc2\x42\ +-\x74\xc9\xbf\x1b\x36\xef\x62\x68\xce\x34\xca\xcd\xd7\x66\x41\xb8\ +-\x09\x8a\x6b\xdd\xa7\x6b\x80\x63\x95\x82\xc2\x5a\x81\xc0\x1d\x8e\ +-\x6a\x34\x40\x61\x35\x9c\x3c\x76\x88\xdd\xdb\x37\xd3\xd4\x1c\xd8\ +-\x66\x3e\x75\x7c\x36\x3f\x5e\xbd\xac\x5d\x35\xd2\x6a\xb6\xf0\xca\ +-\xdb\x9f\xf2\xde\xa7\x7b\x02\x62\xea\x55\x64\x0d\x90\x4c\x1c\x96\ +-\xc8\xd1\x83\xfe\x97\x71\xd8\x3c\xf7\xa1\xaa\xa0\x5d\x9d\x01\xdd\ +-\x20\x84\x60\xe4\xd0\x54\x5d\xcb\xc0\xe5\xfa\x26\xd6\xbe\xf6\x36\ +-\x8b\xbf\xbd\xb2\x5d\x13\x18\x6a\x00\x2b\x74\xba\x4c\xe3\x6a\xf0\ +-\x75\x51\xad\xa0\xe2\xd2\x05\xbe\xfc\xf4\x03\xca\xcb\x4a\xfc\xae\ +-\xc7\x13\x06\x0f\x8c\xe7\xf1\x95\x4b\xb9\x65\x9a\x5b\xaf\xa8\x69\ +-\x92\x4f\xbe\x38\xc8\x8b\x6f\x6e\xa5\xa1\x29\x78\x12\x1a\x40\xc6\ +-\x60\x7d\xf6\x6e\xbb\xdd\x33\x03\x84\x22\x5d\x06\x90\xcd\xde\xc2\ +-\x85\x67\xe6\x8e\xd1\xbd\x0e\x9f\x39\x75\x0c\x97\xcb\xc5\x6d\x7f\ +-\x77\x0f\xe1\x11\x51\xd4\x9b\xbb\xe7\xd1\x34\x8d\x8b\x25\x45\x1c\ +-\xde\xb7\x8b\x0b\xc5\xfa\xcc\x9e\x5d\x61\x32\x1a\xb9\x77\xe9\x3c\ +-\xee\xbb\x6b\x7e\xfb\x69\xfc\x9b\xe2\x8b\x3c\xfb\xf2\x26\x4e\x17\ +-\x07\xc7\x8f\xb5\x2b\xc2\x42\xf5\x89\xe8\x4e\x2f\x0c\x08\x51\xb1\ +-\x1a\x10\x4a\xb9\xb7\x50\xd1\x59\x53\xc6\xf0\x5f\xaf\xeb\xbf\x9b\ +-\xe2\xec\x99\x13\x94\x9e\x2f\x62\x44\xce\x44\x52\x87\x64\x12\x19\ +-\x15\x8b\xdd\x6e\xa3\xa9\xa1\x96\xda\xcb\xd5\x9c\x2f\x3a\xd9\x6b\ +-\x4f\xbb\x8e\x98\x99\x9b\xc3\x8f\x56\xdd\xd5\x1e\x2f\xdc\xd0\xd4\ +-\xc2\xda\xb7\xb6\xf2\xf1\xae\x83\x68\x5a\xdf\x19\x5e\xf4\x4a\x50\ +-\x76\x87\xe7\x43\xaa\x41\xa1\xd1\x20\x90\x85\xde\x9a\x9a\x3a\x28\ +-\x81\x8c\xb4\x41\x5c\x28\xd3\xef\x8e\x6e\xb7\xdb\x38\x79\x74\x3f\ +-\x27\x8f\xee\xd7\x5d\xb6\x27\xa4\x0e\x4a\xe0\x47\xab\x97\x31\x63\ +-\xe2\x28\xc0\x6d\xe7\xdd\xb4\x6d\x0f\x79\x1b\x3e\xa5\xd5\xac\xd3\ +-\x4f\xa4\x17\xd0\xab\x6d\x75\x79\x09\xcf\x35\x28\xe2\x92\x41\x22\ +-\x0b\x7d\xdd\x58\xb0\x64\xfe\x74\xfe\xfc\x9a\xff\x07\x8f\xbe\x84\ +-\xc9\x64\xe2\xae\xc5\xb7\xf1\xe0\x8a\x39\x84\x19\xaf\x8d\xc2\x5f\ +-\x3f\xb7\x9e\x1d\x7b\xf5\xa9\x08\x02\x81\x59\xa7\x62\xce\x68\xea\ +-\x6c\x29\x0c\x37\x42\x5a\xac\x64\x40\x98\x7c\xc7\xa0\xb8\xd4\x42\ +-\x4d\xf1\x2e\x1d\x2c\x99\x37\x8d\xd7\xdf\xfd\x8c\xe6\x56\x0f\x8b\ +-\x79\x3f\x22\x7b\xf4\x04\x66\x2f\x58\x4a\x74\x4c\x1c\x5f\x97\x42\ +-\x6e\x9a\x46\xf4\x95\xc3\x7a\x53\x4b\xff\xb6\xed\x72\xbd\x3e\x37\ +-\x96\xe4\xf8\x30\x46\x24\xb8\xaf\x5c\x4b\x8a\x82\xe4\x28\x89\x10\ +-\x20\x85\xb2\x47\xb1\x86\x73\x06\xf0\xba\x60\x86\x87\x87\x72\xff\ +-\xf2\xdb\x03\x6d\x73\xaf\x11\x9f\x98\xc4\x8a\x95\x3f\x64\xc9\x3d\ +-\xab\x88\x8e\x89\x03\xa0\xc9\x2a\x79\x73\xe7\x85\xf6\xcb\x41\xfa\ +-\x1b\x65\x95\xfa\xdc\x75\x06\xc6\x86\x32\x3a\x49\x32\x29\x45\x92\ +-\x12\xed\xee\x7c\x40\xb3\x18\x29\x32\x4c\x1f\x20\x9a\xf3\xcb\x5d\ +-\x27\x80\x71\xde\x08\x2c\x5f\x74\x33\xbb\x0f\x9d\x08\xf8\x64\xaa\ +-\x07\x46\x53\x08\x33\xe7\x2c\x60\xd2\xf4\xd9\x28\xea\xb5\xe3\x73\ +-\x65\x79\x29\x3b\x3e\x7a\x97\x90\xb0\x30\x26\xe4\x3c\xca\xc0\x48\ +-\x1f\x44\xfa\x08\xc5\x17\xf4\xb9\xb5\x44\x46\x74\xd7\x3d\x49\x28\ +-\x98\x95\x28\x5a\x14\x00\x21\xd9\xe9\x8b\x80\xa2\x28\xfc\xea\x89\ +-\x95\xfd\xe6\xef\x99\x35\x22\x87\x07\x1e\xfb\x57\x72\x67\xce\x6b\ +-\xef\x7c\xab\xc5\xcc\xce\x8f\x37\xf1\xd6\x4b\x6b\xa8\xaa\xb8\x08\ +-\x40\x5d\x9b\xa0\xad\x9f\xc3\x93\xdb\xcc\x16\x0a\xcf\x5f\xd2\x55\ +-\x26\x75\x50\x82\xa7\xe4\x1d\x70\xc5\x33\x4e\x0a\xb9\x0b\xc4\x8f\ +-\x7d\x11\x89\x8f\x8d\xe2\xb7\x3f\x5d\xc5\x53\xbf\x7d\x39\x28\x1e\ +-\x65\x9e\x90\x38\x28\x99\xf9\x8b\x97\x93\x9a\x7e\x2d\x9e\x40\x4a\ +-\x8d\x82\xc3\xfb\xd8\xbd\x7d\x2b\x36\x6b\xe7\xb5\xde\xa9\x41\x41\ +-\x45\xff\x2e\x43\xfb\x8f\x16\xea\x76\x58\x1b\x36\x24\xb9\x5b\x9a\ +-\xa2\xc9\x5d\x70\x85\x01\x9a\x55\xfd\x52\x09\xd5\x5c\xe0\xfb\x5e\ +-\xcf\x9c\xe1\x19\xbc\xf8\x7f\x1e\xe7\x9f\x7e\xf3\xff\x03\x36\x88\ +-\x74\x44\x68\x78\x04\x37\xcd\x5e\xc0\x84\xa9\xb3\x3a\x59\xa5\xca\ +-\xcb\x4a\xd8\xb1\xf5\x5d\x6a\x2a\xbd\x8f\xb8\x56\x9b\xf0\xbe\x81\ +-\xf5\x01\x3e\xfe\xe2\x80\xae\xfc\xaa\xaa\x90\x99\xde\x4d\xb1\xe9\ +-\xb4\x85\xab\x7b\xe0\x0a\x03\x72\xb3\x44\x53\x7e\xb9\x73\x2f\x88\ +-\x5b\x7a\x22\x98\x9e\x92\xc4\x2b\x7f\xf8\x27\x9e\x5d\xb7\x8d\xed\ +-\xbb\xf6\xe8\x1e\x0d\x1d\x11\x1d\x13\xc7\xe4\x9b\xe6\x32\x76\xd2\ +-\xf4\x4e\xf6\x07\x73\x6b\x0b\x5f\x7e\xbe\x99\x53\x05\x87\x7a\xbc\ +-\x4f\xc8\xec\x80\x06\x73\xff\xcc\x82\xd2\x4b\xd5\x1c\x2a\xd0\x77\ +-\x1f\xc6\x90\x94\x41\x98\x8c\x9d\xed\xe5\x52\x88\xdd\xd3\x07\x88\ +-\x66\xe8\xe0\x1d\x2d\x85\x78\x53\x48\x7a\x64\x00\xb8\x7d\x2f\x67\ +-\xdd\x7e\x37\x29\xa3\x66\x52\x70\x78\x2f\xdf\x1c\xcf\xc7\x62\xf6\ +-\xa8\x52\xea\x86\x98\xd8\x78\x86\x64\x65\x33\x22\x67\x02\xe9\x99\ +-\x23\x3a\x8d\xf8\xab\x8e\xae\x7b\x77\x7d\x82\xdd\xea\xff\x81\xca\ +-\xd5\x4f\x53\xe0\xa5\x0d\x1f\xeb\x1e\x70\xd3\x27\x8e\xec\x96\x26\ +-\xa4\xf6\xc6\xd5\xbf\xaf\x31\xc0\xa2\xbc\x2d\x42\xb5\x35\x74\x89\ +-\x11\xf0\x06\x45\xc0\x80\xc4\x41\xcc\x5b\x78\x37\x73\x6e\x5f\x4a\ +-\x55\x65\x19\x97\xab\xca\xa9\xbb\x5c\x85\xcd\x6a\xc5\xe9\xb0\xa3\ +-\xa8\x06\x42\xc3\xc2\x88\x8a\x8a\x25\x3e\x31\x89\xc4\x41\x29\xc4\ +-\xc4\x76\x53\xbc\x02\x50\x56\x7a\x8e\x1d\x5b\xdf\xa5\xb6\x3a\xf8\ +-\x8e\xb3\xc1\xc0\xbe\x23\xa7\xf9\x62\xff\x71\xdd\xe5\xe6\xcc\xe8\ +-\x26\x5c\x5a\x85\x5d\xdd\x74\xf5\x9f\x76\x06\xe4\x66\x89\xa6\xa3\ +-\xe5\xae\x2d\x12\x56\xf8\x43\x78\x6c\x92\xc6\xee\x0b\xee\xd1\xab\ +-\xa8\x2a\xc9\xa9\x19\x3d\x7a\x05\xfb\xc2\x87\x1b\xf2\xb0\x9a\x6f\ +-\xcc\x38\xe1\xcb\xf5\x4d\x3c\xf3\x82\xfe\x30\xdd\x41\x89\xf1\x8c\ +-\xca\x4a\xef\x9a\xfc\x41\xc7\xeb\xf2\x3b\xfb\x61\x68\xf2\x75\x7f\ +-\x08\xbb\x24\x9c\xad\xbd\x61\xde\x7e\xd0\x0d\x97\xe6\xff\x55\x75\ +-\xad\x66\x0b\x3f\xfd\xbf\x2f\x53\xd7\xd8\xac\xbb\x1e\x8f\x86\x7f\ +-\x45\xae\xeb\xf4\x6f\xc7\x7f\x26\xa4\xaa\x9f\x48\x49\x8f\xce\x2f\ +-\xf5\x66\xfd\x17\xb1\xde\x48\x70\x49\x77\x70\x5d\xb3\xcd\x37\x23\ +-\xea\x1b\x5b\xf8\xc7\xa7\x9f\xa7\xa8\x44\x9f\xdc\x0f\x10\x16\x16\ +-\xc2\x8a\xc5\xdd\xb6\xd4\xd3\x13\x07\xa9\x9d\xee\x94\xeb\xc4\x00\ +-\x21\x84\x54\x14\xd9\xed\x8e\x88\xae\x88\x09\x95\x28\x7f\xbd\xfd\ +-\x0f\xb8\xaf\xd9\xdc\x59\xac\xb0\xf9\x1b\x85\xae\x3e\x51\xe0\xf6\ +-\xae\x5e\xf5\x93\xff\xa4\x48\xe7\xa1\xeb\x2a\x96\x2f\xbc\xd9\x83\ +-\xe9\x53\xfe\x47\xd7\x07\x22\xba\x29\xb6\xcf\x0e\x56\x37\x0c\xab\ +-\xd0\x7e\x09\x0c\xf7\x46\xdc\xa4\x42\x4e\x92\xe4\x54\x95\xdb\xa9\ +-\xf7\xaf\x19\x52\xc2\xf9\x7a\x18\x74\xc5\x3f\xb0\xa4\xac\x8a\x75\ +-\x9b\x3e\x67\xfb\x9e\xa3\xbd\x0e\xe6\x88\x8b\x89\xe2\xef\x97\xcc\ +-\xe9\x9a\x5c\x5c\x9c\xac\x6e\xec\x9a\xd8\x8d\x01\x2b\x84\x70\xe5\ +-\x97\x3b\x9f\x01\xf1\xb2\xaf\x4a\xb2\x06\xb8\x1f\x49\x38\xda\xcf\ +-\x27\xd1\xbe\xc0\xa5\xea\x16\x76\x96\x17\xf3\xd1\x8e\xfd\x1c\x3a\ +-\x5e\x14\x70\x14\xcd\x3f\xff\x60\x45\xb7\xd1\x2f\xa4\xfc\xcd\x0a\ +-\x21\xba\x39\x36\x79\x34\xed\x14\x27\xab\xaf\x0d\xab\xd0\x1e\x03\ +-\x26\xf8\xaa\x28\x3d\x4e\x52\xde\xcc\x75\xd3\x4a\xf6\x16\x0e\x9b\ +-\x95\x0f\xff\xf2\x32\x76\x87\x9d\xe6\x86\x3a\x1a\xea\x83\xe7\x55\ +-\xbd\x78\xde\x34\x6e\x9e\x32\xa6\x6b\x72\xfe\xd9\x14\x75\xbd\xa7\ +-\xfc\x1e\x63\x68\x56\x08\xe1\x52\x34\xe5\x11\xf0\xbd\xc2\x08\x60\ +-\xdc\x60\x19\x94\x0b\xb5\xfb\x13\x2e\x97\xcb\x6d\x36\x3d\x57\x18\ +-\xd4\xce\xcf\x19\x9e\xc1\x8f\x1f\xe8\x16\x04\xae\x21\x95\xc7\x3c\ +-\x8d\x7e\xf0\x71\x63\xd6\x84\x34\x71\x10\x78\xad\xa7\x4a\x23\x4d\ +-\x90\x39\xa0\x3f\xb5\x31\x37\x26\x86\xa6\x27\xf3\x87\x9f\x3f\xd4\ +-\xcd\x60\x2f\x21\xcf\xd7\x45\xae\x3e\x07\xaf\x26\x94\x9f\x02\x3d\ +-\x46\xeb\x65\x27\x4a\xaf\x1e\x6f\x7f\x0b\xc8\xce\x4a\x63\xcd\x2f\ +-\x1e\x21\x3a\xb2\x5b\xa0\x76\xad\x53\x2a\xff\xe2\xab\xac\x4f\x06\ +-\xe4\x26\x8b\x5a\x21\xe5\x4a\x7c\x58\xcc\xc0\x2d\x15\x8d\x1c\xf8\ +-\xb7\x39\x0b\xe6\xcd\x18\xcf\x7f\xff\xfa\x31\xe2\xe3\xba\xd9\x4a\ +-\xa4\x40\x3e\x38\x2d\x55\xf8\x1c\xc0\x3d\x2e\xdf\x13\x53\x0d\x5b\ +-\x85\x60\x4d\x4f\xf9\x32\xe3\x25\x03\x23\xfb\x8f\x09\x46\x9d\xee\ +-\xf3\xc1\x46\x58\xa8\x89\x7f\x5c\x75\x17\xbf\x7a\x72\x25\xa1\x21\ +-\xdd\xdb\x22\xe1\xff\xf9\xf3\xde\x8c\x5f\x0e\x2e\xae\x0a\xe5\xa7\ +-\xca\x60\xd7\x74\x10\x33\xbc\xe5\x11\xb8\x5f\x3a\xfa\xec\x6c\xdf\ +-\x4a\x44\x06\x83\x91\x29\xb3\xe6\x33\x6d\xd6\xad\x7d\x5a\x8f\x2f\ +-\x4c\x19\x3f\x82\xa7\x1e\x5e\xe1\xfd\xfd\x02\x21\x0f\x86\x36\xa8\ +-\x3f\xf7\x87\x96\x5f\x0c\xc8\xcd\x15\x8e\xa3\x95\xf2\xbb\x52\xd3\ +-\x0e\x02\x89\xde\xf2\x85\x9b\x20\x3e\x1c\x8f\xde\x70\xc1\xc0\x90\ +-\xac\x6c\xe6\x2f\xba\x9b\xf8\x84\x9e\xef\x63\xe8\x0b\x8c\xcd\xce\ +-\xe4\xbe\xbb\xe6\x33\x33\x37\xc7\x57\xb6\x1a\x0d\xf5\xdb\xfe\x3e\ +-\xf2\xe3\xb7\x8b\xd7\xc4\xc1\xe2\x42\x7e\x85\x5c\x24\xa5\xb6\x53\ +-\xe0\x39\xae\x0c\xdc\x8f\x37\x1c\x28\x53\x82\xca\x84\xd8\xf8\x04\ +-\xe6\x2d\x5c\xc6\xd0\x11\x3e\x7f\x78\x9f\xc0\x64\x34\x32\x67\xc6\ +-\x38\x96\xcc\x9f\xce\xc4\x9c\x61\x3e\xf3\x4a\x68\x91\x42\x59\x98\ +-\x9b\x2c\x2e\xfa\x4b\x5f\x97\x8f\xdd\xa4\x64\x71\xf8\xc8\x25\xc7\ +-\x52\x84\xf2\x31\x78\x7e\x1d\x2f\xc4\x00\x37\x67\x68\x94\x35\x09\ +-\xbe\xa9\x16\x58\x02\x88\xdd\x33\x1a\x4d\x4c\xbb\xe5\x56\x72\x6f\ +-\x9a\x87\xc1\xd0\xb7\x51\x98\x1d\x11\x16\x6a\x62\xca\xb8\x11\xcc\ +-\x98\x94\xc3\x9c\x19\xe3\x3a\xc5\x3c\xf8\x80\x5d\x15\xda\xf2\x09\ +-\xc9\x6a\xbe\x9e\xba\x74\xbf\xa0\x31\x39\xd5\xb8\x33\xbf\xdc\x79\ +-\x3f\x88\x37\xf1\xb2\x89\x0b\x01\xe9\xb1\x92\xd4\x18\x49\x55\x8b\ +-\xfb\x25\xa5\x56\x9d\x51\x9e\xc3\x47\x8d\x63\xee\x82\xbb\x88\xf6\ +-\x62\xc0\x09\x16\x14\x45\x30\x28\x31\x9e\xac\xf4\xc1\xe4\x8c\xc8\ +-\x60\x4c\x76\x06\xa3\x87\xa7\x77\x33\x23\xf6\x00\x4d\x22\xbf\x3f\ +-\x21\xd9\xf8\x99\xde\xfa\x7b\xf5\x86\xcc\xa4\x14\xc3\x86\x23\x15\ +-\x4e\xbb\x90\xe2\x4d\xc0\xeb\x0d\x1d\x8a\x80\xe4\x68\xf7\x13\x54\ +-\xf9\x97\x04\xe5\xcd\x3d\x6f\xd0\xf1\x09\x03\x99\xb7\xf0\x6e\x32\ +-\x86\x75\x37\xe5\x79\xc3\xed\x4b\xee\xa1\xae\xb6\x9a\x96\xc6\x06\ +-\x6c\x36\x0b\x36\x9b\x15\x97\xc3\x81\xfd\x4a\xe4\xa6\x50\x04\x21\ +-\x21\x61\x28\x8a\x8a\x29\xc4\x44\x7a\x62\x04\xe3\x33\xa3\x49\x1a\ +-\x10\x4b\xea\xe0\x04\xbd\x9d\xdd\x15\x76\x90\x2b\x27\xa7\x18\x7a\ +-\x75\xb1\x6a\x40\x22\xcb\x91\x4b\x8e\x79\x42\x28\xef\x03\x3d\x3a\ +-\x0c\x79\x7b\xf7\xf1\x2a\xd6\xfe\xf1\x97\x8c\x9d\x34\x9d\x69\x37\ +-\xdf\x86\xaa\x33\x48\x5c\x2f\x6e\xc9\xd4\x88\xf7\xef\x72\xab\x9e\ +-\xd0\x7a\xe5\x19\x2b\x5d\xef\xc6\x74\x44\xc0\x32\xe3\x91\x0a\x39\ +-\x59\x48\xed\x63\xa0\xc7\x98\xa6\xe2\x3a\xc1\xc9\x2a\xcf\x55\x9a\ +-\xdb\x5a\x08\x8f\xe8\x9f\x2b\x2e\xe7\x0f\xd3\x88\x0a\xfc\x66\x85\ +-\x6a\x29\x94\xc5\x93\x93\xc5\x91\x40\x88\x04\xac\x47\x9b\x9c\x2c\ +-\x8e\x38\x51\x72\x41\xee\xeb\x29\x6f\x5c\xa8\xf7\x83\x5a\x7f\x75\ +-\x7e\x52\x94\x0c\xbc\xf3\xa5\x3c\xa4\xaa\xca\x8c\x40\x3b\x1f\x82\ +-\xf3\x32\x20\x53\x53\x44\x59\x53\xb2\x3a\x5b\xc2\xaf\xf0\xa1\x41\ +-\x0d\xed\x3f\x41\xc6\x2b\x46\x26\x06\x74\x5a\x97\xc0\x73\x21\x4d\ +-\xea\xac\xf1\x83\x44\x60\x31\x55\x57\x10\xb4\xc5\xf6\xca\xcb\xd3\ +-\x4f\xe7\x97\x3b\xf3\x41\xbc\x02\x74\x3b\x26\x06\xf8\xca\x75\xc0\ +-\x18\x18\x29\x89\xd3\x1f\xa3\x7d\x15\xb5\x12\xf9\xc0\xe4\x14\xc3\ +-\x96\x20\x36\x29\xf8\xaa\xfc\x49\x29\x86\xcd\x06\xa7\x32\x1c\x78\ +-\x8e\x2e\xb3\xe1\x7a\xa8\xeb\xe2\xc2\xdc\x0f\x3c\x8f\x1d\x24\xaf\ +-\xbc\xed\xa2\x1b\x12\xc9\x7a\x14\x65\x74\xb0\x3b\x1f\xfa\xf8\x49\ +-\xf3\x23\x15\x72\xb2\xd0\x5c\x2f\x20\xc4\x14\x70\xbb\x83\x7c\xf4\ +-\x8d\xd2\x2f\x8c\x88\x0f\x87\xd1\x49\x1a\x09\x81\x49\x3b\xc7\xae\ +-\x3c\x69\xde\xe3\xfe\xd6\x5b\xf4\xe9\xa2\x30\x39\x59\x1c\x29\x4e\ +-\x51\x67\x80\x5c\x0d\x9c\x55\x15\x30\xf5\xad\x84\x89\x2a\x20\x37\ +-\x55\x72\x4b\x66\x40\x9d\x5f\x24\xa4\x5c\x55\x9c\xac\xe4\xf6\x65\ +-\xe7\x43\x1f\xcf\x80\x8e\x90\x52\x2a\xf9\x15\xae\xc5\x3b\xcf\x29\ +-\x1b\x5a\xac\x22\x38\x52\xb8\x07\x0c\x4f\x90\xe4\x24\xf5\x6e\x8e\ +-\x49\xc9\x49\x81\xfc\x43\x53\x8a\xfa\xd6\x95\x3d\xad\xcf\xd1\xc7\ +-\xe3\xf1\x1a\xae\xf8\xc3\x6c\x91\x52\x46\xbe\x59\xa0\x3d\xd9\x64\ +-\x16\x8f\xd5\xb6\x89\x8c\x60\x3b\xd6\xf6\xe2\xed\x61\x0b\xf0\x21\ +-\x8a\x5c\x37\x69\x90\xfa\xa9\x10\xa2\x5f\xb7\xaa\xeb\xea\xce\xb0\ +-\xee\xb0\x4c\xb7\xba\xb4\xdf\xb6\x39\x94\x85\x4d\x16\xe2\x83\x11\ +-\xda\x3b\x34\x5e\x32\x6e\x70\x8f\x84\x9c\x08\xb9\x07\xc9\x7a\xcd\ +-\xaa\xbe\x97\x9b\x25\x02\xbb\x8e\x25\x00\xdc\x30\xfe\x24\x6f\x15\ +-\xca\x04\x6b\x8b\xf6\x90\xc5\xae\x2c\x6b\xb1\xc9\x31\x16\xa7\x08\ +-\xed\x8d\x7b\x8e\xb7\x25\x48\x48\xce\x03\xdb\x41\x6e\xc7\xa1\x7e\ +-\xde\xd1\x41\xf6\x7a\xe2\x86\x61\x40\x57\xbc\x55\x28\x13\x34\x33\ +-\xb7\x3b\x9c\xda\x4d\x36\x97\x32\xde\xe6\x22\xc3\xa5\xc9\x68\x97\ +-\x26\x8c\x2e\x0d\x83\x53\xc3\xe0\x74\x21\xa4\x00\xa3\x82\x54\x90\ +-\x5a\x88\x51\xd8\x66\x66\xb8\x4e\x98\x54\x71\x01\x41\x91\x40\x9e\ +-\xd1\x50\x0b\x2d\x46\x8a\x66\x25\xf6\xfc\xb0\xe6\xf5\xc0\xff\x00\ +-\x7f\xe1\xcb\x24\x2c\x98\x3d\x94\x00\x00\x00\x00\x49\x45\x4e\x44\ +-\xae\x42\x60\x82\ +-\x00\x00\x49\xbb\ +-\x89\ +-\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\ +-\x00\x01\x00\x00\x00\x01\x00\x08\x06\x00\x00\x00\x5c\x72\xa8\x66\ +-\x00\x00\x00\x04\x73\x42\x49\x54\x08\x08\x08\x08\x7c\x08\x64\x88\ +-\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0d\xd7\x00\x00\x0d\xd7\ +-\x01\x42\x28\x9b\x78\x00\x00\x00\x19\x74\x45\x58\x74\x53\x6f\x66\ +-\x74\x77\x61\x72\x65\x00\x77\x77\x77\x2e\x69\x6e\x6b\x73\x63\x61\ +-\x70\x65\x2e\x6f\x72\x67\x9b\xee\x3c\x1a\x00\x00\x20\x00\x49\x44\ +-\x41\x54\x78\x9c\xec\xbd\x67\x7c\x1c\xd5\xbd\xff\xff\x3e\xb3\xab\ +-\xde\x25\xab\x17\xf7\x82\xbb\x64\x19\x1b\x63\x5c\x31\x06\x4c\xb3\ +-\x29\x09\x84\x16\x48\xc8\x4d\x0f\xe1\xde\x4b\x92\x9b\xe4\x47\x92\ +-\xff\x4d\x42\x72\x13\xd2\x81\x04\xd3\x0c\x04\x0c\x36\x1d\x4c\x71\ +-\xc3\x05\x5c\x24\xb9\xf7\xaa\x66\x49\xb6\xba\xb4\x7d\xe7\xfc\x1f\ +-\xac\x7b\x91\x76\x56\xb3\x3b\xbb\xd2\xbc\x1f\xf0\xc2\xab\x99\x73\ +-\xbe\x5a\xcd\xf9\xcc\x29\xdf\x22\x30\x89\x68\x9e\x5c\x27\xb3\xe2\ +-\xe2\x98\x2c\x24\xc5\x4e\x8f\x3a\x58\x95\x4a\xb6\x2a\xc9\x50\x55\ +-\x52\x3c\x52\x26\x79\x54\xe2\x3d\x2a\x31\x48\x21\x54\x55\x2a\x2a\ +-\x42\x01\xf0\xa8\x08\x55\xfa\xda\x88\xb6\x20\x4f\xb5\x67\x55\xf0\ +-\x08\xc0\x6a\xc1\x63\x55\x70\x58\x14\x3a\x15\x21\xdb\x2d\x8a\x68\ +-\xe9\x17\xaf\x6e\x1b\x98\x2e\x37\x0a\x95\x3a\x69\xb5\x1c\x71\x78\ +-\x38\x3c\xa5\x50\xd8\x0d\xf9\xc5\x4d\x74\x41\x18\x6d\x80\x49\xf7\ +-\xfc\x7d\xa5\x4c\x4c\x48\x61\xae\xea\x55\x67\x38\x3d\xa2\xc4\xa5\ +-\x8a\x22\x87\x9b\x74\x97\x97\x58\xb7\x17\x25\x54\x76\xc4\x5a\xe1\ +-\xea\xa1\x2a\xd6\x73\x7b\xac\x07\x79\x18\xc4\x11\x24\x87\x11\x72\ +-\xbb\xc5\x62\xd9\xee\xae\x66\x6f\x69\xa9\x70\x87\xca\x36\x93\xc0\ +-\x30\x05\x20\xcc\x78\x66\xa7\x4c\x8f\xb2\xf3\x65\xb7\x2a\xe7\xda\ +-\xdc\x8c\xb5\xb9\x44\xae\xdd\x43\x8c\x94\xdd\xdf\x1b\x0a\x46\x64\ +-\x49\x46\x64\xfa\x65\x8c\x0b\xd8\x85\x64\xbb\x10\x6c\x53\x85\xb2\ +-\xc1\xe9\x65\xb3\x39\x63\x08\x2f\x4c\x01\x30\x98\x97\xca\xe5\x48\ +-\x9b\x57\xbd\xcf\xe1\x14\xb3\x1c\x1e\x31\xbc\xd3\x45\x52\x98\x8c\ +-\xf5\x8b\x22\x04\x8c\xcc\x92\x0c\xed\x17\x90\x95\x1e\x60\x2b\xb0\ +-\x0e\x29\xcb\x54\xc5\xb2\xaa\x34\x4f\x54\xea\x6b\xa1\x89\x16\x4c\ +-\x01\x08\x31\x4f\x54\xc8\xd4\x44\x0f\x5f\x77\x7b\xb8\xbd\xc3\x25\ +-\x47\x77\x3a\x45\x5c\x38\x0f\xf8\x4b\x31\xa9\x50\x92\x9b\xdc\x73\ +-\xcb\x85\xe4\x10\xf0\xa9\x2a\xe4\x7b\xc9\x36\xcb\xc7\x43\x87\x0a\ +-\x67\xcf\xad\x33\xf1\x17\x53\x00\x42\xc0\xe2\x32\x39\xa1\xdd\xa3\ +-\x3e\xd2\xe6\x56\x66\xb7\xda\xc9\x52\x23\x71\xc4\x9f\xc7\xa8\xec\ +-\x80\x67\x01\x5d\xd1\x01\x62\x39\x52\x2e\x53\xa4\xf2\xee\xf8\x42\ +-\x51\xa3\x77\x07\x26\xe7\x62\x0a\x40\x90\x78\xaa\x5c\x96\x7a\xec\ +-\xf2\x47\x76\x8f\x98\xd3\xe1\x44\x87\x77\x65\x78\x31\x6d\xa0\x4a\ +-\x7a\x7c\x50\xbb\x50\x41\x7e\x2e\x84\x78\x5d\x7a\x94\xd7\x4b\x8a\ +-\x44\x6d\x50\x7b\xeb\xa3\x98\x02\xa0\x23\x8b\xb6\xca\xe1\x0e\x87\ +-\xfc\x55\x9b\x53\xcc\x6d\x75\x90\x6c\xb4\x3d\xc1\xa2\x28\x45\x52\ +-\x52\x10\x52\x49\x53\x11\xf2\x33\x54\xb1\xd8\x8d\xb2\x78\x52\x81\ +-\x68\x0c\x65\xe7\xbd\x19\x53\x00\x74\x60\x51\xb9\xbc\xf3\x78\x07\ +-\xbf\x6d\x73\x50\xa4\x1a\x6d\x4c\x90\x89\xb5\xc2\xec\xa1\x2a\x51\ +-\x21\x3b\x7c\xbc\x00\x27\x42\xbc\x83\xf4\xfe\xb3\x38\xcf\xba\x5c\ +-\x08\xd1\xdb\x26\x57\x21\xc5\x14\x80\x40\x90\x52\xac\xac\x21\x5f\ +-\xb8\xd4\x87\xaa\x5b\xc5\xb7\x0f\x9e\x10\xe9\xde\x3e\xf2\x18\x8e\ +-\xcb\x93\x0c\x4c\x0b\x9b\x5f\xf6\x80\x84\x97\xbd\x28\x0b\x2f\xcf\ +-\x17\x55\x46\x1b\x13\x89\x98\x02\xa0\x81\xef\x7e\x20\x63\x06\x27\ +-\xf3\x13\x87\x9b\xef\x39\xbd\xa4\x7a\x7b\xe9\xeb\x3e\x35\x0e\x06\ +-\x65\x48\x92\xa2\x25\x55\x2d\x82\x43\x4d\x67\x1e\x93\xe9\x83\x54\ +-\xd2\xe2\x0c\x34\xee\x62\x08\xdc\x42\xe5\x35\x50\xfe\x50\x5c\x20\ +-\xb6\x18\x6d\x4e\x24\x61\x0a\x80\x1f\xfc\xf8\x03\x99\xd9\x2f\x89\ +-\xdf\xda\x5d\x7c\xc5\xe5\x25\xc6\x68\x7b\x82\x45\xac\x15\x46\x66\ +-\x4b\x0a\x53\xe5\xe9\x07\xe3\x68\x8b\xa0\xa2\xc6\xf7\xaf\xc4\x18\ +-\x98\x3e\x50\x25\xca\x62\x9c\x8d\xdd\x23\xd7\x49\x78\xbc\x24\xcf\ +-\xf2\x9e\xb9\x3c\xe8\x1e\x53\x00\xba\xe0\x37\x2b\xe5\x80\xd8\x28\ +-\x16\xb6\xda\x99\xa9\xca\xde\xfb\x5d\x59\x2d\x30\x24\x5d\x32\xa4\ +-\x9f\x3c\xc7\xcd\xf7\x48\xb3\x60\x47\x9d\xc0\xa3\x42\x5a\x1c\x5c\ +-\xd1\x5f\x25\x3a\xac\x07\xff\x19\xa4\x64\x87\x82\xfc\xbf\x96\x7c\ +-\xcb\xcb\x33\x85\xf0\x18\x6d\x4f\xb8\xd2\x6b\x1f\xea\x9e\xf0\xf8\ +-\x4a\x59\x10\x65\xe1\x5f\xed\x4e\xe6\x7a\xc3\x74\xe0\x0b\x01\xa9\ +-\xb1\x90\x16\x27\xb1\x9c\x1c\xb4\x76\x37\xb4\x38\x04\x1d\x27\x5d\ +-\x69\x14\x01\xfd\x12\x24\xf1\xd1\xf8\x36\xed\x24\xb8\x25\xb8\x3d\ +-\xa0\x28\x60\x15\xbe\xe9\x7e\x7e\xb2\xc4\x7a\xd6\xc0\x96\x12\xb6\ +-\xd4\x0a\x8e\xb6\x9c\xf9\xd5\xaf\x1c\x20\xc9\x4c\x88\xc8\x17\xea\ +-\x11\x29\xf8\xcd\xc1\x5c\x65\xe1\x1d\x42\x78\x8d\x36\x26\xdc\x08\ +-\xcb\x87\xdb\x28\xfe\xf7\x33\x99\x1b\x27\x78\xba\xcd\x21\x6f\x50\ +-\xa5\x08\xdb\xef\x26\x2d\x0e\x4a\xf2\x55\x92\x2e\xb1\x18\xd9\xdf\ +-\x28\xd8\x59\x27\xb8\xa2\x48\x92\xad\xd1\xb1\x58\x95\xb0\xb9\x5a\ +-\x50\xdb\x76\xee\xaf\x3f\x26\x47\x32\x38\x23\x22\x05\xe0\x14\xbb\ +-\x91\xf2\xb7\xc5\xf9\x96\x97\x84\x10\xbd\x74\xf7\x46\x3b\x61\xfb\ +-\x90\x87\x92\xc7\xde\x95\xf1\xa9\xa9\xea\x93\xad\x0e\xe5\x6e\xaf\ +-\x0c\x5d\x74\x5d\x20\x44\x5b\x60\xce\xb0\xae\x8f\xe1\x3a\x5c\xf0\ +-\xe9\x7e\x05\xab\x02\x43\xfb\x49\x86\xf5\x93\xf8\x23\x67\x5e\x09\ +-\x9b\x2a\x05\x75\x1d\x17\x5e\x2c\x04\x64\x25\x48\x92\x62\x20\x3e\ +-\x1a\x72\x92\x24\xf1\x51\x3d\xf8\x45\x8c\x63\x8b\x22\xd4\x47\xc7\ +-\xe7\x45\x7d\x6c\xb4\x21\xe1\x40\x9f\x16\x80\xc7\x1e\x93\x4a\xf2\ +-\x2c\x1e\xb1\xbb\x79\xcc\xe9\x25\xb8\x7e\x6d\x3a\x91\x18\x0d\xc3\ +-\x32\x7d\xd3\x7e\x8f\xd7\x37\x5d\x8f\xb2\x42\x6e\x92\x44\x39\xeb\ +-\xaf\xb9\xff\x84\x60\xdf\x71\x81\x14\x70\x45\xa1\x4a\x46\x42\xd7\ +-\xed\x7a\x54\xf8\xe2\xa8\xe0\x84\xcd\xbf\x47\x22\x4a\xf1\xf9\x03\ +-\xc4\x5a\x7b\xf0\xcb\x18\x8a\xf8\x14\x45\x7c\xbf\x24\x57\xec\x32\ +-\xda\x12\x23\xe9\xb3\x02\xf0\xc7\xd5\xf2\x1a\x97\xca\x0b\x36\x37\ +-\x39\x46\xdb\xa2\x07\x85\x29\x92\x09\x01\x7a\xe7\xa9\x12\xbe\xa8\ +-\x14\x34\x5c\xe4\xcd\xdf\x15\x7a\x05\x04\x19\x86\xc0\x8d\xe4\x49\ +-\xd5\xa1\xfc\xbc\x74\xb0\x68\x35\xda\x1c\x23\xe8\x73\x02\xf0\xeb\ +-\x4f\x65\x46\x6c\x0c\x6f\xb6\xda\xb9\x2a\x82\x1f\xdd\x0b\x28\xce\ +-\x93\xf4\x0f\xc0\x41\x47\x02\x65\xd5\x82\xea\x56\xed\x8f\xc2\x35\ +-\x43\x55\xe2\xa3\x35\xdf\x16\x8e\x34\x48\xe4\x8f\x4a\xf2\x2c\xcf\ +-\xf7\xb5\xa3\xc3\xb0\x5e\xef\xea\x8a\x94\xe2\x0f\x6b\xe5\x7f\x7a\ +-\x05\xb5\x2d\xbd\x6c\xf0\x0f\x4a\x0f\x6c\xf0\x83\x6f\xa9\x10\xc8\ +-\xe0\x4f\x3e\xb9\x17\xd0\x4b\xc8\x12\x88\x67\x2b\x6a\xbd\xab\xb7\ +-\xd6\xc8\xe1\x46\x1b\x13\x4a\xfa\xc4\x0c\x60\xa5\x94\xd6\xf2\xb5\ +-\xf2\x8b\x56\xbb\x98\x60\xb4\x2d\x7a\x53\x98\x22\x29\xc9\xf7\x6f\ +-\x93\xef\x7c\x9c\x1e\x58\x7e\x40\xc1\x15\xc0\xe1\x58\xdc\xc9\xf4\ +-\x60\x96\xde\xf7\x0a\xb1\x4b\xf8\x5d\x6c\x8b\xf2\xeb\x51\xa3\x84\ +-\xcb\x68\x63\x82\x4d\xaf\x17\x80\xb2\x5a\x39\x41\x48\x75\xe1\xfe\ +-\x13\x62\xdc\xce\xfa\xde\xf5\xeb\xc6\x47\xf9\x36\xe2\x2c\x3d\xf8\ +-\xb5\x54\xe9\x3b\x35\x70\x7a\x7c\x8d\xb8\xbc\xe0\xf6\x42\xab\x03\ +-\xda\x9c\x02\x9b\xd3\x27\x14\x17\x3b\x37\x1b\x9f\x27\x19\x10\x3e\ +-\x71\x01\xba\x22\xa1\x42\x0a\xe5\x6b\xa5\x79\xa2\xdc\x68\x5b\x82\ +-\x49\xc4\xee\xe1\x76\x87\x94\x52\xd9\x72\x4c\xfd\xae\x94\xea\xef\ +-\x80\xe8\xb8\xc8\x3c\xb2\xea\x92\xa2\x54\xd9\xa3\xc1\x0f\x3e\x67\ +-\xa1\xe4\x18\x20\xe6\x62\x03\xd9\xf7\x99\x94\xd0\xee\x84\xbd\xc7\ +-\x05\x35\x67\xf9\x07\xf4\xd6\x58\x08\x00\x01\xc5\x42\xaa\x1b\xca\ +-\x6a\xbc\xff\x7b\x30\x4f\xf9\x55\x6f\x75\x22\xea\x5d\xaf\xc4\x93\ +-\x6c\xae\x95\x45\x8a\xf4\x2e\x02\x31\x0d\x7c\x6f\xb5\x0d\x55\x0a\ +-\x8d\x9d\x46\x5b\xa6\x2f\xe3\x72\x25\x03\xd3\xbb\x7f\x03\xcb\x93\ +-\xff\xe9\xa9\x6b\x93\xc4\xb7\x67\x70\xb8\x49\x90\x18\x2d\x29\x2d\ +-\x90\xc4\xf4\xda\x57\xc8\xd9\xc8\xcf\xbd\x56\xcb\xdd\x13\xb3\xc5\ +-\x21\xa3\x2d\xd1\x9b\x5e\x27\x00\x2f\x6c\xf2\xfe\xd6\x6a\x15\xdf\ +-\x73\x7b\x89\x73\x7a\xa0\xc3\x25\x68\x77\xfa\xa6\xba\xbd\x8d\xdc\ +-\x24\xc9\xa4\xa2\xae\x7f\xb1\x83\x8d\x82\xdd\x0d\x82\x91\xd9\x92\ +-\x41\x7e\x88\x85\xc9\x25\x69\x93\x42\x7e\x7b\x42\x9e\xf5\x25\xa3\ +-\x0d\xd1\x93\x5e\x23\x00\xef\x6d\x93\x69\xd5\x36\xbe\xa8\x6d\x63\ +-\x58\x57\xd7\xc5\x58\xc1\x22\xc0\xd6\x4b\x32\xd6\x9f\xbd\x0e\x6f\ +-\x77\xfa\x3c\x05\x63\xac\xbe\xb7\xf5\x8e\x3a\xc1\xc1\x46\xdf\x9f\ +-\xb8\x30\x55\x32\x21\xdf\x14\x80\x1e\x23\x78\x41\x45\xf9\x56\x69\ +-\x9e\xb0\x19\x6d\x8a\x1e\xf4\x0a\x01\xf8\x77\x99\xbc\xea\x58\xa7\ +-\x5c\xa6\x28\x22\xbe\x5f\x82\x24\x21\xca\xb7\x6e\xdd\x5e\x27\x38\ +-\x95\xa8\x23\x31\x06\x8a\x73\xcf\x78\xc4\x35\xdb\xe1\x70\x93\xa0\ +-\xd3\x2d\x48\x39\xb9\xfe\x3d\xdc\x2c\x08\x97\xfc\xfb\xfe\x22\x80\ +-\xac\x44\x89\x57\xc2\x89\x4e\x41\x9c\x15\xc6\xe6\x4a\x8e\x36\x73\ +-\xda\xa5\xd7\x6a\x81\x2b\xfb\x87\x61\x1c\x7f\xe4\xb2\x4d\xf5\x2a\ +-\x0b\x4a\x8b\xc4\x41\xa3\x0d\xe9\x29\x11\x2f\x00\x2f\x6e\xf2\xfe\ +-\x8f\x43\x15\x3f\x1f\x99\x25\xa3\xcf\x3e\x97\x6e\xb1\xc3\xaa\x43\ +-\x67\xce\xa8\x86\x64\x48\x46\xe7\x74\x3d\xba\xb7\x9f\xf5\xc6\xec\ +-\x0d\x08\x01\xfd\x53\x25\xc3\x33\x25\xbd\x71\x13\xd4\x60\xda\x84\ +-\x90\xf7\x15\xe7\x59\xdf\x32\xda\x90\x9e\x10\xb1\x4f\xfb\x63\x52\ +-\x2a\x39\x1b\xf8\xb0\xdd\x29\xaf\x99\x31\xf8\xcc\x6e\xb8\xcb\xeb\ +-\x7b\xb3\x1f\x38\x21\x70\x9f\xb5\x4b\x6d\xb5\xc0\x75\xc3\xbb\x3e\ +-\x32\xab\x6a\x15\x94\x55\x87\xdf\x57\x62\x51\xb4\xed\xb8\xa7\xc4\ +-\x42\x41\x8a\x2f\xb1\x47\xe4\xfa\xea\x47\x04\x12\xf8\x5d\x71\x9e\ +-\xf2\x93\x48\x8d\x30\x0c\xbf\xa7\xdd\x0f\x9e\xde\x2c\x73\xed\x0e\ +-\x2a\x9a\xed\x64\x4f\x1f\xa8\x92\x7a\x72\x6a\x5b\xd5\x2a\xd8\x7a\ +-\x4c\xe0\xb9\xc8\x81\x4d\x46\x02\x5c\x39\x40\x3d\xc7\xf5\x51\x4a\ +-\xa8\xef\x14\x20\x7d\x71\xf5\xdb\xeb\x02\xf3\x8a\xd3\x1b\x21\x7c\ +-\xd3\xfa\x82\x64\xc8\x4c\xf4\x0d\xe2\xf2\x1a\x41\x65\xcb\xc5\x6d\ +-\x8b\xb1\x42\x46\xbc\xa4\x5f\x02\xe4\x24\xca\xde\xe4\xa1\x17\x21\ +-\x88\xb7\x2d\x16\xf1\x95\x71\x39\x22\xe2\xce\x99\x8c\x7f\xda\x35\ +-\xf2\xc2\x16\x59\x5c\xdf\x22\xd7\x75\xba\x44\xdc\xd8\xb3\x12\x54\ +-\xee\x6e\x10\xec\x3d\x7e\xe9\x5f\xa7\xb4\x40\x52\x90\x72\x66\x09\ +-\x20\x25\x6c\xac\x12\x1c\x6b\x0f\x9f\xaf\x20\x4a\x81\xa2\x34\xc9\ +-\xa0\x0c\xdf\x3e\x06\x80\xdd\x03\x15\x35\xe7\x06\xea\x08\x7c\x39\ +-\x01\xf2\x52\x24\x59\x89\xbe\x10\xdd\xf0\xf9\x2d\xfa\x2c\x5b\x2d\ +-\x52\xb9\x61\x5c\x81\xa8\x36\xda\x10\x2d\x44\xd4\x04\xf1\x85\x4d\ +-\xf2\xe6\xda\x66\xde\xb0\xbb\x85\x75\x54\xf6\x99\xc1\x5f\xd5\xd2\ +-\xf5\xe0\x07\x2e\x48\x65\x75\xa0\x31\x3c\x06\x7f\xb4\x05\xb2\x93\ +-\x24\x79\x49\x90\x95\x74\xa1\x63\xcf\xa6\x4a\x85\xa6\xb3\xca\x69\ +-\x26\xc7\x40\x71\x7e\xef\xdc\xd0\x73\x79\x3c\xbc\xfa\xf6\x4a\xae\ +-\x9d\x31\x91\xac\x8c\x54\xa3\xcd\xd1\xca\x38\xaf\x50\xbf\x28\xaf\ +-\x96\xf3\x4a\x0a\xc4\x56\xa3\x8d\xf1\x97\x88\x11\x80\x17\xcb\xe4\ +-\xc3\x47\x5b\xf8\x83\xdb\x8b\x18\xda\xef\x4c\x59\x2a\xb7\xea\xdb\ +-\xbc\xeb\x8e\x56\x07\x64\x25\xfa\xfe\xbf\xc5\xe1\x9b\x31\x5c\x8a\ +-\x7e\x09\x92\x7e\xf1\x10\x1f\x03\xd1\x8a\x6f\x0d\xee\xf2\xc2\x81\ +-\x13\x82\x66\x1d\x6a\xdb\x5a\x14\x5f\x42\x8d\xc2\x14\xdf\x54\x5f\ +-\xe9\xc2\x7c\xab\x45\x02\x02\x45\xf8\x2a\xf3\x0e\xe9\x17\xe6\x19\ +-\x4b\x02\xa4\x6c\xfb\x7e\xfe\xb8\x70\x09\x47\xab\xeb\xb9\x7a\x6a\ +-\x89\xd1\xe6\x04\x4a\xbe\x14\xea\x9a\xb2\x5a\xf7\x1d\x13\xf2\xa2\ +-\x96\x19\x6d\x8c\x3f\x44\x84\x00\x2c\xdc\xec\xfd\xcb\xe1\x26\xbe\ +-\xeb\x95\xbe\xa9\xef\xc8\xac\x33\x53\xf9\x83\x8d\xc2\xaf\x60\x96\ +-\x43\x4d\xe2\x74\xc4\x5c\x79\x8d\x72\x49\xc7\xa0\xf8\x68\x5f\xdd\ +-\xbb\xd4\xd8\x73\x3d\xe7\xda\x9c\xe0\xf4\xf6\x6c\xc6\xa0\x08\x18\ +-\xd2\x4f\x32\x24\x43\xfa\x9d\x5c\xb3\x38\x4f\x72\xa2\xf3\xcc\x5e\ +-\x40\x6f\xa3\xa1\xb1\x85\xa7\x5f\x79\x9f\x8f\x56\x6f\x36\xda\x14\ +-\x5d\x10\x90\x84\x54\xde\x2e\xab\xf1\xdc\x3b\x21\xdf\xfa\x9a\xd1\ +-\xf6\x74\x47\xd8\x3f\x52\x4f\x7d\xa1\x2e\xae\x6c\x16\xb7\x9f\x3a\ +-\x9f\x1f\x93\xa3\x9e\x33\x30\xab\x2f\xb1\x31\x76\x3e\x76\xb7\x2f\ +-\x4d\x16\xd0\xa5\x60\xd8\x5c\xb0\xfa\x90\x2f\x9d\x56\xac\xd5\x77\ +-\x7a\xe0\xf6\x42\x67\x0f\xe3\xc2\xa2\x2d\x30\xa5\xff\x99\x0d\x4b\ +-\x7f\x89\x8b\xf2\x39\xf1\xf4\x36\x9c\x2e\x37\x6f\x7c\xf0\x19\xcf\ +-\xbf\xf1\x31\x76\x47\xaf\x0b\xba\x8b\x16\x88\x97\xcb\x6b\x3c\x89\ +-\x25\xf9\xd6\x85\x46\x1b\xd3\x15\x61\x2d\x00\x7f\x5f\xaf\x7e\x58\ +-\xdb\x26\xae\x3d\xf5\xef\x9c\x24\x79\x4e\x41\xca\x56\x87\x2f\x92\ +-\xcd\x5f\xb4\x84\xbd\x7a\x54\x6d\x6d\x77\x47\x69\x81\xbc\xe8\xe0\ +-\xef\xb4\xd9\xe9\xb4\x39\xe9\xb4\x3b\xb0\x39\x1c\xd8\xed\xbe\x4e\ +-\x5d\x1e\x0f\x0e\xe7\x85\xee\x8a\xb1\x31\x51\x44\x5b\x7d\x7f\xb6\ +-\xa4\x04\x5f\x83\x71\x71\x31\xa4\x24\x26\x90\x94\x18\x87\xa2\x84\ +-\xff\x02\x61\xed\xa6\x9d\xfc\xe5\xf9\x37\xa9\xad\xef\xd5\x25\xfe\ +-\x2c\x20\xfe\x55\x56\xeb\x4d\x9a\x90\x67\xf9\x93\xd1\xc6\x5c\x8a\ +-\xb0\x15\x80\x27\x3f\x57\x3f\x3d\xd6\x2e\x66\x9f\xfd\x59\xd1\x59\ +-\xfb\x42\x52\xfa\x5c\x5d\xb5\xa0\x08\xdf\x71\x59\x66\x02\x24\xc7\ +-\xfa\xda\xd8\xa7\xd3\xba\xfe\x6c\xa4\x54\x69\x69\x6e\xa2\xa3\xad\ +-\x99\x8e\xb6\x56\xdc\xb6\x56\x8e\x6e\x68\xe1\x44\x53\x2b\x27\x9a\ +-\xdb\x38\xde\xd4\x4a\x47\xa7\x9d\x0e\x9b\xce\x1d\x03\xf1\xf1\xb1\ +-\xa4\x24\xc6\x93\x92\x94\x48\x46\x5a\x12\xd9\x19\xa9\xf4\x4b\x4f\ +-\x21\x27\x33\x9d\xa2\xfc\x4c\x8a\xf2\xb3\x89\x8f\x35\xa6\xb6\x49\ +-\x75\xdd\x09\xfe\xbc\x70\x29\x9f\x57\xec\x36\xa4\x7f\x03\x10\x42\ +-\xf2\x44\x45\x8d\x37\xa5\x38\xdf\xf2\x0b\xa3\x8d\xb9\x18\x61\x29\ +-\x00\x4f\x6f\x50\x57\xd7\xb4\xfa\x22\xf9\xce\x26\x2e\xca\x37\x15\ +-\x56\xa5\xef\x68\xec\x78\x67\xd7\x02\x90\x18\xe3\xf3\x84\x8b\xb1\ +-\xfa\x62\xe7\xd3\xe2\xcf\xec\xb2\xdb\xdd\xb0\xa3\xbe\x67\x83\xdf\ +-\xeb\xf5\xd2\xd2\x74\x9c\x13\x0d\x75\xb4\x36\x9f\xe0\x44\x43\x1d\ +-\x8d\xc7\xeb\x68\x3a\x5e\x8f\xdb\x6d\xcc\xb4\xd6\x66\x73\x60\xb3\ +-\x39\x38\xd6\xd0\x74\xd1\x9f\x5f\x3f\xf3\x72\x7e\xf2\xed\x3b\x43\ +-\x6a\x93\xd3\xe5\xe6\xe5\xb7\x96\xf3\xd2\x9b\x2b\x70\xb9\x7b\x49\ +-\x10\x86\x06\x24\x3c\x56\x5e\xe3\x55\x4a\xf2\x2d\xff\xcf\x68\x5b\ +-\xce\x27\xec\x04\xe0\xa9\xcf\xd5\x4f\x2f\x36\xf8\x01\x76\xd4\x2b\ +-\x14\x24\x4b\x0e\x37\x0b\xda\x1c\xdd\xb7\x35\x22\xf3\xc2\xb3\xff\ +-\xfa\x76\x41\x65\x0b\xd4\xb5\x9f\x89\x13\xf0\x97\x96\xe6\x46\x6a\ +-\x8f\x1e\xa2\xae\xb6\x8a\x9a\xaa\x43\x34\x1c\xab\x46\x46\x5a\xf0\ +-\x40\x88\x59\xb7\x79\x27\x7f\x7a\x76\xe9\x25\x05\xa9\x0f\xf1\xf3\ +-\x8a\x5a\xaf\xa3\x38\xcf\xf2\x1b\xa3\x0d\x39\x9b\xb0\x12\x80\xa7\ +-\x36\xc8\x77\x6b\x5b\x99\x7d\xa9\x9f\x37\x76\x42\x63\x37\x6f\xfd\ +-\xb3\x39\xdc\x24\x90\xf8\x66\x0c\xad\x76\xa8\x6d\x13\x38\xfc\x2c\ +-\x12\xe5\xf5\x7a\xa9\xad\x3a\x44\xd5\xe1\x83\x1c\xab\x39\x42\x6d\ +-\xd5\x11\x9c\x0e\xfd\xa7\xec\xbd\x95\xca\xda\x06\x9e\x58\xb8\x84\ +-\x4d\x5b\xf7\x19\x6d\x4a\xd8\x20\x25\xbf\x2e\xaf\xf6\xba\x4a\x0a\ +-\x2c\x7f\x30\xda\x96\x53\x84\x8d\x00\x3c\xb9\x5e\xbe\x5e\xdb\xca\ +-\x0d\x7a\xb6\xd9\x68\x83\x46\x3f\xf3\xdc\x03\xb4\xb5\x34\x71\x70\ +-\xef\x4e\x8e\x1c\xd8\x4d\xd5\x91\x03\xb8\x5c\x4e\x3d\xcd\xe9\x13\ +-\xd8\x1c\x4e\x5e\x78\xe3\x13\x16\xbf\xb7\x0a\xf7\xc5\x7c\xb2\xfb\ +-\x3a\x82\xdf\x57\xd4\x7a\xda\x8a\xf3\xac\xff\x32\xda\x14\x08\x13\ +-\x01\xf8\xe7\x06\xef\x33\xd5\xad\xdc\x66\x44\xdf\x4d\xc7\xeb\xd9\ +-\xb7\x6b\x2b\xfb\xf7\x6c\xa3\xbe\xd6\x2c\x31\xdf\x13\x96\xaf\xdb\ +-\xc2\xdf\x5f\x7c\x9b\x86\xc6\x16\xa3\x4d\x09\x67\x84\x94\xe2\xc9\ +-\xb2\x1a\x4f\x5b\x38\xf8\x09\x18\x2e\x00\xcf\x6e\xf2\xfe\xf7\xd1\ +-\x16\xe5\xc1\x50\xf6\xe9\xb0\x75\xb2\x6f\xf7\x56\x76\x6e\xd9\x44\ +-\x4d\x65\xaf\xcb\xf2\x14\x72\x2a\x6b\x1b\xf8\xd3\xb3\x4b\xd9\xb8\ +-\x65\xaf\xd1\xa6\x44\x0a\x16\x21\xc4\xa2\xf2\x1a\x77\x63\x49\x7e\ +-\xd4\xa7\x46\x1a\x62\xa8\x00\xbc\x50\x26\xe7\x57\xb6\xf0\xdb\x50\ +-\xec\xa3\x49\x29\x39\x72\x60\x37\x5b\x36\xae\xe5\xd0\xfe\xdd\x48\ +-\x19\x91\xd1\x9b\x61\x85\xcd\xe6\xe0\xd9\xd7\x3f\xe2\x8d\x0f\xd6\ +-\xe0\xf1\x9a\xd3\x7d\x4d\x48\xa2\x40\x59\xb2\xb9\x4a\x4e\x2d\x2d\ +-\x14\xdb\x8d\x32\xc3\x30\x01\x78\xb9\x42\x8e\xaf\x6c\x61\xb1\xdb\ +-\x1b\xdc\x40\x36\xa7\xc3\xce\xb6\xb2\xf5\x6c\xdd\xb4\x8e\x96\xe6\ +-\x5e\xed\x78\x12\x32\xa4\x94\x7c\xb2\xa6\x9c\xbf\xbf\xf8\x0e\x8d\ +-\x2d\x6d\x46\x9b\x13\xc9\x24\x2b\x8a\xfa\xce\xf6\x7a\x39\x79\x4c\ +-\xb6\xa8\x37\xc2\x00\x43\x04\xe0\xc5\xad\x32\xab\xa6\x45\xae\xb3\ +-\xbb\x45\xd0\xfa\xb7\x75\xb6\xb3\x65\xd3\x5a\xca\x3e\x5f\x6d\xee\ +-\xde\xeb\x48\x65\x4d\x3d\x4f\x3c\xbb\xd4\xdc\xdd\xd7\x8f\x01\x6e\ +-\x8f\xfa\xfe\xd6\x3a\x39\xdd\x88\x7c\x02\x21\x17\x80\xc5\x3b\x65\ +-\x74\x4d\x13\xdb\x3b\x9c\x22\x28\xd5\x78\x3b\xda\x5a\xf9\xfc\xb3\ +-\x8f\xd8\x51\xbe\x01\xaf\xd7\xcf\x33\x3f\x93\x6e\xe9\xb0\xd9\x59\ +-\xf8\xea\x32\x96\x7e\xb4\x16\x6f\x6f\x2e\x08\x60\x0c\x13\x3e\x3f\ +-\xc2\xf6\x95\x2b\xe5\xb0\x99\x33\x45\x48\x1f\xda\x90\x0b\x40\x43\ +-\xab\x5c\xd3\x6c\x17\x59\x7a\xb7\xeb\x74\xd8\xd8\xb0\x66\x39\xe5\ +-\x1b\x56\xe3\xe9\x83\xde\x66\xc1\x42\x4a\xc9\x47\x9f\x95\xf1\x8f\ +-\x45\xef\xd0\xd4\xd2\x6e\xb4\x39\xbd\x96\x13\x9d\x0c\x94\xf1\x7c\ +-\x0a\xcc\x08\x65\xbf\x21\x15\x80\x85\x1b\xbd\xbf\x39\xda\x22\x2e\ +-\xd7\xb3\x4d\x55\x55\xd9\xb2\x69\x0d\xeb\x56\x2c\xc3\xe9\xe8\x15\ +-\x99\x9a\xc3\x86\x7d\x87\xaa\xf9\xe3\x33\x4b\xd8\xb1\xef\x88\xd1\ +-\xa6\xf4\x7a\x06\x67\x48\xf6\x34\x88\xe9\x0b\x37\x7b\x7f\xf9\x60\ +-\xa9\xe5\xe7\xa1\xea\x37\x64\x02\xb0\x68\x93\x9c\x73\xa4\x8d\x47\ +-\xf5\x6c\xb3\xae\xa6\x92\x4f\xdf\x7f\x9d\xba\x9a\x4a\x3d\x9b\xed\ +-\xf3\x9c\x9a\xee\x2f\x59\xb6\x16\x55\x35\xa7\xfb\xa1\x60\x70\x86\ +-\x64\xff\x09\x41\x6d\xab\xf2\xd3\x17\xcb\xe4\xaa\x7b\x27\x88\x15\ +-\xa1\xe8\x37\x24\x02\xf0\xca\x5e\xd9\xaf\xba\x8e\x77\xf4\xda\xf1\ +-\x77\x39\x1d\xac\x5c\xf6\x26\xdb\x2b\x36\x10\x71\x89\xfc\xc3\x18\ +-\x55\x95\xbc\xbf\x62\x03\x4f\xbd\xf2\x1e\xad\x6d\x11\x97\xdf\x32\ +-\xa2\xb1\x2a\xbe\xe4\xae\x9d\x2e\x44\x7d\x87\x7c\xef\xcd\x0a\x99\ +-\x37\xbf\x58\x04\xdd\xa3\x2a\x24\x02\xd0\xd2\xc4\xe7\x1d\x4e\x62\ +-\xf5\x68\xab\xf2\xf0\x3e\x96\xbd\xf9\x0a\x6d\xad\xcd\x7a\x34\x67\ +-\x72\x16\x7f\x7b\xf1\x6d\x16\xbf\xb7\xda\x68\x33\xfa\x2c\xee\x93\ +-\xae\x14\xed\x4e\x11\xd7\xe0\x94\x6b\x81\xd1\xc1\xee\x33\xe8\xd9\ +-\x23\x9e\xd9\xe4\x7d\xaa\xae\x9d\x21\x3d\x6d\xc7\xeb\xf5\xb0\xe2\ +-\x83\xa5\x2c\x7e\xe1\x1f\xe6\xe0\x0f\x12\x1d\x9d\xe6\x71\xa9\x91\ +-\xe4\x26\xfb\x66\xb3\x42\x40\x8b\x43\x8c\x5a\xba\x4b\xfe\x57\xb0\ +-\xfb\x0c\xea\x0c\xe0\xa9\x8d\x72\x76\x6d\x2b\x0f\xf5\xb4\x9d\xf6\ +-\xd6\x16\xde\x5d\xfc\x1c\xb5\xd5\x47\x74\xb0\xca\xc4\x24\x3c\x29\ +-\xce\x93\x8c\xcb\xf5\x89\xc0\xc9\x44\xb1\x3f\x29\xaf\x95\x8b\x4b\ +-\xf2\xc4\xd1\x60\xf5\x19\xb4\x19\xc0\xe2\x9d\x32\xba\xcd\xce\x9b\ +-\x1e\xb5\x67\xeb\xfe\xaa\x23\xfb\x59\xf4\xf4\xff\x99\x83\xdf\xa4\ +-\x4f\xa0\x08\xce\xce\x12\x9d\x8a\xf4\x2e\x5a\x2c\xa5\x9f\x29\x64\ +-\x03\xe8\x2f\x58\x0d\x37\xb7\xcb\xf7\x3b\x9c\x24\xf5\xa4\x8d\xb2\ +-\xcf\x57\xb1\xf8\xf9\xbf\x63\xeb\x34\xcf\x9f\x4d\xfa\x2a\xe2\xaa\ +-\x21\xc7\xd4\xa0\x2d\x05\x82\x22\x00\x2f\x6d\x95\xb7\x1d\x6b\x17\ +-\x57\x07\xdc\x80\x94\xac\x5f\xf5\x21\x2b\x97\xbd\x69\x66\xdc\x31\ +-\x31\x81\x5f\x6e\xa9\x91\xc5\xc1\x68\x58\x77\x01\xf8\xcb\x7e\x19\ +-\x53\xd7\xca\xf3\x97\xca\xbb\xdf\x1d\x5e\xaf\x87\x77\xdf\x78\x81\ +-\xf5\x2b\x23\xa2\xae\x82\x89\x49\xf0\x91\x44\xd5\xb6\xab\xaf\xff\ +-\x7d\xa5\x4c\xd4\xbb\x69\xdd\x05\x20\xae\x99\xb7\xdb\x1c\x24\x04\ +-\x72\xaf\xd7\xeb\xe5\xdd\xc5\xcf\xb1\x77\x47\x85\xde\x66\x99\x98\ +-\x44\x34\x07\x1a\x95\xc1\x4a\x2c\x4b\xf5\x6e\x57\x57\x01\x58\x54\ +-\x26\xaf\xad\x69\x65\x6e\x20\xf7\x9e\x1a\xfc\x07\xf6\xec\xd0\xd3\ +-\x24\x13\x93\x88\xa7\xc5\xee\xcb\x87\x59\xdf\xc1\x9c\x85\x9b\xe4\ +-\x75\x7a\xb6\xad\x9b\x00\x2c\x5e\x2c\x2d\xf5\x1d\xbc\x1a\xc8\xd4\ +-\x5f\x3d\x3d\xf8\x0d\xcb\x8b\x60\x62\x12\x96\x48\x60\x7b\xbd\x72\ +-\x3a\xb9\x6d\xb3\x9d\x7f\x2f\x5e\xac\xdf\xa9\x80\x6e\x02\xd0\x31\ +-\x90\x7f\xb5\x39\x49\x09\xe4\xde\x15\xcb\x96\x9a\x83\xdf\xc4\xe4\ +-\x22\xec\xa8\x13\x34\x9e\xe5\x95\xdd\xe6\x20\xa5\xb5\x3f\xba\x95\ +-\x1b\xd3\x45\x00\x16\x6f\x91\xf9\xc7\xda\xb9\x2f\x90\x7b\x37\xac\ +-\xf9\x84\x2d\x1b\xd7\xea\x61\x86\x89\x49\xaf\xc1\xe1\x81\x4d\xd5\ +-\x82\x83\x8d\x17\xba\xd1\xd4\xb7\x73\xcf\x33\xeb\x64\x7f\x3d\xfa\ +-\xd1\xc5\x13\xb0\xc5\x21\x97\x3a\x3d\x42\xb3\x98\xec\xd9\x51\xc1\ +-\x9a\xe5\xef\xeb\x61\x82\x89\x49\xaf\xa0\xcd\xc9\xc9\xa8\xc0\x4b\ +-\x17\xae\x71\xa9\x28\x4e\x85\xa5\xc0\x84\x9e\xf6\xd7\xe3\x19\xc0\ +-\xbf\xcb\xe5\xec\xda\x76\xed\x31\xfe\x8d\xc7\xeb\xf8\xe8\xad\x57\ +-\xcc\x68\x3e\x13\x13\xc0\xe3\x85\xb2\x1a\xc1\xca\x03\x0a\x55\x2d\ +-\xdd\x57\xad\x6a\xe8\xa0\xe4\xb9\x32\x79\x63\x4f\xfb\xed\xf1\x0c\ +-\xa0\xc9\xce\x22\xad\x1b\x7f\x6e\x97\x8b\xb7\x5f\x7b\xd6\xb0\xfa\ +-\x79\xc1\xc6\x6a\xb1\x90\x96\x92\x48\xbf\xf4\x14\x12\xe2\x7d\x41\ +-\x90\x2e\x97\x87\x6d\x7b\xcc\x14\xe4\x26\x17\xe2\x51\x61\xed\x51\ +-\x85\x16\x0d\xb1\x58\x52\x42\x73\x27\x0b\x81\x1e\x65\xd7\xea\x91\ +-\x00\xbc\xb8\xc9\xfb\xf0\xc1\x66\x72\xb5\xde\xf7\xc9\xfb\x8b\x69\ +-\x3a\x6e\x48\x12\x54\xdd\x89\x8b\x8b\xa1\x64\xd4\x10\x86\x0f\x2a\ +-\x64\xd8\xc0\x02\x86\x0c\xc8\x25\xbb\x5f\x1a\x42\x9c\xbb\x76\xab\ +-\xad\x6f\xe4\x8e\x6f\xff\x7f\x06\x59\x69\x12\xce\xec\xa8\x13\x9a\ +-\x06\xff\x29\x5a\x1c\x64\x3e\xb7\xc9\xfb\x93\xaf\x4e\xb4\xfc\x3a\ +-\xd0\xbe\x03\x16\x80\xc5\x8b\xa5\xe5\xa8\x5d\xfe\xaf\xd6\x09\xfc\ +-\xee\x6d\x9b\xd9\xb5\x65\x53\xa0\xdd\x86\x05\x39\x99\xe9\xcc\xbc\ +-\x62\x1c\x57\x94\x5c\xc6\x98\x11\x83\x88\xb2\x06\x2d\x56\xc3\xa4\ +-\x97\xd3\x6c\x87\xa3\x2d\x81\xc7\xcb\x1d\xb7\x89\x9f\x2e\x5e\x2c\ +-\x1f\xbf\xe3\x0e\x11\x50\x61\x86\x80\x05\xa0\x63\xa0\xfa\xfb\xf6\ +-\x66\x25\x4e\xcb\x3d\x0e\x5b\x27\x2b\x97\xbd\x15\x68\x97\x86\x12\ +-\x6d\xb5\x32\x75\xe2\x28\xe6\x4e\x9f\xc8\x15\x25\x97\xa1\x28\x41\ +-\x4f\xa5\x60\xd2\xcb\x91\x12\xb6\x1e\x53\x7a\xb4\x0d\xd6\xe1\x14\ +-\x71\x2d\x03\xd4\x3f\x00\x3f\x08\xe4\xfe\x80\x04\xe0\x31\x29\xad\ +-\x8d\x9f\xf1\x4d\xad\xf7\x2d\xff\x70\x69\xc4\x45\xf6\xc5\xc5\x46\ +-\x73\xc3\xac\xc9\xdc\xbd\x60\x36\x19\xa9\xc9\x46\x9b\x63\xd2\x8b\ +-\xa8\x6c\x09\x6c\xea\x7f\x3e\x8d\x1d\xca\x37\x17\xef\x94\xff\x7d\ +-\xc7\x28\xa1\x79\x53\x2d\x20\x01\x18\x54\xae\xfe\xfe\x80\x53\xd1\ +-\x94\xe2\xeb\xf0\xfe\xdd\xec\xde\xb6\x39\x90\xee\x0c\x21\x36\x26\ +-\x9a\x3b\x6e\x98\xc6\x97\xe6\xcd\x20\x25\x39\xa0\xd0\x06\x13\x93\ +-\x4b\x22\x81\x03\x17\x39\xe3\x0f\x04\xbb\x87\xe8\xd6\x4e\xfe\x04\ +-\x7c\x4b\xeb\xbd\x9a\xe7\xb1\x8b\xa5\xb4\x34\x74\x88\xff\xd0\x72\ +-\x8f\xea\xf5\xb2\xe2\xc3\x25\x5a\xbb\x32\x8c\x29\x13\x46\xb2\xe8\ +-\x89\x47\x79\xe8\xce\x79\xe6\xe0\x37\x09\x0a\x76\x17\xb4\xeb\x58\ +-\x7d\xbe\xd1\x26\xbf\xf6\xdc\x61\xa9\x39\xef\xa6\xe6\x19\x80\x7b\ +-\x8b\xfa\xfb\x36\x8d\x6f\xff\xad\x65\xeb\x69\x6e\x3c\xae\xb5\xab\ +-\x90\x93\x95\x91\xca\x0f\x1e\x58\xc0\xb4\x49\x63\x8c\x36\xc5\xa4\ +-\x97\x63\xd7\xb9\x76\x8d\xcd\x25\xa2\x3c\xc7\xd5\x3f\x03\xdf\xd0\ +-\x72\x9f\xa6\x19\x80\x94\x52\x34\x74\x28\x9a\x3a\x70\xb9\x9c\x6c\ +-\xf8\xec\x23\x2d\xb7\x18\x42\xc9\xe8\xa1\x2c\xfc\xdd\x0f\xcd\xc1\ +-\x6f\x12\x12\xa2\x82\x90\x8d\xb3\xc9\xa6\xdc\xa7\x35\x50\x48\x93\ +-\x19\x2f\x95\xab\x3f\x6e\xb6\x2b\x7e\xd7\xf4\x53\x04\x1c\xa9\x58\ +-\x4e\x47\x7b\xf8\x6e\xfc\x29\x8a\xc2\x83\x5f\x9a\xcb\x3d\xf3\xe7\ +-\xa0\x28\x41\x2d\x54\x6c\x62\x72\x9a\xa6\x4e\xfd\x9f\xb5\x4e\x17\ +-\x31\x9d\x03\xd5\x9f\x02\xbf\xf0\xf7\x1e\x4d\x02\x90\x9d\x28\xe6\ +-\x67\x24\x48\x6c\x6e\x68\x73\xc0\x09\x9b\xa0\xe3\x12\xeb\x18\xab\ +-\x05\xc6\x64\xd8\xf8\xeb\xca\x55\x5a\xba\x08\x29\xf1\xf1\xb1\xfc\ +-\xef\x23\x5f\x65\xe2\xb8\x61\x46\x9b\x62\xd2\x87\x70\x7a\x60\x67\ +-\x7d\x70\x5e\x36\x8d\x76\xe5\xfb\x04\x43\x00\xca\xab\xe5\x38\x84\ +-\x7a\x5e\xf0\x81\xc4\xe6\x82\x23\xcd\x82\xa3\x2d\x02\xa7\xc7\x97\ +-\xd3\x3c\x33\x41\x32\x26\x47\xf2\xce\x87\xeb\xb0\xdb\x75\xdc\xe9\ +-\xd0\x91\xa4\x84\x78\xfe\xef\xa7\x5f\x67\xd4\xd0\x01\x46\x9b\x62\ +-\xd2\x87\xf0\xaa\xb0\xb1\x5a\xc1\x1d\xa4\x8a\x6b\x6d\x0e\xd2\x9e\ +-\x2f\x93\x5f\xb9\x7f\x82\x78\xd9\x9f\xeb\xfd\x9f\x01\x08\xf5\xbf\ +-\xe1\xc2\x14\xdf\xf1\xd1\x30\x32\x5b\x72\x59\x96\xc4\xee\xf1\x95\ +-\x38\x8a\xb6\x80\xc7\xeb\x65\xc9\xb2\xf0\x0c\xf3\x4d\x4f\x4d\xe2\ +-\x89\x9f\xfd\x07\x83\xfb\xe7\x19\x6d\x8a\x49\x1f\xc2\xa3\xc2\xc6\ +-\xaa\x73\xe3\xfb\x83\x41\x9b\x93\x5f\x01\x7e\x09\x80\x5f\x9b\x80\ +-\x1b\x1b\x64\x0e\x82\xdb\xbb\xba\x46\x08\x88\x8f\xf2\x0d\x7e\x80\ +-\xe5\x6b\x2b\x68\x38\x11\xf4\xd2\x66\x9a\x49\x4f\x4d\xe2\xef\xbf\ +-\xfa\xae\x39\xf8\x4d\x42\x4a\xab\x03\x56\x1d\x52\x68\xe8\x08\xfe\ +-\x3e\x53\x53\x27\x03\x9f\xdf\x22\x47\xf9\x73\xad\x5f\x33\x80\x28\ +-\x8f\xfa\x55\x29\x89\xd2\x62\xc4\x1b\x1f\xae\xd1\x72\x79\x48\x88\ +-\x89\x8e\xe2\x37\x8f\x3e\x40\x61\x6e\xa6\xd1\xa6\x98\xf4\x11\x1c\ +-\x1e\xd8\x77\x5c\x70\xa4\x59\x10\x68\xa6\x6c\xad\xa8\x12\x9c\x4e\ +-\xf9\x7f\x40\xb7\xf9\x03\xbb\x9d\x01\x48\x29\x85\x94\x3c\xa0\xc5\ +-\x80\xa3\xd5\xf5\xec\x3e\x10\x5e\x25\xbb\x85\x10\xfc\xe8\x9b\x5f\ +-\x36\xd7\xfc\x26\x41\x47\x05\xea\xda\x05\x65\x35\x82\x4f\xf7\x2b\ +-\x1c\x6a\x0a\xdd\xe0\x3f\x45\x93\x4d\xcc\x7e\x6c\xa5\xec\xf6\x05\ +-\xdf\xed\x05\x15\x35\x9e\x59\x08\x45\x53\x71\xcf\x0f\x56\x85\x5f\ +-\xb4\xdf\x03\x77\xcc\x65\xce\x55\x25\x46\x9b\x61\xd2\xcb\xb1\xbb\ +-\x61\xfd\x51\x45\x57\x2f\xbf\x00\xed\x88\x2a\x48\xe7\x11\xe0\xf1\ +-\xae\xae\xeb\x7e\x0f\x40\x28\x5f\xd7\xd2\xb1\xaa\xaa\x7c\xfc\x59\ +-\x78\xf9\xfc\x97\x8c\x1e\xca\xfd\xb7\x5d\x63\xb4\x19\x26\x7e\x90\ +-\x94\x10\x4f\x6c\x4c\xb4\xd1\x66\x04\x84\x04\x2a\x6a\x85\xe1\x83\ +-\xff\x14\x36\x87\xec\x36\x36\xa0\xcb\x19\xc0\x86\x6a\x99\x01\xea\ +-\x2d\x5a\x3a\x2d\xdb\x7e\x80\xe3\x4d\xad\x5a\x6e\x09\x2a\x71\x71\ +-\x31\xfc\xf8\x5b\x5f\xbe\x20\x41\x87\x49\x78\xa1\x28\x82\xeb\x66\ +-\x5c\xce\x37\xef\xbe\x81\xd4\x64\xdd\x0b\xe0\x9c\xc6\xe6\x70\xd2\ +-\x70\xbc\x99\xa6\xd6\x76\x4e\x34\xb5\xd1\x61\x77\x60\xb7\x3b\x70\ +-\x38\xdd\xb8\xdc\x1e\x84\x80\xa4\x84\x38\x14\x45\x21\x25\x29\x81\ +-\x94\xa4\x04\xd2\x52\x12\x29\xc8\xcd\x24\x39\xb1\x6b\x1f\xb8\xa3\ +-\xcd\x22\x24\x9b\x7c\xfe\xd2\x62\x17\x45\x2f\x6e\x90\x03\xef\x9d\ +-\x24\x0e\x5f\xea\x9a\x2e\x05\xc0\x2a\xd4\x3b\x81\x18\x2d\x9d\xae\ +-\xdd\x1c\x5e\xe9\xbd\xbf\x7d\xcf\x4d\xe4\x66\xa5\x1b\x6d\x86\x49\ +-\x17\x0c\x1f\x5c\xc8\x23\x5f\xbb\x95\x91\x43\x75\x49\x74\x0b\x80\ +-\xcb\xe3\xe1\xd0\xd1\x5a\x0e\x57\xd5\x73\xb8\xba\x8e\x23\x95\x75\ +-\x1c\xa9\xa9\xe7\x58\x43\x53\xc0\xf5\x26\x93\x93\x12\xe8\x9f\x97\ +-\xc5\x65\x43\x0a\x19\x3d\x7c\x20\xa3\x87\x0f\x20\x2b\x23\x15\x80\ +-\xfa\x0e\xc1\x8e\xba\xf0\x19\xfc\x70\x72\x33\x50\xa8\xbf\x02\xee\ +-\xbe\xd4\x35\x5d\x0a\x80\x40\xde\x7e\x91\xa3\xff\x2e\xf9\xbc\x7c\ +-\xb7\xa6\xeb\x83\xc9\x84\x31\x43\xb9\x79\xce\x15\x46\x9b\x61\x72\ +-\x09\x92\x93\x12\xf8\xc6\x9d\xd7\x73\xe3\xd5\x57\xf4\xd8\x0d\xdb\ +-\xe3\xf5\xb2\x6b\xff\x51\x2a\x76\x1e\xa0\x7c\xc7\x01\x76\xec\x3d\ +-\x82\xd3\xa5\x6f\xc4\x4d\x5b\x7b\x27\xdb\xf7\x1e\x66\xfb\xde\xc3\ +-\x2c\x7e\xff\x33\x00\x06\x15\xe5\x32\x66\xcc\x18\x92\x0b\xc6\x90\ +-\x9d\x57\xa4\x6b\x7f\x7a\xd0\x6a\x57\x6e\xe8\xea\xe7\x97\x14\x80\ +-\xcd\x47\x64\x2e\xa8\x57\x6a\xe9\xec\x68\x75\x3d\xb5\xf5\x8d\x5a\ +-\x6e\x09\x1a\x8a\x22\xf8\xfe\x57\xe7\x9b\x53\xff\x30\x44\x51\x04\ +-\x37\xce\xbe\x82\x6f\xdc\x75\x3d\xc9\x49\x81\x87\x5b\x77\xd8\xec\ +-\x7c\xb6\x61\x3b\xab\x3e\xdf\x4a\xc5\xae\x03\xd8\x1d\xa1\x4f\x32\ +-\x7b\xa8\xf2\x18\x87\x2a\x8f\x01\x1f\x93\x9e\x99\xcd\xf8\x89\x57\ +-\x32\x6a\xdc\xe5\xc4\xc4\x6a\x4a\x96\x15\x34\xda\x9d\xa4\x3c\x5f\ +-\x26\x27\xdc\x3f\x41\x94\x5d\xec\xe7\x97\x14\x00\x4b\xb4\x7a\x87\ +-\x94\x68\x8a\x2c\x5a\x5f\xbe\x4b\xab\x7d\x41\x63\xf6\x94\x62\x06\ +-\x15\x69\xce\x57\x6a\x12\x64\x46\x0e\xed\xcf\x23\x5f\xbb\x95\xe1\ +-\x83\x0b\x03\xba\xdf\x66\x77\xb2\x66\xe3\x76\x96\xaf\xaf\x60\xd3\ +-\xd6\xbd\xb8\x3d\x01\xa5\xc2\x0b\x0a\x4d\xc7\xeb\x59\xf1\xc1\x52\ +-\xd6\x7c\xf2\x1e\xe3\x4a\xa7\x30\x69\xda\x1c\xe2\xe2\x83\xb7\x9f\ +-\xe1\x0f\x12\x70\xb9\xe5\x8f\x81\xdb\x2e\xf6\xf3\x4b\x0a\x80\x94\ +-\xf2\x0e\xad\xd3\xff\x0d\x5b\xf6\x68\xba\x3e\x58\x58\x2c\x0a\x5f\ +-\xbd\x23\xa0\x1a\xa5\x26\x41\x22\x35\x39\x91\x6f\xde\x7d\x03\xd7\ +-\xcd\xb8\x3c\xa0\xe9\xfe\xd1\xea\x7a\x96\x2c\x5b\xcb\x87\xab\x37\ +-\x85\x6d\x7c\xc9\x29\xdc\x6e\x17\x9b\x3f\x5f\xc5\xb6\xb2\xcf\x29\ +-\x99\x3c\x83\xcb\xaf\x9a\x4d\x74\xb4\xa6\xad\x34\x5d\x69\x77\x89\ +-\xab\x2f\xf5\xb3\x8b\x0a\xc0\xd6\x6a\x59\xe0\x45\x9d\xac\xa5\x13\ +-\x55\x55\xd9\xb5\xef\xa8\x56\xdb\x82\xc2\xdc\x69\xa5\x14\xe5\xf5\ +-\x28\x5d\xba\x89\x4e\x28\x8a\xc2\xfc\xb9\x53\xf8\xda\x97\xaf\x23\ +-\x29\xc1\xef\x48\xf2\xd3\x6c\xa8\xd8\xc3\x2b\xef\xac\xa0\x7c\xc7\ +-\x81\x80\x37\xef\x8c\xc2\xe5\x72\xf2\xc5\x67\x1f\xb1\x7b\xdb\x26\ +-\xe6\xdc\xf8\x25\x06\x0c\x19\x61\x88\x1d\x6d\x0e\x52\x5e\xdc\x20\ +-\x4b\xef\x9d\x24\x2e\x38\x9f\xbf\xa8\x00\xa8\x42\xbd\x09\x8d\xc9\ +-\x42\x0e\x55\x1d\xc3\xe6\x30\x5e\x99\x15\x45\x70\xdf\x6d\x73\x8c\ +-\x36\xc3\x04\x18\x3b\x62\x10\x0f\x7f\x6d\x01\x43\x07\xe4\x6b\xbe\ +-\x77\xdb\x9e\x43\x3c\xfd\xf2\x07\x6c\xdd\x7d\x30\x08\x96\x85\x96\ +-\xd6\x96\x26\xde\x58\xf4\x24\xa3\x8a\x27\x31\xfb\xfa\x5b\x43\x3e\ +-\x1b\x90\x80\x03\xf5\x87\xc0\x5d\xe7\xff\xec\xa2\x02\x20\x11\xd7\ +-\xfa\x6e\xf3\x9f\x1d\x7b\xc3\xe3\xed\x3f\x69\xdc\x08\xf2\xb3\xfb\ +-\x19\x6d\x46\x9f\x26\x3d\x2d\x99\x6f\xdd\x7d\x23\x73\xa7\x4d\xd0\ +-\xbc\x09\x5b\x5b\xdf\xc8\x5f\x9f\x7f\x8b\x35\x9b\x76\x04\xc9\x3a\ +-\xe3\xd8\x59\xb1\x81\xfa\x9a\x4a\x6e\xbe\xf3\x6b\xa4\xa5\x87\xf6\ +-\x19\xb5\xb9\x94\x99\x17\xfb\xfc\x02\x01\xd8\xb9\x53\x46\x3b\x51\ +-\x2f\x7a\x71\x57\xec\xdc\x77\x24\x00\xb3\xf4\x67\xfe\x75\x53\x8d\ +-\x36\xa1\xcf\x62\xb1\x28\xdc\x7a\xdd\x55\x3c\x78\xc7\x5c\x12\xe2\ +-\xb5\xed\x82\x3b\x5d\x6e\x5e\x7e\x6b\x39\x2f\xbf\xb5\x42\xf7\xe3\ +-\xbb\x70\xe2\x44\xc3\x31\x5e\x7a\xfa\x0f\xdc\x78\xfb\x7d\x21\x5d\ +-\x12\xb4\xb9\xc8\x7e\xe9\x0b\x99\x7c\xf7\x64\xd1\x76\xf6\xe7\x17\ +-\x08\x80\x33\xd5\x33\x0d\x14\xcd\x5b\x97\x3b\xf7\x1b\x1f\xfc\x93\ +-\x96\x92\xc4\xa4\x71\xc6\xac\xb3\xfa\x3a\xc5\xa3\x86\xf0\xf0\x83\ +-\x0b\x02\x3a\x79\x59\xb3\x69\x07\x7f\x7d\xfe\xad\xb0\x39\x42\x0e\ +-\x36\x4e\x87\x8d\xa5\xaf\xfc\x93\x1b\x6e\xbb\x8f\x61\x23\xc7\x85\ +-\xa4\x4f\x8f\x17\xe1\xb6\xa8\xdf\x00\x7e\x7f\xf6\xe7\x17\x2e\x01\ +-\x84\x72\x9d\xc6\xd9\x3f\x6e\x8f\x97\x9a\x3a\xe3\xb3\xfe\xce\x9a\ +-\x32\x0e\x8b\xc5\xac\xd8\x13\x4a\x32\x52\x93\xf9\xe6\x3d\x81\x4d\ +-\xf7\xab\xeb\x4e\xf0\x97\x67\xdf\x0c\xab\xe3\xe3\x50\xa1\x7a\xbd\ +-\xbc\xbb\xf8\x79\xae\x5f\xf0\x15\x2e\x1b\x5b\x1a\x92\x3e\x6d\x1e\ +-\xf1\x25\xba\x15\x00\xc9\xb5\x5a\x1b\xae\xad\x3b\x81\xd7\x1b\xa4\ +-\x1c\x47\x1a\x98\x31\x39\x34\x6a\x6a\xe2\xab\x80\x7c\xc7\x0d\xd3\ +-\xb9\xff\xb6\x6b\x88\x8f\xd3\xb6\xa9\x65\x77\xb8\x78\x71\xe9\x27\ +-\xbc\xf6\xce\x2a\x5c\x1e\x4f\x90\x2c\x0c\x7f\xa4\x54\xf9\x60\xe9\ +-\xcb\x58\xac\x51\x21\x99\x09\x74\xb8\xc4\x05\x49\x42\xce\x11\x80\ +-\xed\xf5\x32\xdb\xed\x51\x47\x6a\x6d\xf8\x68\xad\xf1\x6f\xff\x84\ +-\xf8\x38\xc6\x8c\x18\x68\xb4\x19\x7d\x82\xe2\x51\x83\xf9\xe1\xd7\ +-\x6e\x63\x60\x61\x8e\xe6\x7b\xd7\x6d\xde\xc9\x13\x0b\x97\x52\x77\ +-\xbc\x29\x08\x96\x45\x1e\x3e\x11\x58\x44\x72\x4a\x1a\x39\xf9\xc1\ +-\x75\x25\xb6\x39\x89\x7d\x63\x9b\x1c\x71\xdb\x58\x71\xda\x61\xe7\ +-\x1c\x01\x70\x7b\xbd\x53\xb5\x3a\xff\x00\x54\xd5\x1a\x5f\xea\x7b\ +-\xd2\xb8\x61\x58\x2d\x66\x95\xde\x60\x92\x99\x9e\xc2\x37\xbe\x72\ +-\x03\xd7\x4e\xd7\x3e\x65\xad\xac\x6d\xe0\xcf\xcf\xbd\xc9\x86\x8a\ +-\xf0\x70\x16\x0b\x27\x3c\x6e\x37\x6f\xfd\xfb\x19\xee\x7e\xe8\x11\ +-\x12\x93\x53\x82\xd6\x8f\x04\xda\x9c\xea\xfd\xc0\x8f\x4e\x7d\x76\ +-\x8e\x00\x08\xc4\x95\x81\xb8\x5a\x1c\xad\x69\xe8\x99\x65\x3a\x50\ +-\x32\xc6\x4c\xed\x1d\x2c\xa2\xad\x56\xbe\x74\xd3\x0c\xee\x5d\x30\ +-\x87\xb8\x58\x6d\xb1\xfa\x36\xbb\x93\xe7\x5e\xff\x88\xd7\xdf\xff\ +-\x0c\x8f\x37\x7c\xdc\x76\xc3\x8d\x8e\xf6\x56\xde\x5d\xfc\x1c\x5f\ +-\x7e\xf0\x7b\x08\x11\xbc\x7d\x2c\xbb\x5b\xcc\xe1\x52\x02\x20\x91\ +-\x57\x06\x32\x03\xa8\x6b\x30\x7e\x3a\x37\x76\xc4\x00\xa3\x4d\xe8\ +-\x95\x94\x8c\x1e\xca\x0f\x1f\x5c\xc0\x80\x00\xa7\xfb\x7f\x7c\x66\ +-\x09\xf5\x27\x9a\x83\x60\x59\xef\xa3\xa6\xea\x30\x1b\xd7\x2e\x67\ +-\xd2\x55\xc1\x73\x64\xb3\xb9\x18\x7e\xf6\xbf\x4f\x0b\xc0\xfa\x2a\ +-\x19\x87\x54\xc7\x07\xd2\x68\x63\x6b\x47\x4f\xed\xea\x11\x09\xf1\ +-\x71\x0c\x28\x30\x03\x7f\xf4\x24\x37\x2b\x9d\xef\xde\x3f\x9f\x69\ +-\x97\x8f\xd6\x7c\xef\xc1\xa3\xb5\x3c\xb1\x70\x29\x5b\x76\x45\xbe\ +-\x17\x5f\xa8\x59\xbf\x72\x19\x83\x86\x8e\x22\x33\x27\x38\x59\xab\ +-\x3b\x5c\x22\xe1\x1f\xdb\x64\xda\xb7\xc6\x8a\x66\x38\x4b\x00\x62\ +-\x2d\x4c\x44\xa2\x69\x7e\xd7\xe9\x82\x6d\x75\x82\x86\x66\x63\x4b\ +-\x7f\x0d\x1d\x90\x67\x96\xf5\xd2\x89\xe8\xa8\x28\xbe\x72\xcb\x2c\ +-\xee\x9e\x3f\x9b\x98\x68\x4d\x89\xa0\xe9\xb0\xd9\x59\xf8\xea\x32\ +-\x96\x7e\xb4\x36\x2c\x4e\x85\x22\x11\xaf\xd7\xc3\x87\x6f\xbe\xc4\ +-\xdd\xdf\xf8\x4f\x14\x45\xff\xa5\x80\x04\x12\x5d\x7c\x09\x78\x0a\ +-\xce\x12\x00\x21\xd5\xcb\xb5\xac\xff\xdb\x9d\xb0\xe6\xb0\x82\xc3\ +-\xe5\xc5\x61\xb3\xe9\x6c\xa6\x36\xcc\xb0\x5f\x7d\x98\x70\x32\x77\ +-\x62\x5e\x76\x86\xa6\xfb\xa4\x94\x7c\xb8\x6a\x13\x4f\xbe\xf4\x1e\ +-\xcd\xad\xe1\x5b\x07\x32\x52\x68\xa8\xab\x61\x7b\xd9\xe7\x8c\x9b\ +-\xa8\x29\x1d\x87\xdf\xb8\x24\x73\x39\x5f\x00\x90\x8c\xf3\x77\xf9\ +-\x2f\x25\x94\x55\x2b\xb8\xbc\x60\xb3\x75\x18\x1e\xa5\x65\x0a\x80\ +-\x3e\xcc\x0d\x60\x77\x7f\xdf\xa1\x6a\xfe\xf8\xcc\x12\x76\x84\x89\ +-\x2b\x78\x6f\x61\xdd\xaa\x0f\x19\x39\xae\x94\xa8\x20\x04\x0e\xd9\ +-\x5d\x8c\x3d\xf5\xff\xa7\x05\x40\x8a\x33\x1f\x76\x47\x75\xab\xa0\ +-\xc5\xe1\xfb\x7f\x5b\x87\xf1\x8a\x6f\x06\xff\x84\x9e\xb6\x0e\x1b\ +-\xff\x7c\xe5\x7d\xde\xf9\xf4\x0b\x54\xd5\x9c\xee\xeb\x8d\xad\xa3\ +-\x9d\x0d\x6b\x96\x33\x75\xf6\xf5\xba\xb7\xdd\xe9\x92\xa7\x37\x18\ +-\x14\x80\xcd\x9b\x65\x14\xe0\x97\x13\xbd\x94\xb0\xef\xc4\x99\xa9\ +-\x82\xcb\x6d\x7c\x08\x70\x76\x66\xaa\xd1\x26\xf4\x19\x54\x55\xf2\ +-\xce\x27\x9f\xf3\xe5\xef\xfe\x9a\xb7\x3e\x5e\x6f\x0e\xfe\x20\x52\ +-\xf6\xf9\x4a\x6c\x9d\xfa\xbf\x60\x1d\x6e\x11\xfb\xf4\x66\x19\x0f\ +-\xa7\x66\x00\xd9\x8c\x00\xff\x36\x00\xab\x5a\xcf\xcd\x7b\xee\x75\ +-\x1b\xeb\xca\x29\x84\x20\xbb\x5f\x9a\xa1\x36\xf4\x15\x76\xed\x3f\ +-\xca\x1f\x9f\x59\xca\x9e\x83\xc6\x07\x7e\xf5\x05\xdc\x6e\x17\x5b\ +-\x36\xad\x65\xca\x8c\x6e\x2b\x7c\x69\x42\x05\xa2\xe1\x1a\xe0\x2d\ +-\x05\xc0\x62\xf1\xfa\x35\xfd\x6f\x77\x72\x41\xea\x63\x8f\xc7\xd8\ +-\xd0\xcd\xc4\xf8\x38\xcd\xbb\xd5\x26\xda\x68\xeb\xb0\xf1\xe7\x67\ +-\xdf\xe4\x3f\xfe\xe7\xcf\xe6\xe0\x0f\x31\x15\x1b\xd6\xe2\x71\xeb\ +-\x3f\xc6\x54\xd5\x17\xf2\x6f\x05\x90\xaa\x18\xd5\xd5\x06\xa0\xc3\ +-\x03\xc7\xda\x04\x7b\x8e\x0b\x5c\xe7\x39\x73\x79\xbc\xc6\xce\x00\ +-\xba\x2b\xd6\x60\x72\x06\x21\x04\x03\x0a\xb2\xfd\xbe\x5e\x55\x55\ +-\xde\xfc\x68\x3d\xcf\xbc\xfa\x21\xed\x9d\xc6\x9e\xf4\xf4\x55\xec\ +-\xb6\x0e\x76\x6f\x2f\x63\x4c\x89\xa6\x0c\x7d\xdd\xe2\x51\x45\x09\ +-\x9c\x5a\x02\x08\x06\x81\x6f\x7d\xdf\xe6\x80\x86\x4e\x41\x9b\x13\ +-\x3a\x5d\x82\x0e\x27\x17\x0c\xfa\xb3\x51\x0d\x8e\xe6\x4a\x4e\x32\ +-\x05\xc0\x1f\x2e\x1b\x52\xc4\xc3\x0f\x2e\xf0\xbb\xf8\xc6\xb6\xdd\ +-\x87\xf8\xe3\x33\x4b\x39\x70\xb4\x26\xc8\x96\x99\x74\x47\xd9\xe7\ +-\xab\x74\x17\x00\x97\x57\x14\xc2\x49\x01\x58\x77\x44\x5c\xa3\x4a\ +-\x41\x9b\x03\xdc\x1a\xf7\x74\x82\x31\x3d\xd1\x82\xd6\x50\xd4\xbe\ +-\x46\x6a\x72\x22\xdf\xb8\x6b\x1e\xf3\x66\x4d\xf2\xcb\x59\xaa\xb1\ +-\xa5\x8d\x7f\x2c\x7a\x97\x8f\x3f\x2b\x33\xfc\x78\xd7\xc4\xc7\x89\ +-\x86\x63\x34\x1c\xab\x26\x2b\xb7\x40\xb7\x36\x9d\x1e\x99\x01\x27\ +-\x05\xa0\xd9\x2e\x52\x3d\x11\xba\x99\x1b\x6d\xed\xb6\xc0\x71\x9f\ +-\xc4\x62\x51\x98\x37\x6b\x12\xdf\xb8\x73\x1e\x29\xc9\xdd\x17\xdf\ +-\xf0\x7a\x55\x96\x2c\x5b\xcb\xc2\xd7\x96\xd1\x69\xb3\x87\xc0\x42\ +-\x13\x2d\xec\xde\x5e\xae\xab\x00\x38\x3c\xc2\x77\x0a\xf0\xd7\x0d\ +-\x72\xe0\xf1\xd6\x00\x22\x80\x4e\x62\xb1\x18\x3b\x00\x2d\x56\x33\ +-\x03\xd0\xf9\x14\x8f\x1a\x7c\x32\x3d\x97\x7f\xfe\xe4\xe5\x3b\x0f\ +-\xf0\xc4\x33\x4b\x38\x5c\x55\x17\x64\xcb\x42\x4b\x5a\x4a\x12\x69\ +-\x29\x89\xa4\x24\x25\x90\x9c\x14\x8f\xd7\xeb\xc5\xee\x70\xd1\x61\ +-\x73\x50\x73\xec\x04\x1d\x11\x24\x74\x7b\x77\x94\x33\x7d\xce\x8d\ +-\xa0\x53\xa5\x2b\x97\x17\xe5\x2f\x9f\xc9\x4c\x6b\x9c\x85\x1e\x15\ +-\xcf\x0b\x86\xbf\xb2\x16\xcc\x1c\x00\x67\xc8\xca\x48\xe5\xdb\xf7\ +-\xde\xcc\xec\x2b\xfd\x8b\xe9\x6a\x68\x6c\xe1\xef\x2f\xbe\xcd\xf2\ +-\x75\x5b\x82\x6c\x59\xf0\x89\xb6\x5a\x19\x37\x6a\x10\x25\xa3\x86\ +-\x32\x7c\x50\x21\x43\x06\xe4\x91\x9e\x9a\x74\xc9\xeb\xa5\x94\x54\ +-\x1d\x3b\xce\x9e\x03\x55\x6c\xd8\xba\x87\x35\x9b\x76\x60\xb3\x39\ +-\x42\x68\xb1\x36\xda\x5a\x9b\xa9\xae\x3c\x4c\x41\xff\x41\xba\xb5\ +-\x99\x94\x24\x63\xa2\xc1\x00\x00\x20\x00\x49\x44\x41\x54\xc0\x64\ +-\xab\xe2\x51\x2f\xd3\x58\x02\xe0\x1c\x84\xc1\x03\xd0\x74\x44\xf1\ +-\x3d\xfc\x5f\xbe\x79\x06\xf7\xcc\xf7\x2f\x5e\xdf\xed\xf1\xb2\xf8\ +-\xbd\x55\x3c\xff\xc6\xc7\x86\xd4\xd3\xd3\x8b\xb8\xd8\x68\xa6\x4f\ +-\x1a\xcb\xac\x2b\x8b\x29\x19\x35\x84\xd8\x18\xff\x63\xd9\x84\x10\ +-\x14\xe5\x65\x51\x94\x97\xc5\x35\xd3\x26\x60\x73\x38\x79\x7f\xc5\ +-\x06\x16\xbd\xb9\x9c\xa6\xe6\xb6\xee\x1b\x30\x80\xfd\xbb\xb6\xe8\ +-\x2a\x00\x0a\x8c\xb1\xaa\x82\x1e\xd5\x64\x56\x0c\x16\x00\x4f\xa4\ +-\x6e\x5e\xe8\xc4\x94\x09\x23\xf9\xde\x57\xe7\x53\x90\xe3\x9f\x3b\ +-\xf4\xc6\x2d\x7b\xf9\xd3\xb3\x4b\xa9\xac\x35\x3e\x89\x4b\xa0\x0c\ +-\x1f\x5c\xc8\xad\xd7\x4e\x65\xc6\xe4\x71\xba\x6d\x02\xc7\xc7\xc6\ +-\x70\xfb\xf5\xd3\x98\x37\x73\x12\xff\xfa\xf7\x07\xbc\xf1\xe1\x9a\ +-\xb0\xdb\x04\x3d\x72\x68\xaf\xae\xed\xb9\x25\x03\xad\x28\x4a\x7a\ +-\x4f\x1a\xb1\x18\xbc\x04\x70\x1b\xec\x87\x60\x14\x85\xb9\x99\x7c\ +-\xf7\xab\xb7\x30\xa5\xc4\xbf\x14\x8e\xb5\xf5\x8d\xfc\xed\x85\xb7\ +-\xf8\x6c\x63\xe4\x16\xdc\x98\x5c\x72\x19\x77\xdd\x3c\x8b\x92\x51\ +-\x43\x82\xd6\x47\x7c\x5c\x0c\xdf\x7f\x60\x3e\xa5\x63\x87\xf1\x8b\ +-\x3f\x2d\x0a\x8b\x6a\x57\xa7\x68\x6c\xa8\xa3\xa3\xbd\x95\xc4\x24\ +-\x7d\xd2\x86\xa9\x1e\x99\x67\x2d\xce\x53\x77\x0f\x4a\x63\xde\xd6\ +-\x63\x0a\xcd\x01\xec\x89\x18\x3d\x03\xb0\xdb\x23\x77\x0a\x1b\x08\ +-\x71\xb1\xd1\xdc\x77\xeb\x35\xdc\x71\xe3\x74\xbf\x4e\x40\x7c\x05\ +-\x37\x56\xf0\xf2\x5b\xcb\x23\xb6\xe0\xc6\xd8\x11\x83\xf8\xe6\x3d\ +-\x37\x30\x66\x78\xe8\x92\xbe\x5e\x59\x3a\x8a\xbf\xfe\xe2\xdb\x7c\ +-\xff\x97\x4f\xd1\x11\x46\x4e\x50\x95\x07\xf7\x31\x72\xfc\x44\x5d\ +-\xda\xf2\x48\x91\x69\x55\x20\x23\x35\x0e\xae\x1a\xa8\x52\x56\x2d\ +-\xa8\x69\xd3\xb6\xcb\x68\xb5\x6a\xcb\x11\xa7\x37\x6d\x9d\x91\xb3\ +-\x93\xdb\x13\x84\x10\xcc\x9e\x32\x9e\x6f\xdd\x7b\x13\x59\x19\xfe\ +-\x05\x3f\x7d\xb6\x71\x07\x7f\x7b\x21\x72\x0b\x6e\xe4\x66\xa5\xf3\ +-\x9d\x7b\x6f\x66\xfa\x64\xbf\x03\x55\x75\x65\xf8\xe0\x42\x1e\x7a\ +-\xe8\xeb\xfc\xe5\x6f\xff\x30\xdc\xdf\xe5\x14\x47\x0e\xed\xd5\x4d\ +-\x00\xbc\x2a\x69\x56\x89\xc8\x00\x89\x22\x60\x42\x81\xc4\x79\x14\ +-\x4e\x74\xfa\x2f\x02\xf1\xf1\xdd\x9f\x31\x07\x93\xf6\x8e\xf0\x51\ +-\xe7\x60\x31\xb8\x7f\x1e\x3f\x78\x60\x3e\xc5\x7e\x4e\x7d\x23\x3d\ +-\x03\x6f\x4c\xb4\x2f\x2b\xd1\x57\x6e\xd1\x9e\x95\x48\x4f\xaa\x5b\ +-\x05\x4a\xea\x20\x66\x5f\x7f\x1b\x1f\xbd\xfd\x6f\xc3\xec\x38\x9b\ +-\xaa\xc3\xfb\x75\x6b\x4b\x55\x65\xa2\x15\xd4\x7e\xa7\x12\x81\x2a\ +-\x02\x26\x15\x49\x3e\x3b\x74\x6e\xc4\x5f\x57\xc4\xc6\x19\xeb\x8a\ +-\xdb\xda\xde\x89\xd7\xab\xf6\xca\x8a\x40\x49\x09\xf1\x7c\xed\xcb\ +-\xd7\x71\xcb\x35\x53\xfc\xfa\xfd\x6c\x0e\x27\x2f\x2e\xf9\x84\xd7\ +-\xde\x5d\x85\xdb\x13\x99\x19\x78\xaf\x9a\x38\x9a\xef\xde\x7f\x8b\ +-\xe6\xac\x44\xc1\x60\xdf\x71\xdf\xb8\x18\x53\x32\x99\xc3\xfb\x77\ +-\xb1\x6f\xd7\x56\x83\x2d\x82\xf6\xb6\x16\x6c\x1d\xed\xc4\x27\x5e\ +-\xfa\x88\xd3\x5f\x3c\x52\xc4\x59\x41\x9c\x33\x9f\x8c\x52\x60\x72\ +-\x7f\x95\xcf\x0e\x29\x38\xfd\xd8\x5f\x8b\x8d\x8b\xf7\x39\x27\x18\ +-\xb4\x63\xaa\xaa\x2a\xc7\x9b\x5a\xc8\xc9\xec\xd1\x5e\x66\x58\xa1\ +-\x28\x82\x1b\x66\x4d\xe2\xa1\xbb\xe6\x91\x9a\xec\x5f\x99\xc6\x4f\ +-\xd7\x55\xf0\x8f\x17\xdf\xa1\xa1\xb1\x25\xc8\xd6\x05\x87\xa2\xbc\ +-\x2c\xbe\xff\xd5\xf9\x4c\x2a\x0e\x9f\xda\x8e\x67\x3f\xd1\xb3\xae\ +-\xbb\x95\xc3\x07\xf6\xe0\x76\x19\xbf\x29\x58\x7f\xac\x9a\x81\x43\ +-\x2f\xeb\x71\x3b\x5e\x29\x63\xac\x42\x12\x2b\xcf\x9b\xf1\x27\x44\ +-\xc1\xd4\x01\x2a\x1b\x2a\x15\x3a\xba\xd9\x63\x53\x2c\x16\xa2\xa2\ +-\xa2\x0d\xfd\x62\xea\x8e\x37\xf7\x1a\x01\x18\x35\x74\x00\x0f\x7f\ +-\x6d\x3e\x23\x06\xfb\x57\x25\xe6\x50\xe5\x31\x9e\x58\xb8\x84\x8a\ +-\x9d\x91\x99\x81\x37\x3e\x36\x86\x7b\x6f\x9d\xc3\x97\x6e\x9c\x41\ +-\x94\x35\xbc\x9c\xba\x06\xa4\x49\xb6\x9f\x0c\x7f\x4f\x4c\x4e\xa1\ +-\xf4\x8a\x19\x7c\xbe\xfa\x23\x83\xad\x82\x06\xbd\x04\x40\x15\x16\ +-\xab\x14\x17\x4f\x04\x92\x14\x03\xb3\x86\xa8\x54\xb6\x08\x1a\x3a\ +-\xa0\xd5\x21\xb0\xb9\x2f\xfe\xa2\x8f\x8f\x4f\xa0\xd5\x40\x01\xa8\ +-\xaa\x3d\xce\xf8\x91\x83\x0d\xeb\x5f\x0f\xd2\xd3\x92\xf9\xe6\xc9\ +-\xaa\x3b\xfe\x14\xd9\xec\xb4\xd9\x59\xf8\xda\x32\x96\x2c\x8b\xdc\ +-\x0c\xbc\x57\x5f\x59\xac\x69\x53\x33\xd4\xf4\x4f\x93\xec\xaa\x17\ +-\x78\x4f\x3e\xf3\xa5\x53\x66\x50\xf6\xc5\x6a\x5c\x4e\x63\x3d\x06\ +-\x1b\x8e\x55\xeb\xd2\x8e\xaa\xa2\x58\xe9\x22\x13\x90\x22\x7c\x2a\ +-\x38\x20\x0d\x40\xe2\xf0\x40\x4d\xab\xa0\xaa\x55\xd0\xea\x38\x23\ +-\x06\xb1\x71\xf1\xb4\xb6\x18\x57\x1c\xe4\x60\x65\xad\x61\x7d\xf7\ +-\x14\xab\xc5\xc2\x6d\xd7\x5f\xc5\x03\xb7\xcf\x25\x3e\x3e\xb6\xdb\ +-\xeb\x4f\x65\xe0\x7d\xea\xe5\xf7\x68\x6a\x31\x3e\x1f\x63\x20\x0c\ +-\x2a\xca\xe5\xe1\x07\x17\xf8\xbd\xa9\x69\x14\x56\x05\x62\xa3\x7c\ +-\xe9\xef\x01\x62\x62\xe3\x19\x39\xb6\x94\x2d\x9b\xd6\x1a\x6a\x57\ +-\x7d\x9d\x4e\x02\x00\xc2\x8a\x20\xc6\xdf\x72\xe0\xb1\x56\x18\x9c\ +-\x21\x19\x9c\x21\x71\xab\xd0\x66\x87\x76\xa7\xe0\x93\x7e\x69\xd4\ +-\xeb\xa4\x4a\x81\xb0\xff\x70\x64\x0a\x40\xe9\xd8\x61\xfc\xe0\xab\ +-\xf3\xfd\xae\xba\x13\xe9\x19\x78\x13\xe2\xe3\x78\xf0\x4b\xd7\x72\ +-\xeb\xb5\x53\x23\x62\xd3\x56\x05\x6c\xe7\x9d\xfe\x8d\x2b\xbd\xd2\ +-\x70\x01\x68\x69\x6e\xc4\xe3\x76\x63\x8d\xea\xf1\x09\x89\xb0\x6a\ +-\x2d\x06\x72\x8a\x28\x05\x32\x12\x20\x23\x41\x32\xbc\x28\x8d\xad\ +-\xdb\x7b\x6a\x4b\xe0\xec\x39\x58\x89\xcb\xe3\x89\x98\xd0\x60\xad\ +-\x45\x36\xdb\x3b\x6d\x3c\xfb\xda\x47\x2c\x59\xb6\x36\x22\x63\x1f\ +-\x84\x10\x5c\x33\x6d\x02\xdf\xbe\xe7\xa6\x2e\x03\x74\xc2\x0d\xbb\ +-\xeb\xc2\x25\x6f\x66\x4e\x1e\xe9\x99\xd9\x34\x1d\x37\xb0\x20\xae\ +-\x94\xb4\xb5\x36\x91\xde\xcf\xff\xec\x4e\x17\xc3\xab\x22\xba\x5c\ +-\x02\xf8\x4b\xae\xc1\x47\x36\x4e\x97\x9b\x3d\xfb\x2b\x19\x7b\x99\ +-\x7e\x81\x12\xc1\x20\x26\x3a\x8a\xbb\x6e\x9e\xc5\x57\x6e\x99\xe5\ +-\x57\xe0\x8a\xaa\xaa\xbc\xf3\xe9\x17\xfc\xf3\xdf\x1f\xd0\xd6\xde\ +-\x19\x02\x0b\xf5\x67\xf8\xe0\x42\x1e\x7e\x70\x01\xa3\x87\x0d\xf0\ +-\xeb\xfa\xda\xfa\x46\x52\x92\xe2\x49\x88\x8f\x0b\xae\x61\x7e\x10\ +-\x6d\x05\x8b\xe0\xf4\x1e\xc0\x29\x86\x5e\x36\x96\x0d\xc7\x3f\x31\ +-\xc6\xa8\x93\xb4\x34\x37\xf6\x58\x00\x24\xe7\x15\x07\x0d\x94\xbc\ +-\x2c\xe3\xcf\x6c\x37\x6e\xdd\x1b\xb0\x00\x34\xda\xa0\xaa\x45\x70\ +-\x59\x96\x24\x26\x48\x93\x88\x94\xa4\x78\x16\x3d\xf1\xa8\xdf\xe7\ +-\xdb\x3b\xf6\x1d\xe1\x8f\xcf\x2c\x61\xdf\x21\xe3\x96\x56\x3d\x21\ +-\x39\x29\x81\x6f\xdc\x79\x3d\x37\x5e\x7d\x85\x5f\x99\x88\x1c\x4e\ +-\x17\x2f\xbf\xb5\x82\x57\xde\x5e\xc1\xa2\x27\x1e\x0d\x0b\x01\x88\ +-\x52\x60\x58\xa6\x64\x77\xc3\xb9\xf6\x0f\x18\x72\x19\x1b\x3e\x33\ +-\x56\x00\x5a\x9b\xf5\xf1\xee\xb4\x02\x2e\xa0\x47\xdf\x76\x6e\x96\ +-\xf1\x69\xb9\x57\x6f\xd8\xc6\xd7\xbe\xac\x3d\x7d\x72\x65\xab\x60\ +-\x6b\x8d\x6f\xa7\x37\x3d\x1e\x8a\x52\xcf\xc8\xbd\xdd\x0d\x31\x56\ +-\xdf\x66\x68\x4f\x49\x88\x8f\xf3\xeb\xa1\x6e\x6b\xef\xe4\xb9\xd7\ +-\x3f\x66\xc9\xb2\x35\xa8\x6a\x78\x45\xa3\xf9\x83\xa2\x08\xe6\x5c\ +-\x35\x81\xef\xde\x77\xb3\xdf\x3e\x0c\xeb\x36\xef\xe4\xcf\xcf\xbd\ +-\x19\x96\x2e\xcb\xc3\x32\x25\x4e\x0f\x1c\x6a\x3a\xf3\x10\xe4\x15\ +-\xf4\xc7\x6a\x8d\x32\x34\x23\xb6\x1e\x9b\xee\x02\xb0\x22\x70\x21\ +-\x7b\x26\x00\x39\x61\x30\x03\x38\x5c\x55\xc7\xa1\xca\x63\x7e\x97\ +-\x09\xb3\xb9\x60\x7b\xbd\xe0\xd8\xc9\xd8\x87\xe4\x58\x28\x48\xf1\ +-\x0d\x38\x09\xec\xaa\x17\x1c\x38\x21\x88\xb2\xc0\xd0\x7e\xbe\x8d\ +-\xcf\x60\xd6\x1f\xf5\x7a\x55\x96\x7c\xb8\x86\x85\x8b\x3f\x8a\xd8\ +-\x94\x5c\x63\x86\x0f\xe4\xe1\x07\x17\x30\x6c\x90\x7f\xa9\xab\x8e\ +-\x54\xd5\xf1\xa7\xe7\xde\x64\xf3\xb6\x7d\x41\xb6\x2c\x70\x04\x30\ +-\x26\x57\x62\x55\xce\x14\xc4\xb1\x58\xac\xe4\xe4\x17\x52\x7d\xf4\ +-\x90\x61\x76\xb5\xe9\x30\x03\xb0\x28\x48\x2b\x92\x1e\x1f\xe0\xc7\ +-\xc7\xc6\x90\x93\x99\x4e\xdd\x71\xe3\x8e\x02\x01\xde\xfe\x64\x3d\ +-\x0f\x3f\x78\xeb\x45\x7f\xe6\x51\xa1\xd3\x09\x2d\x0e\x41\x7d\x07\ +-\xd4\xb5\x09\xce\xde\x4e\x2b\x4c\xf5\x0d\x70\x55\x42\x45\xad\xa0\ +-\xaa\xc5\xf7\xc7\x76\x79\x61\x67\xbd\xe0\x68\xb3\x60\x42\x81\x4a\ +-\x5a\x10\x66\xa6\xe5\x3b\x0f\xf0\xa7\x85\x4b\x39\x54\x79\x4c\xff\ +-\xc6\x43\x40\x7a\x5a\x32\xdf\xba\xfb\x46\xe6\x4e\x9b\xe0\x97\x0f\ +-\x83\xcd\xe6\xe0\xd9\xd7\x3f\xe2\x8d\x0f\xd6\xe0\xf1\x86\xbf\xcb\ +-\xb2\x00\x46\x66\x4b\x12\xa2\x61\x6b\xad\xef\xb9\xe9\x97\x95\x67\ +-\xac\x00\xb4\x36\xeb\xd1\x8c\x3c\xb5\x04\xe8\x31\xc3\x06\xe6\x19\ +-\x2e\x00\xcb\x56\x97\xf1\xf5\x3b\xaf\x27\xf1\xe4\x54\x5b\x95\x70\ +-\xe0\x84\xa0\xb2\x55\xd0\xe9\xa4\xcb\xd3\xce\x7d\x0d\x82\x13\x9d\ +-\xd0\xe6\x10\xd8\x2f\x32\xb3\xeb\x70\xf9\xaa\x21\x4f\x2a\x92\x64\ +-\x27\xea\x33\x35\x8f\xf4\x94\x5c\x56\x8b\x85\x5b\xaf\x9b\xca\x03\ +-\x77\xcc\xf5\x6b\x79\x23\xa5\x64\xd9\xea\xcd\x3c\xf9\xf2\x7b\x61\ +-\x9b\x75\xa7\x2b\xfa\xa7\x49\xe2\xa2\x60\x63\xb5\x20\x33\xdb\xbf\ +-\x7c\x8b\xc1\xc2\x61\xef\x79\x10\x9c\x02\xd2\x2a\x24\xae\xf3\x5d\ +-\x81\x03\x61\xd8\xa0\x42\xc3\x93\x4d\x74\xda\xec\x2c\x7e\x6f\x35\ +-\x0f\xdc\x71\x2d\x52\xc2\xfa\xa3\x0a\x27\xfc\xdc\x3c\x77\xab\x50\ +-\xdf\xde\xf5\x17\xa1\x4a\xf8\xa2\x52\x30\x24\x1d\x32\x13\x7d\xbb\ +-\xc3\x36\x97\x4f\x58\xfa\xc5\x4b\x52\x2f\x32\x06\xaa\x5a\x05\x95\ +-\xcd\xe0\xf0\x08\x14\x01\x59\x89\x92\xc1\xe9\x1e\xde\xf9\x78\x1d\ +-\xff\x7a\xf5\x03\xec\x76\xe3\x7d\xcb\x03\xa1\x78\xd4\x10\x1e\x7e\ +-\x70\xbe\xdf\x89\x47\xf7\x1d\xaa\xe6\x4f\xcf\xbe\xc9\xb6\x3d\xc6\ +-\xbd\x35\xf5\x20\x2b\x51\x72\xd5\x00\x49\xed\x91\x2c\x43\xed\xb0\ +-\xdb\x7a\x7e\x2a\xa4\x28\xa8\x56\x29\xd0\xc5\xaf\x71\xd8\x40\xfd\ +-\x52\x16\xf7\x84\x57\xdf\x5b\xcd\x4d\x73\xae\xa0\x43\xa6\xfa\x3d\ +-\xf8\xb5\x20\x25\xec\x6f\x14\xec\xbf\x60\x09\x26\xc8\x4a\x94\x8c\ +-\xc9\x91\x24\xc5\x80\xc7\x0b\xdb\xea\x04\x95\x2d\xe7\x8a\xca\x96\ +-\xed\x7b\x58\xfd\xd1\x52\x4e\x1c\x8f\xcc\x94\x5c\x59\x19\xa9\x7c\ +-\xe7\xbe\x9b\x99\x35\xc5\xbf\xc4\xa3\x2d\x6d\x1d\xfc\xf3\x95\xf7\ +-\x79\x6f\xc5\x86\x88\xdc\xd4\xbc\x18\x29\xb1\x70\xf5\x98\x54\x5e\ +-\x34\xd0\x06\xa7\xd3\x81\x94\x2a\x42\x04\xee\x50\x65\x15\xd2\x6b\ +-\x05\xd9\x4c\xe0\x59\xc1\x4f\x33\x6c\x50\x7e\x8f\xdb\xd0\x03\x9b\ +-\xcd\xc1\x9f\x9f\x7d\x93\x69\x37\x3d\xe0\xf7\x3d\x85\x29\x92\x31\ +-\xb9\x92\xf5\x47\x94\xd3\x65\xcf\x03\xa1\xa1\x43\xb0\xe2\xa0\x20\ +-\x21\xca\xe7\x41\x76\xf6\xf3\xde\xda\xdc\xc8\xca\x65\x6f\x72\x60\ +-\x8f\x81\x1e\x53\x3d\x20\xda\x6a\xe5\x4b\x37\xcd\xe0\xde\x05\xfe\ +-\x25\x1e\xf5\x7a\x55\xde\xfa\xb8\xf7\x96\x15\x2b\xca\x49\x45\x51\ +-\x14\xe3\x1c\xb3\xa4\xc4\x61\xb3\x13\x97\x10\x78\x3e\x0e\x8b\x82\ +-\xd3\x0a\xca\x89\xae\x57\xc7\xfe\xd1\x2f\x2d\x85\x8c\xd4\x64\x1a\ +-\x5b\x8c\x5f\xdb\xad\xfc\x7c\x2b\x31\xd9\x5f\x30\xba\xd8\xbf\x72\ +-\x4a\x49\xb1\x10\x6d\x81\xd4\x38\x49\x8b\xa3\x67\x62\x28\x25\xe7\ +-\x44\x50\x7a\xdc\x6e\x36\xae\xfb\x94\x8d\x6b\x97\x87\x4d\x56\x19\ +-\xad\x5c\x51\x7c\x19\xdf\x7b\x60\x3e\x85\xb9\x99\x7e\x5d\x5f\xb1\ +-\xf3\x00\x7f\x7a\xf6\x4d\x0e\x1e\x8d\x4c\x17\x6d\x7f\xb0\x5a\x2c\ +-\x24\x25\xc6\xd1\xda\x66\x9c\x83\x96\xc3\xd1\xd9\x23\x01\x50\x84\ +-\xb0\x59\x41\xea\x76\xf8\x5a\x32\x66\x08\x9f\xac\x29\xd7\xab\xb9\ +-\x1e\xf1\xe9\xfb\x6f\x90\xd6\x2f\x9b\xfc\xc2\xee\xf3\xc8\x1d\x6c\ +-\x14\x08\xe0\x58\x37\x7b\x00\x5a\xd9\xb7\x6b\x2b\xab\x3f\x7a\xcb\ +-\xd0\x40\xa9\x9e\x90\x97\x9d\xc1\xf7\xee\x9f\xcf\xd4\x89\xa3\xfc\ +-\xba\xbe\xa1\xb1\x85\x7f\xbc\xf8\x0e\xcb\xd7\x6f\x09\xbb\x8c\xba\ +-\xc1\x20\x25\x31\xc1\x50\x01\xb0\xdb\x6c\xa4\xf5\xe0\x04\x5e\x51\ +-\xe8\xb0\x0a\x38\xa1\xd7\x9f\x6a\xe2\xd8\xe1\x61\x23\x00\x1e\xb7\ +-\x9b\xa5\x2f\xfd\x93\xdb\xef\xfb\x26\x39\x79\x5d\xc7\xd6\x3b\x3d\ +-\xbe\xa3\x3e\xbd\xa8\xae\x3c\xc8\x67\x1f\xbf\x43\x6d\xd5\x11\xdd\ +-\xda\x0c\x25\xb1\x31\xd1\xdc\x3d\x7f\x36\x77\xdd\x3c\x93\x68\x3f\ +-\x02\x4e\x5c\x1e\x0f\x8b\xdf\x5d\xcd\x0b\x4b\x22\xbb\xce\x80\x56\ +-\x92\x12\x8c\xcd\x86\xd5\xd3\x1c\x1c\x56\x85\x26\xab\x0a\x8d\x7a\ +-\x3d\xfa\xa5\x63\x86\xe9\xd4\x92\x3e\x38\x1d\x36\x16\x3f\xf7\x37\ +-\xae\xbf\xf5\x5e\x86\x8c\x18\x1d\xf4\xfe\x8e\x1e\xdc\xcb\xc6\x75\ +-\xcb\x39\x7a\x50\xdf\xfc\xed\xa1\x64\xfa\xe4\xb1\x7c\xf7\xbe\x9b\ +-\xfd\x4e\xb0\xb2\xbe\x7c\x17\x7f\x7d\xee\x2d\xaa\x8e\x1d\x0f\xb2\ +-\x65\xe1\x47\x5c\x9c\xb1\x09\x71\x55\xb5\x67\x3e\x14\x56\x45\x1e\ +-\xb7\x0a\x64\xa3\x1e\x9b\x80\x00\x59\xfd\x52\x29\xca\xcb\x0a\xab\ +-\xa2\x13\x2e\x97\x93\xb7\x5e\x7d\x86\xe2\x89\x53\xb9\x6a\xf6\x3c\ +-\xa2\x63\xf5\xf5\xe4\x71\x39\xec\xec\xd9\xb9\x85\x2d\x1b\xd7\xd0\ +-\x50\x17\xb9\xa5\xb4\x8b\xf2\xb3\x79\xf8\x81\x05\x4c\x1c\xe7\x9f\ +-\x88\x57\xd7\x9d\xe0\x2f\xcf\xbd\xc9\xfa\xb2\x5d\x41\xb6\x2c\x7c\ +-\x89\x32\x38\x25\x7e\x4f\x13\xc1\x58\x15\x51\x6b\x15\x2a\xc7\xa4\ +-\x8e\xa1\xd9\xa5\x63\x87\x85\x95\x00\x00\x20\x25\x15\x1b\xd7\xb0\ +-\x77\xe7\x16\x2e\xbf\xea\x6a\xc6\x4d\xb8\x82\xa8\xe8\xc0\x2b\xca\ +-\xb8\x5d\x4e\x8e\x1c\xdc\xcb\xde\x1d\x15\x1c\xd8\xb3\xdd\x50\x9f\ +-\xf0\x9e\x12\x1f\x1b\xc3\xfd\xb7\x5f\xc3\xed\xf3\xa6\xfb\x95\x92\ +-\xcb\xee\x70\xb1\xe8\xcd\x4f\x78\xf5\xed\x55\xb8\x3c\x7d\xb3\x28\ +-\xcb\x29\xac\x06\xa7\x30\xeb\xf1\x0c\xc0\xaa\x1e\xb1\x4a\xab\xe5\ +-\x08\x3a\x1e\x65\xcc\xbc\x62\x1c\x4b\x97\x19\x9b\x30\xe1\x52\xd8\ +-\x3a\xdb\x59\xb5\xec\x4d\xd6\xad\xf8\x80\x21\x23\xc6\x30\x70\xc8\ +-\x08\x72\xf2\x8a\x48\xeb\x97\xd5\xa5\x0b\x6b\x7b\x5b\x0b\x0d\x75\ +-\x35\x1c\xaf\xab\xe6\xe8\xc1\xfd\xd4\x54\x1d\x42\x8d\x00\x17\xd6\ +-\xae\x10\x42\x9c\x4e\xc9\x95\x99\xee\x5f\xa5\x99\xe5\xeb\xb6\xf0\ +-\xf7\x17\xdf\x8e\xd8\xc4\xa3\x7a\x63\x74\x52\x13\x6f\x0f\xab\x62\ +-\x09\xaf\xb2\xcd\xea\xf0\x70\x38\x56\x41\xa2\xd3\x3a\x60\xdc\x65\ +-\x83\xc9\x4c\x4f\xe1\x78\x53\xab\x1e\xcd\x05\x05\xb7\xcb\xc9\xee\ +-\x6d\x9b\xd9\xbd\x6d\x33\x00\x51\xd1\x31\xa4\x65\x64\x12\x1d\x15\ +-\x43\x54\x4c\x0c\x16\x8b\x05\xbb\xad\x13\xbb\xad\x93\xce\x8e\x36\ +-\x9c\x8e\xc8\x0c\xce\xb9\x14\x5a\x53\x72\x1d\xaa\xac\xe5\x89\x85\ +-\x4b\x23\x36\xf1\x68\xb0\x30\x3a\x8e\x41\xf6\x70\x09\xd0\xea\xe5\ +-\x0b\xeb\x94\x42\x61\x2f\xaf\xf1\x1e\x07\x74\xf1\x6d\x54\x14\xc1\ +-\xec\x2b\x8b\x79\xf5\xdd\x55\x7a\x34\x17\x12\xdc\x2e\xa7\x6e\x89\ +-\x16\xc3\x99\xb8\xd8\x68\xee\xbc\x69\x26\xf7\x2c\x98\xe3\xd7\x74\ +-\xbf\xc3\x66\x67\xd1\xd2\xe5\x2c\x7e\x2f\x72\xeb\x0c\x04\x13\x97\ +-\xdb\xd8\x25\x90\x2a\x03\xff\x9b\x44\x5b\x50\xbf\x33\x49\x34\x5a\ +-\x01\x84\x90\x87\xa5\x14\xba\x39\x37\x5f\x3d\x35\xb2\x04\xa0\xb7\ +-\x23\x84\x60\xee\xb4\x09\x7c\xeb\xee\x1b\x49\x4f\x4b\xee\xf6\x7a\ +-\x55\x95\xbc\xbf\x62\x03\x4f\xbf\xf2\x3e\x2d\x6d\x1d\x21\xb0\x30\ +-\x32\xf1\xb8\x0d\x9e\x01\xf4\xc0\xb5\x3a\x36\x8a\x4e\x38\x99\x11\ +-\x48\x4a\x71\x04\x98\xa4\x8b\x55\xc0\x88\xc1\x45\x0c\x28\xcc\xe1\ +-\x48\x55\x9d\x5e\x4d\x9a\x04\xc8\xb0\x81\x05\xfc\xe0\xc1\xf9\x8c\ +-\x1d\xe1\x5f\xb6\xa4\x5d\xfb\x8f\xf2\xc4\xc2\xa5\xec\x3e\x50\x19\ +-\x64\xcb\x22\x9f\x4e\x83\x2b\x07\xf7\x24\x29\x68\x8c\x45\x36\xc1\ +-\x69\x01\xe0\xa0\x1f\x61\xdc\x9a\xb8\xe3\xfa\x69\xfc\xee\xe9\xc5\ +-\xfa\x36\x6a\xe2\x37\x49\x09\xf1\x7c\xfd\xae\xeb\xb9\x65\xce\x15\ +-\x28\x7e\x96\x70\x7f\xe5\xed\x15\x3c\xf9\xd2\x7b\x7d\xc2\x8b\x4f\ +-\x0f\x8c\xce\xd3\x68\xb1\x6a\x13\x00\x01\xa4\xc4\x41\x6e\x92\x24\ +-\x23\x4e\xbe\x07\x27\x05\x40\x08\xb9\x43\x2f\x5f\x80\x53\x5c\x3b\ +-\x73\x22\xcf\xbc\xf6\x61\xc4\xe6\xae\x8f\x58\x84\x60\xe4\xd8\x52\ +-\xe6\xdf\x72\x33\x63\xfb\x27\x22\x84\xff\x83\xf9\x48\x75\xbd\x39\ +-\xf8\x35\xd0\x62\xb0\x00\xf8\x3b\x03\x88\xb1\xfa\x52\xdd\x0d\x48\ +-\x97\x24\x9c\xbc\x45\x48\xb9\x1a\x4e\x0a\x80\xc5\x62\xd9\xae\x77\ +-\x75\x99\x68\xab\x95\x1b\x67\x5f\xc1\x0b\x4b\x3e\xd6\xb5\x5d\x93\ +-\x4b\x93\x93\x5f\xc4\xec\x79\xb7\x91\x9b\xdf\x1f\x27\xb0\xa9\x0a\ +-\x92\x62\x04\xc5\xf9\x2a\xe9\xc6\xe7\xd8\xec\x55\x38\x9c\x2e\xc3\ +-\x73\x39\x58\x2d\x5d\x67\xb0\x4d\x8c\xf6\xa5\xb3\x3b\x95\xed\xea\ +-\x6c\xbc\x8a\x65\x3b\x9c\x14\x80\xa6\x6c\xf6\xa4\xd4\xe2\x04\x02\ +-\xf7\x8e\xb9\x08\xb7\x5e\x7b\x25\xaf\xbe\xbb\x12\xa7\x2b\x72\x1d\ +-\x65\x22\x81\xb8\x84\x04\xae\x9a\x7d\x23\x63\x4a\x26\x5f\xe0\xcf\ +-\xd0\xee\xf4\x65\x32\x1a\x92\x21\x19\x99\x25\xd1\x7b\xa9\xd7\x57\ +-\xa9\x3f\xae\x4b\x4a\xae\x1e\x31\xae\xd0\x4a\x56\xa6\xa4\xae\x43\ +-\xd0\x76\xb2\x52\x97\x10\x90\x11\x0f\x03\xd3\x25\x79\x49\x97\xfc\ +-\x7b\x3b\x0e\xe5\xb2\x1f\x4e\x0a\xc0\x4c\x21\x3c\xe5\x35\xde\xdd\ +-\x80\x7f\x59\x1e\xfc\x24\x3d\x2d\x99\x3b\x6e\x98\xce\xa2\xa5\x9f\ +-\xea\xd9\xac\xc9\x49\x84\x50\x18\x37\x71\x0a\x53\x67\xcd\xeb\xb2\ +-\x4c\xbb\x94\xb0\xff\x84\xa0\xc9\x2e\x98\x58\xa0\x12\x1b\x19\xf5\ +-\x53\xc2\x9a\xba\x30\x10\x80\x82\xb4\x68\x06\x67\x49\x2e\xcb\xf2\ +-\x55\xea\xb2\xbb\x20\x3e\x0a\xfc\x38\xe1\xdd\x79\x87\x10\x5e\x80\ +-\x33\xbb\x43\x82\x6d\xc1\x30\xf2\x9e\x5b\x66\xfb\x9d\x1e\xda\xc4\ +-\x7f\xf2\x0b\x07\x72\xcf\x37\x1e\xe1\xea\x79\xb7\x77\x39\xf8\xcf\ +-\xa6\xb1\x13\x56\x1e\x54\x38\xd1\x69\x4e\x03\x7a\x4a\x75\xdd\x09\ +-\xa3\x4d\x20\x2d\xe5\x4c\x95\xa5\x28\xc5\x97\xd9\xda\x1f\xef\x64\ +-\xc1\x99\xb1\x7e\x5a\x00\x84\x24\x28\xa9\x6a\xe2\xe3\x63\x79\xe0\ +-\x8e\xb9\xc1\x68\xba\x4f\x12\x9f\x98\xc4\x75\xf3\xbf\xc2\x9d\x0f\ +-\x7e\x9f\xac\x5c\x6d\x69\xd8\x5a\x9a\x1b\xa9\x28\xdb\xc4\xba\xa3\ +-\x67\xd2\xa1\x9b\x04\x86\xd1\x19\x9c\x15\x45\x21\x35\x39\xb0\x64\ +-\x20\x52\x72\x3a\x79\xe7\xe9\xc9\xa0\x2a\x94\x0d\x42\x06\x27\xbd\ +-\xd1\x4d\x73\xae\xe0\xed\x4f\x3e\xef\xd5\x19\x62\x82\x8d\xa2\x28\ +-\x14\x5f\x7e\x15\x57\xce\xbc\x4e\x73\x44\xa3\xc7\xed\x66\xc3\xda\ +-\x4f\xd9\xb4\x76\x39\xc3\xc7\x94\x30\x72\xdc\x44\xb6\x1e\x13\xe4\ +-\x5c\x7a\x8d\x68\xd2\x0d\x87\x0d\xf6\x71\x49\x4d\x4e\xf0\xfb\x78\ +-\xf7\x7c\x84\x50\xbe\x38\xf5\xff\xa7\x05\x20\xb9\x93\x8d\xed\xf1\ +-\xfa\x6f\x04\x82\x2f\x7d\xd2\x4f\xbf\x7b\x17\x0f\xfd\xe8\x09\xd3\ +-\xa5\x34\x00\x0a\x07\x0c\x61\xf6\xf5\xb7\xd2\x2f\x80\x54\xd4\xfb\ +-\xf7\x6c\x67\xd5\x87\x4b\x2f\xc8\x4a\xe4\xf0\xf8\xf2\x16\x26\x18\ +-\x1b\xd2\x1e\x91\xa8\xaa\xca\xfe\xa3\xc6\x86\x7e\x9f\x3d\xfd\xd7\ +-\x88\xb3\xc5\xc5\xe9\xac\x3d\xa7\x05\x60\xe8\x50\xe1\x2c\xaf\xf1\ +-\x54\x80\xf0\x2f\x91\x9e\x46\x86\x0e\xc8\xe7\xfe\xdb\xaf\xe1\x5f\ +-\xff\xfe\x30\x18\xcd\xf7\x4a\x12\x12\x93\x99\x3e\xe7\x26\x46\x8e\ +-\x2b\x45\xeb\xab\xba\xb9\xe9\x04\x2b\x3f\x58\xc2\xa1\xfd\x97\x8e\ +-\xd7\x6f\x77\x0a\x12\xa2\xcd\x73\x7f\xad\xec\x3f\x5c\x63\xf8\x11\ +-\x60\x46\x80\x55\x96\x05\x72\xd3\xcc\x81\xe2\x74\xea\xdb\x73\xf7\ +-\x83\x85\x58\x87\x24\x28\x02\x00\x70\xf7\x2d\x57\xb3\x7e\xf3\x6e\ +-\x76\xee\x3f\x12\xac\x2e\x7a\x05\x8a\xc5\x42\xc9\xe4\xe9\x5c\x39\ +-\xe3\x5a\xcd\x79\x0b\xdc\x2e\x17\x5f\x7c\xf6\x31\x9b\xd7\xaf\xec\ +-\x36\x5c\xb4\xd9\x0e\x39\x91\x53\xad\x3b\x6c\xd8\xbe\xf7\x88\xd1\ +-\x26\x90\x93\x19\x58\x3d\x4e\x89\x58\x77\xf6\xbf\xad\xe7\xfe\x50\ +-\xae\x13\x88\x47\x7a\x60\x57\x97\x58\x2c\x0a\xbf\x7e\xf4\xab\x7c\ +-\xfd\xd1\x27\xcc\x98\xf2\x4b\x50\x38\x70\x08\x57\xcf\xbb\x9d\x8c\ +-\xcc\x1c\xcd\xf7\x1e\xdc\xbb\x83\x15\x1f\x2c\xf1\x3b\x09\xe9\xe1\ +-\x26\xc1\x80\x93\xd5\x6e\x4c\xfc\xa7\x6c\xbb\xf1\xb5\x0c\x8b\xf2\ +-\x03\x2b\x0d\x2e\x91\x97\x16\x00\xab\x62\x59\xa7\xb7\x47\xe0\xf9\ +-\x64\xa4\x26\xf3\xdb\x1f\x3d\xc8\xb7\x7f\xf6\xd7\x3e\x95\x40\xb2\ +-\x3b\x12\x93\x53\x98\x36\xfb\x46\x46\x8e\x9f\xa8\xf9\xde\xe6\xc6\ +-\xe3\xac\xf8\x70\x09\x87\xf7\xef\xd6\x74\x9f\xcb\x0b\x1b\xaa\x14\ +-\xae\x1a\xa0\x62\x70\x6e\x8b\x88\xc1\xed\xf1\xb2\x79\xc7\x7e\xa3\ +-\xcd\xa0\x28\x3f\xa0\xe0\x5d\x29\x14\xcb\x17\x67\x7f\x70\x8e\x00\ +-\x8c\xcb\x11\x0d\xe5\x35\xde\x9d\x80\x7f\x79\xa0\x03\x64\xd8\xc0\ +-\x02\xfe\xe7\x3b\x5f\xe1\xe7\x7f\x7c\xc1\xb8\xc2\x0a\x61\x82\xc5\ +-\x62\xa5\xf4\xca\x99\x4c\xbe\xea\x1a\xa2\xa2\xb5\xed\xc8\xb9\x5d\ +-\x4e\xd6\xaf\xfa\x88\xb2\x2f\x56\x05\x9c\xa1\xa8\xc5\x0e\xdb\x8e\ +-\x09\x8a\xf3\xcd\xbd\x00\x7f\xd8\xba\xeb\xa0\xe1\xeb\x7f\x80\xa2\ +-\xbc\x80\x04\x60\x5b\x49\xae\x38\x27\x7b\xeb\x05\x3e\x61\x12\x3e\ +-\x14\x41\x16\x00\x80\x19\x93\xc7\xf2\xd8\x0f\xee\xe1\x97\x7f\x7e\ +-\xc9\xf0\xcc\x2a\x46\x51\x34\x68\x18\x57\x5f\x7f\x1b\xe9\x99\xda\ +-\xa7\x73\x07\xf7\xee\x60\xf9\xfb\x6f\xe8\x52\x25\xb6\xb2\x45\x30\ +-\x2c\xd3\x14\x00\x7f\x58\xbe\xbe\xc2\x68\x13\x88\xb2\x5a\xc8\xf5\ +-\x33\x6b\xf3\x79\x5c\xb0\x03\x7f\x81\x00\x08\xa9\x2e\x43\x28\xff\ +-\x19\x48\xeb\x5a\x99\x35\x65\x3c\x42\x11\xfc\xe2\x89\x45\x7d\x4a\ +-\x04\x52\xd2\x32\x98\x79\xed\x7c\x86\x8c\x18\xa3\xf9\xde\x13\x0d\ +-\xc7\x58\xfe\xfe\x1b\x54\x1d\x39\xa0\x9b\x3d\x12\x68\x73\x9a\x0e\ +-\x01\xdd\xe1\xf6\x78\x59\xfd\x45\x50\x1c\x66\x35\x51\x98\x97\x1d\ +-\x58\x3e\x42\x45\x59\x76\xfe\x47\x17\x08\x40\x4c\xab\x75\x8d\x23\ +-\x55\x6d\x17\x10\x92\xfd\xe1\x99\x93\xc7\x11\xff\xa3\x18\xfe\xdf\ +-\x13\x2f\xd2\x61\xeb\x5d\xb9\xf7\xce\xc7\x1a\x15\xc5\xe5\x53\x67\ +-\x73\xf9\x95\x57\x6b\x4e\xe6\xe0\x72\xd8\x59\xb7\x6a\x19\x15\x1b\ +-\x3e\x0b\xca\xb2\x29\xc6\x62\xce\x00\xba\xe3\xf3\xb2\x5d\xb4\x75\ +-\x18\x5f\xe7\x70\xd4\xb0\xae\x0b\xdd\x5c\x82\x36\xb5\x86\xf5\xe7\ +-\x7f\x78\x81\x00\x8c\x1a\x25\x5c\xe5\x35\xea\x4a\x90\x37\x05\xd2\ +-\x4b\x20\x4c\x2a\x1e\xc1\x33\xbf\xfb\x21\x3f\x7e\x7c\xa1\xe1\x1e\ +-\x56\xc1\x62\xe8\x88\x31\xcc\xb8\x76\x3e\x29\x5a\x6b\x39\x49\xc9\ +-\xae\xad\x9b\x59\xfd\xe9\x3b\x74\xb6\x07\xaf\xee\x62\x4f\x6b\x22\ +-\xf6\x05\xde\xfa\x78\x5d\xf7\x17\x85\x80\x51\x43\x07\x68\xbf\x49\ +-\x8a\x4f\x4b\x4b\xc5\x05\x61\xb9\x17\x8f\x0b\x93\x72\x19\x82\x90\ +-\x09\x00\x40\x41\x4e\x3f\x9e\xfe\xcd\x0f\x78\xe2\x99\x25\x7c\xb8\ +-\x6a\x53\x28\xbb\x0e\x2a\x85\x03\x86\x30\xf5\xea\x1b\xfc\xaa\x51\ +-\x78\x3e\x0d\x75\x35\x2c\x7f\xff\x0d\x6a\x2a\x0f\x05\xc1\xb2\x73\ +-\xd9\x7e\x4c\xd0\x68\x33\x45\xe0\x52\x54\xd6\x36\xb0\x69\x9b\xf1\ +-\xc7\x7f\x00\xa3\x86\xf5\xd7\x7c\x8f\x50\xd4\x0b\xa6\xff\x70\x09\ +-\x01\x50\xa4\xf2\x8e\x2a\xd4\xbf\x71\x76\xb4\x60\x08\x88\x8f\x8d\ +-\xe1\x7f\xbe\x73\x17\x73\xa6\x4e\xe0\xf1\xa7\x16\x53\x7f\x22\x32\ +-\x8b\x6a\x22\x04\x03\x06\x0d\x67\xe2\x95\xb3\xe8\x3f\x78\xb8\xe6\ +-\xdb\x9d\x0e\x1b\x6b\x57\x7c\xc0\x96\x8d\xeb\x90\x41\x8a\xcf\x38\ +-\x1f\xc9\xb9\x55\x8d\x4d\xce\xe5\xf9\x37\x3e\x0e\x8b\x6c\x49\x09\ +-\xf1\x71\xf4\xd7\xee\x03\xa0\x7a\x5d\x96\xf7\x2e\xf6\x83\x8b\x0a\ +-\xc0\xf8\x42\x51\x53\x51\xe3\x59\x2f\x11\x53\xb5\xf6\xa4\x07\x97\ +-\x8f\x1f\xce\xcf\x7f\xfa\x28\x8b\x96\xae\xa0\xfc\x8b\x55\xb8\x7a\ +-\x58\x04\x31\x54\x44\xc7\xc6\x31\x7a\xdc\xe5\x8c\xbf\x7c\x2a\xe9\ +-\xfd\xb4\x1f\xd3\x48\x29\xd9\xb9\x65\x03\xab\x3f\x7e\x17\xbb\xcd\ +-\xcc\xc6\x1b\x2e\x1c\xa9\xaa\xe3\xd3\xb5\xc6\xef\xfe\x03\x8c\x1e\ +-\xde\x1f\xe5\xfc\xf4\x3e\xdd\x20\x85\x58\x5d\x3a\x40\x5c\x34\x7c\ +-\xf1\x92\xa9\x21\x24\x62\x31\x60\x88\x00\x78\x55\xa8\xe9\x88\x65\ +-\xea\xec\xeb\x99\x70\xc5\x34\x36\x7c\xf6\x09\x5b\x37\xaf\xc7\xed\ +-\x0e\xbf\x57\x94\xd5\x1a\xc5\x80\x21\x23\x18\x31\xaa\x98\x41\x23\ +-\x46\x13\x1d\x60\xc9\xb1\xfa\xda\x2a\x3e\x7d\xff\x75\x8e\x55\x1f\ +-\xd5\xd9\x42\x93\x9e\xb2\xf0\xb5\x65\x61\xe3\xaf\x32\x69\xfc\x65\ +-\x9a\xef\x11\xaa\xbc\x64\x76\xde\x4b\x0a\x80\x27\x4a\x79\xdd\xea\ +-\x56\x9f\x00\x42\x5e\x00\xed\x78\xa7\xc0\x75\xf2\x54\x30\x2e\x3e\ +-\x91\x19\xd7\xce\xe7\x8a\x19\xd7\xb2\x73\xcb\x26\xb6\x96\xad\xa3\ +-\xb1\xc1\xd8\x8d\xc2\xa8\xe8\x18\xfa\x0f\x1a\xc6\xf0\x51\xe3\x19\ +-\x3c\x7c\x34\xd1\x31\xb1\x01\xb7\xe5\xb0\x75\xb2\x66\xf9\xfb\x6c\ +-\x2b\x5b\x1f\x16\x53\x4c\x93\x73\xd9\x77\xb8\x9a\x55\x1b\x8c\x3f\ +-\xfa\x3b\xc5\x94\x09\x23\xb5\xde\xe2\xb5\x58\x95\xa5\x97\xfa\xe1\ +-\x25\x05\xe0\xf2\x2c\x51\x57\x5e\xeb\x59\x83\x14\x33\xb4\xf6\xd8\ +-\x53\x5a\x1d\x17\x7e\x16\x13\x1b\x47\xc9\xe4\x69\x94\x4c\x9e\x46\ +-\x5d\x6d\x25\x07\x76\xef\xe0\xc0\xde\xed\x9c\xa8\x0f\x7e\x8e\x81\ +-\xa8\xe8\x68\xf2\x0b\x07\x51\x34\x70\x28\x85\x03\x87\x92\x9d\x57\ +-\x18\x70\x2c\xf6\x29\xa4\x94\x6c\x2b\x5b\xcf\x9a\xe5\xef\xe3\xb0\ +-\x19\x9b\x5d\xd6\xe4\xe2\xa8\xaa\xe4\x2f\xcf\xbd\x15\x36\xc2\x5c\ +-\x94\x97\x45\x41\x4e\x3f\x8d\x77\x89\x15\xe3\x72\xc4\x25\xab\xf5\ +-\x76\x9d\x1d\x4e\x15\x8b\x11\xcc\xd0\xd8\x63\x8f\x89\xea\x66\xce\ +-\x91\x93\x57\x44\x4e\x5e\x11\x53\x67\x5f\x4f\x7b\x5b\x0b\xb5\x55\ +-\x47\x38\x56\x75\x98\xba\x9a\x2a\x1a\x4f\xd4\x07\xbc\x7e\x16\x42\ +-\x21\x35\x2d\x9d\x8c\xac\x5c\xd2\x33\xb3\xc9\xcc\xca\x25\x3d\x33\ +-\x87\x7e\x59\xb9\x58\x74\x2c\x05\x7d\xac\xfa\x28\x9f\xbe\xff\x3a\ +-\xf5\xb5\x55\xba\xb5\x69\xa2\x3f\x6f\x7c\xb8\x86\x2d\xbb\xc2\xa7\ +-\x1e\x62\x00\x6f\x7f\x40\x7d\xad\xab\x9f\x76\x29\x00\x6e\x94\xc5\ +-\x51\xa8\x7f\x04\x02\x9f\xe3\x06\x40\x6e\x92\x64\x57\xbd\xc0\xe3\ +-\xc7\xb2\x2b\x29\x39\x95\xe1\xa3\xc6\x33\x7c\xd4\x99\x7c\xa6\x4e\ +-\x87\x9d\x96\xa6\x13\x74\x76\xb6\xe3\xe8\xec\xc4\x66\xef\x44\x3d\ +-\x19\x1a\xeb\xb0\xdb\x89\x8e\x8e\xc1\x6a\xb5\x12\x1d\x1b\x4b\x4c\ +-\x4c\x1c\x09\xc9\xc9\x24\x24\x24\x91\x94\x92\x86\x55\x63\xb1\x05\ +-\x2d\xd8\x6d\x1d\xac\xfe\xf8\x5d\x76\x6e\xd9\x10\x36\x6f\x15\x93\ +-\x8b\x53\x75\xec\x38\xff\x7c\xe5\x7d\xa3\xcd\x38\x87\xa9\x13\x47\ +-\x6b\xbd\xc5\x6e\xf5\x58\x2e\x39\xfd\x87\x6e\x04\x60\x52\x81\x68\ +-\x2c\xaf\xf1\xbe\x05\x7c\x59\x6b\xcf\x3d\x21\x2e\x0a\x2e\x2f\x94\ +-\x7c\x71\x54\x10\xc8\xd6\x4b\x4c\x6c\x1c\xd9\x79\x85\xba\xdb\xd5\ +-\x13\x6c\x1d\xed\x2c\xfc\xeb\xaf\x71\x3a\x8c\xf7\x24\x33\xe9\x1a\ +-\x55\x95\xfc\xe6\x1f\xaf\xe2\x70\x86\xcf\xa6\x73\x5e\x76\x06\xe3\ +-\x2e\xf3\xaf\xbc\xdb\x69\x04\xaf\x8f\xed\x2f\xba\x0c\x16\xe9\x76\ +-\x21\x2b\xa5\xfa\x2f\x6d\xbd\xea\x43\x56\xa2\x64\x68\x2f\x0a\x50\ +-\x71\xb9\x5d\xe6\xe0\x8f\x10\x9e\x79\xed\x03\xb6\xed\x0e\xbe\xf3\ +-\x95\x16\xe6\x4e\x2b\xbd\xa0\xe6\x43\x77\x48\x94\x67\xba\xbb\xa6\ +-\x5b\x01\x28\xc9\xb7\xae\x04\x0c\x09\x80\x8e\x35\x13\x55\x98\x84\ +-\x98\x65\xab\x37\xf3\xe2\x92\xf0\xab\x63\x31\xe7\xaa\x12\xad\xb7\ +-\xec\x2b\xc9\x65\x6d\x77\x17\x75\x2b\x00\x42\x08\x89\xe0\x59\xad\ +-\xbd\xf7\x94\x36\x27\xec\x69\x30\x5d\x53\x4d\x42\xc7\xd6\xdd\x07\ +-\xf9\xdd\x93\x5d\xee\x99\x19\xc2\xd8\xcb\x06\x69\x8e\xff\x17\xf0\ +-\x2f\xe1\x47\x61\x48\xbf\xce\xb2\xa2\x2c\xca\x73\x08\x42\x56\xdf\ +-\xab\xc5\x0e\x6b\x0f\x2b\x38\xbb\x4e\x69\x67\x62\xa2\x1b\x47\xab\ +-\xeb\xf9\xc9\xef\x9f\xc3\xe5\x09\xbf\x87\xee\xd6\x6b\xaf\xd2\x7a\ +-\x8b\x4b\xb1\x28\x2f\xfa\x73\xa1\x5f\x02\x30\x26\x5b\xd4\x0b\x95\ +-\x90\x48\x63\xbb\x13\xd6\x1d\x51\x4e\x3b\x02\x99\xf4\x3d\xf6\x1c\ +-\x17\x84\xf2\x90\x64\xdf\xe1\x6a\xbe\xfd\xf3\xbf\xd1\xda\x16\x7e\ +-\xfe\x18\x79\xd9\x19\xcc\x98\x3c\x56\xd3\x3d\x12\x5e\xe9\xea\xec\ +-\xff\x6c\xfc\xf6\x66\x51\xa5\xf2\x7b\x5f\xdb\xc1\xa5\xaa\x55\xe0\ +-\x0e\x0f\xaf\x4b\x13\x83\xa8\x6c\x11\x6c\xa8\x12\x21\x79\x09\xec\ +-\x3e\x50\xc9\x0f\x7e\xf9\x14\x2d\x6d\xe1\x19\x7b\x71\xc7\xbc\xe9\ +-\x9a\x93\x7f\x08\xa9\xfc\xc9\xdf\x6b\xfd\x6e\x79\x42\xa1\xd8\x06\ +-\x62\xb9\x26\x4b\x02\xa0\x3b\x27\x20\x93\xbe\x41\x5d\xbb\x60\xe5\ +-\x01\x85\x23\xcd\x81\x1d\x05\xfb\xc3\x86\x8a\x3d\x7c\xff\xb1\x7f\ +-\xd0\xd6\x1e\x7e\x6f\x7e\x80\xe4\xc4\x78\xae\x9f\x75\xb9\xc6\xbb\ +-\xc4\xb2\x92\x02\xb1\xd5\xdf\xab\x35\xd5\x89\x95\xc2\xfb\x07\x21\ +-\x95\xab\x35\x5a\xa4\x89\xec\x04\xc9\x4e\xcc\xcd\x3f\x13\xb0\x7b\ +-\x60\x4b\xad\x60\x47\x9d\x20\x21\x06\xa2\x15\x49\x94\x05\xfa\xa7\ +-\x41\x76\x62\xe0\x93\x51\x29\x25\xaf\xbc\xbd\x82\xa7\x5f\x79\x1f\ +-\x55\x0d\xdf\xa3\xe6\x2f\xdf\x38\x93\xf8\x58\x8d\xc1\x65\xd2\xfb\ +-\x7f\x5a\x2e\xd7\x24\x00\x13\xf2\xa2\x96\x95\xd7\x78\xb7\x02\xe3\ +-\x34\x19\xa5\x81\xe4\x58\x48\x8a\xf1\xed\x05\x98\x98\x00\x78\x54\ +-\x68\xb5\x03\x27\x5f\x0c\x75\xed\x30\x63\xb0\x24\x39\x80\xc0\xcb\ +-\xd6\xb6\x4e\x7e\xf1\x97\x45\x6c\xdc\xb2\x57\x57\x1b\xf5\xa6\x5f\ +-\x5a\x0a\xb7\xcf\x9b\xa6\xf5\xb6\x6d\xc5\xf9\xd6\x15\x5a\x6e\xd0\ +-\x1c\xd1\x22\xa4\x7c\x42\xeb\x3d\x5a\xc9\x4f\x09\x5f\x55\x36\x31\ +-\x1e\x55\xc2\xfe\xe3\xda\x67\x89\x9f\xae\xab\xe0\x9e\x47\x7e\x17\ +-\xf6\x83\x1f\xe0\x81\x2f\x5d\x4b\x5c\xac\xb6\x34\xf1\x42\xc8\xc7\ +-\xfd\x39\xfa\x3b\x1b\xcd\x02\xb0\x3f\xdf\xf2\x92\x84\xa0\x7e\x83\ +-\xfd\xd3\xa4\x5f\x75\xce\x4d\xfa\x2e\xd5\x6d\xc2\xef\x63\xe2\xda\ +-\xfa\x46\x1e\xf9\xdf\xa7\x79\xec\x89\x17\x69\x6a\x0e\x5e\x5e\x45\ +-\xbd\x28\xca\xcb\x62\xde\x4c\xad\x6b\x7f\xf6\xed\xcf\xb5\x68\x3e\ +-\xa9\xd3\x2c\x00\x77\x08\xe1\x55\x84\xfc\x95\xd6\xfb\xb4\x10\x67\ +-\x85\xab\x06\xa8\x24\x87\x34\x04\xc9\x24\x92\x90\x12\xea\x3b\xba\ +-\x9e\x05\x34\xb7\xb6\xf3\xf7\x17\xdf\xe1\x9e\x87\x1f\x67\x43\xc5\ +-\x9e\x10\x59\xd6\x33\x84\x10\xfc\xe7\x43\xb7\x05\xb0\xf3\x2f\x7f\ +-\x7a\x87\x10\x9a\xcf\x4d\x34\xed\x01\x9c\x62\x7c\xae\xe5\xdf\x15\ +-\xb5\xea\x7f\x03\xda\x0e\x28\x35\x90\x12\x0b\x33\x06\xab\xec\xae\ +-\x17\xec\x3f\x61\x6e\x0a\x9a\x5c\x48\x43\x07\x14\xa5\x5e\xf8\x79\ +-\x73\x6b\x3b\xaf\xbe\xbb\x9a\x25\x1f\xae\x09\xab\x80\x1e\x7f\x98\ +-\x37\xeb\x72\x4a\x46\x0f\xd5\x74\x8f\x94\xec\x28\xce\xb7\x2c\x09\ +-\xa4\xbf\x80\x04\x40\x08\xa1\x96\x57\x7b\x7e\x85\x10\xaf\x07\x72\ +-\xbf\xbf\x28\xc0\xa8\x6c\x89\xc3\xed\xf3\x0f\x30\x31\x39\x9b\x56\ +-\x87\xe0\x94\x6b\x8a\xaa\x4a\xca\x77\xec\xe7\xc3\xd5\x9b\x58\xf5\ +-\xf9\x56\x9c\xae\x90\x39\xae\xea\x46\x7a\x5a\x32\xdf\xbe\x57\x7b\ +-\x32\x6e\x45\xc8\x9f\x0a\x21\x02\x3a\x2d\x0d\x48\x00\x00\x8a\xf3\ +-\x2d\x4b\x2a\x6a\xd5\x2d\xc0\xf8\x6e\x2f\xee\x21\x63\xf3\x24\x8d\ +-\x36\x81\x2d\xf2\xfe\xa6\x26\x41\xa4\xcd\xe6\x66\xe3\xd6\x03\x6c\ +-\xa8\xd8\xcd\xca\xcf\xb7\x46\x7c\xc5\xe9\x47\x1e\xbc\x95\xa4\x84\ +-\x78\xad\xb7\x95\x8d\xcf\xb3\xbc\x13\x68\x9f\x01\x0b\x80\x10\x42\ +-\x96\x57\xbb\xff\x13\xa1\x04\x3d\x74\x2a\x4a\x81\xf1\x79\x92\xf5\ +-\x47\xcd\x59\x40\x5f\x45\x4a\x95\xb6\x96\x66\xea\x8f\x55\xd3\x70\ +-\xac\x86\xfa\x63\x95\x54\x1f\x39\x18\x96\x89\x62\x03\xe1\xe6\x39\ +-\x53\x98\xae\xd1\xe5\x17\x40\xa0\xfe\x58\x88\xc0\xcb\x3a\x05\x2c\ +-\x00\x00\x25\x05\x51\xcb\xcb\x6b\xd4\x77\x41\xde\xd8\x93\x76\xfc\ +-\x21\x2b\x51\x92\x9f\x02\x35\xe6\x52\xa0\xd7\xf3\xe1\xd2\x97\x4e\ +-\x97\x4e\xb3\x77\x76\xd0\xd9\xd1\x8e\xad\xb3\xbd\xd7\x66\x51\x1a\ +-\xd2\x3f\x9f\xef\x3f\x70\x8b\xf6\x1b\xa5\x58\x5a\x5c\x10\xf5\x49\ +-\x4f\xfa\xee\x91\x00\x00\xa8\x5e\xf1\xb0\x62\x91\xd7\x00\x81\xe5\ +-\xc3\xd6\xc0\x98\x1c\x49\x7d\x87\xc0\x63\x06\x0a\xf5\x6a\x42\x51\ +-\x09\x29\x5c\x88\x8f\x8d\xe1\x97\x3f\xbc\x87\x68\x8d\xb5\x22\x01\ +-\x97\x90\xe2\x47\x3d\xed\xbf\xc7\x95\x7f\x4a\x8b\xc4\x41\x09\x7f\ +-\xed\x69\x3b\xfe\x10\x6b\x85\x11\xbd\x28\x4b\x90\x49\xdf\x46\x51\ +-\x14\x7e\xf6\xfd\xbb\x29\xd2\x5e\xe9\x07\x24\x7f\x28\x2e\x14\x3d\ +-\x4e\xd4\xa3\x4b\xe9\x2f\x7b\xb4\xf2\x4b\x20\x24\xc9\xfa\x07\x65\ +-\x48\x92\x82\x3e\xd7\x30\x31\x09\x3e\xdf\xbd\xff\x66\xae\xd2\x9e\ +-\xe8\x13\xa0\xde\x15\xa7\xfc\x56\x0f\x1b\x74\x11\x80\xa9\x99\xa2\ +-\x5d\x22\x7f\xa2\x47\x5b\xdd\xa1\x00\xa3\xb3\xcd\x59\x80\x49\x64\ +-\x73\xf3\x9c\x29\xdc\x7e\xbd\x66\x5f\x7f\x1f\x42\xfe\xd7\xe4\x0c\ +-\xa1\x8b\x4b\xa3\x6e\xc5\x3f\x4b\xf2\x2c\xcf\x83\x08\x49\x32\xb5\ +-\xec\x24\x49\xbf\x78\x53\x04\x4c\x22\x93\xab\xaf\x2c\xe6\x91\xaf\ +-\xdf\x1a\xd0\xbd\x52\x88\x95\xc5\xb9\x96\x97\xf4\xb2\x45\x37\x01\ +-\x10\x42\x48\x8b\x45\x3c\x04\x84\x24\xb8\x7a\x54\x8e\x34\x83\x86\ +-\x4d\x22\x8e\x19\x93\xc7\xf2\xb3\xef\xdd\x1d\x68\x65\x29\x9b\xf4\ +-\x88\xaf\x6b\x0d\xf8\xe9\x0a\x5d\xcb\x7f\x8f\xcb\x11\x87\x81\xa0\ +-\xc6\x09\x9c\x22\x2d\x0e\x72\x92\xcd\x59\x80\x49\xe4\x30\x7d\xf2\ +-\x58\x1e\x7b\xf8\x5e\xcd\x7e\xfe\xa7\x91\xfc\xbc\xb4\x48\xe8\x5a\ +-\xaa\x48\x57\x01\x00\x68\xcd\x53\xfe\x00\x94\xe9\xdd\xee\xc5\x18\ +-\x99\x25\xd1\x98\x2a\xdd\xc4\xc4\x10\xe6\x4e\x2f\xe5\x17\x0f\xdf\ +-\x8b\x35\xf0\x12\x73\x5b\x5a\xf3\x95\x3f\xeb\x69\x13\x04\x41\x00\ +-\x66\x0a\xe1\x51\x85\xf2\x50\x28\xb2\x08\x27\xc5\xf8\x42\x87\x4d\ +-\x4c\xc2\x99\xdb\xaf\x9f\xc6\x4f\xbf\x73\x57\x4f\x06\xbf\x0b\xa9\ +-\xdc\x3f\x53\x08\xdd\x53\x16\xeb\x2e\x00\x00\xa5\x79\xa2\x5c\xc0\ +-\x63\xc1\x68\xfb\x7c\x46\x66\x49\xa2\xcd\xdc\x01\x26\x61\x88\xc5\ +-\xa2\xf0\x5f\x0f\xdd\xce\xf7\x1f\x98\xaf\xb9\xaa\xcf\xd9\x48\xf8\ +-\x99\x96\x3c\x7f\x5a\x08\x8a\x00\x00\x8c\xcf\x55\x7e\x2b\x85\x58\ +-\x19\xac\xf6\x4f\x11\x6d\xf1\x89\x80\x89\x49\x38\x91\x9a\x9c\xc8\ +-\x1f\xfe\xe7\x1b\xdc\x7c\xcd\x94\x1e\xb6\x24\x3f\x3b\xe8\x5b\x56\ +-\x07\x85\xa0\x09\x80\x10\x42\xb5\xaa\xe2\x5e\xa0\x29\x58\x7d\x9c\ +-\xa2\x7f\xba\x24\xd7\xdc\x10\x34\x09\x13\x2e\x1b\x52\xc4\x33\x8f\ +-\x3f\x4c\xe9\xd8\x61\x3d\x6d\xaa\x45\x15\x96\x7b\x02\x49\xf4\xe1\ +-\x2f\x41\x13\x00\x80\x71\x05\xa2\x1a\x29\xbf\x11\xcc\x3e\xc0\x97\ +-\x2a\xb2\x38\x4f\x92\xa0\x2d\x85\x9a\x89\x89\xae\x28\x8a\xe0\xae\ +-\x9b\x67\xf1\xe4\xff\x7e\x8f\x9c\xcc\xf4\x1e\xb7\x27\x91\xff\x51\ +-\x9a\x27\x2a\x75\x30\xed\x92\x04\x55\x00\x00\x4a\x0a\xac\x6f\x20\ +-\x78\x21\xd8\xfd\x44\x5b\xa0\xb4\x40\x0d\xfe\x2f\x14\xe1\xc4\xc6\ +-\xc6\x19\x6d\x42\xaf\x24\x2f\x3b\x83\xbf\xfd\xe2\x3b\x7c\xeb\x9e\ +-\x1b\x7b\xb2\xd9\x77\x1a\x09\xff\x9a\x90\x6f\x0d\x7a\x35\xae\x1e\ +-\x47\x03\xfa\x43\xab\x53\xf9\x8f\x94\x68\x75\x0c\xa0\xb9\xc4\xa9\ +-\x16\xd2\xe2\x60\x68\xa6\x64\x6f\x00\x19\x63\x7b\x3b\x71\x09\x09\ +-\x4c\x9b\x7d\x23\xa3\x4b\x26\x1b\x6d\x4a\xaf\x42\x51\x04\x37\xcf\ +-\x99\xc2\x37\xef\xb9\x51\x7b\x0e\xff\x4b\xb3\xc5\xa9\x2a\xdf\xd7\ +-\xab\xb1\xae\x08\x89\x00\xcc\x1c\x28\x1c\xe5\xb5\x72\x01\x52\x2d\ +-\x03\x32\x82\xd9\xd7\xd0\x0c\xc9\xc1\x46\x81\xc7\x2c\x2f\x06\xf8\ +-\x92\x4c\x5e\x36\xb6\x94\x99\x73\xe7\x13\x97\x90\x60\xb4\x39\xbd\ +-\x8a\xa1\x03\xf2\x79\xe4\xa1\xdb\x18\x3d\x6c\x80\x9e\xcd\x36\x59\ +-\x2c\xca\x82\x29\xf9\xc2\xae\x67\xa3\x97\x22\x24\x02\x00\x50\x92\ +-\x27\x8e\x56\xd4\xb8\xef\x94\x28\x1f\x02\x41\x3b\xb8\xb3\x5a\x20\ +-\x3d\x5e\xd2\xd0\x4d\xc6\xd8\xbe\x40\x5e\xe1\x00\x66\xcf\xbb\x9d\ +-\xec\xdc\x02\xa3\x4d\xe9\x55\x24\x27\x25\xf0\xb5\x2f\x5f\xc7\x2d\ +-\x73\xae\x08\xd4\xa5\xf7\x52\xa8\x52\xa8\x5f\x19\x97\x63\x39\xac\ +-\x67\xa3\x5d\x11\x32\x01\x00\x28\xce\x8f\xfa\xa4\xa2\xc6\xfb\x2b\ +-\x19\x64\x1f\x81\x7e\x09\xbe\x8c\xb1\x7d\x95\xd8\xf8\x04\xae\x98\ +-\x3e\x97\x92\x49\xd3\x7a\x74\xfe\x6c\x72\x2e\x71\xb1\xd1\x2c\xb8\ +-\xf6\x2a\xee\x59\x30\x9b\xc4\x78\xfd\xf7\x52\x84\xe0\xa7\x25\x79\ +-\x51\xcb\x74\x6f\xb8\x0b\x42\x2a\x00\x00\xe3\xf3\x94\x5f\x55\xd4\ +-\xca\x62\x90\x37\x07\xab\x8f\x82\x64\xdf\x3e\x80\xb7\x8f\x2d\x03\ +-\x14\x45\x61\xfc\xc4\xab\xb8\x72\xd6\x75\xc4\x98\x9b\x7d\xba\x11\ +-\x1b\x13\xcd\x8d\xb3\x27\x73\xcf\x82\xab\x49\x4f\x4d\x0a\x4e\x27\ +-\x52\x2c\x19\x9f\x27\x74\x89\xf1\xd7\x42\xc8\x05\x40\x08\xa1\xae\ +-\xaf\x92\x77\xc6\x2a\xea\x0a\x10\x41\xd9\x91\x8a\x8f\x86\xf1\xb9\ +-\x92\xf2\xda\xd0\xd6\x99\x37\x92\x82\xa2\xc1\xcc\x9e\x77\x1b\x99\ +-\x39\x79\x46\x9b\xd2\x6b\x88\x8f\x8f\x65\xde\x8c\xcb\xb9\x7b\xc1\ +-\x6c\x32\x52\x93\x83\xd8\x93\xdc\x6c\xb1\x2a\xf7\xe9\x19\xe5\xe7\ +-\x2f\x21\x17\x00\x80\x29\x85\xc2\x5e\x7e\x4c\xde\x84\x54\x3f\x47\ +-\x32\x38\x18\x7d\x14\xa6\x4a\x14\x05\x2a\x6a\x7a\xf7\x86\x60\x42\ +-\x62\x32\x33\xe6\xde\xcc\x65\x63\x26\x60\x46\x46\xe9\x43\x51\x7e\ +-\x36\xf3\xe7\x4e\x61\xde\xcc\x49\xc4\xc7\x05\x3d\xfd\xd4\xe1\x28\ +-\xab\xe5\x86\x31\xd9\xc2\x90\x1a\xe5\x86\x08\x00\x40\x49\xae\x38\ +-\x5e\x56\x2b\x6f\x14\xa8\xeb\x80\xb4\x60\xf4\x91\x9f\x2c\x49\x8e\ +-\x91\x6c\xac\x52\x7a\x5d\xb5\x61\xc5\x62\xa1\x64\xd2\x34\xa6\xcc\ +-\xb8\x96\xe8\x18\xb3\x86\x5a\x4f\x89\xb2\x5a\x98\x5a\x3a\x9a\xf9\ +-\xd7\x5e\x49\xf1\xa8\x21\xa1\xda\x3b\x69\x52\x85\x72\xfd\x98\x6c\ +-\x51\x1f\x8a\xce\x2e\x86\x61\x02\x00\x30\x21\x4f\xec\x2e\x3f\x26\ +-\xe7\xa3\xaa\x1f\x11\xa4\xac\xc2\x49\x31\xbe\x12\x63\xfb\x8e\x0b\ +-\x0e\x9c\x10\x78\x7b\xc1\x92\xa0\x70\xc0\x10\x66\xcf\xbb\x8d\x7e\ +-\x59\xb9\x46\x9b\x12\xf1\x0c\x1f\x5c\xc8\xdc\x69\xa5\xcc\x99\x5a\ +-\x4c\x5a\x4a\x90\xd6\xf7\x17\x43\xe0\x46\x55\xef\x28\xcd\xb7\x18\ +-\x5a\xb4\xd0\x50\x01\x00\x28\xc9\x15\xab\xcb\x6a\x3c\xf7\x09\xc4\ +-\xcb\x04\xe9\x78\xd0\x22\xe0\xb2\x2c\x49\x61\xaa\x64\x47\x9d\xa0\ +-\xae\x3d\x32\xa7\xca\x49\xc9\xa9\x4c\x9f\x7b\x0b\x23\x46\x17\x1b\ +-\x6d\x4a\xc4\xa2\x28\x82\xcb\x06\xf7\x67\xfa\xa4\x31\x4c\x9b\x3c\ +-\x96\x82\x9c\x7e\x46\x98\xe1\x45\x95\x77\x95\x14\x44\x2d\x37\xa2\ +-\xf3\xb3\x31\x5c\x00\x00\x26\xe4\x5b\x5f\xab\xa8\xf6\xc4\x4a\x21\ +-\x9e\x25\x88\xee\xc9\x89\xd1\x30\xb9\x48\xd2\x64\x97\xec\xae\x17\ +-\x1c\xef\x8c\x0c\x21\xb0\x58\x2c\x4c\xb8\x62\x26\x93\xa7\x5f\x43\ +-\x74\xb4\x99\x12\x59\x2b\x09\xf1\x71\x94\x8e\x1d\xca\xa4\x71\x23\ +-\x98\x52\x3a\x92\x7e\x69\x29\x46\x9a\x23\x85\x90\xff\x51\x9c\x6f\ +-\x7d\xc3\x48\x23\x4e\x11\x16\x02\x00\x50\x5c\x60\x7d\xa1\xdc\xec\ +-\x1a\x97\x00\x00\x09\x20\x49\x44\x41\x54\xac\xc6\x9b\x28\xe0\x6f\ +-\xc1\xee\x2b\x3d\x0e\xae\x1c\x20\xe9\x70\x49\x2a\x9b\x05\x95\x2d\ +-\x02\x87\xee\xa9\x16\xf4\xa1\xff\xe0\xe1\x5c\x3d\xef\x36\xd2\x32\ +-\xb2\x8c\x36\x25\x62\x48\x49\x4e\x60\xd4\xd0\xfe\x8c\x1e\x36\x80\ +-\xf1\xa3\x06\x33\x6a\xe8\x80\xc0\xd3\x70\xe9\x8c\x94\x3c\x52\x92\ +-\x6f\x7d\xc6\x68\x3b\x4e\x11\x36\x02\x00\x30\x21\xdf\xf2\xf7\xb2\ +-\x6a\x6f\xb4\x10\xfc\x31\x14\xfd\x25\x46\xc3\xc8\x6c\xc9\x65\x59\ +-\x92\xda\x36\xc1\x8e\x7a\x81\x3d\x4c\x0a\x90\x26\x26\xa7\x30\x6d\ +-\xf6\x8d\x8c\x1c\x3f\xd1\x68\x53\xc2\x1a\x45\x51\x28\xca\xcf\x62\ +-\xf8\xa0\x02\xc6\x8d\x18\xc4\x98\x11\x03\x19\x50\x90\x1d\x9e\x0e\ +-\x50\x82\x1f\x4f\xc8\xb7\x3c\x61\xb4\x19\x67\x13\x56\x02\x00\x30\ +-\xa1\xc0\xf2\x44\x79\x8d\x37\x15\xf8\x79\xa8\xfa\x14\x02\xf2\x53\ +-\x24\xd9\x89\x92\x6d\x75\xbe\x19\x81\x51\x28\x16\x0b\xe3\x4b\xa7\ +-\x32\xf5\xea\x79\xe6\x74\xff\x2c\xa2\xac\x16\x32\x33\x52\x19\x50\ +-\x90\xcd\xc0\xc2\x5c\x06\x16\xe6\x30\xb0\x20\x9b\xc2\xfc\x2c\x3d\ +-\x83\x70\x82\x86\x84\x5f\x4c\xc8\xb3\x84\xdc\xd1\xa7\x3b\xc2\x50\ +-\x26\x7d\x94\xd7\x78\x1f\x05\x0c\xf9\xc2\x2a\x5b\x04\x5b\x6a\x05\ +-\xaa\x8e\x27\x06\x2d\xcd\x8d\x3c\xf3\xa7\x5f\x76\x79\xcd\xa0\xa1\ +-\x23\x99\x79\xfd\xad\xa4\xa5\x1b\xb2\x31\x85\xcb\xe5\xa4\xb9\xf1\ +-\x38\x4d\x27\xea\x69\x6f\x6d\xa6\xa3\xbd\x95\xb6\x96\x66\x3a\x3b\ +-\xda\xb0\x77\x76\x60\xb7\xdb\x70\x3a\xf4\x8d\x51\x11\x42\x10\x1d\ +-\x13\x47\x5c\x7c\x3c\x89\x49\xc9\x14\x64\xa5\x50\x94\x9d\x4c\x56\ +-\x46\x2a\x19\xa9\xc9\x64\xf5\x4b\x21\x33\x3d\x95\x9c\xcc\x74\x14\ +-\x25\x6c\x1f\xd7\xee\xf8\x7f\x25\xf9\x96\xae\xff\xf8\x06\x11\x76\ +-\x33\x80\x53\x94\xe4\x5b\x1e\x2f\xaf\xf6\xb6\x22\xf8\x3b\x21\xc8\ +-\x5b\x70\x36\x45\xa9\x92\x84\x28\xc9\x86\x2a\x05\x57\x08\x0a\x91\ +-\xa6\xa4\x65\x30\xf3\xda\x05\x0c\x19\x11\x50\x99\x28\xdd\x88\x8e\ +-\x8e\x21\x3b\xb7\xa0\xeb\xe0\x21\x29\x71\x38\xec\xd8\xed\x36\x5c\ +-\x27\xc5\xc0\xe5\x74\xa2\xaa\x5e\xbc\xaa\x17\xb7\xeb\xdc\x72\xdd\ +-\x42\x08\x62\xce\xf2\x53\x88\x89\x8d\x23\x26\x36\x96\xa8\xe8\x18\ +-\xa2\x63\x62\xcf\x99\xe5\xc4\x58\x61\xce\x10\x15\x6b\xef\xc9\xf1\ +-\x28\x85\xe0\xe1\xe2\x3c\x8b\xee\xd9\x7c\xf5\x22\x6c\x05\x00\xa0\ +-\xa4\xc0\xf2\x54\x45\xad\xa7\x5d\x4a\xf1\x3c\x21\xb6\x35\x23\x01\ +-\xa6\xf4\x57\x59\x73\x58\x09\x9a\xef\x80\x35\x2a\x8a\x92\x49\xd3\ +-\xb9\x62\xfa\x5c\xa2\xa2\x23\x24\x9d\x91\x10\xc4\xc6\xc5\x13\x1b\ +-\x17\xaf\x7b\xd3\x43\xfb\xc9\xde\x34\xf8\xbd\x12\xf9\xf5\x92\x3c\ +-\xeb\x73\x46\x1b\xd2\x15\x61\x2d\x00\x00\xc5\x79\xd6\x97\xcb\x6a\ +-\x3c\x1e\x81\x78\x11\x08\xe9\x28\x49\x8d\x83\xd1\xb9\x92\xad\xb5\ +-\xfa\x4f\x3d\x07\x0f\x1b\xc5\xcc\xeb\x6f\x25\x35\x2d\xa8\xe9\x11\ +-\x22\x8a\xcc\x84\x5e\xe0\xa5\xe5\xc3\x89\x94\x77\x4f\x28\x08\x8f\ +-\xa3\xbe\xae\x08\x7b\x01\x80\x93\x7e\x02\x35\xb2\x5a\xa2\xbe\x05\ +-\x84\x74\x81\x5c\x94\x22\xd9\x55\x27\x70\xeb\x14\x4f\x90\x9a\xde\ +-\x8f\x59\xd7\x2d\x60\xd0\xb0\x51\xfa\x34\xd8\x8b\xe8\x0d\x5e\x9a\ +-\x40\xb3\x50\xd5\x05\xc5\x85\x51\xab\x8c\x36\xc4\x1f\x22\x6a\x57\ +-\xa5\xac\x4a\x0e\x11\x8a\xfa\x01\x30\x34\x94\xfd\x6e\xa8\x14\x1c\ +-\xeb\xa1\xf7\x60\x7b\x5b\x0b\x3b\x2b\x36\x32\x71\xea\x2c\x2c\x96\ +-\x88\xd0\xdd\x90\x73\x45\x91\x24\x3b\x29\xa2\x55\xe0\xb0\x2a\x94\ +-\xeb\x4b\xf3\x84\xa1\xee\xbd\x5a\x88\x28\x01\x00\xd8\x5c\x2b\xfb\ +-\x29\xd2\xfb\x16\x88\x2b\x43\xd5\xe7\x81\x46\xc1\x8e\xba\x88\xfb\ +-\xaa\x22\x8e\xab\x87\xa8\x24\x86\xff\x89\xde\xc5\x11\x72\x63\x94\ +-\xc5\x72\x93\x91\x81\x3d\x81\x10\x1e\xee\x51\x1a\x28\xcd\x13\x27\ +-\x54\x61\xb9\x46\x20\xde\x0c\x55\x9f\xa9\x66\xb0\x5d\xd0\xc9\x49\ +-\x92\x91\x3b\xf8\xa5\x58\xe2\xf0\x5a\x66\x44\xda\xe0\x87\x08\x14\ +-\x00\x80\xd2\x3c\x61\x1b\x9f\x27\x6e\x05\x7e\x04\x04\xfd\xa0\x2e\ +-\x39\x36\xa2\xa7\xa5\x61\x8f\x10\x11\x5b\xdd\x49\x02\x8f\x17\xe7\ +-\x8b\x3b\xa6\x14\x86\x26\x89\xa7\xde\x44\xa4\x00\x00\x08\x21\x64\ +-\x49\xbe\xe5\x71\x45\xaa\x73\x80\x86\x60\xf6\x15\x6d\x81\x58\x73\ +-\xd9\x1e\x34\x06\xa6\x49\x92\x23\x6f\x96\xd5\x28\x85\x7a\x5d\x49\ +-\xbe\xe5\x47\x42\x88\x88\x4d\x39\x13\xb1\x02\x70\x8a\xf1\x05\x51\ +-\x2b\x3d\x28\xa5\x48\xb9\x29\x98\xfd\x24\xc5\x44\xe4\x1b\x2a\xec\ +-\x51\xf0\x9d\xff\x47\x12\x12\x2a\x2c\x16\x65\xe2\x84\xbc\xa8\x8f\ +-\x8c\xb6\xa5\xa7\x44\xbc\x00\x00\x5c\x9e\x2f\xaa\x1c\xd2\x32\x5d\ +-\x40\xd0\x9c\x2e\xe2\xa2\x82\xd5\x72\xdf\x26\x3f\x55\x46\xd4\x77\ +-\x2b\xe1\x5f\x6d\x2e\x65\xca\xb8\x1c\x11\xb2\xd4\xdd\xc1\xa4\xd7\ +-\x6d\x6d\x97\xd7\x7a\x6e\x45\x8a\x7f\x02\x3d\x2f\xce\x76\x16\x3b\ +-\xeb\x05\xfb\x4f\xf4\xba\xaf\xcb\x70\xa6\x0f\x52\x49\x8b\x84\x04\ +-\xc6\x82\x56\xa4\xfc\x66\x49\xbe\xf5\xdf\x46\x9b\xa2\x27\xbd\x62\ +-\x06\x70\x36\x25\x79\xd6\x25\x1e\x94\xf1\x08\xb9\xca\x68\x5b\x4c\ +-\xba\x26\x3d\x9e\x88\x18\xfc\x52\x88\x95\x16\x55\x19\xdd\xdb\x06\ +-\x3f\xf4\x42\x01\x00\xdf\x92\xa0\x38\xd7\x32\x4b\x08\x7e\x00\xb8\ +-\xba\xbd\xc1\x24\xe4\x08\x60\x54\x56\xd8\xef\x9d\x79\x24\xfc\xa2\ +-\x24\x57\x5c\x3d\xae\x40\x54\x1b\x6d\x4c\x30\xe8\x95\x02\x00\xbe\ +-\x53\x82\xe2\x3c\xcb\x9f\x15\x94\xc9\x40\x79\x4f\xdb\xeb\x2b\xf5\ +-\x05\x42\xc5\x88\x2c\x49\x46\x58\x97\x2a\x94\x9b\x91\x4a\xe9\x84\ +-\x7c\xcb\x63\x91\xbc\xcb\xdf\x1d\xbd\x56\x00\x4e\x31\x3e\x5f\x54\ +-\xb4\xe6\x29\x93\x4e\xce\x06\x02\x2e\x18\x66\x8e\xff\x9e\x23\x84\ +-\x6f\xca\x3f\xa9\x48\x32\x3c\x33\x6c\xbf\x51\x3b\xf0\xa3\x03\x79\ +-\x96\xc9\x25\x05\x62\xab\xd1\xc6\x04\x9b\x3e\xb5\xab\xb5\xa9\x5e\ +-\x0e\xb2\x78\xe4\x53\x20\xe7\x68\xbd\x77\xdb\x31\xc1\xa1\xa6\x3e\ +-\xf5\x75\x05\x8c\x00\x32\x12\x24\xfd\x12\x20\x21\x0a\x62\xa3\x20\ +-\xc6\x22\x89\x8f\x06\x6b\x38\xbf\x72\xa4\x5c\xad\x60\x79\x68\x7c\ +-\x81\xd8\x67\xb4\x29\xa1\xa2\xcf\x3d\xd1\x52\x4a\x51\x5e\xeb\xbd\ +-\x5f\x20\x7e\x03\x64\xfb\x7b\xdf\xf6\x3a\xc1\xc1\xc6\x3e\xf7\x75\ +-\x69\x26\x3b\x49\x32\x32\x4b\x92\x12\x59\x8e\x3d\x75\x48\xf9\x68\ +-\x49\x81\xf5\x45\xa3\x0d\x09\x35\x7d\xf6\x89\xde\x5a\x27\x13\x3c\ +-\x5e\xf5\xbf\x04\x3c\x0a\x74\xfb\xb8\x9a\x01\x41\x5d\x93\x99\x20\ +-\x19\x96\x19\x61\x31\xfd\x02\x37\x92\x27\x5d\xb1\xca\xcf\x26\x67\ +-\x88\x36\xa3\xcd\x31\x82\x3e\xff\x44\x97\x55\xc9\x21\xc2\x22\x7f\ +-\x8d\x94\xb7\x77\x75\x5d\x5d\xbb\xe0\x8b\xca\x3e\xff\x75\x5d\x40\ +-\x46\x02\x8c\xce\x8e\x90\xb3\xfc\xb3\x10\x88\xf7\xbc\x5e\xf1\x83\ +-\xd2\x22\x71\xd0\x68\x5b\x8c\xc4\x7c\xa2\x4f\x52\x5e\xe3\xbe\x1a\ +-\x94\xc7\x81\x92\x8b\xfd\xbc\xcd\x01\x2b\x0e\x86\xf3\x02\x36\xb4\ +-\xc4\x45\xc1\x98\x1c\x49\x5e\x72\x04\xbd\xf1\x01\x90\x9b\xa5\x94\ +-\x8f\x4e\x28\x88\x5a\x61\xb4\x25\xe1\x80\x29\x00\xe7\x51\x5e\xe3\ +-\xbe\x5a\xa2\xfc\x4e\xc0\x39\xf5\xb7\xdc\x5e\x78\x7f\x8f\x29\x00\ +-\xe0\x9b\xe6\x4f\x2c\x94\x44\x47\x56\xfe\xbe\x9d\x42\xca\x5f\x8c\ +-\xcf\xb7\xbc\x61\x44\x19\xee\x70\xc5\x7c\xa2\xcf\xa3\x24\x3f\xea\ +-\xd3\x92\x3c\x65\x82\x44\xde\x04\x6c\x3b\xf5\xb9\xd5\x02\x61\x52\ +-\x5c\xc6\x50\xd2\xe2\x60\x72\xff\x88\x1a\xfc\xbb\x91\xf2\xbe\x03\ +-\x79\xca\xb8\xe2\x02\xeb\xeb\xe6\xe0\x3f\x17\x73\x06\xd0\x05\x8b\ +-\xa5\xb4\x0c\x3e\xe6\xbd\x53\x48\xf1\x5f\x2d\x76\xc6\xae\x3a\xd4\ +-\xb7\x15\x40\x00\x33\x07\xab\x91\x12\xba\xbb\x45\x08\xf9\xfb\xf1\ +-\xb9\x96\x57\x7b\xb3\x23\x4f\x4f\x31\x05\xc0\x4f\xde\xde\x2d\x17\ +-\x1c\x3a\xc1\x53\x2d\x76\xc2\xd7\x85\x25\xc8\xa4\xc4\xc1\xcc\x41\ +-\xe1\x3e\x96\xe4\x3a\x09\x8f\x97\xe4\x59\xde\x33\xdf\xf6\xdd\x63\ +-\x0a\x80\x46\x16\x95\xcb\x9b\x3a\x9d\x3c\xde\xd0\xc9\x08\x4f\xb8\ +-\x8f\x05\x9d\xc9\x4f\xf6\xad\xfd\xc3\x10\x17\x82\x7f\xab\x5e\xe5\ +-\x0f\xa5\x85\x62\xbb\xd1\xc6\x44\x12\xa6\x00\x04\xc8\xe2\xcd\xb2\ +-\xa8\xd9\xa3\xfe\xae\xd9\xf6\xff\xb7\x77\x37\x3d\x4d\x04\x61\x1c\ +-\xc0\xff\xcf\x4c\x09\x50\x8a\x21\x82\xd8\x42\x40\x88\xc1\x10\x09\ +-\x28\x95\x78\x20\x26\x86\x53\x23\x07\x8d\x9c\xf5\x13\x78\xf4\xa4\ +-\x37\x3f\x84\x31\x72\xd0\x18\xbd\x10\x3d\x18\xe2\x81\x83\x06\x0f\ +-\x36\xbe\x04\x4d\x14\xc3\x41\x13\x4b\xe2\xa1\x18\x15\xb5\x94\x76\ +-\xdf\xe6\x79\x3c\xd4\x78\x52\x23\xd2\x76\xd9\x3a\xbf\x0f\xb0\xf3\ +-\xec\x66\xe7\x9f\xd9\xdd\xd9\x19\x3a\x5d\x0a\x28\x22\xbb\x7a\x6c\ +-\x4f\x77\x42\x30\xb9\x6f\x47\x05\xc0\x1b\x00\xd7\xb4\x56\xd7\x0f\ +-\x25\xa9\xa6\xab\x42\x35\x2a\x1b\x00\x55\x70\xe3\xb9\x9c\xd9\xf4\ +-\x70\xf1\x73\x09\xc3\xbe\x69\xdc\x6b\xda\xda\x04\x64\x0e\x84\x3e\ +-\xec\x71\x41\x34\x0f\x31\xb3\xe3\x3d\xb1\x07\x76\x98\xbf\x3d\x0d\ +-\x7b\xb3\x86\x61\x31\x27\xc9\xf7\xeb\x7c\x69\xbd\xac\x66\xbe\x94\ +-\xd1\xd5\x88\x7f\x10\x4e\x0f\x73\x18\x5f\x00\x0c\x40\x8b\x44\x3c\ +-\x07\x57\xdf\x19\x1f\xa4\xaf\x75\xaf\xa0\x41\xd9\x00\xa8\x91\xd9\ +-\x67\x32\xc2\x06\x17\x4a\x01\x32\xdf\x9c\xc6\x09\x83\x63\x03\x82\ +-\xae\xfa\x4c\xf7\x65\x40\x1e\x13\xd1\x6d\x3f\xa6\xe6\x8e\x76\xd3\ +-\x5a\x3d\x1a\xfd\xdf\xd8\x00\xa8\x83\xbb\x2f\xe4\xe0\xba\xe0\xfc\ +-\x86\x83\x4c\xc1\x41\x4f\x94\x1f\x13\xd2\xbd\x82\xfe\x8e\x9a\x05\ +-\x40\x01\x42\xf7\x49\xf1\x82\xf1\xf4\xbd\x89\x01\xca\xd7\xaa\x21\ +-\xab\x22\xb2\x37\x62\x54\x5d\x5e\x94\x44\xbc\x9d\xcf\x39\xbe\x9a\ +-\x29\x7a\x32\x5a\xf4\xa8\x35\x4a\xa3\x83\x23\xbd\x82\xbe\xea\x06\ +-\xc0\x4b\x00\x0b\xc4\xbc\x60\x3e\xc4\xb2\x13\x13\xe4\x57\xf3\xe0\ +-\xd6\x9f\xd9\x00\x08\xd9\xcd\x15\x49\x99\x32\x9f\x2d\x79\x74\xb2\ +-\xec\xd3\xc8\x86\x83\x8e\xd0\x5f\xb3\xfd\x46\x73\xac\x32\x11\x68\ +-\x1b\x7b\x24\x04\xa8\x74\xf8\x2c\x89\x3c\x12\xad\x1f\xa6\x53\xf4\ +-\xb1\x6a\x05\x5a\x5b\x66\x03\x60\x87\xb9\xf5\x44\x76\xe9\x16\x9c\ +-\x72\x03\x3e\xe1\x06\xea\xf0\xa6\x8f\xbe\x82\x83\x04\x87\x3c\x4a\ +-\x20\x54\xa6\x00\xef\x4d\xfc\x75\x21\x0e\x80\x15\x01\x5e\x91\x60\ +-\x99\x48\x3d\x4d\x94\xb0\x34\x34\x44\x6e\xed\xaa\xb4\xb6\xca\x06\ +-\x40\x04\x5c\x5d\x92\xb8\x12\x4c\x13\xf3\x71\x03\x1a\xf3\x03\xf4\ +-\xbb\x86\x3a\xcb\x3e\xda\x3c\x53\x9f\xff\x39\xf6\x77\x0a\x46\x93\ +-\xbf\xe8\xfc\x84\x3c\x44\x72\x02\xca\x11\xe1\x9d\xb0\xbc\x86\xd2\ +-\xcb\x85\x14\xde\x4e\x11\x05\xf5\xa8\xcd\xfa\x77\x36\x00\x22\xee\ +-\x4a\x56\xba\x5b\x9a\x31\x49\xe0\xb1\x00\xaa\x4f\x8c\x24\x0d\x63\ +-\x8f\x2f\xd8\x6d\x98\xda\x03\x96\x36\x16\x34\x31\x93\x06\x80\x80\ +-\xa1\x01\x90\x61\x90\xf9\xd1\x9f\x35\x01\x5a\xfd\x5c\xf6\x90\x63\ +-\x0a\xac\x35\x02\x05\xf1\x34\xa1\xac\x15\x8a\xe9\x5e\x99\x8f\x37\ +-\x21\x0f\x91\x4f\xac\x64\x4d\x10\x5b\xdd\x70\xb1\x3a\x35\x48\x4e\ +-\x38\x67\x6e\x55\xc3\x77\x15\x65\xab\x07\x70\xac\xd6\x54\x00\x00\ +-\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\ +-\x00\x00\x05\xc2\ +-\x89\ +-\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\ +-\x00\x00\x18\x00\x00\x00\x18\x08\x06\x00\x00\x00\xe0\x77\x3d\xf8\ +-\x00\x00\x00\x04\x73\x42\x49\x54\x08\x08\x08\x08\x7c\x08\x64\x88\ +-\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0d\xd7\x00\x00\x0d\xd7\ +-\x01\x42\x28\x9b\x78\x00\x00\x00\x19\x74\x45\x58\x74\x53\x6f\x66\ +-\x74\x77\x61\x72\x65\x00\x77\x77\x77\x2e\x69\x6e\x6b\x73\x63\x61\ +-\x70\x65\x2e\x6f\x72\x67\x9b\xee\x3c\x1a\x00\x00\x05\x3f\x49\x44\ +-\x41\x54\x48\x89\x7d\x95\x69\x6c\x54\x55\x14\x80\xbf\xfb\xe6\x31\ +-\xe5\xcd\x74\x1e\xb5\x53\x5a\x9c\x96\xca\x5a\x01\x31\x85\x52\x11\ +-\xab\x60\x52\x40\xc3\x22\x1a\x14\x89\x10\x23\xb8\x41\x5c\xb0\x44\ +-\x82\x06\x7f\x68\xa2\xd1\xa8\x08\x08\x46\x04\x11\x90\x62\xaa\x56\ +-\x45\x5a\x4b\x54\x44\x04\x62\x44\x96\x41\x0d\x4b\x2d\x52\x5a\xa0\ +-\x0b\xd0\x5a\x3a\x9d\x4e\x3b\xed\xbc\x77\xfc\x51\x66\xa4\x1b\xe7\ +-\xd7\xbb\x27\xe7\x7e\xe7\x9d\xf5\x2a\xae\x23\xf9\xc7\x24\xa7\x35\ +-\x2c\x2f\x36\xb7\x33\xa9\xd5\x52\x66\xb8\x5d\x9c\x22\x8a\x9c\xc1\ +-\x52\x99\xe4\xa2\x54\x90\xef\x2c\xb4\x9d\xe3\x53\xd5\xf9\xde\x18\ +-\xaa\x27\xe5\xe6\x23\x72\x7b\x30\x2c\xf9\xf5\x21\x35\x5c\xa4\x43\ +-\xe7\x33\x85\x54\x13\xaa\x02\x30\x34\x51\xf0\xba\x63\xe6\x36\x4a\ +-\x7d\xad\x94\x5a\x3e\xf6\x46\x55\xd1\x95\xa5\x75\x55\x7c\x7d\xdc\ +-\xca\x13\x5b\x0e\x04\xc3\xff\xc3\x5d\x7d\xc0\xa1\x41\xa2\x4b\xc8\ +-\x4e\x13\x3c\x7d\xff\xb7\x17\x11\x0d\x91\x39\xb6\x6d\xff\xe5\xaf\ +-\x8a\xcc\xba\x6e\x04\x1b\x0e\xd9\x3b\x83\xad\xcc\x6a\x0c\x34\x71\ +-\xba\xac\x8c\xfa\xfa\x3a\x0c\x09\xa2\x22\x21\x3c\xf1\x06\x8b\xe6\ +-\xcd\xc4\x65\xc4\x01\x50\x71\xbe\x96\x55\x9f\x7c\xc3\x1b\xcb\x16\ +-\x60\xc6\xbb\xae\x89\x86\xa5\x59\x3e\xc7\xda\xa8\x42\x8f\x7e\x6c\ +-\xfa\x5d\x56\x9d\xa8\x6c\x98\xb5\xef\xc7\x9d\x94\x9d\xfc\x13\xdb\ +-\xb6\xbb\xa5\xee\xb1\xd9\x53\x71\x3a\x75\x36\x7c\x56\x42\x61\xc9\ +-\x7e\x22\x96\xd5\x3d\x23\xc2\xea\x92\x93\x91\xd0\x8c\x51\xfa\xa6\ +-\x58\x8a\xb6\x1f\x95\x09\x87\x4f\x55\xe4\x6d\xfd\xf0\x1d\x4a\x8f\ +-\x1f\xeb\x11\x1e\x95\x40\xa0\x99\x82\xa2\xbd\x3d\xc1\x63\x4e\x4c\ +-\x43\xad\xd9\xf6\xbb\x64\xc7\x1c\x5c\xb8\xdc\x54\xb0\xe3\xb3\x4f\ +-\x54\xb8\x35\x04\x40\x3f\xd3\xcd\x73\x8f\xdd\xcf\xca\x15\x4f\xf7\ +-\xea\x28\x2a\xaa\x4b\x9b\xd8\x02\xfb\xca\x35\x77\x63\x84\x02\x00\ +-\xfd\x48\xb5\xa4\x7f\x5a\xb8\x3b\x3d\x18\x0c\x00\x60\x9a\x1e\x3e\ +-\x7e\xeb\x05\x7c\x29\x5e\x02\xc1\x50\xaf\xe0\x74\x5f\x32\x79\x4f\ +-\xcc\xc6\xe3\x76\x11\x08\x86\xb8\x12\x08\xe2\xf1\xc4\x73\xfa\x8a\ +-\x9b\x36\x0b\xea\x42\x0c\x2b\xf0\x4b\xb6\xae\x61\x3f\x70\xe0\xd0\ +-\x1f\xb1\x6e\x7a\x6a\xee\xbd\xf8\x52\xbc\xbd\x82\x75\xdd\xc1\xe2\ +-\xf9\x33\x79\x68\xfa\x44\x76\xfd\x72\x98\xf7\xb7\xec\xa0\xf2\xc2\ +-\xc5\xab\xd1\x28\xd2\x87\x64\x90\x3b\x6d\x36\xde\xfe\x03\x08\xb4\ +-\xc9\x2b\x3a\xa2\xa6\x55\xd5\xfe\x1b\x03\x4c\x1c\x3f\xba\x47\xf0\ +-\x84\xac\x91\xb8\xdd\x06\x71\xce\x3e\x8c\xbe\x79\x10\x8b\x56\xbc\ +-\xcf\x99\xca\xea\x4e\x36\x22\x42\xe5\x99\xbf\xf9\x62\xeb\x07\x2c\ +-\x78\xe6\x25\x5a\x5c\x9e\x1c\xfd\xd7\x72\xfb\xae\xe6\x50\x47\x2a\ +-\x34\x4d\x91\xd8\xcf\xec\x74\x29\x35\x25\x89\x25\x0b\x1f\xe0\xce\ +-\xec\x5b\xa8\x6b\x68\xe4\xed\x8f\x8a\xd9\x7d\xc0\x8f\x5c\x1d\x92\ +-\x21\xe9\x3e\x32\x47\x0e\xa6\xb6\xae\x81\x83\xfe\x53\x88\x08\xa1\ +-\x60\x13\x47\x7f\xdb\x47\xe2\xb4\x99\x37\xe8\x83\x93\x94\xee\xd0\ +-\x1d\x58\x11\x0b\xdb\x16\x82\xcd\x21\x4c\x4f\xc7\x98\xba\x8d\xbe\ +-\xe4\xaf\x59\x8e\xa6\x69\x14\x14\xed\x65\x73\xe1\x0f\xb4\xb4\x84\ +-\x01\xb8\x29\x2d\x85\xbc\x85\xb3\xb9\x2d\x33\x03\x80\xcb\xcd\x8a\ +-\xd5\xf9\x7b\xd8\xff\x53\x31\x00\xe5\x65\x27\x69\xbf\x67\x46\x1f\ +-\xdd\x67\x12\x49\xf7\x25\x73\xf6\x5c\x0d\x00\x3b\x76\x1f\x64\xec\ +-\x1d\x53\x68\x0a\x43\xff\x78\x07\xa5\xa5\xff\xf0\x79\xe1\x37\x9c\ +-\xab\xea\xc8\xb3\x61\xc4\xf1\xf8\x9c\x7b\x99\x33\x63\x12\xb6\x6d\ +-\x63\x59\x36\x0e\x87\x86\xd7\x2d\xe4\x4e\x9a\x10\x73\xd0\x50\x7f\ +-\x09\xa4\x63\xd0\xaa\x73\xb2\x46\x65\x44\x1d\x6c\x2a\x28\x61\xf0\ +-\xe1\x72\xdc\x66\x3f\xaa\xcf\x9d\xa5\xfe\x72\x6d\xac\x80\x53\x26\ +-\x66\xf1\xec\xa3\xf7\x91\x74\x43\x3f\x7e\x3d\x72\x82\xb5\x5b\xbe\ +-\xe5\xe3\xb7\x97\x62\xc6\xbb\xd0\x80\x9c\x61\x06\x4a\x53\x88\x2d\ +-\x44\x22\xed\xc4\xe9\x12\xd6\x41\x95\xcf\x9d\x79\x77\xc6\xae\xbd\ +-\x87\x68\x68\x6c\x42\x44\x28\x3f\x7d\xb2\x53\x1d\xfa\x0f\xf0\x91\ +-\x3b\xfd\x21\x46\x8f\x18\x4a\xbc\x2b\xcc\xb2\x37\x37\x72\xd0\x7f\ +-\xaa\x5b\x23\x04\x9b\x1a\x11\xbb\xa3\x36\xa6\xc7\xcd\xd4\xe1\xea\ +-\x67\x4d\x90\x92\xc4\x04\x0f\xeb\x5e\x7b\x86\x31\xa3\x47\x74\x9a\ +-\x9c\xa4\x14\x1f\x53\x66\xcc\x61\xde\x93\x4b\xa9\x39\x77\x96\x8b\ +-\xf5\xcd\xfc\x75\xbe\xb5\x47\x38\xc0\x81\x43\xc7\xaf\x69\x0e\x2f\ +-\x0a\x29\xd6\x2d\xb4\x9d\x3a\xf6\x9a\x41\x03\x07\x38\x96\x3e\xbf\ +-\x98\xa3\x15\xad\x84\x5a\x42\xb8\x0c\x17\xce\xbe\x06\x15\x67\x4a\ +-\xd9\xb6\xfe\x5d\x1a\xea\x2f\x71\xcb\x98\xf1\x9c\xae\xeb\x71\xc3\ +-\x53\x75\xb1\x8e\xcd\x85\xdf\xc7\xce\xb9\x77\x64\xda\x0e\xb4\x62\ +-\x7d\x7c\xaa\x3a\xef\xaf\xb2\xb6\x02\x4f\x24\x18\x42\x9c\x61\xe0\ +-\xec\x6b\x00\x10\x6e\x0d\xf1\xd5\xb6\xf5\x3d\x02\xa3\xb2\xc7\x5f\ +-\x49\xcb\xbf\x35\x6c\xff\x76\x4f\x6c\xf2\x93\xbd\x09\x4c\xce\xc9\ +-\xda\x96\x99\xa6\x2e\xe8\x00\x9a\xad\xbd\x6a\x69\xf6\xc3\x5e\x17\ +-\x9e\x21\x89\xc2\x99\xfa\x8e\xbf\x8c\xbe\x07\xd7\x93\xf7\xd6\x6e\ +-\xec\x74\x36\x3d\x6e\x5e\x7f\x71\x41\x73\x52\x42\xe2\x0a\xb8\xba\ +-\xec\xc6\x0c\x54\x55\x4a\x93\xb9\x80\x35\xb2\xbf\x10\xa7\x77\x86\ +-\x68\x0e\x07\xd9\x77\xe6\x62\xb8\xdc\xf4\x26\xba\xc3\xc1\xd4\x89\ +-\x59\x6c\x5d\xb9\xcc\x1e\x95\x91\xfe\x48\xf6\x20\x55\x03\x5d\x1e\ +-\x1c\x7f\xb5\xb5\x04\x61\x75\x9b\x85\x76\xbc\x56\x51\x56\xd3\x42\ +-\xd1\x17\x5b\x98\x3c\xfd\x41\xbc\xc9\x03\x00\x68\x6f\x0b\xb3\xff\ +-\xa7\x62\x5a\x5b\x5a\x18\xe8\x35\x18\x98\xec\x26\xdd\x97\xc2\xb8\ +-\x5b\x87\x91\x60\xc6\xdb\x40\x5e\x56\xaa\x63\x5d\x94\xd9\xad\x62\ +-\xfe\xaa\xc8\x2c\x41\x6d\x6f\xb7\xf0\xec\x3a\xa5\xba\xef\xe3\x68\ +-\x54\x0a\x26\x0f\xb3\x71\x3b\x63\xaa\x80\x88\xcc\x1f\x97\xa6\x7f\ +-\xd7\xc9\xae\xeb\xc5\xac\x54\xbd\x48\x69\xda\x50\x5d\xb1\x4e\xeb\ +-\x05\x3e\xd4\x2b\x4c\x1d\x1e\x83\xdb\x08\xf9\x76\xbb\x36\xa2\x2b\ +-\xbc\xc7\x08\xae\x95\x2f\x4f\xc8\x98\x40\xb3\xfd\x72\x30\xac\x72\ +-\xdb\x2c\x65\x86\x2d\x9c\x11\x1b\x75\xcf\x70\xfb\x1f\xc3\xa9\xca\ +-\x94\x48\x89\x26\x5a\x51\x66\x9a\xba\xd0\x1b\xe3\x3f\x12\xae\x2a\ +-\x58\xfd\xf2\x8c\xf2\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\ +-\x82\ +-" +- +-qt_resource_name = b"\ +-\x00\x05\ +-\x00\x6f\xa6\x53\ +-\x00\x69\ +-\x00\x63\x00\x6f\x00\x6e\x00\x73\ +-\x00\x17\ +-\x0b\xce\x1a\xe7\ +-\x00\x71\ +-\x00\x75\x00\x74\x00\x65\x00\x62\x00\x72\x00\x6f\x00\x77\x00\x73\x00\x65\x00\x72\x00\x2d\x00\x31\x00\x32\x00\x38\x00\x78\x00\x31\ +-\x00\x32\x00\x38\x00\x2e\x00\x70\x00\x6e\x00\x67\ +-\x00\x17\ +-\x07\xc8\x36\xe7\ +-\x00\x71\ +-\x00\x75\x00\x74\x00\x65\x00\x62\x00\x72\x00\x6f\x00\x77\x00\x73\x00\x65\x00\x72\x00\x2d\x00\x35\x00\x31\x00\x32\x00\x78\x00\x35\ +-\x00\x31\x00\x32\x00\x2e\x00\x70\x00\x6e\x00\x67\ +-\x00\x15\ +-\x02\x0a\xc7\x87\ +-\x00\x71\ +-\x00\x75\x00\x74\x00\x65\x00\x62\x00\x72\x00\x6f\x00\x77\x00\x73\x00\x65\x00\x72\x00\x2d\x00\x33\x00\x32\x00\x78\x00\x33\x00\x32\ +-\x00\x2e\x00\x70\x00\x6e\x00\x67\ +-\x00\x15\ +-\x02\xf8\xd9\xc7\ +-\x00\x71\ +-\x00\x75\x00\x74\x00\x65\x00\x62\x00\x72\x00\x6f\x00\x77\x00\x73\x00\x65\x00\x72\x00\x2d\x00\x36\x00\x34\x00\x78\x00\x36\x00\x34\ +-\x00\x2e\x00\x70\x00\x6e\x00\x67\ +-\x00\x15\ +-\x02\x26\xc3\x07\ +-\x00\x71\ +-\x00\x75\x00\x74\x00\x65\x00\x62\x00\x72\x00\x6f\x00\x77\x00\x73\x00\x65\x00\x72\x00\x2d\x00\x31\x00\x36\x00\x78\x00\x31\x00\x36\ +-\x00\x2e\x00\x70\x00\x6e\x00\x67\ +-\x00\x15\ +-\x02\x14\xc5\x47\ +-\x00\x71\ +-\x00\x75\x00\x74\x00\x65\x00\x62\x00\x72\x00\x6f\x00\x77\x00\x73\x00\x65\x00\x72\x00\x2d\x00\x34\x00\x38\x00\x78\x00\x34\x00\x38\ +-\x00\x2e\x00\x70\x00\x6e\x00\x67\ +-\x00\x15\ +-\x02\xa6\xd3\x07\ +-\x00\x71\ +-\x00\x75\x00\x74\x00\x65\x00\x62\x00\x72\x00\x6f\x00\x77\x00\x73\x00\x65\x00\x72\x00\x2d\x00\x39\x00\x36\x00\x78\x00\x39\x00\x36\ +-\x00\x2e\x00\x70\x00\x6e\x00\x67\ +-\x00\x17\ +-\x0a\x1f\xbe\xe7\ +-\x00\x71\ +-\x00\x75\x00\x74\x00\x65\x00\x62\x00\x72\x00\x6f\x00\x77\x00\x73\x00\x65\x00\x72\x00\x2d\x00\x32\x00\x35\x00\x36\x00\x78\x00\x32\ +-\x00\x35\x00\x36\x00\x2e\x00\x70\x00\x6e\x00\x67\ +-\x00\x15\ +-\x02\x38\xc1\xc7\ +-\x00\x71\ +-\x00\x75\x00\x74\x00\x65\x00\x62\x00\x72\x00\x6f\x00\x77\x00\x73\x00\x65\x00\x72\x00\x2d\x00\x32\x00\x34\x00\x78\x00\x32\x00\x34\ +-\x00\x2e\x00\x70\x00\x6e\x00\x67\ +-" +- +-qt_resource_struct = b"\ +-\x00\x00\x00\x00\x00\x02\x00\x00\x00\x01\x00\x00\x00\x01\ +-\x00\x00\x00\x00\x00\x02\x00\x00\x00\x09\x00\x00\x00\x02\ +-\x00\x00\x00\x78\x00\x00\x00\x00\x00\x01\x00\x00\xbd\xb9\ +-\x00\x00\x01\x08\x00\x00\x00\x00\x00\x01\x00\x00\xda\x06\ +-\x00\x00\x00\xd8\x00\x00\x00\x00\x00\x01\x00\x00\xd6\x51\ +-\x00\x00\x01\x9c\x00\x00\x00\x00\x00\x01\x00\x01\x49\xa3\ +-\x00\x00\x01\x38\x00\x00\x00\x00\x00\x01\x00\x00\xe6\x0b\ +-\x00\x00\x00\xa8\x00\x00\x00\x00\x00\x01\x00\x00\xc5\x97\ +-\x00\x00\x00\x44\x00\x00\x00\x00\x00\x01\x00\x00\x23\x02\ +-\x00\x00\x01\x68\x00\x00\x00\x00\x00\x01\x00\x00\xff\xe4\ +-\x00\x00\x00\x10\x00\x00\x00\x00\x00\x01\x00\x00\x00\x00\ +-" +- +-def qInitResources(): +- QtCore.qRegisterResourceData(0x01, qt_resource_struct, qt_resource_name, qt_resource_data) +- +-def qCleanupResources(): +- QtCore.qUnregisterResourceData(0x01, qt_resource_struct, qt_resource_name, qt_resource_data) +- +-qInitResources() +diff --git a/qutebrowser/utils/utils.py b/qutebrowser/utils/utils.py +index 9c68932f3..a28d662b3 100644 +--- a/qutebrowser/utils/utils.py ++++ b/qutebrowser/utils/utils.py +@@ -784,30 +784,13 @@ def mimetype_extension(mimetype: str) -> Optional[str]: + + This mostly delegates to Python's mimetypes.guess_extension(), but backports some + changes (via a simple override dict) which are missing from earlier Python versions. +- Most likely, this can be dropped once the minimum Python version is raised to 3.7. ++ Most likely, this can be dropped once the minimum Python version is raised to 3.10. + """ + overrides = { ++ # Added in 3.10 ++ "application/x-hdf5": ".h5", + # Added around 3.8 + "application/manifest+json": ".webmanifest", +- "application/x-hdf5": ".h5", +- +- # Added in Python 3.7 +- "application/wasm": ".wasm", +- +- # Wrong values for Python 3.6 +- # https://bugs.python.org/issue1043134 +- # https://github.com/python/cpython/pull/14375 +- "application/octet-stream": ".bin", # not .a +- "application/postscript": ".ps", # not .ai +- "application/vnd.ms-excel": ".xls", # not .xlb +- "application/vnd.ms-powerpoint": ".ppt", # not .pot +- "application/xml": ".xsl", # not .rdf +- "audio/mpeg": ".mp3", # not .mp2 +- "image/jpeg": ".jpg", # not .jpe +- "image/tiff": ".tiff", # not .tif +- "text/html": ".html", # not .htm +- "text/plain": ".txt", # not .bat +- "video/mpeg": ".mpeg", # not .m1v + } + if mimetype in overrides: + return overrides[mimetype] +diff --git a/requirements.txt b/requirements.txt +index 25c1bd98f..92364a87f 100644 +--- a/requirements.txt ++++ b/requirements.txt +@@ -2,17 +2,11 @@ + + adblock==0.5.2 + colorama==0.4.4 +-dataclasses==0.6 ; python_version<"3.7" + importlib-metadata==4.11.3 ; python_version=="3.7.*" +-importlib-resources==5.6.0 ; python_version=="3.7.*" or python_version=="3.8.*" +-Jinja2==3.1.1 ; python_version>="3.7" +-MarkupSafe==2.1.1 ; python_version>="3.7" ++importlib-resources==5.7.1 ; python_version=="3.7.*" or python_version=="3.8.*" ++Jinja2==3.1.1 ++MarkupSafe==2.1.1 + Pygments==2.11.2 + PyYAML==6.0 +-typing_extensions==4.1.1 ; python_version<"3.8" +-zipp==3.7.0 ; python_version>="3.7" +-importlib-resources<5.6.0 ; python_version=="3.6.*" +-importlib-metadata<4.9 ; python_version=="3.6.*" +-zipp<3.7 ; python_version=="3.6.*" +-MarkupSafe<2.1.0 ; python_version=="3.6.*" +-Jinja2<3.1.0 ; python_version=="3.6.*" ++typing_extensions==4.2.0 ; python_version<"3.8" ++zipp==3.8.0 +diff --git a/scripts/asciidoc2html.py b/scripts/asciidoc2html.py +index afbc4d575..ba8493247 100755 +--- a/scripts/asciidoc2html.py ++++ b/scripts/asciidoc2html.py +@@ -199,7 +199,11 @@ class AsciiDoc: + continue + self._build_website_file(item_path.parent, item_path.name) + +- copy = {'icons': 'icons', 'doc/img': 'doc/img', 'www/media': 'media/'} ++ copy = { ++ 'qutebrowser/icons': 'icons', ++ 'doc/img': 'doc/img', ++ 'www/media': 'media/', ++ } + + for src, dest in copy.items(): + full_src = REPO_ROOT / src +diff --git a/scripts/dev/changelog_urls.json b/scripts/dev/changelog_urls.json +index 0de1d68d9..34b74eeb0 100644 +--- a/scripts/dev/changelog_urls.json ++++ b/scripts/dev/changelog_urls.json +@@ -27,7 +27,6 @@ + "hypothesis": "https://hypothesis.readthedocs.io/en/latest/changes.html", + "mypy": "https://mypy-lang.blogspot.com/", + "types-PyYAML": "https://github.com/python/typeshed/commits/master/stubs/PyYAML", +- "types-dataclasses": "https://github.com/python/typeshed/commits/master/stubs/dataclasses", + "pytest": "https://docs.pytest.org/en/latest/changelog.html", + "iniconfig": "https://github.com/RonnyPfannschmidt/iniconfig/blob/master/CHANGELOG", + "tox": "https://tox.readthedocs.io/en/latest/changelog.html", +@@ -140,7 +139,6 @@ + "importlib-resources": "https://importlib-resources.readthedocs.io/en/latest/history.html", + "importlib-metadata": "https://github.com/python/importlib_metadata/blob/main/CHANGES.rst", + "zipp": "https://github.com/jaraco/zipp/blob/main/CHANGES.rst", +- "dataclasses": "https://github.com/ericvsmith/dataclasses#release-history", + "pip": "https://pip.pypa.io/en/stable/news/", + "wheel": "https://wheel.readthedocs.io/en/stable/news.html", + "setuptools": "https://setuptools.readthedocs.io/en/latest/history.html", +@@ -154,8 +152,10 @@ + "readme-renderer": "https://github.com/pypa/readme_renderer/blob/main/CHANGES.rst", + "requests-toolbelt": "https://github.com/requests/toolbelt/blob/master/HISTORY.rst", + "rfc3986": "https://rfc3986.readthedocs.io/en/latest/release-notes/index.html", +- "tqdm": "https://tqdm.github.io/releases/", + "twine": "https://twine.readthedocs.io/en/stable/changelog.html", + "webencodings": "https://github.com/gsnedders/python-webencodings/commits/master", +- "PyJWT": "https://github.com/jpadilla/pyjwt/blob/master/CHANGELOG.rst" ++ "PyJWT": "https://github.com/jpadilla/pyjwt/blob/master/CHANGELOG.rst", ++ "commonmark": "https://github.com/readthedocs/commonmark.py/blob/master/CHANGELOG.md", ++ "rich": "https://github.com/Textualize/rich/blob/master/CHANGELOG.md", ++ "ply": "https://github.com/dabeaz/ply/blob/master/CHANGES" + } +diff --git a/scripts/dev/check_coverage.py b/scripts/dev/check_coverage.py +index c66cb3e8d..8f1d2df2b 100644 +--- a/scripts/dev/check_coverage.py ++++ b/scripts/dev/check_coverage.py +@@ -333,7 +333,7 @@ def main_check(): + subprocess.run([sys.executable, '-m', 'coverage', 'report', + '--show-missing', '--include', filters], check=True) + print() +- print("To debug this, run 'tox -e py36-pyqt515-cov' " ++ print("To debug this, run 'tox -e py39-pyqt515-cov' " + "(replace Python/Qt versions based on your system) locally and check " + "htmlcov/index.html") + print("or check https://codecov.io/github/qutebrowser/qutebrowser") +@@ -353,7 +353,7 @@ def main_check_all(): + tests. + + This runs pytest with the used executable, so check_coverage.py should be +- called with something like ./.tox/py36/bin/python. ++ called with something like ./.tox/py39/bin/python. + """ + for test_file, src_file in PERFECT_FILES: + if test_file is None: +diff --git a/scripts/dev/gen_resources.py b/scripts/dev/gen_resources.py +deleted file mode 100644 +index efa6c6a3d..000000000 +--- a/scripts/dev/gen_resources.py ++++ /dev/null +@@ -1,30 +0,0 @@ +-#!/usr/bin/env python3 +-# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et: +- +-# Copyright 2014-2021 Florian Bruhin (The-Compiler) +- +-# this file is part of qutebrowser. +-# +-# qutebrowser is free software: you can redistribute it and/or modify +-# it under the terms of the gnu general public license as published by +-# the free software foundation, either version 3 of the license, or +-# (at your option) any later version. +-# +-# qutebrowser is distributed in the hope that it will be useful, +-# but without any warranty; without even the implied warranty of +-# merchantability or fitness for a particular purpose. see the +-# gnu general public license for more details. +-# +-# you should have received a copy of the gnu general public license +-# along with qutebrowser. If not, see . +- +-"""Generate Qt resources based on source files.""" +- +-import subprocess +-import pathlib +- +-ROOT = pathlib.Path(__file__).parents[2] +-OUTPUT = ROOT / 'qutebrowser' / 'resources.py' +-INPUT = ROOT / 'misc' / 'qutebrowser.rcc' +- +-subprocess.run(['pyrcc5', '-o', str(OUTPUT), str(INPUT)], check=True) +diff --git a/scripts/dev/misc_checks.py b/scripts/dev/misc_checks.py +index 05fdb7932..908daad4d 100644 +--- a/scripts/dev/misc_checks.py ++++ b/scripts/dev/misc_checks.py +@@ -50,7 +50,7 @@ def _get_files( + filenames = subprocess.run( + ['git', 'ls-files', '--cached', '--others', '--exclude-standard', '-z'], + stdout=subprocess.PIPE, +- universal_newlines=True, ++ text=True, + check=True, + ) + all_ignored = ignored or [] +diff --git a/scripts/dev/recompile_requirements.py b/scripts/dev/recompile_requirements.py +index f8337b21f..365f9a51e 100644 +--- a/scripts/dev/recompile_requirements.py ++++ b/scripts/dev/recompile_requirements.py +@@ -239,6 +239,9 @@ def extract_requirement_name(path: pathlib.Path) -> str: + + e.g. "pylint" from "misc/requirements/requirements-pylint.txt" + """ ++ if path == pathlib.Path("requirements.txt"): ++ return "qutebrowser" ++ + prefix = "requirements-" + assert path.suffix == ".txt", path + assert path.stem.startswith(prefix), path +@@ -419,7 +422,7 @@ def test_tox(): + list_proc = subprocess.run([venv_python, '-m', 'tox', '--listenvs'], + check=True, + stdout=subprocess.PIPE, +- universal_newlines=True) ++ text=True) + environments = list_proc.stdout.strip().split('\n') + for env in environments: + with utils.gha_group('tox for {}'.format(env)): +diff --git a/scripts/dev/run_pylint_on_tests.py b/scripts/dev/run_pylint_on_tests.py +index a44828a85..28c6e32c9 100644 +--- a/scripts/dev/run_pylint_on_tests.py ++++ b/scripts/dev/run_pylint_on_tests.py +@@ -64,9 +64,6 @@ def main(): + 'import-error', + # tests/helpers imports + 'wrong-import-order', +- # https://github.com/PyCQA/pylint/issues/6036 +- # https://github.com/PyCQA/pylint/issues/6037 +- 'unnecessary-ellipsis', + ] + + toxinidir = sys.argv[1] +diff --git a/scripts/link_pyqt.py b/scripts/link_pyqt.py +index 158cc145d..0ec7f2556 100644 +--- a/scripts/link_pyqt.py ++++ b/scripts/link_pyqt.py +@@ -44,13 +44,13 @@ def run_py(executable, *code): + f.write('\n'.join(code)) + cmd = [executable, filename] + try: +- ret = subprocess.run(cmd, universal_newlines=True, check=True, ++ ret = subprocess.run(cmd, text=True, check=True, + stdout=subprocess.PIPE).stdout + finally: + os.remove(filename) + else: + cmd = [executable, '-c', '\n'.join(code)] +- ret = subprocess.run(cmd, universal_newlines=True, check=True, ++ ret = subprocess.run(cmd, text=True, check=True, + stdout=subprocess.PIPE).stdout + return ret.rstrip() + +diff --git a/scripts/mkvenv.py b/scripts/mkvenv.py +index 7f6920bb8..737ea145d 100755 +--- a/scripts/mkvenv.py ++++ b/scripts/mkvenv.py +@@ -147,7 +147,7 @@ def run_venv( + return subprocess.run( + [str(venv_dir / subdir / executable)] + [str(arg) for arg in args], + check=True, +- universal_newlines=capture_output or capture_error, ++ text=capture_output or capture_error, + stdout=subprocess.PIPE if capture_output else None, + stderr=subprocess.PIPE if capture_error else None, + env=proc_env, +diff --git a/scripts/setupcommon.py b/scripts/setupcommon.py +index b1d246044..bd549d7cc 100644 +--- a/scripts/setupcommon.py ++++ b/scripts/setupcommon.py +@@ -43,7 +43,7 @@ def _call_git(gitpath, *args): + return subprocess.run( + ['git'] + list(args), + cwd=gitpath, check=True, +- stdout=subprocess.PIPE).stdout.decode('UTF-8').strip() ++ stdout=subprocess.PIPE, text=True).stdout.strip() + + + def _git_str(): +diff --git a/setup.py b/setup.py +index 4c4bd3243..cb088e04c 100755 +--- a/setup.py ++++ b/setup.py +@@ -72,9 +72,8 @@ try: + ['qutebrowser = qutebrowser.qutebrowser:main']}, + zip_safe=True, + install_requires=['jinja2', 'PyYAML', +- 'dataclasses; python_version < "3.7"', + 'importlib_resources>=1.1.0; python_version < "3.9"'], +- python_requires='>=3.6', ++ python_requires='>=3.7', + name='qutebrowser', + version=_get_constant('version'), + description=_get_constant('description'), +@@ -96,7 +95,6 @@ try: + 'Operating System :: MacOS', + 'Operating System :: POSIX :: BSD', + 'Programming Language :: Python :: 3', +- 'Programming Language :: Python :: 3.6', + 'Programming Language :: Python :: 3.7', + 'Programming Language :: Python :: 3.8', + 'Programming Language :: Python :: 3.9', +diff --git a/tests/end2end/conftest.py b/tests/end2end/conftest.py +index 14ac6f395..5241ab4c3 100644 +--- a/tests/end2end/conftest.py ++++ b/tests/end2end/conftest.py +@@ -55,8 +55,8 @@ def pytest_unconfigure(config): + if config.getoption('--qute-profile-subprocs'): + stats = pstats.Stats() + for fn in pathlib.Path('prof').iterdir(): +- stats.add((pathlib.Path('prof') / fn)) +- stats.dump_stats((pathlib.Path('prof') / 'combined.pstats')) ++ stats.add(pathlib.Path('prof') / fn) ++ stats.dump_stats(pathlib.Path('prof') / 'combined.pstats') + + + def _check_version(op_str, running_version, version_str, as_hex=False): +diff --git a/tests/end2end/features/conftest.py b/tests/end2end/features/conftest.py +index da42ac6e1..c08eb2e0b 100644 +--- a/tests/end2end/features/conftest.py ++++ b/tests/end2end/features/conftest.py +@@ -214,12 +214,15 @@ def open_path(quteproc, server, path): + path = path.replace('(port)', str(server.port)) + + new_tab = False ++ related_tab = False + new_bg_tab = False + new_window = False + private = False + as_url = False + wait = True + ++ related_tab_suffix = ' in a new related tab' ++ related_background_tab_suffix = ' in a new related background tab' + new_tab_suffix = ' in a new tab' + new_bg_tab_suffix = ' in a new background tab' + new_window_suffix = ' in a new window' +@@ -231,6 +234,14 @@ def open_path(quteproc, server, path): + if path.endswith(new_tab_suffix): + path = path[:-len(new_tab_suffix)] + new_tab = True ++ elif path.endswith(related_tab_suffix): ++ path = path[:-len(related_tab_suffix)] ++ new_tab = True ++ related_tab = True ++ elif path.endswith(related_background_tab_suffix): ++ path = path[:-len(related_background_tab_suffix)] ++ new_bg_tab = True ++ related_tab = True + elif path.endswith(new_bg_tab_suffix): + path = path[:-len(new_bg_tab_suffix)] + new_bg_tab = True +@@ -249,9 +260,9 @@ def open_path(quteproc, server, path): + else: + break + +- quteproc.open_path(path, new_tab=new_tab, new_bg_tab=new_bg_tab, +- new_window=new_window, private=private, as_url=as_url, +- wait=wait) ++ quteproc.open_path(path, related_tab=related_tab, new_tab=new_tab, ++ new_bg_tab=new_bg_tab, new_window=new_window, ++ private=private, as_url=as_url, wait=wait) + + + @bdd.when(bdd.parsers.parse("I set {opt} to {value}")) +diff --git a/tests/end2end/fixtures/quteprocess.py b/tests/end2end/fixtures/quteprocess.py +index ab8f28d26..0254d8990 100644 +--- a/tests/end2end/fixtures/quteprocess.py ++++ b/tests/end2end/fixtures/quteprocess.py +@@ -792,16 +792,17 @@ class QuteProc(testprocess.Process): + self.set_setting(opt, old_value) + + def open_path(self, path, *, new_tab=False, new_bg_tab=False, +- new_window=False, private=False, as_url=False, port=None, +- https=False, wait=True): ++ related_tab=False, new_window=False, private=False, ++ as_url=False, port=None, https=False, wait=True): + """Open the given path on the local webserver in qutebrowser.""" + url = self.path_to_url(path, port=port, https=https) + self.open_url(url, new_tab=new_tab, new_bg_tab=new_bg_tab, +- new_window=new_window, private=private, as_url=as_url, +- wait=wait) ++ related_tab=related_tab, new_window=new_window, ++ private=private, as_url=as_url, wait=wait) + + def open_url(self, url, *, new_tab=False, new_bg_tab=False, +- new_window=False, private=False, as_url=False, wait=True): ++ related_tab=False, new_window=False, private=False, ++ as_url=False, wait=True): + """Open the given url in qutebrowser.""" + if sum(1 for opt in [new_tab, new_bg_tab, new_window, private, as_url] + if opt) > 1: +@@ -811,9 +812,15 @@ class QuteProc(testprocess.Process): + self.send_cmd(url, invalid=True) + line = None + elif new_tab: +- line = self.send_cmd(':open -t ' + url) ++ if related_tab: ++ line = self.send_cmd(':open -t -r ' + url) ++ else: ++ line = self.send_cmd(':open -t ' + url) + elif new_bg_tab: +- line = self.send_cmd(':open -b ' + url) ++ if related_tab: ++ line = self.send_cmd(':open -b -r ' + url) ++ else: ++ line = self.send_cmd(':open -b ' + url) + elif new_window: + line = self.send_cmd(':open -w ' + url) + elif private: +diff --git a/tests/end2end/fixtures/webserver_sub.py b/tests/end2end/fixtures/webserver_sub.py +index b4964d973..392fbe43f 100644 +--- a/tests/end2end/fixtures/webserver_sub.py ++++ b/tests/end2end/fixtures/webserver_sub.py +@@ -231,7 +231,7 @@ def drip(): + + def generate_bytes(): + for _ in range(numbytes): +- yield "*".encode('utf-8') ++ yield b"*" + time.sleep(pause) + + response = flask.Response(generate_bytes(), headers={ +@@ -294,7 +294,7 @@ def view_user_agent(): + def favicon(): + # WORKAROUND for https://github.com/PyCQA/pylint/issues/5783 + # pylint: disable-next=no-member,useless-suppression +- icon_dir = END2END_DIR.parents[1] / 'icons' ++ icon_dir = END2END_DIR.parents[1] / 'qutebrowser' / 'icons' + return flask.send_from_directory( + icon_dir, 'qutebrowser.ico', mimetype='image/vnd.microsoft.icon') + +diff --git a/tests/end2end/test_hints_html.py b/tests/end2end/test_hints_html.py +index f1cda97fe..5af09649f 100644 +--- a/tests/end2end/test_hints_html.py ++++ b/tests/end2end/test_hints_html.py +@@ -59,7 +59,7 @@ def _parse_file(test_name): + with file_path.open('r', encoding='utf-8') as html: + soup = bs4.BeautifulSoup(html, 'html.parser') + +- comment = str(soup.find(text=lambda text: isinstance(text, bs4.Comment))) ++ comment = str(soup.find(string=lambda text: isinstance(text, bs4.Comment))) + + if comment is None: + raise InvalidFile(test_name, "no comment found") +diff --git a/tests/end2end/test_invocations.py b/tests/end2end/test_invocations.py +index 667a4ee72..5a34d0357 100644 +--- a/tests/end2end/test_invocations.py ++++ b/tests/end2end/test_invocations.py +@@ -336,7 +336,7 @@ def test_command_on_start(request, quteproc_new): + quteproc_new.wait_for_quit() + + +-@pytest.mark.parametrize('python', ['python2', 'python3.5']) ++@pytest.mark.parametrize('python', ['python2', 'python3.6']) + def test_launching_with_old_python(python): + try: + proc = subprocess.run( +@@ -346,7 +346,7 @@ def test_launching_with_old_python(python): + except FileNotFoundError: + pytest.skip(f"{python} not found") + assert proc.returncode == 1 +- error = "At least Python 3.6.1 is required to run qutebrowser" ++ error = "At least Python 3.7 is required to run qutebrowser" + assert proc.stderr.decode('ascii').startswith(error) + + +diff --git a/tests/helpers/stubs.py b/tests/helpers/stubs.py +index 6998958b8..b71e68384 100644 +--- a/tests/helpers/stubs.py ++++ b/tests/helpers/stubs.py +@@ -346,6 +346,7 @@ class FakeCommand: + hide: bool = False + debug: bool = False + deprecated: bool = False ++ tree_tab: bool = False + completion: Any = None + maxsplit: int = None + takes_count: Callable[[], bool] = lambda: False +diff --git a/tests/unit/config/test_configtypes.py b/tests/unit/config/test_configtypes.py +index ef3007f71..c34efce54 100644 +--- a/tests/unit/config/test_configtypes.py ++++ b/tests/unit/config/test_configtypes.py +@@ -19,7 +19,6 @@ + """Tests for qutebrowser.config.configtypes.""" + + import re +-import sys + import json + import math + import warnings +@@ -1501,12 +1500,8 @@ class TestRegex: + pytest.param('(' * 500, id='too many parens'), + pytest.param(r'foo\Xbar', id='invalid escape X'), + pytest.param(r'foo\Cbar', id='invalid escape C'), +- pytest.param(r'[[]]', id='nested set', marks=pytest.mark.skipif( +- sys.hexversion < 0x03070000, +- reason="Warning was added in Python 3.7")), +- pytest.param(r'[a||b]', id='set operation', marks=pytest.mark.skipif( +- sys.hexversion < 0x03070000, +- reason="Warning was added in Python 3.7")), ++ pytest.param(r'[[]]', id='nested set'), ++ pytest.param(r'[a||b]', id='set operation'), + ]) + def test_to_py_invalid(self, klass, val): + with pytest.raises(configexc.ValidationError): +diff --git a/tests/unit/misc/test_checkpyver.py b/tests/unit/misc/test_checkpyver.py +index 52e022a44..35f8cfeec 100644 +--- a/tests/unit/misc/test_checkpyver.py ++++ b/tests/unit/misc/test_checkpyver.py +@@ -28,19 +28,18 @@ import pytest + from qutebrowser.misc import checkpyver + + +-TEXT = (r"At least Python 3.6.1 is required to run qutebrowser, but it's " ++TEXT = (r"At least Python 3.7 is required to run qutebrowser, but it's " + r"running with \d+\.\d+\.\d+.") + + + @pytest.mark.not_frozen +-@pytest.mark.parametrize('python', ['python2', 'python3.5']) ++@pytest.mark.parametrize('python', ['python2', 'python3.6']) + def test_old_python(python): + """Run checkpyver with old python versions.""" + try: + proc = subprocess.run( + [python, checkpyver.__file__, '--no-err-windows'], +- stdout=subprocess.PIPE, +- stderr=subprocess.PIPE, ++ capture_output=True, + check=False) + except FileNotFoundError: + pytest.skip(f"{python} not found") +diff --git a/tests/unit/misc/test_notree.py b/tests/unit/misc/test_notree.py +new file mode 100644 +index 000000000..fe07b01ec +--- /dev/null ++++ b/tests/unit/misc/test_notree.py +@@ -0,0 +1,310 @@ ++# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et: ++ ++# Copyright 2019 Florian Bruhin (The-Compiler) ++# ++# This file is part of qutebrowser. ++# ++# qutebrowser is free software: you can redistribute it and/or modify ++# it under the terms of the GNU General Public License as published by ++# the Free Software Foundation, either version 3 of the License, or ++# (at your option) any later version. ++# ++# qutebrowser is distributed in the hope that it will be useful, ++# but WITHOUT ANY WARRANTY; without even the implied warranty of ++# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++# GNU General Public License for more details. ++# ++# You should have received a copy of the GNU General Public License ++# along with qutebrowser. If not, see . ++"""Tests for misc.notree library.""" ++import pytest ++ ++from qutebrowser.misc.notree import TreeError, Node, TraverseOrder ++ ++ ++@pytest.fixture ++def tree(): ++ """Return an example tree. ++ ++ n1 ++ ├─n2 ++ │ ├─n4 ++ │ └─n5 ++ └─n3 ++ ├─n6 ++ │ ├─n7 ++ │ ├─n8 ++ │ └─n9 ++ │ └─n10 ++ └─n11 ++ """ ++ # these are actually used because they appear in expected strings ++ n1 = Node('n1') ++ n2 = Node('n2', n1) ++ n4 = Node('n4', n2) ++ n5 = Node('n5', n2) ++ n3 = Node('n3', n1) ++ n6 = Node('n6', n3) ++ n7 = Node('n7', n6) ++ n8 = Node('n8', n6) ++ n9 = Node('n9', n6) ++ n10 = Node('n10', n9) ++ n11 = Node('n11', n3) ++ return n1, n2, n3, n4, n5, n6, n7, n8, n9, n10, n11 ++ ++ ++@pytest.fixture ++def node(tree): ++ return tree[0] ++ ++ ++def test_creation(): ++ node = Node('foo') ++ assert node.value == 'foo' ++ ++ child = Node('bar', node) ++ assert child.parent == node ++ assert node.children == (child, ) ++ ++ ++def test_attach_parent(): ++ n1 = Node('n1', None, []) ++ print(n1.children) ++ n2 = Node('n2', n1) ++ n3 = Node('n3') ++ ++ n2.parent = n3 ++ assert n2.parent == n3 ++ assert n3.children == (n2, ) ++ assert n1.children == () ++ ++ ++def test_duplicate_child(): ++ p = Node('n1') ++ try: ++ c1 = Node('c1', p) ++ c2 = Node('c2', p) ++ p.children = [c1, c1, c2] ++ raise AssertionError("Can add duplicate child") ++ except TreeError: ++ pass ++ finally: ++ if len(p.children) == 3: ++ raise AssertionError("Can add duplicate child") ++ ++ ++def test_replace_parent(): ++ p1 = Node('foo') ++ p2 = Node('bar') ++ _ = Node('_', p2) ++ c = Node('baz', p1) ++ c.parent = p2 ++ assert c.parent is p2 ++ assert c not in p1.children ++ assert c in p2.children ++ ++ ++def test_replace_children(tree): ++ n2 = tree[1] ++ n3 = tree[2] ++ n6 = tree[5] ++ n11 = tree[10] ++ n3.children = [n11] ++ n2.children = (n6, ) + n2.children ++ assert n6.parent is n2 ++ assert n6 in n2.children ++ assert n11.parent is n3 ++ assert n11 in n3.children ++ assert n6 not in n3.children ++ assert len(n3.children) == 1 ++ ++ ++def test_promote_to_first(tree): ++ n1 = tree[0] ++ n3 = tree[2] ++ n6 = tree[5] ++ assert n6.parent is n3 ++ assert n3.parent is n1 ++ n6.promote(to='first') ++ assert n6.parent is n1 ++ assert n1.children[0] is n6 ++ ++ ++def test_promote_to_last(tree): ++ n1 = tree[0] ++ n3 = tree[2] ++ n6 = tree[5] ++ assert n6.parent is n3 ++ assert n3.parent is n1 ++ n6.promote(to='last') ++ assert n6.parent is n1 ++ assert n1.children[-1] is n6 ++ ++ ++def test_promote_to_prev(tree): ++ n1 = tree[0] ++ n3 = tree[2] ++ n6 = tree[5] ++ assert n6.parent is n3 ++ assert n3.parent is n1 ++ assert n1.children[1] is n3 ++ n6.promote(to='prev') ++ assert n6.parent is n1 ++ assert n1.children[1] is n6 ++ ++ ++def test_promote_to_next(tree): ++ n1 = tree[0] ++ n3 = tree[2] ++ n6 = tree[5] ++ assert n6.parent is n3 ++ assert n3.parent is n1 ++ assert n1.children[1] is n3 ++ n6.promote(to='next') ++ assert n6.parent is n1 ++ assert n1.children[2] is n6 ++ ++ ++def test_demote_to_first(tree): ++ n11 = tree[10] ++ n6 = tree[5] ++ assert n11.parent is n6.parent ++ parent = n11.parent ++ assert parent.children.index(n11) == parent.children.index(n6) + 1 ++ n11.demote(to='first') ++ assert n11.parent is n6 ++ assert n6.children[0] is n11 ++ ++ ++def test_demote_to_last(tree): ++ n11 = tree[10] ++ n6 = tree[5] ++ assert n11.parent is n6.parent ++ parent = n11.parent ++ assert parent.children.index(n11) == parent.children.index(n6) + 1 ++ n11.demote(to='last') ++ assert n11.parent is n6 ++ assert n6.children[-1] is n11 ++ ++ ++def test_traverse(node): ++ len_traverse = len(list(node.traverse())) ++ len_render = len(node.render()) ++ assert len_traverse == len_render ++ ++ ++def test_traverse_postorder(tree): ++ n1, n2, n3, n4, n5, n6, n7, n8, n9, n10, n11 = tree ++ actual = list(n1.traverse(TraverseOrder.POST)) ++ print('\n'.join([str(n) for n in actual])) ++ assert actual == [n4, n5, n2, n7, n8, n10, n9, n6, n11, n3, n1] ++ ++ ++def test_traverse_postorder_r(tree): ++ n1, n2, n3, n4, n5, n6, n7, n8, n9, n10, n11 = tree ++ actual = list(n1.traverse(TraverseOrder.POST_R)) ++ print('\n'.join([str(n) for n in actual])) ++ assert actual == [n11, n10, n9, n8, n7, n6, n3, n5, n4, n2, n1] ++ ++ ++def test_render_tree(node): ++ expected = [ ++ 'n1', ++ '├─n2', ++ '│ ├─n4', ++ '│ └─n5', ++ '└─n3', ++ ' ├─n6', ++ ' │ ├─n7', ++ ' │ ├─n8', ++ ' │ └─n9', ++ ' │ └─n10', ++ ' └─n11' ++ ] ++ result = [char + str(n) for char, n in node.render()] ++ print('\n'.join(result)) ++ assert expected == result ++ ++ ++def test_uid(node): ++ uids = set() ++ for n in node.traverse(): ++ assert n not in uids ++ uids.add(n.uid) ++ # pylint: disable=unused-variable ++ n1 = Node('n1') ++ n2 = Node('n2', n1) ++ n4 = Node('n4', n2) # noqa: F841 ++ n5 = Node('n5', n2) # noqa: F841 ++ n3 = Node('n3', n1) ++ n6 = Node('n6', n3) ++ n7 = Node('n7', n6) # noqa: F841 ++ n8 = Node('n8', n6) # noqa: F841 ++ n9 = Node('n9', n6) ++ n10 = Node('n10', n9) # noqa: F841 ++ n11 = Node('n11', n3) ++ # pylint: enable=unused-variable ++ for n in n1.traverse(): ++ assert n not in uids ++ uids.add(n.uid) ++ ++ n11_uid = n11.uid ++ assert n1.get_descendent_by_uid(n11_uid) is n11 ++ ++ with pytest.raises(TreeError) as _: ++ assert node.get_descendent_by_uid(n11_uid) is n11 ++ ++ ++def test_collapsed(node): ++ pre_collapsed_traverse = list(node.traverse()) ++ to_collapse = node.children[1] ++ ++ # collapse ++ to_collapse.collapsed = True ++ assert to_collapse.collapsed is True ++ for n in node.traverse(render_collapsed=False): ++ assert to_collapse not in n.path[:-1] ++ ++ assert list(to_collapse.traverse(render_collapsed=False)) == [to_collapse] ++ ++ assert list(node.traverse()) == pre_collapsed_traverse ++ ++ expected = [ ++ 'n1', ++ '├─n2', ++ '│ ├─n4', ++ '│ └─n5', ++ '└─n3' ++ ] ++ result = [char + str(n) for char, n in node.render()] ++ print('\n'.join(result)) ++ assert expected == result ++ ++ # uncollapse ++ to_collapse.collapsed = False ++ ++ assert any(n for n in node.traverse(render_collapsed=False) if to_collapse ++ in n.path[:-1]) ++ ++ ++def test_memoization(node): ++ assert node._Node__modified is True ++ node.render() ++ assert node._Node__modified is False ++ ++ node.children[0].parent = None ++ assert node._Node__modified is True ++ node.render() ++ assert node._Node__modified is False ++ ++ n2 = Node('ntest', parent=node) ++ assert node._Node__modified is True ++ assert n2._Node__modified is True ++ node.render() ++ assert node._Node__modified is False ++ ++ node.children[0].children[1].parent = None ++ assert node._Node__modified is True ++ assert node.children[0]._Node__modified is True ++ node.render() ++ assert node._Node__modified is False +diff --git a/tests/unit/misc/userscripts/test_qute_lastpass.py b/tests/unit/misc/userscripts/test_qute_lastpass.py +index 24272a048..ebd9a7591 100644 +--- a/tests/unit/misc/userscripts/test_qute_lastpass.py ++++ b/tests/unit/misc/userscripts/test_qute_lastpass.py +@@ -122,7 +122,7 @@ class TestQuteLastPassComponents: + + subprocess_mock.assert_called_once_with( + ['lpass', 'show', '-x', '-j', '-G', '\\bexample\\.com'], +- stdout=ANY, stderr=ANY) ++ capture_output=True) + + def test_pass_returns_candidates(self, subprocess_mock): + """Test if pass_ returns expected lpass site entry.""" +@@ -263,7 +263,7 @@ class TestQuteLastPassMain: + + subprocess_mock.assert_has_calls([ + call(['lpass', 'show', '-x', '-j', '-G', '\\bwww\\.example\\.com'], +- stdout=ANY, stderr=ANY), ++ capture_output=True), + call(['rofi', '-dmenu'], + input=b'12345 | www.example.com | https://www.example.com | fake@fake.com\n23456 | Sites/www.example.com | https://www.example.com | john.doe@fake.com', + stdout=ANY) +@@ -328,13 +328,13 @@ class TestQuteLastPassMain: + + subprocess_mock.assert_has_calls([ + call(['lpass', 'show', '-x', '-j', '-G', '\\bwww\\.example\\.com'], +- stdout=ANY, stderr=ANY), ++ capture_output=True), + call(['lpass', 'show', '-x', '-j', '-G', '\\bexample\\.com'], +- stdout=ANY, stderr=ANY), ++ capture_output=True), + call(['lpass', 'show', '-x', '-j', '-G', '\\bwwwexample'], +- stdout=ANY, stderr=ANY), ++ capture_output=True), + call(['lpass', 'show', '-x', '-j', '-G', '\\bexample'], +- stdout=ANY, stderr=ANY), ++ capture_output=True), + call(['rofi', '-dmenu'], + input=b'12345 | www.example.com | https://www.example.com | fake@fake.com\n23456 | Sites/www.example.com | https://www.example.com | john.doe@fake.com\n345 | example.com | https://example.com | joe.doe@fake.com\n456 | Sites/example.com | http://example.com | jane.doe@fake.com', + stdout=ANY) +diff --git a/tests/unit/utils/test_standarddir.py b/tests/unit/utils/test_standarddir.py +index f5d8204a4..0ca635ae2 100644 +--- a/tests/unit/utils/test_standarddir.py ++++ b/tests/unit/utils/test_standarddir.py +@@ -498,7 +498,7 @@ def test_no_qapplication(qapp, tmpdir, monkeypatch): + monkeypatch.setenv('HOME', str(home_dir)) + + proc = subprocess.run([sys.executable, str(pyfile)] + sys.path, +- universal_newlines=True, ++ text=True, + check=True, + stdout=subprocess.PIPE) + sub_locations = json.loads(proc.stdout) +diff --git a/tests/unit/utils/test_utils.py b/tests/unit/utils/test_utils.py +index 330ef3b96..4620c2198 100644 +--- a/tests/unit/utils/test_utils.py ++++ b/tests/unit/utils/test_utils.py +@@ -931,7 +931,7 @@ def test_parse_duration_hypothesis(duration): + + @pytest.mark.parametrize('mimetype, extension', [ + ('application/pdf', '.pdf'), # handled by Python +- ('text/plain', '.txt'), # wrong in Python 3.6, overridden ++ ('text/plain', '.txt'), # was wrong in Python 3.6, handled now + ('application/manifest+json', '.webmanifest'), # newer + ('text/xul', '.xul'), # strict=False + ('doesnot/exist', None), +diff --git a/tox.ini b/tox.ini +index 370adbc9e..0990b1b4a 100644 +--- a/tox.ini ++++ b/tox.ini +@@ -18,7 +18,6 @@ passenv = PYTHON DISPLAY XAUTHORITY HOME USERNAME USER CI XDG_* QUTE_* DOCKER QT + basepython = + py: {env:PYTHON:python3} + py3: {env:PYTHON:python3} +- py36: {env:PYTHON:python3.6} + py37: {env:PYTHON:python3.7} + py38: {env:PYTHON:python3.8} + py39: {env:PYTHON:python3.9} diff --git a/patches/webcord/fix-reading-config.patch b/patches/webcord/fix-reading-config.patch new file mode 100644 index 0000000..92e89ca --- /dev/null +++ b/patches/webcord/fix-reading-config.patch @@ -0,0 +1,14 @@ +diff --git a/sources/code/main/modules/config.ts b/sources/code/main/modules/config.ts +index caf51df..41faabe 100644 +--- a/sources/code/main/modules/config.ts ++++ b/sources/code/main/modules/config.ts +@@ -158,6 +158,9 @@ class Config { + #read(): unknown { + const encodedData = readFileSync(this.#path+this.#pathExtension); + let decodedData = encodedData.toString(); ++ if (decodedData === "") ++ return {}; ++ + if(this.#pathExtension === FileExt.Encrypted) + decodedData = safeStorage.decryptString(encodedData); + return JSON.parse(decodedData); diff --git a/pkgs/cargo-checkmate.nix b/pkgs/cargo-checkmate.nix index a85ff80..0620667 100644 --- a/pkgs/cargo-checkmate.nix +++ b/pkgs/cargo-checkmate.nix @@ -1,12 +1,11 @@ -{ - lib, - rustPlatform, - fetchFromGitHub, - pkg-config, - openssl, - zlib, - stdenv, - Security ? null, +{ lib +, rustPlatform +, fetchFromGitHub +, pkg-config +, openssl +, zlib +, stdenv +, Security ? null }: rustPlatform.buildRustPackage rec { @@ -23,7 +22,9 @@ rustPlatform.buildRustPackage rec { cargoSha256 = "sha256-hOB84u55ishahIFSqBnqccqH3OlC9J8mCYzsd23jTyA="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.isDarwin [ Security ]; + buildInputs = [ openssl ] ++ lib.optionals stdenv.isDarwin [ + Security + ]; meta = with lib; { description = "Check all the things."; diff --git a/pkgs/default.nix b/pkgs/default.nix index b702886..ec52a1c 100644 --- a/pkgs/default.nix +++ b/pkgs/default.nix @@ -1,14 +1,8 @@ # Custom packages, that can be defined similarly to ones from nixpkgs # You can build them using 'nix build .#example' or (legacy) 'nix-build -A example' -{ pkgs, inputs }: -rec { +{ pkgs, inputs }: { cargo-checkmate = pkgs.callPackage ./cargo-checkmate.nix { }; - lipsum = pkgs.callPackage ./lipsum.nix { }; + lipsum = pkgs.callPackage ./lipsum.nix { inherit inputs; }; emmet-cli = pkgs.callPackage ./emmet-cli.nix { }; - material-wifi-icons = pkgs.callPackage ./material-wifi-icons.nix { }; - gnome-pass-search-provider = pkgs.callPackage ./gnome-pass-search-provider.nix { }; - factorio-headless = pkgs.callPackage ./factorio-headless { - inherit (pkgs.unstable) factorio-headless; - }; } diff --git a/pkgs/emmet-cli.nix b/pkgs/emmet-cli.nix index 043aff6..c7fce2e 100644 --- a/pkgs/emmet-cli.nix +++ b/pkgs/emmet-cli.nix @@ -1,7 +1,6 @@ -{ - lib, - buildNpmPackage, - fetchFromGitHub, +{ lib +, buildNpmPackage +, fetchFromGitHub }: buildNpmPackage rec { diff --git a/pkgs/factorio-headless/default.nix b/pkgs/factorio-headless/default.nix deleted file mode 100644 index 8d81f1d..0000000 --- a/pkgs/factorio-headless/default.nix +++ /dev/null @@ -1,10 +0,0 @@ -{ factorio-headless, pkgs }: - -factorio-headless.overrideAttrs (_: rec { - version = "2.0.47"; - src = pkgs.fetchurl { - name = "factorio_headless_x64-${version}.tar.xz"; - url = "https://www.factorio.com/get-download/${version}/headless/linux64"; - hash = "sha256-8PMgx3YWpHlCJ+tjenC1VxCPMUGkYzJ2WTIgp2j0miY="; - }; -}) diff --git a/pkgs/factorio-headless/update.sh b/pkgs/factorio-headless/update.sh deleted file mode 100755 index 2f57612..0000000 --- a/pkgs/factorio-headless/update.sh +++ /dev/null @@ -1,14 +0,0 @@ -#!/bin/sh - -set -xe - -cd "$(dirname $0)" - -current_version="$(rg '^.*?version\s*=\s*"(.+)".*?$' --replace '$1' ./default.nix)" -current_hash="$(rg '^.*?hash\s*=\s*"(.+)".*?$' --replace '$1' ./default.nix)" - -new_version="$(curl https://factorio.com/api/latest-releases | jq -r .stable.headless)" -new_hash="$(nix-hash --to-sri --type sha256 $(nix-prefetch-url --type sha256 https://www.factorio.com/get-download/${new_version}/headless/linux64))" - -sd --fixed-strings "$current_version" "$new_version" ./default.nix -sd --fixed-strings "$current_hash" "$new_hash" ./default.nix diff --git a/pkgs/gnome-pass-search-provider.nix b/pkgs/gnome-pass-search-provider.nix deleted file mode 100644 index ab2e94a..0000000 --- a/pkgs/gnome-pass-search-provider.nix +++ /dev/null @@ -1,63 +0,0 @@ -{ - stdenv, - fetchFromGitHub, - python3Packages, - wrapGAppsHook, - gtk3, - gobject-introspection, -}: - -let - inherit (python3Packages) - dbus-python - pygobject3 - fuzzywuzzy - levenshtein - ; -in - -stdenv.mkDerivation rec { - pname = "gnome-pass-search-provider"; - version = "1.4.0"; - - src = fetchFromGitHub { - owner = "jle64"; - repo = "gnome-pass-search-provider"; - rev = version; - hash = "sha256-PDR8fbDoT8IkHiTopQp0zd4DQg7JlacA6NdKYKYmrWw="; - }; - - nativeBuildInputs = [ - python3Packages.wrapPython - wrapGAppsHook - ]; - - propagatedBuildInputs = [ - dbus-python - pygobject3 - fuzzywuzzy - levenshtein - - gtk3 - gobject-introspection - ]; - - env = { - LIBDIR = builtins.placeholder "out" + "/lib"; - DATADIR = builtins.placeholder "out" + "/share"; - }; - - postPatch = '' - substituteInPlace conf/org.gnome.Pass.SearchProvider.service.{dbus,systemd} \ - --replace-fail "/usr/lib" "$LIBDIR" - ''; - - installPhase = '' - bash ./install.sh - ''; - - postFixup = '' - makeWrapperArgs=( "''${gappsWrapperArgs[@]}" ) - wrapPythonProgramsIn "$out/lib" "$out $propagatedBuildInputs" - ''; -} diff --git a/pkgs/lipsum.nix b/pkgs/lipsum.nix index de1b75a..e1dabe5 100644 --- a/pkgs/lipsum.nix +++ b/pkgs/lipsum.nix @@ -1,28 +1,19 @@ -{ - stdenv, - fetchFromGitHub, - pkg-config, - vala, - wrapGAppsHook, -}: -stdenv.mkDerivation rec { +{ pkgs, inputs }: +pkgs.stdenv.mkDerivation rec { pname = "lipsum"; version = "0.0.1"; - src = fetchFromGitHub { - owner = "hannenz"; - repo = "lipsum"; - rev = "0fb31e6ede10fbd78d7652f5fb21670cddd8e3ed"; - hash = "sha256-a6uv0tJulN9cAGWxvQr8B0PUJEY8Rx4e759xzS66Xlo="; - }; + src = inputs.lipsum; - nativeBuildInputs = [ + nativeBuildInputs = with pkgs; [ pkg-config vala wrapGAppsHook ]; - makeFlags = [ "PRG=${pname}" ]; + makeFlags = [ + "PRG=${pname}" + ]; installPhase = '' install -Dm 755 "$pname" "$out/bin/$pname" @@ -30,3 +21,4 @@ stdenv.mkDerivation rec { glib-compile-schemas "$out/share/glib-2.0/schemas/" ''; } + diff --git a/pkgs/material-wifi-icons.nix b/pkgs/material-wifi-icons.nix deleted file mode 100644 index c8b0dcc..0000000 --- a/pkgs/material-wifi-icons.nix +++ /dev/null @@ -1,16 +0,0 @@ -{ stdenv, fetchFromGitHub }: -stdenv.mkDerivation rec { - pname = "material-wifi-icons"; - version = "0.0.1"; - - src = fetchFromGitHub { - owner = "dcousens"; - repo = "material-wifi-icons"; - rev = "2daf6b3d96d65beb2a3e37a9a53556aab3826d97"; - hash = "sha256-KykU5J7SdpBDG+6rkD//XeHd+6pK3qabe+88RduhwKc="; - }; - - installPhase = '' - install -D material-wifi.ttf $out/share/fonts/${pname} - ''; -} diff --git a/scripts/_diffr b/scripts/_diffr old mode 100755 new mode 100644 diff --git a/scripts/_docker-block-external-connections b/scripts/_docker-block-external-connections deleted file mode 100755 index f22bc4f..0000000 --- a/scripts/_docker-block-external-connections +++ /dev/null @@ -1,33 +0,0 @@ -#!/bin/sh - -# Create the DOCKER-USER chain if it doesn't exist -iptables -N DOCKER-USER || true - -# Flush existing rules in the DOCKER-USER chain -iptables -F DOCKER-USER - -# Get all external network interfaces -interfaces=$( - ip -o -f inet addr show | - awk '{print $2}' | - grep -E '^(enp|eth|wlan|wlp)' | - sort -u -) - -for iface in $interfaces; do - # Allow traffic from LAN - iptables -A DOCKER-USER -i "$iface" -s 127.0.0.1 -j ACCEPT - iptables -A DOCKER-USER -i "$iface" -s 10.0.0.0/8 -j ACCEPT - iptables -A DOCKER-USER -i "$iface" -s 192.168.0.0/16 -j ACCEPT - - # Allow established and related connections - iptables -A DOCKER-USER -i "$iface" -m state --state RELATED,ESTABLISHED -j ACCEPT - - # Drop all other traffic - iptables -A DOCKER-USER -i "$iface" -j DROP - - echo "iptables rules have been set up for interface: $iface" -done - -# Return to the previous chain -iptables -A DOCKER-USER -j RETURN diff --git a/scripts/_sway_idle_toggle b/scripts/_sway_idle_toggle old mode 100755 new mode 100644 diff --git a/scripts/amd-fan-control b/scripts/amd-fan-control deleted file mode 100755 index 5b0d7a9..0000000 --- a/scripts/amd-fan-control +++ /dev/null @@ -1,86 +0,0 @@ -#!/usr/bin/env bash - -set -e - -DEVICE="$1" # eg: /sys/class/drm/card1/device -HWMON=$(echo "$DEVICE"/hwmon/hwmon*) - -exit() { - echo "Setting controll to auto" >&2 - echo 2 > "$HWMON/pwm1_enable" -} - -trap exit EXIT INT - -bail() { - echo "Error: $@" >&2 - echo "Exiting..." >&2 - exit 1 -} - -if ! [ -d "$HWMON" ]; then - bail "Invalid HWMON" -fi - -TEMP_INPUT="$HWMON/temp2_input" - -if ! [ -f $TEMP_INPUT ]; then - bail "Invalid TEMP_INPUT" -fi - -TEMP_MIN="$2" -TEMP_MAX="$3" - -if [ -z "$TEMP_MIN" ];then - bail "No minimum temperature provided" -fi - -if [ -z "$TEMP_MAX" ];then - bail "No maximum temperature provided" -fi - -PWM_MIN_PCT="$4" -PWM_MAX_PCT="$5" - -if [ -z "$PWM_MIN_PCT" ];then - bail "No minimum fan speed % not provided" -fi - -if [ -z "$PWM_MAX_PCT" ];then - bail "No maximum fan speed % not provided" -fi - -PWM_MIN="$(( $PWM_MIN_PCT * 255 / 100))" -PWM_MAX="$(( $PWM_MAX_PCT * 255 / 100))" - -echo "Running..." >&2 - -echo "TEMP_MIN=$TEMP_MIN°C" -echo "TEMP_MAX=$TEMP_MAX°C" -echo "FAN_MIN=$PWM_MIN_PCT%" -echo "FAN_MAX=$PWM_MAX_PCT%" - -echo 1 > "$HWMON/pwm1_enable" - -PREV=0 - -while true; do - TEMPERATURE_RAW=$(cat "$TEMP_INPUT") - TEMPERATURE="$(( $TEMPERATURE_RAW / 1000 ))" - # Remap from a number between 60_000..90_000 to 0..255 - PWM=$(( ($TEMPERATURE - $TEMP_MIN) * $PWM_MAX / ($TEMP_MAX - $TEMP_MIN) )) - - if [ "$PWM" -gt $PWM_MAX ]; then - PWM=$PWM_MAX - elif [ "$PWM" -lt $PWM_MIN ]; then - PWM=$PWM_MIN - fi - - AVG="$(( ($PWM * 20 + $PREV * 80) / 100 ))" - - echo "$AVG" - - echo "$AVG" > "$HWMON/pwm1" - PREV="$AVG" - sleep .1s -done diff --git a/scripts/bmenu b/scripts/bmenu old mode 100755 new mode 100644 index 8abad08..c793269 --- a/scripts/bmenu +++ b/scripts/bmenu @@ -8,10 +8,13 @@ if test "$argv[1]" = "run" test -n "$argv[2]" && set t "$argv[2]" || set t "terminal" + test -n "$i3SOCK" && set wrapper 'i3-msg exec --' + test -n "$SWAYSOCK" && set wrapper 'swaymsg exec --' + exec j4-dmenu-desktop \ --dmenu="bmenu start -p Iniciar:" \ --term "$t" \ - --i3-ipc \ + --wrapper="$wrapper" \ --no-generic end diff --git a/scripts/br b/scripts/br old mode 100755 new mode 100644 diff --git a/scripts/controller-battery b/scripts/controller-battery deleted file mode 100755 index b8ed4f2..0000000 --- a/scripts/controller-battery +++ /dev/null @@ -1,38 +0,0 @@ -#!/bin/sh - -set -e - -CONTROLLER=$(find /sys/class/power_supply -maxdepth 1 -name '*controller*' || true) - -if test -z "$CONTROLLER"; then - echo - exit 0 -fi - -CAPACITY=$(cat "$CONTROLLER/capacity") - -echo -n '󰊴' - -if test "$CAPACITY" -ge 90; then - echo '󰁹' -elif test "$CAPACITY" -ge 90; then - echo '󰂂' -elif test "$CAPACITY" -ge 80; then - echo '󰂁' -elif test "$CAPACITY" -ge 70; then - echo '󰂀' -elif test "$CAPACITY" -ge 60; then - echo '󰁿' -elif test "$CAPACITY" -ge 50; then - echo '󰁾' -elif test "$CAPACITY" -ge 40; then - echo '󰁽' -elif test "$CAPACITY" -ge 30; then - echo '󰁼' -elif test "$CAPACITY" -ge 20; then - echo '󰁻' -elif test "$CAPACITY" -ge 10; then - echo '󰁺' -else - echo '󰂎' -fi diff --git a/scripts/default.nix b/scripts/default.nix index 9b0b728..844308b 100644 --- a/scripts/default.nix +++ b/scripts/default.nix @@ -1,154 +1,57 @@ -( - final: prev: - let - lib = prev.lib; - - importScript = (_: path: import (path) { inherit (final) pkgs lib; }); - wrapScript = - name: text: runtimeInputs: - final.runCommand name - { - nativeBuildInputs = [ final.makeWrapper ]; - meta.mainProgram = name; - } - '' - mkdir -p $out/bin - cp ${text} $out/bin/${name} - wrapProgram $out/bin/${name} \ - --suffix PATH : ${lib.makeBinPath runtimeInputs} +(final: prev: +with prev; +let + import_script = (_: path: import (path) { inherit pkgs lib; }); + create_script = (name: text: runtimeInputs: + let + script_body = pkgs.writeTextFile { + inherit name; + executable = true; + text = '' + ${builtins.readFile text} ''; - createScripts = lib.mapAttrs (name: deps: wrapScript name ./${name} deps); + }; + in + (pkgs.writeShellApplication { + inherit name runtimeInputs; + text = ''exec ${script_body} "$@"''; + checkPhase = ""; + })); + create_scripts = + lib.mapAttrs (name: deps: create_script name ./${name} deps); - myPass = final.pass.withExtensions (ex: with ex; [ pass-otp ]); - in - with final; - createScripts { - amd-fan-control = [ bash ]; + pass = pkgs.pass.withExtensions (ex: with ex; [ + pass-otp + ]); +in +create_scripts + { br = [ ]; - bmenu = [ - bemenu - dhist - fish - j4-dmenu-desktop - jq - sway - ]; - down_meme = [ - wl-clipboard - yt-dlp - libnotify - ]; - wl-copy-file = [ - wl-clipboard - fish - ]; + bmenu = [ final.bemenu final.dhist fish j4-dmenu-desktop jq sway ]; + down_meme = [ wl-clipboard yt-dlp libnotify ]; + wl-copy-file = [ wl-clipboard fish ]; _diffr = [ diffr ]; - _thunar-terminal = [ terminal ]; - _sway_idle_toggle = [ swayidle ]; - kak-pager = [ - fish - _diffr - ]; - kak-man-pager = [ kak-pager ]; - helix-pager = [ - fish - _diffr - ]; - helix-man-pager = [ helix-pager ]; - musmenu = [ - mpc-cli - wdmenu - trash-cli - xdg-user-dirs - libnotify - sd - wl-clipboard - ]; - showkeys = [ ]; # This will not work unless programs.wshowkeys is enabled systemwide + _thunar-terminal = [ final.terminal ]; + _sway_idle_toggle = [ final.swayidle ]; + kak-pager = [ fish final._diffr ]; + kak-man-pager = [ final.kak-pager ]; + helix-pager = [ fish final._diffr ]; + helix-man-pager = [ final.helix-pager ]; + musmenu = [ mpc-cli final.wdmenu trash-cli xdg-user-dirs libnotify sd wl-clipboard ]; + showkeys = + [ ]; # This will not work unless programs.wshowkeys is enabled systemwide terminal = [ alacritty ]; playerctl-status = [ playerctl ]; - pass-export = [ - pass2csv - gnupg - sd - ]; - wpass = [ - wdmenu - ripgrep - fd - myPass - sd - wl-clipboard - wtype - ]; - screenshotsh = [ - capitaine-cursors - grim - slurp - jq - sway - wl-clipboard - xdg-user-dirs - ]; - volumesh = [ - pulseaudio - libnotify - ]; - pulse_sink = [ - pulseaudio - pamixer - wdmenu - ]; - color_picker = [ - grim - slurp - wl-clipboard - libnotify - imagemagick - ]; - dzadd = [ - procps - libnotify - wdmenu - jq - mpv - pqiv - python3Packages.deemix - mpc-cli - mpdDup - ]; - mpdDup = [ - mpc-cli - perl - ]; - readQrCode = [ - grim - zbar - wl-clipboard - ]; - git_clean_remote_deleted = [ - git - gnugrep - gawk - findutils - ]; - pint-fmt = [ ]; - powerplay-led-idle = [ - bash - libinput - libratbag - ]; - controller-battery = [ ]; - _docker-block-external-connections = [ - iptables - gawk - gnugrep - iproute2 - ]; - } - // lib.mapAttrs importScript { - wdmenu = ./wdmenu.nix; - wlauncher = ./wlauncher.nix; - _gpg-unlock = ./_gpg-unlock.nix; - } -) + wpass = [ final.wdmenu fd pass sd wl-clipboard wtype ]; + screenshotsh = + [ capitaine-cursors grim slurp jq sway wl-clipboard xdg-user-dirs ]; + volumesh = [ pulseaudio libnotify ]; + pulse_sink = [ pulseaudio pamixer final.wdmenu ]; + color_picker = [ grim slurp wl-clipboard libnotify imagemagick ]; + dzadd = [ procps libnotify final.wdmenu jq mpv pqiv python3Packages.deemix mpc-cli final.mpdDup ]; + mpdDup = [ mpc-cli perl ]; + } // lib.mapAttrs import_script { + wdmenu = ./wdmenu.nix; + wlauncher = ./wlauncher.nix; + _gpg-unlock = ./_gpg-unlock.nix; +}) diff --git a/scripts/git_clean_remote_deleted b/scripts/git_clean_remote_deleted deleted file mode 100755 index 99bc93d..0000000 --- a/scripts/git_clean_remote_deleted +++ /dev/null @@ -1,6 +0,0 @@ -#!/bin/sh - -git branch -vv \ -| grep ': gone]' \ -| awk '{print $1}' \ -| xargs git branch -D diff --git a/scripts/helix-pager b/scripts/helix-pager old mode 100755 new mode 100644 diff --git a/scripts/kak-pager b/scripts/kak-pager old mode 100755 new mode 100644 diff --git a/scripts/pass-export b/scripts/pass-export deleted file mode 100755 index 27596fc..0000000 --- a/scripts/pass-export +++ /dev/null @@ -1,13 +0,0 @@ -#!/bin/sh - -if test -z "$PASSWORD_STORE_DIR"; then - PASSWORD_STORE_DIR="$HOME/.password-store" -fi - -pass2csv "$PASSWORD_STORE_DIR" "$HOME/passwords.csv" \ - -f User '(user|login)(:\s*)?' \ - -f TOTP 'otpauth(:)?' \ - -f URL 'url(:\s*)?' - -# Fix TOTP format for keepass -sd '"//totp/.*?secret=(.*?)(&.*?)?"' '"$1"' "$HOME/passwords.csv" \ No newline at end of file diff --git a/scripts/pint-fmt b/scripts/pint-fmt deleted file mode 100755 index 4d84c88..0000000 --- a/scripts/pint-fmt +++ /dev/null @@ -1,7 +0,0 @@ -#!/bin/sh - -file="$(mktemp)" -cat - >"$file" -./vendor/bin/pint --quiet "$file" -cat "$file" -rm "$file" diff --git a/scripts/playerctl-status b/scripts/playerctl-status old mode 100755 new mode 100644 diff --git a/scripts/powerplay-led-idle b/scripts/powerplay-led-idle deleted file mode 100755 index 888abde..0000000 --- a/scripts/powerplay-led-idle +++ /dev/null @@ -1,79 +0,0 @@ -#!/usr/bin/env bash - -set -e - -# Constants -SECONDS_UNTIL_FADE=$(( 1 * 60)) -SECONDS_UNTIL_OFF=$(( 6 * 60)) - -COLOR_ON=ff0000 -COLOR_FADE=880000 -COLOR_OFF=000000 - -# Logging - -if [[ "$1" = "debug" ]]; then - echo "Running with debugging" >&2 - DEBUG="true" - - SECONDS_UNTIL_FADE=$(( 3 )) - SECONDS_UNTIL_OFF=$(( 5 )) -fi - -log() { - if [[ "$DEBUG" = "true" ]]; then - echo "$@" >&2 - fi -} - -# Implementation - -main() { - CURRENT_STATE="UNKNOWN" - LAST_POINTER_MOTION="$(date +%s)" - - if [ "$(ratbagctl list | wc -l)" -ne 1 ]; then - echo "Not exactly one device found, exiting..." - exit 1 - fi - - DEVICE="$(ratbagctl list | cut -d: -f1)" - - while true; do - while read line; do - LAST_POINTER_MOTION="$(date +%s)" - break - done < <( - timeout 5s \ - libinput debug-events \ - | grep POINTER_MOTION - ) - TIME_SINCE_LAST=$(( "$(date +%s)" - "$LAST_POINTER_MOTION" )) - log "Last pointer motion was $TIME_SINCE_LAST seconds ago" - if [ "$TIME_SINCE_LAST" -gt "$SECONDS_UNTIL_OFF" ]; then - setState OFF "$COLOR_OFF" - elif [ "$TIME_SINCE_LAST" -gt "$SECONDS_UNTIL_FADE" ]; then - setState FADE "$COLOR_FADE" - else - setState ON "$COLOR_ON" - fi - done -} - -setState() { - STATE="$1" - COLOR="$2" - MODE="$3" - - if [[ "$STATE" = "$CURRENT_STATE" ]]; then - log "Already in $STATE state" - return - fi - log "Changing state to $STATE" - CURRENT_STATE="$STATE" - - ratbagctl "$DEVICE" led 0 set mode on - ratbagctl "$DEVICE" led 0 set color "$COLOR" -} - -main diff --git a/scripts/pulse_sink b/scripts/pulse_sink old mode 100755 new mode 100644 diff --git a/scripts/readQrCode b/scripts/readQrCode deleted file mode 100755 index a86de59..0000000 --- a/scripts/readQrCode +++ /dev/null @@ -1,18 +0,0 @@ -#!/bin/sh - -set -o pipefail - -main() { - - if wl-paste | zbarimg -q --raw - | wl-copy - then - notify-send "Copied" "QrCode was copied to clipboard" - rm "$LOGFILE" - else - notify-send "Failed to read QrCode" "Log file is '$LOGFILE'" - fi - -} - -LOGFILE=$(mktemp /tmp/qrcode-XXXXXXXX.log) -main > "$LOGFILE" 2>&1 diff --git a/scripts/screenshotsh b/scripts/screenshotsh old mode 100755 new mode 100644 diff --git a/scripts/showkeys b/scripts/showkeys old mode 100755 new mode 100644 diff --git a/scripts/terminal b/scripts/terminal old mode 100755 new mode 100644 diff --git a/scripts/wdmenu.nix b/scripts/wdmenu.nix index 3505781..85fb6fc 100644 --- a/scripts/wdmenu.nix +++ b/scripts/wdmenu.nix @@ -1,4 +1,12 @@ { pkgs, ... }: +let + inherit (pkgs.uservars) dmenu; + available_menus = { + bmenu = "bmenu"; + rofi = "rofi -dmenu -sort"; + }; + menu_cmd = available_menus.${dmenu}; +in pkgs.writeShellScriptBin "wdmenu" '' - exec bmenu "$@" + exec ${menu_cmd} "$@" '' diff --git a/scripts/wfile-picker.nix b/scripts/wfile-picker.nix index d8ced8a..eb68752 100644 --- a/scripts/wfile-picker.nix +++ b/scripts/wfile-picker.nix @@ -1,6 +1,6 @@ { pkgs, ... }: let - inherit (config.my) dmenu; + inherit (pkgs.uservars) dmenu; available_menus = { bmenu = "bmenu run"; rofi = "rofi -show drun -sort"; diff --git a/scripts/wl-copy-file b/scripts/wl-copy-file old mode 100755 new mode 100644 index 95a4aea..05ffe06 --- a/scripts/wl-copy-file +++ b/scripts/wl-copy-file @@ -10,13 +10,12 @@ if test (count $argv) != 1 end set -a file (realpath $argv[1]) -set -a url (string escape --style=url "$file") set -e argv[1] if test -d "$file" die 1 "Cannot copy directories" >&2 else if test -f "$file" - wl-copy $argv -t text/uri-list "file:///$url" + wl-copy $argv -t text/uri-list "file:///$file" else die 2 "No file found" >&2 end diff --git a/scripts/wlauncher.nix b/scripts/wlauncher.nix index d2c2dec..eb68752 100644 --- a/scripts/wlauncher.nix +++ b/scripts/wlauncher.nix @@ -1,4 +1,12 @@ { pkgs, ... }: +let + inherit (pkgs.uservars) dmenu; + available_menus = { + bmenu = "bmenu run"; + rofi = "rofi -show drun -sort"; + }; + menu_cmd = available_menus.${dmenu}; +in pkgs.writeShellScriptBin "wlauncher" '' - exec bmenu run "$@" + exec ${menu_cmd} "$@" '' diff --git a/scripts/wpass b/scripts/wpass old mode 100755 new mode 100644 index 52bcdff..018616f --- a/scripts/wpass +++ b/scripts/wpass @@ -29,7 +29,7 @@ main() { test -n "$entry" || exit 0 - username=`pass show "$entry" 2>/dev/null | rg -m1 '(login|user|email): (.*)' -r '$2'` + username=`pass show "$entry" 2>/dev/null | perl -ne 'print $2 if /^(login|user|email): (.*)/'` password=`pass show "$entry" 2>/dev/null | head -n 1` otp=`pass otp "$entry" 2>/dev/null` || true @@ -50,6 +50,10 @@ main() { } autotype(){ + if pgrep qutebrowser >/dev/null; then + qutebrowser ":mode-enter insert" + fi + env wtype -s 100 "$username" env wtype -s 100 -k tab env wtype -s 100 "$password" diff --git a/secrets/factorio-settings.age b/secrets/factorio-settings.age deleted file mode 100644 index 77eb8bd..0000000 Binary files a/secrets/factorio-settings.age and /dev/null differ diff --git a/secrets/phantom-nextcloud.age b/secrets/ghost-nextcloud.age similarity index 100% rename from secrets/phantom-nextcloud.age rename to secrets/ghost-nextcloud.age diff --git a/secrets/phantom-renawiki.age b/secrets/ghost-renawiki.age similarity index 100% rename from secrets/phantom-renawiki.age rename to secrets/ghost-renawiki.age diff --git a/secrets/phantom-writefreely.age b/secrets/ghost-writefreely.age similarity index 100% rename from secrets/phantom-writefreely.age rename to secrets/ghost-writefreely.age diff --git a/secrets/monolith-forgejo-runner-token.age b/secrets/monolith-forgejo-runner-token.age deleted file mode 100644 index fff63ca..0000000 Binary files a/secrets/monolith-forgejo-runner-token.age and /dev/null differ diff --git a/secrets/monolith-gitlab-runner-thoreb-itinerario-registrationConfigFile.age b/secrets/monolith-gitlab-runner-thoreb-itinerario-registrationConfigFile.age index 60c5c70..9f9e0e3 100644 Binary files a/secrets/monolith-gitlab-runner-thoreb-itinerario-registrationConfigFile.age and b/secrets/monolith-gitlab-runner-thoreb-itinerario-registrationConfigFile.age differ diff --git a/secrets/monolith/default.yaml b/secrets/monolith/default.yaml deleted file mode 100644 index 0dbc4ae..0000000 --- a/secrets/monolith/default.yaml +++ /dev/null @@ -1,47 +0,0 @@ -forgejo-runners: - git.lelgenio.com-default: ENC[AES256_GCM,data:sEfpBZvgQUkyXPWY4RI0RPJWUbsYK/RGqiYJ5wDSVY9a0EYenyt96QYq6815evq2iQ==,iv:rSWnCOdhfKH4TM9R0/IParYd9laYhWxR+iUhgkVvqfc=,tag:mBcSH/oGDMBgBScvCdn3Zg==,type:str] -gitlab-runners: - thoreb-telemetria-nix: ENC[AES256_GCM,data:zrZvG4be08ulpo7itbrprKK5csCMLvzZjrszfMw1XiJP0FyRTUd9nHgHpbAzbjj2KyT7kKngoZAyengvaTEhkT9sUi1pdGnvajAH8BDDOD0g4LJIHFl4,iv:3bSsTzU7gHx+MchuPg9kmb5xEDugmGPje8Jw74NpRJI=,tag:zffRr77lWbyLt7o/mywb5A==,type:str] - thoreb-itinerario-nix: ENC[AES256_GCM,data:UdAAD0V895sFoEYR56sCG2LlpZugJ0K/nwkTygzWOnbTSmBRAcIQ8qVFPZGw+K+XMSLiCyio6Jp7k8AYP0K1VYm+6aEP3OkqR9FCLQTJgXo=,iv:UGUby50BYkn13OzItk6zZmxc5+SnbZZa4bebQHIow2A=,tag:LjDg3deWwdH2T71EtPo6jA==,type:str] - docker-images-token: ENC[AES256_GCM,data:GGB/KSkjdAyhFKEspAh91ItbqEDf7K/LZSGSn+Jp7SxRfXpDzHIiMD8XJ9PTkGLeQGN4ug1i2nTYPS7d/P5OALWDU+1NPiV9nPdG0w7GERfu4g==,iv:6roabdOKX9xFMf0hWlECd73+943R+hFLos0e2dOpzns=,tag:LrASFc4DtN7aQ+3oOW/p/w==,type:str] - wopus-gitlab-nix: ENC[AES256_GCM,data:asE7J0d58x9VfQFWc07f5T4s5NZ+/VqMQo66EX93J0LbJ4iI5YjvrrIE4pSI1e4Nz/SRQhltaJ0DfSH0+qgjD4wnAONPRi3UlFbSdGWS2bwwRtWe+Nci2krrUFxV2i/ZVE3CwCkNe4mqtII=,iv:gKrD/LhzI+jnDnX6CdxoHfjpiRdrsuRYJF9rTc8SffM=,tag:TczDGSU3gdKmERjBJ7tP/A==,type:str] -sops: - age: - - recipient: age1zrgu7w8059xydagm60phnffghvfe9h2ca58cx8qwagqpyfuvs9fqw79c8h - enc: | - -----BEGIN AGE ENCRYPTED FILE----- - YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBlaFFtOHRBNjZqOXJOV1Bk - SXRhZTdNWklKaTZST2JhU3VFLzBGSWY0QlMwCldwS1hhMDEyZDAxWUlRRXZtTWts - Ti9IOUR2OFdGYkJ4cFRsV0lkbWJvb1EKLS0tIEJUS1ZCZ1M4ZUs5cDhiam5JaEk1 - U1VjNFprNHZWeDhwU3owRXh0MlBFYkUKHPgxz9/w3+JEtOljfyWBPSshfFlVWVys - f15yxlAeWIZVEGqoau7DegVdZiYYIJR2dFBXV1RkKbAwLrbUxAQidg== - -----END AGE ENCRYPTED FILE----- - - recipient: age1ecyynwv93lfu7crjjp8l47defv07quzfzaktwurpep7jc9eha5pscg7lrw - enc: | - -----BEGIN AGE ENCRYPTED FILE----- - YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSB5OWk0cTJ4d25Qd0hrdkFD - a2Fzd1lrMDREclkvRmxUSjFpYXZvRGs2Rm13Cm5aRVZDWE5ZUVR1K2hkZkdKWjYw - K3lKNndBNGFveGVGVWplaHA0MVlYUG8KLS0tIFlVeXhCTGJGUm1HK2RCSFg1RnI3 - aFVxcDFhaGdYekRWRVFIWnRsZndtZFkKgsvxOFHOcO306Z9FkucA1fDOpZA8N1/h - jYmIgcKTFgWoSCvux67lK30jFsYp7sm5z6WxxDYsGcoQ/+pxoUX2jQ== - -----END AGE ENCRYPTED FILE----- - lastmodified: "2025-06-24T11:51:22Z" - mac: ENC[AES256_GCM,data:onyjWlFsH/9YGSi2nGsPmZjhE4nFVQ5Jiwfi4s9KC7NetKD7Reyz2JY6i3YuZspBn3Jvbq8nOKVPGzttMAG+IrqQEv6+MxrCOEnJZXZcqocDNg7dACOXmJB5iwpFVdKscesTH2SScf7Pl/q6l9KOFjFuaZeBB7dlxHVA5zzCVOU=,iv:lEbxg2HfxU6ikgWSpUNAGIfgaz7DnZjXnLWcmsvt0A4=,tag:/Ag37QuJj9Xy/u20Nhy05Q==,type:str] - pgp: - - created_at: "2025-03-07T22:49:16Z" - enc: |- - -----BEGIN PGP MESSAGE----- - - hQEMAzy6JxafzLr5AQgAjwQqdeESOfrOuCjfjALdoy3AnNYC+slusdlra58CoRu6 - YFDAivwPHJBRiuVy43Lo7SWnKXMKvLOry589GBY3JGjNV5U1cPWBhMlTubYZmZWl - iel8Bvw4IF5JksMIvLFdDgexLN7wETzzZP9S8750BCgpSrncrw1k/dUedhv5HUjo - N10x6BPjPSmgolA8uxsISHLAUrKcQoeaWvcZFU1ofKywq08HgIySphy6z3Gmv3Qs - 86saZp1rFm5+qHkrDRgL6Oe3Xx30jVkzn9MHPWzZCDPCEvYGJgXX34NGzbX+/nd3 - JB9XkT2YTFi4BLhdHY3EE7e9//PJc5G9RVDZyAF1e9JeAXH2yR5blXbogoy+VMnS - Yn74Uvs+fnYFTDOiuequro5i0uAyxtrCx8fdfwjuh+9SC5p3N2cBv2eT7zLQwQHi - czHlwxmpi/dMB/u83fR4FzuCUt98VXiezIC4yGn25g== - =Yqqx - -----END PGP MESSAGE----- - fp: 0FECE8316E74BA6F44EFC21A2F8F21CE8721456B - unencrypted_suffix: _unencrypted - version: 3.10.2 diff --git a/secrets/phantom-forgejo-mailer-password.age b/secrets/phantom-forgejo-mailer-password.age deleted file mode 100644 index 90fbe73..0000000 Binary files a/secrets/phantom-forgejo-mailer-password.age and /dev/null differ diff --git a/secrets/phantom-invidious-settings.age b/secrets/phantom-invidious-settings.age deleted file mode 100644 index 6ca9077..0000000 --- a/secrets/phantom-invidious-settings.age +++ /dev/null @@ -1,16 +0,0 @@ -age-encryption.org/v1 --> ssh-rsa BwwxHg -iTcgtxF1IxopbtF+aw7V8IQfH7tWiMk9lE/eWlVHVjeaRvER5W6Y3xZNOFCjtbqY -VwEyV6ibfZ4GJt1jRu2icEH/AnLUJFFGQnxu/K/rtoZ3tqSIk9WCBv3aPo4oZRiU -uaaxi2gD8qo1RLyl/Ij7Djw4i/isUOO1EON5sgx1d39k6qUD4Mak0DSU4EtGdTsr -OaxDAc0kAxhxZQOUH/QlKa0HLonaFcy1LHqvttOcw3UZuZnaYfZiPlcqe3USS9cm -96aIC5cS9pHr4JFrqRYvfpla2TY5jlCB/xBGw3KjGEIQoBPXSsJZA6BCMZyp00++ -tdfS2aomt9HFmb1wZDS0jWAxkVF6nXXBbolFVih+58h0nYLljtHIQ3SizRoXY459 -x3JE9NReHp2OO3SlIeO03Kv8YMBvj7nSSd1C1PMpu+hJ/eCXi1WQxD6QY+40muk6 -KhqE3PZ8BCY2b+VpywUF5gVH28mo3jscqAzhf2dZ3SQlzldI+hFyKPxTdAqkfUOH - ---- cinb+wzjVfTkpfm1CtFIFaepwoQVCj1MquB5rAC45Ew - -6 -ZCHS0 7 EX* qb=OwuP ǖѳ/mv2Vī -xv[̂A~evd0ni1қQ"@ٹ{Kp:ϵusB(Xr[QVgT@*B .hE鲟뒭zlz|k`l88McchZ` ?yeo+M-:/**cZD2&Ǣ e*Hn"~+|ua(6J \ No newline at end of file diff --git a/secrets/phantom-mastodon-mailer-password.age b/secrets/phantom-mastodon-mailer-password.age deleted file mode 100644 index 37232fb..0000000 --- a/secrets/phantom-mastodon-mailer-password.age +++ /dev/null @@ -1,13 +0,0 @@ -age-encryption.org/v1 --> ssh-rsa BwwxHg -Mnc+/tJ0QqxHkg2nl9gEkz5Oj1RgxtOZnD5gRv66ISUOqZhNm1+F+xVEdKn843/q -/WzH0f1cTF9NXP8vIaEo//bMmp50obJAd+JNovJxV+0gb9L55Nu7ayvK+eyk6j5n -eb8TxUnwh5BPkEyc6akDh/O49GXzLlVoFD6Ik/0f3YCqUDNAYOl2bsssXtevCeK/ -WEPoCFGhZfNUrOo/0eAhiujZZ5zVb0CWNqXi8VTe2eWOE20VJULcN13TEyO3ZePx -bAPBmDfS5GgGlV4INWxVLaIMDrzlm0tYozbBNNUbdLFFOhIOrgvay9RWxdk0u2hJ -MPKoKsJ96EFxrbZJdS0W7a+aZk/Q3A3Civ2rtPx+5UANhmlY8e1lUHa26e1vA4K7 -ApoMtDyCbuZ9FbLurwl9zO64wWP68aKzuyKOIw+wpy41NQ/PcViSY8KNG9Pt7A2N -CcOkByx+rwz+JdNHbOF8O4FFG4fNSWn7SvVtu5ymGgVi1bOd8PdJpjDR+6Is0SX7 - ---- DHNyITb7ZseEV58MOD/zHeH5vff0hhlbKg27rlYECGk -J/dev/null; then - run --verbose \ - --log-format internal-json \ - "$@" \ - |& nom --json -else - run "$@" -fi + switch \ + --verbose \ + --print-build-logs \ + --flake .# \ + $@ diff --git a/switch-phantom b/switch-phantom deleted file mode 100755 index 0449f75..0000000 --- a/switch-phantom +++ /dev/null @@ -1,12 +0,0 @@ -#!/bin/sh - -nix fmt - -git --no-pager diff - -nixos-rebuild switch --flake .#phantom \ - --update-input nixpkgs \ - --no-write-lock-file \ - --build-host phantom \ - --target-host phantom \ - "$@" diff --git a/system/android.nix b/system/android.nix deleted file mode 100644 index 3cce4af..0000000 --- a/system/android.nix +++ /dev/null @@ -1,17 +0,0 @@ -{ - config, - pkgs, - lib, - ... -}: -{ - options.my.android.enable = lib.mkEnableOption { }; - - config = lib.mkIf config.my.android.enable { - # Open kde connect ports - programs.kdeconnect.enable = true; - - programs.adb.enable = true; - services.udev.packages = [ pkgs.android-udev-rules ]; - }; -} diff --git a/system/bluetooth.nix b/system/bluetooth.nix deleted file mode 100644 index a5d00c0..0000000 --- a/system/bluetooth.nix +++ /dev/null @@ -1,17 +0,0 @@ -{ pkgs, ... }: -{ - services.blueman.enable = true; - hardware.bluetooth = { - enable = true; - settings = { - General = { - DiscoverableTimeout = 0; - Discoverable = true; - AlwaysPairable = true; - }; - Policy = { - AutoEnable = true; - }; - }; - }; -} diff --git a/system/boot.nix b/system/boot.nix index 3e0151d..25e9a11 100644 --- a/system/boot.nix +++ b/system/boot.nix @@ -1,10 +1,4 @@ -{ - config, - pkgs, - lib, - ... -}: -{ +{ config, pkgs, lib, inputs, ... }: { console = { font = "${pkgs.terminus_font}/share/consolefonts/ter-120n.psf.gz"; packages = [ pkgs.terminus_font ]; @@ -42,9 +36,11 @@ }; plymouth = { enable = true; - theme = lib.mkIf (config.my.desktop == "sway") "red_loader"; + theme = lib.mkIf (pkgs.uservars.desktop == "sway") "red_loader"; themePackages = with pkgs; [ - (adi1090x-plymouth-themes.override { selected_themes = [ "red_loader" ]; }) + (adi1090x-plymouth-themes.override { + selected_themes = [ "red_loader" ]; + }) ]; }; }; diff --git a/system/cachix.nix b/system/cachix.nix new file mode 100644 index 0000000..07af177 --- /dev/null +++ b/system/cachix.nix @@ -0,0 +1,12 @@ +{ pkgs, lib, config, ... }: { + services.cachix-watch-store = { + enable = true; + cacheName = "lelgenio"; + cachixTokenFile = config.age.secrets.lelgenio-cachix.path; + }; + systemd.services.cachix-watch-store-agent = { + serviceConfig.TimeoutStopSec = 3; + # If we don't do this, cachix tends to timeout + serviceConfig.KillMode = lib.mkForce "control-group"; + }; +} diff --git a/system/configuration.nix b/system/configuration.nix index 2380d22..2e3eed5 100644 --- a/system/configuration.nix +++ b/system/configuration.nix @@ -1,51 +1,166 @@ # Edit this configuration file to define what should be installed on # your system. Help is available in the configuration.nix(5) man page # and in the NixOS manual (accessible by running ‘nixos-help’). -{ pkgs, config, ... }: -{ +{ config, pkgs, inputs, ... }: { imports = [ - ./android.nix - ./gaming.nix + ./gamemode.nix + ./cachix.nix ./media-packages.nix ./boot.nix ./thunar.nix ./nix.nix - ./fonts.nix - ./sound.nix - ./bluetooth.nix - ./mouse.nix - ./locale.nix - ./users.nix - ./containers.nix - ./nix-ld.nix - ./network.nix - ../settings ]; - my = import ../user/variables.nix // { - android.enable = true; - media-packages.enable = true; - containers.enable = true; - }; - zramSwap.enable = true; - # Enable touchpad support (enabled default in most desktopManager). - services.libinput.enable = true; + programs.adb.enable = true; + services.udev.packages = [ pkgs.android-udev-rules ]; + # networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. + # Configure network proxy if necessary + # networking.proxy.default = "http://user:password@proxy:port/"; + # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; + # Enable networking + networking.networkmanager.enable = true; + # Open kde connect ports + programs.kdeconnect.enable = true; + networking.firewall.allowedTCPPorts = [ 55201 ]; + + # Set your time zone. + time.timeZone = "America/Sao_Paulo"; + environment.variables.TZ = config.time.timeZone; + # Select internationalisation properties. + i18n.defaultLocale = "pt_BR.utf8"; + + # Enable the GNOME Desktop Environment. + # services.xserver.displayManager.gdm.enable = true; + # services.xserver.desktopManager.gnome.enable = true; + # services.xserver.displayManager.autologin.user = "lelgenio"; + + # Configure keymap in X11 + services.xserver = { + layout = "us"; + xkbVariant = "colemak"; + }; + console.keyMap = "colemak"; + # Enable CUPS to print documents. + # services.printing.enable = true; + services.flatpak.enable = true; + virtualisation.docker.enable = true; + virtualisation.docker.autoPrune.enable = true; + virtualisation.docker.autoPrune.dates = "monthly"; + virtualisation.docker.autoPrune.flags = [ "--all --volumes" ]; + + programs.extra-container.enable = true; + + programs.firejail.enable = true; + + security.rtkit.enable = true; + services.openssh = { + enable = true; + ports = [ 9022 ]; + settings = { + PermitRootLogin = "no"; + PasswordAuthentication = false; + KbdInteractiveAuthentication = false; + }; + }; + # programs.ssh = { + # startAgent = true; + # extraConfig = '' + # AddKeysToAgent yes + # ''; + # }; + + ## Enable sound with pipewire. + sound.enable = true; + hardware.pulseaudio.enable = false; + services.pipewire = { + enable = true; + wireplumber.enable = true; + pulse.enable = true; + alsa.enable = true; + jack.enable = true; + }; + + services.blueman.enable = true; + hardware.bluetooth = { + enable = true; + settings = { + General = { + DiscoverableTimeout = 0; + # Discoverable = true; + AlwaysPairable = true; + }; + Policy = { AutoEnable = true; }; + }; + }; + + # Enable touchpad support (enabled default in most desktopManager). + services.xserver.libinput.enable = true; + + xdg.portal = { + config.common.default = "*"; + enable = true; + wlr.enable = true; + # Always pick the first monitor, this is fine since I only ever use a single monitor + wlr.settings.screencast.chooser_type = "none"; + # gtk portal needed to make gtk apps happy + extraPortals = [ pkgs.xdg-desktop-portal-gtk ]; + }; + + # Define a user account. Don't forget to set a password with ‘passwd’. + users.mutableUsers = false; + users.users.lelgenio = { + isNormalUser = true; + description = "Leonardo Eugênio"; + hashedPassword = "$y$j9T$0e/rczjOVCy7PuwC3pG0V/$gTHZhfO4wQSlFvbDyfghbCnGI2uDI0a52zSrQ/yOA5A"; + extraGroups = [ "networkmanager" "wheel" "docker" "adbusers" "bluetooth" "corectrl" "vboxusers" ]; + shell = pkgs.fish; + openssh.authorizedKeys.keys = [ + "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQCxR/w+38b2lX90yNBqhq3mUmkn1WGu6GAPhN1tVp2ZjYRJNV/+5gWCnTtOWYtDx35HmK/spQ2Qy8X9ttkzORa24fysNx1Iqn/TiXhD7eIJjbGPnrOpIKTkW5/uB3SD/P5NBSa06//BaqJU4sBlG79hoXRpod052hQtdpTVDiMCIV+iboWPKqopmJJfWdBtVnHXs9rep0htPRExxGslImFk7Z6xjcaHyCpIQZPlOGf+sGsmUU7jRqzvZFV8ucIdbnAlMHrU4pepNFhuraESyZVTa/bi9sw0iozXp5Q5+5thMebEslmT1Z771kI4sieDy+O4r8c0Sx2/VY1UAzcpq1faggc3YB01MTh+tiEC6xdMvZLrQGL1NBWjHleMyL53GU5ERluC0vXJF3Hv3BGGBDfXWbrEm5n06DHr2apRVJGC0LwiQ7Woud1X4V4X1pKSusxCVMjT2lmcOwV6YhKhB2sowJc1OdMx4+tL0UWE+YKSZgBHfolwk6ml0F4EO9nnUHc= lelgenio@i15" + ]; + }; + users.users.root.initialHashedPassword = "$y$j9T$E3aBBSSq0Gma8hZD9L7ov0$iCGDW4fqrXWfHO0qodBYYgMFA9CpIraoklHcPbJJrM3"; + + # services.getty.autologinUser = "lelgenio"; + programs.fish.enable = true; + + programs.dzgui.enable = true; + programs.dzgui.package = inputs.dzgui-nix.packages.${pkgs.system}.default; + + packages.media-packages.enable = true; environment.systemPackages = with pkgs; [ + pinentry-curses pavucontrol glib # gsettings usbutils - adwaita-icon-theme # default gnome cursors + # dracula-theme # gtk theme + gnome3.adwaita-icon-theme # default gnome cursors + ]; + + fonts.enableDefaultPackages = true; + fonts.packages = with pkgs; [ + noto-fonts + noto-fonts-cjk + noto-fonts-emoji + nerdfonts_fira_hack ]; services.geoclue2.enable = true; + # programs.qt5ct.enable = true; + # Some programs need SUID wrappers, can be configured further or are + # started in user sessions. + # programs.mtr.enable = true; + services.pcscd.enable = true; + programs.gnupg.agent = { + enable = true; + enableSSHSupport = true; + pinentryFlavor = "curses"; + }; + security.sudo.wheelNeedsPassword = false; - systemd.extraConfig = '' - DefaultTimeoutStopSec=10s - ''; services.logind.extraConfig = '' HandlePowerKey=suspend ''; diff --git a/system/containers.nix b/system/containers.nix deleted file mode 100644 index ddd3e38..0000000 --- a/system/containers.nix +++ /dev/null @@ -1,40 +0,0 @@ -{ - pkgs, - lib, - config, - ... -}: -{ - options.my.containers.enable = lib.mkEnableOption { }; - - config = lib.mkIf config.my.containers.enable { - services.flatpak.enable = true; - programs.appimage.enable = true; - - virtualisation.docker = { - enable = true; - autoPrune = { - enable = true; - dates = "monthly"; - flags = [ - "--all" - "--volumes" - ]; - }; - daemon.settings = { - # needed by bitbucket runner ??? - log-driver = "json-file"; - log-opts = { - max-size = "10m"; - max-file = "3"; - }; - }; - }; - - networking.firewall.extraCommands = lib.getExe pkgs._docker-block-external-connections; - - programs.extra-container.enable = true; - - programs.firejail.enable = true; - }; -} diff --git a/system/fonts.nix b/system/fonts.nix deleted file mode 100644 index 73aa8f7..0000000 --- a/system/fonts.nix +++ /dev/null @@ -1,11 +0,0 @@ -{ pkgs, ... }: -{ - fonts.enableDefaultPackages = true; - fonts.packages = with pkgs; [ - noto-fonts - noto-fonts-cjk-sans - noto-fonts-emoji - nerd-fonts.fira-code - nerd-fonts.hack - ]; -} diff --git a/system/gamemode.nix b/system/gamemode.nix new file mode 100644 index 0000000..d9445ea --- /dev/null +++ b/system/gamemode.nix @@ -0,0 +1,19 @@ +{ config, pkgs, inputs, ... }: { + programs.gamemode.enable = true; + programs.gamemode.enableRenice = true; + programs.gamemode.settings = { + general = { renice = 10; }; + + # Warning: GPU optimisations have the potential to damage hardware + gpu = { + apply_gpu_optimisations = "accept-responsibility"; + gpu_device = 0; + amd_performance_level = "high"; + }; + + custom = { + start = "${pkgs.libnotify}/bin/notify-send 'GameMode started'"; + end = "${pkgs.libnotify}/bin/notify-send 'GameMode ended'"; + }; + }; +} diff --git a/system/gaming.nix b/system/gaming.nix deleted file mode 100644 index e79353e..0000000 --- a/system/gaming.nix +++ /dev/null @@ -1,71 +0,0 @@ -{ - config, - pkgs, - lib, - inputs, - ... -}: -{ - options.my.gaming.enable = lib.mkEnableOption { }; - - config = lib.mkIf config.my.gaming.enable { - programs.steam.enable = true; - programs.steam.extraPackages = - config.fonts.packages - ++ (with pkgs; [ - capitaine-cursors - bibata-cursors - mangohud - xdg-user-dirs - gamescope - - # gamescope compatibility?? - xorg.libXcursor - xorg.libXi - xorg.libXinerama - xorg.libXScrnSaver - libpng - libpulseaudio - libvorbis - stdenv.cc.cc.lib - libkrb5 - keyutils - ]); - - environment.systemPackages = with pkgs; [ - protontricks - bottles - inputs.dzgui-nix.packages.${pkgs.system}.default - ]; - - programs.gamemode = { - enable = true; - enableRenice = true; - settings = { - general = { - renice = 10; - }; - - # Warning: GPU optimisations have the potential to damage hardware - gpu = { - apply_gpu_optimisations = "accept-responsibility"; - gpu_device = 0; - amd_performance_level = "high"; - }; - - custom = { - start = "${pkgs.libnotify}/bin/notify-send 'GameMode started'"; - end = "${pkgs.libnotify}/bin/notify-send 'GameMode ended'"; - }; - }; - }; - - programs.corectrl = { - enable = true; - gpuOverclock = { - enable = true; - ppfeaturemask = "0xffffffff"; - }; - }; - }; -} diff --git a/system/gitlab-runner.nix b/system/gitlab-runner.nix index 8db526f..1cc46a7 100644 --- a/system/gitlab-runner.nix +++ b/system/gitlab-runner.nix @@ -1,55 +1,40 @@ -{ pkgs, lib, ... }: -let - installNixScript = pkgs.writeScriptBin "install-nix" '' - mkdir -p -m 0755 /nix/var/log/nix/drvs - mkdir -p -m 0755 /nix/var/nix/gcroots - mkdir -p -m 0755 /nix/var/nix/profiles - mkdir -p -m 0755 /nix/var/nix/temproots - mkdir -p -m 0755 /nix/var/nix/userpool - mkdir -p -m 1777 /nix/var/nix/gcroots/per-user - mkdir -p -m 1777 /nix/var/nix/profiles/per-user - mkdir -p -m 0755 /nix/var/nix/profiles/per-user/root - mkdir -p -m 0700 "$HOME/.nix-defexpr" - - . ${pkgs.nix}/etc/profile.d/nix.sh - - ${pkgs.nix}/bin/nix-env -i ${ - lib.concatStringsSep " " ( - with pkgs; - [ - nix - cacert - git - openssh - docker - ] - ) - } - ''; -in -{ - mkNixRunner = authenticationTokenConfigFile: { +{ pkgs, lib, ... }: { + mkNixRunner = registrationConfigFile: with lib; rec { # File should contain at least these two variables: # `CI_SERVER_URL` # `REGISTRATION_TOKEN` - inherit authenticationTokenConfigFile; # 2 + inherit registrationConfigFile; # 2 dockerImage = "alpine:3.18.2"; + dockerAllowedImages = [ dockerImage ]; dockerVolumes = [ "/etc/nix/nix.conf:/etc/nix/nix.conf:ro" "/nix/store:/nix/store:ro" "/nix/var/nix/db:/nix/var/nix/db:ro" "/nix/var/nix/daemon-socket:/nix/var/nix/daemon-socket:ro" - "/tmp:/tmp" - "/var/run/docker.sock:/var/run/docker.sock" - "/var/lib/docker/containers:/var/lib/docker/containers" ]; dockerDisableCache = true; - preBuildScript = "\". ${lib.getExe installNixScript}\""; + preBuildScript = pkgs.writeScript "setup-container" '' + mkdir -p -m 0755 /nix/var/log/nix/drvs + mkdir -p -m 0755 /nix/var/nix/gcroots + mkdir -p -m 0755 /nix/var/nix/profiles + mkdir -p -m 0755 /nix/var/nix/temproots + mkdir -p -m 0755 /nix/var/nix/userpool + mkdir -p -m 1777 /nix/var/nix/gcroots/per-user + mkdir -p -m 1777 /nix/var/nix/profiles/per-user + mkdir -p -m 0755 /nix/var/nix/profiles/per-user/root + mkdir -p -m 0700 "$HOME/.nix-defexpr" + + . ${pkgs.nix}/etc/profile.d/nix.sh + + ${pkgs.nix}/bin/nix-env -i ${concatStringsSep " " (with pkgs; [ nix cacert git openssh ])} + ''; environmentVariables = { ENV = "/etc/profile"; USER = "root"; NIX_REMOTE = "daemon"; + PATH = "/nix/var/nix/profiles/default/bin:/nix/var/nix/profiles/default/sbin:/bin:/sbin:/usr/bin:/usr/sbin"; NIX_SSL_CERT_FILE = "/nix/var/nix/profiles/default/etc/ssl/certs/ca-bundle.crt"; }; + tagList = [ "nix" ]; }; } diff --git a/system/gnome.nix b/system/gnome.nix index f56f938..855f5d5 100644 --- a/system/gnome.nix +++ b/system/gnome.nix @@ -1,47 +1,25 @@ -{ pkgs, lib, ... }: -{ - services.xserver = { - enable = true; - desktopManager.gnome = { - enable = true; - # Enable VRR (Variable Refresh Rate) - extraGSettingsOverridePackages = with pkgs; [ gnome.mutter ]; - extraGSettingsOverrides = '' - [org.gnome.mutter] - experimental-features=['variable-refresh-rate', 'scale-monitor-framebuffer'] - ''; - }; - displayManager.gdm.enable = true; - }; +# Edit this configuration file to define what should be installed on +# your system. Help is available in the configuration.nix(5) man page +# and in the NixOS manual (accessible by running ‘nixos-help’). +{ config, pkgs, ... }: { + # Enable the X11 windowing system. + services.xserver.enable = true; + # Enable the GNOME Desktop Environment. + services.xserver.displayManager.gdm.enable = true; + services.xserver.desktopManager.gnome.enable = true; - # Workaround for https://github.com/NixOS/nixpkgs/issues/103746 - systemd.services."getty@tty1".enable = false; - systemd.services."autovt@tty1".enable = false; - - services.displayManager.autoLogin = { + services.xserver.displayManager.autoLogin = { enable = true; user = "lelgenio"; }; - programs.kdeconnect = { - enable = true; - package = pkgs.gnomeExtensions.gsconnect; - }; - - hardware.opentabletdriver.enable = lib.mkForce false; - - programs.gpaste.enable = true; - # services.xserver.displayManager.autologin.user = "lelgenio"; - environment.systemPackages = - with pkgs; - with gnome; - [ - gnome-tweaks - dconf-editor + environment.systemPackages = with pkgs; with gnome; [ + gnome-tweaks + dconf-editor - chrome-gnome-shell - gnomeExtensions.quick-settings-audio-devices-hider - gnome-pass-search-provider - ]; + chrome-gnome-shell + gnomeExtensions.gsconnect + gnomeExtensions.quick-settings-audio-devices-hider + ]; } diff --git a/system/greetd.nix b/system/greetd.nix index 2b5f22f..d8d1531 100644 --- a/system/greetd.nix +++ b/system/greetd.nix @@ -1,17 +1,6 @@ -{ - lib, - pkgs, - config, - ... -}: +{ lib, pkgs, config, ... }: let - inherit (config.my) - key - accent - font - theme - desktop - ; + inherit (pkgs.uservars) key accent font theme desktop; cfg = config.login-manager.greetd; in @@ -28,7 +17,6 @@ in # enable sway window manager programs.sway = { enable = true; - package = pkgs.mySway; wrapperFeatures.gtk = true; }; @@ -45,8 +33,12 @@ in services.greetd = let greetd_main_script = pkgs.writeShellScriptBin "main" '' + ${pkgs.dbus-sway-environment}/bin/dbus-sway-environment export XDG_CURRENT_DESKTOP=sway GTK_THEME="${theme.gtk_theme}" XCURSOR_THEME="${theme.cursor_theme}" - ${pkgs.greetd.gtkgreet}/bin/gtkgreet -l -c ${desktop} + ${pkgs.greetd.gtkgreet}/bin/gtkgreet -l -c ${{ + sway = "sway"; + hyprland = "Hyprland"; + }.${desktop}} swaymsg exit ''; swayConfig = pkgs.writeText "greetd-sway-config" '' @@ -70,7 +62,7 @@ in enable = true; settings = { initial_session = { - command = desktop; + command = "${pkgs.sway}/bin/sway"; user = "lelgenio"; }; default_session = { diff --git a/system/kde.nix b/system/kde.nix index c5ef277..66aa2a2 100644 --- a/system/kde.nix +++ b/system/kde.nix @@ -1,5 +1,4 @@ -{ config, pkgs, ... }: -{ +{ config, pkgs, ... }: { # Enable the X11 windowing system. services.xserver.enable = true; # Enable the KDE Desktop Environment. diff --git a/system/locale.nix b/system/locale.nix deleted file mode 100644 index e2c7e81..0000000 --- a/system/locale.nix +++ /dev/null @@ -1,13 +0,0 @@ -{ pkgs, config, ... }: -{ - time.timeZone = "America/Sao_Paulo"; - environment.variables.TZ = config.time.timeZone; - i18n.defaultLocale = "pt_BR.UTF-8"; - - # Configure keymap in X11 - services.xserver.xkb = { - layout = "us"; - variant = "colemak"; - }; - console.keyMap = "colemak"; -} diff --git a/system/media-packages.nix b/system/media-packages.nix index dec98a2..94a779a 100644 --- a/system/media-packages.nix +++ b/system/media-packages.nix @@ -1,14 +1,7 @@ -{ - config, - pkgs, - lib, - ... -}: -let - cfg = config.my.media-packages; -in -{ - options.my.media-packages = { +{ config, pkgs, lib, ... }: +let cfg = config.packages.media-packages; +in { + options.packages.media-packages = { enable = lib.mkEnableOption "media packages"; }; config = lib.mkIf cfg.enable { @@ -23,10 +16,8 @@ in gimp inkscape krita - kdePackages.breeze - kdePackages.kdenlive - pitivi - blender-hip + kdenlive + blender libreoffice godot_4 ]; diff --git a/system/monolith-forgejo-runner.nix b/system/monolith-forgejo-runner.nix deleted file mode 100644 index fa2b3c6..0000000 --- a/system/monolith-forgejo-runner.nix +++ /dev/null @@ -1,20 +0,0 @@ -{ pkgs, config, ... }: -{ - services.gitea-actions-runner = { - package = pkgs.forgejo-actions-runner; - instances.default = { - enable = true; - name = "monolith"; - url = "https://git.lelgenio.com"; - tokenFile = config.age.secrets.monolith-forgejo-runner-token.path; - labels = [ - # provide a debian base with nodejs for actions - "debian-latest:docker://node:18-bullseye" - # fake the ubuntu name, because node provides no ubuntu builds - "ubuntu-latest:docker://node:18-bullseye" - # provide native execution on the host - #"native:host" - ]; - }; - }; -} diff --git a/system/monolith-gitlab-runner.nix b/system/monolith-gitlab-runner.nix index 6f1f7b3..37b16dd 100644 --- a/system/monolith-gitlab-runner.nix +++ b/system/monolith-gitlab-runner.nix @@ -1,8 +1,4 @@ -{ - config, - pkgs, - ... -}: +{ config, pkgs, lib, ... }: let inherit (pkgs.callPackage ./gitlab-runner.nix { }) mkNixRunner; in @@ -11,38 +7,24 @@ in virtualisation.docker.enable = true; services.gitlab-runner = { enable = true; - settings.concurrent = 12; + settings.concurrent = 4; services = { + # ci_test = { + # registrationConfigFile = "/srv/gitlab-runner/env/ci_test"; + # dockerImage = "debian"; + # dockerPrivileged = true; + # }; + thoreb_builder = { + registrationConfigFile = config.age.secrets.monolith-gitlab-runner-thoreb-itinerario-registrationConfigFile.path; + dockerImage = "debian"; + dockerPrivileged = true; + }; + # runner for building in docker via host's nix-daemon # nix store will be readable in runner, might be insecure - thoreb-telemetria-nix = mkNixRunner config.sops.secrets."gitlab-runners/thoreb-telemetria-nix".path; - thoreb-itinerario-nix = mkNixRunner config.sops.secrets."gitlab-runners/thoreb-itinerario-nix".path; - - wopus-gitlab-nix = mkNixRunner config.sops.secrets."gitlab-runners/wopus-gitlab-nix".path; - - default = { - # File should contain at least these two variables: - # `CI_SERVER_URL` - # `CI_SERVER_TOKEN` - authenticationTokenConfigFile = config.sops.secrets."gitlab-runners/docker-images-token".path; - dockerImage = "debian:stable"; - }; + thoreb-telemetria-nix = mkNixRunner config.age.secrets.gitlab-runner-thoreb-telemetria-registrationConfigFile.path; + thoreb-itinerario-nix = mkNixRunner config.age.secrets.monolith-gitlab-runner-thoreb-itinerario-registrationConfigFile.path; }; }; systemd.services.gitlab-runner.serviceConfig.Nice = 10; - - sops.secrets = { - "gitlab-runners/thoreb-telemetria-nix" = { - sopsFile = ../secrets/monolith/default.yaml; - }; - "gitlab-runners/thoreb-itinerario-nix" = { - sopsFile = ../secrets/monolith/default.yaml; - }; - "gitlab-runners/docker-images-token" = { - sopsFile = ../secrets/monolith/default.yaml; - }; - "gitlab-runners/wopus-gitlab-nix" = { - sopsFile = ../secrets/monolith/default.yaml; - }; - }; } diff --git a/system/mouse.nix b/system/mouse.nix deleted file mode 100644 index b5d5b16..0000000 --- a/system/mouse.nix +++ /dev/null @@ -1,15 +0,0 @@ -{ - # Allow configuring Logitech Peripherals - services.ratbagd.enable = true; - - # Sway does not undersand high resolution scroll wheels - # I don't need this, so I disable it - environment.etc."libinput/local-overrides.quirks".text = '' - [Logitech G502 X PLUS] - MatchUdevType=mouse - MatchBus=usb - MatchVendor=0x046D - MatchProduct=0x4099 - AttrEventCode=-REL_WHEEL_HI_RES - ''; -} diff --git a/system/network.nix b/system/network.nix deleted file mode 100644 index e280ff5..0000000 --- a/system/network.nix +++ /dev/null @@ -1,37 +0,0 @@ -{ pkgs, ... }: -{ - # networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. - # Configure network proxy if necessary - # networking.proxy.default = "http://user:password@proxy:port/"; - # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; - # Enable networking - networking.networkmanager.enable = true; - - networking.firewall = { - enable = true; - logRefusedConnections = false; - }; - - # Enable CUPS to print documents. - services.printing.enable = true; - - security.rtkit.enable = true; - services.openssh = { - enable = true; - ports = [ 9022 ]; - settings = { - PermitRootLogin = "no"; - PasswordAuthentication = false; - KbdInteractiveAuthentication = false; - }; - }; - - # Workaround for nm-wait-online hanging?? - # Ref: https://github.com/NixOS/nixpkgs/issues/180175 - systemd.services.NetworkManager-wait-online = { - serviceConfig.ExecStart = [ - "" - "${pkgs.networkmanager}/bin/nm-online -q" - ]; - }; -} diff --git a/system/nix-ld.nix b/system/nix-ld.nix deleted file mode 100644 index 33afa69..0000000 --- a/system/nix-ld.nix +++ /dev/null @@ -1,21 +0,0 @@ -{ - pkgs, - lib, - config, - ... -}: -{ - options.my.nix-ld.enable = lib.mkEnableOption { }; - - config = lib.mkIf (config.my.nix-ld.enable) { - programs.nix-ld = { - enable = true; - libraries = - with pkgs; - # run appimages + linux games natively - [ fuse ] - ++ (appimageTools.defaultFhsEnvArgs.multiPkgs pkgs) - ++ (appimageTools.defaultFhsEnvArgs.targetPkgs pkgs); - }; - }; -} diff --git a/system/nix-serve.nix b/system/nix-serve.nix index 6cc7161..0bd49c2 100644 --- a/system/nix-serve.nix +++ b/system/nix-serve.nix @@ -1,10 +1,4 @@ -{ - config, - pkgs, - lib, - ... -}: -{ +{ config, pkgs, lib, ... }: { services.nix-serve = { enable = true; secretKeyFile = config.age.secrets.monolith-nix-serve-privkey.path; diff --git a/system/nix.nix b/system/nix.nix index 482bb93..87e4324 100644 --- a/system/nix.nix +++ b/system/nix.nix @@ -1,43 +1,25 @@ -{ - lib, - config, - pkgs, - inputs, - ... -}: -let - collectFlakeInputs = - input: [ input ] ++ lib.concatMap collectFlakeInputs (builtins.attrValues (input.inputs or { })); -in -{ - system.extraDependencies = collectFlakeInputs inputs.self; - +{ config, pkgs, inputs, ... }: { nix.registry.nixpkgs.flake = inputs.nixpkgs; nix = { nixPath = [ "nixpkgs=${inputs.nixpkgs}" ]; gc = { automatic = true; - dates = "weekly"; + dates = "monthly"; options = "--delete-older-than 7d"; }; optimise.automatic = true; settings = { - trusted-users = [ - "root" - "@wheel" - ]; + auto-optimise-store = true; substituters = [ - "https://cache.nixos.org" - "https://nix-community.cachix.org" # "http://nixcache.lelgenio.1337.cx:5000" + "https://hyprland.cachix.org" "https://lelgenio.cachix.org" "https://wegank.cachix.org" "https://snowflakeos.cachix.org/" ]; trusted-public-keys = [ - "cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY=" - "nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs=" # "nixcache.lelgenio.1337.cx:zxCfx7S658llDgAUG0JVyNrlAdFVvPniSdDOkvfTPS8=" + "hyprland.cachix.org-1:a7pgxzMz7+chwVL3/pzj6jIBMioiJM7ypFP8PwtkuGc=" "lelgenio.cachix.org-1:W8tMlmDFLU/V+6DlChXjekxoHZpjgVHZpmusC4cueBc=" "wegank.cachix.org-1:xHignps7GtkPP/gYK5LvA/6UFyz98+sgaxBSy7qK0Vs=" "snowflakeos.cachix.org-1:gXb32BL86r9bw1kBiw9AJuIkqN49xBvPd1ZW8YlqO70=" diff --git a/system/rainbow-gitlab-runner.nix b/system/rainbow-gitlab-runner.nix new file mode 100644 index 0000000..2cae621 --- /dev/null +++ b/system/rainbow-gitlab-runner.nix @@ -0,0 +1,28 @@ +{ config, pkgs, lib, ... }: +let + inherit (pkgs.callPackage ./gitlab-runner.nix { }) mkNixRunner; +in +{ + boot.kernel.sysctl."net.ipv4.ip_forward" = true; + virtualisation.docker.enable = true; + services.gitlab-runner = { + enable = true; + settings.concurrent = 1; + services = { + # ci_test = { + # registrationConfigFile = "/srv/gitlab-runner/env/ci_test"; + # dockerImage = "debian"; + # dockerPrivileged = true; + # }; + thoreb_builder = { + registrationConfigFile = config.age.secrets.rainbow-gitlab-runner-thoreb-itinerario-registrationConfigFile.path; + dockerImage = "debian"; + dockerPrivileged = true; + }; + + thoreb-telemetria-nix = mkNixRunner config.age.secrets.gitlab-runner-thoreb-telemetria-registrationConfigFile.path; + thoreb-itinerario-nix = mkNixRunner config.age.secrets.rainbow-gitlab-runner-thoreb-itinerario-registrationConfigFile.path; + }; + }; + systemd.services.gitlab-runner.serviceConfig.Nice = 10; +} diff --git a/system/secrets.nix b/system/secrets.nix index 588dfe4..776ee6e 100644 --- a/system/secrets.nix +++ b/system/secrets.nix @@ -1,12 +1,14 @@ -{ pkgs, config, ... }: -{ +{ pkgs, ... }: { age = { - identityPaths = [ "/root/.ssh/id_rsa" ]; + identityPaths = [ "/home/lelgenio/.ssh/id_rsa" ]; secrets.lelgenio-cachix.file = ../secrets/lelgenio-cachix.age; - secrets.monolith-gitlab-runner-thoreb-itinerario-registrationConfigFile.file = ../secrets/monolith-gitlab-runner-thoreb-itinerario-registrationConfigFile.age; - secrets.gitlab-runner-thoreb-telemetria-registrationConfigFile.file = ../secrets/gitlab-runner-thoreb-telemetria-registrationConfigFile.age; - secrets.monolith-forgejo-runner-token.file = ../secrets/monolith-forgejo-runner-token.age; - secrets.monolith-nix-serve-privkey.file = ../secrets/monolith-nix-serve-privkey.age; - secrets.phantom-forgejo-mailer-password.file = ../secrets/phantom-forgejo-mailer-password.age; + secrets.monolith-gitlab-runner-thoreb-itinerario-registrationConfigFile.file = + ../secrets/monolith-gitlab-runner-thoreb-itinerario-registrationConfigFile.age; + secrets.gitlab-runner-thoreb-telemetria-registrationConfigFile.file = + ../secrets/gitlab-runner-thoreb-telemetria-registrationConfigFile.age; + secrets.rainbow-gitlab-runner-thoreb-itinerario-registrationConfigFile.file = + ../secrets/rainbow-gitlab-runner-thoreb-itinerario-registrationConfigFile.age; + secrets.monolith-nix-serve-privkey.file = + ../secrets/monolith-nix-serve-privkey.age; }; } diff --git a/system/sops.nix b/system/sops.nix deleted file mode 100644 index d868153..0000000 --- a/system/sops.nix +++ /dev/null @@ -1,15 +0,0 @@ -{ pkgs, ... }: -{ - environment.systemPackages = with pkgs; [ - sops - gnupg - ]; - - sops = { - defaultSopsFile = ../secrets/test.yaml; - age.sshKeyPaths = [ - "/etc/ssh/ssh_host_ed25519_key" - "/home/lelgenio/.ssh/id_ed25519" - ]; - }; -} diff --git a/system/sound.nix b/system/sound.nix deleted file mode 100644 index 40dd701..0000000 --- a/system/sound.nix +++ /dev/null @@ -1,11 +0,0 @@ -{ pkgs, ... }: -{ - services.pulseaudio.enable = false; - services.pipewire = { - enable = true; - wireplumber.enable = true; - pulse.enable = true; - alsa.enable = true; - jack.enable = true; - }; -} diff --git a/system/specialisation.nix b/system/specialisation.nix new file mode 100644 index 0000000..c0e1498 --- /dev/null +++ b/system/specialisation.nix @@ -0,0 +1,24 @@ +{ pkgs, ... }: { + specialisation.dark-theme.configuration = { + nixpkgs.overlays = [ + (final: prev: { + uservars = prev.uservars; + }) + ]; + }; + specialisation.light-theme.configuration = { + nixpkgs.overlays = [ + (final: prev: { + uservars = prev.uservars // rec { + theme = prev.uservars.themes.light; + color = theme.color; + }; + }) + ]; + }; + environment.systemPackages = [ + (pkgs.writeShellScriptBin "theme" '' + sudo "/nix/var/nix/profiles/system/specialisation/$1-theme/bin/switch-to-configuration" test + '') + ]; +} diff --git a/system/steam.nix b/system/steam.nix new file mode 100644 index 0000000..996f16a --- /dev/null +++ b/system/steam.nix @@ -0,0 +1,26 @@ +{ config, pkgs, inputs, ... }: +let + pkgs' = import inputs.nixpkgs-fixed-steam { + inherit (pkgs) system config; + }; +in +{ + programs.steam.enable = true; + programs.steam.package = pkgs'.steam.override { + extraLibraries = pkgs: with config.hardware.opengl; + if pkgs.hostPlatform.is64bit + then [ package ] ++ extraPackages + else [ package32 ] ++ extraPackages32; + + extraPkgs = pkgs: with pkgs; [ + capitaine-cursors + bibata-cursors + mangohud + xdg-user-dirs + ]; + }; + environment.systemPackages = with pkgs; [ + protontricks + bottles + ]; +} diff --git a/system/thunar.nix b/system/thunar.nix index fcb9e3b..e3af8e7 100644 --- a/system/thunar.nix +++ b/system/thunar.nix @@ -1,10 +1,4 @@ -{ - config, - pkgs, - inputs, - ... -}: -{ +{ config, pkgs, inputs, ... }: { programs.thunar = { enable = true; plugins = with pkgs.xfce; [ @@ -16,17 +10,4 @@ services.gvfs.enable = true; # Thumbnail support for images services.tumbler.enable = true; - - environment.systemPackages = [ - (pkgs.writeTextFile { - name = "thumbs"; - text = '' - [Thumbnailer Entry] - TryExec=unzip - Exec=sh -c "${pkgs.unzip}/bin/unzip -p %i preview.png > %o" - MimeType=application/x-krita; - ''; - destination = "/share/thumbnailers/kra.thumbnailer"; - }) - ]; } diff --git a/system/users.nix b/system/users.nix deleted file mode 100644 index 4528a6a..0000000 --- a/system/users.nix +++ /dev/null @@ -1,30 +0,0 @@ -{ pkgs, ... }: -{ - security.sudo.wheelNeedsPassword = false; - - # services.getty.autologinUser = "lelgenio"; - programs.fish.enable = true; - - # Define a user account. Don't forget to set a password with ‘passwd’. - users.mutableUsers = false; - users.users.lelgenio = { - isNormalUser = true; - description = "Leonardo Eugênio"; - hashedPassword = "$y$j9T$0e/rczjOVCy7PuwC3pG0V/$gTHZhfO4wQSlFvbDyfghbCnGI2uDI0a52zSrQ/yOA5A"; - extraGroups = [ - "networkmanager" - "wheel" - "docker" - "adbusers" - "bluetooth" - "corectrl" - "vboxusers" - "input" - ]; - shell = pkgs.fish; - openssh.authorizedKeys.keys = [ - "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQCxR/w+38b2lX90yNBqhq3mUmkn1WGu6GAPhN1tVp2ZjYRJNV/+5gWCnTtOWYtDx35HmK/spQ2Qy8X9ttkzORa24fysNx1Iqn/TiXhD7eIJjbGPnrOpIKTkW5/uB3SD/P5NBSa06//BaqJU4sBlG79hoXRpod052hQtdpTVDiMCIV+iboWPKqopmJJfWdBtVnHXs9rep0htPRExxGslImFk7Z6xjcaHyCpIQZPlOGf+sGsmUU7jRqzvZFV8ucIdbnAlMHrU4pepNFhuraESyZVTa/bi9sw0iozXp5Q5+5thMebEslmT1Z771kI4sieDy+O4r8c0Sx2/VY1UAzcpq1faggc3YB01MTh+tiEC6xdMvZLrQGL1NBWjHleMyL53GU5ERluC0vXJF3Hv3BGGBDfXWbrEm5n06DHr2apRVJGC0LwiQ7Woud1X4V4X1pKSusxCVMjT2lmcOwV6YhKhB2sowJc1OdMx4+tL0UWE+YKSZgBHfolwk6ml0F4EO9nnUHc= lelgenio@i15" - ]; - }; - users.users.root.initialHashedPassword = "$y$j9T$E3aBBSSq0Gma8hZD9L7ov0$iCGDW4fqrXWfHO0qodBYYgMFA9CpIraoklHcPbJJrM3"; -} diff --git a/treefmt.nix b/treefmt.nix deleted file mode 100644 index 6c86ca2..0000000 --- a/treefmt.nix +++ /dev/null @@ -1,8 +0,0 @@ -{ pkgs, ... }: -{ - projectRootFile = "flake.nix"; - programs.nixfmt.enable = true; - programs.nixfmt.package = pkgs.nixfmt-rfc-style; - - settings.on-unmatched = "debug"; -} diff --git a/update b/update index 59bd11a..89694e6 100755 --- a/update +++ b/update @@ -1,4 +1,4 @@ #!/bin/sh nix flake update --verbose --print-build-logs -exec ./switch "$@" +./switch diff --git a/user/alacritty.nix b/user/alacritty.nix index eaaa414..313b573 100644 --- a/user/alacritty.nix +++ b/user/alacritty.nix @@ -1,16 +1,6 @@ -{ - config, - pkgs, - lib, - ... -}: +{ config, pkgs, lib, ... }: let - inherit (config.my) - key - theme - accent - font - ; + inherit (pkgs.uservars) key theme accent font; inherit (theme) color; in { @@ -20,9 +10,7 @@ in settings = { font = { size = font.size.small; - normal = { - family = font.mono; - }; + normal = { family = font.mono; }; }; colors = { primary = { @@ -43,8 +31,8 @@ in cyan = "${color.normal.cyan}"; white = "${color.normal.white}"; }; - draw_bold_text_with_bright_colors = false; }; + draw_bold_text_with_bright_colors = false; window = { opacity = theme.opacity / 100.0; dynamic_padding = true; @@ -52,35 +40,32 @@ in hints = { alphabet = key.hints; - enabled = [ - { - regex = - let - mimes = "(mailto:|gemini:|gopher:|https:|http:|news:|file:|git:|ssh:|ftp:)"; - # I fucking hate regex, look at this bullshit - delimiters = ''^\\u0000-\\u001F\\u007F-\\u009F<>"\\s{-}\\^⟨⟩`''; - # Kakoune uses these characters to represent whitespace, - # but alacritty doesn't know about them - whitespace_characters = ''¬·→''; - in - "${mimes}[${delimiters}${whitespace_characters}]+"; - command = "xdg-open"; - post_processing = true; - mouse = { - enabled = true; - mods = "None"; - }; - binding = { - key = "U"; - mods = "Control|Shift"; - }; - } - ]; + enabled = [{ + regex = + let + mimes = + "(mailto:|gemini:|gopher:|https:|http:|news:|file:|git:|ssh:|ftp:)"; + # I fucking hate regex, look at this bullshit + delimiters = ''^\\u0000-\\u001F\\u007F-\\u009F<>"\\s{-}\\^⟨⟩`''; + # Kakoune uses these characters to represent whitespace, + # but alacritty doesn't know about them + whitespace_characters = ''¬·→''; + in + "${mimes}[${delimiters}${whitespace_characters}]+"; + command = "xdg-open"; + post_processing = true; + mouse = { + enabled = true; + mods = "None"; + }; + binding = { + key = "U"; + mods = "Control|Shift"; + }; + }]; }; - mouse = { - hide_when_typing = true; - }; - keyboard.bindings = [ + mouse = { hide_when_typing = true; }; + key_bindings = [ { key = lib.toUpper key.up; mode = "Vi|~Search"; @@ -116,12 +101,6 @@ in mode = "Vi|~Search"; action = "SearchNext"; } - { - key = lib.toUpper key.next; - mods = "Shift"; - mode = "Vi|~Search"; - action = "SearchPrevious"; - } { key = "Up"; mods = "Control|Shift"; @@ -162,9 +141,7 @@ in }; }; - home.sessionVariables = { - TERMINAL = "alacritty"; - }; + home.sessionVariables = { TERMINAL = "alacritty"; }; # Look at this fucking bullshit: # https://gitlab.gnome.org/GNOME/glib/-/blob/20c4fcb2a7246a2b205649eae3ebda4296217afc/gio/gdesktopappinfo.c#L2702 diff --git a/user/bmenu.nix b/user/bmenu.nix index 1543dcf..047da54 100644 --- a/user/bmenu.nix +++ b/user/bmenu.nix @@ -1,17 +1,6 @@ -{ - config, - pkgs, - lib, - inputs, - ... -}: +{ config, pkgs, lib, inputs, ... }: let - inherit (config.my) - key - theme - accent - font - ; + inherit (pkgs.uservars) key theme accent font; inherit (theme) color; in { diff --git a/user/chat.nix b/user/chat.nix index b42f6fd..7e27892 100644 --- a/user/chat.nix +++ b/user/chat.nix @@ -1,23 +1,22 @@ -{ - config, - pkgs, - lib, - inputs, - ... -}: -{ +{ config, pkgs, lib, inputs, ... }: { wayland.windowManager.sway = { extraConfig = '' exec thunderbird - exec discordcanary + exec webcord exec telegram-desktop ''; }; + wayland.windowManager.hyprland.extraConfig = '' + exec-once = thunderbird + exec-once = webcord + exec-once = telegram-desktop + ''; + home.packages = with pkgs; [ tdesktop - discord-canary + webcord thunderbird - element-desktop + element-desktop-wayland ]; } diff --git a/user/controller.nix b/user/controller.nix new file mode 100644 index 0000000..73ab483 --- /dev/null +++ b/user/controller.nix @@ -0,0 +1,14 @@ +{ config, pkgs, lib, inputs, ... }: { + xdg.desktopEntries = { + connect-controller = { + name = "Connect Controller"; + exec = "bluetoothctl connect 84:30:95:97:1A:79"; + terminal = false; + }; + disconnect-controller = { + name = "Disconnect Controller"; + exec = "bluetoothctl disconnect 84:30:95:97:1A:79"; + terminal = false; + }; + }; +} diff --git a/user/desktop-entries.nix b/user/desktop-entries.nix index c513d45..cb42d40 100644 --- a/user/desktop-entries.nix +++ b/user/desktop-entries.nix @@ -1,10 +1,4 @@ -{ - config, - pkgs, - lib, - ... -}: -{ +{ config, pkgs, lib, ... }: { xdg.desktopEntries = { kak = { name = "Kakoune"; @@ -14,10 +8,7 @@ terminal = true; type = "Application"; icon = "kak.desktop"; - categories = [ - "Utility" - "TextEditor" - ]; + categories = [ "Utility" "TextEditor" ]; startupNotify = true; mimeType = [ "text/english" @@ -41,6 +32,19 @@ TryExec = "kak"; }; }; + neomutt = { + name = "Neomutt"; + genericName = "Email Client"; + comment = "View and Send Emails"; + exec = "neomutt %U"; + terminal = true; + type = "Application"; + icon = "mutt"; + categories = [ "Network" "Email" ]; + startupNotify = false; + mimeType = [ "x-scheme-handler/mailto" ]; + settings = { Keywords = "Mail;E-mail;"; }; + }; down_meme = { name = "DownMeme"; genericName = "Download memes"; @@ -50,14 +54,5 @@ icon = "download"; categories = [ "Network" ]; }; - readQrCode = { - name = "Read QR Code"; - genericName = "Read QR Code from clipboard image"; - exec = "readQrCode"; - terminal = true; - type = "Application"; - icon = "download"; - categories = [ "Network" ]; - }; }; } diff --git a/user/dummy.nix b/user/dummy.nix deleted file mode 100644 index 91e66cc..0000000 --- a/user/dummy.nix +++ /dev/null @@ -1,9 +0,0 @@ -{ lib, ... }: -{ - options.my = { - nix-ld.enable = lib.mkEnableOption { }; - android.enable = lib.mkEnableOption { }; - media-packages.enable = lib.mkEnableOption { }; - containers.enable = lib.mkEnableOption { }; - }; -} diff --git a/user/email.nix b/user/email.nix new file mode 100644 index 0000000..707cd33 --- /dev/null +++ b/user/email.nix @@ -0,0 +1,322 @@ +{ pkgs, lib, config, ... }: +let + inherit (pkgs.uservars.theme) color; + + downloadEmails = "${pkgs.offlineimap}/bin/offlineimap"; + afterSync = "${pkgs.notmuch}/bin/notmuch new"; + + defaultAccountSettings = { boxes, }: { + astroid.enable = true; + imapnotify = { + enable = true; + inherit boxes; + onNotify = downloadEmails; + }; + offlineimap = { + enable = true; + postSyncHookCommand = afterSync; + }; + msmtp.enable = true; + notmuch.enable = true; + }; +in +{ + accounts.email.maildirBasePath = "${config.xdg.dataHome}/maildir"; + accounts.email.accounts = + { + "personal" = { + primary = true; + realName = "Leonardo Eugênio"; + address = "lelgenio@disroot.org"; + userName = "lelgenio"; + imap.host = "disroot.org"; + smtp.host = "disroot.org"; + passwordCommand = toString (pkgs.writeShellScript "get_pass" '' + pass "disroot.org" | head -n1 + ''); + } // defaultAccountSettings { + boxes = [ + "INBOX" + "INBOX.Newsletter" + "INBOX.Git" + ]; + }; + "work" = { + realName = "Leonardo Eugênio"; + address = "leonardo@wopus.com.br"; + userName = "leonardo@wopus.com.br"; + imap.host = "imap.wopus.com.br"; + smtp.host = "smtp.wopus.com.br"; + passwordCommand = toString (pkgs.writeShellScript "get_pass" '' + pass "Trabalho/wopus_email/leonardo@wopus.com.br" | head -n1 + ''); + } // defaultAccountSettings { boxes = [ "INBOX" ]; }; + }; + + services.imapnotify.enable = true; + + programs.offlineimap.enable = true; + systemd.user.services.offlineimap = { + Unit = { + Description = "offlineimap mailbox synchronization"; + }; + Service = { + Type = "oneshot"; + ExecStart = downloadEmails; + }; + }; + systemd.user.timers.offlineimap = { + Unit = { Description = "offlineimap mailbox synchronization"; }; + Timer = { + OnCalendar = "*:0/5"; + Unit = "offlineimap.service"; + }; + Install = { WantedBy = [ "timers.target" ]; }; + }; + + systemd.user.services.maildir-notify-daemon = { + Unit = { + Description = "Desktop notification for new email"; + PartOf = [ "graphical-session.target" ]; + After = [ "graphical-session.target" ]; + }; + Service = { + ExecStart = toString (pkgs.writeShellScript "maildir-notify-daemon-service" '' + exec ${pkgs.maildir-notify-daemon}/bin/maildir-notify-daemon $HOME/Maildir/*/*/new + ''); + Restart = "on-failure"; + }; + Install = { WantedBy = [ "sway-session.target" ]; }; + }; + + programs.notmuch.enable = true; + + programs.msmtp.enable = true; + + programs.astroid = { + enable = true; + externalEditor = "terminal -e $EDITOR %1"; + pollScript = downloadEmails; + extraConfig = { }; + }; + + xdg.configFile = lib.mkIf (color.type == "dark") { + "astroid/ui/thread-view.scss".text = '' + /* ui-version: 5 (do not change when modifying theme for yourself) */ + + * { + color: #ffffff !important; + background-color: #181818 !important; + } + + @import '${pkgs.astroid}/share/astroid/ui/thread-view.scss'; + ''; + "astroid/ui/part.scss".text = '' + /* ui-version: 5 (do not change when modifying theme for yourself) */ + + * { + color: #eee !important; + background-color: #202020 !important; + } + + // @import '${pkgs.astroid}/share/astroid/ui/part.scss'; + ''; + "astroid/keybindings".text = '' + + help.down=e + help.page_down=E + log.down=e + log.page_down=E + raw.down=e + raw.page_down=E + searches.down=e + searches.page_down=E + thread_index.scroll_down=E + thread_index.next_thread=e + thread_view.down=e + thread_view.scroll_down=E + + help.up=i + help.page_up=I + log.up=i + log.page_up=I + raw.up=i + raw.page_up=I + searches.up=i + searches.page_up=I + thread_index.scroll_up=I + thread_index.previous_thread=i + thread_view.up=i + thread_view.scroll_up=I + + thread_index.page_up=C-u + thread_view.page_up=C-u + + thread_index.page_down=C-n + thread_view.page_down=C-n + + thread_view.next_message=l + + thread_view.toggle_unread=N + + main_window.previous_page=n + main_window.next_page=o + + # searches.next_unread=Key (GDK_KEY_Tab) # Jump to next unread thread, default: Key (GDK_KEY_Tab) + # thread_index.previous_unread=Key (false, false, (guint) GDK_KEY_ISO_Left_Tab) # Jump to previous unread thread, default: Key (false, false, (guint) GDK_KEY_ISO_Left_Tab) + + # main_window.quit_ask=q # Quit astroid, default: q + # main_window.quit=Q # Quit astroid (without asking), default: Q + # main_window.jump_to_page_1=M-1 # Jump to page 1, default: M-1 + # main_window.jump_to_page_2=M-2 # Jump to page 2, default: M-2 + # main_window.jump_to_page_3=M-3 # Jump to page 3, default: M-3 + # main_window.jump_to_page_4=M-4 # Jump to page 4, default: M-4 + # main_window.jump_to_page_5=M-5 # Jump to page 5, default: M-5 + # main_window.jump_to_page_6=M-6 # Jump to page 6, default: M-6 + # main_window.jump_to_page_7=M-7 # Jump to page 7, default: M-7 + # main_window.jump_to_page_8=M-8 # Jump to page 8, default: M-8 + # main_window.jump_to_page_9=M-9 # Jump to page 9, default: M-9 + # main_window.jump_to_page_0=M-0 # Jump to page 0, default: M-0 + # main_window.close_page=C-w # Close mode (or window if other windows are open), default: C-w + # main_window.close_page_force=C-W # Force close mode (or window if other windows are open), default: C-W + # main_window.search=o # Search, default: o + # main_window.show_saved_searches=M-s # Show saved searches, default: M-s + # main_window.show_help=Key (GDK_KEY_question) # Show help, default: Key (GDK_KEY_question) + # main_window.show_log=z # Show log window, default: z + # main_window.undo=u # Undo last action, default: u + # main_window.new_mail=m # Compose new mail, default: m + # main_window.poll=P # Start manual poll, default: P + # main_window.toggle_auto_poll=M-p # Toggle auto poll, default: M-p + # main_window.cancel_poll=C-c # Cancel ongoing poll, default: C-c + # main_window.open_new_window=C-o # Open new main window, default: C-o + # main_window.clipboard=\" # Set target clipboard, default: \" + # main_window.clipboard.clipboard=+ # Set target clipboard to CLIPBOARD (default), default: + + # main_window.clipboard.primary=* # Set target clipboard to PRIMARY, default: * + # main_window.open_terminal=| # Open terminal, default: | + # edit_message.edit=Key (GDK_KEY_Return) # Edit message in editor, default: Key (GDK_KEY_Return), Key (GDK_KEY_KP_Enter) + # edit_message.send=y # Send message, default: y + # edit_message.cancel=C-c # Cancel sending message (unreliable), default: C-c + # edit_message.view_raw=V # View raw message, default: V + # edit_message.cycle_from=f # Cycle through From selector, default: f + # edit_message.attach=a # Attach file, default: a + # edit_messsage.attach_mids=A # Attach messages by mids, default: A + # edit_message.save_draft=s # Save draft, default: s + # edit_message.delete_draft=D # Delete draft, default: D + # edit_message.toggle_signature=S # Toggle signature, default: S + # edit_message.toggle_encrypt=E # Toggle encryption and signature, default: E + # help.page_top=1 # Scroll to top, default: 1, Key (GDK_KEY_Home) + # help.page_end=0 # Scroll to end, default: 0, Key (GDK_KEY_End) + # log.home=1 # Scroll home, default: 1, Key (GDK_KEY_Home) + # log.end=0 # Scroll to end, default: 0, Key (GDK_KEY_End) + # pane.swap_focus=Key (false, true, (guint) GDK_KEY_space) # Swap focus to other pane if open, default: Key (false, true, (guint) GDK_KEY_space) + # raw.home=1 # Scroll home, default: 1, Key (GDK_KEY_Home) + # raw.end=0 # Scroll to end, default: 0, Key (GDK_KEY_End) + # reply.cycle_reply_to=r # Cycle through reply selector, default: r + # reply.open_reply_to=R # Open reply selector, default: R + # searches.save=s # Save recent query as saved search, default: s + # searches.delete=d # Delete saved query, default: d + # searches.clear_history=C # Clear search history, default: C + # searches.home=1 # Scroll home, default: 1, Key (GDK_KEY_Home) + # searches.end=0 # Scroll to end, default: 0, Key (GDK_KEY_End) + # searches.previous_unread=Key (false, false, (guint) GDK_KEY_ISO_Left_Tab) # Jump to previous unread thread, default: Key (false, false, (guint) GDK_KEY_ISO_Left_Tab) + # searches.open=Key (GDK_KEY_Return) # Open query, default: Key (GDK_KEY_Return), Key (GDK_KEY_KP_Enter) + # searches.show_all_history=! # Show all history lines, default: ! + # thread_index.close_pane=C-w # Close thread view pane if open, default: C-w + # thread_index.refresh=Key((guint) GDK_KEY_dollar) # Refresh query, default: Key((guint) GDK_KEY_dollar) + # thread_index.refine_query=O # Refine query, default: O + # thread_index.duplicate_refine_query=C-v # Duplicate and refine query, default: C-v + # thread_index.cycle_sort=C-s # "Cycle through sort options: 'oldest', default: C-s + # thread_index.save_query=C-S # Save query, default: C-S + # thread_index.next_unread=Key (GDK_KEY_Tab) # Jump to next unread thread, default: Key (GDK_KEY_Tab) + # thread_index.filter=C-f # Filter rows, default: C-f + # thread_index.filter_clear=Key (GDK_KEY_Escape) # Clear filter, default: Key (GDK_KEY_Escape) + # thread_index.multi.mark_unread=N # Toggle unread, default: N + # thread_index.multi.flag=* # Toggle flagged, default: * + # thread_index.multi.archive=a # Toggle archive, default: a + # thread_index.multi.mark_spam=S # Toggle spam, default: S + # thread_index.multi.tag=+ # Tag, default: + + # thread_index.multi.mute=C-m # Toggle mute, default: C-m + # thread_index.multi.toggle=t # Toggle marked, default: t + # thread_index.multi=Key (GDK_KEY_semicolon) # Apply action to marked threads, default: Key (GDK_KEY_semicolon) + # thread_index.scroll_home=1 # Scroll to first line, default: 1, Key(GDK_KEY_Home) + # thread_index.scroll_end=0 # Scroll to last line, default: 0, Key (GDK_KEY_End) + # thread_index.open_thread=Key (GDK_KEY_Return) # Open thread, default: Key (GDK_KEY_Return), Key (GDK_KEY_KP_Enter) + # thread_index.open_paned=Key (false, true, (guint) GDK_KEY_Return) # Open thread in pane, default: Key (false, true, (guint) GDK_KEY_Return), Key (false, true, (guint) GDK_KEY_KP_Enter) + # thread_index.open_new_window=Key (true, false, (guint) GDK_KEY_Return) # Open thread in new window, default: Key (true, false, (guint) GDK_KEY_Return), Key (true, false, (guint) GDK_KEY_KP_Enter) + # thread_index.reply=r # Reply to last message in thread, default: r + # thread_index.reply_all=G # Reply all to last message in thread, default: G + # thread_index.reply_sender=R # Reply to sender of last message in thread, default: R + # thread_index.reply_mailinglist=M # Reply to mailinglist of last message in thread, default: M + # thread_index.forward=f # Forward last message in thread, default: f + # thread_index.toggle_marked_next=t # Toggle mark thread and move to next, default: t + # thread_index.toggle_marked_all=T # Toggle marked on all loaded threads, default: T + # thread_index.archive=a # Toggle 'inbox' tag on thread, default: a + # thread_index.flag=Key (GDK_KEY_asterisk) # Toggle 'flagged' tag on thread, default: Key (GDK_KEY_asterisk) + # thread_index.unread=N # Toggle 'unread' tag on thread, default: N + # thread_index.spam=S # Toggle 'spam' tag on thread, default: S + # thread_index.mute=C-m # "Toggle 'muted' tag on thread, default: C-m + # thread_index.tag=+ # Edit tags for thread, default: + + # thread_index.edit_draft=E # Edit first message marked as draft or last message in thread as new, default: E + # thread_view.reload=$ # Reload everything, default: $ + # thread_view.show_web_inspector=C-I # Show web inspector, default: C-I + # thread_view.next_element=C-j # Move focus to next element, default: C-j + # thread_view.previous_element=C-k # Move focus to previous element, default: C-k + # thread_view.home=1 # Scroll home, default: 1, Key (GDK_KEY_Home) + # thread_view.end=0 # Scroll to end, default: 0, Key (GDK_KEY_End) + # thread_view.activate=Key (GDK_KEY_Return) # Open/expand/activate focused element, default: Key (GDK_KEY_Return), Key (GDK_KEY_KP_Enter), Key (true, false, (guint) GDK_KEY_space) + # thread_view.save=s # Save attachment or message, default: s + # thread_view.delete_attachment=d # Delete attachment (if editing), default: d + # thread_view.expand=e # Toggle expand, default: e + # thread_view.toggle_expand_all=C-e # Toggle expand on all messages, default: C-e + # thread_view.mark=t # Mark or unmark message, default: t + # thread_view.toggle_mark_all=T # Toggle mark on all messages, default: T + # thread_view.show_remote_images=C-i # Show remote images (warning: approves all requests to remote content for this thread!), default: C-i + # thread_view.zoom_in=C-+ # Zoom in, default: C-+ + # thread_view.zoom_out=C-minus # Zoom out, default: C-minus + # thread_view.save_all_attachments=S # Save all attachments, default: S + # thread_view.next_message_expand=C-n # Focus next message (and expand if necessary), default: C-n + # thread_view.previous_message=p # Focus previous message, default: p + # thread_view.previous_message_expand=C-p # Focus previous message (and expand if necessary), default: C-p + # thread_view.next_unread=Key (GDK_KEY_Tab) # Focus the next unread message, default: Key (GDK_KEY_Tab) + # thread_view.previous_unread=Key (false, false, (guint) GDK_KEY_ISO_Left_Tab) # Focus the previous unread message, default: Key (false, false, (guint) GDK_KEY_ISO_Left_Tab) + # thread_view.compose_to_sender=c # Compose a new message to the sender of the message (or all recipients if sender is you), default: c + # thread_view.reply=r # Reply to current message, default: r + # thread_view.reply_all=G # Reply all to current message, default: G + # thread_view.reply_sender=R # Reply to sender of current message, default: R + # thread_view.reply_mailinglist=M # Reply to mailinglist of current message, default: M + # thread_view.forward=f # Forward current message, default: f + # thread_view.flat=C-F # Toggle flat or indented view of messages, default: C-F + # thread_view.view_raw=V # View raw source for current message, default: V + # thread_view.edit_draft=E # Edit currently focused message as new or draft, default: E + # thread_view.delete_draft=D # Delete currently focused draft, default: D + # thread_view.multi.toggle=t # Toggle marked, default: t + # thread_view.multi.tag=+ # Tag, default: + + # thread_view.multi.yank_mids=C-y # Yank message id's, default: C-y + # thread_view.multi.yank=y # Yank, default: y + # thread_view.multi.yank_raw=Y # Yank raw, default: Y + # thread_view.multi.save=s # Save marked, default: s + # thread_view.multi.print=p # Print marked messages, default: p + # thread_view.multi=Key (GDK_KEY_semicolon) # Apply action to marked messages, default: Key (GDK_KEY_semicolon) + # thread_view.flag=* # Toggle the 'flagged' tag on the message, default: * + # thread_view.archive_thread=a # Toggle 'inbox' tag on the whole thread, default: a + # thread_view.print=C-P # Print focused message, default: C-P + # thread_view.tag_message=+ # Tag message, default: + + # thread_view.search.search_or_next=C-f # Search for text or go to next match, default: C-f + # thread_view.search.cancel=GDK_KEY_Escape # Cancel current search, default: GDK_KEY_Escape + # thread_view.search.previous=P # Go to previous match, default: P + # thread_view.yank=y # Yank current element or message text to clipboard, default: y + # thread_view.yank_raw=Y # Yank raw content of current element or message to clipboard, default: Y + # thread_view.yank_mid=C-y # Yank the Message-ID of the focused message to clipboard, default: C-y + # thread_view.multi_next_thread=Key (":") # Open next after.., default: Key (":") + # thread_view.multi_next_thread.archive=Key ("a") # "Archive, default: Key ("a") + # thread_view.multi_next_thread.archive_next_unread_thread=Key ("A") # "Archive, default: Key ("A") + # thread_view.multi_next_thread.close=Key ("x") # "Archive, default: Key ("x") + # thread_view.multi_next_thread.next_thread=Key ("j") # Goto next, default: Key ("j") + # thread_view.multi_next_thread.previous_thread=Key ("k") # Goto previous, default: Key ("k") + # thread_view.multi_next_thread.next_unread=Key (GDK_KEY_Tab) # Goto next unread, default: Key (GDK_KEY_Tab) + # thread_view.multi_next_thread.previous_unread=Key (false, false, (guint) GDK_KEY_ISO_Left_Tab) # Goto previous unread, default: Key (false, false, (guint) GDK_KEY_ISO_Left_Tab) + + + ''; + }; +} diff --git a/user/firefox.nix b/user/firefox.nix index d15e569..4699999 100644 --- a/user/firefox.nix +++ b/user/firefox.nix @@ -1,17 +1,12 @@ -{ - config, - pkgs, - ... -}: -let - inherit (config.my.theme) color; - - bugfixedFirefox = pkgs.firefox-devedition-unwrapped // { - requireSigning = false; - allowAddonSideload = true; +{ config, pkgs, lib, font, ... }: +let inherit (pkgs.uservars) desktop browser; + bugfixedFirefox = pkgs.firefox-esr-unwrapped // { requireSigning = false; allowAddonSideload = true; }; + cfg = config.packages.firefox; +in { + options.packages.firefox = { + hideTitleBar = lib.mkEnableOption "Hide firefox title bar"; }; -in -{ + config = { programs.firefox = { enable = true; @@ -27,28 +22,16 @@ in url = "https://addons.mozilla.org/firefox/downloads/file/4202411/sponsorblock-5.4.29.xpi"; hash = "sha256-7Xqc8cyQNylMe5/dgDOx1f2QDVmz3JshDlTueu6AcSg="; }) - # (pkgs.fetchFirefoxAddon { - # name = "tree-style-tab"; - # url = "https://addons.mozilla.org/firefox/downloads/file/4197314/tree_style_tab-3.9.19.xpi"; - # hash = "sha256-u2f0elVPj5N/QXa+5hRJResPJAYwuT9z0s/0nwmFtVo="; - # }) + (pkgs.fetchFirefoxAddon { + name = "tree-style-tab"; + url = "https://addons.mozilla.org/firefox/downloads/file/4197314/tree_style_tab-3.9.19.xpi"; + hash = "sha256-u2f0elVPj5N/QXa+5hRJResPJAYwuT9z0s/0nwmFtVo="; + }) (pkgs.fetchFirefoxAddon { name = "ublock-origin"; - url = "https://addons.mozilla.org/firefox/downloads/file/4492375/ublock_origin-1.64.0.xpi"; - hash = "sha256-ueHIaL0awd78q/LgF3bRqQ7/ujSwf+aiE1DUXwIuDp8="; + url = "https://addons.mozilla.org/firefox/downloads/file/4198829/ublock_origin-1.54.0.xpi"; + hash = "sha256-l5cWCQgZFxD/CFhTa6bcKeytmSPDCyrW0+XjcddZ5E0="; }) - (pkgs.fetchFirefoxAddon { - name = "user_agent_string_switcher"; - url = "https://addons.mozilla.org/firefox/downloads/file/4098688/user_agent_string_switcher-0.5.0.xpi"; - hash = "sha256-ncjaPIxG1PBNEv14nGNQH6ai9QL4WbKGk5oJDbY+rjM="; - }) - - (pkgs.fetchFirefoxAddon { - name = "i-still-dont-care-about-cookies"; - url = "https://github.com/OhMyGuus/I-Still-Dont-Care-About-Cookies/releases/download/v1.1.4/istilldontcareaboutcookies-1.1.4.xpi"; - hash = "sha256-yt6yRiLTuaK4K/QwgkL9gCVGsSa7ndFOHqZvKqIGZ5U="; - }) - (pkgs.fetchFirefoxAddon { name = "vimium_ff"; url = "https://addons.mozilla.org/firefox/downloads/file/4191523/vimium_ff-2.0.6.xpi"; @@ -56,19 +39,13 @@ in }) (pkgs.fetchFirefoxAddon { name = "unhook"; - url = "https://addons.mozilla.org/firefox/downloads/file/4263531/youtube_recommended_videos-1.6.7.xpi"; - hash = "sha256-u21ouN9IyOzkTkFSeDz+QBp9psJ1F2Nmsvqp6nh0DRU="; + url = "https://addons.mozilla.org/firefox/downloads/file/4050795/youtube_recommended_videos-1.6.2.xpi"; + hash = "sha256-xMuglNassZb9WqjfEGg6WeuhMACRuYqQor+iX1dEdsE="; }) - # (pkgs.fetchFirefoxAddon { - # name = "invidious_redirect"; - # url = "https://addons.mozilla.org/firefox/downloads/file/4292924/invidious_redirect_2-1.16.xpi"; - # hash = "sha256-ApCc+MNmW9Wd/5seV6npePQVEaszT/rhD9EB7HGiUb8="; - # }) - (pkgs.fetchFirefoxAddon { - name = "substitoot"; - url = "https://addons.mozilla.org/firefox/downloads/file/4236602/substitoot-0.7.2.0.xpi"; - hash = "sha256-1auSqEjkebwRSbmAVUsYwy77dl7TQCOnqgozpoVnqgI="; + name = "mastodon_simplified_federation"; + url = "https://addons.mozilla.org/firefox/downloads/file/4215691/mastodon_simplified_federation-2.2.xpi"; + hash = "sha256-4iU25chpjsdsMTPaa0yQOTWc9V9q1qFz6YV0lYtNjLA="; }) # Locale @@ -85,16 +62,12 @@ in ]; }; profiles = { - dev-edition-default = { + main = { isDefault = true; - search.force = true; - search.default = "ddg"; settings = { "devtools.theme" = "auto"; "toolkit.legacyUserProfileCustomizations.stylesheets" = true; - "sidebar.position_start" = false; # Move sidebar to the right - - "browser.tabs.groups.enabled" = true; + "browser.tabs.inTitlebar" = if desktop == "sway" then 0 else 1; # enable media RDD to allow gpu acceleration "media.rdd-ffmpeg.enabled" = true; @@ -107,11 +80,13 @@ in "media.rdd-vpx.enabled" = true; "media.rdd-wav.enabled" = true; - "media.av1.enabled" = true; + "media.av1.enabled" = false; "media.ffmpeg.vaapi-drm-display.enabled" = true; "media.ffmpeg.vaapi.enabled" = true; "media.ffvpx.enabled" = true; + "gfx.webrender.all" = true; + # Enable installing non signed extensions "extensions.langpacks.signatures.required" = false; "xpinstall.signatures.required" = false; @@ -122,22 +97,21 @@ in "devtools.chrome.enabled" = true; "devtools.debugger.remote-enabled" = true; }; - userChrome = '' - #sidebar-main { - background-color: ${color.bg}; - } - - #tabbrowser-tabbox { - outline-width: 0 !important; - } + userChrome = lib.mkIf cfg.hideTitleBar '' + #titlebar { display: none !important; } + #sidebar-header { display: none !important; } ''; }; }; }; wayland.windowManager.sway = { extraConfig = '' - exec firefox-devedition + exec firefox ''; }; + home.sessionVariables = { + MOZ_ENABLE_WAYLAND = "1"; + MOZ_DISABLE_RDD_SANDBOX = "1"; + }; }; } diff --git a/user/fish/completions/todo.fish b/user/fish/completions/todo.fish new file mode 100644 index 0000000..8c0bb32 --- /dev/null +++ b/user/fish/completions/todo.fish @@ -0,0 +1,124 @@ +set __fish_complete_todoman_subcomands cancel copy delete done edit flush list move new show +function __fish_complete_todoman_not_subcomand + not __fish_seen_subcommand_from $__fish_complete_todoman_subcomands +end + +function __fish_complete_todoman_list_todos + todo list | + string replace -r '^\[.\] ' "" | + string replace -r ' ' '\t' | + string replace -r '\t!*' '\t' | + string replace -r '\(.*?\)' "" +end + +function __fish_complete_todoman_config_path + set -q XDG_CONFIG_DIR + or set -l XDG_CONFIG_DIR "$HOME/.config" + + set -l config_path "$XDG_CONFIG_DIR/todoman/config.py" + + test -f "$config_path" + and echo "$config_path" +end + +function __fish_complete_todoman_lists_dir + set -l config_path (__fish_complete_todoman_config_path) + or return + + # looks something like "~/.local/share/calendars/*" + string replace -fr 'path\s*=\s*"(.*)"\s*$' '$1' < $config_path | + string replace -r '^~' "$HOME" | + string replace -r '\*$' '' +end + +function __fish_complete_todoman_list_lists + set -l lists_path (__fish_complete_todoman_lists_dir) + string replace -r '.*/(.*?)$' '$1' $lists_path/* +end + + +#### Initial command definition #### +complete --erase todo +complete -c todo -f + +#### Base command flags #### +complete -c todo -n __fish_complete_todoman_not_subcomand -s v -l verbosity -a "CRITICAL ERROR WARNING INFO DEBUG" +complete -c todo -n __fish_complete_todoman_not_subcomand -l colour -l color -a "always auto never" +complete -c todo -n __fish_complete_todoman_not_subcomand -l porcelain -a "Use a stable JSON format" +complete -c todo -n __fish_complete_todoman_not_subcomand -s h -l humanize -a "Format all dates and times in a human friendly way" +complete -c todo -n __fish_complete_todoman_not_subcomand -s c -l config -a "The config file to use." +complete -c todo -n __fish_complete_todoman_not_subcomand -l version -d "Show the version and exit." +complete -c todo -n __fish_complete_todoman_not_subcomand -l help -d "Show this message and exit." + +#### Subcommands #### +complete -c todo -n __fish_complete_todoman_not_subcomand -a cancel -d 'Cancel one or more tasks' +complete -c todo -n __fish_complete_todoman_not_subcomand -a copy -d 'Copy tasks to another list' +complete -c todo -n __fish_complete_todoman_not_subcomand -a delete -d 'Delete tasks' +complete -c todo -n __fish_complete_todoman_not_subcomand -a done -d 'Mark one or more tasks as done' +complete -c todo -n __fish_complete_todoman_not_subcomand -a edit -d 'Edit the task with id ID' +complete -c todo -n __fish_complete_todoman_not_subcomand -a flush -d 'Delete done tasks' +complete -c todo -n __fish_complete_todoman_not_subcomand -a list -d 'List tasks' +complete -c todo -n __fish_complete_todoman_not_subcomand -a move -d 'Move tasks to another list' +complete -c todo -n __fish_complete_todoman_not_subcomand -a new -d 'Create a new task with SUMMARY' +complete -c todo -n __fish_complete_todoman_not_subcomand -a show -d 'Show details about a task' + +#### Subcommand flags #### + +complete -c todo -n "__fish_seen_subcommand_from cancel" -a "(__fish_complete_todoman_list_todos)" -d 'Cancel one or more tasks.' +complete -c todo -n "__fish_seen_subcommand_from cancel" -l help -d 'Show this message and exit.' + +complete -c todo -n "__fish_seen_subcommand_from copy" -a "(__fish_complete_todoman_list_todos)" -d 'Cancel one or more tasks.' +complete -c todo -n "__fish_seen_subcommand_from copy" -s l -l list -d 'The list to copy the tasks to.' +complete -c todo -n "__fish_seen_subcommand_from copy" -l help -d 'Show this message and exit.' + +complete -c todo -n "__fish_seen_subcommand_from delete" -a "(__fish_complete_todoman_list_todos)" -d 'Delete tasks.' +complete -c todo -n "__fish_seen_subcommand_from delete" -l yes -d 'Confirm the action without prompting.' +complete -c todo -n "__fish_seen_subcommand_from delete" -l help -d 'Show this message and exit.' + +complete -c todo -n "__fish_seen_subcommand_from done" -a "(__fish_complete_todoman_list_todos)" -d 'Mark one or more tasks as done.' +complete -c todo -n "__fish_seen_subcommand_from done" -l help -d 'Show this message and exit.' + +complete -c todo -n "__fish_seen_subcommand_from edit" -a "(__fish_complete_todoman_list_todos)" -d 'Edit the task with id ID.' +complete -c todo -n "__fish_seen_subcommand_from edit" -l raw -d 'Open the raw file for editing in $EDITOR. Only use this' +complete -c todo -n "__fish_seen_subcommand_from edit" -s s -l start -r -d 'When the task starts.' +complete -c todo -n "__fish_seen_subcommand_from edit" -s d -l due -r -d 'Due date of the task, in the format specified in the configuration.' +complete -c todo -n "__fish_seen_subcommand_from edit" -l location -r -d 'The location where this todo takes place.' +complete -c todo -n "__fish_seen_subcommand_from edit" -l priority -r -d 'Priority for this task' +complete -c todo -n "__fish_seen_subcommand_from edit" -s i -l interactive -r -d 'Go into interactive mode before saving the task.' +complete -c todo -n "__fish_seen_subcommand_from edit" -l help -d 'Show this message and exit.' + +complete -c todo -n "__fish_seen_subcommand_from flush" -d 'Delete done tasks. This will also clear the cache to reset task IDs.' +complete -c todo -n "__fish_seen_subcommand_from flush" -l yes -d 'Confirm the action without prompting.' +complete -c todo -n "__fish_seen_subcommand_from flush" -l help -d 'Show this message and exit.' + +complete -c todo -n "__fish_seen_subcommand_from flush" -d 'Delete done tasks. This will also clear the cache to reset task IDs.' +complete -c todo -n "__fish_seen_subcommand_from flush" -l yes -d 'Confirm the action without prompting.' +complete -c todo -n "__fish_seen_subcommand_from flush" -l help -d 'Show this message and exit.' + +complete -c todo -n "__fish_seen_subcommand_from list" -a "(__fish_complete_todoman_list_lists)" -d 'List tasks by list name' +complete -c todo -n "__fish_seen_subcommand_from list" -l location -r -d 'Only show tasks with location containg TEXT' +complete -c todo -n "__fish_seen_subcommand_from list" -l category -d "Only show tasks with category containg" +complete -c todo -n "__fish_seen_subcommand_from list" -l grep -d "Only show tasks with message containg" +complete -c todo -n "__fish_seen_subcommand_from list" -l sort -d "Sort tasks by field" -a "description location status summary uid rrule percent_complete priority sequence categories completed_at created_at dtstamp start due last_modified" +complete -c todo -n "__fish_seen_subcommand_from list" -l reverse -l no-reverse -d 'Sort tasks in reverse order (see --sort)' +complete -c todo -n "__fish_seen_subcommand_from list" -l due -d 'Only show tasks due in INTEGER hours' +complete -c todo -n "__fish_seen_subcommand_from list" -l priority -r -d 'Only show tasks with priority at least as high as' -a "low medium high" +complete -c todo -n "__fish_seen_subcommand_from list" -l start -r -d "Only shows tasks before/after given DATE" +complete -c todo -n "__fish_seen_subcommand_from list" -l startable -d "Show only todos which should can be started today" +complete -c todo -n "__fish_seen_subcommand_from list" -s s -l status -r -d "Show only todos with the provided comma-separated" -a "NEEDS-ACTION CANCELLED COMPLETED IN-PROCESS ANY" +complete -c todo -n "__fish_seen_subcommand_from list" -l help -d "Show this message and exit." + +complete -c todo -n "__fish_seen_subcommand_from move" -a "(__fish_complete_todoman_list_todos)" -d 'Move tasks to another list.' +complete -c todo -n "__fish_seen_subcommand_from move" -s l -l list -a "(__fish_complete_todoman_list_lists)" -d 'The list to move the tasks to.' +complete -c todo -n "__fish_seen_subcommand_from move" -l help -d 'Show this message and exit.' + +complete -c todo -n "__fish_seen_subcommand_from new" -d 'Create a new task with SUMMARY.' +complete -c todo -n "__fish_seen_subcommand_from new" -s l -l list -a "(__fish_complete_todoman_list_lists)" -d 'List in which the task will be saved.' +complete -c todo -n "__fish_seen_subcommand_from new" -s r -l read-description -d 'Read task description from stdin.' +complete -c todo -n "__fish_seen_subcommand_from new" -s s -l start -d 'When the task starts.' +complete -c todo -n "__fish_seen_subcommand_from new" -s d -l due -d 'Due date of the task, in the format specified in the configuration.' +complete -c todo -n "__fish_seen_subcommand_from new" -l location -d 'The location where this todo takes place.' +complete -c todo -n "__fish_seen_subcommand_from new" -s i -l interactive -d 'Go into interactive mode before saving the task.' +complete -c todo -n "__fish_seen_subcommand_from new" -l help -d 'Show this message and exit.' + +complete -c todo -n "__fish_seen_subcommand_from show" -a "(__fish_complete_todoman_list_todos)" -d 'Show details about a task.' diff --git a/user/fish/default.nix b/user/fish/default.nix index 830d716..344207e 100644 --- a/user/fish/default.nix +++ b/user/fish/default.nix @@ -1,17 +1,7 @@ -{ - config, - pkgs, - lib, - ... -}: -let - inherit (config.my) accent editor desktop; - cfg = config.my.fish; -in -{ - options.my.fish.enable = lib.mkEnableOption { }; - - config = lib.mkIf cfg.enable { +{ config, pkgs, lib, ... }: +let inherit (pkgs.uservars) key theme color accent font editor desktop; +in { + config = { programs.fish = { enable = true; shellInit = '' @@ -35,6 +25,8 @@ in set_color normal bind \cy 'commandline | wl-copy -n' + + ${pkgs.todoman}/bin/todo list ''; shellAliases = { rm = "trash"; @@ -42,18 +34,16 @@ in }; shellAbbrs = { off = "shutdown now"; - v = - { - "helix" = "hx"; - "kakoune" = "kak"; - } - .${editor}; + v = { + "helix" = "hx"; + "kakoune" = "kak"; + }.${editor}; ns = "nix develop --command $SHELL"; wcf = "wl-copy-file"; c = "cargo"; # system sv = "sudo systemct"; - suv = "systemct --user"; + suv = "sudo systemct --user"; # docker abbrs d = "docker"; dc = "docker-compose"; @@ -74,18 +64,21 @@ in gr = "cd (git root)"; gri = "git rebase --interactive FETCH_HEAD"; }; - functions = { - fish_greeting = ""; - }; + functions = { fish_greeting = ""; }; }; programs = { zoxide.enable = true; eza.enable = true; + eza.enableAliases = true; direnv.enable = true; direnv.nix-direnv.enable = true; }; xdg.configFile = { "fish/conf.d/prompt.fish".source = ./fish_prompt.fish; + "fish/completions/" = { + recursive = true; + source = ./completions; + }; "fish/conf.d/" = { recursive = true; source = ./conf.d; @@ -93,18 +86,13 @@ in }; # programs.command-not-found.enable = true; programs.nix-index.enable = true; - home.packages = ( - with pkgs; - with fishPlugins; - [ - trash-cli - wl-copy-file - foreign-env - ] - ++ (lib.optionals (desktop == "sway") [ - async-prompt - done - ]) - ); + home.packages = (with pkgs; with fishPlugins;[ + trash-cli + wl-copy-file + foreign-env + ] ++ (lib.optionals (desktop == "sway") [ + async-prompt + done + ])); }; } diff --git a/user/fish/fish_prompt.fish b/user/fish/fish_prompt.fish index ec7774e..2cba6be 100644 --- a/user/fish/fish_prompt.fish +++ b/user/fish/fish_prompt.fish @@ -51,7 +51,6 @@ end function _fish_prompt_git_unpushed_branches timeout 5s git log \ --branches \ - --decorate-refs-exclude=refs/tags \ --simplify-by-decoration \ --not \ --remotes \ @@ -104,29 +103,29 @@ function fish_git_prompt _fish_prompt_warn "init" end - # if we have at least one commit - if git rev-parse HEAD -- &>/dev/null - # print a "↑" if ahead of origin - test 0 -ne (git log --oneline "$git_remote_branch"..HEAD -- | wc -l) - and set -f _git_sync_ahead '↑' + git rev-parse HEAD -- &>/dev/null + or return - # print a "↓" if behind of origin - test 0 -lt (git log --oneline HEAD.."$git_remote_branch" -- | wc -l) - and set -l _git_sync_behind '↓' + # print a "↑" if ahead of origin + test 0 -ne (git log --oneline "$git_remote_branch"..HEAD -- | wc -l) + and set -f _git_sync_ahead '↑' - if set -q _git_sync_ahead _git_sync_behind - _fish_prompt_normal '⇅' - else if set -q _git_sync_ahead - _fish_prompt_normal '↑' - else if set -q _git_sync_behind - _fish_prompt_normal '↓' - end + # print a "↓" if behind of origin + test 0 -lt (git log --oneline HEAD.."$git_remote_branch" -- | wc -l) + and set -l _git_sync_behind '↓' - if test -n "$git_log_unpushed" - and not string match -qr "$git_branch" "$git_log_unpushed" - _fish_prompt_normal '↻' - _fish_prompt_warn $git_log_unpushed[1] - end + if set -q _git_sync_ahead _git_sync_behind + _fish_prompt_normal '⇅' + else if set -q _git_sync_ahead + _fish_prompt_normal '↑' + else if set -q _git_sync_behind + _fish_prompt_normal '↓' + end + + if test -n "$git_log_unpushed" + and not string match -qr "$git_branch" "$git_log_unpushed" + _fish_prompt_normal '↻' + _fish_prompt_warn $git_log_unpushed[1] end ############################################################ diff --git a/user/fzf.nix b/user/fzf.nix index 468cae5..fc7856a 100644 --- a/user/fzf.nix +++ b/user/fzf.nix @@ -1,11 +1,6 @@ -{ - config, - pkgs, - lib, - ... -}: +{ config, pkgs, lib, inputs, ... }: let - inherit (config.my) theme accent; + inherit (pkgs.uservars) key theme accent font; inherit (theme) color; colors = { @@ -20,21 +15,22 @@ let makeOptList = lib.mapAttrsToList makeKeyValue colors; makeColorValue = lib.strings.concatStringsSep "," makeOptList; color_opts = "--color=${makeColorValue}"; - preview_opts = "--preview '${pkgs.bat}/bin/bat --style=numbers --color=always {}'"; + preview_opts = + "--preview '${pkgs.bat}/bin/bat --style=numbers --color=always {}'"; + in { programs.fzf = { enable = true; fileWidgetCommand = "${pkgs.fd}/bin/fd --type f"; - fileWidgetOptions = [ "--preview '${pkgs.bat}/bin/bat --style=numbers --color=always {}'" ]; + fileWidgetOptions = + [ "--preview '${pkgs.bat}/bin/bat --style=numbers --color=always {}'" ]; changeDirWidgetCommand = "${pkgs.fd}/bin/fd --type d"; - changeDirWidgetOptions = [ "--preview '${pkgs.eza}/bin/eza -T L3 | head -200'" ]; + changeDirWidgetOptions = + [ "--preview '${pkgs.eza}/bin/eza -T L3 | head -200'" ]; - defaultOptions = [ - color_opts - preview_opts - ]; + defaultOptions = [ color_opts preview_opts ]; }; } diff --git a/user/gaming.nix b/user/gaming.nix deleted file mode 100644 index 3e89361..0000000 --- a/user/gaming.nix +++ /dev/null @@ -1,24 +0,0 @@ -{ - config, - lib, - pkgs, - ... -}: -let - cfg = config.my.gaming; -in -{ - options.my.gaming.enable = lib.mkEnableOption { }; - config = lib.mkIf cfg.enable { - my.mangohud.enable = true; - - home.packages = with pkgs; [ - # lutris-unwrapped - # steam # It's enabled in the system config - tlauncher - gamescope - glxinfo - vulkan-tools - ]; - }; -} diff --git a/user/git.nix b/user/git.nix index d411d35..09be75c 100644 --- a/user/git.nix +++ b/user/git.nix @@ -1,61 +1,24 @@ -{ - config, - pkgs, - lib, - ... -}: -let - inherit (config.my) username mail; -in -{ +{ config, pkgs, lib, ... }: +let inherit (pkgs.uservars) username mail; +in { config = { programs.git = { enable = true; - lfs.enable = true; extraConfig = { user = { name = username; email = mail.personal.user; - signingkey = "2F8F21CE8721456B"; }; init.defaultBranch = "main"; - core = { - fsmonitor = true; - untrackedCache = true; - }; - commit = { - verbose = true; - gpgsign = true; - }; - fetch = { - prune = true; - pruneTags = true; - all = true; - }; - push = { - autoSetupRemote = true; - default = "simple"; - followTags = true; - }; + commit.verbose = true; + push.autoSetupRemote = true; pull.rebase = true; - tag.sort = "version:refname"; - merge.conflictStyle = "zdiff3"; - rerere = { - enabled = true; - autoupdate = true; - }; - branch.sort = "-committerdate"; - diff = { - algorithm = "histogram"; - colorMoved = "plain"; - mnemonicPrefix = true; - renames = true; - }; + merge.conflictStyle = "diff3"; + rerere.enabled = true; rebase = { abbreviateCommands = true; autoSquash = true; autoStash = true; - updateRefs = true; }; pager = { log = "${pkgs._diffr}/bin/_diffr | ${pkgs.kak-pager}/bin/kak-pager"; @@ -65,16 +28,8 @@ in alias = { graph = "log --graph --oneline --branches"; root = "rev-parse --show-toplevel"; - clean-deleted-remotes = "!" + (lib.getExe pkgs.git_clean_remote_deleted); }; }; }; - - home.packages = with pkgs; [ - git_clean_remote_deleted - - gh - glab - ]; }; } diff --git a/user/gnome.nix b/user/gnome.nix index 9a3562b..956c1cd 100644 --- a/user/gnome.nix +++ b/user/gnome.nix @@ -1,16 +1,9 @@ -{ - pkgs, - lib, - inputs, - config, - ... -}: -lib.mkIf (config.my.desktop == "gnome") { +{ pkgs, lib, inputs, ... }: lib.mkIf (pkgs.uservars.desktop == "gnome") { home.pointerCursor = { name = "Adwaita"; size = 24; - package = pkgs.adwaita-icon-theme; + package = pkgs.gnome.adwaita-icon-theme; gtk.enable = true; }; @@ -21,31 +14,42 @@ lib.mkIf (config.my.desktop == "gnome") { cursor-theme = "Adwaita"; # color-scheme = "default"; }; - "org/gnome/desktop/wm/preferences" = lib.mkForce { button-layout = "appmenu:close"; }; + "org/gnome/desktop/wm/preferences" = lib.mkForce { + button-layout = "appmenu:close"; + }; "org/gnome/desktop/input-sources" = { xkb-options = [ "lv3:lsgt_switch" ]; }; }; home.packages = with pkgs; [ + inputs.nixos-conf-editor.packages.${pkgs.system}.nixos-conf-editor + inputs.nix-software-center.packages.${pkgs.system}.nix-software-center + adw-gtk3 newsflash foliate amberol pitivi - keepassxc - menulibre + gnome-passwordsafe libsForQt5.qt5ct libsForQt5.qtstyleplugin-kvantum - qt6Packages.qt6ct - qt6Packages.qtstyleplugin-kvantum ]; - services.gpg-agent.pinentry.package = pkgs.pinentry-gnome; + home.sessionVariables = { QT_QPA_PLATFORMTHEME = "qt5ct"; }; xdg.defaultApplications = { - enable = lib.mkForce false; + enable = true; + text-editor = "codium.desktop"; + image-viewer = "org.gnome.eog.desktop"; + video-player = "org.gnome.Totem.desktop"; + web-browser = "firefox.desktop"; + document-viewer = "org.gnome.Evince.desktop"; + file-manager = "org.gnome.Nautilus.desktop"; + archive-manager = "org.gnome.FileRoller.desktop;"; + email-client = "thunderbird.desktop"; + torrent-client = "torrent.desktop"; }; } diff --git a/user/gpg.nix b/user/gpg.nix index f1c472f..e215440 100644 --- a/user/gpg.nix +++ b/user/gpg.nix @@ -1,15 +1,10 @@ -{ - config, - pkgs, - lib, - ... -}: -{ +{ config, pkgs, lib, ... }: { config = { services.gpg-agent = { enable = true; defaultCacheTtl = 604800; maxCacheTtl = 604800; + pinentryFlavor = "gtk2"; extraConfig = '' allow-preset-passphrase ''; @@ -21,9 +16,7 @@ PartOf = [ "graphical-session.target" ]; After = [ "graphical-session.target" ]; }; - Service = { - ExecStart = "${pkgs._gpg-unlock}/bin/_gpg-unlock"; - }; + Service = { ExecStart = "${pkgs._gpg-unlock}/bin/_gpg-unlock"; }; }; }; systemd.user.timers = { @@ -38,10 +31,9 @@ OnUnitActiveSec = "300"; Unit = "gpg_unlock.service"; }; - Install = { - WantedBy = [ "sway-session.target" ]; - }; + Install = { WantedBy = [ "sway-session.target" ]; }; }; }; + }; } diff --git a/user/helix.nix b/user/helix.nix index 15250b4..ad02d0d 100644 --- a/user/helix.nix +++ b/user/helix.nix @@ -1,19 +1,10 @@ -{ - pkgs, - lib, - config, - ... -}: +{ pkgs, lib, ... }: let - inherit (config.my) accent theme editor; + inherit (pkgs.uservars) accent theme editor; inherit (theme) color; - - cfg = config.my.helix; in { - options.my.helix.enable = lib.mkEnableOption "Enable helix config"; - - config = lib.mkIf cfg.enable { + config = { programs.helix = { enable = true; settings = { @@ -83,53 +74,29 @@ in g.n = "goto_line_start"; g.o = "goto_line_end"; }; - keys.insert = { - "A-k" = "normal_mode"; - }; + keys.insert = { "A-k" = "normal_mode"; }; }; languages.language = [ + { name = "nix"; auto-format = true; formatter = { command = "nixpkgs-fmt"; }; } + { name = "rust"; auto-format = true; } { - name = "nix"; - auto-format = true; - formatter.command = "nixpkgs-fmt"; - } - { - name = "rust"; - auto-format = true; + name = "php"; + config.intelephense.format.braces = "k&r"; } ]; - languages.language-server = { - intelephense.config.intelephense.format.braces = "k&r"; - }; - themes = { my-theme = { "inherits" = "gruvbox"; "ui.menu" = "none"; - "ui.background" = { - bg = "none"; - }; + "ui.background" = { bg = "none"; }; "ui.virtual.whitespace" = color.nontxt; - "ui.cursor.primary" = { - fg = accent.fg; - bg = accent.color; - }; - "ui.cursorline.primary" = { - bg = color.bg_dark; - }; - "ui.cursorcolumn.primary" = { - modifiers = [ "bold" ]; - }; - "ui.cursorline" = { - bg = "none"; - }; - "ui.cursorcolumn" = { - bg = "none"; - }; - "ui.linenr.selected" = { - fg = color.txt; - }; + "ui.cursor.primary" = { fg = accent.fg; bg = accent.color; }; + "ui.cursorline.primary" = { bg = color.bg_dark; }; + "ui.cursorcolumn.primary" = { modifiers = [ "bold" ]; }; + "ui.cursorline" = { bg = "none"; }; + "ui.cursorcolumn" = { bg = "none"; }; + "ui.linenr.selected" = { fg = color.txt; }; function = color.normal.orange; module = color.normal.brown; @@ -150,6 +117,8 @@ in }; }; }; - home.sessionVariables = lib.mkIf (editor == "helix") { EDITOR = "hx"; }; + home.sessionVariables = lib.mkIf (editor == "helix") { + EDITOR = "hx"; + }; }; } diff --git a/user/home-manager.nix b/user/home-manager.nix deleted file mode 100644 index 9c8452a..0000000 --- a/user/home-manager.nix +++ /dev/null @@ -1,28 +0,0 @@ -{ pkgs, lib, ... }: -{ - programs.home-manager.enable = true; - - systemd.user.services.home-manager-expire = { - Unit = { - Description = "Remove old home-manager generations"; - }; - Service = { - Type = "oneshot"; - ExecStart = pkgs.writeShellScript "home-manager-expire" '' - ${lib.getExe pkgs.home-manager} expire-generations 7d - ''; - }; - }; - systemd.user.timers.home-manager-expire = { - Unit = { - Description = "Remove old home-manager generations"; - }; - Timer = { - OnCalendar = "daily"; - Unit = "home-manager-expire.service"; - }; - Install = { - WantedBy = [ "timers.target" ]; - }; - }; -} diff --git a/user/home.nix b/user/home.nix index 1778052..7dfc0ed 100644 --- a/user/home.nix +++ b/user/home.nix @@ -1,34 +1,28 @@ -{ - config, - pkgs, - lib, - inputs, - osConfig, - ... -}: -{ +{ config, pkgs, lib, inputs, osConfig, ... }: { imports = [ - ./dummy.nix - ./home-manager.nix + ./controller.nix ./waybar ./helix.nix ./kakoune ./vscode ./fish ./firefox.nix + ./hyprland ./alacritty.nix ./git.nix ./ssh.nix + ./qutebrowser ./gpg.nix ./rofi.nix ./mpv.nix ./mangohud.nix - ./gaming.nix ./pipewire.nix ./mimeapps.nix ./desktop-entries.nix ./chat.nix + ./email.nix ./syncthing.nix + ./vdir.nix ./bmenu.nix ./fzf.nix ./ranger @@ -36,32 +30,27 @@ ./pass.nix ./pqiv.nix ./zathura.nix - ./satty ./man.nix ./mpd.nix ./sway ./gnome.nix ./thunar.nix ./xdg-dirs.nix + # inputs.hyprland.homeManagerModules.default inputs.nix-index-database.hmModules.nix-index - ../settings - ./powerplay-led-idle.nix - ./rm-target.nix ]; - my = import ./variables.nix // { - sway.enable = true; - pass.enable = true; - fish.enable = true; - }; - # Home Manager needs a bit of information about you and the # paths it should manage. home.username = "lelgenio"; home.homeDirectory = "/home/lelgenio"; + # Let Home Manager install and manage itself. + # programs.home-manager.enable = true; home.packages = with pkgs; [ - terminal + # home-manager + + terminal # see flake.nix pulse_sink pulseaudio @@ -69,7 +58,7 @@ ## CLI eza fd - gavin-bc + bc file jq du-dust @@ -82,22 +71,30 @@ comma # System monitors - (btop.override { rocmSupport = true; }) + btop amdgpu_top inxi dmidecode + ncdu ## text manipulation sd ripgrep translate-shell lipsum - python3Packages.python-slugify par mate.engrampa # gnome.nautilus + ## games + # lutris-unwrapped + # steam # It's enabled in the system config + tlauncher + gamescope + glxinfo + vulkan-tools + ## Theming orchis_theme_compact papirus_red @@ -107,6 +104,7 @@ ## Network speedtest-cli nmap + httpie miniupnpc deluge nicotine-plus @@ -118,19 +116,18 @@ # rustup docker-compose + gnumake mariadb nodePackages.intelephense nodePackages.typescript-language-server flow # js lsp server nil # nix lsp server + rnix-lsp # nix lsp clang-tools # c/c++ lsp server rust-analyzer # rust analyzer - unstable.blade-formatter - nixfmt-rfc-style - - nix-output-monitor + nixpkgs-fmt ]; fonts.fontconfig.enable = true; @@ -142,10 +139,14 @@ }; }; home.sessionVariables = { - VOLUME_CHANGE_SOUND = "${pkgs.sound-theme-freedesktop}/share/sounds/freedesktop/stereo/audio-volume-change.oga"; + VOLUME_CHANGE_SOUND = + "${pkgs.sound-theme-freedesktop}/share/sounds/freedesktop/stereo/audio-volume-change.oga"; }; - programs.bash = { + programs.bash = { enable = true; }; + + services.nextcloud-client = { enable = true; + startInBackground = true; }; xdg.defaultApplications = { @@ -153,7 +154,10 @@ text-editor = lib.mkDefault "kak.desktop"; image-viewer = lib.mkDefault "pqiv.desktop"; video-player = lib.mkDefault "mpv.desktop"; - web-browser = lib.mkDefault "firefox-devedition.desktop"; + web-browser = lib.mkDefault ({ + firefox = lib.mkDefault "firefox.desktop"; + qutebrowser = lib.mkDefault "org.qutebrowser.qutebrowser.desktop"; + }.${pkgs.uservars.browser}); document-viewer = lib.mkDefault "org.pwmt.zathura.desktop"; file-manager = lib.mkDefault "thunar.desktop"; archive-manager = "engrampa.desktop"; @@ -161,14 +165,39 @@ torrent-client = lib.mkDefault "torrent.desktop"; }; - wayland.windowManager.sway.extraConfig = - lib.optionalString (osConfig.networking.hostName or "" == "monolith") - '' - exec steam - exec obs --startreplaybuffer --disable-shutdown-check - exec deluge-gtk - exec nicotine + wayland.windowManager.sway.extraConfig = lib.optionalString (osConfig.networking.hostName or "" == "monolith") '' + exec steam + exec obs --startreplaybuffer + exec deluge-gtk + exec nicotine + ''; + + wayland.windowManager.hyprland.extraConfig = lib.optionalString (osConfig.networking.hostName or "" == "monolith") '' + exec-once = steam + exec-once = obs --startreplaybuffer + exec-once = deluge-gtk + exec-once = nicotine + ''; + + systemd.user.services.rm-target = { + Unit = { + Description = "Remove directories named 'target'"; + }; + Service = { + Type = "oneshot"; + ExecStart = pkgs.writeShellScript "rm-target" '' + sudo ${pkgs.fd}/bin/fd -td -u '^\.?target$' "$HOME" -x rm -vrf -- ''; + }; + }; + systemd.user.timers.rm-target = { + Unit = { Description = "Remove directories named 'target'"; }; + Timer = { + OnCalendar = "weekly"; + Unit = "rm-target.service"; + }; + Install = { WantedBy = [ "timers.target" ]; }; + }; # This value determines the Home Manager release that your # configuration is compatible with. This helps avoid breakage diff --git a/user/hyprland/default.nix b/user/hyprland/default.nix new file mode 100644 index 0000000..6eaa16f --- /dev/null +++ b/user/hyprland/default.nix @@ -0,0 +1,66 @@ +{ config, pkgs, lib, ... }: +let + inherit (pkgs.uservars) theme; +in +{ + imports = [ + ../sway/kanshi.nix + ../sway/mako.nix + # ../sway/sway-binds.nix + # ../sway/sway-modes.nix + # ../sway/sway-assigns.nix + # ../sway/swayidle.nix + # ../sway/swaylock.nix + ../sway/theme.nix + ]; + + config = lib.mkIf (pkgs.uservars.desktop == "hyprland") { + services.mako.enable = true; + + wayland.windowManager.hyprland = { + enable = true; + extraConfig = '' + source = /home/lelgenio/projects/nixos-config/user/hyprland/hyprland.conf + ''; + systemd.enable = true; + }; + home.file.".config/hypr/hyprpaper.conf".text = '' + preload = ${theme.background} + wallpaper = ,${theme.background} + ''; + # home.file.".config/eww".source = ./eww; + + packages.firefox.hideTitleBar = true; + + home.packages = with pkgs; [ + eww-wayland + jq + hyprpaper + wdisplays + + waybar + dhist + demoji + bmenu + wdmenu + wlauncher + volumesh + showkeys + pamixer + libnotify + xdg-utils + screenshotsh + color_picker + wf-recorder + wl-clipboard + wtype + wl-crosshair + + grim + swappy + (tesseract5.override { + enableLanguages = [ "eng" "por" ]; + }) + ]; + }; +} diff --git a/user/hyprland/hyprland.conf b/user/hyprland/hyprland.conf new file mode 100644 index 0000000..f84aa97 --- /dev/null +++ b/user/hyprland/hyprland.conf @@ -0,0 +1,282 @@ + +######################################################################################## +AUTOGENERATED HYPR CONFIG. +PLEASE USE THE CONFIG PROVIDED IN THE GIT REPO /examples/hypr.conf AND EDIT IT, +OR EDIT THIS ONE ACCORDING TO THE WIKI INSTRUCTIONS. +######################################################################################## + +# +# Please note not all available settings / options are set here. +# For a full list, see the wiki +# + +# autogenerated = 1 # remove this line to remove the warning + +# See https://wiki.hyprland.org/Configuring/Monitors/ +monitor=,preferred,auto,auto +monitor=DP-1,1920x1080@144,auto,auto + +# See https://wiki.hyprland.org/Configuring/Keywords/ for more + +# Execute your favorite apps at launch +exec-once = hyprpaper & firefox + +# Source a file (multi-file configs) +# source = ~/.config/hypr/myColors.conf + +# Some default env vars. +env = XCURSOR_SIZE,24 + +# For all categories, see https://wiki.hyprland.org/Configuring/Variables/ +input { + kb_layout = us(colemak) + kb_variant = + kb_model = + kb_options = + kb_rules = + + follow_mouse = 1 + + touchpad { + natural_scroll = no + } + + sensitivity = 0 # -1.0 - 1.0, 0 means no modification. +} + +general { + # See https://wiki.hyprland.org/Configuring/Variables/ for more + + gaps_in = 5 + gaps_out = 10 + border_size = 2 + col.active_border = rgba(F44336ee) rgba(202020ee) 45deg + col.inactive_border = rgba(202020ee) + + layout = master + + # Please see https://wiki.hyprland.org/Configuring/Tearing/ before you turn this on + allow_tearing = false +} + +decoration { + # See https://wiki.hyprland.org/Configuring/Variables/ for more + + rounding = 5 + + blur { + enabled = true + size = 3 + passes = 1 + } + + drop_shadow = yes + shadow_range = 4 + shadow_render_power = 3 + col.shadow = rgba(1a1a1aee) +} + +animations { + enabled = yes + + # Some default animations, see https://wiki.hyprland.org/Configuring/Animations/ for more + + bezier = myBezier, 0.05, 0.9, 0.1, 1.05 + + animation = windows, 1, 7, myBezier + animation = windowsOut, 1, 7, default, popin 80% + animation = border, 1, 10, default + animation = borderangle, 1, 8, default + animation = fade, 1, 7, default + animation = workspaces, 1, 6, default +} + +dwindle { + # See https://wiki.hyprland.org/Configuring/Dwindle-Layout/ for more + pseudotile = yes # master switch for pseudotiling. Enabling is bound to mainMod + P in the keybinds section below + preserve_split = yes # you probably want this +} + +master { + # See https://wiki.hyprland.org/Configuring/Master-Layout/ for more + new_is_master = false + no_gaps_when_only = 1 +} + +gestures { + # See https://wiki.hyprland.org/Configuring/Variables/ for more + workspace_swipe = off +} + +misc { + # See https://wiki.hyprland.org/Configuring/Variables/ for more + force_default_wallpaper = 0 # Set to 0 to disable the anime mascot wallpapers +} + +# Example per-device config +# See https://wiki.hyprland.org/Configuring/Keywords/#executing for more +device:epic-mouse-v1 { + sensitivity = -0.5 +} + +# Example windowrule v1 +# windowrule = float, ^(kitty)$ +# Example windowrule v2 +# windowrulev2 = float,class:^(kitty)$,title:^(kitty)$ + + +windowrulev2 = workspace 2, class:qutebrowser +windowrulev2 = workspace 2, class:qutebrowser +windowrulev2 = workspace 2, class:firefox +windowrulev2 = workspace 2, class:firefox +windowrulev2 = workspace 2, class:Chromium +windowrulev2 = workspace 2, class:chromium + +windowrulev2 = workspace 6, class:org.nicotine_plus.Nicotine +windowrulev2 = workspace 6, class:deluge +windowrulev2 = workspace 6, class:com.obsproject.Studio + +windowrulev2 = workspace 7, class:thunderbird +windowrulev2 = workspace 7, class:astroid + +windowrulev2 = workspace 9, class:.*[Ss]team.* +windowrulev2 = workspace 9, class:.*[Ss]team.* +windowrulev2 = workspace 9, class:[Ll]utris + +windowrulev2 = workspace 10, class:.*[Tt]elegram.* +windowrulev2 = workspace 10, class:.*[Tt]elegram.* +windowrulev2 = workspace 10, class:Jitsi Meet +windowrulev2 = workspace 10, class:discord +windowrulev2 = workspace 10, class:Discord +windowrulev2 = workspace 10, class:WebCord +windowrulev2 = workspace 10, class:WebCord +windowrulev2 = workspace 10, class:Element +windowrulev2 = workspace 10, class:Element + +# See https://wiki.hyprland.org/Configuring/Window-Rules/ for more + +# See https://wiki.hyprland.org/Configuring/Keywords/ for more +$mainMod = SUPER + +# Example binds, see https://wiki.hyprland.org/Configuring/Binds/ for more +bind = $mainMod, Return, exec, alacritty +bind = $mainMod, X, killactive, +# bind = $mainMod, M, exit, +bind = $mainMod Control, Return, exec, thunar +bind = $mainMod Shift, Space, togglefloating, + +bind = $mainMod Control, z, exec, swaylock & systemctl suspend + +bind = $mainMod, R, exec, wofi --show drun +bind = $mainMod, P, pseudo, # dwindle +bind = $mainMod, J, togglesplit, # dwindle + +# Move focus with mainMod + arrow keys +bind = $mainMod, left, movefocus, l +bind = $mainMod, right, movefocus, r +bind = $mainMod, up, movefocus, u +bind = $mainMod, down, movefocus, d + +# Switch workspaces with mainMod + [0-9] +bind = $mainMod, 1, workspace, 1 +bind = $mainMod, 2, workspace, 2 +bind = $mainMod, 3, workspace, 3 +bind = $mainMod, 4, workspace, 4 +bind = $mainMod, 5, workspace, 5 +bind = $mainMod, 6, workspace, 6 +bind = $mainMod, 7, workspace, 7 +bind = $mainMod, 8, workspace, 8 +bind = $mainMod, 9, workspace, 9 +bind = $mainMod, 0, workspace, 10 + +# Move active window to a workspace with mainMod + SHIFT + [0-9] +bind = $mainMod SHIFT, 1, movetoworkspace, 1 +bind = $mainMod SHIFT, 2, movetoworkspace, 2 +bind = $mainMod SHIFT, 3, movetoworkspace, 3 +bind = $mainMod SHIFT, 4, movetoworkspace, 4 +bind = $mainMod SHIFT, 5, movetoworkspace, 5 +bind = $mainMod SHIFT, 6, movetoworkspace, 6 +bind = $mainMod SHIFT, 7, movetoworkspace, 7 +bind = $mainMod SHIFT, 8, movetoworkspace, 8 +bind = $mainMod SHIFT, 9, movetoworkspace, 9 +bind = $mainMod SHIFT, 0, movetoworkspace, 10 + +# Example special workspace (scratchpad) +bind = $mainMod, j, togglespecialworkspace, magic +bind = $mainMod SHIFT, j, movetoworkspace, special:magic + +# Scroll through existing workspaces with mainMod + scroll +bind = $mainMod, mouse_down, workspace, e+1 +bind = $mainMod, mouse_up, workspace, e-1 + +# Move/resize windows with mainMod + LMB/RMB and dragging +bindm = $mainMod, mouse:272, movewindow +bindm = $mainMod, mouse:273, resizewindow + +bind = $mainMod, S, exec, wlauncher +bind = $mainMod, B, layoutmsg, swapwithmaster + +bind = $mainMod Shift, E, layoutmsg, swapnext +bind = $mainMod Shift, I, layoutmsg, swapprev + + bind=$mainMod,f,fullscreen + + bind=$mainMod,n,movefocus,l + bind=$mainMod,o,movefocus,r + bind=$mainMod,i,movefocus,u + bind=$mainMod,e,movefocus,d + + bind=$mainMod,left,movefocus,l + bind=$mainMod,right,movefocus,r + bind=$mainMod,up,movefocus,u + bind=$mainMod,down,movefocus,d + + bind=$mainMod,1,workspace,1 + bind=$mainMod,2,workspace,2 + bind=$mainMod,3,workspace,3 + bind=$mainMod,4,workspace,4 + bind=$mainMod,5,workspace,5 + bind=$mainMod,6,workspace,6 + bind=$mainMod,7,workspace,7 + bind=$mainMod,8,workspace,8 + bind=$mainMod,9,workspace,9 + bind=$mainMod,0,workspace,10 + + # bind=ALT,1,movetoworkspace,1 + # bind=ALT,2,movetoworkspace,2 + # bind=ALT,3,movetoworkspace,3 + # bind=ALT,4,movetoworkspace,4 + # bind=ALT,5,movetoworkspace,5 + # bind=ALT,6,movetoworkspace,6 + # bind=ALT,7,movetoworkspace,7 + # bind=ALT,8,movetoworkspace,8 + # bind=ALT,9,movetoworkspace,9 + # bind=ALT,0,movetoworkspace,10 + + bind=$mainMod,u,workspace,e-1 + bind=$mainMod,y,workspace,e+1 + + bind=$mainMod,mouse_down,workspace,e-1 + bind=$mainMod,mouse_up,workspace,e+1 + +# Music mode + +bind=$mainMod,M,submap,music +submap=music + +binde=,Space,exec,mpc toggle + +binde=,U,exec,volumesh -i 10 +binde=,Y,exec,volumesh -d 10 +binde=,O,exec,mpc next +binde=,N,exec,mpc prev +binde=,I,exec,volumesh --mpd -i 10 +binde=,E,exec,volumesh --mpd -d 10 + +binde=,s,exec,pulse_sink + +# use reset to go back to the global submap +bind=,escape,submap,reset + +# will reset the submap, meaning end the current one and return to the global one +submap=reset diff --git a/user/kakoune/colors.nix b/user/kakoune/colors.nix index a0917d4..dbac3e3 100644 --- a/user/kakoune/colors.nix +++ b/user/kakoune/colors.nix @@ -1,9 +1,4 @@ -{ - pkgs, - lib, - color, - accent, -}: +{ pkgs, lib, color, accent }: let colors = lib.mapAttrs (_: lib.replaceStrings [ "#" ] [ "rgb:" ]) { accent_fg = accent.fg; @@ -99,9 +94,8 @@ with colors; face global InlayHint ${bg_light}+buif # Lsp -'' -+ (lib.concatStringsSep "\n" ( - lib.mapAttrsToList +'' + ( + lib.concatStringsSep "\n" (lib.mapAttrsToList (name: color: '' face global HighlightDiagnostic${name} ${color},default+bu face global Diagnostic${name} ${color},default+bu @@ -112,114 +106,6 @@ with colors; Error = "red"; Warning = "yellow"; Hint = "blue"; - } -)) -+ '' - # Color palette - declare-option str red "red" - declare-option str mauve "magenta" - declare-option str maroon "rgb:ee99a0" - declare-option str pink "rgb:f5bde6" - declare-option str cyan "cyan" - declare-option str yellow "yellow" - declare-option str green "green" - declare-option str white "white" - declare-option str blue "blue" - declare-option str sky "rgb:91d7e3" - declare-option str lavender "rgb:b7bdf8" - declare-option str black1 "rgb:202020" - declare-option str black2 "rgb:272727" - declare-option str black3 "rgb:3a3a3a" - declare-option str orange ${orange} - declare-option str teal "rgb:8bd5ca" - declare-option str flamingo "rgb:f0c6c6" - declare-option str gray0 "rgb:606060" - declare-option str gray1 "rgb:737373" - declare-option str bright_red "%opt{red}+b" - declare-option str bright_green "%opt{green}+b" - declare-option str bright_yellow "%opt{yellow}+b" - declare-option str bright_blue "%opt{blue}+b" - declare-option str bright_cyan "%opt{cyan}+b" - declare-option str foreground %opt{white} - declare-option str background %opt{black2} - declare-option str overlay0 "rgb:878787" - declare-option str overlay1 "rgb:9a9a9a" + }) +) - # Tree-sitter () - set-face global ts_attribute "%opt{cyan}" - set-face global ts_comment "%opt{overlay0}+i" - set-face global ts_conceal "%opt{mauve}+i" - set-face global ts_constant "%opt{orange}" - set-face global ts_constant_builtin_boolean "%opt{sky}" - set-face global ts_constant_character "%opt{yellow}" - set-face global ts_constant_macro "%opt{mauve}" - set-face global ts_constructor "%opt{cyan}" - set-face global ts_diff_plus "%opt{green}" - set-face global ts_diff_minus "%opt{red}" - set-face global ts_diff_delta "%opt{blue}" - set-face global ts_diff_delta_moved "%opt{mauve}" - set-face global ts_error "%opt{red}+b" - set-face global ts_function "%opt{blue}" - set-face global ts_function_builtin "%opt{blue}+i" - set-face global ts_function_macro "%opt{mauve}" - set-face global ts_hint "%opt{blue}+b" - set-face global ts_info "%opt{green}+b" - set-face global ts_keyword "%opt{mauve}" - set-face global ts_keyword_conditional "%opt{mauve}+i" - set-face global ts_keyword_control_conditional "%opt{mauve}+i" - set-face global ts_keyword_control_directive "%opt{mauve}+i" - set-face global ts_keyword_control_import "%opt{mauve}+i" - set-face global ts_keyword_directive "%opt{mauve}+i" - set-face global ts_keyword_storage "%opt{mauve}" - set-face global ts_keyword_storage_modifier "%opt{mauve}" - set-face global ts_keyword_storage_modifier_mut "%opt{mauve}" - set-face global ts_keyword_storage_modifier_ref "%opt{teal}" - set-face global ts_label "%opt{cyan}+i" - set-face global ts_markup_bold "%opt{orange}+b" - set-face global ts_markup_heading "%opt{red}" - set-face global ts_markup_heading_1 "%opt{red}" - set-face global ts_markup_heading_2 "%opt{mauve}" - set-face global ts_markup_heading_3 "%opt{green}" - set-face global ts_markup_heading_4 "%opt{yellow}" - set-face global ts_markup_heading_5 "%opt{pink}" - set-face global ts_markup_heading_6 "%opt{teal}" - set-face global ts_markup_heading_marker "%opt{orange}+b" - set-face global ts_markup_italic "%opt{pink}+i" - set-face global ts_markup_list_checked "%opt{green}" - set-face global ts_markup_list_numbered "%opt{blue}+i" - set-face global ts_markup_list_unchecked "%opt{teal}" - set-face global ts_markup_list_unnumbered "%opt{mauve}" - set-face global ts_markup_link_label "%opt{blue}" - set-face global ts_markup_link_url "%opt{teal}+u" - set-face global ts_markup_link_uri "%opt{teal}+u" - set-face global ts_markup_link_text "%opt{blue}" - set-face global ts_markup_quote "%opt{gray1}" - set-face global ts_markup_raw "%opt{green}" - set-face global ts_markup_strikethrough "%opt{gray1}+s" - set-face global ts_namespace "%opt{blue}+i" - set-face global ts_operator "%opt{sky}" - set-face global ts_property "%opt{sky}" - set-face global ts_punctuation "%opt{overlay1}" - set-face global ts_punctuation_special "%opt{sky}" - set-face global ts_special "%opt{blue}" - set-face global ts_spell "%opt{mauve}" - set-face global ts_string "%opt{green}" - set-face global ts_string_regex "%opt{orange}" - set-face global ts_string_regexp "%opt{orange}" - set-face global ts_string_escape "%opt{mauve}" - set-face global ts_string_special "%opt{blue}" - set-face global ts_string_special_path "%opt{orange}" - set-face global ts_string_special_symbol "%opt{mauve}" - set-face global ts_string_symbol "%opt{red}" - set-face global ts_tag "%opt{mauve}" - set-face global ts_tag_error "%opt{red}" - set-face global ts_text "%opt{white}" - set-face global ts_text_title "%opt{mauve}" - set-face global ts_type "%opt{yellow}" - set-face global ts_type_enum_variant "%opt{flamingo}" - set-face global ts_variable "%opt{blue}" - set-face global ts_variable_builtin "%opt{red}" - set-face global ts_variable_other_member "%opt{teal}" - set-face global ts_variable_parameter "%opt{maroon}+i" - set-face global ts_warning "%opt{orange}+b" -'' diff --git a/user/kakoune/default.nix b/user/kakoune/default.nix index fa63e6b..d2ef8eb 100644 --- a/user/kakoune/default.nix +++ b/user/kakoune/default.nix @@ -1,22 +1,11 @@ -{ - config, - pkgs, - lib, - ... -}: +{ config, pkgs, lib, ... }: let - inherit (config.my) - dmenu - editor - theme - accent - ; + inherit (pkgs.uservars) key dmenu editor theme accent; inherit (theme) color; inherit (pkgs) kakounePlugins; inherit (pkgs.kakouneUtils) buildKakounePlugin; in { - imports = [ ./kak-tree-sitter.nix ]; config = { programs.kakoune = { enable = true; @@ -82,61 +71,39 @@ in rev = "1cc6baeb14b773916eb9209469aa77b3cfa67a0a"; sha256 = "sha256-3PLxG9UtT0MMSibvTviXQIgTH3rApZ3WSbNCEH3c7HE="; }; - buildInputs = with pkgs; [ - python3Minimal - ]; }) ]; extraConfig = - lib.concatStringsSep "\n" ( - map (lib.readFile) ( - [ - ./filetypes.kak - ./hooks.kak - ./indent.kak - ./keys.kak - ./lsp-config.kak - ./usermode.kak - ./git-mode.kak - ] - ++ lib.optional (dmenu == "rofi") ./rofi-commands.kak - ) - ) - + '' - try %{ - eval %sh{ kak-tree-sitter -vvvv -dks --init $kak_session } - } + lib.concatStringsSep "\n" + (map (lib.readFile) ([ + ./filetypes.kak + ./hooks.kak + ./indent.kak + ./keys.kak + ./lsp-config.kak + ./usermode.kak + ./git-mode.kak + ] ++ lib.optional (dmenu == "rofi") ./rofi-commands.kak)) + '' - set global scrolloff 10,20 - set global autoreload yes - set global startup_info_version 99999999 + set global scrolloff 10,20 + set global autoreload yes + set global startup_info_version 20200901 - '' - + (import ./colors.nix { - inherit - pkgs - lib - color - accent - ; + '' + (import ./colors.nix { + inherit pkgs lib color accent; }); }; - home.file = { - ".config/kak-lsp/kak-lsp.toml".source = ./kak-lsp.toml; - }; - + home.file = { ".config/kak-lsp/kak-lsp.toml".source = ./kak-lsp.toml; }; home.packages = with pkgs; [ terminal ranger bmenu kak-lsp - kak-tree-sitter kak-pager kak-man-pager emmet-cli nodePackages.prettier - pint-fmt aspell aspellDicts.en @@ -156,3 +123,4 @@ in }; }; } + diff --git a/user/kakoune/filetypes.kak b/user/kakoune/filetypes.kak index b9d19f5..cd93b49 100644 --- a/user/kakoune/filetypes.kak +++ b/user/kakoune/filetypes.kak @@ -12,19 +12,11 @@ hook global WinSetOption filetype=c %{ } hook global WinSetOption filetype=nix %{ - set buffer formatcmd 'nixfmt' -} - -hook global BufCreate .*\.json %{ - set buffer formatcmd "prettier --stdin-filepath=%val{buffile}" -} - -hook global BufCreate .*\.ya?ml %{ - set buffer formatcmd "prettier --stdin-filepath=%val{buffile}" + set buffer formatcmd 'nixpkgs-fmt' } hook global BufCreate .*\.html %{ - set buffer formatcmd "prettier --stdin-filepath=%val{buffile}" + set buffer formatcmd 'prettier --parser html' } hook global BufCreate .*\.component\.html %{ @@ -38,28 +30,8 @@ hook global WinSetOption filetype=angular %[ add-highlighter buffer/angular ref html ] -hook global BufCreate .*\.php %{ - set buffer formatcmd 'pint-fmt' -} - hook global BufCreate .*\.js %{ - set buffer formatcmd "prettier --stdin-filepath=%val{buffile}" -} - -hook global BufCreate .*\.jsx %{ - set buffer formatcmd "prettier --stdin-filepath=%val{buffile}" -} - -hook global BufCreate .*\.ts %{ - set buffer formatcmd "prettier --stdin-filepath=%val{buffile}" -} - -hook global BufCreate .*\.tsx %{ - set buffer formatcmd "prettier --stdin-filepath=%val{buffile}" -} - -hook global BufCreate .*\.scss %{ - set buffer formatcmd "prettier --stdin-filepath=%val{buffile}" + set buffer formatcmd 'prettier --parser babel' } hook global BufCreate .*\.vue %{ @@ -121,7 +93,6 @@ hook global WinSetOption filetype=blade %[ hook -once -always window WinSetOption filetype=.* %{ remove-hooks window blade-.+ } require-module php - require-module javascript add-highlighter buffer/blade regions add-highlighter buffer/blade/base default-region group @@ -137,9 +108,6 @@ hook global WinSetOption filetype=blade %[ add-highlighter buffer/blade/php/ ref php add-highlighter buffer/blade/php/ regex '@((end)?php)' 1:block - add-highlighter buffer/blade/js region '' group - add-highlighter buffer/blade/js/ ref javascript - add-highlighter buffer/blade/expression region '\{\{(?!--)' '(?!--)\}\}' ref php add-highlighter buffer/blade/statement region -recurse '\(' '@(if|foreach|for|section|yield|include)\s*\(' '\)' ref php add-highlighter buffer/blade/base/ regex '@(else(if)?|include|case|break)' 1:keyword diff --git a/user/kakoune/git-mode.kak b/user/kakoune/git-mode.kak index e016f1b..419f96f 100644 --- a/user/kakoune/git-mode.kak +++ b/user/kakoune/git-mode.kak @@ -32,7 +32,6 @@ map global git 'N' ': git-next-merge-conflict ' -docstring 'next git me map global git 'P' ': git-prev-merge-conflict ' -docstring 'previous git merge conflict' map global git 'm' ': git-merge-head ' -docstring 'merge using head' map global git 'M' ': git-merge-new ' -docstring 'merge using new' -map global git '' ': git-merge-head-and-new ' -docstring 'merge using both head and new' map global git '' ': git-merge-original ' -docstring 'merge using original' define-command -override git-next-merge-conflict %{ @@ -54,18 +53,18 @@ define-command -override git-prev-merge-conflict %{ define-command -override git-merge-head %{ evaluate-commands -draft %{ # delete head marker - execute-keys ^{4,}xd + execute-keys ^{4,}d try %{ # select original marker execute-keys /^[|]{4,} # extend to theirs marker - execute-keys ?^={4,}x + execute-keys ?^={4,} } catch %{ # select theirs marker - execute-keys /^={4,}x + execute-keys /^={4,} } # extend to end marker - execute-keys ?^{4,}xd + execute-keys ?^{4,}d } } -docstring "merge using head" @@ -74,11 +73,11 @@ define-command -override git-merge-original %{ # select head marker execute-keys ^{4,} # select to middle of conflict - execute-keys ?^[|]{4,}xd + execute-keys ?^[|]{4,}d # select theirs marker execute-keys /^={4,} # extend to end marker - execute-keys ?^{4,}xd + execute-keys ?^{4,}d } } -docstring "merge using original" @@ -89,23 +88,10 @@ define-command -override git-merge-new %{ # extend to theirs marker execute-keys ?^={4,}\nd # delete end marker - execute-keys /^{4,}xd + execute-keys /^{4,}d } } -docstring "merge using new" -define-command -override git-merge-head-and-new %{ - evaluate-commands -draft %{ - # delete head marker - execute-keys ^{4,}xd - # select middle of conflict - execute-keys /^[|]{4,}x - # extendo to theirs marker - execute-keys ?^={4,}xd - # delete end marker - execute-keys /^{4,}xd - } -} -docstring "merge using head and new" - define-command -override git-graph %{ try %{ delete-buffer '*git-graph*' } edit -scratch '*git-graph*' diff --git a/user/kakoune/hooks.kak b/user/kakoune/hooks.kak index 79d85cc..7bb3cd2 100644 --- a/user/kakoune/hooks.kak +++ b/user/kakoune/hooks.kak @@ -47,7 +47,7 @@ hook global BufOpenFile .*/COMMIT_EDITMSG %{ hook global RegisterModified '"' %{ nop %sh{ { printf %s "$kak_reg_dquote" | wl-copy -n printf %s "$kak_reg_dquote" | xclip -i -selection clipboard -} > /dev/null 2>&1 < /dev/null & }} -group sync-clipboard +} > /dev/null 2>&1 < /dev/null & }} # Trim trailing whitespace hook global BufWritePre .* %{ try %{ diff --git a/user/kakoune/kak-lsp.toml b/user/kakoune/kak-lsp.toml index 9c195bd..0395ec1 100644 --- a/user/kakoune/kak-lsp.toml +++ b/user/kakoune/kak-lsp.toml @@ -7,7 +7,7 @@ verbosity = 2 # set to 0 to disable timeout = 1800 # seconds = 30 minutes -[language_server.angular] +[language.angular] filetypes = ["angular"] roots = [".angular", ".git"] command = "node" @@ -20,80 +20,134 @@ args = [ "--stdio", ] -[language_server.bash-language-server] +[language.bash] filetypes = ["sh"] roots = [".git", ".hg"] command = "bash-language-server" args = ["start"] -[language_server.clangd] +[language.c_cpp] filetypes = ["c", "cpp"] -roots = ["compile_commands.json", ".clangd", ".git", ".hg"] +roots = [ "compile_commands.json", ".clangd", ".git" ] command = "clangd" -[language_server.css-language-server] +[language.crystal] +filetypes = ["crystal"] +roots = ["shard.yml"] +command = "scry" + +[language.css] filetypes = ["css"] -roots = ["package.json", ".git", ".hg"] +roots = ["package.json"] command = "vscode-css-languageserver" args = ["--stdio"] -[language_server.less-language-server] +[language.less] filetypes = ["less"] -roots = ["package.json", ".git", ".hg"] +roots = ["package.json", ".git"] command = "vscode-css-languageserver" args = ["--stdio"] -[language_server.html-language-server] +[language.d] +filetypes = ["d", "di"] +roots = [".git", "dub.sdl", "dub.json"] +command = "dls" + +[language.dart] +# start shell to find path to dart analysis server source +filetypes = ["dart"] +roots = ["pubspec.yaml", ".git"] +command = "sh" +args = ["-c", "dart $(dirname $(which dart))/snapshots/analysis_server.dart.snapshot --lsp"] + +[language.elm] +filetypes = ["elm"] +roots = ["elm.json"] +command = "elm-language-server" +args = ["--stdio"] + +# [language.elm.initialization_options] +# runtime = "node" +# elmPath = "elm" +# elmFormatPath = "elm-format" +# elmTestPath = "elm-test" + +[language.go] +filetypes = ["go"] +roots = ["Gopkg.toml", "go.mod", ".git", ".hg"] +command = "gopls" +offset_encoding = "utf-8" + +[language.haskell] +filetypes = ["haskell"] +roots = ["Setup.hs", "stack.yaml", "*.cabal"] +command = "haskell-language-server-wrapper" +args = ["--lsp"] + +[language.html] filetypes = ["html"] roots = ["package.json"] command = "vscode-html-languageserver" args = ["--stdio"] -settings_section = "_" -[language_server.html-language-server.settings._] -# quotePreference = "single" -# javascript.format.semicolons = "insert" -[language_server.typescript-language-server] -filetypes = ["javascript", "typescript"] -roots = ["package.json", "tsconfig.json", "jsconfig.json", ".git", ".hg"] +[language.javascript] +filetypes = ["javascript"] +roots = [".flowconfig"] +command = "flow" +args = ["lsp"] + +[language.typescript] +filetypes = ["typescript"] +roots = ["package.json"] command = "typescript-language-server" args = ["--stdio"] -settings_section = "_" -[language_server.typescript-language-server.settings._] -# quotePreference = "double" -# typescript.format.semicolons = "insert" -[language_server.json-language-server] +[language.json] filetypes = ["json"] roots = ["package.json"] command = "vscode-json-languageserver" args = ["--stdio"] -[language_server.nil] -filetypes = ["nix"] -command = "nil" -roots = ["flake.nix", "shell.nix", ".git"] -[language_server.nil.settings.nil] -formatting.command = [ "nixfmt" ] +[language.latex] +filetypes = ["latex"] +roots = [".git"] +command = "texlab" -[language_server.intelephense] +[language.nim] +filetypes = ["nim"] +roots = ["*.nimble", ".git"] +command = "nimlsp" + +[language.nix] +filetypes = ["nix"] +roots = ["flake.nix", "shell.nix", ".git"] +command = "rnix-lsp" +[language.nix.settings.nil] +formatting.command = [ "nixpkgs-fmt" ] + +[language.ocaml] +filetypes = ["ocaml"] +roots = ["Makefile", "opam", "*.opam", "dune"] +command = "ocaml-language-server" +args = ["--stdio"] + +[language.php] filetypes = ["php"] roots = [".htaccess", "composer.json"] command = "intelephense" args = ["--stdio"] settings_section = "intelephense" -[language_server.intelephense.settings.intelephense] -storagePath = "/tmp/intelephense" - -format.braces = "k&r" -environment.includePaths = [ +[language.php.settings] +intelephense.format.braces = "k&r" +intelephense.storagePath = "/tmp/intelephense" +intelephense.environment.includePaths = [ "./vendor", "./vendor/autoload", "./vendor/laravel/framework/", "./vendor/laravel/framework/src/", "./vendor/laravel/framework/src/Illuminate/" ] -files.exclude = [ +intelephense.files.exclude = [ "**/.git/**", "**/.svn/**", "**/.hg/**", @@ -104,23 +158,43 @@ files.exclude = [ "**/bower_components/**", "**/resources/views/**" ] -stubs = [ - "apache", "bcmath", "bz2", "calendar", "com_dotnet", "Core", "ctype", - "curl", "date", "dba", "dom", "enchant", "exif", "FFI", "fileinfo", "filter", - "fpm", "ftp", "gd", "gettext", "gmp", "hash", "iconv", "imagick", "imap", - "intl", "json", "ldap", "libxml", "mbstring", "meta", "mysqli", "oci8", - "odbc", "openssl", "pcntl", "pcre", "PDO", "pdo_ibm", "pdo_mysql", "pdo_pgsql", - "pdo_sqlite", "pgsql", "Phar", "posix", "pspell", "readline", "Reflection", - "session", "shmop", "SimpleXML", "snmp", "soap", "sockets", "sodium", - "SPL", "sqlite3", "standard", "superglobals", "sysvmsg", "sysvsem", "sysvshm", - "tidy", "tokenizer", "xml", "xmlreader", "xmlrpc", "xmlwriter", "xsl", - "Zend OPcache", "zip", "zlib", -] +[language.python] +filetypes = ["python"] +roots = ["requirements.txt", "setup.py", ".git", ".hg"] +command = "pyls" +offset_encoding = "utf-8" -[language_server.rust-analyzer] +[language.reason] +filetypes = ["reason"] +roots = ["package.json", "Makefile", ".git", ".hg"] +command = "ocaml-language-server" +args = ["--stdio"] + +[language.ruby] +filetypes = ["ruby"] +roots = ["Gemfile"] +command = "solargraph" +args = ["stdio"] + +# [language.rust] +# filetypes = ["rust"] +# roots = ["Cargo.toml"] +# command = "sh" +# args = [ +# "-c", +# """ +# if path=$(rustup which rls 2>/dev/null); then +# "$path" +# else +# rls +# fi +# """, +# ] + +[language.rust] filetypes = ["rust"] -roots = ["Cargo.toml"] +roots = ["rust-toolchain.toml", "rust-toolchain", "Cargo.toml"] command = "sh" args = [ "-c", @@ -132,37 +206,99 @@ args = [ fi """, ] -[language_server.rust-analyzer.settings.rust-analyzer] -# See https://rust-analyzer.github.io/manual.html#configuration -# cargo.features = [] +[language.rust.settings.rust-analyzer] +## this can use too much space and processing power +# checkOnSave.extraArgs = ["--target-dir", "./target/check"] checkOnSave.command = "clippy" hoverActions.enable = false # kak-lsp doesn't support this at the moment +# procMacro.enable = true +# cargo.loadOutDirsFromCheck = true +# rustfmt.rangeFormatting.enable = true +# rustfmt.extraArgs = ["+nightly"] -[language_server.godot] +[language.terraform] +filetypes = ["terraform"] +roots = ["*.tf"] +command = "terraform-ls" +args = ["serve"] + +[language.godot] filetypes = ["gd", "gdscript", "gdscript3"] roots = ["project.godot", ".git/"] command = "nc" args = [ "localhost", "6008"] -# Semantic tokens support -# See https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_semanticTokens -# for the default list of tokens and modifiers. -# However, many language servers implement their own values. -# Make sure to check the output of `lsp-capabilities` and each server's documentation and source code as well. -# Examples: -# - TypeScript: https://github.com/microsoft/vscode-languageserver-node/blob/main/client/src/common/semanticTokens.ts -# - Rust Analyzer: https://github.com/rust-analyzer/rust-analyzer/blob/master/crates/ide/src/syntax_highlighting.rs -[semantic_tokens] -faces = [ - {face="documentation", token="comment", modifiers=["documentation"]}, - {face="comment", token="comment"}, - {face="function", token="function"}, - {face="keyword", token="keyword"}, - {face="module", token="namespace"}, - {face="operator", token="operator"}, - {face="string", token="string"}, - {face="type", token="type"}, - {face="default+d", token="variable", modifiers=["readonly"]}, - {face="default+d", token="variable", modifiers=["constant"]}, - {face="variable", token="variable"}, -] +[language.clojure] +filetypes = ["clojure"] +roots = ["project.clj", ".git/"] +command = "clojure-lsp" +args = [] + + + + +[semantic_scopes] +# Map textmate scopes to kakoune faces for semantic highlighting +# the underscores are translated to dots, and indicate nesting. +# That is, if variable_other_field is omitted, it will try the face for +# variable_other and then variable +# +# To see a list of available scopes in the debug buffer, run lsp-semantic-available-scopes +variable = "variable" +entity_name_function = "function" +entity_name_type = "type" +variable_other_enummember = "variable" +entity_name_namespace = "module" + +[semantic_modifiers] +documentation = "documentation" +readonly = "default+d" + + + +[[semantic_tokens]] +token = "comment" +face = "documentation" +modifiers = ["documentation"] + +[[semantic_tokens]] +token = "comment" +face = "comment" + +[[semantic_tokens]] +token = "function" +face = "function" + +[[semantic_tokens]] +token = "keyword" +face = "keyword" + +[[semantic_tokens]] +token = "namespace" +face = "module" + +[[semantic_tokens]] +token = "operator" +face = "operator" + +[[semantic_tokens]] +token = "string" +face = "string" + +[[semantic_tokens]] +token = "type" +face = "type" + +[[semantic_tokens]] +token = "variable" +face = "default+d" +modifiers = ["readonly"] + +[[semantic_tokens]] +token = "variable" +face = "default+d" +modifiers = ["constant"] + +[[semantic_tokens]] +token = "variable" +face = "variable" diff --git a/user/kakoune/kak-tree-sitter.nix b/user/kakoune/kak-tree-sitter.nix deleted file mode 100644 index 59ab3e0..0000000 --- a/user/kakoune/kak-tree-sitter.nix +++ /dev/null @@ -1,64 +0,0 @@ -{ pkgs, lib, ... }: -let - hx-src = pkgs.helix.src; - kts-src = pkgs.unstable.kak-tree-sitter-unwrapped.src; - inherit (pkgs) fetchFromGitHub; -in -with pkgs.tree-sitter-grammars; -{ - xdg.configFile."kak-tree-sitter/config.toml".text = - lib.foldlAttrs - ( - acc: name: vals: - acc - + '' - [language.${name}.grammar.source.local] - path = "${vals.parser}" - [language.${name}.grammar] - compile = "cc" - compile_args = ["-c", "-fpic", "../scanner.c", "../parser.c", "-I", ".."] - compile_flags = ["-O3"] - link = "cc" - link_args = ["-shared", "-fpic", "scanner.o", "parser.o", "-o", "typescript.so"] - link_flags = ["-O3"] - [language.${name}.queries.source.local] - path = "${vals.queries}" - [language.${name}.queries] - path = "${vals.queries}" - '' - ) - "" - { - nix = { - parser = tree-sitter-nix + "/parser"; - queries = tree-sitter-nix + "/queries"; - }; - - scss = { - parser = tree-sitter-scss + "/parser"; - queries = tree-sitter-scss + "/queries"; - }; - css = { - parser = tree-sitter-css + "/parser"; - queries = tree-sitter-css + "/queries"; - }; - - javascript = { - parser = tree-sitter-javascript + "/parser"; - queries = tree-sitter-javascript + "/queries"; - }; - typescript = { - parser = - tree-sitter-typescript.overrideAttrs (old: { - src = fetchFromGitHub { - owner = "tree-sitter"; - repo = "tree-sitter-typescript"; - rev = "b1bf4825d9eaa0f3bdeb1e52f099533328acfbdf"; - hash = "sha256-oZKit8kScXcOptmT2ckywL5JlAVe+wuwhuj6ThEI5OQ="; - }; - }) - + "/parser"; - queries = kts-src + "/runtime/queries/typescript"; - }; - }; -} diff --git a/user/lf/default.nix b/user/lf/default.nix index 8dc04a2..5bc0759 100644 --- a/user/lf/default.nix +++ b/user/lf/default.nix @@ -1,11 +1,4 @@ -{ - config, - pkgs, - lib, - inputs, - ... -}: -{ +{ config, pkgs, lib, inputs, ... }: { programs.lf = { enable = true; keybindings = { diff --git a/user/man.nix b/user/man.nix index cc56089..5b80a4e 100644 --- a/user/man.nix +++ b/user/man.nix @@ -1,20 +1,5 @@ -{ - config, - pkgs, - lib, - inputs, - ... -}: -let - inherit (config.my) - key - theme - color - accent - font - desktop - editor - ; +{ config, pkgs, lib, inputs, ... }: +let inherit (pkgs.uservars) key theme color accent font desktop editor; pagers = rec { kak = kakoune; kakoune = { diff --git a/user/mangohud.nix b/user/mangohud.nix index fa0c8ff..e22d3d6 100644 --- a/user/mangohud.nix +++ b/user/mangohud.nix @@ -1,68 +1,64 @@ -{ config, lib, ... }: -let - cfg = config.my.mangohud; -in -{ - options.my.mangohud.enable = lib.mkEnableOption { }; +{ config, pkgs, lib, font, ... }: +let inherit (pkgs.uservars) key theme color accent font; +in { + config = { + programs.mangohud = { + enable = true; + enableSessionWide = true; + settings = { + full = true; + # histogram = true; + no_display = true; + fps_limit = "0,30,60,72,90,120,144,240,288,320"; + toggle_fps_limit = "Shift_R+F10"; - config.programs.mangohud = lib.mkIf cfg.enable { - enable = true; - enableSessionWide = true; - settings = { - full = true; - # histogram = true; - no_display = true; - fps_limit = "0,30,60,72,90,120,144,240,288,320"; - toggle_fps_limit = "Shift_R+F10"; - toggle_preset = "Control_R+F9"; - fps_metrics = "Control_R+F8"; + # legacy_layout = "false"; + # gpu_stats = true; + # gpu_temp = true; + # gpu_core_clock = true; + # gpu_mem_clock = true; + # gpu_power = true; + # gpu_load_change = true; + # gpu_load_value = "50,90"; + gpu_load_color = "FFFFFF,FFAA7F,CC0000"; + # gpu_text = "GPU"; + # cpu_stats = true; + # cpu_temp = true; + # cpu_power = true; + # cpu_mhz = true; + # cpu_load_change = true; + # core_load_change = true; + # cpu_load_value = "50,90"; + cpu_load_color = "FFFFFF,FFAA7F,CC0000"; + cpu_color = "2e97cb"; + # cpu_text = "CPU"; + # io_stats = true; + # io_read = true; + # io_write = true; + io_color = "a491d3"; + # swap = true; + # vram = true; + vram_color = "ad64c1"; + # ram = true; + ram_color = "c26693"; + # fps = true; + engine_color = "eb5b5b"; + gpu_color = "2e9762"; + wine_color = "eb5b5b"; + # frame_timing = "1"; + frametime_color = "00ff00"; + media_player_color = "ffffff"; + background_alpha = "0.8"; + font_size = "24"; - # legacy_layout = "false"; - # gpu_stats = true; - # gpu_temp = true; - # gpu_core_clock = true; - # gpu_mem_clock = true; - # gpu_power = true; - # gpu_load_change = true; - # gpu_load_value = "50,90"; - gpu_load_color = "FFFFFF,FFAA7F,CC0000"; - # gpu_text = "GPU"; - # cpu_stats = true; - # cpu_temp = true; - # cpu_power = true; - # cpu_mhz = true; - # cpu_load_change = true; - # core_load_change = true; - # cpu_load_value = "50,90"; - cpu_load_color = "FFFFFF,FFAA7F,CC0000"; - cpu_color = "2e97cb"; - # cpu_text = "CPU"; - # io_stats = true; - # io_read = true; - # io_write = true; - io_color = "a491d3"; - # swap = true; - # vram = true; - vram_color = "ad64c1"; - # ram = true; - ram_color = "c26693"; - # fps = true; - engine_color = "eb5b5b"; - gpu_color = "2e9762"; - wine_color = "eb5b5b"; - # frame_timing = "1"; - frametime_color = "00ff00"; - media_player_color = "ffffff"; - background_alpha = "0.8"; - font_size = "24"; - - background_color = "020202"; - position = "top-left"; - # text_color = "ffffff"; - round_corners = "10"; - toggle_hud = "Shift_R+F12"; - # toggle_logging = "Shift_L+F12"; - # output_folder = "/home/lelgenio"; + background_color = "020202"; + position = "top-left"; + # text_color = "ffffff"; + round_corners = "10"; + toggle_hud = "Shift_R+F12"; + # toggle_logging = "Shift_L+F12"; + # output_folder = "/home/lelgenio"; + }; }; }; } diff --git a/user/mimeapps.nix b/user/mimeapps.nix index be6ac1a..533b00f 100644 --- a/user/mimeapps.nix +++ b/user/mimeapps.nix @@ -1,12 +1,6 @@ -{ - config, - pkgs, - lib, - font, - ... -}: +{ config, pkgs, lib, font, ... }: let - inherit (config.my) browser; + inherit (pkgs.uservars) browser; cfg = config.xdg.defaultApplications; in { @@ -32,21 +26,20 @@ in xdg.mimeApps = let - createMimeAssociation = ( - mime_prefix: application: mime_suffix: { "${mime_prefix}/${mime_suffix}" = application; } - ); + createMimeAssociation = (mime_prefix: application: mime_suffix: { + "${mime_prefix}/${mime_suffix}" = application; + }); - createMimeAssociations = ( - mime_prefix: application: mime_suffixes: - lib.foldAttrs (n: _: n) { } (map (createMimeAssociation mime_prefix application) mime_suffixes) - ); + createMimeAssociations = (mime_prefix: application: mime_suffixes: + lib.foldAttrs (n: _: n) { } + (map (createMimeAssociation mime_prefix application) mime_suffixes)); - mimes = - simple + mimes = simple // (createMimeAssociations "text" cfg.text-editor text_suffixes) // (createMimeAssociations "image" cfg.image-viewer image_suffixes) // (createMimeAssociations "video" cfg.video-player video_suffixes) - // (createMimeAssociations "application" cfg.archive-manager archive-suffixes); + // (createMimeAssociations "application" cfg.archive-manager archive-suffixes) + ; simple = { "inode/directory" = cfg.file-manager; @@ -428,6 +421,7 @@ in "x-theora+ogg" ]; + archive-suffixes = [ "bzip2" "gzip" @@ -492,7 +486,7 @@ in { enable = true; defaultApplications = mimes; - associations.added = mimes; }; + }; } diff --git a/user/mpd.nix b/user/mpd.nix index b4bdad3..c100000 100644 --- a/user/mpd.nix +++ b/user/mpd.nix @@ -1,16 +1,5 @@ -{ - lib, - pkgs, - config, - ... -}: -let - cfg = config.my.mpd; -in -{ - options.my.mpd.enable = lib.mkEnableOption { }; - - config = lib.mkIf cfg.enable { +{ lib, pkgs, config, ... }: { + config = lib.mkIf (pkgs.uservars.desktop != "gnome") { services.mpd = { enable = true; musicDirectory = config.home.homeDirectory + "/Música"; diff --git a/user/mpv.nix b/user/mpv.nix index 851860f..e77a08f 100644 --- a/user/mpv.nix +++ b/user/mpv.nix @@ -1,5 +1,4 @@ -{ pkgs, ... }: -{ +{pkgs, ... }: { config = { programs.mpv = { enable = true; @@ -7,7 +6,8 @@ # ytdl-format='best'; # ytdl_path = "yt-dlp"; ytdl-format = "bestvideo[height<=1080][vcodec!=vp9]+bestaudio/best"; - ytdl-raw-options = "cookies=~/.cache/cookies-youtube-com.txt,mark-watched="; + ytdl-raw-options = + "cookies=~/.cache/cookies-youtube-com.txt,mark-watched="; osd-fractions = true; save-position-on-quit = true; keep-open = true; @@ -16,7 +16,7 @@ cache-pause-initial = true; cache-pause-wait = 10; - hwdec = "auto"; + hwdec="auto"; }; scripts = with pkgs.mpvScripts; [ mpris diff --git a/user/pass.nix b/user/pass.nix index c3b56c6..324caa2 100644 --- a/user/pass.nix +++ b/user/pass.nix @@ -1,31 +1,17 @@ -{ - config, - pkgs, - lib, - ... -}: -let - cfg = config.my.pass; -in -{ - options.my.pass.enable = lib.mkEnableOption { }; - - config = lib.mkIf cfg.enable { +{ config, pkgs, lib, inputs, ... }: { + config = { programs.password-store = { enable = true; - package = pkgs.pass.withExtensions ( - ex: with ex; [ - pass-otp - pass-import - ] - ); + package = pkgs.pass.withExtensions (ex: with ex; [ + pass-otp + ]); }; services = { pass-secret-service.enable = true; git-sync = { enable = true; repositories.password-store = { - uri = "forgejo@lelgenio.xyz:lelgenio/password-store"; + uri = "git@git.disroot.org:lelgenio/password-store"; path = toString config.programs.password-store.settings.PASSWORD_STORE_DIR; }; }; @@ -34,8 +20,6 @@ in wpass _gpg-unlock qtpass - readQrCode - pass-export ]; }; } diff --git a/user/pipewire.nix b/user/pipewire.nix index 5e87618..44d7c12 100644 --- a/user/pipewire.nix +++ b/user/pipewire.nix @@ -1,10 +1,4 @@ -{ - config, - pkgs, - lib, - ... -}: -{ +{ config, pkgs, lib, ... }: { # RNNoise is a noise supperssion neural network # Here we use it as a plugin for pipewire to create a virtual microphone config = { @@ -46,7 +40,7 @@ ''; }; - xdg.configFile = { + xdg.configFile = { "pipewire/pipewire.conf.d/99-rtp-sink.conf".text = '' context.modules = [ { name = libpipewire-module-rtp-sink diff --git a/user/powerplay-led-idle.nix b/user/powerplay-led-idle.nix deleted file mode 100644 index a34990e..0000000 --- a/user/powerplay-led-idle.nix +++ /dev/null @@ -1,17 +0,0 @@ -{ pkgs, lib, ... }: -{ - systemd.user.services.powerplay-led-idle = { - Unit = { - Description = "Autosuspend Powerplay mousepad led"; - PartOf = [ "graphical-session.target" ]; - After = [ "graphical-session.target" ]; - }; - Service = { - ExecStart = lib.getExe pkgs.powerplay-led-idle; - Restart = "on-failure"; - }; - Install = { - WantedBy = [ "graphical-session.target" ]; - }; - }; -} diff --git a/user/pqiv.nix b/user/pqiv.nix index 755d417..dc5e8de 100644 --- a/user/pqiv.nix +++ b/user/pqiv.nix @@ -1,21 +1,8 @@ -{ - config, - pkgs, - lib, - inputs, - ... -}: +{ config, pkgs, lib, inputs, ... }: let - inherit (config.my) - key - theme - color - accent - font - ; + inherit (pkgs.uservars) key theme color accent font; - make_direction_binds = lib.imap0 ( - idx: direction: + make_direction_binds = lib.imap0 (idx: direction: let sign = if (idx < 2) then 1 else -1; axis = if ((lib.mod idx 2) != 0) then "y" else "x"; @@ -28,10 +15,11 @@ let montage_mode_shift_${axis}(${toString (sign * -1)}) } } - '' - ); + ''); + in { + # My bemenu wrapper xdg.configFile = { "pqivrc".text = '' [options] @@ -57,12 +45,7 @@ in { goto_file_relative(-1) } { goto_file_relative(1); } - ${lib.concatStrings (make_direction_binds [ - "left" - "up" - "right" - "down" - ])} + ${lib.concatStrings (make_direction_binds [ "left" "up" "right" "down" ])} ${key.tabL} { goto_file_relative(-1) } ${key.tabR} { goto_file_relative(1); } @@ -71,7 +54,10 @@ in d { send_keys(6) } y { send_keys(8) } - ${if (key.layout == "colemak") then "\n t { toggle_scale_mode(0) }\n " else ""} + ${if (key.layout == "colemak") then + "\n t { toggle_scale_mode(0) }\n " + else + ""} # vim: ft=ini ''; diff --git a/user/qutebrowser/colors.nix b/user/qutebrowser/colors.nix new file mode 100644 index 0000000..3a90888 --- /dev/null +++ b/user/qutebrowser/colors.nix @@ -0,0 +1,219 @@ +{ config, pkgs, lib, font, ... }: +let + inherit (pkgs.uservars) key theme accent font browser; + inherit (theme) color; +in +{ + programs.qutebrowser.settings = { + hints.border = "2px solid ${accent.color}"; + + content.user_stylesheets = "style.css"; + colors = { + + ######################################################## + # Tabs + ######################################################## + + tabs = + let + tabs_defaults = { + odd = { + fg = color.txt; + bg = color.bg; + }; + even = { + fg = color.txt; + bg = color.bg_dark; + }; + selected = { + odd = { + fg = accent.fg; + bg = accent.color; + }; + even = { + fg = accent.fg; + bg = accent.color; + }; + }; + }; + in + { + bar = { bg = color.bg; }; + pinned = tabs_defaults; + } // tabs_defaults; + + ######################################################## + # Completion for urls and commands + ######################################################## + + completion = { + fg = color.txt; + even = { bg = color.bg; }; + odd = { bg = color.bg; }; + scrollbar = { bg = color.bg_dark; }; + match = { fg = accent.color; }; + category = { + fg = color.txt; + bg = color.bg_dark; + border = { + top = color.bg_dark; + bottom = color.bg_dark; + }; + }; + item = { + selected = { + fg = accent.fg; + bg = accent.color; + border = { + top = color.bg_dark; + bottom = color.bg_dark; + }; + match = { fg = color.txt; }; + }; + }; + }; + + ######################################################## + # Statusbar + ######################################################## + + statusbar = { + normal = { + fg = color.txt; + bg = color.bg; + }; + insert = { + fg = color.normal.green; + bg = color.bg; + }; + passthrough = { + fg = color.normal.blue; + bg = color.bg; + }; + command = { + fg = color.txt; + bg = color.bg; + }; + caret = { + selection = { + fg = accent.fg; + bg = accent.color; + }; + }; + url = { + success = { + https = { fg = color.txt; }; + http = { fg = color.normal.red; }; + }; + hover = { fg = color.normal.cyan; }; + }; + }; + ######################################################## + # Downloads + ######################################################## + + downloads = { + start = { bg = color.normal.blue; }; + stop = { bg = color.normal.green; }; + bar = { bg = color.bg; }; + }; + + ######################################################## + # Choice of what element should be clicked + ######################################################## + + hints = { + fg = color.txt; + bg = color.bg; + match = { fg = accent.color; }; + }; + + ######################################################## + # List of what each keybinding does + ######################################################## + + keyhint = { + fg = color.txt; + bg = color.bg; + suffix = { fg = accent.color; }; + }; + + ######################################################## + # Right click menu + ######################################################## + + contextmenu = { + menu = { + fg = color.txt; + bg = color.bg; + }; + selected = { + fg = accent.fg; + bg = accent.color; + }; + disabled = { fg = color.bg_light; }; + }; + + ######################################################## + # Dark theme + ######################################################## + + # webpage = lib.mkIf (color.type == "dark") { + # bg = color.bg; + # preferred_color_scheme = "dark"; + # darkmode = { + # enabled = false; + # threshold = { + # text = 150; + # background = 205; + # }; + # }; + # }; + }; + }; + home.file = { + ".config/qutebrowser/style.css".text = '' + ${lib.optionalString (color.type == "dark") '' + button, + input[type="button"] { + color: unset; + background-color: unset; + } + + .bg-gradient-to-b, + body { + background-image: none !important; + } + + /*************************** + * Remove borked ellements * + ***************************/ + + .search-filters-wrap:before, .search-filters-wrap:after { + + display: none; + } + ''} + + /***************** + * Hide some ads * + *****************/ + + /*Reddit*/ + #sr-header-area .redesign-beta-optin, + .link.promotedlink.promoted, + .spacer:empty, + .spacer .premium-banner-outer, + .ad-container, + + /*Youtube*/ + div#masthead-ad , + .video-ads, + #player-ads, + ytd-popup-container { + display: none !important; + } + ''; + }; +} + diff --git a/user/qutebrowser/dark-theme.nix b/user/qutebrowser/dark-theme.nix new file mode 100644 index 0000000..a596251 --- /dev/null +++ b/user/qutebrowser/dark-theme.nix @@ -0,0 +1,90 @@ +{ config, pkgs, lib, font, ... }: +let + inherit (pkgs.uservars) theme; + inherit (theme) color; + + # ".config/qutebrowser/greasemonkey/darkreader.js".text = + darkThemeUserscript = enabled: pkgs.writeText "darkreader.js" '' + // ==UserScript== + // @name Dark Reader (Unofficial) + // @icon https://darkreader.org/images/darkreader-icon-256x256.png + // @namespace DarkReader + // @description Inverts the brightness of pages to reduce eye strain + // @version 4.7.15 + // @author https://github.com/darkreader/darkreader#contributors + // @homepageURL https://darkreader.org/ | https://github.com/darkreader/darkreader + // @run-at document-end + // @grant none + // @include http* + // @require https://cdn.jsdelivr.net/npm/darkreader/darkreader.min.js + // @noframes + // ==/UserScript== + + DarkReader.setFetchMethod(window.fetch) + + if (${if enabled then "false" else "true"}) { + DarkReader.disable(); + return; + } + + const ignore_list = [ + "askubuntu.com", + "mathoverflow.com", + "mathoverflow.net", + "serverfault.com", + "stackapps.com", + "stackexchange.com", + "stackoverflow.com", + "superuser.com", + "hub.docker.com", + ]; + + for (let item of ignore_list) { + if (window.location.origin.indexOf(item) >= 0) { + console.log("URL matched dark-mode ignore list"); + return; + } + } + + DarkReader.enable({ + brightness: 100, + contrast: 100, + sepia: 0, + + darkSchemeBackgroundColor: "${color.bg}", + darkSchemeTextColor: "${color.txt}", + + lightSchemeBackgroundColor: "${color.bg}", + lightSchemeTextColor: "${color.txt}", + }); + ''; +in +{ + programs.qutebrowser.keyBindings = { + normal = { + "K" = "spawn --userscript toggle-dark-theme"; + }; + }; + home.file = { + ".local/share/qutebrowser/userscripts/toggle-dark-theme".executable = true; + ".local/share/qutebrowser/userscripts/toggle-dark-theme".text = '' + #!/bin/sh + DARK_READER_SCRIPT="$HOME/.config/qutebrowser/greasemonkey/darkreader.js" + MARKER="$HOME/.config/qutebrowser/is-dark-mode" + if test -f "$MARKER" + then + rm -f "$MARKER" + cp -f ${darkThemeUserscript false} "$DARK_READER_SCRIPT" + echo "jseval --world main DarkReader.disable()" >> "$QUTE_FIFO" + else + touch "$MARKER" + cp -f ${darkThemeUserscript true} "$DARK_READER_SCRIPT" + echo "jseval --world main DarkReader.enable()" >> "$QUTE_FIFO" + fi + if test -n "$QUTE_FIFO"; then + echo "greasemonkey-reload --quiet" >> "$QUTE_FIFO" + fi + ''; + }; +} + diff --git a/user/qutebrowser/default.nix b/user/qutebrowser/default.nix new file mode 100644 index 0000000..467340b --- /dev/null +++ b/user/qutebrowser/default.nix @@ -0,0 +1,152 @@ +{ config, pkgs, lib, font, ... }: +let + inherit (pkgs.uservars) key browser editor; +in +{ + imports = [ + ./colors.nix + ./dark-theme.nix + ./fonts.nix + ]; + + config = { + programs.qutebrowser = { + enable = true; + # enableDefaultBindings = false; + keyBindings = { + normal = { + # basic movent + "${key.left}" = "scroll left"; + "${key.down}" = "scroll down"; + "${key.up}" = "scroll up"; + "${key.right}" = "scroll right"; + + "${lib.toUpper key.up}" = "scroll-px 0 -100"; + "${lib.toUpper key.down}" = "scroll-px 0 100"; + "${lib.toUpper key.left}" = "back"; + "${lib.toUpper key.right}" = "forward"; + "${lib.toUpper key.tabL}" = "tab-prev"; + "${lib.toUpper key.tabR}" = "tab-next"; + + "${key.next}" = "search-next"; + "${lib.toUpper key.next}" = "search-prev"; + + "${key.insertMode}" = "mode-enter insert"; + # ":" = "mode-enter command"; + + "t" = "hint all"; + "h" = "set-cmd-text -s :open"; + "T" = "hint all tab"; + "H" = "set-cmd-text -s :open -t"; + + "" = "tree-tab-promote"; + "" = "tree-tab-demote"; + + "co" = "tab-only --pinned keep"; + + # "K" = "jseval --world main if (DarkReader.isEnabled()) {DarkReader.disable()} else {DarkReader.enable()}"; + }; + insert = { + # quit insert mode + "" = "mode-enter normal"; + }; + caret = { + # basic movent + "${key.left}" = "move-to-prev-char"; + "${key.down}" = "move-to-next-line"; + "${key.up}" = "move-to-prev-line"; + "${key.right}" = "move-to-next-char"; + + "${key.insertMode}" = "mode-enter insert"; + }; + + }; + settings = { + tabs.tree_tabs = true; + tabs.position = "right"; + tabs.pinned.shrink = false; + tabs.title.format = "{tree}{collapsed}{audio}{index}: {current_title}"; + tabs.title.format_pinned = "{tree}{collapsed}{audio}{index} 🔒: {current_title}"; + + session.lazy_restore = true; + auto_save.session = true; + + hints.chars = key.hints; + editor.command = [ + "terminal" + "-e" + { + kakoune = "kak"; + helix = "hx"; + }.${editor} + "{file}" + "+{line}" + ]; + + input.insert_mode.auto_leave = false; + + content.autoplay = false; + content.blocking.adblock.lists = [ + "https://easylist.to/easylist/easylist.txt" + "https://easylist.to/easylist/easyprivacy.txt" + "https://easylist-downloads.adblockplus.org/easylistdutch.txt" + "https://easylist-downloads.adblockplus.org/abp-filters-anti-cv.txt" + "https://www.i-dont-care-about-cookies.eu/abp/" + "https://secure.fanboy.co.nz/fanboy-cookiemonster.txt" + ]; + }; + extraConfig = '' + config.load_autoconfig() + config.set("content.notifications.enabled", True, "https://web.whatsapp.com") + ''; + }; + systemd.user.services = lib.mkIf (browser == "qutebrowser") { + qutebrowser = { + Unit = { + Description = "Qutebrowser Web client"; + PartOf = [ "graphical-session.target" ]; + After = [ "graphical-session.target" ]; + }; + Service = { + ExecStartPre = "/usr/bin/env sleep 10s"; + ExecStart = "${pkgs.qutebrowser}/bin/qutebrowser"; + Restart = "on-failure"; + }; + Install = { WantedBy = [ "sway-session.target" ]; }; + }; + }; + home.file = { + # For some stupid reason qutebrowser crashes if this dir does not exist + ".local/share/qutebrowser/greasemonkey/.keep".text = ""; + ".config/qutebrowser/greasemonkey/youtube.js".text = '' + // ==UserScript== + // @name Auto Skip YouTube Ads + // @version 1.0.2 + // @description Speed up and skip YouTube ads automatically + // @author codiac-killer + // @match *://*.youtube.com/* + // @exclude *://*.youtube.com/subscribe_embed?* + // ==/UserScript== + + let main = new MutationObserver(() => { + // Get skip button and click it + let btn = document.getElementsByClassName("ytp-ad-skip-button ytp-button").item(0) + if (btn) { + btn.click() + } + + // (unskipable ads) If skip button didn't exist / was not clicked speed up video + const ad = [...document.querySelectorAll('.ad-showing')][0]; + if (ad) { + // Speed up and mute + document.querySelector('video').playbackRate = 16; + document.querySelector('video').muted = true; + } + }) + + main.observe(document.getElementsByClassName("video-ads ytp-ad-module").item(0), {attributes: true, characterData: true, childList: true}) + ''; + }; + }; +} + diff --git a/user/qutebrowser/fonts.nix b/user/qutebrowser/fonts.nix new file mode 100644 index 0000000..e6eee6b --- /dev/null +++ b/user/qutebrowser/fonts.nix @@ -0,0 +1,36 @@ +{ pkgs, ... }: +let + inherit (pkgs.uservars) font; +in +{ + programs.qutebrowser.settings.fonts = + let + mkFont = name: size: "${toString size}px ${name}"; + DEF_MONO = mkFont font.mono font.size.medium; + BIG_MONO = mkFont font.mono font.size.big; + DEF_INTER = mkFont font.interface font.size.medium; + BIG_INTER = mkFont font.interface font.size.big; + in + { + debug_console = BIG_INTER; + downloads = BIG_INTER; + hints = "bold " + BIG_MONO; + keyhint = BIG_INTER; + prompts = BIG_INTER; + statusbar = DEF_MONO; + completion = { + entry = BIG_INTER; + category = BIG_INTER; + }; + messages = { + error = DEF_INTER; + info = DEF_INTER; + warning = DEF_INTER; + }; + tabs = { + selected = BIG_INTER; + unselected = BIG_INTER; + }; + }; +} + diff --git a/user/ranger/default.nix b/user/ranger/default.nix index 4b97170..ec09936 100644 --- a/user/ranger/default.nix +++ b/user/ranger/default.nix @@ -1,11 +1,4 @@ -{ - config, - pkgs, - lib, - inputs, - ... -}: -{ +{ config, pkgs, lib, inputs, ... }: { xdg.configFile = { "ranger/rc.conf".source = ./rc.conf; "ranger/rifle.conf".source = ./rifle.conf; diff --git a/user/ranger/rc.conf b/user/ranger/rc.conf index ad71849..3936f36 100644 --- a/user/ranger/rc.conf +++ b/user/ranger/rc.conf @@ -27,10 +27,10 @@ set confirm_on_delete multiple # Use non-default path for file preview script? # ranger ships with scope.sh, a script that calls external programs (see # README.md for dependencies) to preview images, archives, etc. -# set preview_script ~/.config/ranger/scope.sh +set preview_script ~/.config/ranger/scope.sh # Use the external preview script or display simple plain text or image previews? -# set use_preview_script true +set use_preview_script true # Automatically count files in the directory, even before entering them? set automatically_count_files true @@ -40,7 +40,7 @@ set automatically_count_files true set open_all_images true # Be aware of version control systems and display information. -set vcs_aware false +set vcs_aware true # State of the four backends git, hg, bzr, svn. The possible states are # disabled, local (only show local info), enabled (show local and remote diff --git a/user/rm-target.nix b/user/rm-target.nix deleted file mode 100644 index 93c6058..0000000 --- a/user/rm-target.nix +++ /dev/null @@ -1,26 +0,0 @@ -{ pkgs, lib, ... }: -{ - systemd.user.services.rm-target = { - Unit = { - Description = "Remove directories named 'target'"; - }; - Service = { - Type = "oneshot"; - ExecStart = pkgs.writeShellScript "rm-target" '' - sudo ${pkgs.fd}/bin/fd -td -u '^\.?target$' "$HOME" -x rm -vrf -- - ''; - }; - }; - systemd.user.timers.rm-target = { - Unit = { - Description = "Remove directories named 'target'"; - }; - Timer = { - OnCalendar = "weekly"; - Unit = "rm-target.service"; - }; - Install = { - WantedBy = [ "timers.target" ]; - }; - }; -} diff --git a/user/rofi.nix b/user/rofi.nix index c24a0ce..d9026d2 100644 --- a/user/rofi.nix +++ b/user/rofi.nix @@ -1,17 +1,6 @@ -{ - config, - pkgs, - lib, - font, - ... -}: +{ config, pkgs, lib, font, ... }: let - inherit (config.my) - key - theme - accent - font - ; + inherit (pkgs.uservars) key theme accent font; inherit (theme) color; in { @@ -53,15 +42,14 @@ in }; "#window" = { - background-color = mkLiteral "${color.bg}${lib.toHexString (theme.opacity * 255 / 100)}"; + background-color = mkLiteral + "${color.bg}${lib.toHexString (theme.opacity * 255 / 100)}"; # children = map mkLiteral [ "prompt" "entry" ]; border = mkLiteral "2px solid"; border-color = mkLiteral accent.color; padding = 0; }; - "#inputbar" = { - margin = mkLiteral "10px"; - }; + "#inputbar" = { margin = mkLiteral "10px"; }; "#listview" = { # fixed-height=0; border = mkLiteral "2px solid 0px 0px"; @@ -90,7 +78,9 @@ in margin-right = mkLiteral "20px"; size = 24; }; + }; + }; }; } diff --git a/user/satty/config.toml b/user/satty/config.toml deleted file mode 100644 index 84075cb..0000000 --- a/user/satty/config.toml +++ /dev/null @@ -1,63 +0,0 @@ -[general] -# Start Satty in fullscreen mode -fullscreen = true -# Exit directly after copy/save action -early-exit = true -# Draw corners of rectangles round if the value is greater than 0 (0 disables rounded corners) -corner-roundness = 12 -# Select the tool on startup [possible values: pointer, crop, line, arrow, rectangle, text, marker, blur, brush] -initial-tool = "brush" -# Configure the command to be called on copy, for example `wl-copy` -copy-command = "wl-copy" -# Increase or decrease the size of the annotations -# annotation-size-factor = 2 -# Filename to use for saving action. Omit to disable saving to file. Might contain format specifiers: https://docs.rs/chrono/latest/chrono/format/strftime/index.html -# output-filename = "/tmp/test-%Y-%m-%d_%H:%M:%S.png" -# After copying the screenshot, save it to a file as well -# save-after-copy = false -# Hide toolbars by default -# default-hide-toolbars = false -# Experimental: whether window focus shows/hides toolbars. This does not affect initial state of toolbars, see default-hide-toolbars. -# focus-toggles-toolbars = false -# The primary highlighter to use, the other is accessible by holding CTRL at the start of a highlight [possible values: block, freehand] -primary-highlighter = "block" -# Disable notifications -disable-notifications = true -# Actions to trigger on right click (order is important) -# [possible values: save-to-clipboard, save-to-file, exit] -# actions-on-right-click = [] -# Actions to trigger on Enter key (order is important) -# [possible values: save-to-clipboard, save-to-file, exit] -# actions-on-enter = ["save-to-clipboard"] -# Actions to trigger on Escape key (order is important) -# [possible values: save-to-clipboard, save-to-file, exit] -# actions-on-escape = ["exit"] -# Action to perform when the Enter key is pressed [possible values: save-to-clipboard, save-to-file] -# Deprecated: use actions-on-enter instead -action-on-enter = "save-to-clipboard" -# Right click to copy -# Deprecated: use actions-on-right-click instead -# right-click-copy = false -# request no window decoration. Please note that the compositor has the final say in this. At this point. requires xdg-decoration-unstable-v1. -# no-window-decoration = true -# experimental feature: adjust history size for brush input smooting (0: disabled, default: 0, try e.g. 5 or 10) -# brush-smooth-history-size = 10 - -# Font to use for text annotations -[font] -family = "Roboto" -style = "Bold" - -# Custom colours for the colour palette -[color-palette] -# These will be shown in the toolbar for quick selection -palette = [ - "#ff0000", - "#00ffff", - "#a52a2a", - "#dc143c", - "#ff1493", - "#ffd700", - "#008000", -] - diff --git a/user/satty/default.nix b/user/satty/default.nix deleted file mode 100644 index 5709b77..0000000 --- a/user/satty/default.nix +++ /dev/null @@ -1,22 +0,0 @@ -{ - pkgs, - lib, - config, - ... -}: -let - cfg = config.my.satty; -in -{ - options.my.satty.enable = lib.mkEnableOption { }; - - config = lib.mkIf cfg.enable { - xdg.configFile."satty/config.toml" = { - source = ./config.toml; - }; - - home.packages = with pkgs; [ - satty - ]; - }; -} diff --git a/user/ssh.nix b/user/ssh.nix index 4747bb4..382266f 100644 --- a/user/ssh.nix +++ b/user/ssh.nix @@ -1,20 +1,19 @@ -{ +{ config, pkgs, lib, ... }: +let inherit (pkgs.uservars) username mail; +in { config = { - programs.ssh = { - enable = true; - matchBlocks = { - monolith = { - user = "lelgenio"; - hostname = "monolith.lelgenio.com"; - port = 9022; - }; - phantom = { - user = "root"; - hostname = "phantom.lelgenio.com"; - port = 9022; - }; + programs.ssh.enable = true; + programs.ssh.matchBlocks = { + monolith = { + user = "lelgenio"; + hostname = "lelgenio.1337.cx"; + port = 9022; + }; + ghost = { + user = "root"; + hostname = "lelgenio.xyz"; + port = 9022; }; - includes = [ "~/Wopus/.ssh.config" ]; }; }; } diff --git a/user/sway/default.nix b/user/sway/default.nix index 5fbd379..c79e0d8 100644 --- a/user/sway/default.nix +++ b/user/sway/default.nix @@ -1,14 +1,7 @@ -{ - config, - pkgs, - lib, - ... -}: +{ config, pkgs, lib, ... }: let - inherit (config.my) accent font theme; + inherit (pkgs.uservars) key accent font theme; inherit (theme) color; - - cfg = config.my.sway; in { imports = [ @@ -20,30 +13,19 @@ in ./swayidle.nix ./swaylock.nix ./theme.nix - ./gammastep.nix ]; - - options.my.sway.enable = lib.mkEnableOption { }; - - config = lib.mkIf cfg.enable { - my.mako.enable = true; - my.kanshi.enable = true; - my.swayidle.enable = true; - my.swaylock.enable = true; - my.mpd.enable = true; - my.zathura.enable = true; - my.satty.enable = true; - my.waybar.enable = true; - my.gammastep.enable = true; + config = lib.mkIf (pkgs.uservars.desktop == "sway") { + services.mako.enable = true; + services.swayidle.enable = true; + services.kanshi.enable = true; wayland.windowManager.sway = { enable = true; - package = pkgs.mySway; config = { bars = [ ]; floating.modifier = "Mod4"; - terminal = lib.getExe pkgs.alacritty; + terminal = pkgs.alacritty.executable; window.titlebar = false; gaps = { @@ -59,13 +41,7 @@ in bg_color = color.bg_dark; alert = "#000000"; client = border: background: text: indicator: childBorder: { - inherit - border - background - text - indicator - childBorder - ; + inherit border background text indicator childBorder; }; in { @@ -85,14 +61,6 @@ in names = [ font.interface ]; size = font.size.medium * 1.0; }; - # Ignore PS4 controller touchpad events - input."1356:2508:Wireless_Controller_Touchpad".events = "disabled"; - - input."type:pointer" = { - accel_profile = "flat"; - pointer_accel = "0"; - }; - input."type:touchpad" = { # Disable While Typing dwt = "enabled"; @@ -108,42 +76,43 @@ in }; # setup cursor based on home.pointerCursor seat."*" = { - xcursor_theme = "${config.home.pointerCursor.name} ${toString config.home.pointerCursor.size}"; + xcursor_theme = "${config.home.pointerCursor.name} ${ + toString config.home.pointerCursor.size + }"; hide_cursor = "when-typing enable"; }; }; extraConfig = '' for_window [title=.*] inhibit_idle fullscreen + exec ${pkgs.dbus-sway-environment}/bin/dbus-sway-environment exec swaymsg workspace 2 - exec_always systemctl --user restart waybar.service ''; }; + services.gammastep = { + enable = true; + provider = "geoclue2"; + }; services.kdeconnect = { enable = true; indicator = true; }; - services.gpg-agent.pinentry.package = pkgs.pinentry-all; - - xdg.configFile."OpenTabletDriver/settings.json" = { - force = true; - source = ./open-tablet-driver.json; - }; + packages.firefox.hideTitleBar = true; home.packages = with pkgs; [ - mySway + sway swaybg swaylock wdisplays + waybar dhist demoji bmenu wdmenu wlauncher volumesh - brightnessctl showkeys pamixer libnotify @@ -156,13 +125,9 @@ in wl-crosshair grim - satty - xdg-user-dirs + swappy (tesseract5.override { - enableLanguages = [ - "eng" - "por" - ]; + enableLanguages = [ "eng" "por" ]; }) ]; }; diff --git a/user/sway/gammastep.nix b/user/sway/gammastep.nix deleted file mode 100644 index a5b6917..0000000 --- a/user/sway/gammastep.nix +++ /dev/null @@ -1,19 +0,0 @@ -{ config, lib, ... }: -let - cfg = config.my.gammastep; -in -{ - options.my.gammastep.enable = lib.mkEnableOption { }; - - config = lib.mkIf cfg.enable { - services.gammastep = { - enable = true; - dawnTime = "6:00-7:45"; - duskTime = "18:35-20:15"; - temperature = { - day = 6500; - night = 4500; - }; - }; - }; -} diff --git a/user/sway/kanshi.nix b/user/sway/kanshi.nix index 486a209..edc2e3f 100644 --- a/user/sway/kanshi.nix +++ b/user/sway/kanshi.nix @@ -1,43 +1,33 @@ -{ config, lib, ... }: +{ config, pkgs, lib, ... }: let - cfg = config.my.kanshi; + inherit (pkgs.uservars) key accent font theme; + inherit (theme) color; in { - options.my.kanshi.enable = lib.mkEnableOption { }; - - config.services.kanshi = lib.mkIf cfg.enable { - enable = true; - settings = [ - { - profile = { - name = "sedetary"; - outputs = [ - { - criteria = "eDP-1"; - status = "disable"; - position = "1920,312"; - } - { - criteria = "HDMI-A-1"; - position = "0,0"; - } - ]; - exec = [ "xrdb .Xresources" ]; - }; - } - { - profile = { - name = "nomad"; - outputs = [ - { - criteria = "eDP-1"; - status = "enable"; - position = "1920,312"; - } - ]; - exec = [ "xrdb .Xresources" ]; - }; - } - ]; + services.kanshi = { + profiles = { + sedetary = { + outputs = [ + { + criteria = "eDP-1"; + status = "disable"; + position = "1920,312"; + } + { + criteria = "HDMI-A-1"; + position = "0,0"; + } + ]; + exec = [ "xrdb .Xresources" ]; + }; + nomad = { + outputs = [{ + criteria = "eDP-1"; + status = "enable"; + position = "1920,312"; + }]; + exec = [ "xrdb .Xresources" ]; + }; + }; }; } diff --git a/user/sway/mako.nix b/user/sway/mako.nix index 6c78c9f..2089d22 100644 --- a/user/sway/mako.nix +++ b/user/sway/mako.nix @@ -1,73 +1,54 @@ -{ - config, - pkgs, - lib, - ... -}: +{ config, pkgs, lib, ... }: let - inherit (config.my) - accent - font - theme - ; + inherit (pkgs.uservars) key accent font theme desktop; inherit (theme) color; - - cfg = config.my.mako; in { - options.my.mako.enable = lib.mkEnableOption { }; + services.mako = { + borderSize = 2; + borderRadius = if desktop == "sway" then 0 else 5; + padding = "5"; + margin = "15"; + layer = "overlay"; - config = lib.mkIf cfg.enable { - services.mako = { - enable = true; + font = "${font.interface} ${toString font.size.small}"; + textColor = color.txt; - settings = { - border-size = 2; - padding = "5"; - margin = "15"; - layer = "overlay"; + backgroundColor = color.bg; + borderColor = accent.color; + progressColor = "over ${accent.color}88"; - font = "${font.interface} ${toString font.size.small}"; - text-color = color.txt; + defaultTimeout = 10000; - background-color = color.bg; - border-color = accent.color; - progress-color = "over ${accent.color}88"; + extraConfig = '' + [app-name=volumesh] + default-timeout=5000 + group-by=app-name + format=%s\n%b + ''; - default-timeout = 10000; + # # {{@@ header() @@}} + # # text - "app-name=volumesh" = { - "default-timeout" = "5000"; - "group-by" = "app-name"; - "format" = "%s\\n%b"; - }; - }; + # # features + # icons=1 + # markup=1 + # actions=1 + # default-timeout=10000 - # # {{@@ header() @@}} - # # text - - # # features - # icons=1 - # markup=1 - # actions=1 - # default-timeout=10000 - - # # position - # layer=overlay + # # position + # layer=overlay + }; + systemd.user.services.mako = lib.mkIf (config.services.mako.enable) { + Unit = { + Description = "Notification daemon"; + PartOf = [ "graphical-session.target" ]; + After = [ "graphical-session.target" ]; }; - systemd.user.services.mako = lib.mkIf (config.services.mako.enable) { - Unit = { - Description = "Notification daemon"; - PartOf = [ "graphical-session.target" ]; - After = [ "graphical-session.target" ]; - }; - Service = { - ExecStart = "${pkgs.mako}/bin/mako"; - Restart = "on-failure"; - }; - Install = { - WantedBy = [ "sway-session.target" ]; - }; + Service = { + ExecStart = "${pkgs.mako}/bin/mako"; + Restart = "on-failure"; }; + Install = { WantedBy = [ "sway-session.target" "hyprland-sessions.target" ]; }; }; } diff --git a/user/sway/open-tablet-driver.json b/user/sway/open-tablet-driver.json deleted file mode 100644 index bf49af6..0000000 --- a/user/sway/open-tablet-driver.json +++ /dev/null @@ -1,114 +0,0 @@ -{ - "Profiles": [ - { - "Tablet": "Wacom CTL-4100", - "OutputMode": { - "Path": "OpenTabletDriver.Desktop.Output.LinuxArtistMode", - "Settings": [], - "Enable": true - }, - "Filters": [], - "AbsoluteModeSettings": { - "Display": { - "Width": 1920.0, - "Height": 1080.0, - "X": 960.0, - "Y": 540.0, - "Rotation": 0.0 - }, - "Tablet": { - "Width": 152.0, - "Height": 85.5, - "X": 76.0, - "Y": 47.5, - "Rotation": 0.0 - }, - "EnableClipping": false, - "EnableAreaLimiting": false, - "LockAspectRatio": true - }, - "RelativeModeSettings": { - "XSensitivity": 10.0, - "YSensitivity": 10.0, - "RelativeRotation": 0.0, - "RelativeResetDelay": "00:00:00.1000000" - }, - "Bindings": { - "TipActivationThreshold": 0.0, - "TipButton": null, - "EraserActivationThreshold": 0.0, - "EraserButton": null, - "PenButtons": [ - { - "Path": "OpenTabletDriver.Desktop.Binding.LinuxArtistMode.LinuxArtistModeButtonBinding", - "Settings": [ - { - "Property": "Button", - "Value": "Pen Button 1" - } - ], - "Enable": true - }, - { - "Path": "OpenTabletDriver.Desktop.Binding.LinuxArtistMode.LinuxArtistModeButtonBinding", - "Settings": [ - { - "Property": "Button", - "Value": "Pen Button 2" - } - ], - "Enable": true - } - ], - "AuxButtons": [ - { - "Path": "OpenTabletDriver.Desktop.Binding.MultiKeyBinding", - "Settings": [ - { - "Property": "Keys", - "Value": "Control+Z" - } - ], - "Enable": true - }, - { - "Path": "OpenTabletDriver.Desktop.Binding.MultiKeyBinding", - "Settings": [ - { - "Property": "Keys", - "Value": "Control+Shift+Z" - } - ], - "Enable": true - }, - { - "Path": "OpenTabletDriver.Desktop.Binding.MultiKeyBinding", - "Settings": [ - { - "Property": "Keys", - "Value": "Control+Minus" - } - ], - "Enable": true - }, - { - "Path": "OpenTabletDriver.Desktop.Binding.MultiKeyBinding", - "Settings": [ - { - "Property": "Keys", - "Value": "Control+Equal" - } - ], - "Enable": true - } - ], - "MouseButtons": [], - "MouseScrollUp": null, - "MouseScrollDown": null - } - } - ], - "LockUsableAreaDisplay": true, - "LockUsableAreaTablet": true, - "Tools": [] -} \ No newline at end of file diff --git a/user/sway/sway-assigns.nix b/user/sway/sway-assigns.nix index 8f073c7..3731222 100644 --- a/user/sway/sway-assigns.nix +++ b/user/sway/sway-assigns.nix @@ -1,22 +1,26 @@ { config, pkgs, ... }: let + # inherit (pkgs.uservars) key accent font theme; + # inherit (theme) color; + # inherit (pkgs) lib; + + # mod = "Mod4"; + # menu = "wlauncher"; + # terminal = "alacritty"; + + # locked_binds = + # lib.mapAttrs' (k: v: lib.nameValuePair "--locked ${k}" v); + # code_binds = + # lib.mapAttrs' (k: v: lib.nameValuePair "--to-code ${k}" v); + # return_mode = lib.mapAttrs (k: v: "${v}; mode default"); + # playerctl = "exec ${pkgs.playerctl}/bin/playerctl"; in -# inherit (config.my) key accent font theme; -# inherit (theme) color; -# inherit (pkgs) lib; -# mod = "Mod4"; -# menu = "wlauncher"; -# terminal = "alacritty"; -# locked_binds = -# lib.mapAttrs' (k: v: lib.nameValuePair "--locked ${k}" v); -# code_binds = -# lib.mapAttrs' (k: v: lib.nameValuePair "--to-code ${k}" v); -# return_mode = lib.mapAttrs (k: v: "${v}; mode default"); -# playerctl = "exec ${pkgs.playerctl}/bin/playerctl"; { wayland.windowManager.sway.config = { assigns = { "2" = [ + { class = "qutebrowser"; } + { app_id = "qutebrowser"; } { class = "firefox"; } { app_id = "firefox"; } { class = "Chromium"; } @@ -44,15 +48,12 @@ in { title = "Discord"; } { class = "WebCord"; } { app_id = "WebCord"; } - { class = "vesktop"; } - { app_id = "vesktop"; } { class = "Element"; } { app_id = "Element"; } ]; }; floating = { criteria = [ - { class = "Godot"; } { class = "file_picker"; } { app_id = "file_picker"; } { app_id = "wdisplays"; } diff --git a/user/sway/sway-binds.nix b/user/sway/sway-binds.nix index ae71cf4..12a69cc 100644 --- a/user/sway/sway-binds.nix +++ b/user/sway/sway-binds.nix @@ -1,11 +1,6 @@ { config, pkgs, ... }: let - inherit (config.my) - key - accent - font - theme - ; + inherit (pkgs.uservars) key accent font theme; inherit (theme) color; inherit (pkgs) lib; @@ -16,36 +11,38 @@ let _lock = pkgs.writeShellScriptBin "_lock" '' ${pkgs.sway}/bin/swaymsg mode default ${pkgs.swaylock}/bin/swaylock -f + systemctl --user start swayidle.service ''; _suspend = pkgs.writeShellScriptBin "_suspend" '' - ${pkgs.sway}/bin/swaymsg mode default - systemctl --user start swayidle.service + ${_lock}/bin/_lock systemctl suspend ''; # mod+1 to swich to workspace 1 # mod+shift+1 to move to workspace 1 - workspace_binds = lib.forEachMerge (lib.range 1 10) ( - i: + workspace_binds = lib.forEachMerge (lib.range 1 10) (i: let key = toString (lib.mod i 10); workspaceNumber = toString i; in { "${mod}+${key}" = "workspace number ${workspaceNumber}"; - "${mod}+Shift+${key}" = "move container to workspace number ${workspaceNumber}"; - } - ); + "${mod}+Shift+${key}" = + "move container to workspace number ${workspaceNumber}"; + }); prev_next_binds = let - maybe_window = key: if (lib.strings.hasInfix "button" key) then "--whole-window" else ""; - makePrevNextBindFunction = ( - prev_or_next: + maybe_window = key: + if (lib.strings.hasInfix "button" key) then + "--whole-window" + else + ""; + makePrevNextBindFunction = (prev_or_next: map (key: { - "${maybe_window key} ${mod}+${key}" = "workspace ${prev_or_next}_on_output"; - }) - ); + "${maybe_window key} ${mod}+${key}" = + "workspace ${prev_or_next}_on_output"; + })); prev_binds = makePrevNextBindFunction "prev" [ key.tabL "bracketleft" @@ -69,51 +66,36 @@ let # for every direction with both arrow keys and vim keys movement_binds = let - directions = [ - "Left" - "Up" - "Right" - "Down" - ]; + directions = [ "Left" "Up" "Right" "Down" ]; makeVimKeys = (k: key.${lib.toLower k}); makeArrowKeys = (k: k); - makeResizeCommand = - direction: + makeResizeCommand = direction: { Left = "shrink width 20px"; Up = "shrink height 20px"; Right = "grow width 20px"; Down = "grow height 20px"; - } - .${direction}; + }.${direction}; in - lib.forEachMerge - [ - makeVimKeys - makeArrowKeys - ] - ( - prefixFun: - lib.forEachMerge directions ( - direction: - let - resize_cmd = makeResizeCommand direction; - keyBind = prefixFun direction; - in - { - # Move focus - "${mod}+${keyBind}" = "focus ${direction}"; - # Move window - "${mod}+Shift+${keyBind}" = "move ${direction}"; - # Resize window - "${mod}+Control+${keyBind}" = "resize ${resize_cmd}"; - # focus output - "${mod}+mod1+${keyBind}" = "focus output ${direction}"; - # Move workspace to output - "${mod}+mod1+Shift+${keyBind}" = "move workspace output ${direction}"; - } - ) - ); + lib.forEachMerge [ makeVimKeys makeArrowKeys ] (prefixFun: + lib.forEachMerge directions (direction: + let + resize_cmd = makeResizeCommand direction; + keyBind = prefixFun direction; + in + { + # Move focus + "${mod}+${keyBind}" = "focus ${direction}"; + # Move window + "${mod}+Shift+${keyBind}" = "move ${direction}"; + # Resize window + "${mod}+Control+${keyBind}" = "resize ${resize_cmd}"; + # focus output + "${mod}+mod1+${keyBind}" = "focus output ${direction}"; + # Move workspace to output + "${mod}+mod1+Shift+${keyBind}" = + "move workspace output ${direction}"; + })); parenting_binds = { "${mod}+equal" = "focus parent"; @@ -133,7 +115,8 @@ let XF86AudioRaiseVolume = "exec volumesh -i 10"; XF86AudioLowerVolume = "exec volumesh -d 10"; XF86AudioMute = "exec volumesh -t"; - XF86AudioMicMute = "exec pactl set-source-mute @DEFAULT_SOURCE@ toggle"; + XF86AudioMicMute = + "exec pactl set-source-mute @DEFAULT_SOURCE@ toggle"; # Control media XF86AudioPlay = "exec playerctl play-pause"; XF86AudioPause = "exec playerctl play-pause"; @@ -152,36 +135,27 @@ let # Screen area to file "Shift+Print" = "exec ${pkgs.screenshotsh}/bin/screenshotsh area"; # Screen area to clipboard - "Control+Shift+Print" = "exec ${pkgs.screenshotsh}/bin/screenshotsh area-clip"; + "Control+Shift+Print" = + "exec ${pkgs.screenshotsh}/bin/screenshotsh area-clip"; # Focused monitor to clipboard "Control+Print" = "exec ${pkgs.screenshotsh}/bin/screenshotsh clip"; }; - screen_binds = { - "XF86MonBrightnessDown" = "exec brightnessctl --min-value=1 set 5%-"; - "XF86MonBrightnessUp" = "exec brightnessctl --min-value=1 set 5%+"; - "${mod}+l" = lib.getExe _lock; - }; - other_binds = { "${mod}+p" = "exec ${pkgs.wpass}/bin/wpass"; "${mod}+s" = "exec ${menu}"; - "${mod}+g" = - "exec ${pkgs.demoji}/bin/demoji --lang pt --fallback --copy -- ${pkgs.wdmenu}/bin/wdmenu"; + "${mod}+g" = "exec ${pkgs.demoji}/bin/demoji --lang pt --fallback --copy -- ${pkgs.wdmenu}/bin/wdmenu"; "${mod}+c" = "exec ${pkgs.color_picker}/bin/color_picker"; "${mod}+Return" = "exec ${terminal}"; "${mod}+Ctrl+Return" = "exec thunar"; - "${mod}+Shift+s" = '' - exec grim - | satty --filename - --output-filename "$(xdg-user-dir PICTURES)"/Screenshots/satty-$(date '+%Y%m%d-%H:%M:%S').png - ''; + "${mod}+Shift+s" = "exec grim - | swappy -f -"; "${mod}+Ctrl+v" = "exec wl-paste | tesseract -l por - - | wl-copy"; "${mod}+k" = "exec showkeys"; "${mod}+Alt+x" = "exec pkill wl-crosshair || exec wl-crosshair"; "${mod}+x" = "kill"; "${mod}+m" = "mode audio"; - "${mod}+escape" = "mode passthrough;exec notify-send 'Passthrough on'"; - "${mod}+ctrl+k" = "exec swaymsg input type:pointer events disabled"; - "${mod}+ctrl+shift+k" = "exec swaymsg input type:pointer events enabled"; + "${mod}+escape" = + "mode passthrough;exec notify-send 'Passthrough on'"; "${mod}+f" = "fullscreen toggle"; "${mod}+Shift+space" = "floating toggle"; "${mod}+space" = "focus mode_toggle"; @@ -204,6 +178,5 @@ in system_binds parenting_binds screenshot_binds - screen_binds ]; } diff --git a/user/sway/sway-modes.nix b/user/sway/sway-modes.nix index cc3efff..7cb82bd 100644 --- a/user/sway/sway-modes.nix +++ b/user/sway/sway-modes.nix @@ -1,11 +1,6 @@ { config, pkgs, ... }: let - inherit (config.my) - key - accent - font - theme - ; + inherit (pkgs.uservars) key accent font theme; inherit (theme) color; inherit (pkgs) lib; @@ -13,8 +8,10 @@ let menu = "wlauncher"; terminal = "alacritty"; - locked = lib.mapAttrs' (k: v: lib.nameValuePair "--locked ${k}" v); - to-code = lib.mapAttrs' (k: v: lib.nameValuePair "--to-code ${k}" v); + locked = + lib.mapAttrs' (k: v: lib.nameValuePair "--locked ${k}" v); + to-code = + lib.mapAttrs' (k: v: lib.nameValuePair "--to-code ${k}" v); quit-mode = lib.mapAttrs (k: v: "${v}; mode default"); playerctl = "exec ${pkgs.playerctl}/bin/playerctl"; @@ -23,32 +20,20 @@ in { wayland.windowManager.sway.config.modes = { audio = - (bind_group - [ - to-code - locked - ] - { - ${key.tabR} = "exec volumesh -i 10"; - ${key.tabL} = "exec volumesh -d 10"; - ${key.right} = "exec mpc next"; - ${key.left} = "exec mpc prev"; - ${key.up} = "exec volumesh --mpd -i 10"; - ${key.down} = "exec volumesh --mpd -d 10"; - } - ) - // (bind_group - [ - locked - quit-mode - ] - { - "space" = "exec mpc toggle"; - "escape" = ""; - "q" = ""; - } - ) - // (bind_group [ quit-mode ] { + (bind_group [ to-code locked ] { + ${key.tabR} = "exec volumesh -i 10"; + ${key.tabL} = "exec volumesh -d 10"; + ${key.right} = "exec mpc next"; + ${key.left} = "exec mpc prev"; + ${key.up} = "exec volumesh --mpd -i 10"; + ${key.down} = "exec volumesh --mpd -d 10"; + }) // + (bind_group [ locked quit-mode ] { + "space" = "exec mpc toggle"; + "escape" = ""; + "q" = ""; + }) // + (bind_group [ quit-mode ] { "m" = "exec volumesh -t"; "s" = "exec ${pkgs.pulse_sink}/bin/pulse_sink"; @@ -62,38 +47,28 @@ in "Ctrl+s" = "exec ${pkgs.musmenu}/bin/musmenu psave"; "Ctrl+o" = "exec ${pkgs.musmenu}/bin/musmenu pload"; "Ctrl+d" = "exec ${pkgs.musmenu}/bin/musmenu pdelete"; - }) - // { + }) // + { "p" = "mode playerctl"; "Ctrl+c" = "exec musmenu pclear"; - }; + } + ; playerctl = - (bind_group - [ - to-code - locked - ] - { - ${key.left} = "${playerctl} previous"; - ${key.right} = "${playerctl} next"; - ${key.up} = "${playerctl} volume 10+"; - ${key.down} = "${playerctl} volume 10-"; - ${key.tabR} = "${playerctl} volume 10+"; - ${key.tabL} = "${playerctl} volume 10-"; - } - ) - // (bind_group - [ - to-code - quit-mode - ] - { - "space" = "${playerctl} play-pause"; - "escape" = ""; - "q" = ""; - } - ); + (bind_group [ to-code locked ] { + ${key.left} = "${playerctl} previous"; + ${key.right} = "${playerctl} next"; + ${key.up} = "${playerctl} volume 10+"; + ${key.down} = "${playerctl} volume 10-"; + ${key.tabR} = "${playerctl} volume 10+"; + ${key.tabL} = "${playerctl} volume 10-"; + }) // + (bind_group [ to-code quit-mode ] { + "space" = "${playerctl} play-pause"; + "escape" = ""; + "q" = ""; + }) + ; passthrough = { "${mod}+escape" = "mode default;exec notify-send 'Passthrough off'"; diff --git a/user/sway/swayidle.nix b/user/sway/swayidle.nix index b6541f3..d21f40c 100644 --- a/user/sway/swayidle.nix +++ b/user/sway/swayidle.nix @@ -1,19 +1,12 @@ -{ - config, - pkgs, - lib, - ... -}: +{ config, pkgs, lib, ... }: let - asScript = filename: text: toString (pkgs.writeShellScript filename text); + inherit (pkgs.uservars) key accent font theme; + inherit (theme) color; - cfg = config.my.swayidle; + asScript = filename: text: toString (pkgs.writeShellScript filename text); in { - options.my.swayidle.enable = lib.mkEnableOption { }; - - config.services.swayidle = { - enable = cfg.enable; + services.swayidle = { timeouts = [ { timeout = 360; @@ -38,8 +31,6 @@ in event = "after-resume"; command = asScript "after-resume" '' ${pkgs.sway}/bin/swaymsg "output * dpms on" - ${pkgs.systemd}/bin/systemctl --user restart \ - kdeconnect.service kdeconnect-indicator.service ''; } ]; diff --git a/user/sway/swaylock.nix b/user/sway/swaylock.nix index ceb2e6b..dfd99bc 100644 --- a/user/sway/swaylock.nix +++ b/user/sway/swaylock.nix @@ -1,15 +1,11 @@ -{ config, lib, ... }: +{ config, pkgs, lib, ... }: let - inherit (config.my) accent font theme; + inherit (pkgs.uservars) key accent font theme; inherit (theme) color; - - cfg = config.my.swaylock; in { - options.my.swaylock.enable = lib.mkEnableOption { }; - - config.programs.swaylock.settings = lib.mkIf cfg.enable { - image = theme.backgroundPath; + programs.swaylock.settings = { + image = theme.background; font = font.interface; font-size = font.size.medium; indicator-thickness = 20; diff --git a/user/sway/theme.nix b/user/sway/theme.nix index 600f596..74b6157 100644 --- a/user/sway/theme.nix +++ b/user/sway/theme.nix @@ -1,62 +1,44 @@ -{ - config, - pkgs, - lib, - inputs, - ... -}: +{ config, pkgs, lib, inputs, ... }: let - inherit (config.my) theme font desktop; - inherit (theme) - color - gtk_theme - icon_theme - cursor_theme - ; + inherit (pkgs.uservars) theme font desktop; + inherit (theme) color gtk_theme icon_theme cursor_theme; in -lib.mkIf (desktop == "sway") { +lib.mkIf (desktop == "sway") +{ home.pointerCursor = { name = cursor_theme; size = 24; package = pkgs.bibata-cursors; gtk.enable = true; }; - gtk = - { - enable = true; - font = { - name = font.interface; - size = font.size.small; - }; - theme = { - name = gtk_theme; - package = pkgs.orchis_theme_compact; - }; - iconTheme = { - name = icon_theme; - package = pkgs.papirus_red; - }; - } - // ( - let - shared.extraConfig = { - gtk-decoration-layout = "menu:"; - }; - in - { - gtk4 = shared; - gtk3 = shared; - } - ); - - xdg.configFile."gtk-3.0/settings.ini".force = true; - xdg.configFile."gtk-4.0/settings.ini".force = true; - - qt = { + gtk = { enable = true; - platformTheme.name = "gtk3"; - style.name = "kvantum"; - }; + font = { + name = font.interface; + size = font.size.small; + }; + theme = { + name = gtk_theme; + package = pkgs.orchis_theme_compact; + }; + iconTheme = { + name = icon_theme; + package = pkgs.papirus_red; + }; + } // ( + let + shared.extraConfig = { + gtk-decoration-layout = "menu:"; + }; + in + { gtk4 = shared; gtk3 = shared; } + ); + # qt = { + # enable = true; + # platformTheme = "gtk"; + # # style.package = pkgs.libsForQt5.qtstyleplugins; + # # style.name = "gtk2"; + # }; dconf.settings = { "org/gnome/desktop/interface" = { @@ -70,6 +52,21 @@ lib.mkIf (desktop == "sway") { }; }; + # fonts.fontconfig.enable = true; + xdg.configFile = { + "qt5ct/qt5ct.conf".text = '' + [Appearance] + # color_scheme_path=/nix/store/f07mk0vrm47jxw3y5v99hxncy0w4vcyq-qt5ct-1.5/share/qt5ct/colors/darker.conf + custom_palette=false + icon_theme=${icon_theme} + standard_dialogs=default + style=kvantum-dark + + # [Fonts] + # fixed=@Variant(\0\0\0@\0\0\0\x1c\0H\0\x61\0\x63\0k\0 \0N\0\x65\0r\0\x64\0 \0\x46\0o\0n\0t@(\0\0\0\0\0\0\xff\xff\xff\xff\x5\x1\0\x32\x10) + # general=@Variant(\0\0\0@\0\0\0\x1e\0L\0i\0\x62\0\x65\0r\0\x61\0t\0i\0o\0n\0 \0S\0\x61\0n\0s@(\0\0\0\0\0\0\xff\xff\xff\xff\x5\x1\0\x32\x10) + ''; + }; services.xsettingsd = { enable = true; settings = { @@ -82,7 +79,11 @@ lib.mkIf (desktop == "sway") { }; }; + home.sessionVariables = { QT_QPA_PLATFORMTHEME = "gtk3"; }; home.packages = with pkgs; [ + libsForQt5.qt5ct + libsForQt5.qtstyleplugin-kvantum + pkgs.bibata-cursors pkgs.orchis_theme_compact pkgs.papirus_red @@ -92,6 +93,7 @@ lib.mkIf (desktop == "sway") { hack-font font-awesome_5 fira-code + nerdfonts_fira_hack material-wifi-icons ]; } diff --git a/user/syncthing.nix b/user/syncthing.nix index 76e3584..ff2d4db 100644 --- a/user/syncthing.nix +++ b/user/syncthing.nix @@ -1,10 +1,8 @@ -{ ... }: -{ +{ config, pkgs, lib, inputs, ... }: +let inherit (pkgs.uservars) key theme color accent font; +in { services.syncthing = { enable = true; - tray = { - enable = true; - command = "syncthingtray --wait"; - }; + # tray.enable = true; }; } diff --git a/user/thunar.nix b/user/thunar.nix index 26b90e9..3921eb5 100644 --- a/user/thunar.nix +++ b/user/thunar.nix @@ -1,21 +1,11 @@ -{ pkgs, ... }: -{ +{ pkgs, ... }: { home.packages = with pkgs; [ _thunar-terminal (xfce.thunar.override { - thunarPlugins = with pkgs.xfce; [ - thunar-volman - thunar-archive-plugin - ]; + thunarPlugins = with pkgs.xfce; [ thunar-volman thunar-archive-plugin ]; }) ]; - wayland.windowManager.sway = { - extraConfig = '' - exec_always systemctl --user import-environment PATH - ''; - }; - xdg.configFile = { "Thunar/".source = ./thunar; }; diff --git a/user/variables.nix b/user/variables.nix index 65bc69a..1357a63 100644 --- a/user/variables.nix +++ b/user/variables.nix @@ -27,8 +27,7 @@ let icon_theme = "Papirus-Dark"; cursor_theme = "Bibata-Modern-Classic"; - background = ./backgrounds/nixos-dark-pattern.png; - backgroundPath = "~/.local/share/backgrounds/nixos-dark-pattern.png"; + background = "~/.local/share/backgrounds/nixos-dark-pattern.png"; opacity = 95; opacityHex = "ee"; color = { @@ -59,8 +58,7 @@ let icon_theme = "Papirus-Light"; cursor_theme = "Bibata-Modern-Classic"; - background = ./backgrounds/nixos-light-pattern.png; - backgroundPath = "~/.local/share/backgrounds/nixos-light-pattern.png"; + background = "~/.local/share/backgrounds/nixos-light-pattern.png"; opacity = 95; opacityHex = "ee"; color = { @@ -110,12 +108,29 @@ rec { mail = { personal = { from = "Leonardo Eugênio"; - user = "lelgenio@lelgenio.com"; + user = "lelgenio@disroot.org"; + imap = "disroot.org"; + smtp = "disroot.org"; + pass = "disroot.org"; + }; + work = { + from = "Leonardo Eugênio"; + user = "leonardo@wopus.com.br"; + imap = "imap.wopus.com.br"; + smtp = "smtp.wopus.com.br"; + pass = "Work/wopus_email"; }; }; + nextcloud = { + name = "disroot"; + user = "lelgenio"; + host = "cloud.disroot.org"; + pass = "disroot.org"; + }; - dmenu = "bmenu"; - desktop = "sway"; - browser = "firefox-devedition"; + dmenu = "rofi"; + desktop = "hyprland"; + browser = "firefox"; editor = "kakoune"; + email-client = "thunderbird"; } diff --git a/user/vdir.nix b/user/vdir.nix new file mode 100644 index 0000000..61170df --- /dev/null +++ b/user/vdir.nix @@ -0,0 +1,85 @@ +{ pkgs, lib, ... }: +let + inherit (pkgs.uservars) nextcloud; + pass_cmd = (pkgs.writeShellScript "get_pass" '' + pass "${nextcloud.pass}" | head -n1 + ''); +in +{ + systemd.user.services.vdirsyncer = { + Unit.Description = "vdirsyncer calendar and contacts synchronization"; + Service = { + Type = "oneshot"; + ExecStart = toString (pkgs.writeShellScript "run-vdirsyncer" '' + ${pkgs.coreutils}/bin/yes | ${pkgs.vdirsyncer}/bin/vdirsyncer discover + ${pkgs.coreutils}/bin/yes | ${pkgs.vdirsyncer}/bin/vdirsyncer sync + ''); + }; + }; + systemd.user.timers.vdirsyncer = { + Unit.Description = "vdirsyncer calendar and contacts synchronization"; + Timer = { + OnCalendar = "*:0/30"; + Unit = "vdirsyncer.service"; + }; + Install.WantedBy = [ "timers.target" ]; + }; + + xdg.configFile = { + "vdirsyncer/config".text = '' + [general] + status_path = "~/.vdirsyncer/status/" + + [pair contacts] + a = "contacts_local" + b = "contacts_remote" + + collections = ["from a", "from b"] + + metadata = ["displayname"] + + [storage contacts_local] + type = "filesystem" + path = "~/.local/share/contacts/" + fileext = ".vcf" + + [storage contacts_remote] + type = "carddav" + url = "https://${ nextcloud.host }/remote.php/dav/addressbooks/users/${ nextcloud.user }/" + username = "${ nextcloud.user }" + password.fetch = [ "command", "${ pass_cmd }" ] + + [pair calendar] + a = "calendar_local" + b = "calendar_remote" + collections = ["from a", "from b"] + metadata = ["displayname", "color"] + conflict_resolution = "b wins" + + [storage calendar_local] + type = "filesystem" + path = "~/.local/share/calendars/" + fileext = ".ics" + + [storage calendar_remote] + type = "caldav" + url = "https://${ nextcloud.host }/remote.php/dav/calendars/${ nextcloud.user }/" + username = "${ nextcloud.user }" + password.fetch = [ "command", "${ pass_cmd }" ] + ''; + "todoman/config.py".text = '' + path = "~/.local/share/calendars/*" + date_format = "%Y-%m-%d" + time_format = "%H:%M" + default_list = "Personal" + default_due = 48 + ''; + }; + + + home.packages = with pkgs; [ + vdirsyncer + todoman + ]; + +} diff --git a/user/vscode/default.nix b/user/vscode/default.nix index e9a97cb..48851a0 100644 --- a/user/vscode/default.nix +++ b/user/vscode/default.nix @@ -1,10 +1,9 @@ -{ pkgs, config, ... }: -{ +{ pkgs, config, ... }: { programs.vscode = { enable = true; package = pkgs.vscodium; - profiles.default.extensions = with pkgs.vscode-extensions; [ + extensions = with pkgs.vscode-extensions; [ jnoortheen.nix-ide github.github-vscode-theme rust-lang.rust-analyzer @@ -12,11 +11,8 @@ }; home.file = { - "${config.home.homeDirectory}/.config/VSCodium/User/keybindings.json".source = - config.lib.file.mkOutOfStoreSymlink "${config.home.homeDirectory}/projects/nixos-config/user/vscode/keybindings.json"; - "${config.home.homeDirectory}/.config/VSCodium/User/settings.json".source = - config.lib.file.mkOutOfStoreSymlink "${config.home.homeDirectory}/projects/nixos-config/user/vscode/settings.json"; - "${config.home.homeDirectory}/.config/VSCodium/product.json".source = - config.lib.file.mkOutOfStoreSymlink "${config.home.homeDirectory}/projects/nixos-config/user/vscode/product.json"; + "${config.home.homeDirectory}/.config/VSCodium/User/keybindings.json".source = config.lib.file.mkOutOfStoreSymlink "${config.home.homeDirectory}/projects/nixos-config/user/vscode/keybindings.json"; + "${config.home.homeDirectory}/.config/VSCodium/User/settings.json".source = config.lib.file.mkOutOfStoreSymlink "${config.home.homeDirectory}/projects/nixos-config/user/vscode/settings.json"; + "${config.home.homeDirectory}/.config/VSCodium/product.json".source = config.lib.file.mkOutOfStoreSymlink "${config.home.homeDirectory}/projects/nixos-config/user/vscode/product.json"; }; } diff --git a/user/vscode/settings.json b/user/vscode/settings.json index 2ff41eb..9ac0729 100644 --- a/user/vscode/settings.json +++ b/user/vscode/settings.json @@ -9,18 +9,4 @@ "git.confirmSync": false, "editor.suggest.snippetsPreventQuickSuggestions": false, "update.mode": "none", - "intelephense.files.exclude": [ - "**/.git/**", - "**/.svn/**", - "**/.hg/**", - "**/CVS/**", - "**/.DS_Store/**", - "**/node_modules/**", - "**/bower_components/**", - "**/vendor/**/{Tests,tests}/**", - "**/.history/**", - "**/vendor/**/vendor/**", - "**/.direnv/**" - ], - "intelephense.format.braces": "k&r", -} +} \ No newline at end of file diff --git a/user/waybar/default.nix b/user/waybar/default.nix index 5af72bc..3de9b36 100644 --- a/user/waybar/default.nix +++ b/user/waybar/default.nix @@ -1,240 +1,211 @@ -{ - config, - osConfig, - pkgs, - lib, - font, - ... -}: +{ config, osConfig, pkgs, lib, font, ... }: let - inherit (config.my) - key - theme - accent - font - ; + inherit (pkgs.uservars) key theme accent font desktop; inherit (theme) color; - - cfg = config.my.waybar; in { - options.my.waybar.enable = lib.mkEnableOption { }; - - config = lib.mkIf cfg.enable { + config = { programs.waybar = { enable = true; systemd.enable = true; - systemd.target = "sway-session.target"; - settings = [ - { - layer = "top"; - modules-left = [ - "sway/workspaces" - "sway/mode" - "sway/window" - ]; - modules-center = [ "clock" ]; - modules-right = lib.flatten [ - "sway/language" - "mpd" - "custom/playerctl" - "tray" - "custom/controller-battery" - "custom/caffeine" - "pulseaudio" - (lib.optional (osConfig.services.vpn.enable or false) "custom/vpn") - "network" - "battery" - ]; - battery = { - tooltip = true; - states = { - full = 100; - good = 95; - warning = 25; - }; - format = "{icon} "; - format-charging = ""; - format-plugged = ""; - format-full = ""; - format-warning = "{icon} {time}"; - format-icons = [ - "" - "" - "" - "" - "" - "" - ]; + systemd.target = "${desktop}-session.target"; + settings = [{ + layer = "top"; + modules-left = [ + "sway/workspaces" + "sway/mode" + "sway/window" + "hyprland/workspaces" + "hyprland/mode" + "hyprland/window" + ]; + modules-center = [ "clock" ]; + modules-right = lib.flatten [ + "sway/language" + "hyprland/language" + "mpd" + "custom/playerctl" + # "tray" + "custom/caffeine" + "pulseaudio" + (lib.optional (osConfig.services.vpn.enable or false) "custom/vpn") + "network" + "battery" + ]; + battery = { + tooltip = true; + states = { + full = 100; + good = 95; + warning = 25; }; - network = { - interval = 5; - tooltip = false; - on-click = "terminal -e iwd"; - format-wifi = "{icon}"; - format-icons = [ - "" - "" - "" - "" - "" - ]; - format-ethernet = "󰈀"; - format-linked = "󰈀"; - format-disconnected = ""; + format = "{icon} "; + format-charging = ""; + format-plugged = ""; + format-full = ""; + format-warning = "{icon} {time}"; + format-icons = [ "" "" "" "" "" "" ]; + }; + network = { + interval = 5; + tooltip = false; + on-click = "terminal -e iwd"; + format-wifi = "{icon}"; + format-icons = [ "" "" "" "" "" ]; + format-ethernet = "󰈀"; + format-linked = "󰈀"; + format-disconnected = ""; + }; + "sway/workspaces" = { + enable-bar-scroll = true; + format = "{icon}"; + format-icons = { + "1" = ""; + "2" = ""; + "3" = "󰅩"; + "4" = ""; + "5" = ""; + "6" = ""; + "7" = "󰇮"; + "8" = ""; + "9" = ""; + "10" = ""; + urgent = ""; + # focused = ""; + default = ""; }; - "sway/workspaces" = { - enable-bar-scroll = true; - format = "{icon}"; - format-icons = { - "1" = ""; - "2" = ""; - "3" = "󰅩"; - "4" = ""; - "5" = ""; - "6" = ""; - "7" = "󰇮"; - "8" = ""; - "9" = ""; - "10" = ""; - urgent = ""; - # focused = ""; - default = ""; + }; + "sway/window" = { max-length = 40; }; + "sway/language" = { format = "{short} {variant}"; }; + "hyprland/workspaces" = { + enable-bar-scroll = true; + on-scroll-up = "hyprctl dispatch workspace e-1"; + on-scroll-down = "hyprctl dispatch workspace e+1"; + format = "{icon}"; + format-icons = { + "1" = ""; + "2" = ""; + "3" = "󰅩"; + "4" = ""; + "5" = ""; + "6" = ""; + "7" = "󰇮"; + "8" = ""; + "9" = ""; + "10" = ""; + urgent = ""; + # focused = ""; + default = ""; + }; + }; + "hyprland/window" = { max-length = 40; }; + "hyprland/language" = { format = "{short} {variant}"; }; + "tray" = { + "spacing" = 7; + "icon-size" = 19; + }; + clock = { + interval = 60; + format = "{:%H:%M %a %d/%m}"; + tooltip-format = "{calendar}"; + calendar = { + mode = "year"; + mode-mon-col = 3; + weeks-pos = "right"; + on-scroll = 1; + on-click-right = "mode"; + format = { + months = "{}"; + days = "{}"; + weeks = "W{}"; + weekdays = "{}"; + today = "{}"; }; }; - "sway/window" = { - max-length = 40; + actions = { + on-click-right = "mode"; + on-click-forward = "tz_up"; + on-click-backward = "tz_down"; + on-scroll-up = "shift_up"; + on-scroll-down = "shift_down"; }; - "tray" = { - "spacing" = 7; - "icon-size" = 19; - }; - clock = { - interval = 60; - format = "{:L%H:%M %a %d/%m}"; - tooltip-format = "{calendar}"; - calendar = { - mode = "year"; - mode-mon-col = 3; - weeks-pos = "right"; - on-scroll = 1; - on-click-right = "mode"; - format = { - months = "{}"; - days = "{}"; - weeks = "W{}"; - weekdays = "{}"; - today = "{}"; - }; + }; + mpd = + let + mpc = "${pkgs.mpc-cli}/bin/mpc"; + in + { + format = "{stateIcon} {title} - {artist}"; + format-paused = "{stateIcon}"; + format-stopped = ""; + state-icons = { + stopped = ""; + paused = ""; + playing = ""; }; - actions = { - on-click-right = "mode"; - on-click-forward = "tz_up"; - on-click-backward = "tz_down"; - on-scroll-up = "shift_up"; - on-scroll-down = "shift_down"; - }; - }; - mpd = - let - mpc = "${pkgs.mpc-cli}/bin/mpc"; - in - { - format = "{stateIcon} {title} - {artist}"; - format-paused = "{stateIcon}"; - format-stopped = ""; - state-icons = { - paused = ""; - playing = ""; - }; - tooltip = false; - on-click = "${mpc} toggle"; - on-scroll-up = "${mpc} vol +10"; - on-scroll-down = "${mpc} vol -10"; - }; - "custom/playerctl" = { - format = "{} "; - exec = "${pkgs.playerctl-status}/bin/playerctl-status"; - on-click = "${pkgs.playerctl}/bin/playerctl --ignore-player=mpd play-pause"; - interval = 1; tooltip = false; + on-click = "${mpc} toggle"; + on-scroll-up = "${mpc} vol +10"; + on-scroll-down = "${mpc} vol -10"; }; - "sway/language" = { - format = "{short} {variant}"; + "custom/playerctl" = { + format = "{} "; + exec = "${pkgs.playerctl-status}/bin/playerctl-status"; + on-click = "${pkgs.playerctl}/bin/playerctl --ignore-player=mpd play-pause"; + interval = 1; + tooltip = false; + }; + "custom/caffeine" = { + format = "{}"; + exec = "systemctl --user status swayidle > /dev/null && echo 󰒲 || echo 󰒳"; + on-click = "${pkgs._sway_idle_toggle}/bin/_sway_idle_toggle"; + interval = 1; + tooltip = false; + }; + "custom/vpn" = lib.mkIf (osConfig.services.vpn.enable or false) { + format = "{}"; + exec = '' + ${pkgs.mullvad}/bin/mullvad status | ${pkgs.gnugrep}/bin/grep "^Connected" > /dev/null \ + && echo "" \ + || echo "" + ''; + on-click = "mullvad connect"; + on-click-right = "mullvad disconnect"; + interval = 1; + tooltip = false; + }; + pulseaudio = { + interval = 5; + tooltip = false; + scroll-step = 10; + format = "{icon}"; + format-bluetooth = ""; + format-bluetooth-muted = "󰝟"; + format-muted = "󰝟"; + format-icons = { + "rtp-sink" = + [ "󰕿" "󰖀" "󰕾" ]; + "alsa_output.usb-C-Media_Electronics_Inc._USB_Audio_Device-00.analog-stereo" = + [ " 󰕿" " 󰖀" " 󰕾" ]; + "alsa_output.pci-0000_09_00.4.analog-stereo" = + [ " 󰕿" " 󰖀" " 󰕾" ]; + headphone = [ " 󰕿" " 󰖀" " 󰕾" ]; + handsfree = ""; + headset = ""; + phone = ""; + portable = ""; + car = ""; + default = [ "󰕿" "󰖀" "󰕾" ]; }; - "custom/controller-battery" = { - format = "{}"; - exec = lib.getExe pkgs.controller-battery; - interval = 1; - tooltip = false; - }; - "custom/caffeine" = { - format = "{}"; - exec = "systemctl --user status swayidle > /dev/null && echo 󰒲 || echo 󰒳"; - on-click = "${pkgs._sway_idle_toggle}/bin/_sway_idle_toggle"; - interval = 1; - tooltip = false; - }; - "custom/vpn" = lib.mkIf (osConfig.services.vpn.enable or false) { - format = "{}"; - exec = '' - ${pkgs.mullvad}/bin/mullvad status | ${pkgs.gnugrep}/bin/grep "^Connected" > /dev/null \ - && echo "" \ - || echo "" - ''; - on-click = "mullvad connect"; - on-click-right = "mullvad disconnect"; - interval = 1; - tooltip = false; - }; - pulseaudio = { - interval = 5; - tooltip = false; - scroll-step = 10; - format = "{icon}"; - format-bluetooth = ""; - format-bluetooth-muted = "󰝟"; - format-muted = "󰝟"; - format-icons = { - "rtp-sink" = [ - "󰕿" - "󰖀" - "󰕾" - ]; - "alsa_output.usb-C-Media_Electronics_Inc._USB_Audio_Device-00.analog-stereo" = [ - " 󰕿" - " 󰖀" - " 󰕾" - ]; - "alsa_output.pci-0000_09_00.4.analog-stereo" = [ - " 󰕿" - " 󰖀" - " 󰕾" - ]; - headphone = [ - " 󰕿" - " 󰖀" - " 󰕾" - ]; - handsfree = ""; - headset = ""; - phone = ""; - portable = ""; - car = ""; - default = [ - "󰕿" - "󰖀" - "󰕾" - ]; - }; - on-click = "pavucontrol"; - on-click-right = "${pkgs.pulse_sink}/bin/pulse_sink"; - on-scroll-up = "${pkgs.volumesh}/bin/volumesh -i 10"; - on-scroll-down = "${pkgs.volumesh}/bin/volumesh -d 10"; - }; - } - ]; - style = pkgs.replaceVars ./style.css { + on-click = "pavucontrol"; + on-click-right = "${pkgs.pulse_sink}/bin/pulse_sink"; + on-scroll-up = "${pkgs.volumesh}/bin/volumesh -i 10"; + on-scroll-down = "${pkgs.volumesh}/bin/volumesh -d 10"; + }; + }]; + style = builtins.readFile (pkgs.substituteAll { + src = ./style.css; + accent_color = accent.color; color_bg = color.bg; @@ -246,7 +217,7 @@ in font_size_big = "${toString font.size.big}px"; font_size_medium = "${toString font.size.medium}px"; - }; + }); }; home.packages = with pkgs; [ waybar ]; }; diff --git a/user/waybar/style.css b/user/waybar/style.css index 36c6ebd..0f82fea 100644 --- a/user/waybar/style.css +++ b/user/waybar/style.css @@ -20,7 +20,8 @@ window#waybar.solo { background-color: transparent; border: 3px solid transparent; } -#workspaces button.focused { +#workspaces button.focused, +#workspaces button.active { color: @color_txt@; border-top: 3px solid @accent_color@; } @@ -37,7 +38,6 @@ window#waybar.solo { #mpd, #custom-mpd, #custom-playerctl, -#custom-controller-battery, #tray, #clock, #network, diff --git a/user/xdg-dirs.nix b/user/xdg-dirs.nix index c4036c2..d95d6de 100644 --- a/user/xdg-dirs.nix +++ b/user/xdg-dirs.nix @@ -1,7 +1,4 @@ -{ - config, - ... -}: +{ config, pkgs, lib, inputs, ... }: let HOME = config.home.homeDirectory; in @@ -21,4 +18,9 @@ in videos = "${HOME}/Vídeos"; }; }; + + home.sessionVariables = { + CARGO_HOME = "${config.xdg.dataHome}/cargo"; + RUSTUP_HOME = "${config.xdg.dataHome}/rustup"; + }; } diff --git a/user/zathura.nix b/user/zathura.nix index ae8e003..d3c9f5e 100644 --- a/user/zathura.nix +++ b/user/zathura.nix @@ -1,68 +1,57 @@ -{ config, lib, ... }: +{ config, pkgs, lib, font, ... }: let - inherit (config.my) - key - accent - font - theme - ; + inherit (pkgs.uservars) key accent font theme; inherit (theme) color; - - cfg = config.my.zathura; in { - options.my.zathura.enable = lib.mkEnableOption { }; + config = { + programs.zathura.enable = true; + programs.zathura.options = { + font = "${font.mono} ${toString font.size.small}"; + guioptions = "s"; - config = lib.mkIf cfg.enable { - programs.zathura = { - enable = true; - options = { - font = "${font.mono} ${toString font.size.small}"; - guioptions = "s"; + selection-clipboard = "clipboard"; - selection-clipboard = "clipboard"; + recolor = true; + # Turn images grayscale, so they don't look weird + recolor-keephue = false; + recolor-lightcolor = "rgba(0,0,0,0)"; + recolor-darkcolor = color.txt; - recolor = true; - # Turn images grayscale, so they don't look weird - recolor-keephue = false; - recolor-lightcolor = "rgba(0,0,0,0)"; - recolor-darkcolor = color.txt; + default-bg = color.bg_dark; - default-bg = color.bg_dark; + inputbar-bg = color.bg_dark; + inputbar-fg = color.txt; - inputbar-bg = color.bg_dark; - inputbar-fg = color.txt; + statusbar-bg = color.bg; + statusbar-fg = color.txt; - statusbar-bg = color.bg; - statusbar-fg = color.txt; + completion-bg = color.bg; + completion-fg = color.txt; - completion-bg = color.bg; - completion-fg = color.txt; + completion-group-bg = color.bg_dark; + completion-group-fg = color.txt; - completion-group-bg = color.bg_dark; - completion-group-fg = color.txt; + completion-highlight-bg = accent.color; + completion-highlight-fg = accent.fg; - completion-highlight-bg = accent.color; - completion-highlight-fg = accent.fg; - - index-active-bg = accent.color; - index-active-fg = accent.fg; - }; - mappings = { - "" = "toggle_statusbar"; - ${key.left} = "scroll left"; - ${key.down} = "scroll down"; - ${key.up} = "scroll up"; - ${key.right} = "scroll right"; - "[index] ${key.left}" = "navigate_index collapse"; - "[index] ${key.down}" = "navigate_index down"; - "[index] ${key.up}" = "navigate_index up"; - "[index] ${key.right}" = "navigate_index expand"; - ${lib.toUpper key.down} = "navigate next"; - ${lib.toUpper key.up} = "navigate previous"; - ${key.next} = "search forward"; - ${lib.toUpper key.next} = "search backward"; - }; + index-active-bg = accent.color; + index-active-fg = accent.fg; + }; + programs.zathura.mappings = { + "" = "toggle_statusbar"; + ${key.left} = "scroll left"; + ${key.down} = "scroll down"; + ${key.up} = "scroll up"; + ${key.right} = "scroll right"; + "[index] ${key.left}" = "navigate_index collapse"; + "[index] ${key.down}" = "navigate_index down"; + "[index] ${key.up}" = "navigate_index up"; + "[index] ${key.right}" = "navigate_index expand"; + ${lib.toUpper key.down} = "navigate next"; + ${lib.toUpper key.up} = "navigate previous"; + ${key.next} = "search forward"; + ${lib.toUpper key.next} = "search backward"; }; }; }