Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Update copyright lines.
[simgrid.git] / examples / s4u / app-bittorrent / s4u-tracker.cpp
1 /* Copyright (c) 2012-2021. The SimGrid Team.
2  * All rights reserved.                                                     */
3
4 /* This program is free software; you can redistribute it and/or modify it
5  * under the terms of the license (GNU LGPL) which comes with this package. */
6
7 #include "s4u-tracker.hpp"
8 #include <algorithm>
9
10 XBT_LOG_NEW_DEFAULT_CATEGORY(s4u_bt_tracker, "Messages specific for the tracker");
11
12 Tracker::Tracker(std::vector<std::string> args)
13 {
14   // Checking arguments
15   xbt_assert(args.size() == 2, "Wrong number of arguments for the tracker.");
16   // Retrieving end time
17   try {
18     deadline = std::stod(args[1]);
19   } catch (const std::invalid_argument&) {
20     throw std::invalid_argument("Invalid deadline:" + args[1]);
21   }
22   xbt_assert(deadline > 0, "Wrong deadline supplied");
23
24   mailbox = simgrid::s4u::Mailbox::by_name(TRACKER_MAILBOX);
25
26   XBT_INFO("Tracker launched.");
27 }
28
29 void Tracker::operator()()
30 {
31   simgrid::s4u::CommPtr comm = nullptr;
32   TrackerQuery* query        = nullptr;
33   while (simgrid::s4u::Engine::get_clock() < deadline) {
34     if (comm == nullptr)
35       comm = mailbox->get_async<TrackerQuery>(&query);
36     if (comm->test()) {
37       // Retrieve the data sent by the peer.
38       xbt_assert(query != nullptr);
39
40       // Add the peer to our peer list, if not already known.
41       if (known_peers.find(query->getPeerId()) == known_peers.end()) {
42         known_peers.insert(query->getPeerId());
43       }
44
45       // Sending back peers to the requesting peer
46       auto* answer = new TrackerAnswer(TRACKER_QUERY_INTERVAL);
47       std::set<int>::iterator next_peer;
48       int nb_known_peers = static_cast<int>(known_peers.size());
49       int max_tries      = std::min(MAXIMUM_PEERS, nb_known_peers);
50       int tried          = 0;
51       while (tried < max_tries) {
52         do {
53           next_peer = known_peers.begin();
54           std::advance(next_peer, random.uniform_int(0, nb_known_peers - 1));
55         } while (answer->getPeers().find(*next_peer) != answer->getPeers().end());
56         answer->addPeer(*next_peer);
57         tried++;
58       }
59       query->getReturnMailbox()->put_init(answer, TRACKER_COMM_SIZE)->detach();
60
61       delete query;
62       comm = nullptr;
63     } else {
64       simgrid::s4u::this_actor::sleep_for(1);
65     }
66   }
67   XBT_INFO("Tracker is leaving");
68 }