Create utility method to generate .torrent-files
Change-Id: Ib8aa32f178399c020ecfeab4f905933889dadb19
Refs: #3432
diff --git a/src/torrent-file.cpp b/src/torrent-file.cpp
index a9797fd..2b8fd15 100644
--- a/src/torrent-file.cpp
+++ b/src/torrent-file.cpp
@@ -21,9 +21,16 @@
#include "torrent-file.hpp"
+#include <ndn-cxx/security/key-chain.hpp>
+#include <ndn-cxx/security/signing-helpers.hpp>
+
#include <algorithm>
#include <boost/range/adaptors.hpp>
+#include <boost/filesystem.hpp>
+#include <boost/filesystem/fstream.hpp>
+
+namespace fs = boost::filesystem;
namespace ndn {
@@ -59,18 +66,6 @@
this->wireDecode(block);
}
-const Name&
-TorrentFile::getName() const
-{
- return Data::getName();
-}
-
-const Name&
-TorrentFile::getCommonPrefix() const
-{
- return m_commonPrefix;
-}
-
void
TorrentFile::createSuffixCatalog()
{
@@ -186,14 +181,14 @@
// Check whether there is a TorrentFilePtr
auto element = content.elements_begin();
if (content.elements_end() == element) {
- BOOST_THROW_EXCEPTION(Error(".Torrent-file with empty content"));
+ BOOST_THROW_EXCEPTION(Error("Torrent-file with empty content"));
}
element->parse();
Name name(*element);
if (name.empty())
- BOOST_THROW_EXCEPTION(Error("Empty name included in the .torrent-file"));
+ BOOST_THROW_EXCEPTION(Error("Empty name included in the torrent-file"));
- if (name.get(name.size() - 3) == name::Component(".torrent-file")) {
+ if (name.get(name.size() - 3) == name::Component("torrent-file")) {
m_torrentFilePtr = name;
++element;
m_commonPrefix = Name(*element);
@@ -209,11 +204,11 @@
element->parse();
Name fileManifestSuffix(*element);
if (fileManifestSuffix.empty())
- BOOST_THROW_EXCEPTION(Error("Empty manifest file name included in the .torrent-file"));
+ BOOST_THROW_EXCEPTION(Error("Empty manifest file name included in the torrent-file"));
this->insertToSuffixCatalog(fileManifestSuffix);
}
if (m_suffixCatalog.size() == 0) {
- BOOST_THROW_EXCEPTION(Error(".Torrent-file with empty catalog of file manifest names"));
+ BOOST_THROW_EXCEPTION(Error("Torrent-file with empty catalog of file manifest names"));
}
}
@@ -235,6 +230,74 @@
m_suffixCatalog.clear();
}
+std::pair<std::vector<TorrentFile>,
+ std::vector<std::pair<std::vector<FileManifest>,
+ std::vector<Data>>>>
+TorrentFile::generate(const std::string& directoryPath,
+ size_t namesPerSegment,
+ size_t subManifestSize,
+ size_t dataPacketSize,
+ bool returnData)
+{
+ BOOST_ASSERT(0 < namesPerSegment);
+
+ std::vector<TorrentFile> torrentSegments;
+
+ fs::path path(directoryPath);
+ if (!fs::exists(path)) {
+ BOOST_THROW_EXCEPTION(Error(directoryPath + ": no such directory."));
+ }
+
+ Name directoryPathName(directoryPath);
+ fs::recursive_directory_iterator directoryPtr(fs::system_complete(directoryPath).string());
+
+ Name commonPrefix("/NTORRENT" +
+ directoryPathName.getSubName(directoryPathName.size() - 1).toUri());
+
+ Name torrentName(commonPrefix.toUri() + "/torrent-file");
+ TorrentFile currentTorrentFile(torrentName, commonPrefix, {});
+ std::vector<std::pair<std::vector<FileManifest>, std::vector<Data>>> manifestPairs;
+
+ size_t manifestFileCounter = 0u;
+ for (fs::recursive_directory_iterator i = directoryPtr;
+ i != fs::recursive_directory_iterator();
+ ++i) {
+ Name manifestPrefix("/NTORRENT" +
+ directoryPathName.getSubName(directoryPathName.size() - 1).toUri());
+ std::pair<std::vector<FileManifest>, std::vector<Data>> currentManifestPair =
+ FileManifest::generate((*i).path().string(),
+ manifestPrefix, subManifestSize,
+ dataPacketSize, returnData);
+
+ if (manifestFileCounter != 0 && 0 == manifestFileCounter % namesPerSegment) {
+ torrentSegments.push_back(currentTorrentFile);
+ Name currentTorrentName = torrentName;
+ currentTorrentName.appendSequenceNumber(static_cast<int>(manifestFileCounter));
+ currentTorrentFile = TorrentFile(currentTorrentName, commonPrefix, {});
+ }
+ currentTorrentFile.insert(currentManifestPair.first[0].getName());
+ currentManifestPair.first.shrink_to_fit();
+ currentManifestPair.second.shrink_to_fit();
+ manifestPairs.push_back(currentManifestPair);
+ ++manifestFileCounter;
+ }
+
+ // Sign and append the last torrent-file
+ security::KeyChain keyChain;
+ keyChain.sign(currentTorrentFile, signingWithSha256());
+ torrentSegments.push_back(currentTorrentFile);
+
+ for (auto it = torrentSegments.rbegin() + 1; it != torrentSegments.rend(); ++it) {
+ auto next = it - 1;
+ it->setTorrentFilePtr(next->getFullName());
+ keyChain.sign(*it, signingWithSha256());
+ }
+
+ torrentSegments.shrink_to_fit();
+ manifestPairs.shrink_to_fit();
+ return std::make_pair(torrentSegments, manifestPairs);
+}
+
} // namespace ntorrent
} // namespace ndn
diff --git a/src/torrent-file.hpp b/src/torrent-file.hpp
index ea095ac..98e222c 100644
--- a/src/torrent-file.hpp
+++ b/src/torrent-file.hpp
@@ -22,6 +22,8 @@
#ifndef TORRENT_FILE_HPP
#define TORRENT_FILE_HPP
+#include "file-manifest.hpp"
+
#include <ndn-cxx/name.hpp>
#include <ndn-cxx/encoding/block.hpp>
#include <ndn-cxx/data.hpp>
@@ -45,14 +47,14 @@
};
/**
- * @brief Create a new empty .TorrentFile.
+ * @brief Create a new empty TorrentFile.
*/
TorrentFile() = default;
/**
- * @brief Create a new .TorrentFile.
- * @param torrentFileName The name of the .torrent-file
- * @param torrentFilePtr A pointer (name) to the next segment of the .torrent-file
+ * @brief Create a new TorrentFile.
+ * @param torrentFileName The name of the torrent-file
+ * @param torrentFilePtr A pointer (name) to the next segment of the torrent-file
* @param commonPrefix The common name prefix of the manifest file names included in the catalog
* @param catalog The catalog containing the name of each file manifest
*/
@@ -62,8 +64,8 @@
const std::vector<ndn::Name>& catalog);
/**
- * @brief Create a new .TorrentFile.
- * @param torrentFileName The name of the .torrent-file
+ * @brief Create a new TorrentFile.
+ * @param torrentFileName The name of the torrent-file
* @param commonPrefix The common name prefix of the manifest file names included in the catalog
* @param catalog The catalog containing the name of each file manifest
*/
@@ -72,26 +74,26 @@
const std::vector<ndn::Name>& catalog);
/**
- * @brief Create a new .TorrentFile
- * @param block The block format of the .torrent-file
+ * @brief Create a new TorrentFile
+ * @param block The block format of the torrent-file
*/
explicit
TorrentFile(const Block& block);
/**
- * @brief Get the name of the .TorrentFile
+ * @brief Get the name of the TorrentFile
*/
const Name&
getName() const;
/**
- * @brief Get the common prefix of the file manifest names of this .torrent-file
+ * @brief Get the common prefix of the file manifest names of this torrent-file
*/
const Name&
getCommonPrefix() const;
/**
- * @brief Get a shared pointer to the name of the next segment of the .torrent-file.
+ * @brief Get a shared pointer to the name of the next segment of the torrent-file.
*
* If there is no next segment, it returns a nullptr
*/
@@ -111,10 +113,10 @@
wireDecode(const Block& wire);
/**
- * @brief Finalize .torrent-file before signing the data packet
+ * @brief Finalize torrent-file before signing the data packet
*
* This method has to be called (every time) right before signing or encoding
- * the .torrent-file
+ * the torrent-file
*/
void
finalize();
@@ -137,9 +139,33 @@
size_t
catalogSize() const;
+ /**
+ * @brief Given a directory path for the torrent file, it generates the torrent file
+ *
+ * @param directoryPath The path to the directory for which we are to create a torrent-file
+ * @param torrentFilePrefix The prefix to be used for the name of this torrent-file
+ * @param namesPerSegment The number of manifest names to be included in each segment of the
+ * torrent-file
+ * @param returnData Determines whether the data would be returned in memory or it will be
+ * stored on disk without being returned
+ *
+ * Generates the torrent-file for the directory at the specified 'directoryPath',
+ * splitting the torrent-file into multiple segments, each one of which contains
+ * at most 'namesPerSegment' number of manifest names
+ *
+ **/
+ static std::pair<std::vector<TorrentFile>,
+ std::vector<std::pair<std::vector<FileManifest>,
+ std::vector<Data>>>>
+ generate(const std::string& directoryPath,
+ size_t namesPerSegment,
+ size_t subManifestSize,
+ size_t dataPacketSize,
+ bool returnData = false);
+
protected:
/**
- * @brief prepend .torrent file as a Content block to the encoder
+ * @brief prepend torrent file as a Content block to the encoder
*/
template<encoding::Tag TAG>
size_t
@@ -153,7 +179,7 @@
private:
/**
- * @brief Check whether the .torrent-file has a pointer to the next segment
+ * @brief Check whether the torrent-file has a pointer to the next segment
*/
bool
hasTorrentFilePtr() const;
@@ -172,7 +198,7 @@
* @brief Construct the catalog of long names from a catalog of suffixes for the file
* manifests' name
*
- * After decoding a .torrent-file from its wire format, we construct the catalog of
+ * After decoding a torrent-file from its wire format, we construct the catalog of
* long names from the decoded common prefix and suffixes
*
*/
@@ -185,6 +211,12 @@
void
insertToSuffixCatalog(const PartialName& suffix);
+ /**
+ * @brief Set the pointer of the current torrent-file segment to the next segment
+ */
+ void
+ setTorrentFilePtr(const Name& ptrName);
+
private:
Name m_commonPrefix;
Name m_torrentFilePtr;
@@ -222,6 +254,25 @@
m_suffixCatalog.push_back(suffix);
}
+inline void
+TorrentFile::setTorrentFilePtr(const Name& ptrName)
+{
+ m_torrentFilePtr = ptrName;
+}
+
+inline const Name&
+TorrentFile::getName() const
+{
+ return Data::getName();
+}
+
+inline const Name&
+TorrentFile::getCommonPrefix() const
+{
+ return m_commonPrefix;
+}
+
+
} // namespace ntorrent
} // namespace ndn
diff --git a/tests/testdata/foo/bar2.txt b/tests/testdata/foo/bar2.txt
new file mode 100644
index 0000000..f913c4b
--- /dev/null
+++ b/tests/testdata/foo/bar2.txt
@@ -0,0 +1 @@
+1282 2710 7100 3622 7082 4629 3199 5120 6008 1060 2968 233 1564 3443 8071 1295 8836 4001 324 7654 2443 7562 7389 2292 891 1687 2966 5461 6359 5857 3166 4938 5630 4599 1711 3298 764 5177 5560 4463 611 6568 2835 2043 3632 716 659 794 7352 2673 3655 7261 4105 3844 3755 3382 1092 5860 3520 613 388 5255 758 4900 5392 4156 2333 1445 5348 8290 485 8601 7400 2198 4097 9063 5253 4878 10000 2500 6260 1916 8652 7484 532 2776 1844 6006 4531 5569 1187 2468 5475 8248 216 5293 5769 3059 1486 8057 6457 5414 8612 2128 3638 7967 2338 626 1982 1295 8013 1157 1488 5258 959 8522 9263 9214 7250 5995 7164 7243 8105 8393 5076 7643 4994 1102 4619 8003 9820 5856 4098 4418 4081 9239 347 2721 8886 2363 6038 9849 9277 2258 3745 3624 4442 6334 6154 1023 6800 3442 8646 9934 2546 9652 292 3521 1305 5187 312 2309 3157 4280 5245 3207 822 2053 6956 2248 8262 9904 7351 8552 7023 5919 8038 8402 6855 176 7309 4684 3810 3417 37 3771 2710 3099 8008 1739 7361 678 5959 1902 5024 8242 3707 1510 7088 4423 9370 1638 4154 242 6265 9160 9413 9874 1047 8205 172 6512 2458 4710 9136 7798 2156 6412 5903 2887 925 8482 2542 8677 1731 5333 306 150 5460 8298 1406 3644 7524 2351 9587 2580 7176 1936 8069 1507 6206 7270 9144 8377 2579 8970 7199 3203 2846 2273 2511 462 4730 434 1086 1832 7749 6922 2983 5016 5205 3596 9518 3603 881 6210 8062 7595 8545 5321 351 7005 6589 6179 1588 5094 6651 8948 4371 6982 830 4222 9574 6786 6242 2783 5042 1210 757 63 2969 3921 5121 4414 3814 5463 1135 4504 2135 6701 5976 9635 5119 3506 1633 7400 7296 7327 3241 8619 3565 384 3473 9067 4780 7745 2909 3298 5428 281 206 4786 8779 7206 2333 8382 3196 7526 7869 2624 4041 8627 9063 852 3016 2551 3206 3781 6724 7451 3792 5867 7046 2633 2195 3571 8289 7314 4901 8130 1901 5218 6073 4758 3352 8484 7859 9142 6197 6866 7819 8654 9360 7313 1489 3182 4613 5607 631 4191 9881 4941 5490 9784 2574 6008 5756 7846 7673 4165 2381 2013 2291 2889 9130 2077 1552 7390 8538 2326 7192 1297 3760 288 6023 1966 2020 812 1135 859 5248 1336 9199 1960 758 4454 3656 9306 8925 299 8812 5638 3246 7814 7255 8216 4196 7787 7452 4558 841 590 975 2360 2171 2835 6210 3873 511 4264 4633 8173 9054 8889 4454 9908 2273 8499 1520 1203 9012 6247 6548 961 1537 9530 15 5510 8262 6870 8752 4472 2222 4082 2693 3629 1694 8237 1018 513 7837 9958 5647 234 1928 4609 9049 3644 4282 7787 4631 9560 115 8850 9096 5399 2450 473 7514 149 9388 1945 9272 4291 7562 8098 4419 74 6506 9649 3535 9250 803 4965 6675 8474 1664 6568 3648 6925 4485 7647 2849 3761 9764 4908 3719 1388 8461 2654 1495 9116 1867 4471 3012 1795 5045 7058 2287 7361 276 6650 1375 8657 9536 4737 9289 2573 7056 9018 1509 7141 392 1368 3849 1635 6025 147 2601 1142 5655 3789 5340 578 1532 2890 278 5144 1621 5489 3360 4802 5080 8144 7176 4999 2791 926 1579 8701 6251 3165 3366 47 612 400 1055 8556 5267 8427 508 6345 7333 7332 7066 2071 9029 8029 1097 2840 8920 6471 3459 3557 3408 323 8733 9228 6506 3337 9650 1923 4132 3855 4706 4647 4292 9610 9294 4239 4598 1339 3301 7907 1574 8929 6194 4388 1704 2006 5053 7069 6875 3564 6245 6071 691 3601 7230 8984 7668 9204 1720 5216 7007 4705 6616 7033 2065 2530 5018 2110 4163 3118 3530 6733 2750 6419 6315 3351 5148 168 3592 2449 8025 8553 5344 6830 3300 3660 2631 309 9280 9049 3972 8584 9315 3825 9285 4867 9527 6240 8855 552 5296 3056 6055 7118 8015 8009 636 6411 3053 5103 8365 5504 297 4673 6071 8159 1222 3560 611 9839 1237 8709 2731 8095 6152 9048 2788 8747 3227 5522 7920 2781 3215 1286 3724 4540 6788 4643 9281 4652 4115 1802 8400 2750 8292 7069 8342 2268 1085 5627 9797 7367 1402 2700 1700 4574 2676 3734 3250 2659 6937 8784 4224 6119 8317 1390 9829 631 5235 8652 4231 9928 3047 273 141 6427 3475 9191 5350 6289 8547 7714 7124 3193 488 6015 6581 5725 1478 6792 3679 7062 4163 2123 7680 3703 5084 9516 6879 934 819 1858 372 8845 6613 6394 3074 5713 2396 7824 2508 8852 4753 7751 5870 6219 6904 7338 7022 9973 7623 1128 1608 6229 7799 8155 8612 9624 9835 8754 1354 6865 6198 158 5768 8701 8901 6885 7107 726 8820 2887 2071 9588 4153 1862 2078 6106 89 2555 812 364 9148 3066 9041 3605 6723 86 2851 6210 5275 871 7026 2459 9938 7613 2179 4880 6203 9115 1146 3073 478 7943 2418 1012 7754 1615 8458 4685 1063 2352 6488 4583 2905 4812 3327 9402 2200 7471 1344 2308 5160 8166 1229 4304 5277 4411 4781 2808 9045 8133 7210 1767 7867 4958 141 9458 9844 7301 5350 4969 2957 697 7811 4155 2945 8349 1848 9800 8306 4179 9529 1854 321 6521 337 954 4861 1666 6616 5764 7913 8768 5211 7274 5405 3917 3739 1463 3210 4252 4532 8649 81 7796 9532 7424 7765 44 976 6610 7412 395 8968 1872 3176 4629 6067 1480 7341 5615 9093 3965 1122 6662 7737 3843 1952 4345 7953 8772 2164 6948 5084 4560 3301 8599 9804 7940 1153 3336 827 2729 8696 4850 3106 6647 5181 6650 7626 464 1434 2923 9091 1309 5547 3793 5899 7303 3902 8887 7076 386 6099 138 3662 1388 2714 8350 8453 793 4968 4800 5586 9525 9312 7629 6538 4300 8774 8185 4665 5612 3596 2062 8696 1267 7199 6199 5523 4371 2465 6363 5858 9853 1828 3993 2475 6110 3764 6710 620 2061 9976 1764 2643 3496 6252 7512 1488 1051 3254 1968 9917 8848 3029 1552 1868 2256 2557 9078 6366 4742 2372 3272 5113 9487 3034 3439 673 5171 6972 9300 9103 1366 5576 3530 2325 8004 6985 7979 497 3043 3872 5320 4988 462 2073 4214 679 9387 6400 3909 2777 432 7737 9831 8024 9290 7507 2774 9738 4331 8527 9644 8261 1742 9914 7575 7610 2414 143 4223 7510 9874 9662 7920 5153 668 4143 5605 5863 6015 6284 5641 5316 2911 4201 6055 1159 4007 378 4565 4958 2007 678 6545 6746 8226 4455 8594 6184 9693 9378 3615 5250 3713 1616 3195 329 6495 2118 3069 9176 1508 7889 7273 5442 9669 9662 6821 9122 2815 2370 2288 7944 7211 6034 2181 5025 981 5925 7530 9673 544 7302 9327 7138 1238 9555 7175 9361 8337 6871 9279 1580 7516 9773 8676 3599 7909 9567 3353 3357 2226 3461 3543 6358 8636 4421 9975 91 3767 5791 6260 1239 5951 2731 7594 2570 7356 6662 8056 4513 3595 2953 4881 5455 2043 5196 3655 7344 3348 311 9882 7924 5112 2519 6281 2643 5408 4712 8803 7798 8795 3495 7030 5350 8980 9309 4231 4470 7166 1712 8866 4534 776 9691 2237 186 3330 4088 4884 8421 522 3265 6829 595 8974 8034 2277 7893 9085 8346 9567 6592 2982 4824 6452 9534 9065 2137 8752 3725 9701 5428 7810 8899 8235 9486 499 4576 4960 7739 1231 8337 4296 9206 9037 2568 1665 9199 9510 2382 1395 5919 1219 2277 8911 4542 7524 3840 186 9885 681 8347 8361 1928 6824 1236 3641 411 4601 3175 5856 2762 4253 6492 4605 6584 2816 7373 1205 4078 7558 1804 9834 7614 4885 2838 5916 7390 4462 1112 6729 8006 7599 9409 8297 9670 7129 3485 2796 4479 5230 590 542 1438 3817 895 2006 1136 3562 5151 5043 8062 1217 6160 9280 3509 6329 214 1948 5903 1029 12 2415 8755 8319 3484 1975 5425 2956 8201 561 6256 3418 2927 1551 1751 1188 1321 2867 4753 3676 7406 7827 6169 6326 9956 4288 7097 765 9753 5094 2592 6224 3625 1068 7404 4446 4516 8982 3725 2779 7766 6895 880 632 7115 6640 9631 9908 9644 210 7828 3667 831 1640 8898 1125 6445 546 5262 5782 7277 8212 2217 1857 539 2889 676 2710 4107 311 8544 2580 2459 7056 106 7786 3646 6516 8618 2603 752 7706 4926 9364 7595 8835 7339 4707 4487 9693 2022 1338 8420 293 7746 171 7195 6101 7893 7984 5407 500 4727 2933 3314 5177 9579 8738 8725 6120 7518 8399 2134 1820 3177 2937 3991 156 4892 8223 2174 5996 9748 8531 5963 8961 5171 264 2817 6978 2977 1393 4242 1809 5937 7461 4142 1461 6212 8049 2368 2542 9121 6770 3959 3739 7517 1153 4550 3872 2916 9355 9006 7881 8929 2432 9099 3992 5708 7231 7022 1877 5196 4470 1409 7816 3161 7456 4845 9468 5433 9963 9618 7209 7500 7344 892 5254 2962 330 2364 6459 825 6023 7017 864 2919 7194 8948 1969 8451 4559 1901 586 3175 6481 3606 3276 1021 4178 9514 3508 910 6047 6630 7884 4345 5776 7412 2092 2187 5347 8248 2253 627 8168 5619 9458 8339 5262 7512 8515 9865 1587 8174 6392 4738 5553 2248 308 8434 4182 3075 3182 8833 8138 9026 835 1717 1278 5771 345 7609 5208 501 7607 2463 9051 2553 3494 9224 9017 4024 9956 5374 2906 888 5261 8450 9795 3936 652 8263 5471 9258 45 6229 9892 7467 165 5598 2952 6051 8687 4071 4956 716 6805 7690 8921 5518 4458 7360 1532 8998 3662 1353 396 5994 1944 9645 8803 1361 9510 1376 378 2974 8527 6149 3331 4810 554 2470 275 9955 2827 5584 4534 7298 9282 3334 7486 7636 5949 6286 9621 3700 3946 4451 4933 2292 9196 1549 9921 3898 8591 7853 9104 7435 9543 2749 5847 5810 1952 455 6401 6987 8108 4524 1964 4798 861 808 3092 406 954 3863 5467 8257 515 676 2907 6699 4180 8920 1554 9167 1997 8520 988 5285 9613 8875 3768 6042 4184 6721 7252 9222 7653 6327 6371 6440 7969 8804 100 4565 665 4906 1486 2506 5825 2547 4002 5347 8183 6077 703 6338 1325 605 9134 6079 3276 9632 2686 4796 9937 2388 5750 6311 1897 1287 2828 7297 6264 3898 2504 4168 1485 7732 4441 1376 1303 6304 9140 5683 4652 5336 8726 8296 2296 4477 3374 25 3540 4502 1020 3961 5651 1987 3057 8292 2132 661 5339 4238 1330 8515 7171 2817 2091 1887 3556 2807 3603 3309 7644 1063 9587 7238 7459 4908 36 3167 1688 2540 3009 1680 7450 9984 3542 4080 540 7657 9188 8369 7297 277 5421 47 1435 5747 3933 3974 2532 3959 7129 8826 5432 3882 2072 7841 2733 2023 9102 2734 4892 7103 4777 384 3888 4604 1200 3232 9642 6257 5940 6459 6881 3127 9254 3886 9320 7077 7866 1529 5651 807 875 99 499 1271 1352 4518 9645 8858 8695 2578 2698 3986 9439 81 6664 4137 9140 3014 3814 5987 7127 5958 7973 8235 3740 5819 9324 1880 924 2896 5699 627 3051 2712 1383 48 9903 1916 4880 1422 6284 3342 5617 2512 5854 5809 2340 5891 5 1692 4309 1288 1260 5916 6995 2401 5822 1381 656 8622 6481 3184 7283 9492 8685 7774 9282 8511 7538 3586 2108 9109 8238 1396 4828 4713 3109 3455 2585 657 9960 7894 470 9544 3929 5272 6952 5576 5570 6885 130 8397 5661 7868 6701 2390 7011 9638 3596 6710 2153 2848 9530 1517 7393 8583 7199 7380 8382 7839 2089 9490 968 1791 9749 599 6475 9244 9261 6137 3202 829 5081 3697 1696 7102 3529 7114 2055 4646 5428 2710 6133 1873 5245 6459 2170 330 3258 1679 5872 5158 4258 9033 672 153 4435 1510 2028 4900 4757 4788 2250 8945 4644 9269 3715 6898 1246 3822 592 8869 1958 5919 2485 4091 9257 6347 251 232 1299 9064 3706 5904 3116 8052 8258 3177 995 8702 1858 7129 3919 4765 6719 4937 5192 2784 7705 5819 2370 1755 1851 8054 1907 2546 689 6412 3840 3993 6626 5841 707 304 7290 3230 9492 2458 5803 5680 713 1064 6783 1773 5222 1033 4538 5074 6359 8556 1600 7556 8523 3568 304 588 7548 5378 3725 7690 7738 5885 4908 7495 5636 9912 19 9653 5674 7560 3727 3404 967 9003 1623 5056 1548 4984 4477 7887 4389 180 7365 7834 2881 1829 2754 4583 8275 409 8342 6611 7967 2905 5659 1534 2452 8265 6545 2785 8240 951 4840 3239 1174 2669 8602 4196 9193 7038 9554 3440 3682 1778 2548 5544 9399 5479 717 6994 2863 9396 5863 235 9721 6718 1913 5037 817 2963 9475 4662 7973 116 7227 5184 20 3695 835 6723 3406 125 1448 7775 2772 4460 5308 280 5468 2807 4691 1153 7119 6201 9892 5918 8266 2484 2732 6260 3417 9457 4345 6293 7193 2616 1475 7794 765 4572 7587 7400 8325 7469 6035 2146 4945 5939 4995 6561 9252 3925 4726 6346 5945 8354 6546 2759 913 6089 3826 3526 593 75 4855 4042 2756 7278 8419 5592 2162 9545 2169 6222 573 4611 265 3827 5422 604 5373 5354 4315 4364 6332 9520 8639 4873 1997 5392 3205 3147 9141 3673 3921 3063 7185 7025 1425 8590 5053 4108 8537 2485 2756 740 9498 4046 1637 2915 8218 9133 8906 3854 6706 8187 3607 2482 2635 4027 2781 4440 33 3768 4202 5992 5273 2985 66 2164 220 2480 8696 9420 6634 9913 4603 101 6604 8455 2956 6459 3294 732 6766 8322 5154 4836 1160 627 2781 9175 4482 7780 4650 8646 6149 688 7266 9324 1582 6555 2702 9710 2280 9272 6819 2633 2310 1270 6048 7676 9235 8370 6092 8327 1872 4193 3768 656 2712 5202 8958 5665 7396 7407 735 4124 6913 6650 3228 1634 8552 6979 4170 3932 1398 8795 403 8704 3838 6572 4912 9952 5092 9870 7930 1139 2842 1912 3298 1196 230 9919 9390 8120 3560 3260 7903 1765 3624 2026 5780 3750 3092 1546 6996 8208 8328 6755 4314 4408 8823 1896 8045 7598 3042 2055 5859 3083 1846 3073 6721 9158 7730 3322 6703 9830 5338 4933 8793 3728 1150 530 9610 6073 719 2403 6985 1510 311 783 3822 706 4917 5157 4239 7024 2867 4546 9478 8028 8074 4239 4946 2686 1447 8001 3270 2346 5848 7672 5431 3547 3922 4211 425 5845 1490 4534 9487 6417 9412 5834 3559 5765 2034 9240 5070 834 3478 1900 1856 6847 3812 2677 5867 7172 9963 3286 3325 6312 9945 4620 9380 9813 5466 6395 3091 7870 5172 8444 9308 8820 2344 5783 9045 9204 4999 6379 1285 2919 5263 2583 821 6988 4719 9338 4533 9961 3323 5211 7723 4819 7833 2675 9860 8798 8555 5630 999 7697 857 6797 3203 9226 8811 7326 301 5810 5352 3076 6296 8090 6269 3717 6760 1331 3048 1610 4132 345 3963 326 3936 1532 2602 3031 6158 3930 5847 3345 9238 590 4472 1356 409 8193 626 9231 9516 2788 1460 4741 3702 6613 3048 1608 5673 9797 6431 9679 9834 2905 4871 3640 4147 9197 4434 3095 9140 4172 8945 3813 4044 988 2101 5562 328 4902 7824 8443 7848 9398 1383 5461 584 7478 536 300 6271 9881 1547 9832 9557 1148 5447 8450 5828 8979 6195 4593 9262 7676 296 798 9290 4149 2193 8847 470 7363 847 7777 2577 5108 6582 6264 1 8961 9785 8691 981 8605 648 3699 7053 4433 2127 2183 9982 2872 3352 4987 6456 7740 5244 2284 636 482 3812 2512 1153 5288 5512 8534 8947 6111 1766 8720 5836 2634 3189 7037 7061 2364 3834 4892 4807 7530 1021 1673 4931 7227 9477 5280 9838 5675 8728 416 3758 6200 4737 6117 8557 9517 7798 4000 4455 2780 8434 8198 7023 9730 5607 4044 6482 4773 9712 9252 7785 6061 6122 7864 7990 4110 5210 7656 8009 6608 7042 2721 1481 9992 1764 1370 3966 2400 8494 7321 2323 1768 8026 2598 2574 5051 2364 6917 1222 7576 5014 3676 9334 1221 2985 6839 163 3643 8608 560 3316 5941 1555 2511 8321 7917 7585 2119 1291 6841 8529 1716 9332 5083 999 788 7852 5757 670 7601 5133 468 47 917 6788 7918 7554 9972 2139 4138 9559 2466 7520 5773 6520 9332 2817 558 7649 691 6310 1154 1606 4450 3466 6108 1942 3409 1132 2321 1318 9737 395 830 3381 7665 8202 7379 3180 3204 3737 3676 7391 5997 272 7838 4565 7940 1311 242 8112 8602 4555 2844 5923 7658 7254 8780 1452 8620 1853 5599 9872 9030 9485 6449 1969 4186 4437 5555 9492 966 6314 3730 4174 4085 5564 2507 384 3232 9947 5651 1160 5058 9728 7396 4183 1036 7735 4079 2566 9244 6118 1154 7389 4970 9391 2763 9215 2590 1130 324 2061 7006 5346 7766 8239 4452 3342 3831 8957 4266 2730 275 7692 8531 8624 476 783 5175 9693 449 5862 2846 5735 1071 6876 1695 4121 9627 9939 9428 3152 2071 6573 1365 7539 5314 2652 7195 7826 3547 8509 2067 6913 4025 6790 5303 6766 3730 6062 4412 2643 4588 6961 9809 208 9333 1065 1540 5620 888 3812 597 5569 2489 3220 2486 6854 1022 8262 8141 7358 1116 7151 8615 2503 2103 7401 9368 7105 2466 7922 5733 8153 9602 1221 864 896 6993 5197 4108 7061 7449 7509 5373 4775 5881 2121 740 8468 9444 621 2394 189 7080 9209 9828 5056 983 2713 6480 9278 2323 5874 8883 9284 8684 390 7153 7537 1897 6094 8459 70 1015 7627 4084 2543 2923 4400 3928 3608 3237 8607 3387 8921 1582 7344 6712 3414 580 2017 9946 4593 763 141 4012 2034 9194 8391 3795 5752 2811 2310 284 8469 7052 8666 1824 5294 7795 3282 2062 2510 4767 6222 8241 5545 8839 4153 8759 5297 4098 3460 4054 7027 1660 2507 9330 4159 3472 3764 3091 6748 2901 7965 3654 5021 3573 5931 8584 6457 6155 4500 517 4174 4522 3863 6275 5175 2072 9446 9225 9055 5331 3292 5227 1850 2777 843 9201 4617 1736 4564 2234 8708 143 1989 8995 1597 4705 5634 4008 5982 4421 5294 4369 8507 7961 8947 4959 3360 6505 6093 9967 2485 5160 4783 598 7123 1593 420 4172 6169 9048 7032 3760 9105 8248 2927 527 3284 2851 6682 6565 6010 1901 1563 2706 5430 9278 3750 2924 8609 5191 1501 7560 4447 8885 3443 6748 4352 665 2317 5950 569 6769 5716 1956 3184 2034 2435 6789 9318 4371 6342 458 1072 4397 6524 9363 3159 9677 4579 3663 7336 4029 1074 9757 6109 5055 8997 3078 9783 6094 122 1242 3593 3371 3587 9433 2930 717 9536 2053 990 8774 5851 3598 1025 2281 4218 8183 1281 1481 9775 4677 1826 3973 8466 1103 5400 7705 6938 183 3316 3445 4182 4979 839 9068 3039 5181 3190 2756 6911 6897 78 5702 3078 1135 5272 7741 1133 3009 3826 1569 9482 2952 890 3765 9792 405 4469 5273 5227 5008 6727 9489 4281 2055 6125 3957 8405 9316 427 7880 2411 1206 9726 1830 1748 6917 9820 2529 6949 512 773 7979 9467 772 5167 656 7223 1457 1809 1757 4811 4897 9246 9768 6184 412 8355 4868 9462 9433 3772 1162 3257 6305 8601 457 9205 3114 3258 1370 8821 4394 424 8415 7891 614 8873 6413 3190 4716 9457 2332 6373 4742 4067 355 3242 3092 8850 9955 164 2032 2735 2985 4572 7934 5177 4743 2991 606 6194 4632 9168 1961 7221 2841 7580 2356 6965 3975 436 2040 1760 1120 4653 5842 5706 4015 5315 3536 9311 6574 9138 4234 611 7793 3424 6287 7916 4740 2281 7998 8758 1231 8896 3648 9098 8953 8675 6604 7991 8731 9056 382 6780 85 891 8520 2442 3092 8610 8222 4989 5284 9882 1581 7340 9092 9477 5225 3747 2396 9680 3189 7683 7975 193 4117 5240 8899 597 4001 7710 2204 8009 1699 2207 8509 2664 9193 5050 9410 1176 8937 9435 8252 6722 5151 3448 9400 5681 485 4196 3213 3765 7829 7193 1542 9254 3533 7457 6957 262 1392 3909 209 158 6468 813 3573 2373 8264 6640 2558 4541 1485 109 7879 2879 4136 1992 2320 7623 8528 942 2057 8336 6925 2197 4384 6940 9029 3129 5600 6720 8171 213 5226 5633 7892 5183 2849 3084 2437 3037 8016 4079 4192 3016 2907 704 6557 6325 7581 5122 7204 2436 325 3485 2247 1774 5044 4604 2088 2915 7378 5106 864 4526 6892 6001 6769 6196 5671 1476 1747 147 4400 4550 9883 5323 7395 7800 7233 3857 2667 8030 7325 7414 7682 9321 3896 2416 7011 3054 5039 347 3716 4282 5545 6811 7508 7167 2757 5893 401 2689 8856 1922 2680 4198 1338 875 1758 951 1029 6024 6390 3148 3467 8671 9186 4019 3436 1573 9701 9085 9973 3628 4108 3430 8495 8437 4896 111 7241 738 3750 2818 7951 3999 9601 3072 6844 6841 762 6986 4122 7881 1500 5057 9012 904 8684 2875 4915 6686 9653 3267 1158 491 6779 1259 9578 2666 4019 6900 8758 2961 2341 1762 8145 3167 9404 5384 6013 4109 9972 6122 1727 2649 912 4220 6243 1576 795 8973 6979 6917 3184 7297 8920 7863 2321 8356 9129 9590 3009 8381 3736 9898 8916 3020 3642 515 8692 2223 3037 8844 8595 394 1182 984 2307 7015 7598 9682 3412 5700 9454 6273 1640 8584 7029 495 7355 3816 1677 3305 432 832 8294 434 644 6137 2679 7721 1307 4672 1590 2131 9211 4721 2173 5289 5742 5099 5629 1610 9750 4105 4896 3919 4587 7321 2617 1536 2844 8008 2692 7698 3183 5284 286 7698 6898 2513 796 5847 7452 9211 8032 3604 1732 989 9421 8709 5867 9174 5166 6519 5444 5243 8157 2820 2026 2419 2334 1821 4160 5666 6889 7998 4517 9614 7957 1347 1376 9696 3982 2025 4373 7935 4567 4221 7671 2792 6711 609 738 8233 516 8956 5078 7773 5041 4830 7949 1518 2047 5994 4694 2201 7535 4637 6856 4483 6821 4234 9809 5724 1444 8257 8951 1603 8251 5852 145 5945 6576 764 5795 7678 2438 16 7661 738 3354 8473 5766 5188 4008 222 6306 1213 6289 2588 8896 9648 1819 7152 8626 4492 4111 3210 3307 9292 5492 6828 3504 3671 1061 931 9608 6693 7557 3539 7976 2463 6936 3377 7191 1305 916 5577 7727 6412 9697 3821 8418 5225 2488 3754 8573 7306 2131 8472 9970 1889 1106 1814 6328 2381 6017 1577 3906 1160 1076 3103 2687 964 2789 818 5920 6233 6003 1522 8717 6662 677 8246 2427 8260 3226 7425 2150 5106 243 4209 2711 2968 1222 2995 7938 5540 4522 9941 3444 6667 1231 7935 741 5582 1747 4375 6067 2602 1903 3900 5608 4520 1540 4825 2794 1603 7450 6764 3507 618 6913 1510 3674 1298 1225 9177 4453 6782 8514 3333 3837 9185 916 3916 7148 6796 4132 606 6506 1625 8802 9219 369 809 9218 2189 3874 8088 979 730 8045 557 7210 6814 6008 785 1870 95 2223 8086 4359 5781 4266 4555 9638 3755 5898 4290 3643 777 3610 1904 2718 2306 9754 8106 9047 9119 2142 1313 8051 2473 8179 6553 464 6625 440 529 4863 9213 9254 887 9134 4283 6129 7920 8736 1614 483 2244 5481 1840 1360 7949 7500 7918 2519 7869 6079 7616 1931 4026 6970 3749 8232 8820 7402 2444 2131 2011 8340 6094 9083 4138 8941 5922 8736 4468 3844 5581 8209 1537 2398 4312 5217 1355 6673 2290 3706 5846 9552 1449 3310 9411 1891 5186 3607 2057 4628 2293 7541 2461 6691 5484 1257 2477 6449 8929 8740 6581 5365 9869 8147 9645 60 8498 9407 3818 2924 6082 839 8827 2718 3142 2347 551 6713 510 2984 5099 4915 2399 5699 7934 9732 7892 3222 4442 7763 9447 3476 9251 4208 1953 9148 2438 7880 1945 6069 9982 2043 4567 9830 6951 4931 5891 3086 7238 1212 5894 8804 8995 5098 4958 1920 5738 5368 580 2467 6537 9957 5123 3515 340 6243 8094 7504 6844 9948 5668 4213 8329 9315 978 9327 946 4606 5724 759 9781 5645 5655 514 3594 8985 7883 9742 5080 8026 8031 7818 6147 719 6788 6338 4962 9097 401 7211 5855 7851 9111 1838 6175 9496 7384 2053 2066 6683 4058 5126 2897 5274 483 9607 6699 6486 2545 1797 4110 7298 8824 6506 472 6887 9078 1227 1004 9146 1950 1006 4995 9734 8536 5974 4745 3770 2499 7306 6573 3973 5339 5572 2532 3370 5774 1490 7870 2702 3666 368 59 545 777 4197 9494 5660 3064 1332 3152 9226 8576 393 3911 7563 3346 6510 2610 3753 8267 4520 1439 2621 7314 2886 5392 4289 2211 1259 6019 3416 6311 5871 2284 708 1713 7770 6825 8763 3623 9812 4038 5932 1106 5519 2918 7907 1903 1241 7762 65 4122 3294 3823 9850 7825 4692 3533 1284 2093 6158 4641 4622 4470 8697 1062 3283 7291 8683 3233 4270 5540 8364 6497 8868 5037 2865 3302 1523 1156 6565 2179 1800 5548 6853 7745 6093 4048 2992 7099 8228 6545 6015 1208 8324 3175 1093 7 2868 474 9805 8602 7749 1995 9772 4062 426 4410 3233 881 6756 3055 9833 1561 9181 9422 171 9193 5078 7065 6581 3036 3687 9814 6460 2231 1848 3995 9123 6262 8094 5889 7909 794 1393 2198 3836 2797 1251 7999 6456 2319 9889 8500 9796 9968 8517 7021 4912 3132 4981 5750 9551 133 8072 8984 8102 5178 3972 4135 10 3280 9322 4644 7972 1326 8840 9261 917 1711 7855 9458 3084 7864 9059 1263 9581 1138 2262 6060 5144 8781 9013 7721 3165 2406 5291 2297 5057 9646 3531 879 4228 5853 288 3238 5146 9906 2180 1798 311 1192 4980 9179 5001 2363 1407 6030 6076 925 3295 4880 7024 1342 594 6607 173 7197 6914 1579 7443 4405 9721 8328 2465 8228 5390 8418 3277 6783 1076 5239 3402 5044 4516 8794 9647 3725 9127 1214 3103 5863 328 7559 4151 4859 657 5787 4804 4084 3955 8320 8322 6388 5981 5486 2856 5189 9251 8046 2931 7686 1569 8914 8995 4148 407 9442 1300 7657 6146 4020 6822 6045 5620 8859 4045 1590 841 4470 9308 4570 7165 6730 245 7736 1046 232 6160 847 2708 7610 3683 7726 1096 7669 5100 4247 1952 831 2232 5161 9572 2991 4223 5446 4596 9215 757 4103 5787 1640 9088 8176 1874 8917 7718 2221 1681 6492 1888 4334 1164 108 1978 517 1462 1847 6382 3413 3215 3464 9409 6630 1552 9059 1458 5680 5176 3802 9660 4859 3143 2901 942 9490 5956 401 2146 3981 7668 8389 6031 7154 2787 2364 6539 3818 5882 6469 6661 6571 2476 5381 1843 938 9406 781 5459 3514 6463 7742 6241 8441 2950 9096 6876 4779 6176 9826 9314 5982 6662 2228 3939 526 8221 4597 8393 8372 1355 6158 1130 8323 3343 4102 7428 1834 2131 9253 5894 3930 3365 1735 8728 4377 2574 8544 330 9934 2462 4499 6235 9710 5857 7068 971 4109 5230 2474 8367 4931 7004 6243 5853 7314 7315 7969 7874 145 8862 4355 4028 8963 1669 6161 1224 9401 3861 2450 1530 4245 4200 58 9634 417 2938 8998 667 5461 1851 4262 5886 7345 7632 747 162 6933 8394 1167 7202 4464 1800 8624 519 9173 5139 1105 7909 1849 3774 8097 4616 6174 5678 5403 3271 7376 9598 4762 607 7781 9077 8547 9726 2804 4969 315 3265 2981 1722 7294 4072 5379 2710 5676 6559 4093 4587 8665 2430 5054 3387 6132 8944 8764 6303 787 2033 9322 5309 6514 8973 3258 8849 6733 4546 4049 4559 4089 3467 7970 4207 1021 7497 9860 9265 35 8560 1014 3805 6223 7673 7519 8340 80 2829 7908 4488 7258 3493 1317 7027 3955 130 7008 919 5007 7654 1939 8114 699 9448 5744 3933 9186 4262 222 4961 3136 7348 3472 5537 6356 9233 311 1633 9443 7870 6874 3736 9203 8322 773 3447 9430 4375 6872 6596 5404 5936 6984 5326 6680 3875 6671 3693 5458 3403 8303 3403 2420 7048 4646 4196 8561 4335 1536 7647 7615 3994 2662 9407 8520 3009 6007 3516 5416 9517 1210 2400 7909 3764 5275 6327 612 9157 7753 5495 2092 4649 6129 3855 6386 3016 7245 4810 5706 210 9365 2615 7673 486 163 2215 221 6863 6637 8258 8714 2960 4705 8171 9694 2915 3451 2307 5254 1442 6779 8575 879 3791 5937 5952 4376 1799 6347 1618 2320 2132 6470 1228 6440 5251 9171 1450 9493 2048 7955 1919 1143 7613 8342 9252 6584 7017 1757 2411 8748 710 3366 912 3833 599 6561 8711 7530 6103 3015 8845 4254 1770 1006 5189 5241 1568 9395 8203 4425 5364 6834 9503 1114 9767 9750 4253 6974 9664 2008 535 5778 23 9882 76 2743 3356 8966 6108 636 645 7501 4561 4298 4283 9382 4783 2852 7268 1153 7404 1085 2282 7430 9844 8633 7812 1157 3391 4003 4968 2294 1951 1603 9360 8029 1397 4665 9881 2979 2594 3199 1820 6847 9824 9685 5512 407 4111 5794 4747 7851 432 7266 2384 5061 1593 771 1934 545 484 9189 4499 251 6581 6846 1146 3534 1573 9656 8706 5929 4803 9214 7012 7672 3416 7815 4978 3891 7135 5380 9311 2982 6591 4468 7485 6443 3363 3733 5256 8885 651 8863 9266 8339 1955 5630 9308 1771 7820 8823 1515 13 1151 6999 3765 7497 6712 9178 16 5400 613 7784 5563 3544 4473 5413 5372 1248 8385 6474 868 7031 5656 2481 6553 4115 9058 4614 1577 1093 1876 5540 4387 1614 493 6134 3703 8867 9560 9050 4437 3606 3821 1432 9 7585 8271 8213 4307 2552 5531 9335 3716 4567 3926 5952 7673 4789 8742 2639 9191 4053 8707 3219 7150 8909 550 1654 9031 6076 7328 273 6371 6628 773 3159 3219 4004 8249 8859 7453 4809 9433 9999 8348 4886 8184 87 3403 4414 5976 3367 7807 8123 6642 5430 375 3826 8756 7618 6016 3089 117 4508 4354 850 124 6901 8322 1604 6965 8751 7234 3810 3941 3219 4306 161 5110 6494 1760 3019 4328 2813 9984 2719 9270 4550 2964 6936 1575 8792 9249 5845 6733 7567 5724 4399 4577 7915 9557 8480 5776 5803 3495 7019 7265 8938 2479 2183 2483 5345 6394 6764 5174 2573 3411 911 6709 2094 1142 8476 4336 2260 2333 8646 7713 1965 9349 2784 4264 5936 4725 6148 1159 584 5836 8290 4876 7276 4613 950 4364 7019 8035 4800 4205 6120 7898 550 7470 7709 4568 9107 9055 5638 7081 6238 6332 9089 2066 5569 1320 7422 3374 7459 243 3842 2654 4332 3833 6393 7118 8333 2923 4695 5679 7274 7691 8481 6825 3038 5871 2944 9609 2403 3040 202 7356 6950 3260 7063 4684 5415 5933 6920 6982 7630 249 7046 8618 1212 2156 2746 9084 2404 3359 9831 404 866 5689 6780 4923 196 2597 2309 8757 3505 5215 4735 4425 3596 9485 9948 6073 8985 7915 3487 3112 4551 7227 328 3872 4502 691 9278 4386 4261 4586 7132 9714 7887 575 7518 8927 2152 4556 2772 4155 6559 7300 3984 3948 3318 6495 2575 9283 5765 6000 47 2791 5693 2335 5174 4382 4659 3243 3480 628 8492 4518 6281 9455 5270 4899 3213 9368 9894 8102 5590 5610 6607 532 3929 3486 7771 1536 664 9771 1279 3862 9145 16 2517 2251 5043 96 647 1510 5345 4799 1302 7076 1228 3526 7342 7224 5887 954 29 3184 2460 1800 9562 2473 3373 6987 5516 8129 6089 3436 1505 9102 9724 4244 170 3654 6313 5763 1949 4144 4677 8114 2759 7413 4398 9985 6740 1637 9692 2643 9879 1979 6448 8576 8523 659 2025 5912 3381 7372 6723 1001 3018 9735 2946 3585 4516 6483 3538 9850 4773 607 1632 9468 9466 381 7500 9793 84 8135 63 277 4246 5441 8922 5670 8752 1947 844 698 7854 882 4865 6845 6727 4516 517 758 4518 6198 5492 8273 2381 4765 5693 4212 2484 2183 2964 8456 4261 5321 5527 4571 9163 152 9874 6782 3030 8169 747 5427 758 2940 9829 8850 3641 9364 8340 3079 1658 4290 3869 5412 3350 9528 3978 5651 3381 8148 2826 2894 7325 777 3879 6160 9714 9347 2866 7677 2139 4983 432 7789 2490 7204 7921 4372 3763 1724 830 3930 4905 1731 8112 112 9979 2222 1094 3170 4567 3114 297 6024 5609 2360 2963 5595 5720 3479 230 6014 7874 5223 9534 1095 315 4437 6460 7666 4852 777 935 2155 2346 1919 3526 7274 4209 9700 5 3340 2093 8668 7943 1272 8856 2754 222 3667 1835 9527 6049 1594 3873 3657 9655 6406 8012 3714 7244 945 3386 5954 8110 7591 1643 5004 1216 7397 4024 9162 8343 8860 1119 4394 2395 3600 4418 5666 8931 1077 4308 3621 3308 7997 9117 167 3420 3907 1801 9266 7775 2111 2080 5059 8403 2520 6826 2206 2461 3589 7580 7683 9195 4381 7590 6608 9791 4884 8791 4002 6115 3018 1663 6613 5159 2865 1023 4771 1899 4597 7635 1451 7101 5510 9608 4243 4721 6219 2483 4725 8618 5772 6564 697 4130 8037 7871 8956 1741 9380 9352 3859 3880 7217 3801 967 2742 5205 7839 9477 9383 8755 7408 9150 6377 2080 6476 7180 9046 8200 2613 612 4017 5649 1686 941 2741 9909 8198 2148 4559 8215 1536 8985 2351 8268 7895 7211 9923 4485 9974 4857 9857 2275 4485 8842 9508 1516 716 3674 2932 8024 2249 2097 1168 2703 8725 2404 4015 5100 2985 6861 9574 2138 8111 2426 6815 2319 2507 1371 1645 9993 4912 1817 4600 5165 5651 4951 6644 3740 5693 8817 4588 3880 7996 4260 3220 4643 8445 1247 2380 4552 9303 20 2107 2314 2317 1544 7555 5707 9755 7213 4022 2685 2930 1000 8709 2791 1818 1758 3724 9513 9994 1934 725 6975 218 9567 3400 9485 6896 4450 4987 2797 1068 1334 1586 3161 1886 9369 2732 2738 9665 524 6131 4963 7277 8393 1449 958 6888 6660 9407 2241 636 9307 2982 4563 3223 1361 6774 8936 7899 8223 5766 2662 8836 7447 8688 3948 1280 7156 6611 4151 8914 4596 7381 81 3133 9952 9092 5115 7788 6659 511 6941 8768 7221 113 8367 5840 8973 8464 775 4477 759 4106 1816 4347 6870 1469 9955 6727 3780 6822 7772 4579 8012 5052 7642 7590 2270 7863 4158 3974 16 3031 1926 9170 5409 8996 7947 7422 9402 6778 9127 966 9218 2191 4804 9068 2853 7491 646 8391 3168 932 9700 9822 3508 6959 5930 571 9234 1837 9262 5127 4796 5514 7955 1290 9936 9413 6800 5376 4345 6104 8716 8973 2840 3848 282 6162 281 8615 801 7179 4436 6162 7856 4686 6457 6521 9649 9606 5139 5830 5008 1946 2823 4828 2469 1596 6524 6826 6094 6504 6918 9213 7193 8090 8665 4291 1640 1929 7720 6390 1745 9810 760 9672 276 9293 244 6808 4243 2393 8078 360 4326 989 5957 605 9060 6528 8181 9277 7368 2152 9422 2853 538 1933 6886 4682 4204 4085 9640 9137 7140 8833 4406 4858 5635 3835 1087 1144 9548 344 1568 7159 1959 7567 7292 5489 8880 5157 9527 8589 1625 9905 9701 4676 6230 3581 6461 2759 3540 6758 8870 451 8295 4604 3492 1012 5492 4562 9343 4161 2762 6220 4418 4001 4156 1640 3863 7241 6462 7089 9796 3013 930 9825 8663 482 447 5809 9906 1741 7920 6155 9601 6156 2407 417 9109 4505 2118 3279 9476 8696 9289 6934 7635 2465 2107 8187 2468 2397 711 200 3894 7162 5660 9302 7720 9645 6760 3499 7533 7650 5515 3876 4457 9593 2735 5311 1710 8442 1516 427 4032 9997 2124 2050 9910 3088 726 2669 7656 4325 3655 6057 7653 3185 5712 3884 2747 8425 7053 4980 9273 5028 1004 2928 2587 6420 1888 7590 8474 5399 3899 7943 8187 6695 1481 5053 6608 9357 5565 2117 5553 9916 9980 682 3766 6832 8454 4491 8770 6997 2988 6895 3344 1344 4794 2252 413 6659 8133 3401 7670 8077 5401 7217 5797 4252 380 1045 4589 953 8575 6044 2851 4622 3938 4309 4381 5137 1084 1159 6559 6901 4699 3149 4675 3841 8864 348 798 6766 3206 4877 9314 8661 7207 8080 9153 4626 699 3152 9764 3870 4000 9929 5103 3779 9773 5038 5793 8264 7192 4928 860 848 8819 7787 2987 6954 2396 5743 9901 3300 6791 556 6498 5720 9583 2648 6020 8925 5211 9075 1227 6144 3748 9800 2305 3757 1122 6470 7903 9076 5662 3744 6250 4945 6037 5236 1045 6139 4601 4317 2250 8727 3139 5150 6918 3259 9907 8700 3839 6314 2948 1391 443 4077 1814 1805 5114 1518 6947 1346 6882 1068 8405 3548 4845 7283 386 5491 7258 313 9362 7782 741 9217 9474 2001 7443 600 9206 1251 9167 6787 5108 321 8746 9846 3012 584 1237 4113 8524 5124 2188 5100 5357 2785 7517 6920 7455 7406 5392 2156 1719 5266 4945 5070 4376 2131 5767 7391 4007 6929 804 5964 208 1952 1793 9437 1555 6945 8536 8187 5025 2163 6027 5022 3257 5936 9327 7013 3368 5768 6390 7626 6352 1781 3791 7812 2903 7409 1434 9507 1852 623 3823 973 1752 9863 5056 869 9923 2013 7575 4898 1288 8980 9525 125 8640 9053 9661 3486 2696 6432 6145 3758 4971 7820 2964 4978 5513 7139 2548 8906 8637 6829 9689 3230 2077 7319 6986 4032 6015 4815 830 6605 4807 1051 4609 4680 1282 2171 3546 8010 9646 3386 7332 2807 6315 7466 2853 7271 5605 5256 6543 146 7110 9026 6083 9747 2556 2550 8320 9256 9695 1683 4228 315 3394 6460 2853 592 7222 6929 9072 3107 4465 7474 6413 1383 1436 7602 6956 6145 452 769 5518 5267 9282 1721 5401 4055 2348 4999 2045 7202 7619 3408 6424 6923 6599 8859 644 8774 7785 4516 7891 6327 8509 5667 7171 2582 5630 3175 3063 8737 7502 7350 6312 4506 5573 3931 5174 7870 2217 8351 9590 4337 1609 9537 7932 5820 5607 7538 7199 6604 5506 9832 4080 4546 8287 9808 6697 6398 6927 8152 5806 7730 6673 6138 9763 5864 3379 4548 345 3946 6229 2499 1271 3227 3407 6685 3971 3032 1654 4098 4747 1872 251 7069 7806 9298 9800 2623 1738 1647 1067 4710 4205 8203 9329 9032 9302 3711 7495 2876 6524 8187 9412 3552 9184 1744 4162 8924 8329 333 6759 856 5776 1554 1458 8626 5953 9482 6306 2325 1577 2522 8463 2177 1824 7439 3320 1435 2072 4359 9588 2358 9297 2450 7599 2012 7269 4734 8013 7071 7054 6708 8236 3475 5404 7094 992 7330 3558 8686 4025 4369 9902 2792 3704 6592 7951 4364 926 2758 2698 522 7032 7501 2424 2662 7578 8214 7317 1928 353 6427 2111 3261 3744 9793 1598 8570 5571 2024 5568 4700 2370 5580 8716 4102 1010 2447 9914 3774 2529 8865 2208 8281 9915 4990 4016 3504 7766 3426 6709 4879 7094 4070 3273 1487 4314 9253 4616 9247 1396 1353 4950 8750 7009 115 9411 8774 9444 7034 4317 1366 1892 7884 7743 1233 9124 6390 7685 2450 9087 4764 1935 6875 9680 6452 3734 9285 2090 8904 7086 8105 7434 4174 2619 6866 1664 9535 6626 9624 6357 8180 3863 2535 8104 3045 1505 5994 6901 854 6791 2505 8730 9038 3001 9947 7171 3296 5400 2836 2893 1435 4303 4543 7262 3981 1589 5908 1433 2202 9461 2116 4150 6789 4952 2093 9859 4733 2244 1968 9183 6894 6131 8755 6047 7409 9746 6849 8835 5851 1389 710 9768 1308 6455 439 8 471 9832 1155 2035 6290 2095 7180 8566 5263 7077 8068 3670 7456 2741 7079 6506 7953 4290 9290 4272 1299 649 8487 5855 6572 7688 6241 542 4952 1710 8372 6973 1594 7482 5897 3036 3513 5530 3519 917 8888 5132 1189 9024 5996 6600 7635 8732 6080 3426 1296 1191 6207 2272 4407 3869 2815 9680 8087 4737 7417 2278 644 4808 3343 1485 1734 7684 9453 243 5691 8044 7827 4508 150 4708 7199 7106 368 8277 5213 8084 4634 1029 2547 9380 2583 5000 8011 8783 5462 3789 2176 6072 6880 4249 9384 6997 7987 437 2185 5025 2063 1390 9127 8423 9582 5143 4326 3171 9517 163 4022 8447 6914 629 2960 3307 2282 5675 5265 5476 1119 9011 7601 4026 9683 8777 6263 8192 4892 3372 226 795 9427 1924 1601 1787 8255 3127 7720 7186 385 8627 147 8759 3840 6543 1248 6591 7519 2573 7264 9128 1546 203 1587 2481 9619 957 9982 9285 7416 1959 9041 3326 3292 397 4799 664 4943 5641 3261 6446 6339 4482 9965 5634 4622 468 8278 2177 6893 1985 9226 165 6858 1947 3350 2631 8908 1764 3216 9242 8048 7801 998 9049 4788 4163 7087 8720 384 6875 2510 7074 6564 9230 1883 9042 3066 9424 7690 7519 4430 8829 3134 2327 3645 5800 368 6536 6955 7455 3427 1913 7588 192 2151 7531 7043 9064 2120 7340 8415 5522 9604 2767 1190 5644 4337 6977 2445 3028 9375 2180 2006 4788 4749 502 2371 4060 9149 7866 5383 7480 6999 3143 5463 4567 9402 7494 7589 2922 9385 688 2668 4664 4751 3196 6729 1993 5168 2970 294 4762 5957 8866 8773 7354 2504 4965 8667 7880 8741 1725 8141 4017 5782 8393 9612 6459 1276 4416 909 1530 5290 1336 9959 4983 6616 9481 827 6447 8645 1944 4413 1869 2344 9314 760 4869 1412 4969 9373 6708 3134 796 9978 5309 7239 230 6200 8288 1846 2538 3646 6686 5019 6053 8156 1285 2421 8855 6845 3829 5394 4167 9572 5047 7863 4554 3492 5750 6092 4947 8007 1980 274 869 6093 870 8723 8795 2513 2748 162 5883 1984 3575 4347 4065 8977 5104 5329 7039 8035 4408 2356 3101 1782 7591 8680 6367 7169 7270 559 7336 3382 8825 1455 4521 4360 1594 1051 5064 6929 5698 9706 2977 8434 1692 9525 7391 5231 1769 3242 8240 6190 7850 6854 2148 287 4969 941 3491 3662 1555 574 3138 5632 7343 4837 5349 7954 9828 5627 5172 7643 7567 8270 2032 2756 7545 6910 8085 1647 1120 2628 5491 9051 2084 8605 4561 7459 8599 5331 7959 9337 4895 1829 2994 5231 7893 6380 1947 4271 9296 378 7466 9857 5705 5289 6991 1456 7615 9313 6687 2423 10 7364 3338 7756 5182 938 9116 5336 2520 8400 3535 6837 3295 2330 4659 2914 8055 8371 8452 5540 8524 3635 2912 7731 6738 4138 13 5409 982 9942 6939 1721 952 5942 180 3161 9695 1279 1076 3492 3898 8920 1030 5606 1099 8416 9359 424 4998 9053 8594 3203 7512 9100 5908 1797 8628 6431 2128 9825 8779 8361 6561 5997 4147 6770 5341 2351 8305 5206 1599 7103 1457 6045 4788 4869 2570 9565 5608 7273 733 6658 4009 8068 6558 2474 2085 247 4425 8009 2161 6981 2278 1951 749 9887 5522 2551 7536 2514 5766 3747 7724 5552 7593 1373 7069 3868 2292 1968 3308 4550 4174 8470 6836 2831 4789 3860 724 864 7910 6935 9810 6290 6421 5874 9286 5872 6113 7603 7523 3435 3259 9208 3765 1471 4501 9169 7227 5215 6862 5462 9304 2199 9525 4493 8579 1956 429 6095 4507 4111 2662 27 693 7768 2012 7065 9503 9122 6801 5968 7692 9043 5972 3023 3844 8057 7198 122 551 2658 1963 3334 9670 2592 5964 2848 751 9752 4853 9104 2873 246 4742 2652 1250 1652 3991 4803 5865 8399 9379 8842 3880 4241 4657 8278 9118 3615 4109 8191 8577 2376 5377 1885 4704 7764 933 4489 4514 801 1557 2827 761 2605 4004 3834 7611 1867 4119 9886 5153 6925 1553 3140 4500 4287 6556 8191 6558 7191 2299 3465 9421 4130 9981 3378 2458 7913 6679 1325 7859 2642 4741 9720 2122 6814 8594 9454 6974 4352 754 1401 3441 4005 7484 463 6645 3207 9733 1719 1223 7972 1151 8450 9090 5839 9770 4103 8135 5154 1167 5458 4677 1765 9795 5802 224 4654 1275 9761 7716 3864 8738 4230 4130 216 689 4936 3105 6881 3938 2002 1453 4854 5575 9828 9960 1295 3874 3643 7034 1555 209 6568 3779 8834 2012 5431 8786 6449 8549 8768 4713 5036 1330 7305 1859 9151 1475 5774 3506 2196 6462 1050 4980 6117 8677 3344 4126 8887 1601 3567 2615 2722 1782 9029 517 7496 6475 5095 9409 4050 1556 3522 717 3517 2123 9165 4831 987 863 6979 5443 5750 6098 2071 7548 8283 3490 5481 1550 1863 9348 9757 9286 1873 3972 7948 2859 5571 9688 4785 8064 1019 6336 2376 6258 6502 6323 9314 3443 3095 3964 6474 5060 9191 6681 5697 8498 4512 7859 2012 9970 1737 2497 7519 9581 1953 4252 9375 2302 4013 3317 8341 5133 7475 8355 5913 709 4615 8015 7459 4320 6488 7729 9534 6925 6610 6965 116 4707 1649 5716 3136 2552 1400 247 2206 1344 3603 6429 1167 2178 9535 6786 6500 2211 9697 4117 864 1085 3033 3785 3390 5141 9610 9150 7351 1215 4860 959 2791 6073 4585 9485 483 8312 445 8386 1632 5217 6731 7954 137 6040 736 4831 6188 2877 6070 6967 7924 481 1126 3266 4485 5408 2477 3951 4575 6851 3883 2136 6028 8265 4748 2190 3316 675 7901 6004 2095 7477 4526 5966 3181 5696 5384 2841 9059 4732 5304 651 3314 7947 986 4959 5967 9178 5652 1799 6471 1948 7798 595 8763 6836 1512 1521 8101 1354 4509 1846 7955 3880 1525 5437 4029 4726 1013 869 5172 3271 5763 9869 9033 2043 9909 4689 8751 961 868 779 2528 8433 9333 6161 3047 5024 260 5502 2197 4710 9476 4848 8184 9361 7938 376 6602 2137 1329 4802 2055 8193 6954 4019 1428 1225 4301 9408 7331 9714 9066 3256 7219 3654 8946 1387 5317 9796 9630 215 8308 9463 2958 8277 9047 8852 991 7802 8273 4505 7139 7125 6208 1369 7887 9796 8339 8944 172 7099 9124 3935 9303 900 777 847 79 9658 3210 6465 2383 4786 1506 6145 831 9619 751 8973 7592 6712 8052 4678 9646 1718 6383 5004 5723 2440 8327 6269 5437 9206 3260 875 2217 2322 618 3369 5639 9444 9602 9485 5789 7890 2089 3602 9525 4172 7702 339 3507 2706 6900 3814 1619 7977 5098 1593 2626 5617 9749 2841 4894 5966 8142 3437 7927 5029 8698 2524 4882 2240 6648 1305 5471 399 7268 8483 5202 3220 823 7542 3074 8115 3788 7469 2493 6243 2786 1382 7776 5791 7794 7914 4078 3033 8487 8552 23 7175 6356 1308 8103 9934 147 7120 9892 438 5280 1894 3924 7000 5561 6310 8573 8691 1172 2871 2076 6017 2854 9475 7904 5342 6329 4647 2011 5015 2943 8093 6847 2162 9007 5718 1228 9743 3616 3878 7708 9130 2443 8757 1042 8615 4423 8844 435 2698 115 2873 7200 2457 8999 5770 5953 3492 355 2356 5168 842 1847 2578 1999 7408 2075 8452 9404 1139 93 7619 8166 4367 4098 6540 5634 1493 3527 7459 3245 2755 5578 6527 9235 173 2545 9625 4523 9708 691 1378 8658 6292 6207 8080 8373 5525 3235 2532 7795 9111 7593 9957 2199 6737 2505 9634 1390 7921 1412 5801 4403 5767 9185 6256 7284 2637 7427 8940 6435 3713 2295 298 2127 6229 5676 2913 5378 3504 3814 7384 6391 6660 3449 8303 8060 9198 5148 5120 2667 2698 5103 7931 6964 1385 3725 9281 6583 1256 75 1076 3266 9330 9818 4352 4200 6010 9405 9711 7125 59 3283 1109 9099 318 3685 2942 960 2649 8683 9891 1693 6539 2173 2041 3755 3248 9874 8275 8905 1721 3898 9776 5904 4281 8539 6007 2115 2131 5924 2295 2371 3332 971 4896 9961 4161 9553 3860 7360 3774 4636 948 2590 7589 4440 8194 370 8435 5314 6228 5214 7295 3596 1012 3640 9586 979 6336 9809 9547 4323 4449 485 2946 4405 9838 8497 100 6098 2583 916 3483 4632 4536 2227 7190 2156 133 5139 414 5503 3497 1129 6892 6805 7140 8454 554 8930 2955 3351 3016 2261 5969 329 7680 3701 845 4174 7182 4665 9703 8902 8927 3089 3637 3134 8543 6287 4733 7041 3627 2139 4475 9332 4450 4194 2563 377 7844 940 5631 4832 2462 3338 9737 3209 3349 6363 4852 8806 8522 4707 7205 5274 3202 5894 7700 4645 8671 8176 8265 604 2273 3047 1430 3162 824 1473 6970 7641 4097 3619 2685 8757 2394 7223 6471 2963 2929 3217 9125 9559 9400 548 5596 39 6750 8602 7580 710 5310 1858 9382 1592 53 9119 7371 5253 5438 9332 4403 2121 6577 1768 690 5034 7831 4802 9925 8897 7657 4510 6860 2310 3310 5055 5871 8944 7773 9436 8577 5456 1413 1223 7834 5749 9215 9151 9447 1787 7624 1901 5335 672 3872 2399 411 4043 9171 730 1885 5970 3180 9867 5251 7849 6097 2133 352 4045 1053 802 6353 465 5694 2303 3545 7568 9403 1546 6003 4924 6667 7199 7481 1948 3312 2913 1406 1958 8078 2624 7044 3250 8957 3163 7017 4207 387 2723 8802 2951 9527 3427 9448 2085 5414 3356 8599 3121 5996 7429 6251 9794 2982 2635 8075 6066 745 2948 4677 9638 4805 9381 4084 8617 4049 721 5058 4560 9591 4808 4694 6491 9671 9254 5364 7608 7775 5271 7281 8245 3081 9116 3916 3108 3366 9929 411 5150 6508 7878 1141 5874 2438 1117 7540 9291 9189 2434 2701 5046 379 811 208 3829 5819 5987 7302 9520 4747 1667 5933 2933 8500 1075 2844 7487 63 8341 8735 6167 2604 4610 4991 5922 1739 343 8041 416 4904 5630 2853 6142 7275 4112 555 6335 8985 3154 1810 4480 9771 1096 1056 9790 6392 9152 418 7050 9906 1123 3848 2617 8137 9183 9428 8506 2064 7885 162 1276 6894 6858 1469 1459 88 6398 6672 40 7158 8380 340 1142 419 8263 1293 3694 6059 4324 3609 3046 7998 7858 5238 3966 6802 5854 5587 2920 6753 2599 7878 3776 8677 7004 9612 3505 6475 8354 2340 3867 6961 8888 700 6573 850 808 1719 6296 3455 4087 8300 5738 5925 8424 1598 4649 8052 9475 5073 6289 6633 7127 9005 9693 3156 8179 8911 5730 9484 7045 7364 4705 1720 444 6946 2780 1126 4314 1396 5037 4874 7899 9187 2943 3396 4321 4695 1396 5654 7286 131 3793 3203 9768 1849 2147 8538 8121 2358 7328 2402 4428 6321 3909 1480 9003 7924 6290 3230 5283 5408 4032 6410 4373 9893 6165 7035 3240 773 2616 1801 3163 2911 7685 7883 7993 2868 9492 5517 8290 9394 2252 234 2684 3134 6201 1688 307 4721 6799 3132 7847 1318 7562 8881 8135 4793 6706 3049 7824 1870 9099 2604 433 8905 7426 2064 4263 4259 7844 1825 3606 9201 4498 9546 9988 9347 5220 8312 4563 5561 4070 6532 8537 6336 5509 3255 3123 4567 6774 529 6971 2900 5912 869 7631 8030 9111 5446 1473 4455 106 4911 2247 6456 7409 9973 9326 4598 4988 3912 5591 2776 5821 201 1397 2968 5266 2773 8530 6822 4729 5877 3775 5848 765 858 9234 9697 2165 5457 4027 9388 9411 6437 8418 5544 6611 1259 144 3978 4438 6415 2785 8187 8408 9866 6638 8843 1174 7072 200 5426 2986 3641 3435 9334 2541 8896 2676 8843 7476 5886 7421 7958 2828 5706 329 7937 7355 1587 5382 5675 8372 1423 6681 9159 4055 5719 5603 3135 6960 6655 8666 5445 3797 2211 5483 5023 4516 7041 169 8012 3528 3546 9170 3048 2326 1720 4832 8492 7320 9158 781 1255 6268 338 442 4235 4712 6650 3126 8022 1697 5479 850 3468 3832 4354 6933 9151 2262 1942 4418 8972 482 4223 8013 342 3475 1617 9761 4146 3778 2909 572 4009 4186 6196 9474 8596 4030 6287 8298 472 4465 1216 2582 7507 3761 5136 3347 1424 3760 3412 4004 8373 4878 1348 2760 7589 6381 721 3833 3283 7007 6907 4682 9487 9228 6652 4294 8193 6547 5884 5868 9812 5030 3484 732 117 673 1471 4854 2404 3544 5815 8957 6746 1367 4561 6861 6640 3390 4713 8670 5611 8961 4183 492 4348 2801 2746 8373 5645 9051 9107 4471 8777 66 8852 5496 886 2158 7574 2269 8995 7083 4326 6737 4026 5609 8636 103 8285 4032 2270 4051 4603 4959 3776 7985 8206 6797 1487 2364 5129 3853 1778 5877 6135 1571 6537 7813 8276 9018 2341 2228 4999 2548 3294 23 7843 2643 5980 3922 1978 5141 153 4552 2068 2929 3520 8532 7610 5158 80 6450 4631 2821 256 147 4270 5101 5832 7243 6142 6650 6240 8673 3545 7939 8489 7219 6146 6812 6668 5657 1917 6922 722 1916 5195 3647 7146 4519 900 1193 6633 2344 4751 397 3067 5864 9998 7325 8373 2038 4821 4330 631 3257 4307 9688 7115 4000 6131 5358 8541 6295 385 1951 6345 8972 827 8183 7004 2409 6095 9657 5534 9371 2273 4104 2646 7338 2363 9757 9086 1325 3875 3154 5931 2 2139 2592 5502 626 9018 287 1608 643 1196 4744 664 8366 1387 9891 3979 6828 8305 2068 5998 4788 6445 7757 8252 2546 3954 3421 5193 8961 2670 9328 7739 8074 9968 9191 8780 3640 2171 5965 7142 1832 2067 8573 7432 8868 3085 42 9804 8100 6119 8729 6841 2634 5571 1645 4297 1317 6042 1938 6594 5233 3564 9607 9574 9029 8132 8383 9811 8126 2133 4021 589 212 1836 7688 5161 6043 5146 124 4364 3452 5259 3441 3949 3057 1970 7240 2079 6954 8440 5525 8894 9368 1155 4821 136 248 1504 8606 714 3038 4701 8078 2929 8037 4325 6040 4822 925 7117 1534 7980 5649 2513 1057 9397 5066 7180 8912 9003 7837 8309 1340 3299 336 9587 7550 1976 2585 4370 8122 399 4646 6978 7562 4777 8103 5882 1068 5125 8253 7695 8007 8331 7033 8778 2081 5536 5846 7888 716 8465 2522 407 7530 3795 3074 5024 3867 5415 6587 1286 307 4466 7624 7890 9245 1009 7273 8143 9460 5859 7697 1435 6430 2417 7143 3919 2367 1351 9015 5623 5804 4711 1869 5496 424 1356 450 9044 8597 5960 890 3590 6843 8687 9308 2087 26 79 8322 5374 8622 8313 2795 5916 4388 7830 4218 5422 3013 8614 3178 9904 5475 430 9416 1342 571 2648 8129 9994 961 5757 9423 6030 4614 3977 5800 9439 9184 8040 9054 5466 4373 8605 3837 3407 3956 9111 2571 3779 6264 4200 4871 5896 3603 1956 7250 2857 6001 7361 9824 7584 7102 8929 3321 4318 7641 8979 1592 7329 6294 5817 1775 6539 1914 1459 2710 1002 6121 1144 1909 6425 1466 409 6410 8994 6606 1444 2518 757 675 3253 2900 1262 495 8055 3778 1852 2885 554 4828 6145 311 7178 2946 303 6063 8160 2308 6946 8424 5519 824 9416 874 4002 4753 7802 6824 3136 9277 8722 8689 1087 5032 2233 5362 307 795 5075 3456 6937 6170 4821 9309 4306 4282 7528 2088 3892 4345 4749 5508 5165 5925 4552 3967 9143 2235 4329 7510 6627 4329 2381 6707 4359 9443 4198 1266 3824 4725 3186 914 8614 5850 4292 7376 7988 704 3810 1915 9075 3357 5263 9097 1939 6923 6754 1025 5787 5116 7595 368 8797 2866 1176 8768 1441 2576 8455 3039 8762 4725 8514 8448 3763 9125 9030 7541 4789 2739 4702 984 8804 4278 1292 2329 3216 5661 5856 7522 8287 2554 8016 6881 506 3743 2253 528 1855 8299 112 9428 2373 9013 5672 6011 1415 4337 4111 151 6396 7145 4854 6886 1785 3813 8049 5912 6940 2944 2022 1689 4046 3217 2042 890 8135 4667 3907 1159 2321 6406 3496 7670 1189 372 1842 1551 2205 8631 6332 9140 1803 3052 8667 4794 4354 6804 487 8247 3840 9261 6392 2372 846 8694 1819 1450 4141 8828 5099 9532 4397 3886 8435 9193 2573 5427 2744 5820 7599 5126 7196 1520 4570 2393 2146 5312 5579 6404 1630 1380 4851 2539 4982 9130 2567 6097 7542 6539 3542 9153 7424 6054 1213 9042 7103 8130 8903 9877 7040 3737 6276 7219 2092 780 2531 8103 2992 506 1287 5414 3231 8 3339 3924 8016 7901 6622 1157 7667 3265 1340 3263 8697 9859 5612 102 2465 4067 4344 8741 4383 9437 2116 557 3776 6667 4218 75 8508 9901 3725 8763 6766 7884 4484 7850 1377 4062 3562 4115 106 6455 7706 4186 2429 843 8936 3429 9259 2370 1979 3322 4527 2492 5878 3860 6655 1094 2331 3033 8753 3661 2829 4666 2782 8460 7356 4659 783 6420 2672 1144 1568 4660 5909 3545 9656 3927 8662 9021 37 8541 5341 1769 245 4995 2148 5800 8005 9318 3003 6237 5401 3721 2399 4525 526 1075 204 5764 9670 7340 8874 5435 7397 7158 5920 5305 8842 1481 6270 6840 3770 685 5273 3743 9941 4151 49 3642 7585 7098 5873 3207 3674 7292 3847 798 4133 2441 4276 4247 5803 3183 6761 9603 1988 4707 5162 7908 3843 6126 2890 6477 5849 2179 4468 9810 6794 1563 2137 3117 7840 6517 1768 9923 2394 8628 2458 6427 6518 8354 5744 8457 6219 6730 5739 2166 3779 1393 6637 8212 4741 6637 7488 3051 7764 4166 8882 9189 5123 8349 2363 2728 103 2378 9611 3665 3079 2000 9315 1842 599 613 8860 7767 7472 758 6771 8564 9363 1951 7654 1177 3190 7930 5347 5610 8334 5595 1710 6473 8281 543 2382 1843 1402 3133 8999 5771 4944 9906 2742 7163 5930 7245 8898 2939 6067 9550 6251 3071 8531 600 8146 1698 2738 5385 526 343 2062 3437 6884 5735 7478 8854 4008 6371 9851 2115 268 236 6311 9438 7775 8528 2753 4381 5089 5568 2705 9831 5196 6532 2150 2295 5125 5982 480 4761 8111 6532 3243 1049 2964 2095 1929 5742 1647 8932 9137 6150 4143 9915 2965 216 7242 192 5400 4215 96 8145 4618 397 6710 9449 4462 3109 2187 7738 6367 2483 8834 4150 6943 1484 7965 306 2818 5856 8571 8731 2362 4277 1900 1015 2355 184 8458 9702 7257 4850 3681 1581 985 2206 8495 6172 8577 6107 570 5550 1155 3016 2083 1932 4972 7903 7609 8049 7069 366 1050 778 367 6502 7621 5952 9647 7285 6093 8962 4121 6029 1433 7735 4121 4097 9398 8048 2755 1762 1204 1183 8631 9563 2605 1309 7422 4025 3900 4606 5132 7912 3609 2904 1155 7008 238 384 494 2693 8340 9202 2469 5568 7907 6181 8541 2662 9468 4989 8098 5715 5416 7734 4202 7277 4988 5524 8823 8222 9388 2995 3235 9256 1497 4148 5818 6599 9935 1165 3329 4405 8917 4007 944 6600 9648 8893 8487 3954 4529 1949 2127 247 7999 2793 1514 4240 8627 8167 3947 6872 7969 8136 1227 4955 6059 8578 2796 6938 4609 5547 2450 3312 2800 8684 5343 8259 8152 7111 211 7968 487 3985 389 2973 3586 7342 8683 3392 4895 3845 6381 34 762 3333 5435 4027 4492 4132 4193 354 7636 9274 4758 8415 6959 7577 6818 8803 2120 7331 1993 7833 1480 2029 3003 2737 6255 7429 1428 4817 5051 3505 5923 9275 2581 9726 5356 3667 6581 6256 8456 780 2328 7392 6795 4742 7076 6716 4855 127 9447 609 1827 2134 1205 4449 3755 2268 8909 7894 180 2633 5006 2328 9779 1198 5164 5288 3289 7076 700 5779 999 3092 2499 1913 8333 4889 4796 4637 3479 9688 693 8254 762 1404 2988 5338 7312 3437 4647 1699 847 4131 6597 9198 2661 1591 5856 7357 8696 8331 8886 4621 8923 5148 2669 7016 5168 5550 7056 7893 6632 6998 9335 8849 7808 9648 8740 6686 5895 7659 1596 765
diff --git a/tests/unit-tests/torrent-file.t.cpp b/tests/unit-tests/torrent-file.t.cpp
index abd224a..955d54c 100644
--- a/tests/unit-tests/torrent-file.t.cpp
+++ b/tests/unit-tests/torrent-file.t.cpp
@@ -22,11 +22,18 @@
#include "boost-test.hpp"
#include "torrent-file.hpp"
+#include "file-manifest.hpp"
#include <ndn-cxx/data.hpp>
#include <ndn-cxx/signature.hpp>
#include <ndn-cxx/security/key-chain.hpp>
+#include <boost/range/adaptors.hpp>
+#include <boost/filesystem.hpp>
+#include <boost/filesystem/fstream.hpp>
+
+namespace fs = boost::filesystem;
+
namespace ndn {
namespace ntorrent {
@@ -35,81 +42,81 @@
const static uint8_t TorrentFileTest[] = {
- 0x6, 0xfd,
- 0x1, 0xe4,
- 0x7, 0x25,
+ 0x6, 0xfd, // data
+ 0x1, 0xea,
+ 0x7, 0x2c, // name
0x8, 0x8,
0x4e, 0x54, 0x4f, 0x52, 0x52, 0x45, 0x4e, 0x54,
0x8, 0xa,
0x6c, 0x69, 0x6e, 0x75, 0x78, 0x31, 0x35, 0x2e, 0x30, 0x31,
- 0x8, 0xd,
- 0x2e, 0x74, 0x6f, 0x72, 0x72, 0x65, 0x6e, 0x74, 0x2d, 0x66, 0x69, 0x6c, 0x65,
- 0x14, 0x0,
- 0x15, 0x77,
- 0x7, 0x37,
- 0x8, 0x8,
- 0x4e, 0x54, 0x4f, 0x52, 0x52, 0x45, 0x4e, 0x54,
- 0x8, 0xa,
- 0x6c, 0x69, 0x6e, 0x75, 0x78, 0x31, 0x35, 0x2e, 0x30, 0x31,
- 0x8, 0xd,
- 0x2e, 0x74, 0x6f, 0x72, 0x72, 0x65, 0x6e, 0x74, 0x2d, 0x66, 0x69, 0x6c, 0x65,
- 0x8, 0x8,
- 0x73, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x32,
- 0x8, 0x6,
- 0x41, 0x45, 0x33, 0x32, 0x31, 0x43,
- 0x7, 0x16,
- 0x8, 0x8,
- 0x4e, 0x54, 0x4f, 0x52, 0x52, 0x45, 0x4e, 0x54,
- 0x8, 0xa,
- 0x6c, 0x69, 0x6e, 0x75, 0x78, 0x31, 0x35, 0x2e, 0x30, 0x31,
- 0x7, 0x11,
- 0x8, 0x5,
- 0x66, 0x69, 0x6c, 0x65, 0x30,
- 0x8, 0x8,
- 0x31, 0x41, 0x32, 0x42, 0x33, 0x43, 0x34, 0x44,
- 0x7, 0x11,
- 0x8, 0x5,
- 0x66, 0x69, 0x6c, 0x65, 0x31,
- 0x8, 0x8,
- 0x32, 0x41, 0x33, 0x42, 0x34, 0x43, 0x35, 0x45,
- 0x16, 0x3c,
- 0x1b, 0x1,
- 0x1,
- 0x1c, 0x37,
- 0x7, 0x35,
- 0x8, 0xc,
- 0x74, 0x6d, 0x70, 0x2d, 0x69, 0x64, 0x65, 0x6e, 0x74, 0x69, 0x74, 0x79,
- 0x8, 0x4,
- 0x3d, 0xa8, 0x2c, 0x19,
- 0x8, 0x3,
- 0x4b, 0x45, 0x59,
- 0x8, 0x11,
- 0x6b, 0x73, 0x6b, 0x2d, 0x31, 0x34, 0x35, 0x34, 0x39, 0x37, 0x33, 0x38, 0x37, 0x36, 0x31, 0x37, 0x31,
- 0x8, 0x7,
- 0x49, 0x44, 0x2d, 0x43, 0x45, 0x52, 0x54,
- 0x17, 0xfd,
- 0x1, 0x0, 0x37, 0x61, 0xc9, 0x3b, 0x43, 0xe8, 0xa3, 0xcd, 0xf0, 0xb1,
- 0x14, 0x78, 0x50, 0x6, 0x3c, 0x8a, 0x7, 0x4d, 0xe4, 0xa8, 0xbe, 0xc1,
- 0x8c, 0x40, 0xaf, 0xaa, 0x21, 0x9f, 0x58, 0xed, 0xc0, 0x99, 0x92, 0xb8,
- 0xb2, 0xb8, 0xac, 0x4, 0x3f, 0xa2, 0x25, 0xd7, 0x68, 0xa9, 0x5e, 0xc6,
- 0xf5, 0x20, 0x69, 0xe3, 0xf, 0x37, 0xfc, 0xc7, 0x3f, 0x72, 0x8, 0x74,
- 0x8, 0x5e, 0x10, 0x4d, 0xef, 0xa3, 0x58, 0x59, 0xb6, 0x90, 0x53, 0x1c,
- 0x4b, 0x22, 0xb0, 0x3e, 0x87, 0x95, 0x5b, 0xa6, 0xd, 0x84, 0x1f, 0x60,
- 0xda, 0xe, 0x22, 0x29, 0xda, 0x38, 0x1c, 0x90, 0x4a, 0x2a, 0x60, 0xe4,
- 0xc9, 0x36, 0xb6, 0x4f, 0x9a, 0x17, 0x69, 0x99, 0xf4, 0x84, 0xa5, 0x5b,
- 0xec, 0x70, 0x34, 0x1b, 0xbc, 0x14, 0xee, 0xb1, 0xa7, 0x42, 0xb7, 0xd8,
- 0x9, 0x45, 0xe0, 0x2d, 0x4, 0x8f, 0x66, 0xdb, 0x43, 0x68, 0x8e, 0x53,
- 0x94, 0x1e, 0xcd, 0xaa, 0x47, 0x80, 0xaf, 0xd0, 0x1d, 0x6b, 0x21, 0x1,
- 0x5a, 0x36, 0x97, 0x87, 0x44, 0xc9, 0x31, 0x57, 0xcd, 0x5d, 0xc1, 0xa5,
- 0xfc, 0x35, 0xb1, 0x60, 0x29, 0xc6, 0x82, 0xe9, 0x52, 0x33, 0xac, 0xf9,
- 0xb, 0xca, 0xbe, 0x62, 0x8b, 0x88, 0x49, 0x9a, 0x6f, 0xbd, 0xed, 0x1e,
- 0x8c, 0x4c, 0x63, 0xfb, 0xd9, 0x20, 0xcb, 0x1c, 0x66, 0xa4, 0xb9, 0xc,
- 0x21, 0x61, 0xc4, 0x56, 0x4c, 0xa8, 0x58, 0x4b, 0x7a, 0x81, 0x2c, 0xf0,
- 0x2f, 0xce, 0x7d, 0x1d, 0xbf, 0x16, 0xc, 0x74, 0x35, 0x83, 0x8a, 0x22,
- 0xc4, 0x2, 0xeb, 0x42, 0xd3, 0x76, 0x36, 0x8a, 0x71, 0x7b, 0x6b, 0xb8,
- 0x3f, 0x7a, 0xb8, 0xc6, 0xf6, 0xca, 0xed, 0x74, 0xdb, 0xa4, 0x42, 0x65,
- 0xa5, 0x96, 0xde, 0xd9, 0xfa, 0x45, 0x25, 0x9a, 0xc1, 0xde, 0xd1, 0xf6,
- 0x7a, 0xaf, 0xa3, 0xfd, 0x4e, 0xa9
+ 0x8, 0xc,
+ 0x74, 0x6f, 0x72, 0x72, 0x65, 0x6e, 0x74, 0x2d, 0x66, 0x69, 0x6c, 0x65,
+ 0x8, 0x6,
+ 0x41, 0x42, 0x32, 0x43, 0x44, 0x41,
+ 0x14, 0x0, // meta-info
+ 0x15, 0x76, // content
+ 0x7, 0x36,
+ 0x8, 0x8,
+ 0x4e, 0x54, 0x4f, 0x52, 0x52, 0x45, 0x4e, 0x54,
+ 0x8, 0xa,
+ 0x6c, 0x69, 0x6e, 0x75, 0x78, 0x31, 0x35, 0x2e, 0x30, 0x31,
+ 0x8, 0xc,
+ 0x74, 0x6f, 0x72, 0x72, 0x65, 0x6e, 0x74, 0x2d, 0x66, 0x69, 0x6c, 0x65,
+ 0x8, 0x8,
+ 0x73, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x32,
+ 0x8, 0x6,
+ 0x41, 0x45, 0x33, 0x32, 0x31, 0x43,
+ 0x7, 0x16,
+ 0x8, 0x8,
+ 0x4e, 0x54, 0x4f, 0x52, 0x52, 0x45, 0x4e, 0x54,
+ 0x8, 0xa,
+ 0x6c, 0x69, 0x6e, 0x75, 0x78, 0x31, 0x35, 0x2e, 0x30, 0x31,
+ 0x7, 0x11,
+ 0x8, 0x5,
+ 0x66, 0x69, 0x6c, 0x65, 0x30,
+ 0x8, 0x8,
+ 0x31, 0x41, 0x32, 0x42, 0x33, 0x43, 0x34, 0x44,
+ 0x7, 0x11,
+ 0x8, 0x5,
+ 0x66, 0x69, 0x6c, 0x65, 0x31,
+ 0x8, 0x8,
+ 0x32, 0x41, 0x33, 0x42, 0x34, 0x43, 0x35, 0x45,
+ 0x16, 0x3c, // SignatureInfo
+ 0x1b, 0x1, // SignatureType
+ 0x1,
+ 0x1c, 0x37, // KeyLocator
+ 0x7, 0x35,
+ 0x8, 0xc,
+ 0x74, 0x6d, 0x70, 0x2d, 0x69, 0x64, 0x65, 0x6e, 0x74, 0x69, 0x74, 0x79,
+ 0x8, 0x4,
+ 0x3d, 0xa8, 0x2c, 0x19,
+ 0x8, 0x3,
+ 0x4b, 0x45, 0x59,
+ 0x8, 0x11,
+ 0x6b, 0x73, 0x6b, 0x2d, 0x31, 0x34, 0x35, 0x34, 0x39, 0x37, 0x33, 0x38,
+ 0x37, 0x36, 0x31, 0x37, 0x31,
+ 0x8, 0x7,
+ 0x49, 0x44, 0x2d, 0x43, 0x45, 0x52, 0x54,
+ 0x17, 0xfd, // SignatureValue
+ 0x1, 0x0, 0x3d, 0xb6, 0x32, 0x59, 0xbd, 0xe5, 0xad, 0x27, 0x1b, 0xc2, 0x68,
+ 0x3d, 0x7a, 0xd3, 0x4e, 0xf, 0x40, 0xa5, 0xf8, 0x80, 0x4b, 0xf2, 0xf9, 0xb1,
+ 0x7, 0xea, 0x56, 0x84, 0xd, 0x94, 0xd, 0xf9, 0x88, 0xd4, 0xe0, 0xb6, 0x63, 0xac,
+ 0x3a, 0xdc, 0x17, 0xc2, 0xff, 0xde, 0xc, 0xc3, 0xef, 0xb, 0x3b, 0x1a, 0xef, 0xb,
+ 0x7, 0x99, 0x9b, 0xb7, 0xe6, 0x4a, 0x68, 0xf8, 0xda, 0x62, 0x29, 0xfd, 0xb1, 0xb1,
+ 0xe9, 0xe3, 0x3a, 0x42, 0x1f, 0xbd, 0xad, 0x96, 0xc4, 0x5f, 0x34, 0x55, 0x9, 0xba,
+ 0x7a, 0x82, 0x2d, 0x9c, 0x7b, 0x52, 0x9d, 0xf, 0xd6, 0xea, 0xc3, 0x60, 0xbf, 0x75,
+ 0xfb, 0x0, 0x1b, 0xb8, 0x4, 0xa8, 0x6e, 0x95, 0x5a, 0xcf, 0xca, 0x90, 0x20, 0x21,
+ 0x58, 0x27, 0x2c, 0xef, 0xed, 0x23, 0x37, 0xfa, 0xd, 0xc6, 0x3, 0x7b, 0xd6, 0xef,
+ 0x76, 0x3, 0xd7, 0x22, 0xd8, 0x6f, 0xa2, 0x7d, 0xc2, 0x84, 0xee, 0x65, 0xbf, 0x63,
+ 0xe2, 0x27, 0xc4, 0xeb, 0xb7, 0xb2, 0xa6, 0xa0, 0x58, 0x68, 0x1a, 0x3a, 0x85, 0xd8,
+ 0x8d, 0xd8, 0xfb, 0x52, 0x9b, 0xba, 0x22, 0x2d, 0xb2, 0x4b, 0x9e, 0x3d, 0xf5, 0x61,
+ 0x83, 0x6f, 0x78, 0x67, 0x85, 0x3d, 0xf, 0x24, 0x47, 0xbf, 0x8c, 0xdf, 0xdf, 0x8a,
+ 0xc8, 0xa9, 0xed, 0xaf, 0x8b, 0x49, 0xdf, 0x2d, 0x2a, 0xfe, 0x2f, 0x4b, 0xc5, 0xe6,
+ 0x7e, 0xee, 0x35, 0xf1, 0x6, 0x88, 0x9c, 0xa0, 0x25, 0xf, 0x6, 0x56, 0xf4, 0x72,
+ 0x89, 0x2f, 0x95, 0x64, 0x39, 0x38, 0x21, 0xc3, 0x75, 0xef, 0x80, 0x5a, 0x73, 0x1a,
+ 0xec, 0xb9, 0x6d, 0x3, 0x47, 0xac, 0x64, 0x7f, 0x85, 0xbe, 0xb9, 0xab, 0x87, 0x9f,
+ 0xd2, 0x9c, 0xe7, 0x9c, 0x86, 0xd5, 0x59, 0x65, 0x73, 0x24, 0x15, 0x3e, 0xfc, 0x94,
+ 0xf8, 0x7, 0x26, 0x9b, 0x4f, 0x6e, 0x1b, 0x1c
};
BOOST_AUTO_TEST_SUITE(TestTorrentFile)
@@ -117,31 +124,32 @@
BOOST_AUTO_TEST_CASE(CheckGettersSetters)
{
- TorrentFile file("/NTORRENT/linux15.01/.torrent-file",
- "/NTORRENT/linux15.01/.torrent-file/segment2/AE321C",
+ TorrentFile file("/NTORRENT/linux15.01/torrent-file/AB2CDA",
+ "/NTORRENT/linux15.01/torrent-file/segment2/AE321C",
"/NTORRENT/linux15.01",
{"/NTORRENT/linux15.01/file0/1A2B3C4D",
"/NTORRENT/linux15.01/file1/2A3B4C5E"});
- BOOST_CHECK_EQUAL(file.getName(), "/NTORRENT/linux15.01/.torrent-file");
+ BOOST_CHECK_EQUAL(file.getName(), "/NTORRENT/linux15.01/torrent-file/AB2CDA");
BOOST_CHECK_EQUAL(file.getCatalog().size(), 2);
- BOOST_CHECK_EQUAL(*(file.getTorrentFilePtr()), "/NTORRENT/linux15.01/.torrent-file/segment2/AE321C");
+ BOOST_CHECK_EQUAL(*(file.getTorrentFilePtr()),
+ "/NTORRENT/linux15.01/torrent-file/segment2/AE321C");
BOOST_CHECK_EQUAL(file.getCatalog()[0], "/NTORRENT/linux15.01/file0/1A2B3C4D");
BOOST_CHECK_EQUAL(file.getCatalog()[1], "/NTORRENT/linux15.01/file1/2A3B4C5E");
- TorrentFile file2("/NTORRENT/linux15.01/.torrent-file",
+ TorrentFile file2("/NTORRENT/linux15.01/torrent-file/AB2CDA",
"/NTORRENT/linux15.01",
{"/NTORRENT/linux15.01/file0/1A2B3C4D"});
- BOOST_CHECK_EQUAL(file2.getName(), "/NTORRENT/linux15.01/.torrent-file");
+ BOOST_CHECK_EQUAL(file2.getName(), "/NTORRENT/linux15.01/torrent-file/AB2CDA");
BOOST_CHECK(!file2.getTorrentFilePtr());
BOOST_CHECK_EQUAL(file2.getCatalog().size(), 1);
}
BOOST_AUTO_TEST_CASE(CheckEncodeDecode)
{
- TorrentFile file("/NTORRENT/linux15.01/.torrent-file",
- "/NTORRENT/linux15.01/.torrent-file/segment2/AE321C",
+ TorrentFile file("/NTORRENT/linux15.01/torrent-file/AB2CDA",
+ "/NTORRENT/linux15.01/torrent-file/segment2/AE321C",
"/NTORRENT/linux15.01",
{"/NTORRENT/linux15.01/file0/1A2B3C4D",
"/NTORRENT/linux15.01/file1/2A3B4C5E"});
@@ -155,8 +163,9 @@
TorrentFile file2;
file2.wireDecode(wire);
- BOOST_CHECK_EQUAL(file2.getName(), "/NTORRENT/linux15.01/.torrent-file");
- BOOST_CHECK_EQUAL(*(file2.getTorrentFilePtr()), "/NTORRENT/linux15.01/.torrent-file/segment2/AE321C");
+ BOOST_CHECK_EQUAL(file2.getName(), "/NTORRENT/linux15.01/torrent-file/AB2CDA");
+ BOOST_CHECK_EQUAL(*(file2.getTorrentFilePtr()),
+ "/NTORRENT/linux15.01/torrent-file/segment2/AE321C");
BOOST_CHECK_EQUAL(file2.getCatalog().size(), 2);
BOOST_CHECK_EQUAL(file2.getCatalog()[0], "/NTORRENT/linux15.01/file0/1A2B3C4D");
BOOST_CHECK_EQUAL(file2.getCatalog()[1], "/NTORRENT/linux15.01/file1/2A3B4C5E");
@@ -165,7 +174,7 @@
BOOST_AUTO_TEST_CASE(CheckEncodeDecodeNoTorrentFilePtr)
{
- TorrentFile file("/NTORRENT/linux15.01/.torrent-file",
+ TorrentFile file("/NTORRENT/linux15.01/torrent-file/AB2CDA",
"/NTORRENT/linux15.01",
{"/NTORRENT/linux15.01/file0/1A2B3C4D",
"/NTORRENT/linux15.01/file1/2A3B4C5E"});
@@ -179,7 +188,7 @@
TorrentFile file2;
file2.wireDecode(wire);
- BOOST_CHECK_EQUAL(file2.getName(), "/NTORRENT/linux15.01/.torrent-file");
+ BOOST_CHECK_EQUAL(file2.getName(), "/NTORRENT/linux15.01/torrent-file/AB2CDA");
BOOST_CHECK(!file2.getTorrentFilePtr());
BOOST_CHECK_EQUAL(file2.getCatalog().size(), 2);
BOOST_CHECK_EQUAL(file2.getCatalog()[0], "/NTORRENT/linux15.01/file0/1A2B3C4D");
@@ -188,7 +197,7 @@
BOOST_AUTO_TEST_CASE(CheckEncodeDecodeEmptyTorrentFile)
{
- TorrentFile file("/NTORRENT/linux15.01/.torrent-file",
+ TorrentFile file("/NTORRENT/linux15.01/torrent-file/AB2CDA",
"",
{});
@@ -207,8 +216,8 @@
BOOST_AUTO_TEST_CASE(CheckEncodeDecodeEmptyCatalog)
{
- TorrentFile file("/NTORRENT/linux15.01/.torrent-file",
- "/NTORRENT/linux15.01/.torrent-file/segment2/AE321C",
+ TorrentFile file("/NTORRENT/linux15.01/torrent-file/AB2CDA",
+ "/NTORRENT/linux15.01/torrent-file/segment2/AE321C",
"/NTORRENT/linux15.01",
{});
@@ -229,8 +238,9 @@
Block TorrentFileBlock(TorrentFileTest, sizeof(TorrentFileTest));
TorrentFile file(TorrentFileBlock);
- BOOST_CHECK_EQUAL(file.getName(), "/NTORRENT/linux15.01/.torrent-file");
- BOOST_CHECK_EQUAL(*(file.getTorrentFilePtr()), "/NTORRENT/linux15.01/.torrent-file/segment2/AE321C");
+ BOOST_CHECK_EQUAL(file.getName(), "/NTORRENT/linux15.01/torrent-file/AB2CDA");
+ BOOST_CHECK_EQUAL(*(file.getTorrentFilePtr()),
+ "/NTORRENT/linux15.01/torrent-file/segment2/AE321C");
BOOST_CHECK_EQUAL(file.getCatalog().size(), 2);
BOOST_CHECK_EQUAL(file.getCatalog()[0], "/NTORRENT/linux15.01/file0/1A2B3C4D");
BOOST_CHECK_EQUAL(file.getCatalog()[1], "/NTORRENT/linux15.01/file1/2A3B4C5E");
@@ -239,8 +249,8 @@
BOOST_AUTO_TEST_CASE(TestInsertErase)
{
- TorrentFile file("/NTORRENT/linux15.01/.torrent-file",
- "/NTORRENT/linux15.01/.torrent-file/segment2/AE321C",
+ TorrentFile file("/NTORRENT/linux15.01/torrent-file/AB2CDA",
+ "/NTORRENT/linux15.01/torrent-file/segment2/AE321C",
"/NTORRENT/linux15.01",
{"/NTORRENT/linux15.01/file0/1A2B3C4D",
"/NTORRENT/linux15.01/file1/2A3B4C5E"});
@@ -258,8 +268,8 @@
BOOST_AUTO_TEST_CASE(TestInsertAndEncodeTwice)
{
- TorrentFile file("/NTORRENT/linux15.01/.torrent-file",
- "/NTORRENT/linux15.01/.torrent-file/segment2/AE321C",
+ TorrentFile file("/NTORRENT/linux15.01/torrent-file/AB2CDA",
+ "/NTORRENT/linux15.01/torrent-file/segment2/AE321C",
"/NTORRENT/linux15.01",
{"/NTORRENT/linux15.01/file0/1A2B3C4D",
"/NTORRENT/linux15.01/file1/2A3B4C5E"});
@@ -289,6 +299,137 @@
BOOST_AUTO_TEST_SUITE_END()
+BOOST_AUTO_TEST_CASE(TestTorrentFileGenerator)
+{
+ const struct {
+ size_t d_dataPacketSize;
+ size_t d_subManifestSize;
+ const char *d_directoryPath;
+ size_t d_namesPerSegment;
+ bool d_shouldThrow;
+ } DATA [] = {
+ // Affirmative tests
+ {1024 , 100 , "tests/testdata/foo" , 1, false },
+ {512 , 80 , "tests/testdata/foo" , 3, false },
+ {256 , 50 , "tests/testdata/foo" , 2, false },
+ {2048 , 20 , "tests/testdata/foo" , 4, false },
+ {512 , 80 , "tests/testdata/foo" , 1, false },
+ {1024 , 50 , "tests/testdata/foo" , 1, false },
+ {2048 , 128 , "tests/testdata/foo", 2, false },
+ // Negative tests
+ // non-existent directory
+ {128 , 128 , "tests/testdata/foo-fake", 2, true },
+ };
+ enum { NUM_DATA = sizeof DATA / sizeof *DATA };
+ for (int i = 0; i < NUM_DATA; ++i) {
+ auto dataPacketSize = DATA[i].d_dataPacketSize;
+ auto subManifestSize = DATA[i].d_subManifestSize;
+ auto directoryPath = DATA[i].d_directoryPath;
+ auto namesPerSegment = DATA[i].d_namesPerSegment;
+ auto shouldThrow = DATA[i].d_shouldThrow;
+
+
+ std::pair<std::vector<TorrentFile>,
+ std::vector<std::pair<std::vector<FileManifest>,
+ std::vector<Data>>>> torrentFilePair1;
+
+ std::pair<std::vector<TorrentFile>,
+ std::vector<std::pair<std::vector<FileManifest>,
+ std::vector<Data>>>> torrentFilePair2;
+
+ if (shouldThrow) {
+ BOOST_REQUIRE_THROW(TorrentFile::generate(directoryPath,
+ namesPerSegment,
+ subManifestSize,
+ dataPacketSize),
+ TorrentFile::Error);
+
+ BOOST_REQUIRE_THROW(TorrentFile::generate(directoryPath,
+ namesPerSegment,
+ subManifestSize,
+ dataPacketSize,
+ true),
+ TorrentFile::Error);
+ }
+ else {
+ torrentFilePair1 = TorrentFile::generate(directoryPath,
+ namesPerSegment,
+ subManifestSize,
+ dataPacketSize);
+
+ torrentFilePair2 = TorrentFile::generate(directoryPath,
+ namesPerSegment,
+ subManifestSize,
+ dataPacketSize,
+ true);
+
+ auto torrentFileSegments = torrentFilePair1.first;
+ auto manifestPairs1 = torrentFilePair1.second;
+ auto manifestPairs2 = torrentFilePair2.second;
+
+ // Check that generate has not returned any data packets unless otherwise specified
+ for (auto i = manifestPairs1.begin(); i != manifestPairs1.end(); ++i) {
+ BOOST_CHECK_EQUAL((*i).second.size(), 0);
+ }
+
+ Name directoryPathName(directoryPath);
+ fs::recursive_directory_iterator directoryPtr(fs::system_complete(directoryPath).string());
+ int numberOfDirectoryFiles = 0;
+ for (fs::recursive_directory_iterator i = directoryPtr;
+ i != fs::recursive_directory_iterator(); ++i) {
+ numberOfDirectoryFiles++;
+ }
+ // Verify the basic attributes of the torrent-file
+ for (auto it = torrentFileSegments.begin(); it != torrentFileSegments.end(); ++it) {
+ // Verify that each file torrent-file is signed
+ BOOST_CHECK_NO_THROW(it->getFullName());
+ BOOST_CHECK_EQUAL(it->getCommonPrefix(),
+ Name("/NTORRENT" +
+ directoryPathName.getSubName(
+ directoryPathName.size() - 1).toUri()));
+ if (it != torrentFileSegments.end() - 1) {
+ BOOST_CHECK_EQUAL(it->getCatalog().size(), namesPerSegment);
+ BOOST_CHECK_EQUAL(*(it->getTorrentFilePtr()), (it+1)->getFullName());
+ }
+ else {
+ BOOST_CHECK_LE(it->getCatalog().size(), subManifestSize);
+ BOOST_CHECK(!(it->getTorrentFilePtr()));
+ }
+ }
+ int myDiv = (numberOfDirectoryFiles / namesPerSegment);
+ if (numberOfDirectoryFiles % namesPerSegment == 0) {
+ BOOST_CHECK_EQUAL(torrentFileSegments.size(), myDiv);
+ }
+ else {
+ BOOST_CHECK_EQUAL(torrentFileSegments.size(), (myDiv + 1));
+ }
+
+ std::vector<uint8_t> dataBytes;
+ for (auto i = manifestPairs2.begin() ; i != manifestPairs2.end(); ++i) {
+ for (auto d : (*i).second) {
+ auto content = d.getContent();
+ dataBytes.insert(dataBytes.end(), content.value_begin(), content.value_end());
+ }
+ }
+ // load the contents of the directory files from disk
+ std::vector<uint8_t> directoryFilesBytes;
+ fs::recursive_directory_iterator directoryPtr2(fs::system_complete(directoryPath).string());
+ for (fs::recursive_directory_iterator i = directoryPtr2;
+ i != fs::recursive_directory_iterator();
+ ++i) {
+ fs::ifstream is((*i), fs::ifstream::binary | fs::ifstream::in);
+ is >> std::noskipws;
+ std::istream_iterator<uint8_t> start(is), end;
+ std::vector<uint8_t> fileBytes(start, end);
+ directoryFilesBytes.insert(directoryFilesBytes.end(), fileBytes.begin(), fileBytes.end());
+ }
+ // confirm that they are equal
+ BOOST_CHECK_EQUAL_COLLECTIONS(directoryFilesBytes.begin(), directoryFilesBytes.end(),
+ dataBytes.begin(), dataBytes.end());
+ }
+ }
+}
+
} // namespace tests
} // namespace ntorrent