Node.c 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. /* vim: set expandtab ts=4 sw=4: */
  2. /*
  3. * You may redistribute this program and/or modify it under the terms of
  4. * the GNU General Public License as published by the Free Software Foundation,
  5. * either version 3 of the License, or (at your option) any later version.
  6. *
  7. * This program is distributed in the hope that it will be useful,
  8. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. * GNU General Public License for more details.
  11. *
  12. * You should have received a copy of the GNU General Public License
  13. * along with this program. If not, see <https://www.gnu.org/licenses/>.
  14. */
  15. #include "dht/dhtcore/Node.h"
  16. #include "switch/EncodingScheme.h"
  17. #include "util/Assert.h"
  18. #include "util/Bits.h"
  19. bool Node_isAncestorOf(struct Node_Two* ancestor, struct Node_Two* child)
  20. {
  21. struct Node_Two* nn = child;
  22. for (;;) {
  23. if (nn == ancestor) { return true; }
  24. struct Node_Link* next = Node_getBestParent(nn);
  25. if (!next || next->parent == nn) { return false; }
  26. nn = next->parent;
  27. }
  28. }
  29. void Node_setParentCostAndPath(struct Node_Two* node,
  30. struct Node_Link* bestParent,
  31. uint64_t cost,
  32. uint64_t path)
  33. {
  34. if (bestParent) {
  35. Assert_true(bestParent->child == node);
  36. Assert_true(cost != UINT64_MAX);
  37. Assert_true(path != UINT64_MAX);
  38. if (bestParent->parent == node) {
  39. Assert_true(cost == 0);
  40. Assert_true(path == 1);
  41. } else {
  42. Assert_true(!Node_isAncestorOf(node, bestParent->parent));
  43. }
  44. } else {
  45. Assert_true(cost == UINT64_MAX);
  46. Assert_true(path == UINT64_MAX);
  47. }
  48. node->bestParent_pvt = bestParent;
  49. node->cost_pvt = cost;
  50. node->address.path = path;
  51. }
  52. bool Node_isOneHopLink(struct Node_Link* link)
  53. {
  54. struct EncodingScheme* ps = link->parent->encodingScheme;
  55. int num = EncodingScheme_getFormNum(ps, link->cannonicalLabel);
  56. Assert_true(num > -1 && num < ps->count);
  57. return EncodingScheme_formSize(&ps->forms[num]) == Bits_log2x64(link->cannonicalLabel);
  58. }