docs: Wrong/outdated docs for tr(KEY) in doc/descriptors.md #30279

issue benma openend this issue on June 12, 2024
  1. benma commented at 8:49 pm on June 12, 2024: none

    Bitcoin Core uses BIP-386 for tr(...) descriptors, and in the case of tr(KEY), the produced key is tweaked according to BIP-341:

    https://github.com/bitcoin/bips/blob/85cda4e225b4d5fd7aff403f69d827f23f6afbbc/bip-0341.mediawiki?plain=1#L156

    In the current descriptors.md, it is documented that tr(KEY) uses KEY as the internal key, with no further comment:

    https://github.com/bitcoin/bitcoin/blob/a7bc9b76e73f04dfe4d6ba42033fe38659090e8b/doc/descriptors.md?plain=1#L82

    By looking only at descriptors.md without knowledge or reference to BIP-386, one can interpret tr(KEY) to use KEY directly without tweaking.

    Ideally the docs should be expanded to reference BIP-386.

  2. achow101 commented at 9:27 pm on June 12, 2024: member

    I thought the phrase “internal key” is unambiguous to mean that the key will need tweaking, as that is how BIP 341 defines that phrase.

    It might make sense to remove descriptors.md since it’s ostensibly superseded by the BIPs too.

  3. benma commented at 12:35 pm on June 13, 2024: none

    I for one was confused. Imo being explicit is better than being implicit. “internal key” is ambiguous to me, as it means it is untweaked, but it does not mean it must be tweaked. BIP-341 merely says “should”.

    Removing the descriptors.md in in favor of BIPs is not optimal, because:

    • the BIPs are not the docs for Bitcoin Core - Bitcoin Core should document itself what it supports
    • it is hard to get an overview of what is supported in Bitcoin Core by scrolling BIPs

    I think the best would be to complete the docs and link to the relevant BIPs. In this particular issue, linking to BIP-386 for tr(...) descriptors and mentioning that tr(KEY) uses the tweak described in BIP-341 would make the docs here much more useful.

    Other parts are also not up to date, like the support for miniscript expressions for SCRIPT. There it would also be great to expand the docs and link to https://bitcoin.sipa.be/miniscript/ (afaik there is no BIP for that).

  4. pythcoiner commented at 11:48 am on June 18, 2024: none

    There it would also be great to expand the docs and link to https://bitcoin.sipa.be/miniscript/ (afaik there is no BIP for that).

    There is re recent PR in BIP repo.

  5. sipa commented at 11:50 am on June 18, 2024: member
    I agree with @benma. I think we should make the descriptors.md file more explicit, but also link to the relevant BIPs now.
  6. willcl-ark added the label Docs on Jun 26, 2024
  7. willcl-ark added the label Descriptors on Jun 26, 2024

github-metadata-mirror

This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2024-12-21 15:12 UTC

This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me