Contract 0x79B6C6F8634ea477ED725eC23b7b6Fcb41F00E58

 
Txn Hash Method
Block
From
To
Value
0x0c85daba0cde684b2afaef23b9fe9129c4e38d1600e58be6ebc1706f1b149d2cToggle Contract ...126509992021-06-17 8:53:095 days 10 hrs agoZapper.Fi: Deployer 2 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.00037150414
0xebbbcc8122a44cfd7f5331a97918360ba4b1c6e8590e97df8ef7dd4727998028Zap Out With Per...125412982021-05-31 9:15:0722 days 10 hrs ago0x5679d808f2734f8b09f26f4cb0a7fb0439dbebfb IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.0063026415
0x9f3cefebc48f3f26232bd50b52d6b2187e6359aadc061e00cfda31bb8ae4628aZap Out2Pair Tok...123414862021-04-30 11:13:3453 days 8 hrs ago0xa2ec894516358dabb3b5b30508485eac340424e6 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.00528573535
0x5f257ca6af5041ff00ed55f8e6c8dcffbd3728ddf49f828cc04ac2c00d04f49aZap Out2Pair Tok...123404822021-04-30 7:20:5553 days 12 hrs ago0x13990a35817ba2ec788458add79b9658f377369f IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.00573879838
0x366241a2c9e0e2c4ff95d83c36c9e1587bb8fad3f0841ac3b55b7b6c5413bda6Zap Out123396712021-04-30 4:23:1353 days 15 hrs ago0x62243aa0bf16741ed5cdd128dc5c2311dde3efe2 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.00773348137
0xb25fa235a57f1dc2411c6913d1d73f4449d2a36edb3f38d304bc417ff801bddfZap Out122891072021-04-22 9:10:4161 days 10 hrs ago0x60bf3e3763e199519a702c5cc61d9867f024df95 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.026634762121
0x3997b0550b8b250d8cd25ce62b846de38641cbb521ed813603bc4712b20da952Zap Out122283092021-04-12 23:42:4570 days 20 hrs ago0x60bf3e3763e199519a702c5cc61d9867f024df95 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.02396990283
0xaa23817f590c24b0227f2211857106bbd1b755df7ddfd0f1df3851fbf399d617Zap Out With Per...122191512021-04-11 14:25:5372 days 5 hrs ago0xf98b8f2f50113feb1eae094298059845571971d6 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.055791088142117.785714286
0x31b19c3b88083c507c06fb2b7d0d4cb448c6a8f19fe070c7a83085945c9d5729Zap Out121765482021-04-05 0:59:4978 days 18 hrs ago0xd9f19b0752a1ad141cd93001fa5ca06ba12016e4 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.02625608799
0x410f2da3706d96d4d11f3fe3edf8c00dda003434ec53b43f10f2a26170c66b80Zap Out With Per...120696792021-03-19 14:12:3795 days 5 hrs ago0x201f28f737236e00505f3b6e8e7849e7332eeb42 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.036366064112
0x74eb3b62c4c509691c5cbafde7f9156c10a1af88d1c0df886a78b94fca71de6eZap Out2Pair Tok...119994812021-03-08 18:31:06106 days 1 hr ago0xf36a255d105dd1ed51593751ae66f99fc1a6c3c6 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.02980937494
0x516248b82b79416e14c7054626084c3afe9797e103355090a02761ed4b254db9In Case Tokenget...119994102021-03-08 18:17:24106 days 1 hr agoZapper.Fi: Deployer 2 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.00642967130
0x1bf2a7a8d0885dff0a161000aec884d66ac967938a73752a0eed25219240cd0dZap Out With Per...119992342021-03-08 17:38:39106 days 2 hrs ago0xe9a18d531e8e48bb27702a679eb0ca016f0fef9b IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.0391085125
0x17b23706ddd568d2bea49f4854ff5dfe479c29d30a4f6ac12ac1e791d297e4a7Zap Out2Pair Tok...119991452021-03-08 17:19:26106 days 2 hrs ago0xbd178fe085a12505473a96a57d6f2ce0bbf3a490 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.004597548102
0x646b5c6b2085d9d6877f10ce66abd6ac90766d1369935fcf57f8060f4f1a9cbaZap Out2Pair Tok...119991452021-03-08 17:19:26106 days 2 hrs ago0xbd178fe085a12505473a96a57d6f2ce0bbf3a490 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.018332154102
0x2e7a5f03c0f0493a49198e98e170cf29da7c360eed843b20c81e27371c6aeeb0Zap Out2Pair Tok...119991172021-03-08 17:13:51106 days 2 hrs ago0x00538a078314200fe2b74c096f7970aee2f1a372 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.045500577137
0x13c3e6fec347148bbc65a2eb0c1a9e047763cceb52688c53f3c67822a4885277Zap Out119990432021-03-08 17:00:47106 days 2 hrs ago0x0fba3e495b76d9b352028142de9113c5a3454de1 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.038810618154
0x6c83c5a303abdf7adf3f5302b17a4f99964c75a9239a7d1f91e8e651b645e682Zap Out119990062021-03-08 16:51:02106 days 2 hrs ago0xbe4736749ef1e1c1e686bb161fb17cdd4aea563e IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.064751406111
0x59ad69294255c90191d5cc14ee36138b3339751589daa8e7d9d41c10c1fabf0fZap Out With Per...119990052021-03-08 16:51:00106 days 2 hrs ago0xc0eb311c2f846bd359ed8eaa9a766d5e4736846a IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.034821366457111.000001459
0xe09a5f3649d3f54d030628c0f1fe6e003a65ba6e56d833537732f3f2d3fdebb4Zap Out119988832021-03-08 16:23:19106 days 3 hrs ago0x3fcac584d0b71a9564602c1f0288ec1c0d9846cf IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.045935656158
0x817732ab73745b6bff127c1484cef3310a4d47c6808395007395625d084b8b8eZap Out2Pair Tok...119987822021-03-08 15:59:52106 days 3 hrs agoENS Name dfff.eth IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.025289972116
0x1d518fa7abe05b51e95344849742920be9e6faa90de3068c9d237a420c6e1e42Zap Out119987772021-03-08 15:59:09106 days 3 hrs ago0x827ea2c64d3f5093f632ab6daa94ee8d7eee0686 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.0404696160
0xde6e58cd800d5a42eccbc3b2c060ba56170f7baa965814d9d381b1008161810eZap Out2Pair Tok...119987222021-03-08 15:46:33106 days 4 hrs ago0xbfdaa10e3045823fa6a60e98f530ac02fdeec501 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.0265013181118.7
0x559d81aeecbf0608a01f8c3f0c5dc457fbf3f4465f1f57472e7c4bdb95169a67Zap Out119984552021-03-08 14:46:44106 days 5 hrs ago0x15396ccbcf993e56eb56a9bc3d2115dc2ccfaa1c IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.046776559726175.900001604
0xd425109ea78c01acb55df126721145bb53b315abaf2bac53a13a803731e990daZap Out119984442021-03-08 14:43:53106 days 5 hrs ago0xc5907a5fbf77495161df1c88982175be1f212968 IN  0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580 Ether0.04402341155
[ Download CSV Export 
Latest 25 internal transaction
Parent Txn Hash Block From To Value
0xebbbcc8122a44cfd7f5331a97918360ba4b1c6e8590e97df8ef7dd4727998028125412982021-05-31 9:15:0722 days 10 hrs ago Wrapped Ether 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.174832407137287193 Ether
0xebbbcc8122a44cfd7f5331a97918360ba4b1c6e8590e97df8ef7dd4727998028125412982021-05-31 9:15:0722 days 10 hrs ago Uniswap V2: Router 2 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.174306837187408474 Ether
0x366241a2c9e0e2c4ff95d83c36c9e1587bb8fad3f0841ac3b55b7b6c5413bda6123396712021-04-30 4:23:1353 days 15 hrs ago 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580x62243aa0bf16741ed5cdd128dc5c2311dde3efe20.183903774284214617 Ether
0x366241a2c9e0e2c4ff95d83c36c9e1587bb8fad3f0841ac3b55b7b6c5413bda6123396712021-04-30 4:23:1353 days 15 hrs ago Wrapped Ether 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.092104736404896547 Ether
0x366241a2c9e0e2c4ff95d83c36c9e1587bb8fad3f0841ac3b55b7b6c5413bda6123396712021-04-30 4:23:1353 days 15 hrs ago Uniswap V2: Router 2 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.09179903787931807 Ether
0xb25fa235a57f1dc2411c6913d1d73f4449d2a36edb3f38d304bc417ff801bddf122891072021-04-22 9:10:4161 days 10 hrs ago 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580x60bf3e3763e199519a702c5cc61d9867f024df951.195061635545883047 Ether
0xb25fa235a57f1dc2411c6913d1d73f4449d2a36edb3f38d304bc417ff801bddf122891072021-04-22 9:10:4161 days 10 hrs ago Wrapped Ether 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.598509745548439941 Ether
0xb25fa235a57f1dc2411c6913d1d73f4449d2a36edb3f38d304bc417ff801bddf122891072021-04-22 9:10:4161 days 10 hrs ago Uniswap V2: Router 2 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.596551889997443106 Ether
0x3997b0550b8b250d8cd25ce62b846de38641cbb521ed813603bc4712b20da952122283092021-04-12 23:42:4570 days 20 hrs ago 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580x60bf3e3763e199519a702c5cc61d9867f024df951.061513924897452351 Ether
0x3997b0550b8b250d8cd25ce62b846de38641cbb521ed813603bc4712b20da952122283092021-04-12 23:42:4570 days 20 hrs ago Wrapped Ether 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.531684344285248099 Ether
0x3997b0550b8b250d8cd25ce62b846de38641cbb521ed813603bc4712b20da952122283092021-04-12 23:42:4570 days 20 hrs ago Uniswap V2: Router 2 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.529829580612204252 Ether
0xaa23817f590c24b0227f2211857106bbd1b755df7ddfd0f1df3851fbf399d617122191512021-04-11 14:25:5372 days 5 hrs ago Wrapped Ether 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.892899456062421167 Ether
0xaa23817f590c24b0227f2211857106bbd1b755df7ddfd0f1df3851fbf399d617122191512021-04-11 14:25:5372 days 5 hrs ago Uniswap V2: Router 2 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.889225741652047688 Ether
0x31b19c3b88083c507c06fb2b7d0d4cb448c6a8f19fe070c7a83085945c9d5729121765482021-04-05 0:59:4978 days 18 hrs ago 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580xd9f19b0752a1ad141cd93001fa5ca06ba12016e46.026779840345322458 Ether
0x31b19c3b88083c507c06fb2b7d0d4cb448c6a8f19fe070c7a83085945c9d5729121765482021-04-05 0:59:4978 days 18 hrs ago Wrapped Ether 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e583.026236901249421348 Ether
0x31b19c3b88083c507c06fb2b7d0d4cb448c6a8f19fe070c7a83085945c9d5729121765482021-04-05 0:59:4978 days 18 hrs ago Uniswap V2: Router 2 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e583.00054293909590111 Ether
0x410f2da3706d96d4d11f3fe3edf8c00dda003434ec53b43f10f2a26170c66b80120696792021-03-19 14:12:3795 days 5 hrs ago 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580x201f28f737236e00505f3b6e8e7849e7332eeb420.269373319641850362 Ether
0x410f2da3706d96d4d11f3fe3edf8c00dda003434ec53b43f10f2a26170c66b80120696792021-03-19 14:12:3795 days 5 hrs ago Wrapped Ether 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.134902009188011965 Ether
0x410f2da3706d96d4d11f3fe3edf8c00dda003434ec53b43f10f2a26170c66b80120696792021-03-19 14:12:3795 days 5 hrs ago Uniswap V2: Router 2 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.134471310453838397 Ether
0x1bf2a7a8d0885dff0a161000aec884d66ac967938a73752a0eed25219240cd0d119992342021-03-08 17:38:39106 days 2 hrs ago 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580xe9a18d531e8e48bb27702a679eb0ca016f0fef9b24.027568793761225411 Ether
0x1bf2a7a8d0885dff0a161000aec884d66ac967938a73752a0eed25219240cd0d119992342021-03-08 17:38:39106 days 2 hrs ago Uniswap V2: Router 2 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e5811.994522064857092891 Ether
0x1bf2a7a8d0885dff0a161000aec884d66ac967938a73752a0eed25219240cd0d119992342021-03-08 17:38:39106 days 2 hrs ago Wrapped Ether 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e5812.03304672890413252 Ether
0x6c83c5a303abdf7adf3f5302b17a4f99964c75a9239a7d1f91e8e651b645e682119990062021-03-08 16:51:02106 days 2 hrs ago 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580xbe4736749ef1e1c1e686bb161fb17cdd4aea563e1.562349983806687747 Ether
0x6c83c5a303abdf7adf3f5302b17a4f99964c75a9239a7d1f91e8e651b645e682119990062021-03-08 16:51:02106 days 2 hrs ago Wrapped Ether 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.786349389614452982 Ether
0x6c83c5a303abdf7adf3f5302b17a4f99964c75a9239a7d1f91e8e651b645e682119990062021-03-08 16:51:02106 days 2 hrs ago Uniswap V2: Router 2 0x79b6c6f8634ea477ed725ec23b7b6fcb41f00e580.776000594192234765 Ether
[ Download CSV Export 
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
UniswapV2_ZapOut_General_V2_1

Compiler Version
v0.5.17+commit.d19bba13

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, GNU GPLv2 license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2020-10-09
*/

// ███████╗░█████╗░██████╗░██████╗░███████╗██████╗░░░░███████╗██╗
// ╚════██║██╔══██╗██╔══██╗██╔══██╗██╔════╝██╔══██╗░░░██╔════╝██║
// ░░███╔═╝███████║██████╔╝██████╔╝█████╗░░██████╔╝░░░█████╗░░██║
// ██╔══╝░░██╔══██║██╔═══╝░██╔═══╝░██╔══╝░░██╔══██╗░░░██╔══╝░░██║
// ███████╗██║░░██║██║░░░░░██║░░░░░███████╗██║░░██║██╗██║░░░░░██║
// ╚══════╝╚═╝░░╚═╝╚═╝░░░░░╚═╝░░░░░╚══════╝╚═╝░░╚═╝╚═╝╚═╝░░░░░╚═╝
// Copyright (C) 2020 zapper, nodar, suhail, seb, apoorv, sumit

// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 2 of the License, or
// (at your option) any later version.
//
// This program 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 Affero General Public License for more details.
//
// Visit <https://www.gnu.org/licenses/>for a copy of the GNU Affero General Public License

///@author Zapper
///@notice this contract implements one click removal of liquidity from Uniswap V2 pools, receiving ETH, ERC tokens or both.

pragma solidity ^0.5.0;

/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     * - Subtraction cannot overflow.
     *
     * _Available since v2.4.0._
     */
    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;

        return c;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) {
            return 0;
        }

        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");

        return c;
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     * - The divisor cannot be zero.
     *
     * _Available since v2.4.0._
     */
    function div(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        // Solidity only automatically asserts when dividing by 0
        require(b > 0, errorMessage);
        uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return mod(a, b, "SafeMath: modulo by zero");
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts with custom message when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     * - The divisor cannot be zero.
     *
     * _Available since v2.4.0._
     */
    function mod(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}

// File: @openzeppelin/contracts/GSN/Context.sol

pragma solidity ^0.5.0;

/*
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with GSN meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
contract Context {
    // Empty internal constructor, to prevent people from mistakenly deploying
    // an instance of this contract, which should be used via inheritance.
    constructor() internal {}

    // solhint-disable-previous-line no-empty-blocks

    function _msgSender() internal view returns (address payable) {
        return msg.sender;
    }

    function _msgData() internal view returns (bytes memory) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

// File: @openzeppelin/contracts/ownership/Ownable.sol

pragma solidity ^0.5.0;

/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
contract Ownable is Context {
    address private _owner;

    event OwnershipTransferred(
        address indexed previousOwner,
        address indexed newOwner
    );

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() internal {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view returns (address) {
        return _owner;
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(isOwner(), "Ownable: caller is not the owner");
        _;
    }

    /**
     * @dev Returns true if the caller is the current owner.
     */
    function isOwner() public view returns (bool) {
        return _msgSender() == _owner;
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public onlyOwner {
        _transferOwnership(newOwner);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     */
    function _transferOwnership(address newOwner) internal {
        require(
            newOwner != address(0),
            "Ownable: new owner is the zero address"
        );
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}

// File: @openzeppelin/contracts/token/ERC20/IERC20.sol

pragma solidity ^0.5.0;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP. Does not include
 * the optional functions; to access them see {ERC20Detailed}.
 */
interface IERC20 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address recipient, uint256 amount)
        external
        returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender)
        external
        view
        returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `sender` to `recipient` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
}

// File: @openzeppelin/contracts/utils/Address.sol

pragma solidity ^0.5.5;

/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // According to EIP-1052, 0x0 is the value returned for not-yet created accounts
        // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned
        // for accounts without code, i.e. `keccak256('')`
        bytes32 codehash;


            bytes32 accountHash
         = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
        // solhint-disable-next-line no-inline-assembly
        assembly {
            codehash := extcodehash(account)
        }
        return (codehash != accountHash && codehash != 0x0);
    }

    /**
     * @dev Converts an `address` into `address payable`. Note that this is
     * simply a type cast: the actual underlying value is not changed.
     *
     * _Available since v2.4.0._
     */
    function toPayable(address account)
        internal
        pure
        returns (address payable)
    {
        return address(uint160(account));
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     *
     * _Available since v2.4.0._
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(
            address(this).balance >= amount,
            "Address: insufficient balance"
        );

        // solhint-disable-next-line avoid-call-value
        (bool success, ) = recipient.call.value(amount)("");
        require(
            success,
            "Address: unable to send value, recipient may have reverted"
        );
    }
}

// File: @openzeppelin/contracts/utils/ReentrancyGuard.sol

pragma solidity ^0.5.0;

/**
 * @dev Contract module that helps prevent reentrant calls to a function.
 *
 * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier
 * available, which can be applied to functions to make sure there are no nested
 * (reentrant) calls to them.
 *
 * Note that because there is a single `nonReentrant` guard, functions marked as
 * `nonReentrant` may not call one another. This can be worked around by making
 * those functions `private`, and then adding `external` `nonReentrant` entry
 * points to them.
 *
 * TIP: If you would like to learn more about reentrancy and alternative ways
 * to protect against it, check out our blog post
 * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].
 *
 * _Since v2.5.0:_ this module is now much more gas efficient, given net gas
 * metering changes introduced in the Istanbul hardfork.
 */
contract ReentrancyGuard {
    bool private _notEntered;

    constructor() internal {
        // Storing an initial non-zero value makes deployment a bit more
        // expensive, but in exchange the refund on every call to nonReentrant
        // will be lower in amount. Since refunds are capped to a percetange of
        // the total transaction's gas, it is best to keep them low in cases
        // like this one, to increase the likelihood of the full refund coming
        // into effect.
        _notEntered = true;
    }

    /**
     * @dev Prevents a contract from calling itself, directly or indirectly.
     * Calling a `nonReentrant` function from another `nonReentrant`
     * function is not supported. It is possible to prevent this from happening
     * by making the `nonReentrant` function external, and make it call a
     * `private` function that does the actual work.
     */
    modifier nonReentrant() {
        // On the first call to nonReentrant, _notEntered will be true
        require(_notEntered, "ReentrancyGuard: reentrant call");

        // Any calls to nonReentrant after this point will fail
        _notEntered = false;

        _;

        // By storing the original value once again, a refund is triggered (see
        // https://eips.ethereum.org/EIPS/eip-2200)
        _notEntered = true;
    }
}

// File: @openzeppelin/contracts/token/ERC20/SafeERC20.sol

pragma solidity ^0.5.0;

/**
 * @title SafeERC20
 * @dev Wrappers around ERC20 operations that throw on failure (when the token
 * contract returns false). Tokens that return no value (and instead revert or
 * throw on failure) are also supported, non-reverting calls are assumed to be
 * successful.
 * To use this library you can add a `using SafeERC20 for ERC20;` statement to your contract,
 * which allows you to call the safe operations as `token.safeTransfer(...)`, etc.
 */
library SafeERC20 {
    using SafeMath for uint256;
    using Address for address;

    function safeTransfer(
        IERC20 token,
        address to,
        uint256 value
    ) internal {
        callOptionalReturn(
            token,
            abi.encodeWithSelector(token.transfer.selector, to, value)
        );
    }

    function safeTransferFrom(
        IERC20 token,
        address from,
        address to,
        uint256 value
    ) internal {
        callOptionalReturn(
            token,
            abi.encodeWithSelector(token.transferFrom.selector, from, to, value)
        );
    }

    function safeApprove(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        // safeApprove should only be called when setting an initial allowance,
        // or when resetting it to zero. To increase and decrease it, use
        // 'safeIncreaseAllowance' and 'safeDecreaseAllowance'
        // solhint-disable-next-line max-line-length
        require(
            (value == 0) || (token.allowance(address(this), spender) == 0),
            "SafeERC20: approve from non-zero to non-zero allowance"
        );
        callOptionalReturn(
            token,
            abi.encodeWithSelector(token.approve.selector, spender, value)
        );
    }

    function safeIncreaseAllowance(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        uint256 newAllowance = token.allowance(address(this), spender).add(
            value
        );
        callOptionalReturn(
            token,
            abi.encodeWithSelector(
                token.approve.selector,
                spender,
                newAllowance
            )
        );
    }

    function safeDecreaseAllowance(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        uint256 newAllowance = token.allowance(address(this), spender).sub(
            value,
            "SafeERC20: decreased allowance below zero"
        );
        callOptionalReturn(
            token,
            abi.encodeWithSelector(
                token.approve.selector,
                spender,
                newAllowance
            )
        );
    }

    /**
     * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement
     * on the return value: the return value is optional (but if data is returned, it must not be false).
     * @param token The token targeted by the call.
     * @param data The call data (encoded using abi.encode or one of its variants).
     */
    function callOptionalReturn(IERC20 token, bytes memory data) private {
        // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since
        // we're implementing it ourselves.

        // A Solidity high level call has three parts:
        //  1. The target address is checked to verify it contains contract code
        //  2. The call itself is made, and success asserted
        //  3. The return value is decoded, which in turn checks the size of the returned data.
        // solhint-disable-next-line max-line-length
        require(address(token).isContract(), "SafeERC20: call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = address(token).call(data);
        require(success, "SafeERC20: low-level call failed");

        if (returndata.length > 0) {
            // Return data is optional
            // solhint-disable-next-line max-line-length
            require(
                abi.decode(returndata, (bool)),
                "SafeERC20: ERC20 operation did not succeed"
            );
        }
    }
}

interface IUniswapV2Router02 {
    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint256 amountADesired,
        uint256 amountBDesired,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    )
        external
        returns (
            uint256 amountA,
            uint256 amountB,
            uint256 liquidity
        );

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (
            uint256 amountToken,
            uint256 amountETH,
            uint256 liquidity
        );

    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint256 liquidity,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountA, uint256 amountB);

    function removeLiquidityETH(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountToken, uint256 amountETH);

    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint256 liquidity,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountA, uint256 amountB);

    function removeLiquidityETHWithPermit(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountToken, uint256 amountETH);

    function swapExactTokensForTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapTokensForExactTokens(
        uint256 amountOut,
        uint256 amountInMax,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapExactETHForTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable returns (uint256[] memory amounts);

    function swapTokensForExactETH(
        uint256 amountOut,
        uint256 amountInMax,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapExactTokensForETH(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapETHForExactTokens(
        uint256 amountOut,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable returns (uint256[] memory amounts);

    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountETH);

    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountETH);

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;

    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable;

    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;

    function quote(
        uint256 amountA,
        uint256 reserveA,
        uint256 reserveB
    ) external pure returns (uint256 amountB);

    function getAmountOut(
        uint256 amountIn,
        uint256 reserveIn,
        uint256 reserveOut
    ) external pure returns (uint256 amountOut);

    function getAmountIn(
        uint256 amountOut,
        uint256 reserveIn,
        uint256 reserveOut
    ) external pure returns (uint256 amountIn);

    function getAmountsOut(uint256 amountIn, address[] calldata path)
        external
        view
        returns (uint256[] memory amounts);

    function getAmountsIn(uint256 amountOut, address[] calldata path)
        external
        view
        returns (uint256[] memory amounts);
}

interface Iuniswap {
    // converting ERC20 to ERC20 and transfer
    function tokenToTokenTransferInput(
        uint256 tokens_sold,
        uint256 min_tokens_bought,
        uint256 min_eth_bought,
        uint256 deadline,
        address recipient,
        address token_addr
    ) external returns (uint256 tokens_bought);

    function tokenToTokenSwapInput(
        uint256 tokens_sold,
        uint256 min_tokens_bought,
        uint256 min_eth_bought,
        uint256 deadline,
        address token_addr
    ) external returns (uint256 tokens_bought);

    function getTokenToEthInputPrice(uint256 tokens_sold)
        external
        view
        returns (uint256 eth_bought);

    function tokenToEthTransferInput(
        uint256 tokens_sold,
        uint256 min_eth,
        uint256 deadline,
        address recipient
    ) external returns (uint256 eth_bought);

    function ethToTokenSwapInput(uint256 min_tokens, uint256 deadline)
        external
        payable
        returns (uint256 tokens_bought);

    function ethToTokenTransferInput(
        uint256 min_tokens,
        uint256 deadline,
        address recipient
    ) external payable returns (uint256 tokens_bought);

    function balanceOf(address _owner) external view returns (uint256);

    function transfer(address _to, uint256 _value) external returns (bool);

    function transferFrom(
        address from,
        address to,
        uint256 tokens
    ) external returns (bool success);
}

interface IUniswapV2Pair {
    function token0() external pure returns (address);

    function token1() external pure returns (address);

    function totalSupply() external view returns (uint256);

    function getReserves()
        external
        view
        returns (
            uint112 _reserve0,
            uint112 _reserve1,
            uint32 _blockTimestampLast
        );

    function permit(
        address owner,
        address spender,
        uint256 value,
        uint256 deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external;
}

interface IWETH {
    function deposit() external payable;

    function transfer(address to, uint256 value) external returns (bool);

    function withdraw(uint256) external;
}

interface IUniswapV2Factory {
    function getPair(address tokenA, address tokenB)
        external
        view
        returns (address);
}

contract UniswapV2_ZapOut_General_V2_1 is ReentrancyGuard, Ownable {
    using SafeMath for uint256;
    using SafeERC20 for IERC20;
    using Address for address;
    bool public stopped = false;
    uint16 public goodwill;
    address
        private constant zgoodwillAddress = 0xE737b6AfEC2320f616297e59445b60a11e3eF75F;

    uint256
        private constant deadline = 0xf000000000000000000000000000000000000000000000000000000000000000;

    IUniswapV2Router02 private constant uniswapV2Router = IUniswapV2Router02(
        0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
    );

    IUniswapV2Factory
        private constant UniSwapV2FactoryAddress = IUniswapV2Factory(
        0x5C69bEe701ef814a2B6a3EDD4B1652CB9cc5aA6f
    );

    address private constant wethTokenAddress = address(
        0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2
    );

    constructor(uint16 _goodwill) public {
        goodwill = _goodwill;
    }

    // circuit breaker modifiers
    modifier stopInEmergency {
        if (stopped) {
            revert("Temporarily Paused");
        } else {
            _;
        }
    }

    /**
    @notice This function is used to zapout of given Uniswap pair in the bounded tokens
    @param _FromUniPoolAddress The uniswap pair address to zapout
    @param _IncomingLP The amount of LP
    @return the amount of pair tokens received after zapout
     */
    function ZapOut2PairToken(address _FromUniPoolAddress, uint256 _IncomingLP)
        public
        nonReentrant
        stopInEmergency
        returns (uint256 amountA, uint256 amountB)
    {
        IUniswapV2Pair pair = IUniswapV2Pair(_FromUniPoolAddress);

        require(address(pair) != address(0), "Error: Invalid Unipool Address");

        //get reserves
        address token0 = pair.token0();
        address token1 = pair.token1();

        IERC20(_FromUniPoolAddress).safeTransferFrom(
            msg.sender,
            address(this),
            _IncomingLP
        );

        uint256 goodwillPortion = _transferGoodwill(
            _FromUniPoolAddress,
            _IncomingLP
        );

        IERC20(_FromUniPoolAddress).safeApprove(
            address(uniswapV2Router),
            SafeMath.sub(_IncomingLP, goodwillPortion)
        );

        if (token0 == wethTokenAddress || token1 == wethTokenAddress) {
            address _token = token0 == wethTokenAddress ? token1 : token0;
            (amountA, amountB) = uniswapV2Router.removeLiquidityETH(
                _token,
                SafeMath.sub(_IncomingLP, goodwillPortion),
                1,
                1,
                msg.sender,
                deadline
            );
        } else {
            (amountA, amountB) = uniswapV2Router.removeLiquidity(
                token0,
                token1,
                SafeMath.sub(_IncomingLP, goodwillPortion),
                1,
                1,
                msg.sender,
                deadline
            );
        }
    }

    /**
    @notice This function is used to zapout of given Uniswap pair in ETH/ERC20 Tokens
    @param _ToTokenContractAddress The ERC20 token to zapout in (address(0x00) if ether)
    @param _FromUniPoolAddress The uniswap pair address to zapout from
    @param _IncomingLP The amount of LP
    @return the amount of eth/tokens received after zapout
     */
    function ZapOut(
        address _ToTokenContractAddress,
        address _FromUniPoolAddress,
        uint256 _IncomingLP,
        uint256 _minTokensRec
    ) public nonReentrant stopInEmergency returns (uint256) {
        IUniswapV2Pair pair = IUniswapV2Pair(_FromUniPoolAddress);

        require(address(pair) != address(0), "Error: Invalid Unipool Address");

        //get pair tokens
        address token0 = pair.token0();
        address token1 = pair.token1();

        IERC20(_FromUniPoolAddress).safeTransferFrom(
            msg.sender,
            address(this),
            _IncomingLP
        );

        uint256 goodwillPortion = _transferGoodwill(
            _FromUniPoolAddress,
            _IncomingLP
        );

        IERC20(_FromUniPoolAddress).safeApprove(
            address(uniswapV2Router),
            SafeMath.sub(_IncomingLP, goodwillPortion)
        );

        (uint256 amountA, uint256 amountB) = uniswapV2Router.removeLiquidity(
            token0,
            token1,
            SafeMath.sub(_IncomingLP, goodwillPortion),
            1,
            1,
            address(this),
            deadline
        );

        uint256 tokenBought;
        if (
            canSwapFromV2(_ToTokenContractAddress, token0) &&
            canSwapFromV2(_ToTokenContractAddress, token1)
        ) {
            tokenBought = swapFromV2(token0, _ToTokenContractAddress, amountA);
            tokenBought += swapFromV2(token1, _ToTokenContractAddress, amountB);
        } else if (canSwapFromV2(_ToTokenContractAddress, token0)) {
            uint256 token0Bought = swapFromV2(token1, token0, amountB);
            tokenBought = swapFromV2(
                token0,
                _ToTokenContractAddress,
                token0Bought.add(amountA)
            );
        } else if (canSwapFromV2(_ToTokenContractAddress, token1)) {
            uint256 token1Bought = swapFromV2(token0, token1, amountA);
            tokenBought = swapFromV2(
                token1,
                _ToTokenContractAddress,
                token1Bought.add(amountB)
            );
        }

        require(tokenBought >= _minTokensRec, "High slippage");

        if (_ToTokenContractAddress == address(0)) {
            msg.sender.transfer(tokenBought);
        } else {
            IERC20(_ToTokenContractAddress).safeTransfer(
                msg.sender,
                tokenBought
            );
        }

        return tokenBought;
    }

    function ZapOut2PairTokenWithPermit(
        address _FromUniPoolAddress,
        uint256 _IncomingLP,
        uint256 _approvalAmount,
        uint256 _deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external stopInEmergency returns (uint256 amountA, uint256 amountB) {
        // permit
        IUniswapV2Pair(_FromUniPoolAddress).permit(
            msg.sender,
            address(this),
            _approvalAmount,
            _deadline,
            v,
            r,
            s
        );
        (amountA, amountB) = ZapOut2PairToken(_FromUniPoolAddress, _IncomingLP);
    }

    function ZapOutWithPermit(
        address _ToTokenContractAddress,
        address _FromUniPoolAddress,
        uint256 _IncomingLP,
        uint256 _minTokensRec,
        uint256 _approvalAmount,
        uint256 _deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external stopInEmergency returns (uint256) {
        // permit
        IUniswapV2Pair(_FromUniPoolAddress).permit(
            msg.sender,
            address(this),
            _approvalAmount,
            _deadline,
            v,
            r,
            s
        );

        return (
            ZapOut(
                _ToTokenContractAddress,
                _FromUniPoolAddress,
                _IncomingLP,
                _minTokensRec
            )
        );
    }

    //swaps _fromToken for _toToken
    //for eth, address(0) otherwise ERC token address
    function swapFromV2(
        address _fromToken,
        address _toToken,
        uint256 amount
    ) internal returns (uint256) {
        require(
            _fromToken != address(0) || _toToken != address(0),
            "Invalid Exchange values"
        );
        if (_fromToken == _toToken) return amount;

        require(canSwapFromV2(_fromToken, _toToken), "Cannot be exchanged");
        require(amount > 0, "Invalid amount");

        if (_fromToken == address(0)) {
            if (_toToken == wethTokenAddress) {
                IWETH(wethTokenAddress).deposit.value(amount)();
                return amount;
            }
            address[] memory path = new address[](2);
            path[0] = wethTokenAddress;
            path[1] = _toToken;
            uint256 minTokens = uniswapV2Router.getAmountsOut(amount, path)[1];
            minTokens = SafeMath.div(
                SafeMath.mul(minTokens, SafeMath.sub(10000, 200)),
                10000
            );
            uint256[] memory amounts = uniswapV2Router
                .swapExactETHForTokens
                .value(amount)(minTokens, path, address(this), deadline);
            return amounts[1];
        } else if (_toToken == address(0)) {
            if (_fromToken == wethTokenAddress) {
                IWETH(wethTokenAddress).withdraw(amount);
                return amount;
            }
            address[] memory path = new address[](2);
            IERC20(_fromToken).safeApprove(address(uniswapV2Router), amount);
            path[0] = _fromToken;
            path[1] = wethTokenAddress;
            uint256 minTokens = uniswapV2Router.getAmountsOut(amount, path)[1];
            minTokens = SafeMath.div(
                SafeMath.mul(minTokens, SafeMath.sub(10000, 200)),
                10000
            );
            uint256[] memory amounts = uniswapV2Router.swapExactTokensForETH(
                amount,
                minTokens,
                path,
                address(this),
                deadline
            );
            return amounts[1];
        } else {
            IERC20(_fromToken).safeApprove(address(uniswapV2Router), amount);
            uint256 returnedAmount = _swapTokenToTokenV2(
                _fromToken,
                _toToken,
                amount
            );
            require(returnedAmount > 0, "Error in swap");
            return returnedAmount;
        }
    }

    //swaps 2 ERC tokens (UniV2)
    function _swapTokenToTokenV2(
        address _fromToken,
        address _toToken,
        uint256 amount
    ) internal returns (uint256) {
        IUniswapV2Pair pair1 = IUniswapV2Pair(
            UniSwapV2FactoryAddress.getPair(_fromToken, wethTokenAddress)
        );
        IUniswapV2Pair pair2 = IUniswapV2Pair(
            UniSwapV2FactoryAddress.getPair(_toToken, wethTokenAddress)
        );
        IUniswapV2Pair pair3 = IUniswapV2Pair(
            UniSwapV2FactoryAddress.getPair(_fromToken, _toToken)
        );

        uint256[] memory amounts;

        if (_haveReserve(pair3)) {
            address[] memory path = new address[](2);
            path[0] = _fromToken;
            path[1] = _toToken;
            uint256 minTokens = uniswapV2Router.getAmountsOut(amount, path)[1];
            minTokens = SafeMath.div(
                SafeMath.mul(minTokens, SafeMath.sub(10000, 200)),
                10000
            );
            amounts = uniswapV2Router.swapExactTokensForTokens(
                amount,
                minTokens,
                path,
                address(this),
                deadline
            );
            return amounts[1];
        } else if (_haveReserve(pair1) && _haveReserve(pair2)) {
            address[] memory path = new address[](3);
            path[0] = _fromToken;
            path[1] = wethTokenAddress;
            path[2] = _toToken;
            uint256 minTokens = uniswapV2Router.getAmountsOut(amount, path)[2];
            minTokens = SafeMath.div(
                SafeMath.mul(minTokens, SafeMath.sub(10000, 200)),
                10000
            );
            amounts = uniswapV2Router.swapExactTokensForTokens(
                amount,
                minTokens,
                path,
                address(this),
                deadline
            );
            return amounts[2];
        }
        return 0;
    }

    function canSwapFromV2(address _fromToken, address _toToken)
        public
        view
        returns (bool)
    {
        require(
            _fromToken != address(0) || _toToken != address(0),
            "Invalid Exchange values"
        );

        if (_fromToken == _toToken) return true;

        if (_fromToken == address(0) || _fromToken == wethTokenAddress) {
            if (_toToken == wethTokenAddress || _toToken == address(0))
                return true;
            IUniswapV2Pair pair = IUniswapV2Pair(
                UniSwapV2FactoryAddress.getPair(_toToken, wethTokenAddress)
            );
            if (_haveReserve(pair)) return true;
        } else if (_toToken == address(0) || _toToken == wethTokenAddress) {
            if (_fromToken == wethTokenAddress || _fromToken == address(0))
                return true;
            IUniswapV2Pair pair = IUniswapV2Pair(
                UniSwapV2FactoryAddress.getPair(_fromToken, wethTokenAddress)
            );
            if (_haveReserve(pair)) return true;
        } else {
            IUniswapV2Pair pair1 = IUniswapV2Pair(
                UniSwapV2FactoryAddress.getPair(_fromToken, wethTokenAddress)
            );
            IUniswapV2Pair pair2 = IUniswapV2Pair(
                UniSwapV2FactoryAddress.getPair(_toToken, wethTokenAddress)
            );
            IUniswapV2Pair pair3 = IUniswapV2Pair(
                UniSwapV2FactoryAddress.getPair(_fromToken, _toToken)
            );
            if (_haveReserve(pair1) && _haveReserve(pair2)) return true;
            if (_haveReserve(pair3)) return true;
        }
        return false;
    }

    //checks if the UNI v2 contract have reserves to swap tokens
    function _haveReserve(IUniswapV2Pair pair) internal view returns (bool) {
        if (address(pair) != address(0)) {
            uint256 totalSupply = pair.totalSupply();
            if (totalSupply > 0) return true;
        }
    }

    /**
    @notice This function is used to calculate and transfer goodwill
    @param _tokenContractAddress Token in which goodwill is deducted
    @param tokens2Trade The total amount of tokens to be zapped in
    @return The quantity of goodwill deducted
     */
    function _transferGoodwill(
        address _tokenContractAddress,
        uint256 tokens2Trade
    ) internal returns (uint256 goodwillPortion) {
        if (goodwill == 0) {
            return 0;
        }

        goodwillPortion = SafeMath.div(
            SafeMath.mul(tokens2Trade, goodwill),
            10000
        );

        IERC20(_tokenContractAddress).safeTransfer(
            zgoodwillAddress,
            goodwillPortion
        );
    }

    function set_new_goodwill(uint16 _new_goodwill) public onlyOwner {
        require(
            _new_goodwill >= 0 && _new_goodwill < 10000,
            "GoodWill Value not allowed"
        );
        goodwill = _new_goodwill;
    }

    function inCaseTokengetsStuck(IERC20 _TokenAddress) public onlyOwner {
        uint256 qty = _TokenAddress.balanceOf(address(this));
        _TokenAddress.safeTransfer(owner(), qty);
    }

    // - to Pause the contract
    function toggleContractActive() public onlyOwner {
        stopped = !stopped;
    }

    // - to withdraw any ETH balance sitting in the contract
    function withdraw() public onlyOwner {
        uint256 contractBalance = address(this).balance;
        address payable _to = owner().toPayable();
        _to.transfer(contractBalance);
    }

    function() external payable {
        require(msg.sender != tx.origin, "Do not send ETH directly");
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"uint16","name":"_goodwill","type":"uint16"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"payable":true,"stateMutability":"payable","type":"fallback"},{"constant":false,"inputs":[{"internalType":"address","name":"_ToTokenContractAddress","type":"address"},{"internalType":"address","name":"_FromUniPoolAddress","type":"address"},{"internalType":"uint256","name":"_IncomingLP","type":"uint256"},{"internalType":"uint256","name":"_minTokensRec","type":"uint256"}],"name":"ZapOut","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_FromUniPoolAddress","type":"address"},{"internalType":"uint256","name":"_IncomingLP","type":"uint256"}],"name":"ZapOut2PairToken","outputs":[{"internalType":"uint256","name":"amountA","type":"uint256"},{"internalType":"uint256","name":"amountB","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_FromUniPoolAddress","type":"address"},{"internalType":"uint256","name":"_IncomingLP","type":"uint256"},{"internalType":"uint256","name":"_approvalAmount","type":"uint256"},{"internalType":"uint256","name":"_deadline","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"ZapOut2PairTokenWithPermit","outputs":[{"internalType":"uint256","name":"amountA","type":"uint256"},{"internalType":"uint256","name":"amountB","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_ToTokenContractAddress","type":"address"},{"internalType":"address","name":"_FromUniPoolAddress","type":"address"},{"internalType":"uint256","name":"_IncomingLP","type":"uint256"},{"internalType":"uint256","name":"_minTokensRec","type":"uint256"},{"internalType":"uint256","name":"_approvalAmount","type":"uint256"},{"internalType":"uint256","name":"_deadline","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"ZapOutWithPermit","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"_fromToken","type":"address"},{"internalType":"address","name":"_toToken","type":"address"}],"name":"canSwapFromV2","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"goodwill","outputs":[{"internalType":"uint16","name":"","type":"uint16"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"contract IERC20","name":"_TokenAddress","type":"address"}],"name":"inCaseTokengetsStuck","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"isOwner","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"renounceOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"uint16","name":"_new_goodwill","type":"uint16"}],"name":"set_new_goodwill","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"stopped","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"toggleContractActive","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"withdraw","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"}]

60806040526000805460ff60a81b191690553480156200001e57600080fd5b50604051620034e0380380620034e0833981810160405260208110156200004457600080fd5b50516000805460ff19166001178155620000666001600160e01b03620000de16565b60008054610100600160a81b0319166101006001600160a01b038416908102919091178255604051929350917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3506000805461ffff909216600160b01b0261ffff60b01b19909216919091179055620000e2565b3390565b6133ee80620000f26000396000f3fe6080604052600436106100e85760003560e01c80638da5cb5b1161008a578063c246c8e011610059578063c246c8e014610341578063ee857b69146103b4578063f27cf320146103ed578063f2fde38b14610428576100e8565b80638da5cb5b146102615780638f32d59b14610292578063b10e1dbc146102a7578063bf93516c146102d5576100e8565b8063551196d5116100c6578063551196d5146101c45780635de0398e146101f7578063715018a61461022357806375f12b2114610238576100e8565b80631385d24c1461013f5780633ccfd60b1461015457806349c082cd14610169575b3332141561013d576040805162461bcd60e51b815260206004820152601860248201527f446f206e6f742073656e6420455448206469726563746c790000000000000000604482015290519081900360640190fd5b005b34801561014b57600080fd5b5061013d61045b565b34801561016057600080fd5b5061013d6104c3565b34801561017557600080fd5b506101b26004803603608081101561018c57600080fd5b506001600160a01b03813581169160208101359091169060408101359060600135610564565b60408051918252519081900360200190f35b3480156101d057600080fd5b5061013d600480360360208110156101e757600080fd5b50356001600160a01b03166109eb565b34801561020357600080fd5b5061020c610ad0565b6040805161ffff9092168252519081900360200190f35b34801561022f57600080fd5b5061013d610ae1565b34801561024457600080fd5b5061024d610b77565b604080519115158252519081900360200190f35b34801561026d57600080fd5b50610276610b87565b604080516001600160a01b039092168252519081900360200190f35b34801561029e57600080fd5b5061024d610b9b565b3480156102b357600080fd5b5061013d600480360360208110156102ca57600080fd5b503561ffff16610bc4565b3480156102e157600080fd5b506101b260048036036101208110156102f957600080fd5b506001600160a01b03813581169160208101359091169060408101359060608101359060808101359060a08101359060ff60c0820135169060e0810135906101000135610c87565b34801561034d57600080fd5b5061039b600480360360e081101561036457600080fd5b506001600160a01b038135169060208101359060408101359060608101359060ff6080820135169060a08101359060c00135610d80565b6040805192835260208301919091528051918290030190f35b3480156103c057600080fd5b5061039b600480360360408110156103d757600080fd5b506001600160a01b038135169060200135610e7b565b3480156103f957600080fd5b5061024d6004803603604081101561041057600080fd5b506001600160a01b03813581169160200135166112c2565b34801561043457600080fd5b5061013d6004803603602081101561044b57600080fd5b50356001600160a01b031661177a565b610463610b9b565b6104a2576040805162461bcd60e51b8152602060048201819052602482015260008051602061333a833981519152604482015290519081900360640190fd5b6000805460ff60a81b198116600160a81b9182900460ff1615909102179055565b6104cb610b9b565b61050a576040805162461bcd60e51b8152602060048201819052602482015260008051602061333a833981519152604482015290519081900360640190fd5b476000610526610518610b87565b6001600160a01b03166117cd565b6040519091506001600160a01b0382169083156108fc029084906000818181858888f1935050505015801561055f573d6000803e3d6000fd5b505050565b6000805460ff166105bc576040805162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604482015290519081900360640190fd5b6000805460ff191690819055600160a81b900460ff1615610619576040805162461bcd60e51b815260206004820152601260248201527115195b5c1bdc985c9a5b1e4814185d5cd95960721b604482015290519081900360640190fd5b836001600160a01b038116610675576040805162461bcd60e51b815260206004820152601e60248201527f4572726f723a20496e76616c696420556e69706f6f6c20416464726573730000604482015290519081900360640190fd5b6000816001600160a01b0316630dfe16816040518163ffffffff1660e01b815260040160206040518083038186803b1580156106b057600080fd5b505afa1580156106c4573d6000803e3d6000fd5b505050506040513d60208110156106da57600080fd5b50516040805163d21220a760e01b815290519192506000916001600160a01b0385169163d21220a7916004808301926020929190829003018186803b15801561072257600080fd5b505afa158015610736573d6000803e3d6000fd5b505050506040513d602081101561074c57600080fd5b5051905061076b6001600160a01b03881633308963ffffffff6117d416565b60006107778888611834565b90506107ac6000805160206132f983398151915261079589846118a4565b6001600160a01b038b16919063ffffffff6118ed16565b6000806000805160206132f983398151915263baa2abde86866107cf8d886118a4565b604080516001600160e01b031960e087901b1681526001600160a01b039485166004820152929093166024830152604482015260016064820181905260848201523060a4820152600f60fc1b60c4820152815160e480830193928290030181600087803b15801561083f57600080fd5b505af1158015610853573d6000803e3d6000fd5b505050506040513d604081101561086957600080fd5b508051602090910151909250905060006108838c876112c2565b801561089457506108948c866112c2565b156108b7576108a4868d85611a00565b90506108b1858d84611a00565b0161092e565b6108c18c876112c2565b156108f75760006108d3868885611a00565b90506108ef878e6108ea848863ffffffff6123b316565b611a00565b91505061092e565b6109018c866112c2565b1561092e576000610913878786611a00565b905061092a868e6108ea848763ffffffff6123b316565b9150505b88811015610973576040805162461bcd60e51b815260206004820152600d60248201526c4869676820736c69707061676560981b604482015290519081900360640190fd5b6001600160a01b038c166109b457604051339082156108fc029083906000818181858888f193505050501580156109ae573d6000803e3d6000fd5b506109ce565b6109ce6001600160a01b038d16338363ffffffff61240d16565b96505050505050506000805460ff19166001179055949350505050565b6109f3610b9b565b610a32576040805162461bcd60e51b8152602060048201819052602482015260008051602061333a833981519152604482015290519081900360640190fd5b604080516370a0823160e01b815230600482015290516000916001600160a01b038416916370a0823191602480820192602092909190829003018186803b158015610a7c57600080fd5b505afa158015610a90573d6000803e3d6000fd5b505050506040513d6020811015610aa657600080fd5b50519050610acc610ab5610b87565b6001600160a01b038416908363ffffffff61240d16565b5050565b600054600160b01b900461ffff1681565b610ae9610b9b565b610b28576040805162461bcd60e51b8152602060048201819052602482015260008051602061333a833981519152604482015290519081900360640190fd5b600080546040516101009091046001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a360008054610100600160a81b0319169055565b600054600160a81b900460ff1681565b60005461010090046001600160a01b031690565b6000805461010090046001600160a01b0316610bb561245f565b6001600160a01b031614905090565b610bcc610b9b565b610c0b576040805162461bcd60e51b8152602060048201819052602482015260008051602061333a833981519152604482015290519081900360640190fd5b6127108161ffff1610610c65576040805162461bcd60e51b815260206004820152601a60248201527f476f6f6457696c6c2056616c7565206e6f7420616c6c6f776564000000000000604482015290519081900360640190fd5b6000805461ffff909216600160b01b0261ffff60b01b19909216919091179055565b60008054600160a81b900460ff1615610cdc576040805162461bcd60e51b815260206004820152601260248201527115195b5c1bdc985c9a5b1e4814185d5cd95960721b604482015290519081900360640190fd5b6040805163d505accf60e01b8152336004820152306024820152604481018890526064810187905260ff8616608482015260a4810185905260c4810184905290516001600160a01b038b169163d505accf9160e480830192600092919082900301818387803b158015610d4e57600080fd5b505af1158015610d62573d6000803e3d6000fd5b50505050610d728a8a8a8a610564565b9a9950505050505050505050565b600080548190600160a81b900460ff1615610dd7576040805162461bcd60e51b815260206004820152601260248201527115195b5c1bdc985c9a5b1e4814185d5cd95960721b604482015290519081900360640190fd5b6040805163d505accf60e01b8152336004820152306024820152604481018990526064810188905260ff8716608482015260a4810186905260c4810185905290516001600160a01b038b169163d505accf9160e480830192600092919082900301818387803b158015610e4957600080fd5b505af1158015610e5d573d6000803e3d6000fd5b50505050610e6b8989610e7b565b909a909950975050505050505050565b60008054819060ff16610ed5576040805162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604482015290519081900360640190fd5b6000805460ff191690819055600160a81b900460ff1615610f32576040805162461bcd60e51b815260206004820152601260248201527115195b5c1bdc985c9a5b1e4814185d5cd95960721b604482015290519081900360640190fd5b836001600160a01b038116610f8e576040805162461bcd60e51b815260206004820152601e60248201527f4572726f723a20496e76616c696420556e69706f6f6c20416464726573730000604482015290519081900360640190fd5b6000816001600160a01b0316630dfe16816040518163ffffffff1660e01b815260040160206040518083038186803b158015610fc957600080fd5b505afa158015610fdd573d6000803e3d6000fd5b505050506040513d6020811015610ff357600080fd5b50516040805163d21220a760e01b815290519192506000916001600160a01b0385169163d21220a7916004808301926020929190829003018186803b15801561103b57600080fd5b505afa15801561104f573d6000803e3d6000fd5b505050506040513d602081101561106557600080fd5b505190506110846001600160a01b03881633308963ffffffff6117d416565b60006110908888611834565b90506110ae6000805160206132f983398151915261079589846118a4565b6001600160a01b0383166000805160206132b383398151915214806110e957506001600160a01b0382166000805160206132b3833981519152145b156111df5760006001600160a01b0384166000805160206132b3833981519152146111145783611116565b825b90506000805160206132f98339815191526302751cec826111378b866118a4565b604080516001600160e01b031960e086901b1681526001600160a01b03909316600484015260248301919091526001604483018190526064830152336084830152600f60fc1b60a4830152805160c4808401938290030181600087803b1580156111a057600080fd5b505af11580156111b4573d6000803e3d6000fd5b505050506040513d60408110156111ca57600080fd5b50805160209091015190975095506112a89050565b6000805160206132f983398151915263baa2abde84846111ff8b866118a4565b604080516001600160e01b031960e087901b1681526001600160a01b039485166004820152929093166024830152604482015260016064820181905260848201523360a4820152600f60fc1b60c4820152815160e480830193928290030181600087803b15801561126f57600080fd5b505af1158015611283573d6000803e3d6000fd5b505050506040513d604081101561129957600080fd5b50805160209091015190965094505b505050506000805460ff1916600117905590939092509050565b60006001600160a01b0383161515806112e357506001600160a01b03821615155b61132e576040805162461bcd60e51b8152602060048201526017602482015276496e76616c69642045786368616e67652076616c75657360481b604482015290519081900360640190fd5b816001600160a01b0316836001600160a01b0316141561135057506001611774565b6001600160a01b038316158061137c57506001600160a01b0383166000805160206132b3833981519152145b15611478576001600160a01b0382166000805160206132b383398151915214806113ad57506001600160a01b038216155b156113ba57506001611774565b6040805163e6a4390560e01b81526001600160a01b03841660048201526000805160206132b383398151915260248201529051600091735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f9163e6a4390591604480820192602092909190829003018186803b15801561142c57600080fd5b505afa158015611440573d6000803e3d6000fd5b505050506040513d602081101561145657600080fd5b5051905061146381612463565b15611472576001915050611774565b50611770565b6001600160a01b03821615806114a457506001600160a01b0382166000805160206132b3833981519152145b15611554576001600160a01b0383166000805160206132b383398151915214806114d557506001600160a01b038316155b156114e257506001611774565b6040805163e6a4390560e01b81526001600160a01b03851660048201526000805160206132b383398151915260248201529051600091735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f9163e6a4390591604480820192602092909190829003018186803b15801561142c57600080fd5b6040805163e6a4390560e01b81526001600160a01b03851660048201526000805160206132b383398151915260248201529051600091735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f9163e6a4390591604480820192602092909190829003018186803b1580156115c657600080fd5b505afa1580156115da573d6000803e3d6000fd5b505050506040513d60208110156115f057600080fd5b50516040805163e6a4390560e01b81526001600160a01b03861660048201526000805160206132b383398151915260248201529051919250600091735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f9163e6a43905916044808301926020929190829003018186803b15801561166657600080fd5b505afa15801561167a573d6000803e3d6000fd5b505050506040513d602081101561169057600080fd5b50516040805163e6a4390560e01b81526001600160a01b038881166004830152871660248201529051919250600091735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f9163e6a43905916044808301926020929190829003018186803b1580156116fa57600080fd5b505afa15801561170e573d6000803e3d6000fd5b505050506040513d602081101561172457600080fd5b5051905061173183612463565b8015611741575061174182612463565b156117525760019350505050611774565b61175b81612463565b1561176c5760019350505050611774565b5050505b5060005b92915050565b611782610b9b565b6117c1576040805162461bcd60e51b8152602060048201819052602482015260008051602061333a833981519152604482015290519081900360640190fd5b6117ca816124f3565b50565b805b919050565b604080516001600160a01b0385811660248301528416604482015260648082018490528251808303909101815260849091019091526020810180516001600160e01b03166323b872dd60e01b17905261182e90859061259e565b50505050565b60008054600160b01b900461ffff1661184f57506000611774565b6000546118749061186c908490600160b01b900461ffff16612756565b6127106127af565b90506117746001600160a01b03841673e737b6afec2320f616297e59445b60a11e3ef75f8363ffffffff61240d16565b60006118e683836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506127f1565b9392505050565b801580611973575060408051636eb1769f60e11b81523060048201526001600160a01b03848116602483015291519185169163dd62ed3e91604480820192602092909190829003018186803b15801561194557600080fd5b505afa158015611959573d6000803e3d6000fd5b505050506040513d602081101561196f57600080fd5b5051155b6119ae5760405162461bcd60e51b81526004018080602001828103825260368152602001806133846036913960400191505060405180910390fd5b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663095ea7b360e01b17905261055f90849061259e565b60006001600160a01b038416151580611a2157506001600160a01b03831615155b611a6c576040805162461bcd60e51b8152602060048201526017602482015276496e76616c69642045786368616e67652076616c75657360481b604482015290519081900360640190fd5b826001600160a01b0316846001600160a01b03161415611a8d5750806118e6565b611a9784846112c2565b611ade576040805162461bcd60e51b815260206004820152601360248201527210d85b9b9bdd08189948195e18da185b99d959606a1b604482015290519081900360640190fd5b60008211611b24576040805162461bcd60e51b815260206004820152600e60248201526d125b9d985b1a5908185b5bdd5b9d60921b604482015290519081900360640190fd5b6001600160a01b038416611f5b576001600160a01b0383166000805160206132b38339815191521415611bbb576000805160206132b38339815191526001600160a01b031663d0e30db0836040518263ffffffff1660e01b81526004016000604051808303818588803b158015611b9a57600080fd5b505af1158015611bae573d6000803e3d6000fd5b50505050508190506118e6565b60408051600280825260608083018452926020830190803883390190505090506000805160206132b383398151915281600081518110611bf757fe5b60200260200101906001600160a01b031690816001600160a01b0316815250508381600181518110611c2557fe5b6001600160a01b039092166020928302919091018201526040805163d06ca61f60e01b815260048101868152602482019283528451604483015284516000946000805160206132f98339815191529463d06ca61f948a948994909360649092019185810191028083838c5b83811015611ca8578181015183820152602001611c90565b50505050905001935050505060006040518083038186803b158015611ccc57600080fd5b505afa158015611ce0573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526020811015611d0957600080fd5b8101908080516040519392919084600160201b821115611d2857600080fd5b908301906020820185811115611d3d57600080fd5b82518660208202830111600160201b82111715611d5957600080fd5b82525081516020918201928201910280838360005b83811015611d86578181015183820152602001611d6e565b50505050905001604052505050600181518110611d9f57fe5b60200260200101519050611dc261186c82611dbd61271060c86118a4565b612756565b604051637ff36ab560e01b8152600481018281523060448301819052600f60fc1b606484018190526080602485019081528751608486015287519596506060956000805160206132f983398151915295637ff36ab5958c958a958c959194909360a401906020808801910280838360005b83811015611e4b578181015183820152602001611e33565b50505050905001955050505050506000604051808303818588803b158015611e7257600080fd5b505af1158015611e86573d6000803e3d6000fd5b50505050506040513d6000823e601f3d908101601f191682016040526020811015611eb057600080fd5b8101908080516040519392919084600160201b821115611ecf57600080fd5b908301906020820185811115611ee457600080fd5b82518660208202830111600160201b82111715611f0057600080fd5b82525081516020918201928201910280838360005b83811015611f2d578181015183820152602001611f15565b50505050905001604052505050905080600181518110611f4957fe5b602002602001015193505050506118e6565b6001600160a01b03831661232f576001600160a01b0384166000805160206132b38339815191521415611ffc576000805160206132b38339815191526001600160a01b0316632e1a7d4d836040518263ffffffff1660e01b815260040180828152602001915050600060405180830381600087803b158015611fdc57600080fd5b505af1158015611ff0573d6000803e3d6000fd5b505050508190506118e6565b60408051600280825260608083018452926020830190803883390190505090506120446001600160a01b0386166000805160206132f98339815191528563ffffffff6118ed16565b848160008151811061205257fe5b60200260200101906001600160a01b031690816001600160a01b0316815250506000805160206132b38339815191528160018151811061208e57fe5b6001600160a01b039092166020928302919091018201526040805163d06ca61f60e01b815260048101868152602482019283528451604483015284516000946000805160206132f98339815191529463d06ca61f948a948994909360649092019185810191028083838c5b838110156121115781810151838201526020016120f9565b50505050905001935050505060006040518083038186803b15801561213557600080fd5b505afa158015612149573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052602081101561217257600080fd5b8101908080516040519392919084600160201b82111561219157600080fd5b9083019060208201858111156121a657600080fd5b82518660208202830111600160201b821117156121c257600080fd5b82525081516020918201928201910280838360005b838110156121ef5781810151838201526020016121d7565b5050505090500160405250505060018151811061220857fe5b6020026020010151905061222661186c82611dbd61271060c86118a4565b905060606000805160206132f98339815191526001600160a01b03166318cbafe586848630600f60fc1b6040518663ffffffff1660e01b81526004018086815260200185815260200180602001846001600160a01b03166001600160a01b03168152602001838152602001828103825285818151815260200191508051906020019060200280838360005b838110156122c95781810151838201526020016122b1565b505050509050019650505050505050600060405180830381600087803b1580156122f257600080fd5b505af1158015612306573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526020811015611eb057600080fd5b6123576001600160a01b0385166000805160206132f98339815191528463ffffffff6118ed16565b6000612364858585612888565b9050600081116123ab576040805162461bcd60e51b815260206004820152600d60248201526c04572726f7220696e207377617609c1b604482015290519081900360640190fd5b949350505050565b6000828201838110156118e6576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b17905261055f90849061259e565b3390565b60006001600160a01b038216156117cf576000826001600160a01b03166318160ddd6040518163ffffffff1660e01b815260040160206040518083038186803b1580156124af57600080fd5b505afa1580156124c3573d6000803e3d6000fd5b505050506040513d60208110156124d957600080fd5b5051905080156124ed5760019150506117cf565b50919050565b6001600160a01b0381166125385760405162461bcd60e51b81526004018080602001828103825260268152602001806132d36026913960400191505060405180910390fd5b600080546040516001600160a01b038085169361010090930416917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b6125b0826001600160a01b0316613214565b612601576040805162461bcd60e51b815260206004820152601f60248201527f5361666545524332303a2063616c6c20746f206e6f6e2d636f6e747261637400604482015290519081900360640190fd5b60006060836001600160a01b0316836040518082805190602001908083835b6020831061263f5780518252601f199092019160209182019101612620565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d80600081146126a1576040519150601f19603f3d011682016040523d82523d6000602084013e6126a6565b606091505b5091509150816126fd576040805162461bcd60e51b815260206004820181905260248201527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564604482015290519081900360640190fd5b80511561182e5780806020019051602081101561271957600080fd5b505161182e5760405162461bcd60e51b815260040180806020018281038252602a81526020018061335a602a913960400191505060405180910390fd5b60008261276557506000611774565b8282028284828161277257fe5b04146118e65760405162461bcd60e51b81526004018080602001828103825260218152602001806133196021913960400191505060405180910390fd5b60006118e683836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061324d565b600081848411156128805760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561284557818101518382015260200161282d565b50505050905090810190601f1680156128725780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6040805163e6a4390560e01b81526001600160a01b03851660048201526000805160206132b3833981519152602482015290516000918291735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f9163e6a43905916044808301926020929190829003018186803b1580156128fb57600080fd5b505afa15801561290f573d6000803e3d6000fd5b505050506040513d602081101561292557600080fd5b50516040805163e6a4390560e01b81526001600160a01b03871660048201526000805160206132b383398151915260248201529051919250600091735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f9163e6a43905916044808301926020929190829003018186803b15801561299b57600080fd5b505afa1580156129af573d6000803e3d6000fd5b505050506040513d60208110156129c557600080fd5b50516040805163e6a4390560e01b81526001600160a01b038981166004830152881660248201529051919250600091735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f9163e6a43905916044808301926020929190829003018186803b158015612a2f57600080fd5b505afa158015612a43573d6000803e3d6000fd5b505050506040513d6020811015612a5957600080fd5b505190506060612a6882612463565b15612e165760408051600280825260608083018452926020830190803883390190505090508881600081518110612a9b57fe5b60200260200101906001600160a01b031690816001600160a01b0316815250508781600181518110612ac957fe5b6001600160a01b039092166020928302919091018201526040805163d06ca61f60e01b8152600481018a8152602482019283528451604483015284516000946000805160206132f98339815191529463d06ca61f948e948994909360649092019185810191028083838c5b83811015612b4c578181015183820152602001612b34565b50505050905001935050505060006040518083038186803b158015612b7057600080fd5b505afa158015612b84573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526020811015612bad57600080fd5b8101908080516040519392919084600160201b821115612bcc57600080fd5b908301906020820185811115612be157600080fd5b82518660208202830111600160201b82111715612bfd57600080fd5b82525081516020918201928201910280838360005b83811015612c2a578181015183820152602001612c12565b50505050905001604052505050600181518110612c4357fe5b60200260200101519050612c6161186c82611dbd61271060c86118a4565b90506000805160206132f98339815191526001600160a01b03166338ed173989838530600f60fc1b6040518663ffffffff1660e01b81526004018086815260200185815260200180602001846001600160a01b03166001600160a01b03168152602001838152602001828103825285818151815260200191508051906020019060200280838360005b83811015612d02578181015183820152602001612cea565b505050509050019650505050505050600060405180830381600087803b158015612d2b57600080fd5b505af1158015612d3f573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526020811015612d6857600080fd5b8101908080516040519392919084600160201b821115612d8757600080fd5b908301906020820185811115612d9c57600080fd5b82518660208202830111600160201b82111715612db857600080fd5b82525081516020918201928201910280838360005b83811015612de5578181015183820152602001612dcd565b50505050905001604052505050925082600181518110612e0157fe5b602002602001015196505050505050506118e6565b612e1f84612463565b8015612e2f5750612e2f83612463565b1561320657604080516003808252608082019092526060916020820183803883390190505090508881600081518110612e6457fe5b60200260200101906001600160a01b031690816001600160a01b0316815250506000805160206132b383398151915281600181518110612ea057fe5b60200260200101906001600160a01b031690816001600160a01b0316815250508781600281518110612ece57fe5b6001600160a01b039092166020928302919091018201526040805163d06ca61f60e01b8152600481018a8152602482019283528451604483015284516000946000805160206132f98339815191529463d06ca61f948e948994909360649092019185810191028083838c5b83811015612f51578181015183820152602001612f39565b50505050905001935050505060006040518083038186803b158015612f7557600080fd5b505afa158015612f89573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526020811015612fb257600080fd5b8101908080516040519392919084600160201b821115612fd157600080fd5b908301906020820185811115612fe657600080fd5b82518660208202830111600160201b8211171561300257600080fd5b82525081516020918201928201910280838360005b8381101561302f578181015183820152602001613017565b5050505090500160405250505060028151811061304857fe5b6020026020010151905061306661186c82611dbd61271060c86118a4565b90506000805160206132f98339815191526001600160a01b03166338ed173989838530600f60fc1b6040518663ffffffff1660e01b81526004018086815260200185815260200180602001846001600160a01b03166001600160a01b03168152602001838152602001828103825285818151815260200191508051906020019060200280838360005b838110156131075781810151838201526020016130ef565b505050509050019650505050505050600060405180830381600087803b15801561313057600080fd5b505af1158015613144573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052602081101561316d57600080fd5b8101908080516040519392919084600160201b82111561318c57600080fd5b9083019060208201858111156131a157600080fd5b82518660208202830111600160201b821117156131bd57600080fd5b82525081516020918201928201910280838360005b838110156131ea5781810151838201526020016131d2565b50505050905001604052505050925082600281518110612e0157fe5b506000979650505050505050565b6000813f7fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a4708181148015906123ab575050151592915050565b6000818361329c5760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561284557818101518382015260200161282d565b5060008385816132a857fe5b049594505050505056fe000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc24f776e61626c653a206e6577206f776e657220697320746865207a65726f20616464726573730000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f774f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725361666545524332303a204552433230206f7065726174696f6e20646964206e6f7420737563636565645361666545524332303a20617070726f76652066726f6d206e6f6e2d7a65726f20746f206e6f6e2d7a65726f20616c6c6f77616e6365a265627a7a72315820f231ede41067ad37f3706d355e11574bd0f85e73c376bfa5d12fa07114b7034364736f6c634300051100320000000000000000000000000000000000000000000000000000000000000000

Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)

0000000000000000000000000000000000000000000000000000000000000000

-----Decoded View---------------
Arg [0] : _goodwill (uint16): 0

-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 0000000000000000000000000000000000000000000000000000000000000000


Deployed ByteCode Sourcemap

32439:15676:0:-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;48052:10;48066:9;48052:23;;48044:60;;;;;-1:-1:-1;;;48044:60:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;32439:15676;47646:86;;8:9:-1;5:2;;;30:1;27;20:12;5:2;47646:86:0;;;:::i;47802:195::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;47802:195:0;;;:::i;35870:2531::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;35870:2531:0;;;;;;13:3:-1;8;5:12;2:2;;;30:1;27;20:12;2:2;-1:-1;;;;;;35870:2531:0;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;47415:191;;8:9:-1;5:2;;;30:1;27;20:12;5:2;47415:191:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;47415:191:0;-1:-1:-1;;;;;47415:191:0;;:::i;32645:22::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;32645:22:0;;;:::i;:::-;;;;;;;;;;;;;;;;;;;10528:140;;8:9:-1;5:2;;;30:1;27;20:12;5:2;10528:140:0;;;:::i;32611:27::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;32611:27:0;;;:::i;:::-;;;;;;;;;;;;;;;;;;9717:79;;8:9:-1;5:2;;;30:1;27;20:12;5:2;9717:79:0;;;:::i;:::-;;;;-1:-1:-1;;;;;9717:79:0;;;;;;;;;;;;;;10083:94;;8:9:-1;5:2;;;30:1;27;20:12;5:2;10083:94:0;;;:::i;47169:238::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;47169:238:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;47169:238:0;;;;:::i;39044:793::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;39044:793:0;;;;;;13:3:-1;8;5:12;2:2;;;30:1;27;20:12;2:2;-1:-1;;;;;;39044:793:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;38409:627::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;38409:627:0;;;;;;13:3:-1;8;5:12;2:2;;;30:1;27;20:12;2:2;-1:-1;;;;;;38409:627:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;33862:1632;;8:9:-1;5:2;;;30:1;27;20:12;5:2;33862:1632:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;33862:1632:0;;;;;;;;:::i;44420:1677::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;44420:1677:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;44420:1677:0;;;;;;;;;;:::i;10823:109::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;10823:109:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;10823:109:0;-1:-1:-1;;;;;10823:109:0;;:::i;47646:86::-;9929:9;:7;:9::i;:::-;9921:54;;;;;-1:-1:-1;;;9921:54:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;9921:54:0;;;;;;;;;;;;;;;47717:7;;;-1:-1:-1;;;;47706:18:0;;-1:-1:-1;;;47717:7:0;;;;;;47716:8;47706:18;;;;;;47646:86::o;47802:195::-;9929:9;:7;:9::i;:::-;9921:54;;;;;-1:-1:-1;;;9921:54:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;9921:54:0;;;;;;;;;;;;;;;47876:21;47850:23;47930:19;:7;:5;:7::i;:::-;-1:-1:-1;;;;;47930:17:0;;:19::i;:::-;47960:29;;47908:41;;-1:-1:-1;;;;;;47960:12:0;;;:29;;;;;47973:15;;47960:29;;;;47973:15;47960:12;:29;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;47960:29:0;9986:1;;47802:195::o;35870:2531::-;36080:7;19568:11;;;;19560:55;;;;;-1:-1:-1;;;19560:55:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;19707:5;19693:19;;-1:-1:-1;;19693:19:0;;;;;-1:-1:-1;;;33473:7:0;;19693:19;33473:7;33469:102;;;33497:28;;;-1:-1:-1;;;33497:28:0;;;;;;;;;;;;-1:-1:-1;;;33497:28:0;;;;;;;;;;;;;;33469:102;36137:19;-1:-1:-1;;;;;36178:27:0;;36170:70;;;;;-1:-1:-1;;;36170:70:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;36280:14;36297:4;-1:-1:-1;;;;;36297:11:0;;:13;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;36297:13:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;36297:13:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;36297:13:0;36338;;;-1:-1:-1;;;36338:13:0;;;;36297;;-1:-1:-1;36321:14:0;;-1:-1:-1;;;;;36338:11:0;;;;;:13;;;;;36297;;36338;;;;;;;:11;:13;;;5:2:-1;;;;30:1;27;20:12;5:2;36338:13:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;36338:13:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;36338:13:0;;-1:-1:-1;36364:134:0;-1:-1:-1;;;;;36364:44:0;;36423:10;36456:4;36476:11;36364:134;:44;:134;:::i;:::-;36511:23;36537:88;36569:19;36603:11;36537:17;:88::i;:::-;36511:114;;36638:146;-1:-1:-1;;;;;;;;;;;36731:42:0;36744:11;36757:15;36731:12;:42::i;:::-;-1:-1:-1;;;;;36638:39:0;;;:146;;:39;:146;:::i;:::-;36798:15;;-1:-1:-1;;;;;;;;;;;36834:31:0;36880:6;36901;36922:42;36935:11;36948:15;36922:12;:42::i;:::-;36834:224;;;-1:-1:-1;;;;;;36834:224:0;;;;;;;-1:-1:-1;;;;;36834:224:0;;;;;;;;;;;;;;;;;;;36979:1;36834:224;;;;;;;;;;37019:4;36834:224;;;;-1:-1:-1;;;36834:224:0;;;;;;;;;;;;;;;;;-1:-1:-1;36834:224:0;;;;5:2:-1;;;;30:1;27;20:12;5:2;36834:224:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;36834:224:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;36834:224:0;;;;;;;;;-1:-1:-1;36834:224:0;-1:-1:-1;37071:19:0;37119:46;37133:23;37158:6;37119:13;:46::i;:::-;:109;;;;;37182:46;37196:23;37221:6;37182:13;:46::i;:::-;37101:930;;;37269:52;37280:6;37288:23;37313:7;37269:10;:52::i;:::-;37255:66;;37351:52;37362:6;37370:23;37395:7;37351:10;:52::i;:::-;37336:67;37101:930;;;37425:46;37439:23;37464:6;37425:13;:46::i;:::-;37421:610;;;37488:20;37511:35;37522:6;37530;37538:7;37511:10;:35::i;:::-;37488:58;-1:-1:-1;37575:136:0;37604:6;37629:23;37671:25;37488:58;37688:7;37671:25;:16;:25;:::i;:::-;37575:10;:136::i;:::-;37561:150;;37421:610;;;;37733:46;37747:23;37772:6;37733:13;:46::i;:::-;37729:302;;;37796:20;37819:35;37830:6;37838;37846:7;37819:10;:35::i;:::-;37796:58;-1:-1:-1;37883:136:0;37912:6;37937:23;37979:25;37796:58;37996:7;37979:25;:16;:25;:::i;37883:136::-;37869:150;;37729:302;;38066:13;38051:11;:28;;38043:54;;;;;-1:-1:-1;;;38043:54:0;;;;;;;;;;;;-1:-1:-1;;;38043:54:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;38114:37:0;;38110:253;;38168:32;;:10;;:32;;;;;38188:11;;38168:32;;;;38188:11;38168:10;:32;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;38168:32:0;38110:253;;;38233:118;-1:-1:-1;;;;;38233:44:0;;38296:10;38325:11;38233:118;:44;:118;:::i;:::-;38382:11;-1:-1:-1;;;;;;;19873:11:0;:18;;-1:-1:-1;;19873:18:0;19887:4;19873:18;;;35870:2531;;-1:-1:-1;;;;35870:2531:0:o;47415:191::-;9929:9;:7;:9::i;:::-;9921:54;;;;;-1:-1:-1;;;9921:54:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;9921:54:0;;;;;;;;;;;;;;;47509:38;;;-1:-1:-1;;;47509:38:0;;47541:4;47509:38;;;;;;47495:11;;-1:-1:-1;;;;;47509:23:0;;;;;:38;;;;;;;;;;;;;;;:23;:38;;;5:2:-1;;;;30:1;27;20:12;5:2;47509:38:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;47509:38:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;47509:38:0;;-1:-1:-1;47558:40:0;47585:7;:5;:7::i;:::-;-1:-1:-1;;;;;47558:26:0;;;47594:3;47558:40;:26;:40;:::i;:::-;9986:1;47415:191;:::o;32645:22::-;;;-1:-1:-1;;;32645:22:0;;;;;:::o;10528:140::-;9929:9;:7;:9::i;:::-;9921:54;;;;;-1:-1:-1;;;9921:54:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;9921:54:0;;;;;;;;;;;;;;;10627:1;10611:6;;10590:40;;10611:6;;;;-1:-1:-1;;;;;10611:6:0;;10590:40;;10627:1;;10590:40;10658:1;10641:19;;-1:-1:-1;;;;;;10641:19:0;;;10528:140::o;32611:27::-;;;-1:-1:-1;;;32611:27:0;;;;;:::o;9717:79::-;9755:7;9782:6;;;;-1:-1:-1;;;;;9782:6:0;;9717:79::o;10083:94::-;10123:4;10163:6;;;;;-1:-1:-1;;;;;10163:6:0;10147:12;:10;:12::i;:::-;-1:-1:-1;;;;;10147:22:0;;10140:29;;10083:94;:::o;47169:238::-;9929:9;:7;:9::i;:::-;9921:54;;;;;-1:-1:-1;;;9921:54:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;9921:54:0;;;;;;;;;;;;;;;47305:5;47289:13;:21;;;47245:119;;;;;-1:-1:-1;;;47245:119:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;47375:8;:24;;;;;;-1:-1:-1;;;47375:24:0;-1:-1:-1;;;;47375:24:0;;;;;;;;;47169:238::o;39044:793::-;39373:7;33473;;-1:-1:-1;;;33473:7:0;;;;33469:102;;;33497:28;;;-1:-1:-1;;;33497:28:0;;;;;;;;;;;;-1:-1:-1;;;33497:28:0;;;;;;;;;;;;;;33469:102;39412:208;;;-1:-1:-1;;;39412:208:0;;39469:10;39412:208;;;;39502:4;39412:208;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;39412:42:0;;;;;:208;;;;;-1:-1:-1;;39412:208:0;;;;;;;-1:-1:-1;39412:42:0;:208;;;5:2:-1;;;;30:1;27;20:12;5:2;39412:208:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;39412:208:0;;;;39655:163;39680:23;39722:19;39760:11;39790:13;39655:6;:163::i;:::-;39633:196;39044:793;-1:-1:-1;;;;;;;;;;39044:793:0:o;38409:627::-;38674:15;33473:7;;38674:15;;-1:-1:-1;;;33473:7:0;;;;33469:102;;;33497:28;;;-1:-1:-1;;;33497:28:0;;;;;;;;;;;;-1:-1:-1;;;33497:28:0;;;;;;;;;;;;;;33469:102;38738:208;;;-1:-1:-1;;;38738:208:0;;38795:10;38738:208;;;;38828:4;38738:208;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;38738:42:0;;;;;:208;;;;;-1:-1:-1;;38738:208:0;;;;;;;-1:-1:-1;38738:42:0;:208;;;5:2:-1;;;;30:1;27;20:12;5:2;38738:208:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;38738:208:0;;;;38978:50;38995:19;39016:11;38978:16;:50::i;:::-;38957:71;;;;-1:-1:-1;38409:627:0;-1:-1:-1;;;;;;;;38409:627:0:o;33862:1632::-;34019:15;19568:11;;34019:15;;19568:11;;19560:55;;;;;-1:-1:-1;;;19560:55:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;19707:5;19693:19;;-1:-1:-1;;19693:19:0;;;;;-1:-1:-1;;;33473:7:0;;19693:19;33473:7;33469:102;;;33497:28;;;-1:-1:-1;;;33497:28:0;;;;;;;;;;;;-1:-1:-1;;;33497:28:0;;;;;;;;;;;;;;33469:102;34106:19;-1:-1:-1;;;;;34147:27:0;;34139:70;;;;;-1:-1:-1;;;34139:70:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;34246:14;34263:4;-1:-1:-1;;;;;34263:11:0;;:13;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;34263:13:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;34263:13:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;34263:13:0;34304;;;-1:-1:-1;;;34304:13:0;;;;34263;;-1:-1:-1;34287:14:0;;-1:-1:-1;;;;;34304:11:0;;;;;:13;;;;;34263;;34304;;;;;;;:11;:13;;;5:2:-1;;;;30:1;27;20:12;5:2;34304:13:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;34304:13:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;34304:13:0;;-1:-1:-1;34330:134:0;-1:-1:-1;;;;;34330:44:0;;34389:10;34422:4;34442:11;34330:134;:44;:134;:::i;:::-;34477:23;34503:88;34535:19;34569:11;34503:17;:88::i;:::-;34477:114;;34604:146;-1:-1:-1;;;;;;;;;;;34697:42:0;34710:11;34723:15;34697:12;:42::i;34604:146::-;-1:-1:-1;;;;;34767:26:0;;-1:-1:-1;;;;;;;;;;;34767:26:0;;:56;;-1:-1:-1;;;;;;34797:26:0;;-1:-1:-1;;;;;;;;;;;34797:26:0;34767:56;34763:724;;;34840:14;-1:-1:-1;;;;;34857:26:0;;-1:-1:-1;;;;;;;;;;;34857:26:0;:44;;34895:6;34857:44;;;34886:6;34857:44;34840:61;-1:-1:-1;;;;;;;;;;;;34937:34:0;34840:61;35015:42;35028:11;35041:15;35015:12;:42::i;:::-;34937:231;;;-1:-1:-1;;;;;;34937:231:0;;;;;;;-1:-1:-1;;;;;34937:231:0;;;;;;;;;;;;;;35076:1;34937:231;;;;;;;;;;35116:10;34937:231;;;;-1:-1:-1;;;34937:231:0;;;;;;;;;;;;;;;;-1:-1:-1;34937:231:0;;;;5:2:-1;;;;30:1;27;20:12;5:2;34937:231:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;34937:231:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;34937:231:0;;;;;;;;;-1:-1:-1;34937:231:0;-1:-1:-1;34763:724:0;;-1:-1:-1;34763:724:0;;-1:-1:-1;;;;;;;;;;;35222:31:0;35272:6;35297;35322:42;35335:11;35348:15;35322:12;:42::i;:::-;35222:253;;;-1:-1:-1;;;;;;35222:253:0;;;;;;;-1:-1:-1;;;;;35222:253:0;;;;;;;;;;;;;;;;;;;35383:1;35222:253;;;;;;;;;;35423:10;35222:253;;;;-1:-1:-1;;;35222:253:0;;;;;;;;;;;;;;;;;-1:-1:-1;35222:253:0;;;;5:2:-1;;;;30:1;27;20:12;5:2;35222:253:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;35222:253:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;35222:253:0;;;;;;;;;-1:-1:-1;35222:253:0;-1:-1:-1;34763:724:0;33558:1;;;;19873:11;:18;;-1:-1:-1;;19873:18:0;19887:4;19873:18;;;33862:1632;;;;-1:-1:-1;33862:1632:0;-1:-1:-1;33862:1632:0:o;44420:1677::-;44529:4;-1:-1:-1;;;;;44573:24:0;;;;;:50;;-1:-1:-1;;;;;;44601:22:0;;;;44573:50;44551:123;;;;;-1:-1:-1;;;44551:123:0;;;;;;;;;;;;-1:-1:-1;;;44551:123:0;;;;;;;;;;;;;;;44705:8;-1:-1:-1;;;;;44691:22:0;:10;-1:-1:-1;;;;;44691:22:0;;44687:39;;;-1:-1:-1;44722:4:0;44715:11;;44687:39;-1:-1:-1;;;;;44743:24:0;;;;:58;;-1:-1:-1;;;;;;44771:30:0;;-1:-1:-1;;;;;;;;;;;44771:30:0;44743:58;44739:1328;;;-1:-1:-1;;;;;44822:28:0;;-1:-1:-1;;;;;;;;;;;44822:28:0;;:54;;-1:-1:-1;;;;;;44854:22:0;;;44822:54;44818:88;;;-1:-1:-1;44902:4:0;44895:11;;44818:88;44976:59;;;-1:-1:-1;;;44976:59:0;;-1:-1:-1;;;;;44976:59:0;;;;;;-1:-1:-1;;;;;;;;;;;44976:59:0;;;;;;44921:19;;33137:42;;44976:31;;:59;;;;;;;;;;;;;;;33137:42;44976:59;;;5:2:-1;;;;30:1;27;20:12;5:2;44976:59:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;44976:59:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;44976:59:0;;-1:-1:-1;45069:18:0;44976:59;45069:12;:18::i;:::-;45065:35;;;45096:4;45089:11;;;;;45065:35;44739:1328;;;;-1:-1:-1;;;;;45122:22:0;;;;:54;;-1:-1:-1;;;;;;45148:28:0;;-1:-1:-1;;;;;;;;;;;45148:28:0;45122:54;45118:949;;;-1:-1:-1;;;;;45197:30:0;;-1:-1:-1;;;;;;;;;;;45197:30:0;;:58;;-1:-1:-1;;;;;;45231:24:0;;;45197:58;45193:92;;;-1:-1:-1;45281:4:0;45274:11;;45193:92;45355:61;;;-1:-1:-1;;;45355:61:0;;-1:-1:-1;;;;;45355:61:0;;;;;;-1:-1:-1;;;;;;;;;;;45355:61:0;;;;;;45300:19;;33137:42;;45355:31;;:61;;;;;;;;;;;;;;;33137:42;45355:61;;;5:2:-1;;;;30:1;27;20:12;45118:949:0;45570:61;;;-1:-1:-1;;;45570:61:0;;-1:-1:-1;;;;;45570:61:0;;;;;;-1:-1:-1;;;;;;;;;;;45570:61:0;;;;;;45514:20;;33137:42;;45570:31;;:61;;;;;;;;;;;;;;;33137:42;45570:61;;;5:2:-1;;;;30:1;27;20:12;5:2;45570:61:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;45570:61:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;45570:61:0;45717:59;;;-1:-1:-1;;;45717:59:0;;-1:-1:-1;;;;;45717:59:0;;;;;;-1:-1:-1;;;;;;;;;;;45717:59:0;;;;;;45570:61;;-1:-1:-1;45661:20:0;;33137:42;;45717:31;;:59;;;;;45570:61;;45717:59;;;;;;;33137:42;45717:59;;;5:2:-1;;;;30:1;27;20:12;5:2;45717:59:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;45717:59:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;45717:59:0;45862:53;;;-1:-1:-1;;;45862:53:0;;-1:-1:-1;;;;;45862:53:0;;;;;;;;;;;;;;;45717:59;;-1:-1:-1;45806:20:0;;33137:42;;45862:31;;:53;;;;;45717:59;;45862:53;;;;;;;33137:42;45862:53;;;5:2:-1;;;;30:1;27;20:12;5:2;45862:53:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;45862:53:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;45862:53:0;;-1:-1:-1;45949:19:0;45962:5;45949:12;:19::i;:::-;:42;;;;;45972:19;45985:5;45972:12;:19::i;:::-;45945:59;;;46000:4;45993:11;;;;;;;45945:59;46023:19;46036:5;46023:12;:19::i;:::-;46019:36;;;46051:4;46044:11;;;;;;;46019:36;45118:949;;;;-1:-1:-1;46084:5:0;44420:1677;;;;;:::o;10823:109::-;9929:9;:7;:9::i;:::-;9921:54;;;;;-1:-1:-1;;;9921:54:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;9921:54:0;;;;;;;;;;;;;;;10896:28;10915:8;10896:18;:28::i;:::-;10823:109;:::o;15942:159::-;16084:7;15942:159;;;;:::o;20808:284::-;21005:68;;;-1:-1:-1;;;;;21005:68:0;;;;;;;;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;21005:68:0;;;;;;;;25:18:-1;;61:17;;-1:-1;;;;;182:15;-1:-1;;;179:29;160:49;;20952:132:0;;20985:5;;20952:18;:132::i;:::-;20808:284;;;;:::o;46689:472::-;46812:23;46852:8;;-1:-1:-1;;;46852:8:0;;;;46848:54;;-1:-1:-1;46889:1:0;46882:8;;46848:54;46986:8;;46932:94;;46959:36;;46972:12;;-1:-1:-1;;;46986:8:0;;;;46959:12;:36::i;:::-;47010:5;46932:12;:94::i;:::-;46914:112;-1:-1:-1;47039:114:0;-1:-1:-1;;;;;47039:42:0;;32727;46914:112;47039:114;:42;:114;:::i;3298:136::-;3356:7;3383:43;3387:1;3390;3383:43;;;;;;;;;;;;;;;;;:3;:43::i;:::-;3376:50;3298:136;-1:-1:-1;;;3298:136:0:o;21100:706::-;21518:10;;;21517:62;;-1:-1:-1;21534:39:0;;;-1:-1:-1;;;21534:39:0;;21558:4;21534:39;;;;-1:-1:-1;;;;;21534:39:0;;;;;;;;;:15;;;;;;:39;;;;;;;;;;;;;;;:15;:39;;;5:2:-1;;;;30:1;27;20:12;5:2;21534:39:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;21534:39:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;21534:39:0;:44;21517:62;21495:166;;;;-1:-1:-1;;;21495:166:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;21725:62;;;-1:-1:-1;;;;;21725:62:0;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;21725:62:0;;;;;;;;25:18:-1;;61:17;;-1:-1;;;;;182:15;-1:-1;;;179:29;160:49;;21672:126:0;;21705:5;;21672:18;:126::i;39937:2480::-;40063:7;-1:-1:-1;;;;;40105:24:0;;;;;:50;;-1:-1:-1;;;;;;40133:22:0;;;;40105:50;40083:123;;;;;-1:-1:-1;;;40083:123:0;;;;;;;;;;;;-1:-1:-1;;;40083:123:0;;;;;;;;;;;;;;;40235:8;-1:-1:-1;;;;;40221:22:0;:10;-1:-1:-1;;;;;40221:22:0;;40217:41;;;-1:-1:-1;40252:6:0;40245:13;;40217:41;40279:35;40293:10;40305:8;40279:13;:35::i;:::-;40271:67;;;;;-1:-1:-1;;;40271:67:0;;;;;;;;;;;;-1:-1:-1;;;40271:67:0;;;;;;;;;;;;;;;40366:1;40357:6;:10;40349:37;;;;;-1:-1:-1;;;40349:37:0;;;;;;;;;;;;-1:-1:-1;;;40349:37:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;40403:24:0;;40399:2011;;-1:-1:-1;;;;;40448:28:0;;-1:-1:-1;;;;;;;;;;;40448:28:0;40444:148;;;-1:-1:-1;;;;;;;;;;;;;;;;40497:31:0;;40535:6;40497:47;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;40497:47:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;40497:47:0;;;;;40570:6;40563:13;;;;40444:148;40630:16;;;40644:1;40630:16;;;40606:21;40630:16;;;;;40606:21;40630:16;;;;;105:10:-1;40630:16:0;88:34:-1;136:17;;-1:-1;40630:16:0;40606:40;;-1:-1:-1;;;;;;;;;;;40661:4:0;40666:1;40661:7;;;;;;;;;;;;;:26;-1:-1:-1;;;;;40661:26:0;;;-1:-1:-1;;;;;40661:26:0;;;;;40712:8;40702:4;40707:1;40702:7;;;;;;;;-1:-1:-1;;;;;40702:18:0;;;:7;;;;;;;;;;:18;40755:43;;;-1:-1:-1;;;40755:43:0;;;;;;;;;;;;;;;;;;;;;;40735:17;;-1:-1:-1;;;;;;;;;;;32981:42:0;40755:29;;40785:6;;40793:4;;40755:43;;;;;;;;;;;;;;;40735:17;8:100:-1;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;40755:43:0;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;40755:43:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;40755:43:0;;;;;;39:16:-1;36:1;17:17;2:54;101:4;40755:43:0;80:15:-1;;;-1:-1;;76:31;65:43;;120:4;113:20;13:2;5:11;;2:2;;;29:1;26;19:12;2:2;40755:43:0;;;;;;;;;;;;;-1:-1:-1;;;14:3;11:20;8:2;;;44:1;41;34:12;8:2;62:21;;;;123:4;114:14;;138:31;;;135:2;;;182:1;179;172:12;135:2;219:3;213:10;331:9;325:2;311:12;307:21;289:16;285:44;282:59;-1:-1;;;247:12;244:29;233:116;230:2;;;362:1;359;352:12;230:2;373:25;;-1:-1;40755:43:0;;421:4:-1;412:14;;;;40755:43:0;;;;;412:14:-1;40755:43:0;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;40755:43:0;;;;;;;;;;;40799:1;40755:46;;;;;;;;;;;;;;40735:66;;40828:119;40859:49;40872:9;40883:24;40896:5;40903:3;40883:12;:24::i;:::-;40859:12;:49::i;40828:119::-;40989:129;;-1:-1:-1;;;40989:129:0;;;;;;;;41102:4;40989:129;;;;;;-1:-1:-1;;;40989:129:0;;;;;;;;;;;;;;;;;;;;;40816:131;;-1:-1:-1;40962:24:0;;-1:-1:-1;;;;;;;;;;;32981:42:0;40989:55;;41069:6;;40816:131;;41088:4;;41102;;32823:66;;40989:129;;;;;;;;;;;;-1:-1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;40989:129:0;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;40989:129:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;40989:129:0;;;;;;;39:16:-1;36:1;17:17;2:54;101:4;40989:129:0;80:15:-1;;;-1:-1;;76:31;65:43;;120:4;113:20;13:2;5:11;;2:2;;;29:1;26;19:12;2:2;40989:129:0;;;;;;;;;;;;;-1:-1:-1;;;14:3;11:20;8:2;;;44:1;41;34:12;8:2;62:21;;;;123:4;114:14;;138:31;;;135:2;;;182:1;179;172:12;135:2;219:3;213:10;331:9;325:2;311:12;307:21;289:16;285:44;282:59;-1:-1;;;247:12;244:29;233:116;230:2;;;362:1;359;352:12;230:2;373:25;;-1:-1;40989:129:0;;421:4:-1;412:14;;;;40989:129:0;;;;;412:14:-1;40989:129:0;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;40989:129:0;;;;;;;;;;;40962:156;;41140:7;41148:1;41140:10;;;;;;;;;;;;;;41133:17;;;;;;;40399:2011;-1:-1:-1;;;;;41172:22:0;;41168:1242;;-1:-1:-1;;;;;41215:30:0;;-1:-1:-1;;;;;;;;;;;41215:30:0;41211:143;;;-1:-1:-1;;;;;;;;;;;;;;;;41266:32:0;;41299:6;41266:40;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;41266:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;41266:40:0;;;;41332:6;41325:13;;;;41211:143;41392:16;;;41406:1;41392:16;;;41368:21;41392:16;;;;;41368:21;41392:16;;;;;105:10:-1;41392:16:0;88:34:-1;136:17;;-1:-1;;41368:40:0;-1:-1:-1;41423:64:0;-1:-1:-1;;;;;41423:30:0;;-1:-1:-1;;;;;;;;;;;41480:6:0;41423:64;:30;:64;:::i;:::-;41512:10;41502:4;41507:1;41502:7;;;;;;;;;;;;;:20;-1:-1:-1;;;;;41502:20:0;;;-1:-1:-1;;;;;41502:20:0;;;;;-1:-1:-1;;;;;;;;;;;41537:4:0;41542:1;41537:7;;;;;;;;-1:-1:-1;;;;;41537:26:0;;;:7;;;;;;;;;;:26;41598:43;;;-1:-1:-1;;;41598:43:0;;;;;;;;;;;;;;;;;;;;;;41578:17;;-1:-1:-1;;;;;;;;;;;32981:42:0;41598:29;;41628:6;;41636:4;;41598:43;;;;;;;;;;;;;;;41578:17;8:100:-1;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;41598:43:0;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;41598:43:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;41598:43:0;;;;;;39:16:-1;36:1;17:17;2:54;101:4;41598:43:0;80:15:-1;;;-1:-1;;76:31;65:43;;120:4;113:20;13:2;5:11;;2:2;;;29:1;26;19:12;2:2;41598:43:0;;;;;;;;;;;;;-1:-1:-1;;;14:3;11:20;8:2;;;44:1;41;34:12;8:2;62:21;;;;123:4;114:14;;138:31;;;135:2;;;182:1;179;172:12;135:2;219:3;213:10;331:9;325:2;311:12;307:21;289:16;285:44;282:59;-1:-1;;;247:12;244:29;233:116;230:2;;;362:1;359;352:12;230:2;373:25;;-1:-1;41598:43:0;;421:4:-1;412:14;;;;41598:43:0;;;;;412:14:-1;41598:43:0;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;41598:43:0;;;;;;;;;;;41642:1;41598:46;;;;;;;;;;;;;;41578:66;;41671:119;41702:49;41715:9;41726:24;41739:5;41746:3;41726:12;:24::i;41671:119::-;41659:131;;41805:24;-1:-1:-1;;;;;;;;;;;;;;;;41832:37:0;;41888:6;41913:9;41941:4;41972;-1:-1:-1;;;41832:187:0;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;41832:187:0;-1:-1:-1;;;;;41832:187:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;41832:187:0;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;41832:187:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;41832:187:0;;;;;;39:16:-1;36:1;17:17;2:54;101:4;41832:187:0;80:15:-1;;;-1:-1;;76:31;65:43;;120:4;113:20;13:2;5:11;;2:2;;;29:1;26;19:12;41168:1242:0;42084:64;-1:-1:-1;;;;;42084:30:0;;-1:-1:-1;;;;;;;;;;;42141:6:0;42084:64;:30;:64;:::i;:::-;42163:22;42188:115;42226:10;42255:8;42282:6;42188:19;:115::i;:::-;42163:140;;42343:1;42326:14;:18;42318:44;;;;;-1:-1:-1;;;42318:44:0;;;;;;;;;;;;-1:-1:-1;;;42318:44:0;;;;;;;;;;;;;;;42384:14;39937:2480;-1:-1:-1;;;;39937:2480:0:o;2842:181::-;2900:7;2932:5;;;2956:6;;;;2948:46;;;;;-1:-1:-1;;;2948:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;20553:247;20723:58;;;-1:-1:-1;;;;;20723:58:0;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;20723:58:0;;;;;;;;25:18:-1;;61:17;;-1:-1;;;;;182:15;-1:-1;;;179:29;160:49;;20670:122:0;;20703:5;;20670:18;:122::i;8399:98::-;8479:10;8399:98;:::o;46171:237::-;46237:4;-1:-1:-1;;;;;46258:27:0;;;46254:147;;46302:19;46324:4;-1:-1:-1;;;;;46324:16:0;;:18;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;46324:18:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;46324:18:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;46324:18:0;;-1:-1:-1;46361:15:0;;46357:32;;46385:4;46378:11;;;;;46357:32;46254:147;46171:237;;;:::o;11038:266::-;-1:-1:-1;;;;;11126:22:0;;11104:110;;;;-1:-1:-1;;;11104:110:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;11251:6;;;11230:38;;-1:-1:-1;;;;;11230:38:0;;;;11251:6;;;;;;11230:38;;;11279:6;:17;;-1:-1:-1;;;;;11279:17:0;;;;;-1:-1:-1;;;;;;11279:17:0;;;;;;;;;11038:266::o;23163:1176::-;23767:27;23775:5;-1:-1:-1;;;;;23767:25:0;;:27::i;:::-;23759:71;;;;;-1:-1:-1;;;23759:71:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;23904:12;23918:23;23953:5;-1:-1:-1;;;;;23945:19:0;23965:4;23945:25;;;;;;;;;;;;;36:153:-1;66:2;61:3;58:11;36:153;;176:10;;164:23;;-1:-1;;139:12;;;;98:2;89:12;;;;114;36:153;;;274:1;267:3;263:2;259:12;254:3;250:22;246:30;315:4;311:9;305:3;299:10;295:26;356:4;350:3;344:10;340:21;389:7;380;377:20;372:3;365:33;3:399;;;23945:25:0;;;;;;;;;;;;;;;;;;;;;;;;14:1:-1;21;16:31;;;;75:4;69:11;64:16;;144:4;140:9;133:4;115:16;111:27;107:43;104:1;100:51;94:4;87:65;169:16;166:1;159:27;225:16;222:1;215:4;212:1;208:12;193:49;7:242;;16:31;36:4;31:9;;7:242;;23903:67:0;;;;23989:7;23981:52;;;;;-1:-1:-1;;;23981:52:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;24050:17;;:21;24046:286;;24223:10;24212:30;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;24212:30:0;24186:134;;;;-1:-1:-1;;;24186:134:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4248:471;4306:7;4551:6;4547:47;;-1:-1:-1;4581:1:0;4574:8;;4547:47;4618:5;;;4622:1;4618;:5;:1;4642:5;;;;;:10;4634:56;;;;-1:-1:-1;;;4634:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5187:132;5245:7;5272:39;5276:1;5279;5272:39;;;;;;;;;;;;;;;;;:3;:39::i;3771:226::-;3891:7;3927:12;3919:6;;;;3911:29;;;;-1:-1:-1;;;3911:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;3911:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;3963:5:0;;;3771:226::o;42459:1953::-;42666:61;;;-1:-1:-1;;;42666:61:0;;-1:-1:-1;;;;;42666:61:0;;;;;;-1:-1:-1;;;;;;;;;;;42666:61:0;;;;;;42594:7;;;;33137:42;;42666:31;;:61;;;;;;;;;;;;;;33137:42;42666:61;;;5:2:-1;;;;30:1;27;20:12;5:2;42666:61:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;42666:61:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;42666:61:0;42801:59;;;-1:-1:-1;;;42801:59:0;;-1:-1:-1;;;;;42801:59:0;;;;;;-1:-1:-1;;;;;;;;;;;42801:59:0;;;;;;42666:61;;-1:-1:-1;42749:20:0;;33137:42;;42801:31;;:59;;;;;42666:61;;42801:59;;;;;;;33137:42;42801:59;;;5:2:-1;;;;30:1;27;20:12;5:2;42801:59:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;42801:59:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;42801:59:0;42934:53;;;-1:-1:-1;;;42934:53:0;;-1:-1:-1;;;;;42934:53:0;;;;;;;;;;;;;;;42801:59;;-1:-1:-1;42882:20:0;;33137:42;;42934:31;;:53;;;;;42801:59;;42934:53;;;;;;;33137:42;42934:53;;;5:2:-1;;;;30:1;27;20:12;5:2;42934:53:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;42934:53:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;42934:53:0;;-1:-1:-1;43011:24:0;43052:19;42934:53;43052:12;:19::i;:::-;43048:1338;;;43112:16;;;43126:1;43112:16;;;43088:21;43112:16;;;;;43088:21;43112:16;;;;;105:10:-1;43112:16:0;88:34:-1;136:17;;-1:-1;43112:16:0;43088:40;;43153:10;43143:4;43148:1;43143:7;;;;;;;;;;;;;:20;-1:-1:-1;;;;;43143:20:0;;;-1:-1:-1;;;;;43143:20:0;;;;;43188:8;43178:4;43183:1;43178:7;;;;;;;;-1:-1:-1;;;;;43178:18:0;;;:7;;;;;;;;;;:18;43231:43;;;-1:-1:-1;;;43231:43:0;;;;;;;;;;;;;;;;;;;;;;43211:17;;-1:-1:-1;;;;;;;;;;;32981:42:0;43231:29;;43261:6;;43269:4;;43231:43;;;;;;;;;;;;;;;43211:17;8:100:-1;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;43231:43:0;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;43231:43:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;43231:43:0;;;;;;39:16:-1;36:1;17:17;2:54;101:4;43231:43:0;80:15:-1;;;-1:-1;;76:31;65:43;;120:4;113:20;13:2;5:11;;2:2;;;29:1;26;19:12;2:2;43231:43:0;;;;;;;;;;;;;-1:-1:-1;;;14:3;11:20;8:2;;;44:1;41;34:12;8:2;62:21;;;;123:4;114:14;;138:31;;;135:2;;;182:1;179;172:12;135:2;219:3;213:10;331:9;325:2;311:12;307:21;289:16;285:44;282:59;-1:-1;;;247:12;244:29;233:116;230:2;;;362:1;359;352:12;230:2;373:25;;-1:-1;43231:43:0;;421:4:-1;412:14;;;;43231:43:0;;;;;412:14:-1;43231:43:0;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;43231:43:0;;;;;;;;;;;43275:1;43231:46;;;;;;;;;;;;;;43211:66;;43304:119;43335:49;43348:9;43359:24;43372:5;43379:3;43359:12;:24::i;43304:119::-;43292:131;;-1:-1:-1;;;;;;;;;;;;;;;;43448:40:0;;43507:6;43532:9;43560:4;43591;-1:-1:-1;;;43448:190:0;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;43448:190:0;-1:-1:-1;;;;;43448:190:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;43448:190:0;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;43448:190:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;43448:190:0;;;;;;39:16:-1;36:1;17:17;2:54;101:4;43448:190:0;80:15:-1;;;-1:-1;;76:31;65:43;;120:4;113:20;13:2;5:11;;2:2;;;29:1;26;19:12;2:2;43448:190:0;;;;;;;;;;;;;-1:-1:-1;;;14:3;11:20;8:2;;;44:1;41;34:12;8:2;62:21;;;;123:4;114:14;;138:31;;;135:2;;;182:1;179;172:12;135:2;219:3;213:10;331:9;325:2;311:12;307:21;289:16;285:44;282:59;-1:-1;;;247:12;244:29;233:116;230:2;;;362:1;359;352:12;230:2;373:25;;-1:-1;43448:190:0;;421:4:-1;412:14;;;;43448:190:0;;;;;412:14:-1;43448:190:0;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;43448:190:0;;;;;;;;;;;43438:200;;43660:7;43668:1;43660:10;;;;;;;;;;;;;;43653:17;;;;;;;;;;43048:1338;43692:19;43705:5;43692:12;:19::i;:::-;:42;;;;;43715:19;43728:5;43715:12;:19::i;:::-;43688:698;;;43775:16;;;43789:1;43775:16;;;;;;;;;43751:21;;43775:16;;;43751:21;;105:10:-1;43775:16:0;88:34:-1;136:17;;-1:-1;43775:16:0;43751:40;;43816:10;43806:4;43811:1;43806:7;;;;;;;;;;;;;:20;-1:-1:-1;;;;;43806:20:0;;;-1:-1:-1;;;;;43806:20:0;;;;;-1:-1:-1;;;;;;;;;;;43841:4:0;43846:1;43841:7;;;;;;;;;;;;;:26;-1:-1:-1;;;;;43841:26:0;;;-1:-1:-1;;;;;43841:26:0;;;;;43892:8;43882:4;43887:1;43882:7;;;;;;;;-1:-1:-1;;;;;43882:18:0;;;:7;;;;;;;;;;:18;43935:43;;;-1:-1:-1;;;43935:43:0;;;;;;;;;;;;;;;;;;;;;;43915:17;;-1:-1:-1;;;;;;;;;;;32981:42:0;43935:29;;43965:6;;43973:4;;43935:43;;;;;;;;;;;;;;;43915:17;8:100:-1;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;43935:43:0;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;43935:43:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;43935:43:0;;;;;;39:16:-1;36:1;17:17;2:54;101:4;43935:43:0;80:15:-1;;;-1:-1;;76:31;65:43;;120:4;113:20;13:2;5:11;;2:2;;;29:1;26;19:12;2:2;43935:43:0;;;;;;;;;;;;;-1:-1:-1;;;14:3;11:20;8:2;;;44:1;41;34:12;8:2;62:21;;;;123:4;114:14;;138:31;;;135:2;;;182:1;179;172:12;135:2;219:3;213:10;331:9;325:2;311:12;307:21;289:16;285:44;282:59;-1:-1;;;247:12;244:29;233:116;230:2;;;362:1;359;352:12;230:2;373:25;;-1:-1;43935:43:0;;421:4:-1;412:14;;;;43935:43:0;;;;;412:14:-1;43935:43:0;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;43935:43:0;;;;;;;;;;;43979:1;43935:46;;;;;;;;;;;;;;43915:66;;44008:119;44039:49;44052:9;44063:24;44076:5;44083:3;44063:12;:24::i;44008:119::-;43996:131;;-1:-1:-1;;;;;;;;;;;;;;;;44152:40:0;;44211:6;44236:9;44264:4;44295;-1:-1:-1;;;44152:190:0;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;44152:190:0;-1:-1:-1;;;;;44152:190:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;44152:190:0;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;44152:190:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;44152:190:0;;;;;;39:16:-1;36:1;17:17;2:54;101:4;44152:190:0;80:15:-1;;;-1:-1;;76:31;65:43;;120:4;113:20;13:2;5:11;;2:2;;;29:1;26;19:12;2:2;44152:190:0;;;;;;;;;;;;;-1:-1:-1;;;14:3;11:20;8:2;;;44:1;41;34:12;8:2;62:21;;;;123:4;114:14;;138:31;;;135:2;;;182:1;179;172:12;135:2;219:3;213:10;331:9;325:2;311:12;307:21;289:16;285:44;282:59;-1:-1;;;247:12;244:29;233:116;230:2;;;362:1;359;352:12;230:2;373:25;;-1:-1;44152:190:0;;421:4:-1;412:14;;;;44152:190:0;;;;;412:14:-1;44152:190:0;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;44152:190:0;;;;;;;;;;;44142:200;;44364:7;44372:1;44364:10;;;;;;;43688:698;-1:-1:-1;44403:1:0;;42459:1953;-1:-1:-1;;;;;;;42459:1953:0:o;15066:659::-;15126:4;15625:20;;15455:66;15674:23;;;;;;:42;;-1:-1:-1;;15701:15:0;;;15666:51;-1:-1:-1;;15066:659:0:o;5849:379::-;5969:7;6071:12;6064:5;6056:28;;;;-1:-1:-1;;;6056:28:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27:10:-1;;8:100;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;6056:28:0;;6095:9;6111:1;6107;:5;;;;;;;5849:379;-1:-1:-1;;;;;5849:379:0:o

Swarm Source

bzzr://f231ede41067ad37f3706d355e11574bd0f85e73c376bfa5d12fa07114b70343
Block Transaction Difficulty Gas Used Reward
Block Uncle Number Difficulty Gas Used Reward
Loading
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.