forked from extern/nushell
This commit extracts five new crates: - nu-source, which contains the core source-code handling logic in Nu, including Text, Span, and also the pretty.rs-based debug logic - nu-parser, which is the parser and expander logic - nu-protocol, which is the bulk of the types and basic conveniences used by plugins - nu-errors, which contains ShellError, ParseError and error handling conveniences - nu-textview, which is the textview plugin extracted into a crate One of the major consequences of this refactor is that it's no longer possible to `impl X for Spanned<Y>` outside of the `nu-source` crate, so a lot of types became more concrete (Value became a concrete type instead of Spanned<Value>, for example). This also turned a number of inherent methods in the main nu crate into plain functions (impl Value {} became a bunch of functions in the `value` namespace in `crate::data::value`).
39 lines
944 B
Rust
39 lines
944 B
Rust
#![allow(unused)]
|
|
|
|
pub(crate) mod color_trace;
|
|
pub(crate) mod expand_trace;
|
|
|
|
pub(crate) use self::color_trace::*;
|
|
pub(crate) use self::expand_trace::*;
|
|
|
|
use crate::hir::tokens_iterator::TokensIteratorState;
|
|
use nu_source::{PrettyDebug, PrettyDebugWithSource, Text};
|
|
|
|
#[derive(Debug)]
|
|
pub(crate) enum DebugIteratorToken {
|
|
Seen(String),
|
|
Unseen(String),
|
|
Cursor,
|
|
}
|
|
|
|
pub(crate) fn debug_tokens(state: &TokensIteratorState, source: &str) -> Vec<DebugIteratorToken> {
|
|
let mut out = vec![];
|
|
|
|
for (i, token) in state.tokens.iter().enumerate() {
|
|
if state.index == i {
|
|
out.push(DebugIteratorToken::Cursor);
|
|
}
|
|
|
|
if state.seen.contains(&i) {
|
|
out.push(DebugIteratorToken::Seen(format!("{}", token.debug(source))));
|
|
} else {
|
|
out.push(DebugIteratorToken::Unseen(format!(
|
|
"{}",
|
|
token.debug(source)
|
|
)));
|
|
}
|
|
}
|
|
|
|
out
|
|
}
|