Files
rippled/include/xrpl/protocol
Ed Hennis da1cb2d7ce Merge remote-tracking branch 'upstream/develop' into ximinez/loanpay-assertion
* upstream/develop: (149 commits)
  fix: Fix previous ledger size typo in RCLConsensus (6696)
  chore: Enable clang-tidy misc checks (6655)
  ci: Use pull_request_target to check for signed commits (6697)
  chore: Remove unnecessary clang-format off/on directives (6682)
  fix: Fix Workers::stop() race between m_allPaused and m_runningTaskCount (6574)
  ci: Only publish docs in public repos (6687)
  chore: Enable remaining clang-tidy `performance` checks (6648)
  refactor: Address PR comments after the modularisation PRs (6389)
  chore: Fix clang-tidy header filter (6686)
  ci: [DEPENDABOT] bump actions/deploy-pages from 4.0.5 to 5.0.0 (6684)
  ci: [DEPENDABOT] bump codecov/codecov-action from 5.5.3 to 6.0.0 (6685)
  fix: Guard Coro::resume() against completed coroutines (6608)
  refactor: Split LoanInvariant into LoanBrokerInvariant and LoanInvariant (6674)
  ci: Don't publish docs on release branches (6673)
  refactor: Make function naming in ServiceRegistry consistent (6390)
  chore: Shorten job names to stay within Linux 15-char thread limit (6669)
  fix: Improve loan invariant message (6668)
  ci: Upload artifacts only in public repositories (6670)
  ci: Add conflicting-pr workflow (6656)
  chore: Add more AI tools to .gitignore (6658)
  ...
2026-03-31 18:54:27 -04:00
..
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-25 16:32:45 +00:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00
2026-03-31 18:44:32 -04:00

protocol

Classes and functions for handling data and values associated with the XRP Ledger protocol.

Serialized Objects

Objects transmitted over the network must be serialized into a canonical format. The prefix "ST" refers to classes that deal with the serialized format.

The term "Tx" or "tx" is an abbreviation for "Transaction", a commonly occurring object type.

Optional Fields

Our serialized fields have some "type magic" to make optional fields easier to read:

  • The operation x[sfFoo] means "return the value of 'Foo' if it exists, or the default value if it doesn't."
  • The operation x[~sfFoo] means "return the value of 'Foo' if it exists, or nothing if it doesn't." This usage of the tilde/bitwise NOT operator is not standard outside of the rippled codebase.
    • As a consequence of this, x[~sfFoo] = y[~sfFoo] assigns the value of Foo from y to x, including omitting Foo from x if it doesn't exist in y.

Typically, for things that are guaranteed to exist, you use x[sfFoo] and avoid having to deal with a container that may or may not hold a value. For things not guaranteed to exist, you use x[~sfFoo] because you want such a container. It avoids having to look something up twice, once just to see if it exists and a second time to get/set its value. (Real example)

The source of this "type magic" is in SField.h.