Extract core stuff into own crates
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`).
2019-11-26 03:30:48 +01:00
|
|
|
[package]
|
2020-04-06 09:16:14 +02:00
|
|
|
authors = ["The Nu Project Contributors"]
|
2020-04-21 20:34:32 +02:00
|
|
|
description = "Nushell parser"
|
2020-07-05 22:12:44 +02:00
|
|
|
edition = "2018"
|
2020-04-21 20:34:32 +02:00
|
|
|
license = "MIT"
|
2020-07-05 22:12:44 +02:00
|
|
|
name = "nu-parser"
|
2021-08-03 10:01:09 +02:00
|
|
|
version = "0.35.0"
|
Extract core stuff into own crates
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`).
2019-11-26 03:30:48 +01:00
|
|
|
|
|
|
|
[dependencies]
|
2021-06-22 07:22:33 +02:00
|
|
|
bigdecimal = { version="0.2.0", features=["serde"] }
|
2021-01-07 01:38:22 +01:00
|
|
|
codespan-reporting = "0.11.0"
|
2020-07-05 22:12:44 +02:00
|
|
|
derive-new = "0.5.8"
|
2021-01-11 19:50:53 +01:00
|
|
|
derive_is_enum_variant = "0.1.1"
|
2021-06-22 07:22:33 +02:00
|
|
|
indexmap = { version="1.6.1", features=["serde-1"] }
|
2021-02-05 21:54:54 +01:00
|
|
|
log = "0.4"
|
2021-06-22 07:22:33 +02:00
|
|
|
num-bigint = { version="0.3.1", features=["serde"] }
|
2021-01-07 04:03:00 +01:00
|
|
|
num-traits = "0.2.14"
|
2021-02-05 21:54:54 +01:00
|
|
|
serde = "1.0"
|
2021-02-04 08:20:21 +01:00
|
|
|
itertools = "0.10.0"
|
|
|
|
smart-default = "0.6.0"
|
2019-12-02 22:14:51 +01:00
|
|
|
|
2021-01-11 18:53:58 +01:00
|
|
|
dunce = "1.0.1"
|
2021-08-03 10:01:09 +02:00
|
|
|
nu-errors = { version = "0.35.0", path="../nu-errors" }
|
|
|
|
nu-path = { version = "0.35.0", path="../nu-path" }
|
|
|
|
nu-protocol = { version = "0.35.0", path="../nu-protocol" }
|
|
|
|
nu-source = { version = "0.35.0", path="../nu-source" }
|
|
|
|
nu-test-support = { version = "0.35.0", path="../nu-test-support" }
|
2019-12-03 01:34:33 +01:00
|
|
|
|
|
|
|
[features]
|
2019-12-12 06:56:12 +01:00
|
|
|
stable = []
|