allow tables to have annotations (#9613)

# Description

follow up to #8529 and #8914

this works very similarly to record annotations, only difference being
that

```sh
table<name: string>
      ^^^^  ^^^^^^
      |     | 
      |     represents the type of the items in that column
      |
      represents the column name
```
more info on the syntax can be found
[here](https://github.com/nushell/nushell/pull/8914#issue-1672113520)

# User-Facing Changes

**[BREAKING CHANGE]**
this change adds a field to `SyntaxShape::Table` so any plugins that
used it will have to update and include the field. though if you are
unsure of the type the table expects, `SyntaxShape::Table(vec![])` will
suffice
This commit is contained in:
mike
2023-07-07 12:06:09 +03:00
committed by GitHub
parent 440a0e960a
commit 8e38596bc9
25 changed files with 343 additions and 153 deletions

View File

@@ -38,7 +38,7 @@ impl Command for SubCommand {
])
.named(
"columns",
SyntaxShape::Table,
SyntaxShape::Table(vec![]),
"For a record or table input, convert strings in the given columns to their basename",
Some('c'),
)

View File

@@ -35,7 +35,7 @@ impl Command for SubCommand {
.input_output_types(vec![(Type::String, Type::String)])
.named(
"columns",
SyntaxShape::Table,
SyntaxShape::Table(vec![]),
"For a record or table input, convert strings at the given columns to their dirname",
Some('c'),
)

View File

@@ -34,7 +34,7 @@ impl Command for SubCommand {
.input_output_types(vec![(Type::String, Type::Bool)])
.named(
"columns",
SyntaxShape::Table,
SyntaxShape::Table(vec![]),
"For a record or table input, check strings at the given columns, and replace with result",
Some('c'),
)

View File

@@ -43,7 +43,7 @@ impl Command for SubCommand {
.switch("no-symlink", "Do not resolve symbolic links", Some('n'))
.named(
"columns",
SyntaxShape::Table,
SyntaxShape::Table(vec![]),
"For a record or table input, expand strings at the given columns",
Some('c'),
)

View File

@@ -39,7 +39,7 @@ impl Command for SubCommand {
])
.named(
"columns",
SyntaxShape::Table,
SyntaxShape::Table(vec![]),
"For a record or table input, join strings at the given columns",
Some('c'),
)

View File

@@ -35,7 +35,7 @@ impl Command for SubCommand {
.input_output_types(vec![(Type::String, Type::Record(vec![]))])
.named(
"columns",
SyntaxShape::Table,
SyntaxShape::Table(vec![]),
"For a record or table input, convert strings at the given columns",
Some('c'),
)

View File

@@ -40,7 +40,7 @@ impl Command for SubCommand {
)
.named(
"columns",
SyntaxShape::Table,
SyntaxShape::Table(vec![]),
"For a record or table input, convert strings at the given columns",
Some('c'),
)

View File

@@ -32,7 +32,7 @@ impl Command for SubCommand {
.input_output_types(vec![(Type::String, Type::List(Box::new(Type::String)))])
.named(
"columns",
SyntaxShape::Table,
SyntaxShape::Table(vec![]),
"For a record or table input, split strings at the given columns",
Some('c'),
)

View File

@@ -32,7 +32,7 @@ impl Command for SubCommand {
.input_output_types(vec![(Type::String, Type::String)])
.named(
"columns",
SyntaxShape::Table,
SyntaxShape::Table(vec![]),
"For a record or table input, check strings at the given columns, and replace with result",
Some('c'),
)