Files
rippled/include/xrpl/basics
Denis Angell 9294479a8a Merge remote-tracking branch 'origin/develop' into dangell7/docs
# Conflicts:
#	include/xrpl/protocol/STParsedJSON.h
#	include/xrpl/shamap/SHAMapTreeNode.h
#	src/libxrpl/ledger/helpers/TokenHelpers.cpp
#	src/libxrpl/protocol/STIssue.cpp
#	src/libxrpl/protocol/STParsedJSON.cpp
#	src/libxrpl/shamap/SHAMapTreeNode.cpp
#	src/libxrpl/tx/invariants/PermissionedDEXInvariant.cpp
#	src/libxrpl/tx/transactors/nft/NFTokenAcceptOffer.cpp
#	src/libxrpl/tx/transactors/vault/VaultWithdraw.cpp
#	src/xrpld/rpc/detail/Role.cpp
#	src/xrpld/rpc/detail/TransactionSign.cpp
#	src/xrpld/rpc/handlers/account/AccountObjects.cpp
2026-05-14 08:59:49 +02:00
..
2026-05-13 23:01:44 +02:00
2026-05-11 15:39:48 +00:00

Basics

Utility functions and classes.

The module xrpl/basics should contain no dependencies on other modules.

Choosing an xrpld container.

  • std::vector

    • For ordered containers with most insertions or erases at the end.
  • std::deque

    • For ordered containers with most insertions or erases at the start or end.
  • std::list

    • For ordered containers with inserts and erases to the middle.
    • For containers with iterators stable over insert and erase.
    • Generally slower and bigger than std::vector or std::deque except for those cases.
  • std::set

    • For sorted containers.
  • xrpl::hash_set

    • Where inserts and contains need to be O(1).
    • For "small" sets, std::set might be faster and smaller.
  • xrpl::hardened_hash_set

The following container is deprecated

  • std::unordered_set
  • Use xrpl::hash_set instead, which uses a better hashing algorithm.
  • Or use xrpl::hardened_hash_set to prevent algorithmic complexity attacks.