ord 0.27.1

◉ Ordinal wallet and block explorer
Documentation
use super::*;

#[derive(Serialize)]
struct Label {
  first_sat: SatLabel,
  inscriptions: BTreeMap<u64, BTreeSet<InscriptionId>>,
}

#[derive(Serialize)]
struct SatLabel {
  name: String,
  number: u64,
  rarity: Rarity,
}

#[derive(Serialize)]
struct Line {
  label: String,
  r#ref: String,
  r#type: String,
}

pub(crate) fn run(wallet: Wallet) -> SubcommandResult {
  let mut lines: Vec<Line> = Vec::new();

  let sat_ranges = wallet.get_wallet_sat_ranges()?;

  let mut inscriptions_by_output: BTreeMap<OutPoint, BTreeMap<u64, Vec<InscriptionId>>> =
    BTreeMap::new();

  for (satpoint, inscriptions) in wallet.inscriptions() {
    inscriptions_by_output
      .entry(satpoint.outpoint)
      .or_default()
      .insert(satpoint.offset, inscriptions.clone());
  }

  for (output, ranges) in sat_ranges {
    let sat = Sat(ranges[0].0);
    let mut inscriptions = BTreeMap::<u64, BTreeSet<InscriptionId>>::new();

    if let Some(output_inscriptions) = inscriptions_by_output.get(&output) {
      for (&offset, offset_inscriptions) in output_inscriptions {
        inscriptions
          .entry(offset)
          .or_default()
          .extend(offset_inscriptions);
      }
    }

    lines.push(Line {
      label: serde_json::to_string(&Label {
        first_sat: SatLabel {
          name: sat.name(),
          number: sat.n(),
          rarity: sat.rarity(),
        },
        inscriptions,
      })?,
      r#ref: output.to_string(),
      r#type: "output".into(),
    });
  }

  for line in lines {
    serde_json::to_writer(io::stdout(), &line)?;
    println!();
  }

  Ok(None)
}